From 794bb0224935e32bbe5f2863140c10860fad4f96 Mon Sep 17 00:00:00 2001 From: MadameSheema Date: Sun, 12 Jan 2020 12:25:19 +0100 Subject: [PATCH 001/139] logs in one time (#54447) --- .../smoke_tests/pagination/pagination.spec.ts | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/x-pack/legacy/plugins/siem/cypress/integration/smoke_tests/pagination/pagination.spec.ts b/x-pack/legacy/plugins/siem/cypress/integration/smoke_tests/pagination/pagination.spec.ts index 73711f1434d5f..3853e703a7c07 100644 --- a/x-pack/legacy/plugins/siem/cypress/integration/smoke_tests/pagination/pagination.spec.ts +++ b/x-pack/legacy/plugins/siem/cypress/integration/smoke_tests/pagination/pagination.spec.ts @@ -18,9 +18,16 @@ import { import { DEFAULT_TIMEOUT, loginAndWaitForPage, waitForTableLoad } from '../../lib/util/helpers'; describe('Pagination', () => { - it('pagination updates results and page number', () => { + before(() => { loginAndWaitForPage(HOSTS_PAGE_TAB_URLS.uncommonProcesses); waitForTableLoad(UNCOMMON_PROCCESSES_TABLE); + }); + + afterEach(() => { + cy.get(getPageButtonSelector(0)).click({ force: true }); + }); + + it('pagination updates results and page number', () => { cy.get(getPageButtonSelector(0)).should('have.class', 'euiPaginationButton-isActive'); cy.get(getDraggableField('process.name')) @@ -42,8 +49,6 @@ describe('Pagination', () => { }); it('pagination keeps track of page results when tabs change', () => { - loginAndWaitForPage(HOSTS_PAGE_TAB_URLS.uncommonProcesses); - waitForTableLoad(UNCOMMON_PROCCESSES_TABLE); cy.get(getPageButtonSelector(0)).should('have.class', 'euiPaginationButton-isActive'); let thirdPageResult: string; cy.get(getPageButtonSelector(2)).click({ force: true }); @@ -78,7 +83,6 @@ describe('Pagination', () => { * when we figure out a way to really mock the data, we should come back to it */ it('pagination resets results and page number to first page when refresh is clicked', () => { - loginAndWaitForPage(HOSTS_PAGE_TAB_URLS.uncommonProcesses); cy.get(NUMBERED_PAGINATION, { timeout: DEFAULT_TIMEOUT }); cy.get(getPageButtonSelector(0)).should('have.class', 'euiPaginationButton-isActive'); // let firstResult: string; From aeebedfa4d05b08dd89aef7f1c1cfb49dac4f0be Mon Sep 17 00:00:00 2001 From: Pierre Gayvallet Date: Sun, 12 Jan 2020 22:37:42 +0100 Subject: [PATCH 002/139] Add ApplicationService app status management (#50223) * add unimplemented registerAppStatusUpdater & remove observers for apps and legacyApps * adapt NavLinksService to use new application observables * merge availableApps$ and availableLegacyApps$ * updating core docs * adapt the navLink updating methods * filters the inaccessible apps from availableApps$ * restrict access to navigateToApp depending on app status * fixes due to merge * add statusUpdater$ to AppBase * export new types * disable navlink depending on app status * update generated doc * update snapshots for disabled prop * Address josh review * Address review comments * fix merge conflicts * adapt changes due to merge * update generated doc * add comment and fix navlink url for custom url apps * add AppNavLinkStatus type to split app/navlink states * fix typo * review comments and improvements * add functional tests * update generated docs and migration guide * fix wrong type cast on AppsMenuProvider.readLinks * properly type return of navigateToApp --- ...kibana-plugin-public.appbase.chromeless.md | 13 + .../public/kibana-plugin-public.appbase.id.md | 2 + .../public/kibana-plugin-public.appbase.md | 8 +- ...ana-plugin-public.appbase.navlinkstatus.md | 13 + ...=> kibana-plugin-public.appbase.status.md} | 8 +- .../kibana-plugin-public.appbase.tooltip.md | 13 + .../kibana-plugin-public.appbase.updater_.md | 44 ++ .../kibana-plugin-public.applicationsetup.md | 1 + ...lic.applicationsetup.registerappupdater.md | 47 ++ .../kibana-plugin-public.appnavlinkstatus.md | 23 + .../public/kibana-plugin-public.appstatus.md | 21 + ...kibana-plugin-public.appupdatablefields.md | 13 + .../public/kibana-plugin-public.appupdater.md | 13 + .../core/public/kibana-plugin-public.md | 298 ++++++------ src/core/MIGRATION.md | 29 ++ .../application/application_service.mock.ts | 9 +- .../application/application_service.test.ts | 423 ++++++++++++++---- .../application/application_service.tsx | 129 +++++- src/core/public/application/index.ts | 4 + src/core/public/application/types.ts | 166 ++++++- src/core/public/chrome/chrome_service.test.ts | 9 +- src/core/public/chrome/chrome_service.tsx | 13 +- .../nav_links/nav_links_service.test.ts | 124 +++-- .../chrome/nav_links/nav_links_service.ts | 79 ++-- .../chrome/nav_links/to_nav_link.test.ts | 178 ++++++++ .../public/chrome/nav_links/to_nav_link.ts | 48 ++ src/core/public/chrome/ui/header/header.tsx | 2 +- src/core/public/index.ts | 4 + src/core/public/legacy/legacy_service.ts | 1 + .../toasts/global_toast_list.test.tsx | 4 +- src/core/public/plugins/plugin_context.ts | 1 + src/core/public/public.api.md | 30 +- test/functional/services/apps_menu.ts | 11 +- .../plugins/core_app_status/kibana.json | 8 + .../plugins/core_app_status/package.json | 17 + .../core_app_status/public/application.tsx | 64 +++ .../plugins/core_app_status/public/index.ts | 24 + .../plugins/core_app_status/public/plugin.tsx | 56 +++ .../plugins/core_app_status/tsconfig.json | 14 + .../core_plugins/application_status.ts | 116 +++++ .../test_suites/core_plugins/index.ts | 1 + .../advanced_settings_security.ts | 12 +- .../advanced_settings_spaces.ts | 4 +- .../apps/apm/feature_controls/apm_security.ts | 13 +- .../apps/apm/feature_controls/apm_spaces.ts | 8 +- .../feature_controls/canvas_security.ts | 8 +- .../canvas/feature_controls/canvas_spaces.ts | 8 +- .../feature_controls/dashboard_security.ts | 9 +- .../feature_controls/dashboard_spaces.ts | 8 +- .../feature_controls/dev_tools_security.ts | 9 +- .../feature_controls/dev_tools_spaces.ts | 8 +- .../feature_controls/discover_security.ts | 9 +- .../feature_controls/discover_spaces.ts | 8 +- .../feature_controls/endpoint_spaces.ts | 8 +- .../graph/feature_controls/graph_security.ts | 13 +- .../graph/feature_controls/graph_spaces.ts | 8 +- .../index_patterns_security.ts | 12 +- .../feature_controls/index_patterns_spaces.ts | 4 +- .../infrastructure_security.ts | 12 +- .../feature_controls/infrastructure_spaces.ts | 8 +- .../infra/feature_controls/logs_security.ts | 12 +- .../infra/feature_controls/logs_spaces.ts | 8 +- .../feature_controls/ml_security.ts | 8 +- .../feature_controls/ml_spaces.ts | 8 +- .../maps/feature_controls/maps_security.ts | 12 +- .../apps/maps/feature_controls/maps_spaces.ts | 4 +- .../feature_controls/monitoring_security.ts | 8 +- .../feature_controls/monitoring_spaces.ts | 8 +- .../feature_controls/spaces_security.ts | 8 +- .../feature_controls/timelion_security.ts | 8 +- .../feature_controls/timelion_spaces.ts | 8 +- .../feature_controls/uptime_security.ts | 13 +- .../uptime/feature_controls/uptime_spaces.ts | 8 +- .../feature_controls/visualize_security.ts | 8 +- .../feature_controls/visualize_spaces.ts | 8 +- 75 files changed, 1798 insertions(+), 581 deletions(-) create mode 100644 docs/development/core/public/kibana-plugin-public.appbase.chromeless.md create mode 100644 docs/development/core/public/kibana-plugin-public.appbase.navlinkstatus.md rename docs/development/core/public/{kibana-plugin-public.appbase.tooltip_.md => kibana-plugin-public.appbase.status.md} (56%) create mode 100644 docs/development/core/public/kibana-plugin-public.appbase.tooltip.md create mode 100644 docs/development/core/public/kibana-plugin-public.appbase.updater_.md create mode 100644 docs/development/core/public/kibana-plugin-public.applicationsetup.registerappupdater.md create mode 100644 docs/development/core/public/kibana-plugin-public.appnavlinkstatus.md create mode 100644 docs/development/core/public/kibana-plugin-public.appstatus.md create mode 100644 docs/development/core/public/kibana-plugin-public.appupdatablefields.md create mode 100644 docs/development/core/public/kibana-plugin-public.appupdater.md create mode 100644 src/core/public/chrome/nav_links/to_nav_link.test.ts create mode 100644 src/core/public/chrome/nav_links/to_nav_link.ts create mode 100644 test/plugin_functional/plugins/core_app_status/kibana.json create mode 100644 test/plugin_functional/plugins/core_app_status/package.json create mode 100644 test/plugin_functional/plugins/core_app_status/public/application.tsx create mode 100644 test/plugin_functional/plugins/core_app_status/public/index.ts create mode 100644 test/plugin_functional/plugins/core_app_status/public/plugin.tsx create mode 100644 test/plugin_functional/plugins/core_app_status/tsconfig.json create mode 100644 test/plugin_functional/test_suites/core_plugins/application_status.ts diff --git a/docs/development/core/public/kibana-plugin-public.appbase.chromeless.md b/docs/development/core/public/kibana-plugin-public.appbase.chromeless.md new file mode 100644 index 0000000000000..ddbf9aafbd28a --- /dev/null +++ b/docs/development/core/public/kibana-plugin-public.appbase.chromeless.md @@ -0,0 +1,13 @@ + + +[Home](./index.md) > [kibana-plugin-public](./kibana-plugin-public.md) > [AppBase](./kibana-plugin-public.appbase.md) > [chromeless](./kibana-plugin-public.appbase.chromeless.md) + +## AppBase.chromeless property + +Hide the UI chrome when the application is mounted. Defaults to `false`. Takes precedence over chrome service visibility settings. + +Signature: + +```typescript +chromeless?: boolean; +``` diff --git a/docs/development/core/public/kibana-plugin-public.appbase.id.md b/docs/development/core/public/kibana-plugin-public.appbase.id.md index 57daa0c94bdf6..89dd32d296104 100644 --- a/docs/development/core/public/kibana-plugin-public.appbase.id.md +++ b/docs/development/core/public/kibana-plugin-public.appbase.id.md @@ -4,6 +4,8 @@ ## AppBase.id property +The unique identifier of the application + Signature: ```typescript diff --git a/docs/development/core/public/kibana-plugin-public.appbase.md b/docs/development/core/public/kibana-plugin-public.appbase.md index a93a195c559b1..eb6d91cb92488 100644 --- a/docs/development/core/public/kibana-plugin-public.appbase.md +++ b/docs/development/core/public/kibana-plugin-public.appbase.md @@ -16,10 +16,14 @@ export interface AppBase | Property | Type | Description | | --- | --- | --- | | [capabilities](./kibana-plugin-public.appbase.capabilities.md) | Partial<Capabilities> | Custom capabilities defined by the app. | +| [chromeless](./kibana-plugin-public.appbase.chromeless.md) | boolean | Hide the UI chrome when the application is mounted. Defaults to false. Takes precedence over chrome service visibility settings. | | [euiIconType](./kibana-plugin-public.appbase.euiicontype.md) | string | A EUI iconType that will be used for the app's icon. This icon takes precendence over the icon property. | | [icon](./kibana-plugin-public.appbase.icon.md) | string | A URL to an image file used as an icon. Used as a fallback if euiIconType is not provided. | -| [id](./kibana-plugin-public.appbase.id.md) | string | | +| [id](./kibana-plugin-public.appbase.id.md) | string | The unique identifier of the application | +| [navLinkStatus](./kibana-plugin-public.appbase.navlinkstatus.md) | AppNavLinkStatus | The initial status of the application's navLink. Defaulting to visible if status is accessible and hidden if status is inaccessible See [AppNavLinkStatus](./kibana-plugin-public.appnavlinkstatus.md) | | [order](./kibana-plugin-public.appbase.order.md) | number | An ordinal used to sort nav links relative to one another for display. | +| [status](./kibana-plugin-public.appbase.status.md) | AppStatus | The initial status of the application. Defaulting to accessible | | [title](./kibana-plugin-public.appbase.title.md) | string | The title of the application. | -| [tooltip$](./kibana-plugin-public.appbase.tooltip_.md) | Observable<string> | An observable for a tooltip shown when hovering over app link. | +| [tooltip](./kibana-plugin-public.appbase.tooltip.md) | string | A tooltip shown when hovering over app link. | +| [updater$](./kibana-plugin-public.appbase.updater_.md) | Observable<AppUpdater> | An [AppUpdater](./kibana-plugin-public.appupdater.md) observable that can be used to update the application [AppUpdatableFields](./kibana-plugin-public.appupdatablefields.md) at runtime. | diff --git a/docs/development/core/public/kibana-plugin-public.appbase.navlinkstatus.md b/docs/development/core/public/kibana-plugin-public.appbase.navlinkstatus.md new file mode 100644 index 0000000000000..d6744c3e75756 --- /dev/null +++ b/docs/development/core/public/kibana-plugin-public.appbase.navlinkstatus.md @@ -0,0 +1,13 @@ + + +[Home](./index.md) > [kibana-plugin-public](./kibana-plugin-public.md) > [AppBase](./kibana-plugin-public.appbase.md) > [navLinkStatus](./kibana-plugin-public.appbase.navlinkstatus.md) + +## AppBase.navLinkStatus property + +The initial status of the application's navLink. Defaulting to `visible` if `status` is `accessible` and `hidden` if status is `inaccessible` See [AppNavLinkStatus](./kibana-plugin-public.appnavlinkstatus.md) + +Signature: + +```typescript +navLinkStatus?: AppNavLinkStatus; +``` diff --git a/docs/development/core/public/kibana-plugin-public.appbase.tooltip_.md b/docs/development/core/public/kibana-plugin-public.appbase.status.md similarity index 56% rename from docs/development/core/public/kibana-plugin-public.appbase.tooltip_.md rename to docs/development/core/public/kibana-plugin-public.appbase.status.md index 0767ead5f1455..a5fbadbeea1ff 100644 --- a/docs/development/core/public/kibana-plugin-public.appbase.tooltip_.md +++ b/docs/development/core/public/kibana-plugin-public.appbase.status.md @@ -1,13 +1,13 @@ -[Home](./index.md) > [kibana-plugin-public](./kibana-plugin-public.md) > [AppBase](./kibana-plugin-public.appbase.md) > [tooltip$](./kibana-plugin-public.appbase.tooltip_.md) +[Home](./index.md) > [kibana-plugin-public](./kibana-plugin-public.md) > [AppBase](./kibana-plugin-public.appbase.md) > [status](./kibana-plugin-public.appbase.status.md) -## AppBase.tooltip$ property +## AppBase.status property -An observable for a tooltip shown when hovering over app link. +The initial status of the application. Defaulting to `accessible` Signature: ```typescript -tooltip$?: Observable; +status?: AppStatus; ``` diff --git a/docs/development/core/public/kibana-plugin-public.appbase.tooltip.md b/docs/development/core/public/kibana-plugin-public.appbase.tooltip.md new file mode 100644 index 0000000000000..85921a5a321dd --- /dev/null +++ b/docs/development/core/public/kibana-plugin-public.appbase.tooltip.md @@ -0,0 +1,13 @@ + + +[Home](./index.md) > [kibana-plugin-public](./kibana-plugin-public.md) > [AppBase](./kibana-plugin-public.appbase.md) > [tooltip](./kibana-plugin-public.appbase.tooltip.md) + +## AppBase.tooltip property + +A tooltip shown when hovering over app link. + +Signature: + +```typescript +tooltip?: string; +``` diff --git a/docs/development/core/public/kibana-plugin-public.appbase.updater_.md b/docs/development/core/public/kibana-plugin-public.appbase.updater_.md new file mode 100644 index 0000000000000..3edd357383449 --- /dev/null +++ b/docs/development/core/public/kibana-plugin-public.appbase.updater_.md @@ -0,0 +1,44 @@ + + +[Home](./index.md) > [kibana-plugin-public](./kibana-plugin-public.md) > [AppBase](./kibana-plugin-public.appbase.md) > [updater$](./kibana-plugin-public.appbase.updater_.md) + +## AppBase.updater$ property + +An [AppUpdater](./kibana-plugin-public.appupdater.md) observable that can be used to update the application [AppUpdatableFields](./kibana-plugin-public.appupdatablefields.md) at runtime. + +Signature: + +```typescript +updater$?: Observable; +``` + +## Example + +How to update an application navLink at runtime + +```ts +// inside your plugin's setup function +export class MyPlugin implements Plugin { + private appUpdater = new BehaviorSubject(() => ({})); + + setup({ application }) { + application.register({ + id: 'my-app', + title: 'My App', + updater$: this.appUpdater, + async mount(params) { + const { renderApp } = await import('./application'); + return renderApp(params); + }, + }); + } + + start() { + // later, when the navlink needs to be updated + appUpdater.next(() => { + navLinkStatus: AppNavLinkStatus.disabled, + }) + } + +``` + diff --git a/docs/development/core/public/kibana-plugin-public.applicationsetup.md b/docs/development/core/public/kibana-plugin-public.applicationsetup.md index a63de399c2ecb..cf9bc5189af40 100644 --- a/docs/development/core/public/kibana-plugin-public.applicationsetup.md +++ b/docs/development/core/public/kibana-plugin-public.applicationsetup.md @@ -16,5 +16,6 @@ export interface ApplicationSetup | Method | Description | | --- | --- | | [register(app)](./kibana-plugin-public.applicationsetup.register.md) | Register an mountable application to the system. | +| [registerAppUpdater(appUpdater$)](./kibana-plugin-public.applicationsetup.registerappupdater.md) | Register an application updater that can be used to change the [AppUpdatableFields](./kibana-plugin-public.appupdatablefields.md) fields of all applications at runtime.This is meant to be used by plugins that needs to updates the whole list of applications. To only updates a specific application, use the updater$ property of the registered application instead. | | [registerMountContext(contextName, provider)](./kibana-plugin-public.applicationsetup.registermountcontext.md) | Register a context provider for application mounting. Will only be available to applications that depend on the plugin that registered this context. Deprecated, use [CoreSetup.getStartServices()](./kibana-plugin-public.coresetup.getstartservices.md). | diff --git a/docs/development/core/public/kibana-plugin-public.applicationsetup.registerappupdater.md b/docs/development/core/public/kibana-plugin-public.applicationsetup.registerappupdater.md new file mode 100644 index 0000000000000..39b4f878a3f79 --- /dev/null +++ b/docs/development/core/public/kibana-plugin-public.applicationsetup.registerappupdater.md @@ -0,0 +1,47 @@ + + +[Home](./index.md) > [kibana-plugin-public](./kibana-plugin-public.md) > [ApplicationSetup](./kibana-plugin-public.applicationsetup.md) > [registerAppUpdater](./kibana-plugin-public.applicationsetup.registerappupdater.md) + +## ApplicationSetup.registerAppUpdater() method + +Register an application updater that can be used to change the [AppUpdatableFields](./kibana-plugin-public.appupdatablefields.md) fields of all applications at runtime. + +This is meant to be used by plugins that needs to updates the whole list of applications. To only updates a specific application, use the `updater$` property of the registered application instead. + +Signature: + +```typescript +registerAppUpdater(appUpdater$: Observable): void; +``` + +## Parameters + +| Parameter | Type | Description | +| --- | --- | --- | +| appUpdater$ | Observable<AppUpdater> | | + +Returns: + +`void` + +## Example + +How to register an application updater that disables some applications: + +```ts +// inside your plugin's setup function +export class MyPlugin implements Plugin { + setup({ application }) { + application.registerAppUpdater( + new BehaviorSubject(app => { + if (myPluginApi.shouldDisable(app)) + return { + status: AppStatus.inaccessible, + }; + }) + ); + } +} + +``` + diff --git a/docs/development/core/public/kibana-plugin-public.appnavlinkstatus.md b/docs/development/core/public/kibana-plugin-public.appnavlinkstatus.md new file mode 100644 index 0000000000000..d6b22ac2b9217 --- /dev/null +++ b/docs/development/core/public/kibana-plugin-public.appnavlinkstatus.md @@ -0,0 +1,23 @@ + + +[Home](./index.md) > [kibana-plugin-public](./kibana-plugin-public.md) > [AppNavLinkStatus](./kibana-plugin-public.appnavlinkstatus.md) + +## AppNavLinkStatus enum + +Status of the application's navLink. + +Signature: + +```typescript +export declare enum AppNavLinkStatus +``` + +## Enumeration Members + +| Member | Value | Description | +| --- | --- | --- | +| default | 0 | The application navLink will be visible if the application's [AppStatus](./kibana-plugin-public.appstatus.md) is set to accessible and hidden if the application status is set to inaccessible. | +| disabled | 2 | The application navLink is visible but inactive and not clickable in the navigation bar. | +| hidden | 3 | The application navLink does not appear in the navigation bar. | +| visible | 1 | The application navLink is visible and clickable in the navigation bar. | + diff --git a/docs/development/core/public/kibana-plugin-public.appstatus.md b/docs/development/core/public/kibana-plugin-public.appstatus.md new file mode 100644 index 0000000000000..23fb7186569da --- /dev/null +++ b/docs/development/core/public/kibana-plugin-public.appstatus.md @@ -0,0 +1,21 @@ + + +[Home](./index.md) > [kibana-plugin-public](./kibana-plugin-public.md) > [AppStatus](./kibana-plugin-public.appstatus.md) + +## AppStatus enum + +Accessibility status of an application. + +Signature: + +```typescript +export declare enum AppStatus +``` + +## Enumeration Members + +| Member | Value | Description | +| --- | --- | --- | +| accessible | 0 | Application is accessible. | +| inaccessible | 1 | Application is not accessible. | + diff --git a/docs/development/core/public/kibana-plugin-public.appupdatablefields.md b/docs/development/core/public/kibana-plugin-public.appupdatablefields.md new file mode 100644 index 0000000000000..b9260c79cd972 --- /dev/null +++ b/docs/development/core/public/kibana-plugin-public.appupdatablefields.md @@ -0,0 +1,13 @@ + + +[Home](./index.md) > [kibana-plugin-public](./kibana-plugin-public.md) > [AppUpdatableFields](./kibana-plugin-public.appupdatablefields.md) + +## AppUpdatableFields type + +Defines the list of fields that can be updated via an [AppUpdater](./kibana-plugin-public.appupdater.md). + +Signature: + +```typescript +export declare type AppUpdatableFields = Pick; +``` diff --git a/docs/development/core/public/kibana-plugin-public.appupdater.md b/docs/development/core/public/kibana-plugin-public.appupdater.md new file mode 100644 index 0000000000000..f1b965cc2fc22 --- /dev/null +++ b/docs/development/core/public/kibana-plugin-public.appupdater.md @@ -0,0 +1,13 @@ + + +[Home](./index.md) > [kibana-plugin-public](./kibana-plugin-public.md) > [AppUpdater](./kibana-plugin-public.appupdater.md) + +## AppUpdater type + +Updater for applications. see [ApplicationSetup](./kibana-plugin-public.applicationsetup.md) + +Signature: + +```typescript +export declare type AppUpdater = (app: AppBase) => Partial | undefined; +``` diff --git a/docs/development/core/public/kibana-plugin-public.md b/docs/development/core/public/kibana-plugin-public.md index f03f3457ca93f..64cbdd880fed1 100644 --- a/docs/development/core/public/kibana-plugin-public.md +++ b/docs/development/core/public/kibana-plugin-public.md @@ -1,147 +1,151 @@ - - -[Home](./index.md) > [kibana-plugin-public](./kibana-plugin-public.md) - -## kibana-plugin-public package - -The Kibana Core APIs for client-side plugins. - -A plugin's `public/index` file must contain a named import, `plugin`, that implements [PluginInitializer](./kibana-plugin-public.plugininitializer.md) which returns an object that implements [Plugin](./kibana-plugin-public.plugin.md). - -The plugin integrates with the core system via lifecycle events: `setup`, `start`, and `stop`. In each lifecycle method, the plugin will receive the corresponding core services available (either [CoreSetup](./kibana-plugin-public.coresetup.md) or [CoreStart](./kibana-plugin-public.corestart.md)) and any interfaces returned by dependency plugins' lifecycle method. Anything returned by the plugin's lifecycle method will be exposed to downstream dependencies when their corresponding lifecycle methods are invoked. - -## Classes - -| Class | Description | -| --- | --- | -| [SavedObjectsClient](./kibana-plugin-public.savedobjectsclient.md) | Saved Objects is Kibana's data persisentence mechanism allowing plugins to use Elasticsearch for storing plugin state. The client-side SavedObjectsClient is a thin convenience library around the SavedObjects HTTP API for interacting with Saved Objects. | -| [SimpleSavedObject](./kibana-plugin-public.simplesavedobject.md) | This class is a very simple wrapper for SavedObjects loaded from the server with the [SavedObjectsClient](./kibana-plugin-public.savedobjectsclient.md).It provides basic functionality for creating/saving/deleting saved objects, but doesn't include any type-specific implementations. | -| [ToastsApi](./kibana-plugin-public.toastsapi.md) | Methods for adding and removing global toast messages. | - -## Enumerations - -| Enumeration | Description | -| --- | --- | -| [AppLeaveActionType](./kibana-plugin-public.appleaveactiontype.md) | Possible type of actions on application leave. | - -## Interfaces - -| Interface | Description | -| --- | --- | -| [App](./kibana-plugin-public.app.md) | Extension of [common app properties](./kibana-plugin-public.appbase.md) with the mount function. | -| [AppBase](./kibana-plugin-public.appbase.md) | | -| [AppLeaveConfirmAction](./kibana-plugin-public.appleaveconfirmaction.md) | Action to return from a [AppLeaveHandler](./kibana-plugin-public.appleavehandler.md) to show a confirmation message when trying to leave an application.See | -| [AppLeaveDefaultAction](./kibana-plugin-public.appleavedefaultaction.md) | Action to return from a [AppLeaveHandler](./kibana-plugin-public.appleavehandler.md) to execute the default behaviour when leaving the application.See | -| [ApplicationSetup](./kibana-plugin-public.applicationsetup.md) | | -| [ApplicationStart](./kibana-plugin-public.applicationstart.md) | | -| [AppMountContext](./kibana-plugin-public.appmountcontext.md) | The context object received when applications are mounted to the DOM. Deprecated, use [CoreSetup.getStartServices()](./kibana-plugin-public.coresetup.getstartservices.md). | -| [AppMountParameters](./kibana-plugin-public.appmountparameters.md) | | -| [Capabilities](./kibana-plugin-public.capabilities.md) | The read-only set of capabilities available for the current UI session. Capabilities are simple key-value pairs of (string, boolean), where the string denotes the capability ID, and the boolean is a flag indicating if the capability is enabled or disabled. | -| [ChromeBadge](./kibana-plugin-public.chromebadge.md) | | -| [ChromeBrand](./kibana-plugin-public.chromebrand.md) | | -| [ChromeDocTitle](./kibana-plugin-public.chromedoctitle.md) | APIs for accessing and updating the document title. | -| [ChromeHelpExtension](./kibana-plugin-public.chromehelpextension.md) | | -| [ChromeNavControl](./kibana-plugin-public.chromenavcontrol.md) | | -| [ChromeNavControls](./kibana-plugin-public.chromenavcontrols.md) | [APIs](./kibana-plugin-public.chromenavcontrols.md) for registering new controls to be displayed in the navigation bar. | -| [ChromeNavLink](./kibana-plugin-public.chromenavlink.md) | | -| [ChromeNavLinks](./kibana-plugin-public.chromenavlinks.md) | [APIs](./kibana-plugin-public.chromenavlinks.md) for manipulating nav links. | -| [ChromeRecentlyAccessed](./kibana-plugin-public.chromerecentlyaccessed.md) | [APIs](./kibana-plugin-public.chromerecentlyaccessed.md) for recently accessed history. | -| [ChromeRecentlyAccessedHistoryItem](./kibana-plugin-public.chromerecentlyaccessedhistoryitem.md) | | -| [ChromeStart](./kibana-plugin-public.chromestart.md) | ChromeStart allows plugins to customize the global chrome header UI and enrich the UX with additional information about the current location of the browser. | -| [ContextSetup](./kibana-plugin-public.contextsetup.md) | An object that handles registration of context providers and configuring handlers with context. | -| [CoreSetup](./kibana-plugin-public.coresetup.md) | Core services exposed to the Plugin setup lifecycle | -| [CoreStart](./kibana-plugin-public.corestart.md) | Core services exposed to the Plugin start lifecycle | -| [DocLinksStart](./kibana-plugin-public.doclinksstart.md) | | -| [EnvironmentMode](./kibana-plugin-public.environmentmode.md) | | -| [ErrorToastOptions](./kibana-plugin-public.errortoastoptions.md) | Options available for [IToasts](./kibana-plugin-public.itoasts.md) APIs. | -| [FatalErrorInfo](./kibana-plugin-public.fatalerrorinfo.md) | Represents the message and stack of a fatal Error | -| [FatalErrorsSetup](./kibana-plugin-public.fatalerrorssetup.md) | FatalErrors stop the Kibana Public Core and displays a fatal error screen with details about the Kibana build and the error. | -| [HttpErrorRequest](./kibana-plugin-public.httperrorrequest.md) | | -| [HttpErrorResponse](./kibana-plugin-public.httperrorresponse.md) | | -| [HttpFetchOptions](./kibana-plugin-public.httpfetchoptions.md) | All options that may be used with a [HttpHandler](./kibana-plugin-public.httphandler.md). | -| [HttpFetchQuery](./kibana-plugin-public.httpfetchquery.md) | | -| [HttpHandler](./kibana-plugin-public.httphandler.md) | A function for making an HTTP requests to Kibana's backend. See [HttpFetchOptions](./kibana-plugin-public.httpfetchoptions.md) for options and [IHttpResponse](./kibana-plugin-public.ihttpresponse.md) for the response. | -| [HttpHeadersInit](./kibana-plugin-public.httpheadersinit.md) | | -| [HttpInterceptor](./kibana-plugin-public.httpinterceptor.md) | An object that may define global interceptor functions for different parts of the request and response lifecycle. See [IHttpInterceptController](./kibana-plugin-public.ihttpinterceptcontroller.md). | -| [HttpRequestInit](./kibana-plugin-public.httprequestinit.md) | Fetch API options available to [HttpHandler](./kibana-plugin-public.httphandler.md)s. | -| [HttpSetup](./kibana-plugin-public.httpsetup.md) | | -| [I18nStart](./kibana-plugin-public.i18nstart.md) | I18nStart.Context is required by any localizable React component from @kbn/i18n and @elastic/eui packages and is supposed to be used as the topmost component for any i18n-compatible React tree. | -| [IAnonymousPaths](./kibana-plugin-public.ianonymouspaths.md) | APIs for denoting paths as not requiring authentication | -| [IBasePath](./kibana-plugin-public.ibasepath.md) | APIs for manipulating the basePath on URL segments. | -| [IContextContainer](./kibana-plugin-public.icontextcontainer.md) | An object that handles registration of context providers and configuring handlers with context. | -| [IHttpFetchError](./kibana-plugin-public.ihttpfetcherror.md) | | -| [IHttpInterceptController](./kibana-plugin-public.ihttpinterceptcontroller.md) | Used to halt a request Promise chain in a [HttpInterceptor](./kibana-plugin-public.httpinterceptor.md). | -| [IHttpResponse](./kibana-plugin-public.ihttpresponse.md) | | -| [IHttpResponseInterceptorOverrides](./kibana-plugin-public.ihttpresponseinterceptoroverrides.md) | Properties that can be returned by HttpInterceptor.request to override the response. | -| [IUiSettingsClient](./kibana-plugin-public.iuisettingsclient.md) | Client-side client that provides access to the advanced settings stored in elasticsearch. The settings provide control over the behavior of the Kibana application. For example, a user can specify how to display numeric or date fields. Users can adjust the settings via Management UI. [IUiSettingsClient](./kibana-plugin-public.iuisettingsclient.md) | -| [LegacyCoreSetup](./kibana-plugin-public.legacycoresetup.md) | Setup interface exposed to the legacy platform via the ui/new_platform module. | -| [LegacyCoreStart](./kibana-plugin-public.legacycorestart.md) | Start interface exposed to the legacy platform via the ui/new_platform module. | -| [LegacyNavLink](./kibana-plugin-public.legacynavlink.md) | | -| [NotificationsSetup](./kibana-plugin-public.notificationssetup.md) | | -| [NotificationsStart](./kibana-plugin-public.notificationsstart.md) | | -| [OverlayBannersStart](./kibana-plugin-public.overlaybannersstart.md) | | -| [OverlayRef](./kibana-plugin-public.overlayref.md) | Returned by [OverlayStart](./kibana-plugin-public.overlaystart.md) methods for closing a mounted overlay. | -| [OverlayStart](./kibana-plugin-public.overlaystart.md) | | -| [PackageInfo](./kibana-plugin-public.packageinfo.md) | | -| [Plugin](./kibana-plugin-public.plugin.md) | The interface that should be returned by a PluginInitializer. | -| [PluginInitializerContext](./kibana-plugin-public.plugininitializercontext.md) | The available core services passed to a PluginInitializer | -| [SavedObject](./kibana-plugin-public.savedobject.md) | | -| [SavedObjectAttributes](./kibana-plugin-public.savedobjectattributes.md) | The data for a Saved Object is stored as an object in the attributes property. | -| [SavedObjectReference](./kibana-plugin-public.savedobjectreference.md) | A reference to another saved object. | -| [SavedObjectsBaseOptions](./kibana-plugin-public.savedobjectsbaseoptions.md) | | -| [SavedObjectsBatchResponse](./kibana-plugin-public.savedobjectsbatchresponse.md) | | -| [SavedObjectsBulkCreateObject](./kibana-plugin-public.savedobjectsbulkcreateobject.md) | | -| [SavedObjectsBulkCreateOptions](./kibana-plugin-public.savedobjectsbulkcreateoptions.md) | | -| [SavedObjectsBulkUpdateObject](./kibana-plugin-public.savedobjectsbulkupdateobject.md) | | -| [SavedObjectsBulkUpdateOptions](./kibana-plugin-public.savedobjectsbulkupdateoptions.md) | | -| [SavedObjectsCreateOptions](./kibana-plugin-public.savedobjectscreateoptions.md) | | -| [SavedObjectsFindOptions](./kibana-plugin-public.savedobjectsfindoptions.md) | | -| [SavedObjectsFindResponsePublic](./kibana-plugin-public.savedobjectsfindresponsepublic.md) | Return type of the Saved Objects find() method.\*Note\*: this type is different between the Public and Server Saved Objects clients. | -| [SavedObjectsImportConflictError](./kibana-plugin-public.savedobjectsimportconflicterror.md) | Represents a failure to import due to a conflict. | -| [SavedObjectsImportError](./kibana-plugin-public.savedobjectsimporterror.md) | Represents a failure to import. | -| [SavedObjectsImportMissingReferencesError](./kibana-plugin-public.savedobjectsimportmissingreferenceserror.md) | Represents a failure to import due to missing references. | -| [SavedObjectsImportResponse](./kibana-plugin-public.savedobjectsimportresponse.md) | The response describing the result of an import. | -| [SavedObjectsImportRetry](./kibana-plugin-public.savedobjectsimportretry.md) | Describes a retry operation for importing a saved object. | -| [SavedObjectsImportUnknownError](./kibana-plugin-public.savedobjectsimportunknownerror.md) | Represents a failure to import due to an unknown reason. | -| [SavedObjectsImportUnsupportedTypeError](./kibana-plugin-public.savedobjectsimportunsupportedtypeerror.md) | Represents a failure to import due to having an unsupported saved object type. | -| [SavedObjectsMigrationVersion](./kibana-plugin-public.savedobjectsmigrationversion.md) | Information about the migrations that have been applied to this SavedObject. When Kibana starts up, KibanaMigrator detects outdated documents and migrates them based on this value. For each migration that has been applied, the plugin's name is used as a key and the latest migration version as the value. | -| [SavedObjectsStart](./kibana-plugin-public.savedobjectsstart.md) | | -| [SavedObjectsUpdateOptions](./kibana-plugin-public.savedobjectsupdateoptions.md) | | -| [UiSettingsState](./kibana-plugin-public.uisettingsstate.md) | | - -## Type Aliases - -| Type Alias | Description | -| --- | --- | -| [AppLeaveAction](./kibana-plugin-public.appleaveaction.md) | Possible actions to return from a [AppLeaveHandler](./kibana-plugin-public.appleavehandler.md)See [AppLeaveConfirmAction](./kibana-plugin-public.appleaveconfirmaction.md) and [AppLeaveDefaultAction](./kibana-plugin-public.appleavedefaultaction.md) | -| [AppLeaveHandler](./kibana-plugin-public.appleavehandler.md) | A handler that will be executed before leaving the application, either when going to another application or when closing the browser tab or manually changing the url. Should return confirm to to prompt a message to the user before leaving the page, or default to keep the default behavior (doing nothing).See [AppMountParameters](./kibana-plugin-public.appmountparameters.md) for detailed usage examples. | -| [AppMount](./kibana-plugin-public.appmount.md) | A mount function called when the user navigates to this app's route. | -| [AppMountDeprecated](./kibana-plugin-public.appmountdeprecated.md) | A mount function called when the user navigates to this app's route. | -| [AppUnmount](./kibana-plugin-public.appunmount.md) | A function called when an application should be unmounted from the page. This function should be synchronous. | -| [ChromeBreadcrumb](./kibana-plugin-public.chromebreadcrumb.md) | | -| [ChromeHelpExtensionMenuCustomLink](./kibana-plugin-public.chromehelpextensionmenucustomlink.md) | | -| [ChromeHelpExtensionMenuDiscussLink](./kibana-plugin-public.chromehelpextensionmenudiscusslink.md) | | -| [ChromeHelpExtensionMenuDocumentationLink](./kibana-plugin-public.chromehelpextensionmenudocumentationlink.md) | | -| [ChromeHelpExtensionMenuGitHubLink](./kibana-plugin-public.chromehelpextensionmenugithublink.md) | | -| [ChromeHelpExtensionMenuLink](./kibana-plugin-public.chromehelpextensionmenulink.md) | | -| [ChromeNavLinkUpdateableFields](./kibana-plugin-public.chromenavlinkupdateablefields.md) | | -| [HandlerContextType](./kibana-plugin-public.handlercontexttype.md) | Extracts the type of the first argument of a [HandlerFunction](./kibana-plugin-public.handlerfunction.md) to represent the type of the context. | -| [HandlerFunction](./kibana-plugin-public.handlerfunction.md) | A function that accepts a context object and an optional number of additional arguments. Used for the generic types in [IContextContainer](./kibana-plugin-public.icontextcontainer.md) | -| [HandlerParameters](./kibana-plugin-public.handlerparameters.md) | Extracts the types of the additional arguments of a [HandlerFunction](./kibana-plugin-public.handlerfunction.md), excluding the [HandlerContextType](./kibana-plugin-public.handlercontexttype.md). | -| [HttpStart](./kibana-plugin-public.httpstart.md) | See [HttpSetup](./kibana-plugin-public.httpsetup.md) | -| [IContextProvider](./kibana-plugin-public.icontextprovider.md) | A function that returns a context value for a specific key of given context type. | -| [IToasts](./kibana-plugin-public.itoasts.md) | Methods for adding and removing global toast messages. See [ToastsApi](./kibana-plugin-public.toastsapi.md). | -| [MountPoint](./kibana-plugin-public.mountpoint.md) | A function that should mount DOM content inside the provided container element and return a handler to unmount it. | -| [PluginInitializer](./kibana-plugin-public.plugininitializer.md) | The plugin export at the root of a plugin's public directory should conform to this interface. | -| [PluginOpaqueId](./kibana-plugin-public.pluginopaqueid.md) | | -| [RecursiveReadonly](./kibana-plugin-public.recursivereadonly.md) | | -| [SavedObjectAttribute](./kibana-plugin-public.savedobjectattribute.md) | Type definition for a Saved Object attribute value | -| [SavedObjectAttributeSingle](./kibana-plugin-public.savedobjectattributesingle.md) | Don't use this type, it's simply a helper type for [SavedObjectAttribute](./kibana-plugin-public.savedobjectattribute.md) | -| [SavedObjectsClientContract](./kibana-plugin-public.savedobjectsclientcontract.md) | SavedObjectsClientContract as implemented by the [SavedObjectsClient](./kibana-plugin-public.savedobjectsclient.md) | -| [Toast](./kibana-plugin-public.toast.md) | | -| [ToastInput](./kibana-plugin-public.toastinput.md) | Inputs for [IToasts](./kibana-plugin-public.itoasts.md) APIs. | -| [ToastInputFields](./kibana-plugin-public.toastinputfields.md) | Allowed fields for [ToastInput](./kibana-plugin-public.toastinput.md). | -| [ToastsSetup](./kibana-plugin-public.toastssetup.md) | [IToasts](./kibana-plugin-public.itoasts.md) | -| [ToastsStart](./kibana-plugin-public.toastsstart.md) | [IToasts](./kibana-plugin-public.itoasts.md) | -| [UnmountCallback](./kibana-plugin-public.unmountcallback.md) | A function that will unmount the element previously mounted by the associated [MountPoint](./kibana-plugin-public.mountpoint.md) | - + + +[Home](./index.md) > [kibana-plugin-public](./kibana-plugin-public.md) + +## kibana-plugin-public package + +The Kibana Core APIs for client-side plugins. + +A plugin's `public/index` file must contain a named import, `plugin`, that implements [PluginInitializer](./kibana-plugin-public.plugininitializer.md) which returns an object that implements [Plugin](./kibana-plugin-public.plugin.md). + +The plugin integrates with the core system via lifecycle events: `setup`, `start`, and `stop`. In each lifecycle method, the plugin will receive the corresponding core services available (either [CoreSetup](./kibana-plugin-public.coresetup.md) or [CoreStart](./kibana-plugin-public.corestart.md)) and any interfaces returned by dependency plugins' lifecycle method. Anything returned by the plugin's lifecycle method will be exposed to downstream dependencies when their corresponding lifecycle methods are invoked. + +## Classes + +| Class | Description | +| --- | --- | +| [SavedObjectsClient](./kibana-plugin-public.savedobjectsclient.md) | Saved Objects is Kibana's data persisentence mechanism allowing plugins to use Elasticsearch for storing plugin state. The client-side SavedObjectsClient is a thin convenience library around the SavedObjects HTTP API for interacting with Saved Objects. | +| [SimpleSavedObject](./kibana-plugin-public.simplesavedobject.md) | This class is a very simple wrapper for SavedObjects loaded from the server with the [SavedObjectsClient](./kibana-plugin-public.savedobjectsclient.md).It provides basic functionality for creating/saving/deleting saved objects, but doesn't include any type-specific implementations. | +| [ToastsApi](./kibana-plugin-public.toastsapi.md) | Methods for adding and removing global toast messages. | + +## Enumerations + +| Enumeration | Description | +| --- | --- | +| [AppLeaveActionType](./kibana-plugin-public.appleaveactiontype.md) | Possible type of actions on application leave. | +| [AppNavLinkStatus](./kibana-plugin-public.appnavlinkstatus.md) | Status of the application's navLink. | +| [AppStatus](./kibana-plugin-public.appstatus.md) | Accessibility status of an application. | + +## Interfaces + +| Interface | Description | +| --- | --- | +| [App](./kibana-plugin-public.app.md) | Extension of [common app properties](./kibana-plugin-public.appbase.md) with the mount function. | +| [AppBase](./kibana-plugin-public.appbase.md) | | +| [AppLeaveConfirmAction](./kibana-plugin-public.appleaveconfirmaction.md) | Action to return from a [AppLeaveHandler](./kibana-plugin-public.appleavehandler.md) to show a confirmation message when trying to leave an application.See | +| [AppLeaveDefaultAction](./kibana-plugin-public.appleavedefaultaction.md) | Action to return from a [AppLeaveHandler](./kibana-plugin-public.appleavehandler.md) to execute the default behaviour when leaving the application.See | +| [ApplicationSetup](./kibana-plugin-public.applicationsetup.md) | | +| [ApplicationStart](./kibana-plugin-public.applicationstart.md) | | +| [AppMountContext](./kibana-plugin-public.appmountcontext.md) | The context object received when applications are mounted to the DOM. Deprecated, use [CoreSetup.getStartServices()](./kibana-plugin-public.coresetup.getstartservices.md). | +| [AppMountParameters](./kibana-plugin-public.appmountparameters.md) | | +| [Capabilities](./kibana-plugin-public.capabilities.md) | The read-only set of capabilities available for the current UI session. Capabilities are simple key-value pairs of (string, boolean), where the string denotes the capability ID, and the boolean is a flag indicating if the capability is enabled or disabled. | +| [ChromeBadge](./kibana-plugin-public.chromebadge.md) | | +| [ChromeBrand](./kibana-plugin-public.chromebrand.md) | | +| [ChromeDocTitle](./kibana-plugin-public.chromedoctitle.md) | APIs for accessing and updating the document title. | +| [ChromeHelpExtension](./kibana-plugin-public.chromehelpextension.md) | | +| [ChromeNavControl](./kibana-plugin-public.chromenavcontrol.md) | | +| [ChromeNavControls](./kibana-plugin-public.chromenavcontrols.md) | [APIs](./kibana-plugin-public.chromenavcontrols.md) for registering new controls to be displayed in the navigation bar. | +| [ChromeNavLink](./kibana-plugin-public.chromenavlink.md) | | +| [ChromeNavLinks](./kibana-plugin-public.chromenavlinks.md) | [APIs](./kibana-plugin-public.chromenavlinks.md) for manipulating nav links. | +| [ChromeRecentlyAccessed](./kibana-plugin-public.chromerecentlyaccessed.md) | [APIs](./kibana-plugin-public.chromerecentlyaccessed.md) for recently accessed history. | +| [ChromeRecentlyAccessedHistoryItem](./kibana-plugin-public.chromerecentlyaccessedhistoryitem.md) | | +| [ChromeStart](./kibana-plugin-public.chromestart.md) | ChromeStart allows plugins to customize the global chrome header UI and enrich the UX with additional information about the current location of the browser. | +| [ContextSetup](./kibana-plugin-public.contextsetup.md) | An object that handles registration of context providers and configuring handlers with context. | +| [CoreSetup](./kibana-plugin-public.coresetup.md) | Core services exposed to the Plugin setup lifecycle | +| [CoreStart](./kibana-plugin-public.corestart.md) | Core services exposed to the Plugin start lifecycle | +| [DocLinksStart](./kibana-plugin-public.doclinksstart.md) | | +| [EnvironmentMode](./kibana-plugin-public.environmentmode.md) | | +| [ErrorToastOptions](./kibana-plugin-public.errortoastoptions.md) | Options available for [IToasts](./kibana-plugin-public.itoasts.md) APIs. | +| [FatalErrorInfo](./kibana-plugin-public.fatalerrorinfo.md) | Represents the message and stack of a fatal Error | +| [FatalErrorsSetup](./kibana-plugin-public.fatalerrorssetup.md) | FatalErrors stop the Kibana Public Core and displays a fatal error screen with details about the Kibana build and the error. | +| [HttpErrorRequest](./kibana-plugin-public.httperrorrequest.md) | | +| [HttpErrorResponse](./kibana-plugin-public.httperrorresponse.md) | | +| [HttpFetchOptions](./kibana-plugin-public.httpfetchoptions.md) | All options that may be used with a [HttpHandler](./kibana-plugin-public.httphandler.md). | +| [HttpFetchQuery](./kibana-plugin-public.httpfetchquery.md) | | +| [HttpHandler](./kibana-plugin-public.httphandler.md) | A function for making an HTTP requests to Kibana's backend. See [HttpFetchOptions](./kibana-plugin-public.httpfetchoptions.md) for options and [IHttpResponse](./kibana-plugin-public.ihttpresponse.md) for the response. | +| [HttpHeadersInit](./kibana-plugin-public.httpheadersinit.md) | | +| [HttpInterceptor](./kibana-plugin-public.httpinterceptor.md) | An object that may define global interceptor functions for different parts of the request and response lifecycle. See [IHttpInterceptController](./kibana-plugin-public.ihttpinterceptcontroller.md). | +| [HttpRequestInit](./kibana-plugin-public.httprequestinit.md) | Fetch API options available to [HttpHandler](./kibana-plugin-public.httphandler.md)s. | +| [HttpSetup](./kibana-plugin-public.httpsetup.md) | | +| [I18nStart](./kibana-plugin-public.i18nstart.md) | I18nStart.Context is required by any localizable React component from @kbn/i18n and @elastic/eui packages and is supposed to be used as the topmost component for any i18n-compatible React tree. | +| [IAnonymousPaths](./kibana-plugin-public.ianonymouspaths.md) | APIs for denoting paths as not requiring authentication | +| [IBasePath](./kibana-plugin-public.ibasepath.md) | APIs for manipulating the basePath on URL segments. | +| [IContextContainer](./kibana-plugin-public.icontextcontainer.md) | An object that handles registration of context providers and configuring handlers with context. | +| [IHttpFetchError](./kibana-plugin-public.ihttpfetcherror.md) | | +| [IHttpInterceptController](./kibana-plugin-public.ihttpinterceptcontroller.md) | Used to halt a request Promise chain in a [HttpInterceptor](./kibana-plugin-public.httpinterceptor.md). | +| [IHttpResponse](./kibana-plugin-public.ihttpresponse.md) | | +| [IHttpResponseInterceptorOverrides](./kibana-plugin-public.ihttpresponseinterceptoroverrides.md) | Properties that can be returned by HttpInterceptor.request to override the response. | +| [IUiSettingsClient](./kibana-plugin-public.iuisettingsclient.md) | Client-side client that provides access to the advanced settings stored in elasticsearch. The settings provide control over the behavior of the Kibana application. For example, a user can specify how to display numeric or date fields. Users can adjust the settings via Management UI. [IUiSettingsClient](./kibana-plugin-public.iuisettingsclient.md) | +| [LegacyCoreSetup](./kibana-plugin-public.legacycoresetup.md) | Setup interface exposed to the legacy platform via the ui/new_platform module. | +| [LegacyCoreStart](./kibana-plugin-public.legacycorestart.md) | Start interface exposed to the legacy platform via the ui/new_platform module. | +| [LegacyNavLink](./kibana-plugin-public.legacynavlink.md) | | +| [NotificationsSetup](./kibana-plugin-public.notificationssetup.md) | | +| [NotificationsStart](./kibana-plugin-public.notificationsstart.md) | | +| [OverlayBannersStart](./kibana-plugin-public.overlaybannersstart.md) | | +| [OverlayRef](./kibana-plugin-public.overlayref.md) | Returned by [OverlayStart](./kibana-plugin-public.overlaystart.md) methods for closing a mounted overlay. | +| [OverlayStart](./kibana-plugin-public.overlaystart.md) | | +| [PackageInfo](./kibana-plugin-public.packageinfo.md) | | +| [Plugin](./kibana-plugin-public.plugin.md) | The interface that should be returned by a PluginInitializer. | +| [PluginInitializerContext](./kibana-plugin-public.plugininitializercontext.md) | The available core services passed to a PluginInitializer | +| [SavedObject](./kibana-plugin-public.savedobject.md) | | +| [SavedObjectAttributes](./kibana-plugin-public.savedobjectattributes.md) | The data for a Saved Object is stored as an object in the attributes property. | +| [SavedObjectReference](./kibana-plugin-public.savedobjectreference.md) | A reference to another saved object. | +| [SavedObjectsBaseOptions](./kibana-plugin-public.savedobjectsbaseoptions.md) | | +| [SavedObjectsBatchResponse](./kibana-plugin-public.savedobjectsbatchresponse.md) | | +| [SavedObjectsBulkCreateObject](./kibana-plugin-public.savedobjectsbulkcreateobject.md) | | +| [SavedObjectsBulkCreateOptions](./kibana-plugin-public.savedobjectsbulkcreateoptions.md) | | +| [SavedObjectsBulkUpdateObject](./kibana-plugin-public.savedobjectsbulkupdateobject.md) | | +| [SavedObjectsBulkUpdateOptions](./kibana-plugin-public.savedobjectsbulkupdateoptions.md) | | +| [SavedObjectsCreateOptions](./kibana-plugin-public.savedobjectscreateoptions.md) | | +| [SavedObjectsFindOptions](./kibana-plugin-public.savedobjectsfindoptions.md) | | +| [SavedObjectsFindResponsePublic](./kibana-plugin-public.savedobjectsfindresponsepublic.md) | Return type of the Saved Objects find() method.\*Note\*: this type is different between the Public and Server Saved Objects clients. | +| [SavedObjectsImportConflictError](./kibana-plugin-public.savedobjectsimportconflicterror.md) | Represents a failure to import due to a conflict. | +| [SavedObjectsImportError](./kibana-plugin-public.savedobjectsimporterror.md) | Represents a failure to import. | +| [SavedObjectsImportMissingReferencesError](./kibana-plugin-public.savedobjectsimportmissingreferenceserror.md) | Represents a failure to import due to missing references. | +| [SavedObjectsImportResponse](./kibana-plugin-public.savedobjectsimportresponse.md) | The response describing the result of an import. | +| [SavedObjectsImportRetry](./kibana-plugin-public.savedobjectsimportretry.md) | Describes a retry operation for importing a saved object. | +| [SavedObjectsImportUnknownError](./kibana-plugin-public.savedobjectsimportunknownerror.md) | Represents a failure to import due to an unknown reason. | +| [SavedObjectsImportUnsupportedTypeError](./kibana-plugin-public.savedobjectsimportunsupportedtypeerror.md) | Represents a failure to import due to having an unsupported saved object type. | +| [SavedObjectsMigrationVersion](./kibana-plugin-public.savedobjectsmigrationversion.md) | Information about the migrations that have been applied to this SavedObject. When Kibana starts up, KibanaMigrator detects outdated documents and migrates them based on this value. For each migration that has been applied, the plugin's name is used as a key and the latest migration version as the value. | +| [SavedObjectsStart](./kibana-plugin-public.savedobjectsstart.md) | | +| [SavedObjectsUpdateOptions](./kibana-plugin-public.savedobjectsupdateoptions.md) | | +| [UiSettingsState](./kibana-plugin-public.uisettingsstate.md) | | + +## Type Aliases + +| Type Alias | Description | +| --- | --- | +| [AppLeaveAction](./kibana-plugin-public.appleaveaction.md) | Possible actions to return from a [AppLeaveHandler](./kibana-plugin-public.appleavehandler.md)See [AppLeaveConfirmAction](./kibana-plugin-public.appleaveconfirmaction.md) and [AppLeaveDefaultAction](./kibana-plugin-public.appleavedefaultaction.md) | +| [AppLeaveHandler](./kibana-plugin-public.appleavehandler.md) | A handler that will be executed before leaving the application, either when going to another application or when closing the browser tab or manually changing the url. Should return confirm to to prompt a message to the user before leaving the page, or default to keep the default behavior (doing nothing).See [AppMountParameters](./kibana-plugin-public.appmountparameters.md) for detailed usage examples. | +| [AppMount](./kibana-plugin-public.appmount.md) | A mount function called when the user navigates to this app's route. | +| [AppMountDeprecated](./kibana-plugin-public.appmountdeprecated.md) | A mount function called when the user navigates to this app's route. | +| [AppUnmount](./kibana-plugin-public.appunmount.md) | A function called when an application should be unmounted from the page. This function should be synchronous. | +| [AppUpdatableFields](./kibana-plugin-public.appupdatablefields.md) | Defines the list of fields that can be updated via an [AppUpdater](./kibana-plugin-public.appupdater.md). | +| [AppUpdater](./kibana-plugin-public.appupdater.md) | Updater for applications. see [ApplicationSetup](./kibana-plugin-public.applicationsetup.md) | +| [ChromeBreadcrumb](./kibana-plugin-public.chromebreadcrumb.md) | | +| [ChromeHelpExtensionMenuCustomLink](./kibana-plugin-public.chromehelpextensionmenucustomlink.md) | | +| [ChromeHelpExtensionMenuDiscussLink](./kibana-plugin-public.chromehelpextensionmenudiscusslink.md) | | +| [ChromeHelpExtensionMenuDocumentationLink](./kibana-plugin-public.chromehelpextensionmenudocumentationlink.md) | | +| [ChromeHelpExtensionMenuGitHubLink](./kibana-plugin-public.chromehelpextensionmenugithublink.md) | | +| [ChromeHelpExtensionMenuLink](./kibana-plugin-public.chromehelpextensionmenulink.md) | | +| [ChromeNavLinkUpdateableFields](./kibana-plugin-public.chromenavlinkupdateablefields.md) | | +| [HandlerContextType](./kibana-plugin-public.handlercontexttype.md) | Extracts the type of the first argument of a [HandlerFunction](./kibana-plugin-public.handlerfunction.md) to represent the type of the context. | +| [HandlerFunction](./kibana-plugin-public.handlerfunction.md) | A function that accepts a context object and an optional number of additional arguments. Used for the generic types in [IContextContainer](./kibana-plugin-public.icontextcontainer.md) | +| [HandlerParameters](./kibana-plugin-public.handlerparameters.md) | Extracts the types of the additional arguments of a [HandlerFunction](./kibana-plugin-public.handlerfunction.md), excluding the [HandlerContextType](./kibana-plugin-public.handlercontexttype.md). | +| [HttpStart](./kibana-plugin-public.httpstart.md) | See [HttpSetup](./kibana-plugin-public.httpsetup.md) | +| [IContextProvider](./kibana-plugin-public.icontextprovider.md) | A function that returns a context value for a specific key of given context type. | +| [IToasts](./kibana-plugin-public.itoasts.md) | Methods for adding and removing global toast messages. See [ToastsApi](./kibana-plugin-public.toastsapi.md). | +| [MountPoint](./kibana-plugin-public.mountpoint.md) | A function that should mount DOM content inside the provided container element and return a handler to unmount it. | +| [PluginInitializer](./kibana-plugin-public.plugininitializer.md) | The plugin export at the root of a plugin's public directory should conform to this interface. | +| [PluginOpaqueId](./kibana-plugin-public.pluginopaqueid.md) | | +| [RecursiveReadonly](./kibana-plugin-public.recursivereadonly.md) | | +| [SavedObjectAttribute](./kibana-plugin-public.savedobjectattribute.md) | Type definition for a Saved Object attribute value | +| [SavedObjectAttributeSingle](./kibana-plugin-public.savedobjectattributesingle.md) | Don't use this type, it's simply a helper type for [SavedObjectAttribute](./kibana-plugin-public.savedobjectattribute.md) | +| [SavedObjectsClientContract](./kibana-plugin-public.savedobjectsclientcontract.md) | SavedObjectsClientContract as implemented by the [SavedObjectsClient](./kibana-plugin-public.savedobjectsclient.md) | +| [Toast](./kibana-plugin-public.toast.md) | | +| [ToastInput](./kibana-plugin-public.toastinput.md) | Inputs for [IToasts](./kibana-plugin-public.itoasts.md) APIs. | +| [ToastInputFields](./kibana-plugin-public.toastinputfields.md) | Allowed fields for [ToastInput](./kibana-plugin-public.toastinput.md). | +| [ToastsSetup](./kibana-plugin-public.toastssetup.md) | [IToasts](./kibana-plugin-public.itoasts.md) | +| [ToastsStart](./kibana-plugin-public.toastsstart.md) | [IToasts](./kibana-plugin-public.itoasts.md) | +| [UnmountCallback](./kibana-plugin-public.unmountcallback.md) | A function that will unmount the element previously mounted by the associated [MountPoint](./kibana-plugin-public.mountpoint.md) | + diff --git a/src/core/MIGRATION.md b/src/core/MIGRATION.md index b70ac610f24a7..173d73ffab664 100644 --- a/src/core/MIGRATION.md +++ b/src/core/MIGRATION.md @@ -55,6 +55,7 @@ - [Provide Legacy Platform API to the New platform plugin](#provide-legacy-platform-api-to-the-new-platform-plugin) - [On the server side](#on-the-server-side) - [On the client side](#on-the-client-side) + - [Updates an application navlink at runtime](#updates-an-app-navlink-at-runtime) Make no mistake, it is going to take a lot of work to move certain plugins to the new platform. Our target is to migrate the entire repo over to the new platform throughout 7.x and to remove the legacy plugin system no later than 8.0, and this is only possible if teams start on the effort now. @@ -1624,3 +1625,31 @@ class MyPlugin { It's not currently possible to use a similar pattern on the client-side. Because Legacy platform plugins heavily rely on global angular modules, which aren't available on the new platform. So you can utilize the same approach for only *stateless Angular components*, as long as they are not consumed by a New Platform application. When New Platform applications are on the page, no legacy code is executed, so the `registerLegacyAPI` function would not be called. + +### Updates an application navlink at runtime + +The application API now provides a way to updates some of a registered application's properties after registration. + +```typescript +// inside your plugin's setup function +export class MyPlugin implements Plugin { + private appUpdater = new BehaviorSubject(() => ({})); + setup({ application }) { + application.register({ + id: 'my-app', + title: 'My App', + updater$: this.appUpdater, + async mount(params) { + const { renderApp } = await import('./application'); + return renderApp(params); + }, + }); + } + start() { + // later, when the navlink needs to be updated + appUpdater.next(() => { + navLinkStatus: AppNavLinkStatus.disabled, + tooltip: 'Application disabled', + }) + } +``` \ No newline at end of file diff --git a/src/core/public/application/application_service.mock.ts b/src/core/public/application/application_service.mock.ts index b2e2161c92cc8..dee47315fc322 100644 --- a/src/core/public/application/application_service.mock.ts +++ b/src/core/public/application/application_service.mock.ts @@ -17,7 +17,7 @@ * under the License. */ -import { Subject } from 'rxjs'; +import { BehaviorSubject, Subject } from 'rxjs'; import { capabilitiesServiceMock } from './capabilities/capabilities_service.mock'; import { @@ -25,17 +25,21 @@ import { InternalApplicationStart, ApplicationStart, InternalApplicationSetup, + App, + LegacyApp, } from './types'; import { ApplicationServiceContract } from './test_types'; const createSetupContractMock = (): jest.Mocked => ({ register: jest.fn(), + registerAppUpdater: jest.fn(), registerMountContext: jest.fn(), }); const createInternalSetupContractMock = (): jest.Mocked => ({ register: jest.fn(), registerLegacyApp: jest.fn(), + registerAppUpdater: jest.fn(), registerMountContext: jest.fn(), }); @@ -50,8 +54,7 @@ const createInternalStartContractMock = (): jest.Mocked(); return { - availableApps: new Map(), - availableLegacyApps: new Map(), + applications$: new BehaviorSubject>(new Map()), capabilities: capabilitiesServiceMock.createStartContract().capabilities, currentAppId$: currentAppId$.asObservable(), getComponent: jest.fn(), diff --git a/src/core/public/application/application_service.test.ts b/src/core/public/application/application_service.test.ts index 1132abc11703f..4672a42c9eb06 100644 --- a/src/core/public/application/application_service.test.ts +++ b/src/core/public/application/application_service.test.ts @@ -18,8 +18,8 @@ */ import { createElement } from 'react'; -import { Subject } from 'rxjs'; -import { bufferCount, skip, takeUntil } from 'rxjs/operators'; +import { BehaviorSubject, Subject } from 'rxjs'; +import { bufferCount, skip, take, takeUntil } from 'rxjs/operators'; import { shallow } from 'enzyme'; import { injectedMetadataServiceMock } from '../injected_metadata/injected_metadata_service.mock'; @@ -29,8 +29,25 @@ import { overlayServiceMock } from '../overlays/overlay_service.mock'; import { MockCapabilitiesService, MockHistory } from './application_service.test.mocks'; import { MockLifecycle } from './test_types'; import { ApplicationService } from './application_service'; - -function mount() {} +import { App, AppNavLinkStatus, AppStatus, AppUpdater, LegacyApp } from './types'; + +const createApp = (props: Partial): App => { + return { + id: 'some-id', + title: 'some-title', + mount: () => () => undefined, + ...props, + }; +}; + +const createLegacyApp = (props: Partial): LegacyApp => { + return { + id: 'some-id', + title: 'some-title', + appUrl: '/my-url', + ...props, + }; +}; let setupDeps: MockLifecycle<'setup'>; let startDeps: MockLifecycle<'start'>; @@ -53,9 +70,9 @@ describe('#setup()', () => { it('throws an error if two apps with the same id are registered', () => { const { register } = service.setup(setupDeps); - register(Symbol(), { id: 'app1', mount } as any); + register(Symbol(), createApp({ id: 'app1' })); expect(() => - register(Symbol(), { id: 'app1', mount } as any) + register(Symbol(), createApp({ id: 'app1' })) ).toThrowErrorMatchingInlineSnapshot( `"An application is already registered with the id \\"app1\\""` ); @@ -66,37 +83,91 @@ describe('#setup()', () => { await service.start(startDeps); expect(() => - register(Symbol(), { id: 'app1', mount } as any) + register(Symbol(), createApp({ id: 'app1' })) ).toThrowErrorMatchingInlineSnapshot(`"Applications cannot be registered after \\"setup\\""`); }); + it('allows to register a statusUpdater for the application', async () => { + const setup = service.setup(setupDeps); + + const pluginId = Symbol('plugin'); + const updater$ = new BehaviorSubject(app => ({})); + setup.register(pluginId, createApp({ id: 'app1', updater$ })); + setup.register(pluginId, createApp({ id: 'app2' })); + const { applications$ } = await service.start(startDeps); + + let applications = await applications$.pipe(take(1)).toPromise(); + expect(applications.size).toEqual(2); + expect(applications.get('app1')).toEqual( + expect.objectContaining({ + id: 'app1', + legacy: false, + navLinkStatus: AppNavLinkStatus.default, + status: AppStatus.accessible, + }) + ); + expect(applications.get('app2')).toEqual( + expect.objectContaining({ + id: 'app2', + legacy: false, + navLinkStatus: AppNavLinkStatus.default, + status: AppStatus.accessible, + }) + ); + + updater$.next(app => ({ + status: AppStatus.inaccessible, + tooltip: 'App inaccessible due to reason', + })); + + applications = await applications$.pipe(take(1)).toPromise(); + expect(applications.size).toEqual(2); + expect(applications.get('app1')).toEqual( + expect.objectContaining({ + id: 'app1', + legacy: false, + navLinkStatus: AppNavLinkStatus.default, + status: AppStatus.inaccessible, + tooltip: 'App inaccessible due to reason', + }) + ); + expect(applications.get('app2')).toEqual( + expect.objectContaining({ + id: 'app2', + legacy: false, + navLinkStatus: AppNavLinkStatus.default, + status: AppStatus.accessible, + }) + ); + }); + it('throws an error if an App with the same appRoute is registered', () => { const { register, registerLegacyApp } = service.setup(setupDeps); - register(Symbol(), { id: 'app1', mount } as any); + register(Symbol(), createApp({ id: 'app1' })); expect(() => - register(Symbol(), { id: 'app2', mount, appRoute: '/app/app1' } as any) + register(Symbol(), createApp({ id: 'app2', appRoute: '/app/app1' })) ).toThrowErrorMatchingInlineSnapshot( `"An application is already registered with the appRoute \\"/app/app1\\""` ); - expect(() => registerLegacyApp({ id: 'app1' } as any)).not.toThrow(); + expect(() => registerLegacyApp(createLegacyApp({ id: 'app1' }))).toThrow(); - register(Symbol(), { id: 'app-next', mount, appRoute: '/app/app3' } as any); + register(Symbol(), createApp({ id: 'app-next', appRoute: '/app/app3' })); expect(() => - register(Symbol(), { id: 'app2', mount, appRoute: '/app/app3' } as any) + register(Symbol(), createApp({ id: 'app2', appRoute: '/app/app3' })) ).toThrowErrorMatchingInlineSnapshot( `"An application is already registered with the appRoute \\"/app/app3\\""` ); - expect(() => registerLegacyApp({ id: 'app3' } as any)).not.toThrow(); + expect(() => registerLegacyApp(createLegacyApp({ id: 'app3' }))).not.toThrow(); }); it('throws an error if an App starts with the HTTP base path', () => { const { register } = service.setup(setupDeps); expect(() => - register(Symbol(), { id: 'app2', mount, appRoute: '/test/app2' } as any) + register(Symbol(), createApp({ id: 'app2', appRoute: '/test/app2' })) ).toThrowErrorMatchingInlineSnapshot( `"Cannot register an application route that includes HTTP base path"` ); @@ -107,9 +178,11 @@ describe('#setup()', () => { it('throws an error if two apps with the same id are registered', () => { const { registerLegacyApp } = service.setup(setupDeps); - registerLegacyApp({ id: 'app2' } as any); - expect(() => registerLegacyApp({ id: 'app2' } as any)).toThrowErrorMatchingInlineSnapshot( - `"A legacy application is already registered with the id \\"app2\\""` + registerLegacyApp(createLegacyApp({ id: 'app2' })); + expect(() => + registerLegacyApp(createLegacyApp({ id: 'app2' })) + ).toThrowErrorMatchingInlineSnapshot( + `"An application is already registered with the id \\"app2\\""` ); }); @@ -117,22 +190,228 @@ describe('#setup()', () => { const { registerLegacyApp } = service.setup(setupDeps); await service.start(startDeps); - expect(() => registerLegacyApp({ id: 'app2' } as any)).toThrowErrorMatchingInlineSnapshot( - `"Applications cannot be registered after \\"setup\\""` - ); + expect(() => + registerLegacyApp(createLegacyApp({ id: 'app2' })) + ).toThrowErrorMatchingInlineSnapshot(`"Applications cannot be registered after \\"setup\\""`); }); it('throws an error if a LegacyApp with the same appRoute is registered', () => { const { register, registerLegacyApp } = service.setup(setupDeps); - registerLegacyApp({ id: 'app1' } as any); + registerLegacyApp(createLegacyApp({ id: 'app1' })); expect(() => - register(Symbol(), { id: 'app2', mount, appRoute: '/app/app1' } as any) + register(Symbol(), createApp({ id: 'app2', appRoute: '/app/app1' })) ).toThrowErrorMatchingInlineSnapshot( `"An application is already registered with the appRoute \\"/app/app1\\""` ); - expect(() => registerLegacyApp({ id: 'app1:other' } as any)).not.toThrow(); + expect(() => registerLegacyApp(createLegacyApp({ id: 'app1:other' }))).not.toThrow(); + }); + }); + + describe('registerAppStatusUpdater', () => { + it('updates status fields', async () => { + const setup = service.setup(setupDeps); + + const pluginId = Symbol('plugin'); + setup.register(pluginId, createApp({ id: 'app1' })); + setup.register(pluginId, createApp({ id: 'app2' })); + setup.registerAppUpdater( + new BehaviorSubject(app => { + if (app.id === 'app1') { + return { + status: AppStatus.inaccessible, + navLinkStatus: AppNavLinkStatus.disabled, + tooltip: 'App inaccessible due to reason', + }; + } + return { + tooltip: 'App accessible', + }; + }) + ); + const start = await service.start(startDeps); + const applications = await start.applications$.pipe(take(1)).toPromise(); + + expect(applications.size).toEqual(2); + expect(applications.get('app1')).toEqual( + expect.objectContaining({ + id: 'app1', + legacy: false, + navLinkStatus: AppNavLinkStatus.disabled, + status: AppStatus.inaccessible, + tooltip: 'App inaccessible due to reason', + }) + ); + expect(applications.get('app2')).toEqual( + expect.objectContaining({ + id: 'app2', + legacy: false, + navLinkStatus: AppNavLinkStatus.default, + status: AppStatus.accessible, + tooltip: 'App accessible', + }) + ); + }); + + it(`properly combine with application's updater$`, async () => { + const setup = service.setup(setupDeps); + const pluginId = Symbol('plugin'); + const appStatusUpdater$ = new BehaviorSubject(app => ({ + status: AppStatus.inaccessible, + navLinkStatus: AppNavLinkStatus.disabled, + })); + setup.register(pluginId, createApp({ id: 'app1', updater$: appStatusUpdater$ })); + setup.register(pluginId, createApp({ id: 'app2' })); + + setup.registerAppUpdater( + new BehaviorSubject(app => { + if (app.id === 'app1') { + return { + status: AppStatus.accessible, + tooltip: 'App inaccessible due to reason', + }; + } + return { + status: AppStatus.inaccessible, + navLinkStatus: AppNavLinkStatus.hidden, + }; + }) + ); + + const { applications$ } = await service.start(startDeps); + const applications = await applications$.pipe(take(1)).toPromise(); + + expect(applications.size).toEqual(2); + expect(applications.get('app1')).toEqual( + expect.objectContaining({ + id: 'app1', + legacy: false, + navLinkStatus: AppNavLinkStatus.disabled, + status: AppStatus.inaccessible, + tooltip: 'App inaccessible due to reason', + }) + ); + expect(applications.get('app2')).toEqual( + expect.objectContaining({ + id: 'app2', + legacy: false, + status: AppStatus.inaccessible, + navLinkStatus: AppNavLinkStatus.hidden, + }) + ); + }); + + it('applies the most restrictive status in case of multiple updaters', async () => { + const setup = service.setup(setupDeps); + + const pluginId = Symbol('plugin'); + setup.register(pluginId, createApp({ id: 'app1' })); + setup.registerAppUpdater( + new BehaviorSubject(app => { + return { + status: AppStatus.inaccessible, + navLinkStatus: AppNavLinkStatus.disabled, + }; + }) + ); + setup.registerAppUpdater( + new BehaviorSubject(app => { + return { + status: AppStatus.accessible, + navLinkStatus: AppNavLinkStatus.default, + }; + }) + ); + + const start = await service.start(startDeps); + const applications = await start.applications$.pipe(take(1)).toPromise(); + + expect(applications.size).toEqual(1); + expect(applications.get('app1')).toEqual( + expect.objectContaining({ + id: 'app1', + legacy: false, + navLinkStatus: AppNavLinkStatus.disabled, + status: AppStatus.inaccessible, + }) + ); + }); + + it('emits on applications$ when a status updater changes', async () => { + const setup = service.setup(setupDeps); + + const pluginId = Symbol('plugin'); + setup.register(pluginId, createApp({ id: 'app1' })); + + const statusUpdater = new BehaviorSubject(app => { + return { + status: AppStatus.inaccessible, + navLinkStatus: AppNavLinkStatus.disabled, + }; + }); + setup.registerAppUpdater(statusUpdater); + + const start = await service.start(startDeps); + let latestValue: ReadonlyMap = new Map(); + start.applications$.subscribe(apps => { + latestValue = apps; + }); + + expect(latestValue.get('app1')).toEqual( + expect.objectContaining({ + id: 'app1', + legacy: false, + status: AppStatus.inaccessible, + navLinkStatus: AppNavLinkStatus.disabled, + }) + ); + + statusUpdater.next(app => { + return { + status: AppStatus.accessible, + navLinkStatus: AppNavLinkStatus.hidden, + }; + }); + + expect(latestValue.get('app1')).toEqual( + expect.objectContaining({ + id: 'app1', + legacy: false, + status: AppStatus.accessible, + navLinkStatus: AppNavLinkStatus.hidden, + }) + ); + }); + + it('also updates legacy apps', async () => { + const setup = service.setup(setupDeps); + + setup.registerLegacyApp(createLegacyApp({ id: 'app1' })); + + setup.registerAppUpdater( + new BehaviorSubject(app => { + return { + status: AppStatus.inaccessible, + navLinkStatus: AppNavLinkStatus.hidden, + tooltip: 'App inaccessible due to reason', + }; + }) + ); + + const start = await service.start(startDeps); + const applications = await start.applications$.pipe(take(1)).toPromise(); + + expect(applications.size).toEqual(1); + expect(applications.get('app1')).toEqual( + expect.objectContaining({ + id: 'app1', + legacy: true, + status: AppStatus.inaccessible, + navLinkStatus: AppNavLinkStatus.hidden, + tooltip: 'App inaccessible due to reason', + }) + ); }); }); @@ -141,7 +420,8 @@ describe('#setup()', () => { const container = setupDeps.context.createContextContainer.mock.results[0].value; const pluginId = Symbol(); - registerMountContext(pluginId, 'test' as any, mount as any); + const mount = () => () => undefined; + registerMountContext(pluginId, 'test' as any, mount); expect(container.registerContext).toHaveBeenCalledWith(pluginId, 'test', mount); }); }); @@ -171,35 +451,40 @@ describe('#start()', () => { setupDeps.injectedMetadata.getLegacyMode.mockReturnValue(true); const { register, registerLegacyApp } = service.setup(setupDeps); - register(Symbol(), { id: 'app1', mount } as any); - registerLegacyApp({ id: 'app2' } as any); - - const { availableApps, availableLegacyApps } = await service.start(startDeps); - - expect(availableApps).toMatchInlineSnapshot(` - Map { - "app1" => Object { - "appRoute": "/app/app1", - "id": "app1", - "mount": [Function], - }, - } - `); - expect(availableLegacyApps).toMatchInlineSnapshot(` - Map { - "app2" => Object { - "id": "app2", - }, - } - `); + register(Symbol(), createApp({ id: 'app1' })); + registerLegacyApp(createLegacyApp({ id: 'app2' })); + + const { applications$ } = await service.start(startDeps); + const availableApps = await applications$.pipe(take(1)).toPromise(); + + expect(availableApps.size).toEqual(2); + expect([...availableApps.keys()]).toEqual(['app1', 'app2']); + expect(availableApps.get('app1')).toEqual( + expect.objectContaining({ + appRoute: '/app/app1', + id: 'app1', + legacy: false, + navLinkStatus: AppNavLinkStatus.default, + status: AppStatus.accessible, + }) + ); + expect(availableApps.get('app2')).toEqual( + expect.objectContaining({ + appUrl: '/my-url', + id: 'app2', + legacy: true, + navLinkStatus: AppNavLinkStatus.default, + status: AppStatus.accessible, + }) + ); }); it('passes appIds to capabilities', async () => { const { register } = service.setup(setupDeps); - register(Symbol(), { id: 'app1', mount } as any); - register(Symbol(), { id: 'app2', mount } as any); - register(Symbol(), { id: 'app3', mount } as any); + register(Symbol(), createApp({ id: 'app1' })); + register(Symbol(), createApp({ id: 'app2' })); + register(Symbol(), createApp({ id: 'app3' })); await service.start(startDeps); expect(MockCapabilitiesService.start).toHaveBeenCalledWith({ @@ -222,29 +507,15 @@ describe('#start()', () => { const { register, registerLegacyApp } = service.setup(setupDeps); - register(Symbol(), { id: 'app1', mount } as any); - registerLegacyApp({ id: 'legacyApp1' } as any); - register(Symbol(), { id: 'app2', mount } as any); - registerLegacyApp({ id: 'legacyApp2' } as any); + register(Symbol(), createApp({ id: 'app1' })); + registerLegacyApp(createLegacyApp({ id: 'legacyApp1' })); + register(Symbol(), createApp({ id: 'app2' })); + registerLegacyApp(createLegacyApp({ id: 'legacyApp2' })); - const { availableApps, availableLegacyApps } = await service.start(startDeps); + const { applications$ } = await service.start(startDeps); + const availableApps = await applications$.pipe(take(1)).toPromise(); - expect(availableApps).toMatchInlineSnapshot(` - Map { - "app1" => Object { - "appRoute": "/app/app1", - "id": "app1", - "mount": [Function], - }, - } - `); - expect(availableLegacyApps).toMatchInlineSnapshot(` - Map { - "legacyApp1" => Object { - "id": "legacyApp1", - }, - } - `); + expect([...availableApps.keys()]).toEqual(['app1', 'legacyApp1']); }); describe('getComponent', () => { @@ -290,9 +561,9 @@ describe('#start()', () => { it('creates URL for registered appId', async () => { const { register, registerLegacyApp } = service.setup(setupDeps); - register(Symbol(), { id: 'app1', mount } as any); - registerLegacyApp({ id: 'legacyApp1' } as any); - register(Symbol(), { id: 'app2', mount, appRoute: '/custom/path' } as any); + register(Symbol(), createApp({ id: 'app1' })); + registerLegacyApp(createLegacyApp({ id: 'legacyApp1' })); + register(Symbol(), createApp({ id: 'app2', appRoute: '/custom/path' })); const { getUrlForApp } = await service.start(startDeps); @@ -329,7 +600,7 @@ describe('#start()', () => { it('changes the browser history for custom appRoutes', async () => { const { register } = service.setup(setupDeps); - register(Symbol(), { id: 'app2', mount, appRoute: '/custom/path' } as any); + register(Symbol(), createApp({ id: 'app2', appRoute: '/custom/path' })); const { navigateToApp } = await service.start(startDeps); @@ -343,7 +614,7 @@ describe('#start()', () => { it('appends a path if specified', async () => { const { register } = service.setup(setupDeps); - register(Symbol(), { id: 'app2', mount, appRoute: '/custom/path' } as any); + register(Symbol(), createApp({ id: 'app2', appRoute: '/custom/path' })); const { navigateToApp } = await service.start(startDeps); @@ -363,7 +634,7 @@ describe('#start()', () => { it('includes state if specified', async () => { const { register } = service.setup(setupDeps); - register(Symbol(), { id: 'app2', mount, appRoute: '/custom/path' } as any); + register(Symbol(), createApp({ id: 'app2', appRoute: '/custom/path' })); const { navigateToApp } = await service.start(startDeps); @@ -429,7 +700,7 @@ describe('#start()', () => { const { registerLegacyApp } = service.setup(setupDeps); - registerLegacyApp({ id: 'baseApp:legacyApp1' } as any); + registerLegacyApp(createLegacyApp({ id: 'baseApp:legacyApp1' })); const { navigateToApp } = await service.start(startDeps); diff --git a/src/core/public/application/application_service.tsx b/src/core/public/application/application_service.tsx index 5b464737ffe07..c69b96274aa95 100644 --- a/src/core/public/application/application_service.tsx +++ b/src/core/public/application/application_service.tsx @@ -18,8 +18,8 @@ */ import React from 'react'; -import { BehaviorSubject, Subject } from 'rxjs'; -import { takeUntil } from 'rxjs/operators'; +import { BehaviorSubject, Observable, Subject, Subscription } from 'rxjs'; +import { map, takeUntil } from 'rxjs/operators'; import { createBrowserHistory, History } from 'history'; import { InjectedMetadataSetup } from '../injected_metadata'; @@ -27,18 +27,23 @@ import { HttpSetup, HttpStart } from '../http'; import { OverlayStart } from '../overlays'; import { ContextSetup, IContextContainer } from '../context'; import { AppRouter } from './ui'; -import { CapabilitiesService, Capabilities } from './capabilities'; +import { Capabilities, CapabilitiesService } from './capabilities'; import { App, + AppBase, AppLeaveHandler, - LegacyApp, AppMount, AppMountDeprecated, AppMounter, - LegacyAppMounter, - Mounter, + AppNavLinkStatus, + AppStatus, + AppUpdatableFields, + AppUpdater, InternalApplicationSetup, InternalApplicationStart, + LegacyApp, + LegacyAppMounter, + Mounter, } from './types'; import { getLeaveAction, isConfirmAction } from './application_leave'; @@ -62,12 +67,13 @@ interface StartDeps { // Mount functions with two arguments are assumed to expect deprecated `context` object. const isAppMountDeprecated = (mount: (...args: any[]) => any): mount is AppMountDeprecated => mount.length === 2; -const filterAvailable = (map: Map, capabilities: Capabilities) => - new Map( - [...map].filter( +function filterAvailable(m: Map, capabilities: Capabilities) { + return new Map( + [...m].filter( ([id]) => capabilities.navLinks[id] === undefined || capabilities.navLinks[id] === true ) ); +} const findMounter = (mounters: Map, appRoute?: string) => [...mounters].find(([, mounter]) => mounter.appRoute === appRoute); const getAppUrl = (mounters: Map, appId: string, path: string = '') => @@ -75,17 +81,25 @@ const getAppUrl = (mounters: Map, appId: string, path: string = .replace(/\/{2,}/g, '/') // Remove duplicate slashes .replace(/\/$/, ''); // Remove trailing slash +const allApplicationsFilter = '__ALL__'; + +interface AppUpdaterWrapper { + application: string; + updater: AppUpdater; +} + /** * Service that is responsible for registering new applications. * @internal */ export class ApplicationService { - private readonly apps = new Map(); - private readonly legacyApps = new Map(); + private readonly apps = new Map(); private readonly mounters = new Map(); private readonly capabilities = new CapabilitiesService(); private readonly appLeaveHandlers = new Map(); private currentAppId$ = new BehaviorSubject(undefined); + private readonly statusUpdaters$ = new BehaviorSubject>(new Map()); + private readonly subscriptions: Subscription[] = []; private stop$ = new Subject(); private registrationClosed = false; private history?: History; @@ -109,8 +123,22 @@ export class ApplicationService { this.navigate = (url, state) => // basePath not needed here because `history` is configured with basename this.history ? this.history.push(url, state) : redirectTo(basePath.prepend(url)); + this.mountContext = context.createContextContainer(); + const registerStatusUpdater = (application: string, updater$: Observable) => { + const updaterId = Symbol(); + const subscription = updater$.subscribe(updater => { + const nextValue = new Map(this.statusUpdaters$.getValue()); + nextValue.set(updaterId, { + application, + updater, + }); + this.statusUpdaters$.next(nextValue); + }); + this.subscriptions.push(subscription); + }; + return { registerMountContext: this.mountContext!.registerContext, register: (plugin, app) => { @@ -145,7 +173,17 @@ export class ApplicationService { this.currentAppId$.next(app.id); return unmount; }; - this.apps.set(app.id, app); + + const { updater$, ...appProps } = app; + this.apps.set(app.id, { + ...appProps, + status: app.status ?? AppStatus.accessible, + navLinkStatus: app.navLinkStatus ?? AppNavLinkStatus.default, + legacy: false, + }); + if (updater$) { + registerStatusUpdater(app.id, updater$); + } this.mounters.set(app.id, { appRoute: app.appRoute!, appBasePath: basePath.prepend(app.appRoute!), @@ -158,15 +196,25 @@ export class ApplicationService { if (this.registrationClosed) { throw new Error('Applications cannot be registered after "setup"'); - } else if (this.legacyApps.has(app.id)) { - throw new Error(`A legacy application is already registered with the id "${app.id}"`); + } else if (this.apps.has(app.id)) { + throw new Error(`An application is already registered with the id "${app.id}"`); } else if (basename && appRoute!.startsWith(basename)) { throw new Error('Cannot register an application route that includes HTTP base path'); } const appBasePath = basePath.prepend(appRoute); const mount: LegacyAppMounter = () => redirectTo(appBasePath); - this.legacyApps.set(app.id, app); + + const { updater$, ...appProps } = app; + this.apps.set(app.id, { + ...appProps, + status: app.status ?? AppStatus.accessible, + navLinkStatus: app.navLinkStatus ?? AppNavLinkStatus.default, + legacy: true, + }); + if (updater$) { + registerStatusUpdater(app.id, updater$); + } this.mounters.set(app.id, { appRoute, appBasePath, @@ -174,6 +222,8 @@ export class ApplicationService { unmountBeforeMounting: true, }); }, + registerAppUpdater: (appUpdater$: Observable) => + registerStatusUpdater(allApplicationsFilter, appUpdater$), }; } @@ -190,16 +240,35 @@ export class ApplicationService { http, }); const availableMounters = filterAvailable(this.mounters, capabilities); + const availableApps = filterAvailable(this.apps, capabilities); + + const applications$ = new BehaviorSubject(availableApps); + this.statusUpdaters$ + .pipe( + map(statusUpdaters => { + return new Map( + [...availableApps].map(([id, app]) => [ + id, + updateStatus(app, [...statusUpdaters.values()]), + ]) + ); + }) + ) + .subscribe(apps => applications$.next(apps)); return { - availableApps: filterAvailable(this.apps, capabilities), - availableLegacyApps: filterAvailable(this.legacyApps, capabilities), + applications$, capabilities, currentAppId$: this.currentAppId$.pipe(takeUntil(this.stop$)), registerMountContext: this.mountContext.registerContext, getUrlForApp: (appId, { path }: { path?: string } = {}) => getAppUrl(availableMounters, appId, path), navigateToApp: async (appId, { path, state }: { path?: string; state?: any } = {}) => { + const app = applications$.value.get(appId); + if (app && app.status !== AppStatus.accessible) { + // should probably redirect to the error page instead + throw new Error(`Trying to navigate to an inaccessible application: ${appId}`); + } if (await this.shouldNavigate(overlays)) { this.appLeaveHandlers.delete(this.currentAppId$.value!); this.navigate!(getAppUrl(availableMounters, appId, path), state); @@ -259,6 +328,32 @@ export class ApplicationService { public stop() { this.stop$.next(); this.currentAppId$.complete(); + this.statusUpdaters$.complete(); + this.subscriptions.forEach(sub => sub.unsubscribe()); window.removeEventListener('beforeunload', this.onBeforeUnload); } } + +const updateStatus = (app: T, statusUpdaters: AppUpdaterWrapper[]): T => { + let changes: Partial = {}; + statusUpdaters.forEach(wrapper => { + if (wrapper.application !== allApplicationsFilter && wrapper.application !== app.id) { + return; + } + const fields = wrapper.updater(app); + if (fields) { + changes = { + ...changes, + ...fields, + // status and navLinkStatus enums are ordered by reversed priority + // if multiple updaters wants to change these fields, we will always follow the priority order. + status: Math.max(changes.status ?? 0, fields.status ?? 0), + navLinkStatus: Math.max(changes.navLinkStatus ?? 0, fields.navLinkStatus ?? 0), + }; + } + }); + return { + ...app, + ...changes, + }; +}; diff --git a/src/core/public/application/index.ts b/src/core/public/application/index.ts index 17fec9261accf..e7ea330657648 100644 --- a/src/core/public/application/index.ts +++ b/src/core/public/application/index.ts @@ -27,6 +27,10 @@ export { AppUnmount, AppMountContext, AppMountParameters, + AppStatus, + AppNavLinkStatus, + AppUpdatableFields, + AppUpdater, ApplicationSetup, ApplicationStart, AppLeaveHandler, diff --git a/src/core/public/application/types.ts b/src/core/public/application/types.ts index 4caf236979c37..0d955482d2226 100644 --- a/src/core/public/application/types.ts +++ b/src/core/public/application/types.ts @@ -34,6 +34,9 @@ import { SavedObjectsStart } from '../saved_objects'; /** @public */ export interface AppBase { + /** + * The unique identifier of the application + */ id: string; /** @@ -41,15 +44,62 @@ export interface AppBase { */ title: string; + /** + * The initial status of the application. + * Defaulting to `accessible` + */ + status?: AppStatus; + + /** + * The initial status of the application's navLink. + * Defaulting to `visible` if `status` is `accessible` and `hidden` if status is `inaccessible` + * See {@link AppNavLinkStatus} + */ + navLinkStatus?: AppNavLinkStatus; + + /** + * An {@link AppUpdater} observable that can be used to update the application {@link AppUpdatableFields} at runtime. + * + * @example + * + * How to update an application navLink at runtime + * + * ```ts + * // inside your plugin's setup function + * export class MyPlugin implements Plugin { + * private appUpdater = new BehaviorSubject(() => ({})); + * + * setup({ application }) { + * application.register({ + * id: 'my-app', + * title: 'My App', + * updater$: this.appUpdater, + * async mount(params) { + * const { renderApp } = await import('./application'); + * return renderApp(params); + * }, + * }); + * } + * + * start() { + * // later, when the navlink needs to be updated + * appUpdater.next(() => { + * navLinkStatus: AppNavLinkStatus.disabled, + * }) + * } + * ``` + */ + updater$?: Observable; + /** * An ordinal used to sort nav links relative to one another for display. */ order?: number; /** - * An observable for a tooltip shown when hovering over app link. + * A tooltip shown when hovering over app link. */ - tooltip$?: Observable; + tooltip?: string; /** * A EUI iconType that will be used for the app's icon. This icon @@ -67,8 +117,76 @@ export interface AppBase { * Custom capabilities defined by the app. */ capabilities?: Partial; + + /** + * Flag to keep track of legacy applications. + * For internal use only. any value will be overridden when registering an App. + * + * @internal + */ + legacy?: boolean; + + /** + * Hide the UI chrome when the application is mounted. Defaults to `false`. + * Takes precedence over chrome service visibility settings. + */ + chromeless?: boolean; } +/** + * Accessibility status of an application. + * + * @public + */ +export enum AppStatus { + /** + * Application is accessible. + */ + accessible = 0, + /** + * Application is not accessible. + */ + inaccessible = 1, +} + +/** + * Status of the application's navLink. + * + * @public + */ +export enum AppNavLinkStatus { + /** + * The application navLink will be `visible` if the application's {@link AppStatus} is set to `accessible` + * and `hidden` if the application status is set to `inaccessible`. + */ + default = 0, + /** + * The application navLink is visible and clickable in the navigation bar. + */ + visible = 1, + /** + * The application navLink is visible but inactive and not clickable in the navigation bar. + */ + disabled = 2, + /** + * The application navLink does not appear in the navigation bar. + */ + hidden = 3, +} + +/** + * Defines the list of fields that can be updated via an {@link AppUpdater}. + * @public + */ +export type AppUpdatableFields = Pick; + +/** + * Updater for applications. + * see {@link ApplicationSetup} + * @public + */ +export type AppUpdater = (app: AppBase) => Partial | undefined; + /** * Extension of {@link AppBase | common app properties} with the mount function. * @public @@ -374,6 +492,35 @@ export interface ApplicationSetup { */ register(app: App): void; + /** + * Register an application updater that can be used to change the {@link AppUpdatableFields} fields + * of all applications at runtime. + * + * This is meant to be used by plugins that needs to updates the whole list of applications. + * To only updates a specific application, use the `updater$` property of the registered application instead. + * + * @example + * + * How to register an application updater that disables some applications: + * + * ```ts + * // inside your plugin's setup function + * export class MyPlugin implements Plugin { + * setup({ application }) { + * application.registerAppUpdater( + * new BehaviorSubject(app => { + * if (myPluginApi.shouldDisable(app)) + * return { + * status: AppStatus.inaccessible, + * }; + * }) + * ); + * } + * } + * ``` + */ + registerAppUpdater(appUpdater$: Observable): void; + /** * Register a context provider for application mounting. Will only be available to applications that depend on the * plugin that registered this context. Deprecated, use {@link CoreSetup.getStartServices}. @@ -389,7 +536,7 @@ export interface ApplicationSetup { } /** @internal */ -export interface InternalApplicationSetup { +export interface InternalApplicationSetup extends Pick { /** * Register an mountable application to the system. * @param plugin - opaque ID of the plugin that registers this application @@ -462,16 +609,11 @@ export interface ApplicationStart { export interface InternalApplicationStart extends Pick { /** - * Apps available based on the current capabilities. Should be used - * to show navigation links and make routing decisions. - */ - availableApps: ReadonlyMap; - /** - * Apps available based on the current capabilities. Should be used - * to show navigation links and make routing decisions. - * @internal + * Apps available based on the current capabilities. + * Should be used to show navigation links and make routing decisions. + * Applications manually disabled from the client-side using {@link AppUpdater} */ - availableLegacyApps: ReadonlyMap; + applications$: Observable>; /** * Register a context provider for application mounting. Will only be available to applications that depend on the diff --git a/src/core/public/chrome/chrome_service.test.ts b/src/core/public/chrome/chrome_service.test.ts index d9c35b20db03b..abd04722a49f2 100644 --- a/src/core/public/chrome/chrome_service.test.ts +++ b/src/core/public/chrome/chrome_service.test.ts @@ -18,7 +18,7 @@ */ import * as Rx from 'rxjs'; -import { toArray } from 'rxjs/operators'; +import { take, toArray } from 'rxjs/operators'; import { shallow } from 'enzyme'; import React from 'react'; @@ -54,7 +54,9 @@ function defaultStartDeps(availableApps?: App[]) { }; if (availableApps) { - deps.application.availableApps = new Map(availableApps.map(app => [app.id, app])); + deps.application.applications$ = new Rx.BehaviorSubject>( + new Map(availableApps.map(app => [app.id, app])) + ); } return deps; @@ -211,13 +213,14 @@ describe('start', () => { new FakeApp('beta', true), new FakeApp('gamma', false), ]); - const { availableApps, navigateToApp } = startDeps.application; + const { applications$, navigateToApp } = startDeps.application; const { chrome, service } = await start({ startDeps }); const promise = chrome .getIsVisible$() .pipe(toArray()) .toPromise(); + const availableApps = await applications$.pipe(take(1)).toPromise(); [...availableApps.keys()].forEach(appId => navigateToApp(appId)); service.stop(); diff --git a/src/core/public/chrome/chrome_service.tsx b/src/core/public/chrome/chrome_service.tsx index 18c0c9870d72f..a674b49a8e134 100644 --- a/src/core/public/chrome/chrome_service.tsx +++ b/src/core/public/chrome/chrome_service.tsx @@ -19,7 +19,7 @@ import React from 'react'; import { BehaviorSubject, Observable, ReplaySubject, combineLatest, of, merge } from 'rxjs'; -import { map, takeUntil } from 'rxjs/operators'; +import { flatMap, map, takeUntil } from 'rxjs/operators'; import { parse } from 'url'; import { i18n } from '@kbn/i18n'; @@ -118,11 +118,12 @@ export class ChromeService { // combineLatest below regardless of having an application value yet. of(isEmbedded), application.currentAppId$.pipe( - map( - appId => - !!appId && - application.availableApps.has(appId) && - !!application.availableApps.get(appId)!.chromeless + flatMap(appId => + application.applications$.pipe( + map(applications => { + return !!appId && applications.has(appId) && !!applications.get(appId)!.chromeless; + }) + ) ) ) ); diff --git a/src/core/public/chrome/nav_links/nav_links_service.test.ts b/src/core/public/chrome/nav_links/nav_links_service.test.ts index 5a45491df28e7..3d9a4bfdb6a56 100644 --- a/src/core/public/chrome/nav_links/nav_links_service.test.ts +++ b/src/core/public/chrome/nav_links/nav_links_service.test.ts @@ -20,34 +20,47 @@ import { NavLinksService } from './nav_links_service'; import { take, map, takeLast } from 'rxjs/operators'; import { App, LegacyApp } from '../../application'; +import { BehaviorSubject } from 'rxjs'; -const mockAppService = { - availableApps: new Map( - ([ - { id: 'app1', order: 0, title: 'App 1', icon: 'app1' }, - { - id: 'app2', - order: -10, - title: 'App 2', - euiIconType: 'canvasApp', - }, - { id: 'chromelessApp', order: 20, title: 'Chromless App', chromeless: true }, - ] as App[]).map(app => [app.id, app]) - ), - availableLegacyApps: new Map( - ([ - { id: 'legacyApp1', order: 5, title: 'Legacy App 1', icon: 'legacyApp1', appUrl: '/app1' }, - { - id: 'legacyApp2', - order: -5, - title: 'Legacy App 2', - euiIconType: 'canvasApp', - appUrl: '/app2', - }, - { id: 'legacyApp3', order: 15, title: 'Legacy App 3', appUrl: '/app3' }, - ] as LegacyApp[]).map(app => [app.id, app]) - ), -} as any; +const availableApps = new Map([ + ['app1', { id: 'app1', order: 0, title: 'App 1', icon: 'app1' }], + [ + 'app2', + { + id: 'app2', + order: -10, + title: 'App 2', + euiIconType: 'canvasApp', + }, + ], + ['chromelessApp', { id: 'chromelessApp', order: 20, title: 'Chromless App', chromeless: true }], + [ + 'legacyApp1', + { + id: 'legacyApp1', + order: 5, + title: 'Legacy App 1', + icon: 'legacyApp1', + appUrl: '/app1', + legacy: true, + }, + ], + [ + 'legacyApp2', + { + id: 'legacyApp2', + order: -10, + title: 'Legacy App 2', + euiIconType: 'canvasApp', + appUrl: '/app2', + legacy: true, + }, + ], + [ + 'legacyApp3', + { id: 'legacyApp3', order: 20, title: 'Legacy App 3', appUrl: '/app3', legacy: true }, + ], +]); const mockHttp = { basePath: { @@ -57,10 +70,16 @@ const mockHttp = { describe('NavLinksService', () => { let service: NavLinksService; + let mockAppService: any; let start: ReturnType; beforeEach(() => { service = new NavLinksService(); + mockAppService = { + applications$: new BehaviorSubject>( + availableApps as any + ), + }; start = service.start({ application: mockAppService, http: mockHttp }); }); @@ -183,22 +202,36 @@ describe('NavLinksService', () => { .toPromise() ).toEqual(['legacyApp1']); }); + + it('still removes all other links when availableApps are re-emitted', async () => { + start.showOnly('legacyApp2'); + mockAppService.applications$.next(mockAppService.applications$.value); + expect( + await start + .getNavLinks$() + .pipe( + take(1), + map(links => links.map(l => l.id)) + ) + .toPromise() + ).toEqual(['legacyApp2']); + }); }); describe('#update()', () => { it('updates the navlinks and returns the updated link', async () => { - expect(start.update('legacyApp1', { hidden: true })).toMatchInlineSnapshot(` - Object { - "appUrl": "/app1", - "baseUrl": "http://localhost/wow/app1", - "hidden": true, - "icon": "legacyApp1", - "id": "legacyApp1", - "legacy": true, - "order": 5, - "title": "Legacy App 1", - } - `); + expect(start.update('legacyApp1', { hidden: true })).toEqual( + expect.objectContaining({ + appUrl: '/app1', + disabled: false, + hidden: true, + icon: 'legacyApp1', + id: 'legacyApp1', + legacy: true, + order: 5, + title: 'Legacy App 1', + }) + ); const hiddenLinkIds = await start .getNavLinks$() .pipe( @@ -212,6 +245,19 @@ describe('NavLinksService', () => { it('returns undefined if link does not exist', () => { expect(start.update('fake', { hidden: true })).toBeUndefined(); }); + + it('keeps the updated link when availableApps are re-emitted', async () => { + start.update('legacyApp1', { hidden: true }); + mockAppService.applications$.next(mockAppService.applications$.value); + const hiddenLinkIds = await start + .getNavLinks$() + .pipe( + take(1), + map(links => links.filter(l => l.hidden).map(l => l.id)) + ) + .toPromise(); + expect(hiddenLinkIds).toEqual(['legacyApp1']); + }); }); describe('#enableForcedAppSwitcherNavigation()', () => { diff --git a/src/core/public/chrome/nav_links/nav_links_service.ts b/src/core/public/chrome/nav_links/nav_links_service.ts index 31a729f90cd93..650ef77b6fe42 100644 --- a/src/core/public/chrome/nav_links/nav_links_service.ts +++ b/src/core/public/chrome/nav_links/nav_links_service.ts @@ -18,11 +18,13 @@ */ import { sortBy } from 'lodash'; -import { BehaviorSubject, ReplaySubject, Observable } from 'rxjs'; +import { BehaviorSubject, combineLatest, Observable, ReplaySubject } from 'rxjs'; import { map, takeUntil } from 'rxjs/operators'; -import { NavLinkWrapper, ChromeNavLinkUpdateableFields, ChromeNavLink } from './nav_link'; + import { InternalApplicationStart } from '../../application'; import { HttpStart } from '../../http'; +import { ChromeNavLink, ChromeNavLinkUpdateableFields, NavLinkWrapper } from './nav_link'; +import { toNavLink } from './to_nav_link'; interface StartDeps { application: InternalApplicationStart; @@ -95,39 +97,38 @@ export interface ChromeNavLinks { getForceAppSwitcherNavigation$(): Observable; } +type LinksUpdater = (navLinks: Map) => Map; + export class NavLinksService { private readonly stop$ = new ReplaySubject(1); public start({ application, http }: StartDeps): ChromeNavLinks { - const appLinks = [...application.availableApps] - .filter(([, app]) => !app.chromeless) - .map( - ([appId, app]) => - [ - appId, - new NavLinkWrapper({ - ...app, - legacy: false, - baseUrl: relativeToAbsolute(http.basePath.prepend(`/app/${appId}`)), - }), - ] as [string, NavLinkWrapper] - ); - - const legacyAppLinks = [...application.availableLegacyApps].map( - ([appId, app]) => - [ - appId, - new NavLinkWrapper({ - ...app, - legacy: true, - baseUrl: relativeToAbsolute(http.basePath.prepend(app.appUrl)), - }), - ] as [string, NavLinkWrapper] + const appLinks$ = application.applications$.pipe( + map(apps => { + return new Map( + [...apps] + .filter(([, app]) => !app.chromeless) + .map(([appId, app]) => [appId, toNavLink(app, http.basePath)]) + ); + }) ); - const navLinks$ = new BehaviorSubject>( - new Map([...legacyAppLinks, ...appLinks]) - ); + // now that availableApps$ is an observable, we need to keep record of all + // manual link modifications to be able to re-apply then after every + // availableApps$ changes. + const linkUpdaters$ = new BehaviorSubject([]); + const navLinks$ = new BehaviorSubject>(new Map()); + + combineLatest([appLinks$, linkUpdaters$]) + .pipe( + map(([appLinks, linkUpdaters]) => { + return linkUpdaters.reduce((links, updater) => updater(links), appLinks); + }) + ) + .subscribe(navlinks => { + navLinks$.next(navlinks); + }); + const forceAppSwitcherNavigation$ = new BehaviorSubject(false); return { @@ -153,7 +154,10 @@ export class NavLinksService { return; } - navLinks$.next(new Map([...navLinks$.value.entries()].filter(([linkId]) => linkId === id))); + const updater: LinksUpdater = navLinks => + new Map([...navLinks.entries()].filter(([linkId]) => linkId === id)); + + linkUpdaters$.next([...linkUpdaters$.value, updater]); }, update(id: string, values: ChromeNavLinkUpdateableFields) { @@ -161,17 +165,17 @@ export class NavLinksService { return; } - navLinks$.next( + const updater: LinksUpdater = navLinks => new Map( - [...navLinks$.value.entries()].map(([linkId, link]) => { + [...navLinks.entries()].map(([linkId, link]) => { return [linkId, link.id === id ? link.update(values) : link] as [ string, NavLinkWrapper ]; }) - ) - ); + ); + linkUpdaters$.next([...linkUpdaters$.value, updater]); return this.get(id); }, @@ -196,10 +200,3 @@ function sortNavLinks(navLinks: ReadonlyMap) { 'order' ); } - -function relativeToAbsolute(url: string) { - // convert all link urls to absolute urls - const a = document.createElement('a'); - a.setAttribute('href', url); - return a.href; -} diff --git a/src/core/public/chrome/nav_links/to_nav_link.test.ts b/src/core/public/chrome/nav_links/to_nav_link.test.ts new file mode 100644 index 0000000000000..23fdabe0f3430 --- /dev/null +++ b/src/core/public/chrome/nav_links/to_nav_link.test.ts @@ -0,0 +1,178 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +import { App, AppMount, AppNavLinkStatus, AppStatus, LegacyApp } from '../../application'; +import { toNavLink } from './to_nav_link'; + +import { httpServiceMock } from '../../mocks'; + +function mount() {} + +const app = (props: Partial = {}): App => ({ + mount: (mount as unknown) as AppMount, + id: 'some-id', + title: 'some-title', + status: AppStatus.accessible, + navLinkStatus: AppNavLinkStatus.default, + appRoute: `/app/some-id`, + legacy: false, + ...props, +}); + +const legacyApp = (props: Partial = {}): LegacyApp => ({ + appUrl: '/my-app-url', + id: 'some-id', + title: 'some-title', + status: AppStatus.accessible, + navLinkStatus: AppNavLinkStatus.default, + legacy: true, + ...props, +}); + +describe('toNavLink', () => { + const basePath = httpServiceMock.createSetupContract({ basePath: '/base-path' }).basePath; + + it('uses the application properties when creating the navLink', () => { + const link = toNavLink( + app({ + id: 'id', + title: 'title', + order: 12, + tooltip: 'tooltip', + euiIconType: 'my-icon', + }), + basePath + ); + expect(link.properties).toEqual( + expect.objectContaining({ + id: 'id', + title: 'title', + order: 12, + tooltip: 'tooltip', + euiIconType: 'my-icon', + }) + ); + }); + + it('flags legacy apps when converting to navLink', () => { + expect(toNavLink(app({}), basePath).properties.legacy).toEqual(false); + expect(toNavLink(legacyApp({}), basePath).properties.legacy).toEqual(true); + }); + + it('handles applications with custom app route', () => { + const link = toNavLink( + app({ + appRoute: '/my-route/my-path', + }), + basePath + ); + expect(link.properties.baseUrl).toEqual('http://localhost/base-path/my-route/my-path'); + }); + + it('uses appUrl when converting legacy applications', () => { + expect( + toNavLink( + legacyApp({ + appUrl: '/my-legacy-app/#foo', + }), + basePath + ).properties + ).toEqual( + expect.objectContaining({ + baseUrl: 'http://localhost/base-path/my-legacy-app/#foo', + }) + ); + }); + + it('uses the application status when the navLinkStatus is set to default', () => { + expect( + toNavLink( + app({ + navLinkStatus: AppNavLinkStatus.default, + status: AppStatus.accessible, + }), + basePath + ).properties + ).toEqual( + expect.objectContaining({ + disabled: false, + hidden: false, + }) + ); + + expect( + toNavLink( + app({ + navLinkStatus: AppNavLinkStatus.default, + status: AppStatus.inaccessible, + }), + basePath + ).properties + ).toEqual( + expect.objectContaining({ + disabled: false, + hidden: true, + }) + ); + }); + + it('uses the navLinkStatus of the application to set the hidden and disabled properties', () => { + expect( + toNavLink( + app({ + navLinkStatus: AppNavLinkStatus.visible, + }), + basePath + ).properties + ).toEqual( + expect.objectContaining({ + disabled: false, + hidden: false, + }) + ); + + expect( + toNavLink( + app({ + navLinkStatus: AppNavLinkStatus.hidden, + }), + basePath + ).properties + ).toEqual( + expect.objectContaining({ + disabled: false, + hidden: true, + }) + ); + + expect( + toNavLink( + app({ + navLinkStatus: AppNavLinkStatus.disabled, + }), + basePath + ).properties + ).toEqual( + expect.objectContaining({ + disabled: true, + hidden: false, + }) + ); + }); +}); diff --git a/src/core/public/chrome/nav_links/to_nav_link.ts b/src/core/public/chrome/nav_links/to_nav_link.ts new file mode 100644 index 0000000000000..18e4b7b26b6ba --- /dev/null +++ b/src/core/public/chrome/nav_links/to_nav_link.ts @@ -0,0 +1,48 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +import { App, AppNavLinkStatus, AppStatus, LegacyApp } from '../../application'; +import { IBasePath } from '../../http'; +import { NavLinkWrapper } from './nav_link'; + +export function toNavLink(app: App | LegacyApp, basePath: IBasePath): NavLinkWrapper { + const useAppStatus = app.navLinkStatus === AppNavLinkStatus.default; + return new NavLinkWrapper({ + ...app, + hidden: useAppStatus + ? app.status === AppStatus.inaccessible + : app.navLinkStatus === AppNavLinkStatus.hidden, + disabled: useAppStatus ? false : app.navLinkStatus === AppNavLinkStatus.disabled, + legacy: isLegacyApp(app), + baseUrl: isLegacyApp(app) + ? relativeToAbsolute(basePath.prepend(app.appUrl)) + : relativeToAbsolute(basePath.prepend(app.appRoute!)), + }); +} + +function relativeToAbsolute(url: string) { + // convert all link urls to absolute urls + const a = document.createElement('a'); + a.setAttribute('href', url); + return a.href; +} + +function isLegacyApp(app: App | LegacyApp): app is LegacyApp { + return app.legacy === true; +} diff --git a/src/core/public/chrome/ui/header/header.tsx b/src/core/public/chrome/ui/header/header.tsx index 75f78ac8b2fa0..0447add491788 100644 --- a/src/core/public/chrome/ui/header/header.tsx +++ b/src/core/public/chrome/ui/header/header.tsx @@ -309,7 +309,7 @@ class HeaderUI extends Component { .filter(navLink => !navLink.hidden) .map(navLink => ({ key: navLink.id, - label: navLink.title, + label: navLink.tooltip ?? navLink.title, // Use href and onClick to support "open in new tab" and SPA navigation in the same link href: navLink.href, diff --git a/src/core/public/index.ts b/src/core/public/index.ts index ea704749c6131..5b17eccc37f8b 100644 --- a/src/core/public/index.ts +++ b/src/core/public/index.ts @@ -94,6 +94,10 @@ export { AppLeaveAction, AppLeaveDefaultAction, AppLeaveConfirmAction, + AppStatus, + AppNavLinkStatus, + AppUpdatableFields, + AppUpdater, } from './application'; export { diff --git a/src/core/public/legacy/legacy_service.ts b/src/core/public/legacy/legacy_service.ts index a4fdd86de5311..f906aff1759e2 100644 --- a/src/core/public/legacy/legacy_service.ts +++ b/src/core/public/legacy/legacy_service.ts @@ -81,6 +81,7 @@ export class LegacyPlatformService { ...core, getStartServices: () => this.startDependencies, application: { + ...core.application, register: notSupported(`core.application.register()`), registerMountContext: notSupported(`core.application.registerMountContext()`), }, diff --git a/src/core/public/notifications/toasts/global_toast_list.test.tsx b/src/core/public/notifications/toasts/global_toast_list.test.tsx index 61d73ac233188..dc2a9dabe791e 100644 --- a/src/core/public/notifications/toasts/global_toast_list.test.tsx +++ b/src/core/public/notifications/toasts/global_toast_list.test.tsx @@ -57,9 +57,9 @@ it('subscribes to toasts$ on mount and unsubscribes on unmount', () => { it('passes latest value from toasts$ to ', () => { const el = shallow( render({ - toasts$: Rx.from([[], [{ id: 1 }], [{ id: 1 }, { id: 2 }]]) as any, + toasts$: Rx.from([[], [{ id: '1' }], [{ id: '1' }, { id: '2' }]]) as any, }) ); - expect(el.find(EuiGlobalToastList).prop('toasts')).toEqual([{ id: 1 }, { id: 2 }]); + expect(el.find(EuiGlobalToastList).prop('toasts')).toEqual([{ id: '1' }, { id: '2' }]); }); diff --git a/src/core/public/plugins/plugin_context.ts b/src/core/public/plugins/plugin_context.ts index 848f46605d4de..f146c2452868b 100644 --- a/src/core/public/plugins/plugin_context.ts +++ b/src/core/public/plugins/plugin_context.ts @@ -96,6 +96,7 @@ export function createPluginSetupContext< return { application: { register: app => deps.application.register(plugin.opaqueId, app), + registerAppUpdater: statusUpdater$ => deps.application.registerAppUpdater(statusUpdater$), registerMountContext: (contextName, provider) => deps.application.registerMountContext(plugin.opaqueId, contextName, provider), }, diff --git a/src/core/public/public.api.md b/src/core/public/public.api.md index c76d6191de8a3..aef689162f45a 100644 --- a/src/core/public/public.api.md +++ b/src/core/public/public.api.md @@ -26,13 +26,18 @@ export interface App extends AppBase { // @public (undocumented) export interface AppBase { capabilities?: Partial; + chromeless?: boolean; euiIconType?: string; icon?: string; - // (undocumented) id: string; + // @internal + legacy?: boolean; + navLinkStatus?: AppNavLinkStatus; order?: number; + status?: AppStatus; title: string; - tooltip$?: Observable; + tooltip?: string; + updater$?: Observable; } // @public @@ -74,6 +79,7 @@ export type AppLeaveHandler = (factory: AppLeaveActionFactory) => AppLeaveAction // @public (undocumented) export interface ApplicationSetup { register(app: App): void; + registerAppUpdater(appUpdater$: Observable): void; // @deprecated registerMountContext(contextName: T, provider: IContextProvider): void; } @@ -123,9 +129,29 @@ export interface AppMountParameters { onAppLeave: (handler: AppLeaveHandler) => void; } +// @public +export enum AppNavLinkStatus { + default = 0, + disabled = 2, + hidden = 3, + visible = 1 +} + +// @public +export enum AppStatus { + accessible = 0, + inaccessible = 1 +} + // @public export type AppUnmount = () => void; +// @public +export type AppUpdatableFields = Pick; + +// @public +export type AppUpdater = (app: AppBase) => Partial | undefined; + // @public export interface Capabilities { [key: string]: Record>; diff --git a/test/functional/services/apps_menu.ts b/test/functional/services/apps_menu.ts index a4cd98b2a06ec..fe17532f6a41a 100644 --- a/test/functional/services/apps_menu.ts +++ b/test/functional/services/apps_menu.ts @@ -25,7 +25,7 @@ export function AppsMenuProvider({ getService }: FtrProviderContext) { return new (class AppsMenu { /** - * Get the text and href from each of the links in the apps menu + * Get the attributes from each of the links in the apps menu */ public async readLinks() { const appMenu = await testSubjects.find('navDrawer'); @@ -37,12 +37,21 @@ export function AppsMenuProvider({ getService }: FtrProviderContext) { return { text: $(link).text(), href: $(link).attr('href'), + disabled: $(link).attr('disabled') != null, }; }); return links; } + /** + * Get the attributes from the link with the given name. + * @param name + */ + public async getLink(name: string) { + return (await this.readLinks()).find(nl => nl.text === name); + } + /** * Determine if an app link with the given name exists * @param name diff --git a/test/plugin_functional/plugins/core_app_status/kibana.json b/test/plugin_functional/plugins/core_app_status/kibana.json new file mode 100644 index 0000000000000..91d8e6fd8f9e1 --- /dev/null +++ b/test/plugin_functional/plugins/core_app_status/kibana.json @@ -0,0 +1,8 @@ +{ + "id": "core_app_status", + "version": "0.0.1", + "kibanaVersion": "kibana", + "configPath": ["core_app_status"], + "server": false, + "ui": true +} diff --git a/test/plugin_functional/plugins/core_app_status/package.json b/test/plugin_functional/plugins/core_app_status/package.json new file mode 100644 index 0000000000000..61655487c6acb --- /dev/null +++ b/test/plugin_functional/plugins/core_app_status/package.json @@ -0,0 +1,17 @@ +{ + "name": "core_app_status", + "version": "1.0.0", + "main": "target/test/plugin_functional/plugins/core_app_status", + "kibana": { + "version": "kibana", + "templateVersion": "1.0.0" + }, + "license": "Apache-2.0", + "scripts": { + "kbn": "node ../../../../scripts/kbn.js", + "build": "rm -rf './target' && tsc" + }, + "devDependencies": { + "typescript": "3.5.3" + } +} diff --git a/test/plugin_functional/plugins/core_app_status/public/application.tsx b/test/plugin_functional/plugins/core_app_status/public/application.tsx new file mode 100644 index 0000000000000..323774392a6d7 --- /dev/null +++ b/test/plugin_functional/plugins/core_app_status/public/application.tsx @@ -0,0 +1,64 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +import React from 'react'; +import { render, unmountComponentAtNode } from 'react-dom'; +import { + EuiPage, + EuiPageBody, + EuiPageContent, + EuiPageContentBody, + EuiPageContentHeader, + EuiPageContentHeaderSection, + EuiPageHeader, + EuiPageHeaderSection, + EuiTitle, +} from '@elastic/eui'; + +import { AppMountContext, AppMountParameters } from 'kibana/public'; + +const AppStatusApp = () => ( + + + + + +

Welcome to App Status Test App!

+
+
+
+ + + + +

App Status Test App home page section title

+
+
+
+ App Status Test App content +
+
+
+); + +export const renderApp = (context: AppMountContext, { element }: AppMountParameters) => { + render(, element); + + return () => unmountComponentAtNode(element); +}; diff --git a/test/plugin_functional/plugins/core_app_status/public/index.ts b/test/plugin_functional/plugins/core_app_status/public/index.ts new file mode 100644 index 0000000000000..e0ad7c25a54b8 --- /dev/null +++ b/test/plugin_functional/plugins/core_app_status/public/index.ts @@ -0,0 +1,24 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +import { PluginInitializer } from 'kibana/public'; +import { CoreAppStatusPlugin, CoreAppStatusPluginSetup, CoreAppStatusPluginStart } from './plugin'; + +export const plugin: PluginInitializer = () => + new CoreAppStatusPlugin(); diff --git a/test/plugin_functional/plugins/core_app_status/public/plugin.tsx b/test/plugin_functional/plugins/core_app_status/public/plugin.tsx new file mode 100644 index 0000000000000..85caaaf5f9090 --- /dev/null +++ b/test/plugin_functional/plugins/core_app_status/public/plugin.tsx @@ -0,0 +1,56 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +import { Plugin, CoreSetup, AppUpdater, AppUpdatableFields, CoreStart } from 'kibana/public'; +import { BehaviorSubject } from 'rxjs'; + +export class CoreAppStatusPlugin + implements Plugin { + private appUpdater = new BehaviorSubject(() => ({})); + + public setup(core: CoreSetup, deps: {}) { + core.application.register({ + id: 'app_status', + title: 'App Status', + euiIconType: 'snowflake', + updater$: this.appUpdater, + async mount(context, params) { + const { renderApp } = await import('./application'); + return renderApp(context, params); + }, + }); + + return {}; + } + + public start(core: CoreStart) { + return { + setAppStatus: (status: Partial) => { + this.appUpdater.next(() => status); + }, + navigateToApp: async (appId: string) => { + return core.application.navigateToApp(appId); + }, + }; + } + public stop() {} +} + +export type CoreAppStatusPluginSetup = ReturnType; +export type CoreAppStatusPluginStart = ReturnType; diff --git a/test/plugin_functional/plugins/core_app_status/tsconfig.json b/test/plugin_functional/plugins/core_app_status/tsconfig.json new file mode 100644 index 0000000000000..5fcaeafbb0d85 --- /dev/null +++ b/test/plugin_functional/plugins/core_app_status/tsconfig.json @@ -0,0 +1,14 @@ +{ + "extends": "../../../../tsconfig.json", + "compilerOptions": { + "outDir": "./target", + "skipLibCheck": true + }, + "include": [ + "index.ts", + "public/**/*.ts", + "public/**/*.tsx", + "../../../../typings/**/*", + ], + "exclude": [] +} diff --git a/test/plugin_functional/test_suites/core_plugins/application_status.ts b/test/plugin_functional/test_suites/core_plugins/application_status.ts new file mode 100644 index 0000000000000..703ae30533bae --- /dev/null +++ b/test/plugin_functional/test_suites/core_plugins/application_status.ts @@ -0,0 +1,116 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +import expect from '@kbn/expect'; +import { + AppNavLinkStatus, + AppStatus, + AppUpdatableFields, +} from '../../../../src/core/public/application/types'; +import { PluginFunctionalProviderContext } from '../../services'; +import { CoreAppStatusPluginStart } from '../../plugins/core_app_status/public/plugin'; +import '../../plugins/core_provider_plugin/types'; + +// eslint-disable-next-line import/no-default-export +export default function({ getService, getPageObjects }: PluginFunctionalProviderContext) { + const PageObjects = getPageObjects(['common']); + const browser = getService('browser'); + const appsMenu = getService('appsMenu'); + + const setAppStatus = async (s: Partial) => { + await browser.executeAsync(async (status: Partial, cb: Function) => { + const plugin = window.__coreProvider.start.plugins + .core_app_status as CoreAppStatusPluginStart; + plugin.setAppStatus(status); + cb(); + }, s); + }; + + const navigateToApp = async (i: string): Promise<{ error?: string }> => { + return (await browser.executeAsync(async (appId, cb: Function) => { + // navigating in legacy mode performs a page refresh + // and webdriver seems to re-execute the script after the reload + // as it considers it didn't end on the previous session. + // however when testing navigation to NP app, __coreProvider is not accessible + // so we need to check for existence. + if (!window.__coreProvider) { + cb({}); + } + const plugin = window.__coreProvider.start.plugins + .core_app_status as CoreAppStatusPluginStart; + try { + await plugin.navigateToApp(appId); + cb({}); + } catch (e) { + cb({ + error: e.message, + }); + } + }, i)) as any; + }; + + describe('application status management', () => { + beforeEach(async () => { + await PageObjects.common.navigateToApp('settings'); + }); + + it('can change the navLink status at runtime', async () => { + await setAppStatus({ + navLinkStatus: AppNavLinkStatus.disabled, + }); + let link = await appsMenu.getLink('App Status'); + expect(link).not.to.eql(undefined); + expect(link!.disabled).to.eql(true); + + await setAppStatus({ + navLinkStatus: AppNavLinkStatus.hidden, + }); + link = await appsMenu.getLink('App Status'); + expect(link).to.eql(undefined); + + await setAppStatus({ + navLinkStatus: AppNavLinkStatus.visible, + tooltip: 'Some tooltip', + }); + link = await appsMenu.getLink('Some tooltip'); // the tooltip replaces the name in the selector we use. + expect(link).not.to.eql(undefined); + expect(link!.disabled).to.eql(false); + }); + + it('shows an error when navigating to an inaccessible app', async () => { + await setAppStatus({ + status: AppStatus.inaccessible, + }); + + const result = await navigateToApp('app_status'); + expect(result.error).to.contain( + 'Trying to navigate to an inaccessible application: app_status' + ); + }); + + it('allows to navigate to an accessible app', async () => { + await setAppStatus({ + status: AppStatus.accessible, + }); + + const result = await navigateToApp('app_status'); + expect(result.error).to.eql(undefined); + }); + }); +} diff --git a/test/plugin_functional/test_suites/core_plugins/index.ts b/test/plugin_functional/test_suites/core_plugins/index.ts index 6c55245d10f03..d66e2e7dc5da7 100644 --- a/test/plugin_functional/test_suites/core_plugins/index.ts +++ b/test/plugin_functional/test_suites/core_plugins/index.ts @@ -28,5 +28,6 @@ export default function({ loadTestFile }: PluginFunctionalProviderContext) { loadTestFile(require.resolve('./ui_settings')); loadTestFile(require.resolve('./top_nav')); loadTestFile(require.resolve('./application_leave_confirm')); + loadTestFile(require.resolve('./application_status')); }); } diff --git a/x-pack/test/functional/apps/advanced_settings/feature_controls/advanced_settings_security.ts b/x-pack/test/functional/apps/advanced_settings/feature_controls/advanced_settings_security.ts index f148d62421ff8..ad4f81777e780 100644 --- a/x-pack/test/functional/apps/advanced_settings/feature_controls/advanced_settings_security.ts +++ b/x-pack/test/functional/apps/advanced_settings/feature_controls/advanced_settings_security.ts @@ -67,9 +67,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows management navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Management']); }); @@ -125,9 +123,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows Management navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Management']); }); @@ -178,9 +174,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows Management navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Discover', 'Management']); }); diff --git a/x-pack/test/functional/apps/advanced_settings/feature_controls/advanced_settings_spaces.ts b/x-pack/test/functional/apps/advanced_settings/feature_controls/advanced_settings_spaces.ts index 9ac6d4fdef19f..ee58be76928b3 100644 --- a/x-pack/test/functional/apps/advanced_settings/feature_controls/advanced_settings_spaces.ts +++ b/x-pack/test/functional/apps/advanced_settings/feature_controls/advanced_settings_spaces.ts @@ -40,9 +40,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('Management'); }); diff --git a/x-pack/test/functional/apps/apm/feature_controls/apm_security.ts b/x-pack/test/functional/apps/apm/feature_controls/apm_security.ts index 9190e0b4886ce..e2d5efac4644c 100644 --- a/x-pack/test/functional/apps/apm/feature_controls/apm_security.ts +++ b/x-pack/test/functional/apps/apm/feature_controls/apm_security.ts @@ -60,10 +60,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { it('shows apm navlink', async () => { const navLinks = await appsMenu.readLinks(); - expect(navLinks.map((link: Record) => link.text)).to.eql([ - 'APM', - 'Management', - ]); + expect(navLinks.map(link => link.text)).to.eql(['APM', 'Management']); }); it('can navigate to APM app', async () => { @@ -111,9 +108,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows apm navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['APM', 'Management']); }); @@ -166,9 +161,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it(`doesn't show APM navlink`, async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).not.to.contain('APM'); }); diff --git a/x-pack/test/functional/apps/apm/feature_controls/apm_spaces.ts b/x-pack/test/functional/apps/apm/feature_controls/apm_spaces.ts index 191ba5c4d1e25..1ac1784e0e05d 100644 --- a/x-pack/test/functional/apps/apm/feature_controls/apm_spaces.ts +++ b/x-pack/test/functional/apps/apm/feature_controls/apm_spaces.ts @@ -30,9 +30,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('APM'); }); @@ -61,9 +59,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).not.to.contain('APM'); }); diff --git a/x-pack/test/functional/apps/canvas/feature_controls/canvas_security.ts b/x-pack/test/functional/apps/canvas/feature_controls/canvas_security.ts index a58eb61ec4ca2..d0e37ec8e3f35 100644 --- a/x-pack/test/functional/apps/canvas/feature_controls/canvas_security.ts +++ b/x-pack/test/functional/apps/canvas/feature_controls/canvas_security.ts @@ -65,9 +65,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows canvas navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Canvas', 'Management']); }); @@ -143,9 +141,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows canvas navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Canvas', 'Management']); }); diff --git a/x-pack/test/functional/apps/canvas/feature_controls/canvas_spaces.ts b/x-pack/test/functional/apps/canvas/feature_controls/canvas_spaces.ts index 5a6857901536f..28b572401892b 100644 --- a/x-pack/test/functional/apps/canvas/feature_controls/canvas_spaces.ts +++ b/x-pack/test/functional/apps/canvas/feature_controls/canvas_spaces.ts @@ -40,9 +40,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('Canvas'); }); @@ -98,9 +96,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).not.to.contain('Canvas'); }); diff --git a/x-pack/test/functional/apps/dashboard/feature_controls/dashboard_security.ts b/x-pack/test/functional/apps/dashboard/feature_controls/dashboard_security.ts index aa6860b35763f..d25fae3c4894c 100644 --- a/x-pack/test/functional/apps/dashboard/feature_controls/dashboard_security.ts +++ b/x-pack/test/functional/apps/dashboard/feature_controls/dashboard_security.ts @@ -75,10 +75,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { it('shows dashboard navlink', async () => { const navLinks = await appsMenu.readLinks(); - expect(navLinks.map((link: Record) => link.text)).to.eql([ - 'Dashboard', - 'Management', - ]); + expect(navLinks.map(link => link.text)).to.eql(['Dashboard', 'Management']); }); it(`landing page shows "Create new Dashboard" button`, async () => { @@ -255,9 +252,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows dashboard navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Dashboard', 'Management']); }); diff --git a/x-pack/test/functional/apps/dashboard/feature_controls/dashboard_spaces.ts b/x-pack/test/functional/apps/dashboard/feature_controls/dashboard_spaces.ts index c1197fa7023c5..ebe08a60c2563 100644 --- a/x-pack/test/functional/apps/dashboard/feature_controls/dashboard_spaces.ts +++ b/x-pack/test/functional/apps/dashboard/feature_controls/dashboard_spaces.ts @@ -43,9 +43,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('Dashboard'); }); @@ -107,9 +105,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).not.to.contain('Dashboard'); }); diff --git a/x-pack/test/functional/apps/dev_tools/feature_controls/dev_tools_security.ts b/x-pack/test/functional/apps/dev_tools/feature_controls/dev_tools_security.ts index fd7739e6930d0..494fd71ea6f34 100644 --- a/x-pack/test/functional/apps/dev_tools/feature_controls/dev_tools_security.ts +++ b/x-pack/test/functional/apps/dev_tools/feature_controls/dev_tools_security.ts @@ -63,10 +63,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { it('shows Dev Tools navlink', async () => { const navLinks = await appsMenu.readLinks(); - expect(navLinks.map((link: Record) => link.text)).to.eql([ - 'Dev Tools', - 'Management', - ]); + expect(navLinks.map(link => link.text)).to.eql(['Dev Tools', 'Management']); }); describe('console', () => { @@ -146,9 +143,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it(`shows 'Dev Tools' navlink`, async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Dev Tools', 'Management']); }); diff --git a/x-pack/test/functional/apps/dev_tools/feature_controls/dev_tools_spaces.ts b/x-pack/test/functional/apps/dev_tools/feature_controls/dev_tools_spaces.ts index e3bc3a1c6ce11..4184d223a9686 100644 --- a/x-pack/test/functional/apps/dev_tools/feature_controls/dev_tools_spaces.ts +++ b/x-pack/test/functional/apps/dev_tools/feature_controls/dev_tools_spaces.ts @@ -40,9 +40,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('Dev Tools'); }); @@ -79,9 +77,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).not.to.contain('Dev Tools'); }); diff --git a/x-pack/test/functional/apps/discover/feature_controls/discover_security.ts b/x-pack/test/functional/apps/discover/feature_controls/discover_security.ts index 553ce459ebb18..1912b16d96f36 100644 --- a/x-pack/test/functional/apps/discover/feature_controls/discover_security.ts +++ b/x-pack/test/functional/apps/discover/feature_controls/discover_security.ts @@ -81,10 +81,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { it('shows discover navlink', async () => { const navLinks = await appsMenu.readLinks(); - expect(navLinks.map((link: Record) => link.text)).to.eql([ - 'Discover', - 'Management', - ]); + expect(navLinks.map(link => link.text)).to.eql(['Discover', 'Management']); }); it('shows save button', async () => { @@ -170,9 +167,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows discover navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Discover', 'Management']); }); diff --git a/x-pack/test/functional/apps/discover/feature_controls/discover_spaces.ts b/x-pack/test/functional/apps/discover/feature_controls/discover_spaces.ts index 3e5dcd7b0c987..e6b6f28f8b92f 100644 --- a/x-pack/test/functional/apps/discover/feature_controls/discover_spaces.ts +++ b/x-pack/test/functional/apps/discover/feature_controls/discover_spaces.ts @@ -49,9 +49,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('Discover'); }); @@ -93,9 +91,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).not.to.contain('Discover'); }); diff --git a/x-pack/test/functional/apps/endpoint/feature_controls/endpoint_spaces.ts b/x-pack/test/functional/apps/endpoint/feature_controls/endpoint_spaces.ts index 1d1fb566eb075..d8eb969b99b3b 100644 --- a/x-pack/test/functional/apps/endpoint/feature_controls/endpoint_spaces.ts +++ b/x-pack/test/functional/apps/endpoint/feature_controls/endpoint_spaces.ts @@ -30,9 +30,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await pageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('EEndpoint'); }); @@ -70,9 +68,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await pageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).not.to.contain('EEndpoint'); }); }); diff --git a/x-pack/test/functional/apps/graph/feature_controls/graph_security.ts b/x-pack/test/functional/apps/graph/feature_controls/graph_security.ts index acc8943033a1a..a2b062e6ef84f 100644 --- a/x-pack/test/functional/apps/graph/feature_controls/graph_security.ts +++ b/x-pack/test/functional/apps/graph/feature_controls/graph_security.ts @@ -64,10 +64,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { it('shows graph navlink', async () => { const navLinks = await appsMenu.readLinks(); - expect(navLinks.map((link: Record) => link.text)).to.eql([ - 'Graph', - 'Management', - ]); + expect(navLinks.map(link => link.text)).to.eql(['Graph', 'Management']); }); it('landing page shows "Create new graph" button', async () => { @@ -129,9 +126,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows graph navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Graph', 'Management']); }); @@ -183,9 +178,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it(`doesn't show graph navlink`, async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).not.to.contain('Graph'); }); diff --git a/x-pack/test/functional/apps/graph/feature_controls/graph_spaces.ts b/x-pack/test/functional/apps/graph/feature_controls/graph_spaces.ts index 0945b35ba0930..a0b0d5bef9668 100644 --- a/x-pack/test/functional/apps/graph/feature_controls/graph_spaces.ts +++ b/x-pack/test/functional/apps/graph/feature_controls/graph_spaces.ts @@ -34,9 +34,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('Graph'); }); @@ -75,9 +73,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).not.to.contain('Graph'); }); diff --git a/x-pack/test/functional/apps/index_patterns/feature_controls/index_patterns_security.ts b/x-pack/test/functional/apps/index_patterns/feature_controls/index_patterns_security.ts index 4929bb52c170c..30cdc95b38e62 100644 --- a/x-pack/test/functional/apps/index_patterns/feature_controls/index_patterns_security.ts +++ b/x-pack/test/functional/apps/index_patterns/feature_controls/index_patterns_security.ts @@ -69,9 +69,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows management navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Management']); }); @@ -125,9 +123,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows management navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Management']); }); @@ -179,9 +175,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows Management navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Discover', 'Management']); }); diff --git a/x-pack/test/functional/apps/index_patterns/feature_controls/index_patterns_spaces.ts b/x-pack/test/functional/apps/index_patterns/feature_controls/index_patterns_spaces.ts index bc8542288410c..6a2b77de17f45 100644 --- a/x-pack/test/functional/apps/index_patterns/feature_controls/index_patterns_spaces.ts +++ b/x-pack/test/functional/apps/index_patterns/feature_controls/index_patterns_spaces.ts @@ -40,9 +40,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('Management'); }); diff --git a/x-pack/test/functional/apps/infra/feature_controls/infrastructure_security.ts b/x-pack/test/functional/apps/infra/feature_controls/infrastructure_security.ts index 4d61e0996419c..5062f094061c0 100644 --- a/x-pack/test/functional/apps/infra/feature_controls/infrastructure_security.ts +++ b/x-pack/test/functional/apps/infra/feature_controls/infrastructure_security.ts @@ -60,9 +60,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows metrics navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Metrics', 'Management']); }); @@ -175,9 +173,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows metrics navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Metrics', 'Management']); }); @@ -417,9 +413,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it(`doesn't show metrics navlink`, async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.not.contain(['Metrics']); }); diff --git a/x-pack/test/functional/apps/infra/feature_controls/infrastructure_spaces.ts b/x-pack/test/functional/apps/infra/feature_controls/infrastructure_spaces.ts index 300b22e5bcbc3..7c2a11a542d66 100644 --- a/x-pack/test/functional/apps/infra/feature_controls/infrastructure_spaces.ts +++ b/x-pack/test/functional/apps/infra/feature_controls/infrastructure_spaces.ts @@ -48,9 +48,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('Metrics'); }); @@ -101,9 +99,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).not.to.contain('Metrics'); }); diff --git a/x-pack/test/functional/apps/infra/feature_controls/logs_security.ts b/x-pack/test/functional/apps/infra/feature_controls/logs_security.ts index d092e6736656e..b9634c29dac1c 100644 --- a/x-pack/test/functional/apps/infra/feature_controls/logs_security.ts +++ b/x-pack/test/functional/apps/infra/feature_controls/logs_security.ts @@ -57,9 +57,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows logs navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Logs', 'Management']); }); @@ -122,9 +120,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows logs navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Logs', 'Management']); }); @@ -187,9 +183,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it(`doesn't show logs navlink`, async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.not.contain('Logs'); }); diff --git a/x-pack/test/functional/apps/infra/feature_controls/logs_spaces.ts b/x-pack/test/functional/apps/infra/feature_controls/logs_spaces.ts index 8230b25efbbf9..6b078d2cfa71a 100644 --- a/x-pack/test/functional/apps/infra/feature_controls/logs_spaces.ts +++ b/x-pack/test/functional/apps/infra/feature_controls/logs_spaces.ts @@ -36,9 +36,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('Logs'); }); @@ -77,9 +75,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.not.contain('Logs'); }); diff --git a/x-pack/test/functional/apps/machine_learning/feature_controls/ml_security.ts b/x-pack/test/functional/apps/machine_learning/feature_controls/ml_security.ts index 8b2df502dc100..8fb6f21c778d3 100644 --- a/x-pack/test/functional/apps/machine_learning/feature_controls/ml_security.ts +++ b/x-pack/test/functional/apps/machine_learning/feature_controls/ml_security.ts @@ -80,9 +80,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it(`doesn't show ml navlink`, async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).not.to.contain('Machine Learning'); }); }); @@ -103,9 +101,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows ML navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('Machine Learning'); }); }); diff --git a/x-pack/test/functional/apps/machine_learning/feature_controls/ml_spaces.ts b/x-pack/test/functional/apps/machine_learning/feature_controls/ml_spaces.ts index 13036737218bc..fc94688e98811 100644 --- a/x-pack/test/functional/apps/machine_learning/feature_controls/ml_spaces.ts +++ b/x-pack/test/functional/apps/machine_learning/feature_controls/ml_spaces.ts @@ -39,9 +39,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('Machine Learning'); }); @@ -71,9 +69,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).not.to.contain('Machine Learning'); }); diff --git a/x-pack/test/functional/apps/maps/feature_controls/maps_security.ts b/x-pack/test/functional/apps/maps/feature_controls/maps_security.ts index cf31f445a96f3..804ad5725edfd 100644 --- a/x-pack/test/functional/apps/maps/feature_controls/maps_security.ts +++ b/x-pack/test/functional/apps/maps/feature_controls/maps_security.ts @@ -65,9 +65,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows maps navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Maps', 'Management']); }); @@ -154,9 +152,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows Maps navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Maps', 'Management']); }); @@ -251,9 +247,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('does not show Maps navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Discover', 'Management']); }); diff --git a/x-pack/test/functional/apps/maps/feature_controls/maps_spaces.ts b/x-pack/test/functional/apps/maps/feature_controls/maps_spaces.ts index 0c86b47b373e6..e157586aecead 100644 --- a/x-pack/test/functional/apps/maps/feature_controls/maps_spaces.ts +++ b/x-pack/test/functional/apps/maps/feature_controls/maps_spaces.ts @@ -42,9 +42,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('Maps'); }); diff --git a/x-pack/test/functional/apps/monitoring/feature_controls/monitoring_security.ts b/x-pack/test/functional/apps/monitoring/feature_controls/monitoring_security.ts index 8848df83d36d6..d985da42ab5ed 100644 --- a/x-pack/test/functional/apps/monitoring/feature_controls/monitoring_security.ts +++ b/x-pack/test/functional/apps/monitoring/feature_controls/monitoring_security.ts @@ -76,9 +76,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it(`doesn't show monitoring navlink`, async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).not.to.contain('Stack Monitoring'); }); }); @@ -99,9 +97,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows monitoring navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('Stack Monitoring'); }); }); diff --git a/x-pack/test/functional/apps/monitoring/feature_controls/monitoring_spaces.ts b/x-pack/test/functional/apps/monitoring/feature_controls/monitoring_spaces.ts index 80f33ff6175c5..7459b53ca4a32 100644 --- a/x-pack/test/functional/apps/monitoring/feature_controls/monitoring_spaces.ts +++ b/x-pack/test/functional/apps/monitoring/feature_controls/monitoring_spaces.ts @@ -41,9 +41,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('Stack Monitoring'); }); @@ -74,9 +72,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).not.to.contain('Stack Monitoring'); }); diff --git a/x-pack/test/functional/apps/spaces/feature_controls/spaces_security.ts b/x-pack/test/functional/apps/spaces/feature_controls/spaces_security.ts index 46f0be1e6f6d6..1e79c76bf83e5 100644 --- a/x-pack/test/functional/apps/spaces/feature_controls/spaces_security.ts +++ b/x-pack/test/functional/apps/spaces/feature_controls/spaces_security.ts @@ -55,9 +55,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows management navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('Management'); }); @@ -131,9 +129,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows management navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('Management'); }); diff --git a/x-pack/test/functional/apps/timelion/feature_controls/timelion_security.ts b/x-pack/test/functional/apps/timelion/feature_controls/timelion_security.ts index 64fb218a62c80..dea45f161e451 100644 --- a/x-pack/test/functional/apps/timelion/feature_controls/timelion_security.ts +++ b/x-pack/test/functional/apps/timelion/feature_controls/timelion_security.ts @@ -59,9 +59,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows timelion navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Timelion', 'Management']); }); @@ -113,9 +111,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows timelion navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Timelion', 'Management']); }); diff --git a/x-pack/test/functional/apps/timelion/feature_controls/timelion_spaces.ts b/x-pack/test/functional/apps/timelion/feature_controls/timelion_spaces.ts index ea5e255071dad..fb203a23359bd 100644 --- a/x-pack/test/functional/apps/timelion/feature_controls/timelion_spaces.ts +++ b/x-pack/test/functional/apps/timelion/feature_controls/timelion_spaces.ts @@ -38,9 +38,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('Timelion'); }); @@ -71,9 +69,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).not.to.contain('Timelion'); }); diff --git a/x-pack/test/functional/apps/uptime/feature_controls/uptime_security.ts b/x-pack/test/functional/apps/uptime/feature_controls/uptime_security.ts index c5a597cdaffb0..a004f8db66823 100644 --- a/x-pack/test/functional/apps/uptime/feature_controls/uptime_security.ts +++ b/x-pack/test/functional/apps/uptime/feature_controls/uptime_security.ts @@ -64,10 +64,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { it('shows uptime navlink', async () => { const navLinks = await appsMenu.readLinks(); - expect(navLinks.map((link: Record) => link.text)).to.eql([ - 'Uptime', - 'Management', - ]); + expect(navLinks.map(link => link.text)).to.eql(['Uptime', 'Management']); }); it('can navigate to Uptime app', async () => { @@ -117,9 +114,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows uptime navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Uptime', 'Management']); }); @@ -170,9 +165,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it(`doesn't show uptime navlink`, async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).not.to.contain('Uptime'); }); diff --git a/x-pack/test/functional/apps/uptime/feature_controls/uptime_spaces.ts b/x-pack/test/functional/apps/uptime/feature_controls/uptime_spaces.ts index 96bc3c5f74f59..77c5b323340bf 100644 --- a/x-pack/test/functional/apps/uptime/feature_controls/uptime_spaces.ts +++ b/x-pack/test/functional/apps/uptime/feature_controls/uptime_spaces.ts @@ -30,9 +30,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('Uptime'); }); @@ -59,9 +57,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).not.to.contain('Uptime'); }); diff --git a/x-pack/test/functional/apps/visualize/feature_controls/visualize_security.ts b/x-pack/test/functional/apps/visualize/feature_controls/visualize_security.ts index 86fe606ecafad..d55076cb0ab43 100644 --- a/x-pack/test/functional/apps/visualize/feature_controls/visualize_security.ts +++ b/x-pack/test/functional/apps/visualize/feature_controls/visualize_security.ts @@ -74,9 +74,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows visualize navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Visualize', 'Management']); }); @@ -190,9 +188,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { }); it('shows visualize navlink', async () => { - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.eql(['Visualize', 'Management']); }); diff --git a/x-pack/test/functional/apps/visualize/feature_controls/visualize_spaces.ts b/x-pack/test/functional/apps/visualize/feature_controls/visualize_spaces.ts index d0fdc7c95ea38..9193862d2ba9e 100644 --- a/x-pack/test/functional/apps/visualize/feature_controls/visualize_spaces.ts +++ b/x-pack/test/functional/apps/visualize/feature_controls/visualize_spaces.ts @@ -40,9 +40,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).to.contain('Visualize'); }); @@ -81,9 +79,7 @@ export default function({ getPageObjects, getService }: FtrProviderContext) { await PageObjects.common.navigateToApp('home', { basePath: '/s/custom_space', }); - const navLinks = (await appsMenu.readLinks()).map( - (link: Record) => link.text - ); + const navLinks = (await appsMenu.readLinks()).map(link => link.text); expect(navLinks).not.to.contain('Visualize'); }); From 8454f193d99c7b079723d7587e9c90467e312a11 Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Sat, 11 Jan 2020 22:07:53 -0500 Subject: [PATCH 003/139] add categories remove cruft remove cruft more palettes move options to size as well default rename auto-select tmp stops for consistency fix legend toggle behavior add default stop subdued text color custom legend --- .../legacy/plugins/maps/common/constants.js | 7 + .../maps/public/layers/fields/es_agg_field.js | 4 +- .../maps/public/layers/fields/es_doc_field.js | 28 ++- .../maps/public/layers/fields/field.js | 6 +- .../plugins/maps/public/layers/layer.js | 4 + .../es_search_source/es_search_source.js | 15 ++ .../public/layers/sources/vector_source.js | 4 + .../maps/public/layers/styles/color_utils.js | 43 +++++ .../components/color/color_palette_select.js | 130 +++++++++++++ .../components/color/color_ramp_select.js | 20 +- .../color/color_stops_categorical.js | 130 +++++++++++++ ...{color_stops.js => color_stops_ordinal.js} | 51 +++--- .../components/color/color_stops_utils.js | 52 +++++- .../components/color/dynamic_color_form.js | 155 +++++++++++----- .../extract_color_from_style_property.js | 38 ++-- ... => ordinal_field_meta_options_popover.js} | 2 +- .../components/size/dynamic_size_form.js | 17 ++ .../vector/components/style_prop_editor.js | 17 -- .../vector/components/vector_style_editor.js | 18 +- .../properties/dynamic_color_property.js | 173 ++++++++++++++---- .../dynamic_orientation_property.js | 2 +- .../properties/dynamic_style_property.js | 118 ++++++++++-- .../properties/dynamic_text_property.js | 2 +- .../maps/public/layers/vector_layer.js | 4 + 24 files changed, 871 insertions(+), 169 deletions(-) create mode 100644 x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_palette_select.js create mode 100644 x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js rename x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/{color_stops.js => color_stops_ordinal.js} (80%) rename x-pack/legacy/plugins/maps/public/layers/styles/vector/components/{field_meta_options_popover.js => ordinal_field_meta_options_popover.js} (98%) diff --git a/x-pack/legacy/plugins/maps/common/constants.js b/x-pack/legacy/plugins/maps/common/constants.js index 6e7776d43f4d4..ab8b853377b3b 100644 --- a/x-pack/legacy/plugins/maps/common/constants.js +++ b/x-pack/legacy/plugins/maps/common/constants.js @@ -140,3 +140,10 @@ export const LAYER_STYLE_TYPE = { VECTOR: 'VECTOR', HEATMAP: 'HEATMAP', }; + +export const COLOR_MAP_TYPE = { + CATEGORICAL: 'CATEGORICAL', + ORDINAL: 'ORDINAL', +}; + +export const COLOR_PALETTE_MAX_SIZE = 10; diff --git a/x-pack/legacy/plugins/maps/public/layers/fields/es_agg_field.js b/x-pack/legacy/plugins/maps/public/layers/fields/es_agg_field.js index 189aad3785034..65109cb99809f 100644 --- a/x-pack/legacy/plugins/maps/public/layers/fields/es_agg_field.js +++ b/x-pack/legacy/plugins/maps/public/layers/fields/es_agg_field.js @@ -82,7 +82,7 @@ export class ESAggMetricField extends AbstractField { return !isMetricCountable(this.getAggType()); } - async getFieldMetaRequest(config) { - return this._esDocField.getFieldMetaRequest(config); + async getOrdinalFieldMetaRequest(config) { + return this._esDocField.getOrdinalFieldMetaRequest(config); } } diff --git a/x-pack/legacy/plugins/maps/public/layers/fields/es_doc_field.js b/x-pack/legacy/plugins/maps/public/layers/fields/es_doc_field.js index ee082e4546b8b..f9baf180dfe5c 100644 --- a/x-pack/legacy/plugins/maps/public/layers/fields/es_doc_field.js +++ b/x-pack/legacy/plugins/maps/public/layers/fields/es_doc_field.js @@ -6,6 +6,7 @@ import { AbstractField } from './field'; import { ESTooltipProperty } from '../tooltips/es_tooltip_property'; +import { COLOR_PALETTE_MAX_SIZE } from '../../../common/constants'; export class ESDocField extends AbstractField { static type = 'ES_DOC'; @@ -29,7 +30,7 @@ export class ESDocField extends AbstractField { return true; } - async getFieldMetaRequest(/* config */) { + async getOrdinalFieldMetaRequest() { const field = await this._getField(); if (field.type !== 'number' && field.type !== 'date') { @@ -51,4 +52,29 @@ export class ESDocField extends AbstractField { }, }; } + + async getCategoricalFieldMetaRequest() { + const field = await this._getField(); + if (field.type !== 'string') { + //UX does not support categorical styling for number/date fields + return null; + } + + const topTerms = { + size: COLOR_PALETTE_MAX_SIZE - 1, //need additional color for the "other"-value + }; + if (field.scripted) { + topTerms.script = { + source: field.script, + lang: field.lang, + }; + } else { + topTerms.field = this._fieldName; + } + return { + [this._fieldName]: { + terms: topTerms, + }, + }; + } } diff --git a/x-pack/legacy/plugins/maps/public/layers/fields/field.js b/x-pack/legacy/plugins/maps/public/layers/fields/field.js index f1401a78e2174..b5d157ad1697a 100644 --- a/x-pack/legacy/plugins/maps/public/layers/fields/field.js +++ b/x-pack/legacy/plugins/maps/public/layers/fields/field.js @@ -45,7 +45,11 @@ export class AbstractField { return false; } - async getFieldMetaRequest(/* config */) { + async getOrdinalFieldMetaRequest(/* config */) { + return null; + } + + async getCategoricalFieldMetaRequest() { return null; } } diff --git a/x-pack/legacy/plugins/maps/public/layers/layer.js b/x-pack/legacy/plugins/maps/public/layers/layer.js index 21c5f15fb6122..80da9555b384e 100644 --- a/x-pack/legacy/plugins/maps/public/layers/layer.js +++ b/x-pack/legacy/plugins/maps/public/layers/layer.js @@ -344,6 +344,10 @@ export class AbstractLayer { return []; } + async getStringFields() { + return []; + } + async getFields() { return []; } diff --git a/x-pack/legacy/plugins/maps/public/layers/sources/es_search_source/es_search_source.js b/x-pack/legacy/plugins/maps/public/layers/sources/es_search_source/es_search_source.js index 8ef4966e03c1b..39015f85ce875 100644 --- a/x-pack/legacy/plugins/maps/public/layers/sources/es_search_source/es_search_source.js +++ b/x-pack/legacy/plugins/maps/public/layers/sources/es_search_source/es_search_source.js @@ -125,6 +125,21 @@ export class ESSearchSource extends AbstractESSource { } } + async getStringFields() { + try { + const indexPattern = await this.getIndexPattern(); + const aggFields = indexPattern.fields.getByType('string').filter(field => { + return field.aggregatable; + }); + return aggFields.map(field => { + return this.createField({ fieldName: field.name }); + }); + } catch (error) { + //error surfaces in the LayerTOC UI + return []; + } + } + async getFields() { try { const indexPattern = await this.getIndexPattern(); diff --git a/x-pack/legacy/plugins/maps/public/layers/sources/vector_source.js b/x-pack/legacy/plugins/maps/public/layers/sources/vector_source.js index bf7267e9c5858..0dec50d77dd70 100644 --- a/x-pack/legacy/plugins/maps/public/layers/sources/vector_source.js +++ b/x-pack/legacy/plugins/maps/public/layers/sources/vector_source.js @@ -107,6 +107,10 @@ export class AbstractVectorSource extends AbstractSource { return [...(await this.getDateFields()), ...(await this.getNumberFields())]; } + async getStringFields() { + return []; + } + async getLeftJoinFields() { return []; } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.js b/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.js index 8aa32fa7e09c0..a6188b317573b 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.js @@ -12,6 +12,7 @@ import { ColorGradient } from './components/color_gradient'; import { palettes } from '@elastic/eui/lib/services'; import tinycolor from 'tinycolor2'; import chroma from 'chroma-js'; +import { COLOR_PALETTE_MAX_SIZE } from '../../../common/constants'; const GRADIENT_INTERVALS = 8; @@ -84,3 +85,45 @@ export function getLinearGradient(colorStrings) { } return `${linearGradient} ${colorStrings[colorStrings.length - 1]} 100%)`; } + +export const COLOR_PALETTES = [ + { + id: 'palette_0', + colors: DEFAULT_FILL_COLORS.slice(0, COLOR_PALETTE_MAX_SIZE), + }, + { + id: 'palette_1', + colors: [ + '#a6cee3', + '#1f78b4', + '#b2df8a', + '#33a02c', + '#fb9a99', + '#e31a1c', + '#fdbf6f', + '#ff7f00', + '#cab2d6', + '#6a3d9a', + ], + }, + { + id: 'palette_2', + colors: [ + '#8dd3c7', + '#ffffb3', + '#bebada', + '#fb8072', + '#80b1d3', + '#fdb462', + '#b3de69', + '#fccde5', + '#d9d9d9', + '#bc80bd', + ], + }, +]; + +export function getColorPalette(paletteId) { + const palette = COLOR_PALETTES.find(palette => palette.id === paletteId); + return palette ? palette.colors : null; +} diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_palette_select.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_palette_select.js new file mode 100644 index 0000000000000..b161e9a24df58 --- /dev/null +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_palette_select.js @@ -0,0 +1,130 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React, { Component, Fragment } from 'react'; +import PropTypes from 'prop-types'; + +import { EuiSuperSelect, EuiSpacer } from '@elastic/eui'; +import { FormattedMessage } from '@kbn/i18n/react'; +import { ColorStopsCategorical } from './color_stops_categorical'; +import { COLOR_PALETTES } from '../../../color_utils'; +import { COLOR_MAP_TYPE } from '../../../../../../common/constants'; + +const CUSTOM_COLOR_PALETTE = 'CUSTOM_COLOR_PALETTE'; +const CUSTOM_OPTION = { + value: CUSTOM_COLOR_PALETTE, + inputDisplay: ( + + ), +}; + +const colorPaletteInputs = COLOR_PALETTES.map(palette => { + const paletteDisplay = palette.colors.map(color => { + const style = { + backgroundColor: color, + width: '10%', + position: 'relative', + height: '100%', + display: 'inline-block', + }; + // eslint-disable-next-line react/no-danger + return
; + }); + return { + value: palette.id, + inputDisplay:
{paletteDisplay}
, + }; +}); + +export class ColorPaletteSelect extends Component { + state = {}; + + static getDerivedStateFromProps(nextProps, prevState) { + if (nextProps.customColorPalette !== prevState.prevPropsCustomColorPalette) { + return { + prevPropsCustomColorPalette: nextProps.customColorPalette, // reset tracker to latest value + customColorPalette: nextProps.customColorPalette, // reset customColorPalette to latest value + }; + } + + return null; + } + + _onColorPaletteSelect = selectedValue => { + const useCustomColorPalette = selectedValue === CUSTOM_COLOR_PALETTE; + this.props.onChange({ + type: COLOR_MAP_TYPE.CATEGORICAL, + color: useCustomColorPalette ? null : selectedValue, + useCustomColorPalette, + }); + }; + + _onCustomColorPaletteChange = ({ colorStops }) => { + this.props.onChange({ + type: COLOR_MAP_TYPE.CATEGORICAL, + customColorPalette: colorStops, + }); + }; + + render() { + const { + color, + onChange, // eslint-disable-line no-unused-vars + useCustomColorPalette, + customColorPalette, // eslint-disable-line no-unused-vars + ...rest + } = this.props; + + let colorStopsInput; + if (useCustomColorPalette) { + colorStopsInput = ( + + + + + ); + } + + const colorPaletteOptions = [CUSTOM_OPTION, ...colorPaletteInputs]; + let valueOfSelected; + if (useCustomColorPalette) { + valueOfSelected = CUSTOM_COLOR_PALETTE; + } else { + if (colorPaletteOptions.find(option => option.value === color)) { + valueOfSelected = color; + } else { + valueOfSelected = colorPaletteInputs[0].value; + this._onColorPaletteSelect(valueOfSelected); + } + } + + return ( + + + {colorStopsInput} + + ); + } +} + +ColorPaletteSelect.propTypes = { + color: PropTypes.string, + onChange: PropTypes.func.isRequired, + useCustomColorPalette: PropTypes.bool, + customColorPalette: PropTypes.array, +}; diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_ramp_select.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_ramp_select.js index c2dd51a0182e3..f8dd7fa11c27c 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_ramp_select.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_ramp_select.js @@ -10,7 +10,8 @@ import PropTypes from 'prop-types'; import { EuiSuperSelect, EuiSpacer } from '@elastic/eui'; import { COLOR_GRADIENTS } from '../../../color_utils'; import { FormattedMessage } from '@kbn/i18n/react'; -import { ColorStops } from './color_stops'; +import { ColorStopsOrdinal } from './color_stops_ordinal'; +import { COLOR_MAP_TYPE } from '../../../../../../common/constants'; const CUSTOM_COLOR_RAMP = 'CUSTOM_COLOR_RAMP'; @@ -33,6 +34,7 @@ export class ColorRampSelect extends Component { this.props.onChange({ color: useCustomColorRamp ? null : selectedValue, useCustomColorRamp, + type: COLOR_MAP_TYPE.ORDINAL, }); }; @@ -45,6 +47,7 @@ export class ColorRampSelect extends Component { this.props.onChange({ customColorRamp: colorStops, + type: COLOR_MAP_TYPE.ORDINAL, }); }; @@ -62,7 +65,7 @@ export class ColorRampSelect extends Component { colorStopsInput = ( - @@ -82,13 +85,24 @@ export class ColorRampSelect extends Component { }, ...COLOR_GRADIENTS, ]; + let valueOfSelected; + if (useCustomColorRamp) { + valueOfSelected = CUSTOM_COLOR_RAMP; + } else { + if (colorRampOptions.find(option => option.value === color)) { + valueOfSelected = color; + } else { + valueOfSelected = COLOR_GRADIENTS[0].value; + this._onColorRampSelect(valueOfSelected); + } + } return ( diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js new file mode 100644 index 0000000000000..6c7174612a107 --- /dev/null +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js @@ -0,0 +1,130 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import _ from 'lodash'; +import React from 'react'; +import PropTypes from 'prop-types'; + +import { EuiFormRow, EuiFieldText, EuiFlexGroup, EuiFlexItem, EuiButtonIcon } from '@elastic/eui'; +import { addCategoricalRow, removeRow, getColorInput, getDeleteButton } from './color_stops_utils'; + +const DEFAULT_COLOR = '#FF0000'; +const DEFAULT_NEXT_COLOR = '#00FF00'; + +export const ColorStopsCategorical = ({ + colorStops = [ + { stop: null, color: DEFAULT_COLOR }, //first stop is the "other" color + { stop: '', color: DEFAULT_NEXT_COLOR }, + ], + onChange, +}) => { + function getStopInput(stop, index) { + const onStopChange = e => { + const newColorStops = _.cloneDeep(colorStops); + newColorStops[index].stop = e.target.value; + onChange({ + colorStops: newColorStops, + isInvalid: false, + }); + }; + + let stopInput; + if (index === 0) { + stopInput = ( + + ); + } else { + stopInput = ( + + ); + } + + return { + stopInput: stopInput, + }; + } + + const rows = colorStops.map((colorStop, index) => { + const { stopInput } = getStopInput(colorStop.stop, index); + const { colorError, colorInput } = getColorInput(colorStops, onChange, colorStop.color, index); + const errors = colorError ? [colorError] : []; + + const onAdd = () => { + const newColorStops = addCategoricalRow(colorStops, index); + onChange({ + colorStops: newColorStops, + isInvalid: false, + }); + }; + + let deleteButton; + if (colorStops.length > 2) { + const onRemove = () => { + const newColorStops = removeRow(colorStops, index); + onChange({ + colorStops: newColorStops, + isInvalid: false, + }); + }; + deleteButton = getDeleteButton(onRemove); + } + + return ( + +
+ + {stopInput} + {colorInput} + +
+ {deleteButton} + +
+
+
+ ); + }); + + return
{rows}
; +}; + +ColorStopsCategorical.propTypes = { + /** + * Array of { stop, color }. + * Stops are numbers in strictly ascending order. + * The range is from the given stop number (inclusive) to the next stop number (exclusive). + * Colors are color hex strings (3 or 6 character). + */ + colorStops: PropTypes.arrayOf( + PropTypes.shape({ + stopKey: PropTypes.number, + color: PropTypes.string, + }) + ), + /** + * Callback for when the color stops changes. Called with { colorStops, isInvalid } + */ + onChange: PropTypes.func.isRequired, +}; diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_ordinal.js similarity index 80% rename from x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops.js rename to x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_ordinal.js index d523cf5870912..63fa52d50158f 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_ordinal.js @@ -16,11 +16,21 @@ import { EuiFlexItem, EuiButtonIcon, } from '@elastic/eui'; -import { addRow, removeRow, isColorInvalid, isStopInvalid, isInvalid } from './color_stops_utils'; +import { + addOrdinalRow, + removeRow, + isColorInvalid, + isOrdinalStopInvalid, + isOrdinalStopsInvalid, + getDeleteButton, +} from './color_stops_utils'; const DEFAULT_COLOR = '#FF0000'; -export const ColorStops = ({ colorStops = [{ stop: 0, color: DEFAULT_COLOR }], onChange }) => { +export const ColorStopsOrdinal = ({ + colorStops = [{ stop: 0, color: DEFAULT_COLOR }], + onChange, +}) => { function getStopInput(stop, index) { const onStopChange = e => { const newColorStops = _.cloneDeep(colorStops); @@ -28,12 +38,12 @@ export const ColorStops = ({ colorStops = [{ stop: 0, color: DEFAULT_COLOR }], o newColorStops[index].stop = isNaN(sanitizedValue) ? '' : sanitizedValue; onChange({ colorStops: newColorStops, - isInvalid: isInvalid(newColorStops), + isInvalid: isOrdinalStopsInvalid(newColorStops), }); }; let error; - if (isStopInvalid(stop)) { + if (isOrdinalStopInvalid(stop)) { error = 'Stop must be a number'; } else if (index !== 0 && colorStops[index - 1].stop >= stop) { error = 'Stop must be greater than previous stop value'; @@ -53,7 +63,7 @@ export const ColorStops = ({ colorStops = [{ stop: 0, color: DEFAULT_COLOR }], o newColorStops[index].color = color; onChange({ colorStops: newColorStops, - isInvalid: isInvalid(newColorStops), + isInvalid: isOrdinalStopsInvalid(newColorStops), }); }; @@ -74,34 +84,25 @@ export const ColorStops = ({ colorStops = [{ stop: 0, color: DEFAULT_COLOR }], o errors.push(colorError); } - const onRemove = () => { - const newColorStops = removeRow(colorStops, index); - onChange({ - colorStops: newColorStops, - isInvalid: isInvalid(newColorStops), - }); - }; - const onAdd = () => { - const newColorStops = addRow(colorStops, index); + const newColorStops = addOrdinalRow(colorStops, index); onChange({ colorStops: newColorStops, - isInvalid: isInvalid(newColorStops), + isInvalid: isOrdinalStopsInvalid(newColorStops), }); }; let deleteButton; if (colorStops.length > 1) { - deleteButton = ( - - ); + const onRemove = () => { + const newColorStops = removeRow(colorStops, index); + onChange({ + colorStops: newColorStops, + isInvalid: isOrdinalStopsInvalid(newColorStops), + }); + }; + deleteButton = getDeleteButton(onRemove); } return ( @@ -135,7 +136,7 @@ export const ColorStops = ({ colorStops = [{ stop: 0, color: DEFAULT_COLOR }], o return
{rows}
; }; -ColorStops.propTypes = { +ColorStopsOrdinal.propTypes = { /** * Array of { stop, color }. * Stops are numbers in strictly ascending order. diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js index fb0a25cf7d5ee..b7dd692952db7 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js @@ -4,7 +4,10 @@ * you may not use this file except in compliance with the Elastic License. */ -import { isValidHex } from '@elastic/eui'; +import { EuiButtonIcon, EuiColorPicker, isValidHex } from '@elastic/eui'; +import _ from 'lodash'; +import React from 'react'; +import { COLOR_MAP_TYPE } from '../../../../../../common/constants'; export function removeRow(colorStops, index) { if (colorStops.length === 1) { @@ -14,7 +17,15 @@ export function removeRow(colorStops, index) { return [...colorStops.slice(0, index), ...colorStops.slice(index + 1)]; } -export function addRow(colorStops, index) { +export function addOrdinalRow(colorStops, index) { + return addRow(colorStops, index, COLOR_MAP_TYPE.ORDINAL); +} + +export function addCategoricalRow(colorStops, index) { + return addRow(colorStops, index, COLOR_MAP_TYPE.CATEGORICAL); +} + +export function addRow(colorStops, index, colorMapType) { const currentStop = colorStops[index].stop; let delta = 1; if (index === colorStops.length - 1) { @@ -29,22 +40,51 @@ export function addRow(colorStops, index) { delta = (nextStop - currentStop) / 2; } + const nextValue = colorMapType === COLOR_MAP_TYPE.ORDINAL ? currentStop + delta : currentStop; const newRow = { - stop: currentStop + delta, + stop: nextValue, color: '#FF0000', }; return [...colorStops.slice(0, index + 1), newRow, ...colorStops.slice(index + 1)]; } +export function getDeleteButton(onRemove) { + return ( + + ); +} + +export function getColorInput(colorStops, onChange, color, index) { + const onColorChange = color => { + const newColorStops = _.cloneDeep(colorStops); + newColorStops[index].color = color; + onChange({ + colorStops: newColorStops, + isInvalid: false, + }); + }; + + return { + colorError: isColorInvalid(color) ? 'Color must provide a valid hex value' : undefined, + colorInput: , + }; +} + export function isColorInvalid(color) { return !isValidHex(color) || color === ''; } -export function isStopInvalid(stop) { +export function isOrdinalStopInvalid(stop) { return stop === '' || isNaN(stop); } -export function isInvalid(colorStops) { +export function isOrdinalStopsInvalid(colorStops) { return colorStops.some((colorStop, index) => { // expect stops to be in ascending order let isDescending = false; @@ -53,6 +93,6 @@ export function isInvalid(colorStops) { isDescending = prevStop >= colorStop.stop; } - return isColorInvalid(colorStop.color) || isStopInvalid(colorStop.stop) || isDescending; + return isColorInvalid(colorStop.color) || isOrdinalStopInvalid(colorStop.stop) || isDescending; }); } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js index 5e0f7434b04d0..546c9394e4865 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js @@ -8,55 +8,126 @@ import _ from 'lodash'; import React, { Fragment } from 'react'; import { FieldSelect } from '../field_select'; import { ColorRampSelect } from './color_ramp_select'; +import { ColorPaletteSelect } from './color_palette_select'; import { EuiFlexGroup, EuiFlexItem, EuiSpacer } from '@elastic/eui'; +import { COLOR_MAP_TYPE } from '../../../../../../common/constants'; +import { OrdinalFieldMetaOptionsPopover } from '../ordinal_field_meta_options_popover'; -export function DynamicColorForm({ - fields, - onDynamicStyleChange, - staticDynamicSelect, - styleProperty, -}) { - const styleOptions = styleProperty.getOptions(); - - const onFieldChange = ({ field }) => { - onDynamicStyleChange(styleProperty.getStyleName(), { ...styleOptions, field }); +export class DynamicColorForm extends React.Component { + state = { + colorMapType: COLOR_MAP_TYPE.ORDINAL, }; - const onColorChange = colorOptions => { - onDynamicStyleChange(styleProperty.getStyleName(), { - ...styleOptions, - ...colorOptions, - }); - }; + constructor() { + super(); + this._isMounted = false; + } - let colorRampSelect; - if (styleOptions.field && styleOptions.field.name) { - colorRampSelect = ( - - ); + componentWillUnmount() { + this._isMounted = false; + } + + componentDidMount() { + this._isMounted = true; + this._loadColorMapType(); } - return ( - - - {staticDynamicSelect} - - { + const options = { + ...this.props.styleProperty.getOptions(), + fieldMetaOptions, + }; + this.props.onDynamicStyleChange(this.props.styleProperty.getStyleName(), options); + }; + + _getColorSelector() { + const { onDynamicStyleChange, styleProperty } = this.props; + const styleOptions = styleProperty.getOptions(); + + let colorSelect; + if (styleOptions.field && styleOptions.field.name) { + const onColorChange = colorOptions => { + onDynamicStyleChange(styleProperty.getStyleName(), { + ...styleOptions, + ...colorOptions, + }); + }; + if (this.state.colorMapType === COLOR_MAP_TYPE.ORDINAL) { + colorSelect = ( + onColorChange(options)} + color={styleOptions.color} + customColorRamp={styleOptions.customColorRamp} + useCustomColorRamp={_.get(styleOptions, 'useCustomColorRamp', false)} + compressed + /> + ); + } else if (this.state.colorMapType === COLOR_MAP_TYPE.CATEGORICAL) { + colorSelect = ( + onColorChange(options)} + color={styleOptions.color} + customColorPalette={styleOptions.customColorPalette} + useCustomColorPalette={_.get(styleOptions, 'useCustomColorPalette', false)} compressed /> - - - - {colorRampSelect} - - ); + ); + } + return colorSelect; + } + } + + render() { + const { fields, onDynamicStyleChange, staticDynamicSelect, styleProperty } = this.props; + const styleOptions = styleProperty.getOptions(); + const onFieldChange = ({ field }) => { + onDynamicStyleChange(styleProperty.getStyleName(), { ...styleOptions, field }); + }; + + const colorSelect = this._getColorSelector(); + + const fieldMetaOptionsPopover = + this.state.colorMapType === COLOR_MAP_TYPE.ORDINAL && styleProperty.supportsFieldMeta() ? ( + + ) : null; + + return ( + + + {staticDynamicSelect} + + + + + + {colorSelect} + {fieldMetaOptionsPopover} + + ); + } } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/legend/extract_color_from_style_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/legend/extract_color_from_style_property.js index 157b863ac4986..3b11c7b77a237 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/legend/extract_color_from_style_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/legend/extract_color_from_style_property.js @@ -5,7 +5,8 @@ */ import { VectorStyle } from '../../vector_style'; -import { getColorRampCenterColor } from '../../../color_utils'; +import { getColorRampCenterColor, getColorPalette } from '../../../color_utils'; +import { COLOR_MAP_TYPE } from '../../../../../../common/constants'; export function extractColorFromStyleProperty(colorStyleProperty, defaultColor) { if (!colorStyleProperty) { @@ -21,19 +22,30 @@ export function extractColorFromStyleProperty(colorStyleProperty, defaultColor) return defaultColor; } - // return middle of gradient for dynamic style property + if (colorStyleProperty.options.type === COLOR_MAP_TYPE.CATEGORICAL) { + if (colorStyleProperty.options.useCustomColorPalette) { + return colorStyleProperty.options.customColorPalette && + colorStyleProperty.options.customColorPalette.length + ? colorStyleProperty.options.customColorPalette[0].color + : defaultColor; + } - if (colorStyleProperty.options.useCustomColorRamp) { - if ( - !colorStyleProperty.options.customColorRamp || - !colorStyleProperty.options.customColorRamp.length - ) { - return defaultColor; + const palette = getColorPalette(colorStyleProperty.options.color); + return palette[0]; + } else { + // return middle of gradient for dynamic style property + if (colorStyleProperty.options.useCustomColorRamp) { + if ( + !colorStyleProperty.options.customColorRamp || + !colorStyleProperty.options.customColorRamp.length + ) { + return defaultColor; + } + // favor the lowest color in even arrays + const middleIndex = Math.floor((colorStyleProperty.options.customColorRamp.length - 1) / 2); + return colorStyleProperty.options.customColorRamp[middleIndex].color; } - // favor the lowest color in even arrays - const middleIndex = Math.floor((colorStyleProperty.options.customColorRamp.length - 1) / 2); - return colorStyleProperty.options.customColorRamp[middleIndex].color; - } - return getColorRampCenterColor(colorStyleProperty.options.color); + return getColorRampCenterColor(colorStyleProperty.options.color); + } } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/field_meta_options_popover.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/ordinal_field_meta_options_popover.js similarity index 98% rename from x-pack/legacy/plugins/maps/public/layers/styles/vector/components/field_meta_options_popover.js rename to x-pack/legacy/plugins/maps/public/layers/styles/vector/components/ordinal_field_meta_options_popover.js index 471403e1f3999..dee333f163960 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/field_meta_options_popover.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/ordinal_field_meta_options_popover.js @@ -31,7 +31,7 @@ function getIsEnableToggleLabel(styleName) { } } -export class FieldMetaOptionsPopover extends Component { +export class OrdinalFieldMetaOptionsPopover extends Component { state = { isPopoverOpen: false, }; diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/size/dynamic_size_form.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/size/dynamic_size_form.js index 8b069cd53b731..2f3a80684b3b1 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/size/dynamic_size_form.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/size/dynamic_size_form.js @@ -9,6 +9,7 @@ import React, { Fragment } from 'react'; import { FieldSelect } from '../field_select'; import { SizeRangeSelector } from './size_range_selector'; import { EuiFlexGroup, EuiFlexItem, EuiSpacer } from '@elastic/eui'; +import { OrdinalFieldMetaOptionsPopover } from '../ordinal_field_meta_options_popover'; export function DynamicSizeForm({ fields, @@ -22,6 +23,14 @@ export function DynamicSizeForm({ onDynamicStyleChange(styleProperty.getStyleName(), { ...styleOptions, field }); }; + const onFieldMetaOptionsChange = fieldMetaOptions => { + const options = { + ...styleProperty.getOptions(), + fieldMetaOptions, + }; + onDynamicStyleChange(styleProperty.getStyleName(), options); + }; + const onSizeRangeChange = ({ minSize, maxSize }) => { onDynamicStyleChange(styleProperty.getStyleName(), { ...styleOptions, @@ -43,6 +52,13 @@ export function DynamicSizeForm({ ); } + const fieldMetaOptionsPopover = styleProperty.supportsFieldMeta() ? ( + + ) : null; + return ( @@ -58,6 +74,7 @@ export function DynamicSizeForm({ {sizeRange} + {fieldMetaOptionsPopover} ); } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/style_prop_editor.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/style_prop_editor.js index 1ac8edfb2cc69..ed80e94358a10 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/style_prop_editor.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/style_prop_editor.js @@ -5,7 +5,6 @@ */ import React, { Component, Fragment } from 'react'; -import { FieldMetaOptionsPopover } from './field_meta_options_popover'; import { getVectorStyleLabel } from './get_vector_style_label'; import { EuiFormRow, EuiSelect } from '@elastic/eui'; import { VectorStyle } from '../vector_style'; @@ -35,14 +34,6 @@ export class StylePropEditor extends Component { } }; - _onFieldMetaOptionsChange = fieldMetaOptions => { - const options = { - ...this.props.styleProperty.getOptions(), - fieldMetaOptions, - }; - this.props.onDynamicStyleChange(this.props.styleProperty.getStyleName(), options); - }; - renderStaticDynamicSelect() { const options = [ { @@ -80,13 +71,6 @@ export class StylePropEditor extends Component { } render() { - const fieldMetaOptionsPopover = this.props.styleProperty.isDynamic() ? ( - - ) : null; - return ( ); diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/vector_style_editor.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/vector_style_editor.js index 8e80e036dbb8b..d65a75a795738 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/vector_style_editor.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/vector_style_editor.js @@ -31,6 +31,7 @@ export class VectorStyleEditor extends Component { state = { dateFields: [], numberFields: [], + stringFields: [], fields: [], defaultDynamicProperties: getDefaultDynamicProperties(), defaultStaticProperties: getDefaultStaticProperties(), @@ -76,6 +77,13 @@ export class VectorStyleEditor extends Component { this.setState({ numberFields: numberFieldsArray }); } + const stringFields = await this.props.layer.getStringFields(); + const stringFieldPromises = stringFields.map(getFieldMeta); + const stringFieldsArray = await Promise.all(stringFieldPromises); + if (this._isMounted && !_.isEqual(stringFieldsArray, this.state.stringFields)) { + this.setState({ stringFields: stringFieldsArray }); + } + const fields = await this.props.layer.getFields(); const fieldPromises = fields.map(getFieldMeta); const fieldsArray = await Promise.all(fieldPromises); @@ -125,6 +133,10 @@ export class VectorStyleEditor extends Component { return [...this.state.dateFields, ...this.state.numberFields]; } + _getOrdinalAndStringFields() { + return [...this.state.dateFields, ...this.state.numberFields, ...this.state.stringFields]; + } + _handleSelectedFeatureChange = selectedFeature => { this.setState({ selectedFeature }); }; @@ -156,7 +168,7 @@ export class VectorStyleEditor extends Component { onStaticStyleChange={this._onStaticStyleChange} onDynamicStyleChange={this._onDynamicStyleChange} styleProperty={this.props.styleProperties[VECTOR_STYLES.FILL_COLOR]} - fields={this._getOrdinalFields()} + fields={this._getOrdinalAndStringFields()} defaultStaticStyleOptions={ this.state.defaultStaticProperties[VECTOR_STYLES.FILL_COLOR].options } @@ -174,7 +186,7 @@ export class VectorStyleEditor extends Component { onStaticStyleChange={this._onStaticStyleChange} onDynamicStyleChange={this._onDynamicStyleChange} styleProperty={this.props.styleProperties[VECTOR_STYLES.LINE_COLOR]} - fields={this._getOrdinalFields()} + fields={this._getOrdinalAndStringFields()} defaultStaticStyleOptions={ this.state.defaultStaticProperties[VECTOR_STYLES.LINE_COLOR].options } @@ -241,7 +253,7 @@ export class VectorStyleEditor extends Component { onStaticStyleChange={this._onStaticStyleChange} onDynamicStyleChange={this._onDynamicStyleChange} styleProperty={this.props.styleProperties[VECTOR_STYLES.LABEL_COLOR]} - fields={this._getOrdinalFields()} + fields={this._getOrdinalAndStringFields()} defaultStaticStyleOptions={ this.state.defaultStaticProperties[VECTOR_STYLES.LABEL_COLOR].options } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js index 200df9e5cc33d..27b06810c1439 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js @@ -7,12 +7,20 @@ import { DynamicStyleProperty } from './dynamic_style_property'; import _ from 'lodash'; import { getComputedFieldName } from '../style_util'; -import { getColorRampStops } from '../../color_utils'; +import { getColorRampStops, getColorPalette } from '../../color_utils'; import { ColorGradient } from '../../components/color_gradient'; import React from 'react'; -import { EuiFlexGroup, EuiFlexItem, EuiSpacer, EuiText, EuiToolTip } from '@elastic/eui'; +import { + EuiFlexGroup, + EuiFlexItem, + EuiSpacer, + EuiText, + EuiToolTip, + EuiTextColor, +} from '@elastic/eui'; import { VectorIcon } from '../components/legend/vector_icon'; import { VECTOR_STYLES } from '../vector_style_defaults'; +import { COLOR_MAP_TYPE } from '../../../../../common/constants'; export class DynamicColorProperty extends DynamicStyleProperty { syncCircleColorWithMb(mbLayerId, mbMap, alpha) { @@ -55,7 +63,17 @@ export class DynamicColorProperty extends DynamicStyleProperty { mbMap.setPaintProperty(mbLayerId, 'text-opacity', alpha); } - isCustomColorRamp() { + isOrdinal() { + return ( + typeof this._options.type === 'undefined' || this._options.type === COLOR_MAP_TYPE.ORDINAL + ); + } + + isCategorical() { + return this._options.type === COLOR_MAP_TYPE.CATEGORICAL; + } + + isCustomOrdinalColorRamp() { return this._options.useCustomColorRamp; } @@ -63,16 +81,16 @@ export class DynamicColorProperty extends DynamicStyleProperty { return true; } - isScaled() { - return !this.isCustomColorRamp(); + isOrdinalScaled() { + return this.isOrdinal() && !this.isCustomOrdinalColorRamp(); } - isRanged() { - return !this.isCustomColorRamp(); + isOrdinalRanged() { + return this.isOrdinal() && !this.isCustomOrdinalColorRamp(); } - hasBreaks() { - return this.isCustomColorRamp(); + hasOrdinalBreaks() { + return (this.isOrdinal() && this.isCustomOrdinalColorRamp()) || this.isCategorical(); } _getMbColor() { @@ -82,6 +100,12 @@ export class DynamicColorProperty extends DynamicStyleProperty { return null; } + return this._getMBDataDrivenColor({ + targetName: getComputedFieldName(this._styleName, this._options.field.name), + }); + } + + _getMbDataDrivenOrdinalColor({ targetName }) { if ( this._options.useCustomColorRamp && (!this._options.customColorRamp || !this._options.customColorRamp.length) @@ -89,15 +113,8 @@ export class DynamicColorProperty extends DynamicStyleProperty { return null; } - return this._getMBDataDrivenColor({ - targetName: getComputedFieldName(this._styleName, this._options.field.name), - colorStops: this._getMBColorStops(), - isSteps: this._options.useCustomColorRamp, - }); - } - - _getMBDataDrivenColor({ targetName, colorStops, isSteps }) { - if (isSteps) { + const colorStops = this._getMbOrdinalColorStops(); + if (this._options.useCustomColorRamp) { const firstStopValue = colorStops[0]; const lessThenFirstStopValue = firstStopValue - 1; return [ @@ -107,7 +124,6 @@ export class DynamicColorProperty extends DynamicStyleProperty { ...colorStops, ]; } - return [ 'interpolate', ['linear'], @@ -118,14 +134,81 @@ export class DynamicColorProperty extends DynamicStyleProperty { ]; } - _getMBColorStops() { - if (this._options.useCustomColorRamp) { - return this._options.customColorRamp.reduce((accumulatedStops, nextStop) => { - return [...accumulatedStops, nextStop.stop, nextStop.color]; - }, []); + _getColorPaletteStops() { + if (this._options.useCustomColorPalette && this._options.customColorPalette) { + return this._options.customColorPalette.map((config, index) => { + return { + stop: config.stop, + color: config.color, + isDefault: index === 0, + }; + }); + } + + const fieldMeta = this.getFieldMeta(); + if (!fieldMeta || !fieldMeta.categories) { + return []; + } + + const colors = getColorPalette(this._options.color); + if (!colors) { + return []; + } + const maxLength = Math.min(colors.length, fieldMeta.categories.length + 1); + + const stops = []; + for (let i = 0; i < maxLength; i++) { + stops.push({ + stop: i === 0 ? '__DEFAULT__' : fieldMeta.categories[i - 1].key, + isDefault: i === 0, + color: colors[i], + }); + } + return stops; + } + + _getMbDataDrivenCategoricalColor() { + if ( + this._options.useCustomColorPalette && + (!this._options.customColorPalette || !this._options.customColorPalette.length) + ) { + return null; } - return getColorRampStops(this._options.color); + const paletteStops = this._getColorPaletteStops(); + if (!paletteStops.length) { + return null; + } + const mbStops = []; + for (let i = 1; i < paletteStops.length; i++) { + const stop = paletteStops[i]; + mbStops.push(stop.stop); + mbStops.push(stop.color); + } + mbStops.push(paletteStops[0].color); //first color is default color + return ['match', ['get', this._options.field.name], ...mbStops]; + } + + _getMBDataDrivenColor({ targetName }) { + if (this.isCategorical()) { + return this._getMbDataDrivenCategoricalColor({ targetName }); + } else { + return this._getMbDataDrivenOrdinalColor({ targetName }); + } + } + + _getOrdinalColorStopsFromCustom() { + return this._options.customColorRamp.reduce((accumulatedStops, nextStop) => { + return [...accumulatedStops, nextStop.stop, nextStop.color]; + }, []); + } + + _getMbOrdinalColorStops() { + if (this._options.useCustomColorRamp) { + return this._getOrdinalColorStopsFromCustom(); + } else { + return getColorRampStops(this._options.color); + } } renderRangeLegendHeader() { @@ -172,19 +255,43 @@ export class DynamicColorProperty extends DynamicStyleProperty { ); } - _renderColorbreaks({ isLinesOnly, isPointsOnly, symbolId }) { - if (!this._options.customColorRamp) { - return null; + _getColorRampStops() { + if (this._options.useCustomColorRamp && this._options.customColorRamp) { + return this._options.customColorRamp; + } else { + return []; + } + } + + _getColorStops() { + if (this.isOrdinal()) { + return this._getColorRampStops(); + } else if (this.isCategorical()) { + return this._getColorPaletteStops(); + } else { + return []; } + } + + _renderColorbreaks({ isLinesOnly, isPointsOnly, symbolId }) { + const stops = this._getColorStops(); + return stops.map((config, index) => { + let textValue; + if (config.isDefault) { + textValue = ( + + Default + + ); + } else { + const value = this.formatField(config.stop); + textValue = {value}; + } - return this._options.customColorRamp.map((config, index) => { - const value = this.formatField(config.stop); return ( - - {value} - + {textValue} {this._renderStopIcon(config.color, isLinesOnly, isPointsOnly, symbolId)} diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_orientation_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_orientation_property.js index 5b6f494600c2a..1d2457142c082 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_orientation_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_orientation_property.js @@ -26,7 +26,7 @@ export class DynamicOrientationProperty extends DynamicStyleProperty { return false; } - isScaled() { + isOrdinalScaled() { return false; } } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js index bac3c96581967..5a9ba1d6f03c2 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js @@ -7,7 +7,7 @@ import _ from 'lodash'; import { AbstractStyleProperty } from './style_property'; import { DEFAULT_SIGMA } from '../vector_style_defaults'; -import { STYLE_TYPE } from '../../../../../common/constants'; +import { COLOR_PALETTE_MAX_SIZE, STYLE_TYPE } from '../../../../../common/constants'; import { scaleValue } from '../style_util'; import React from 'react'; import { OrdinalLegend } from './components/ordinal_legend'; @@ -39,11 +39,15 @@ export class DynamicStyleProperty extends AbstractStyleProperty { return true; } - hasBreaks() { + isCategorical() { return false; } - isRanged() { + hasOrdinalBreaks() { + return false; + } + + isOrdinalRanged() { return true; } @@ -61,21 +65,33 @@ export class DynamicStyleProperty extends AbstractStyleProperty { } supportsFieldMeta() { - return this.isComplete() && this.isScaled() && this._field.supportsFieldMeta(); + if (this.isOrdinal()) { + return this.isComplete() && this.isOrdinalScaled() && this._field.supportsFieldMeta(); + } else if (this.isCategorical()) { + return this.isComplete() && this._field.supportsFieldMeta(); + } else { + return false; + } } async getFieldMetaRequest() { - const fieldMetaOptions = this.getFieldMetaOptions(); - return this._field.getFieldMetaRequest({ - sigma: _.get(fieldMetaOptions, 'sigma', DEFAULT_SIGMA), - }); + if (this.isOrdinal()) { + const fieldMetaOptions = this.getFieldMetaOptions(); + return this._field.getOrdinalFieldMetaRequest({ + sigma: _.get(fieldMetaOptions, 'sigma', DEFAULT_SIGMA), + }); + } else if (this.isCategorical()) { + return this._field.getCategoricalFieldMetaRequest(); + } else { + return null; + } } supportsFeatureState() { return true; } - isScaled() { + isOrdinalScaled() { return true; } @@ -83,11 +99,7 @@ export class DynamicStyleProperty extends AbstractStyleProperty { return _.get(this.getOptions(), 'fieldMetaOptions', {}); } - pluckStyleMetaFromFeatures(features) { - if (!this.isOrdinal()) { - return null; - } - + _pluckOrdinalStyleMetaFromFeatures(features) { const name = this.getField().getName(); let min = Infinity; let max = -Infinity; @@ -109,11 +121,44 @@ export class DynamicStyleProperty extends AbstractStyleProperty { }; } - pluckStyleMetaFromFieldMetaData(fieldMetaData) { - if (!this.isOrdinal()) { + _pluckCategoricalStyleMetaFromFeatures(features) { + const fieldName = this.getField().getName(); + const counts = new Map(); + for (let i = 0; i < features.length; i++) { + const feature = features[i]; + const term = feature.properties[fieldName]; + if (counts.has(term)) { + counts.set(term, counts.get(term) + 1); + } else { + counts.set(term, 1); + } + } + + const ordered = []; + for (const [key, value] of counts) { + ordered.push({ key, count: value }); + } + + ordered.sort((a, b) => { + return a.count - b.count; + }); + const truncated = ordered.slice(0, COLOR_PALETTE_MAX_SIZE); + return { + categories: truncated, + }; + } + + pluckStyleMetaFromFeatures(features) { + if (this.isOrdinal()) { + return this._pluckOrdinalStyleMetaFromFeatures(features); + } else if (this.isCategorical()) { + return this._pluckCategoricalStyleMetaFromFeatures(features); + } else { return null; } + } + _pluckOrdinalStyleMetaFromFieldMetaData(fieldMetaData) { const realFieldName = this._field.getESDocFieldName ? this._field.getESDocFieldName() : this._field.getName(); @@ -136,6 +181,33 @@ export class DynamicStyleProperty extends AbstractStyleProperty { }; } + _pluckCategoricalStyleMetaFromFieldMetaData(fieldMetaData) { + const name = this.getField().getName(); + if (!fieldMetaData[name] || !fieldMetaData[name].buckets) { + return null; + } + + const ordered = fieldMetaData[name].buckets.map(bucket => { + return { + key: bucket.key, + count: bucket.doc_count, + }; + }); + return { + categories: ordered, + }; + } + + pluckStyleMetaFromFieldMetaData(fieldMetaData) { + if (this.isOrdinal()) { + return this._pluckOrdinalStyleMetaFromFieldMetaData(fieldMetaData); + } else if (this.isCategorical()) { + return this._pluckCategoricalStyleMetaFromFieldMetaData(fieldMetaData); + } else { + return null; + } + } + formatField(value) { if (this.getField()) { const fieldName = this.getField().getName(); @@ -152,7 +224,7 @@ export class DynamicStyleProperty extends AbstractStyleProperty { } const valueAsFloat = parseFloat(value); - if (this.isScaled()) { + if (this.isOrdinalScaled()) { return scaleValue(valueAsFloat, this.getFieldMeta()); } if (isNaN(valueAsFloat)) { @@ -181,9 +253,15 @@ export class DynamicStyleProperty extends AbstractStyleProperty { } renderLegendDetailRow({ loadIsPointsOnly, loadIsLinesOnly, symbolId }) { - if (this.isRanged()) { - return this._renderRangeLegend(); - } else if (this.hasBreaks()) { + if (this.isOrdinal()) { + if (this.isOrdinalRanged()) { + return this._renderRangeLegend(); + } else if (this.hasOrdinalBreaks()) { + return this._renderCategoricalLegend({ loadIsPointsOnly, loadIsLinesOnly, symbolId }); + } else { + return null; + } + } else if (this.isCategorical()) { return this._renderCategoricalLegend({ loadIsPointsOnly, loadIsLinesOnly, symbolId }); } else { return null; diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_text_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_text_property.js index fbc4c3af78f98..6a40a80a1a7a6 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_text_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_text_property.js @@ -29,7 +29,7 @@ export class DynamicTextProperty extends DynamicStyleProperty { return false; } - isScaled() { + isOrdinalScaled() { return false; } } diff --git a/x-pack/legacy/plugins/maps/public/layers/vector_layer.js b/x-pack/legacy/plugins/maps/public/layers/vector_layer.js index dd9a1b7a14c10..54618dc8d5b44 100644 --- a/x-pack/legacy/plugins/maps/public/layers/vector_layer.js +++ b/x-pack/legacy/plugins/maps/public/layers/vector_layer.js @@ -213,6 +213,10 @@ export class VectorLayer extends AbstractLayer { return [...(await this.getDateFields()), ...(await this.getNumberFields())]; } + async getStringFields() { + return await this._source.getStringFields(); + } + async getFields() { const sourceFields = await this._source.getFields(); return [...sourceFields, ...this._getJoinFields()]; From f431bb5519dcf79251859d5d34cdbc8bb8881793 Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Sun, 12 Jan 2020 18:37:56 -0500 Subject: [PATCH 004/139] internationalize test --- .../color/color_stops_categorical.js | 55 ++++++-------- .../components/color/color_stops_ordinal.js | 71 +++++++------------ .../components/color/color_stops_utils.js | 68 ++++++++++++++---- 3 files changed, 99 insertions(+), 95 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js index 6c7174612a107..d7a382a6c7e5e 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js @@ -8,15 +8,20 @@ import _ from 'lodash'; import React from 'react'; import PropTypes from 'prop-types'; -import { EuiFormRow, EuiFieldText, EuiFlexGroup, EuiFlexItem, EuiButtonIcon } from '@elastic/eui'; -import { addCategoricalRow, removeRow, getColorInput, getDeleteButton } from './color_stops_utils'; - -const DEFAULT_COLOR = '#FF0000'; -const DEFAULT_NEXT_COLOR = '#00FF00'; +import { EuiFieldText } from '@elastic/eui'; +import { + addCategoricalRow, + removeRow, + getColorInput, + getDeleteButton, + getColorStopRow, + DEFAULT_CUSTOM_COLOR, + DEFAULT_NEXT_COLOR, +} from './color_stops_utils'; export const ColorStopsCategorical = ({ colorStops = [ - { stop: null, color: DEFAULT_COLOR }, //first stop is the "other" color + { stop: null, color: DEFAULT_CUSTOM_COLOR }, //first stop is the "other" color { stop: '', color: DEFAULT_NEXT_COLOR }, ], onChange, @@ -55,8 +60,17 @@ export const ColorStopsCategorical = ({ } const rows = colorStops.map((colorStop, index) => { + const onColorChange = color => { + const newColorStops = _.cloneDeep(colorStops); + newColorStops[index].color = color; + onChange({ + colorStops: newColorStops, + isInvalid: false, + }); + }; + const { stopInput } = getStopInput(colorStop.stop, index); - const { colorError, colorInput } = getColorInput(colorStops, onChange, colorStop.color, index); + const { colorError, colorInput } = getColorInput(colorStops, onColorChange, colorStop.color); const errors = colorError ? [colorError] : []; const onAdd = () => { @@ -79,32 +93,7 @@ export const ColorStopsCategorical = ({ deleteButton = getDeleteButton(onRemove); } - return ( - -
- - {stopInput} - {colorInput} - -
- {deleteButton} - -
-
-
- ); + return getColorStopRow({ index, errors, stopInput, colorInput, deleteButton, onAdd }); }); return
{rows}
; diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_ordinal.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_ordinal.js index 63fa52d50158f..d12691d0d9afe 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_ordinal.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_ordinal.js @@ -8,22 +8,17 @@ import _ from 'lodash'; import React from 'react'; import PropTypes from 'prop-types'; -import { - EuiColorPicker, - EuiFormRow, - EuiFieldNumber, - EuiFlexGroup, - EuiFlexItem, - EuiButtonIcon, -} from '@elastic/eui'; +import { EuiFieldNumber } from '@elastic/eui'; import { addOrdinalRow, removeRow, - isColorInvalid, + getColorInput, isOrdinalStopInvalid, isOrdinalStopsInvalid, getDeleteButton, + getColorStopRow, } from './color_stops_utils'; +import { i18n } from '@kbn/i18n'; const DEFAULT_COLOR = '#FF0000'; @@ -44,20 +39,34 @@ export const ColorStopsOrdinal = ({ let error; if (isOrdinalStopInvalid(stop)) { - error = 'Stop must be a number'; + error = i18n.translate('xpack.maps.styles.colorStops.ordinalStop.numberWarningLabel', { + defaultMessage: 'Stop must be a number', + }); } else if (index !== 0 && colorStops[index - 1].stop >= stop) { - error = 'Stop must be greater than previous stop value'; + error = i18n.translate( + 'xpack.maps.styles.colorStops.ordinalStop.numberOrderingWarningLabel', + { + defaultMessage: 'Stop must be greater than previous stop value', + } + ); } return { stopError: error, stopInput: ( - + ), }; } - function getColorInput(color, index) { + const rows = colorStops.map((colorStop, index) => { const onColorChange = color => { const newColorStops = _.cloneDeep(colorStops); newColorStops[index].color = color; @@ -67,15 +76,8 @@ export const ColorStopsOrdinal = ({ }); }; - return { - colorError: isColorInvalid(color) ? 'Color must provide a valid hex value' : undefined, - colorInput: , - }; - } - - const rows = colorStops.map((colorStop, index) => { const { stopError, stopInput } = getStopInput(colorStop.stop, index); - const { colorError, colorInput } = getColorInput(colorStop.color, index); + const { colorError, colorInput } = getColorInput(colorStops, onColorChange, colorStop.color); const errors = []; if (stopError) { errors.push(stopError); @@ -105,32 +107,7 @@ export const ColorStopsOrdinal = ({ deleteButton = getDeleteButton(onRemove); } - return ( - -
- - {stopInput} - {colorInput} - -
- {deleteButton} - -
-
-
- ); + return getColorStopRow({ index, errors, stopInput, colorInput, deleteButton, onAdd }); }); return
{rows}
; diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js index b7dd692952db7..e8dab332e7570 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js @@ -4,10 +4,17 @@ * you may not use this file except in compliance with the Elastic License. */ -import { EuiButtonIcon, EuiColorPicker, isValidHex } from '@elastic/eui'; -import _ from 'lodash'; +import { + EuiButtonIcon, + EuiColorPicker, + EuiFlexGroup, + EuiFlexItem, + EuiFormRow, + isValidHex, +} from '@elastic/eui'; import React from 'react'; import { COLOR_MAP_TYPE } from '../../../../../../common/constants'; +import { i18n } from '@kbn/i18n'; export function removeRow(colorStops, index) { if (colorStops.length === 1) { @@ -53,29 +60,57 @@ export function getDeleteButton(onRemove) { ); } -export function getColorInput(colorStops, onChange, color, index) { - const onColorChange = color => { - const newColorStops = _.cloneDeep(colorStops); - newColorStops[index].color = color; - onChange({ - colorStops: newColorStops, - isInvalid: false, - }); - }; - +export function getColorInput(colorStops, onColorChange, color) { return { - colorError: isColorInvalid(color) ? 'Color must provide a valid hex value' : undefined, + colorError: isColorInvalid(color) + ? i18n.translate('xpack.maps.styles.colorStops.hexWarningLabel', { + defaultMessage: 'Color must provide a valid hex value', + }) + : undefined, colorInput: , }; } +export function getColorStopRow({ index, errors, stopInput, colorInput, deleteButton, onAdd }) { + return ( + +
+ + {stopInput} + {colorInput} + +
+ {deleteButton} + +
+
+
+ ); +} + export function isColorInvalid(color) { return !isValidHex(color) || color === ''; } @@ -96,3 +131,6 @@ export function isOrdinalStopsInvalid(colorStops) { return isColorInvalid(colorStop.color) || isOrdinalStopInvalid(colorStop.stop) || isDescending; }); } + +export const DEFAULT_CUSTOM_COLOR = '#FF0000'; +export const DEFAULT_NEXT_COLOR = '#00FF00'; From 87fac2c4dfd89f14d4545cb9de1381dddbfcff58 Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Sun, 12 Jan 2020 19:32:27 -0500 Subject: [PATCH 005/139] remove some dupe --- .../vector/components/color/color_stops.js | 83 +++++++++++++ .../color/color_stops_categorical.js | 115 ++++++++---------- .../components/color/color_stops_ordinal.js | 113 ++++++----------- 3 files changed, 171 insertions(+), 140 deletions(-) create mode 100644 x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops.js diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops.js new file mode 100644 index 0000000000000..9c5a550b31410 --- /dev/null +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops.js @@ -0,0 +1,83 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import _ from 'lodash'; +import React from 'react'; +import { removeRow, getColorInput, getDeleteButton, getColorStopRow } from './color_stops_utils'; + +export const ColorStops = ({ + onChange, + colorStops, + isStopsInvalid, + sanitizeStopInput, + getStopError, + renderStopInput, + addNewRow, + canDeleteStop, +}) => { + function getStopInput(stop, index) { + const onStopChange = e => { + const newColorStops = _.cloneDeep(colorStops); + const newValue = sanitizeStopInput(e.target.value); + newColorStops[index].stop = newValue; + onChange({ + colorStops: newColorStops, + isInvalid: isStopsInvalid(newColorStops), + }); + }; + + const error = getStopError(stop, index); + return { + stopError: error, + stopInput: renderStopInput(stop, onStopChange, index), + }; + } + + const rows = colorStops.map((colorStop, index) => { + const onColorChange = color => { + const newColorStops = _.cloneDeep(colorStops); + newColorStops[index].color = color; + onChange({ + colorStops: newColorStops, + isInvalid: isStopsInvalid(newColorStops), + }); + }; + + const { stopError, stopInput } = getStopInput(colorStop.stop, index); + const { colorError, colorInput } = getColorInput(colorStops, onColorChange, colorStop.color); + const errors = []; + if (stopError) { + errors.push(stopError); + } + if (colorError) { + errors.push(colorError); + } + + const onAdd = () => { + const newColorStops = addNewRow(colorStops, index); + onChange({ + colorStops: newColorStops, + isInvalid: isStopsInvalid(newColorStops), + }); + }; + + let deleteButton; + if (canDeleteStop(colorStops, index)) { + const onRemove = () => { + const newColorStops = removeRow(colorStops, index); + onChange({ + colorStops: newColorStops, + isInvalid: isStopsInvalid(newColorStops), + }); + }; + deleteButton = getDeleteButton(onRemove); + } + + return getColorStopRow({ index, errors, stopInput, colorInput, deleteButton, onAdd }); + }); + + return
{rows}
; +}; diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js index d7a382a6c7e5e..41e75de90ca76 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js @@ -4,20 +4,13 @@ * you may not use this file except in compliance with the Elastic License. */ -import _ from 'lodash'; import React from 'react'; import PropTypes from 'prop-types'; import { EuiFieldText } from '@elastic/eui'; -import { - addCategoricalRow, - removeRow, - getColorInput, - getDeleteButton, - getColorStopRow, - DEFAULT_CUSTOM_COLOR, - DEFAULT_NEXT_COLOR, -} from './color_stops_utils'; +import { addCategoricalRow, DEFAULT_CUSTOM_COLOR, DEFAULT_NEXT_COLOR } from './color_stops_utils'; +import { i18n } from '@kbn/i18n'; +import { ColorStops } from './color_stops'; export const ColorStopsCategorical = ({ colorStops = [ @@ -26,23 +19,32 @@ export const ColorStopsCategorical = ({ ], onChange, }) => { - function getStopInput(stop, index) { - const onStopChange = e => { - const newColorStops = _.cloneDeep(colorStops); - newColorStops[index].stop = e.target.value; - onChange({ - colorStops: newColorStops, - isInvalid: false, - }); - }; + const sanitizeStopInput = value => { + return value; + }; + const getStopError = () => { + return null; + }; + + const renderStopInput = (stop, onStopChange, index) => { let stopInput; if (index === 0) { stopInput = ( + ); } + return stopInput; + }; - return { - stopInput: stopInput, - }; - } - - const rows = colorStops.map((colorStop, index) => { - const onColorChange = color => { - const newColorStops = _.cloneDeep(colorStops); - newColorStops[index].color = color; - onChange({ - colorStops: newColorStops, - isInvalid: false, - }); - }; - - const { stopInput } = getStopInput(colorStop.stop, index); - const { colorError, colorInput } = getColorInput(colorStops, onColorChange, colorStop.color); - const errors = colorError ? [colorError] : []; - - const onAdd = () => { - const newColorStops = addCategoricalRow(colorStops, index); - onChange({ - colorStops: newColorStops, - isInvalid: false, - }); - }; - - let deleteButton; - if (colorStops.length > 2) { - const onRemove = () => { - const newColorStops = removeRow(colorStops, index); - onChange({ - colorStops: newColorStops, - isInvalid: false, - }); - }; - deleteButton = getDeleteButton(onRemove); - } - - return getColorStopRow({ index, errors, stopInput, colorInput, deleteButton, onAdd }); - }); + const canDeleteStop = (colorStops, index) => { + return colorStops.length > 2 && index !== 0; + }; - return
{rows}
; + return ( + false} + sanitizeStopInput={sanitizeStopInput} + getStopError={getStopError} + renderStopInput={renderStopInput} + canDeleteStop={canDeleteStop} + addNewRow={addCategoricalRow} + /> + ); }; ColorStopsCategorical.propTypes = { diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_ordinal.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_ordinal.js index d12691d0d9afe..61fbb376ad601 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_ordinal.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_ordinal.js @@ -4,39 +4,29 @@ * you may not use this file except in compliance with the Elastic License. */ -import _ from 'lodash'; import React from 'react'; import PropTypes from 'prop-types'; +import { ColorStops } from './color_stops'; import { EuiFieldNumber } from '@elastic/eui'; import { addOrdinalRow, - removeRow, - getColorInput, isOrdinalStopInvalid, isOrdinalStopsInvalid, - getDeleteButton, - getColorStopRow, + DEFAULT_CUSTOM_COLOR, } from './color_stops_utils'; import { i18n } from '@kbn/i18n'; -const DEFAULT_COLOR = '#FF0000'; - export const ColorStopsOrdinal = ({ - colorStops = [{ stop: 0, color: DEFAULT_COLOR }], + colorStops = [{ stop: 0, color: DEFAULT_CUSTOM_COLOR }], onChange, }) => { - function getStopInput(stop, index) { - const onStopChange = e => { - const newColorStops = _.cloneDeep(colorStops); - const sanitizedValue = parseFloat(e.target.value); - newColorStops[index].stop = isNaN(sanitizedValue) ? '' : sanitizedValue; - onChange({ - colorStops: newColorStops, - isInvalid: isOrdinalStopsInvalid(newColorStops), - }); - }; + const sanitizeStopInput = value => { + const sanitizedValue = parseFloat(value); + return isNaN(sanitizedValue) ? '' : sanitizedValue; + }; + const getStopError = (stop, index) => { let error; if (isOrdinalStopInvalid(stop)) { error = i18n.translate('xpack.maps.styles.colorStops.ordinalStop.numberWarningLabel', { @@ -50,67 +40,38 @@ export const ColorStopsOrdinal = ({ } ); } + return error; + }; - return { - stopError: error, - stopInput: ( - - ), - }; - } - - const rows = colorStops.map((colorStop, index) => { - const onColorChange = color => { - const newColorStops = _.cloneDeep(colorStops); - newColorStops[index].color = color; - onChange({ - colorStops: newColorStops, - isInvalid: isOrdinalStopsInvalid(newColorStops), - }); - }; - - const { stopError, stopInput } = getStopInput(colorStop.stop, index); - const { colorError, colorInput } = getColorInput(colorStops, onColorChange, colorStop.color); - const errors = []; - if (stopError) { - errors.push(stopError); - } - if (colorError) { - errors.push(colorError); - } - - const onAdd = () => { - const newColorStops = addOrdinalRow(colorStops, index); - - onChange({ - colorStops: newColorStops, - isInvalid: isOrdinalStopsInvalid(newColorStops), - }); - }; - - let deleteButton; - if (colorStops.length > 1) { - const onRemove = () => { - const newColorStops = removeRow(colorStops, index); - onChange({ - colorStops: newColorStops, - isInvalid: isOrdinalStopsInvalid(newColorStops), - }); - }; - deleteButton = getDeleteButton(onRemove); - } + const renderStopInput = (stop, onStopChange) => { + return ( + + ); + }; - return getColorStopRow({ index, errors, stopInput, colorInput, deleteButton, onAdd }); - }); + const canDeleteStop = colorStops => { + return colorStops.length > 1; + }; - return
{rows}
; + return ( + + ); }; ColorStopsOrdinal.propTypes = { From a50f5729c9d65a980569c291beb10b1fa8db0f16 Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Sun, 12 Jan 2020 20:55:17 -0500 Subject: [PATCH 006/139] show unique count error log --- .../vector/components/color/color_stops.js | 3 ++- .../color/color_stops_categorical.js | 24 +++++++++++++++---- .../components/color/color_stops_utils.js | 8 +++++++ 3 files changed, 30 insertions(+), 5 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops.js index 9c5a550b31410..9f1ea340aa17f 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops.js @@ -23,9 +23,10 @@ export const ColorStops = ({ const newColorStops = _.cloneDeep(colorStops); const newValue = sanitizeStopInput(e.target.value); newColorStops[index].stop = newValue; + const invalid = isStopsInvalid(newColorStops); onChange({ colorStops: newColorStops, - isInvalid: isStopsInvalid(newColorStops), + isInvalid: invalid, }); }; diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js index 41e75de90ca76..d15157852270d 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js @@ -8,7 +8,12 @@ import React from 'react'; import PropTypes from 'prop-types'; import { EuiFieldText } from '@elastic/eui'; -import { addCategoricalRow, DEFAULT_CUSTOM_COLOR, DEFAULT_NEXT_COLOR } from './color_stops_utils'; +import { + addCategoricalRow, + isCategoricalStopsInvalid, + DEFAULT_CUSTOM_COLOR, + DEFAULT_NEXT_COLOR, +} from './color_stops_utils'; import { i18n } from '@kbn/i18n'; import { ColorStops } from './color_stops'; @@ -23,8 +28,19 @@ export const ColorStopsCategorical = ({ return value; }; - const getStopError = () => { - return null; + const getStopError = (stop, index) => { + let count = 0; + for (let i = 1; i < colorStops.length; i++) { + if (colorStops[i].stop === stop && i !== index) { + count++; + } + } + + return count + ? i18n.translate('xpack.maps.styles.colorStops.categoricalStop.noDupesWarningLabel', { + defaultMessage: 'Stops should have unique values', + }) + : null; }; const renderStopInput = (stop, onStopChange, index) => { @@ -76,7 +92,7 @@ export const ColorStopsCategorical = ({ false} + isStopsInvalid={isCategoricalStopsInvalid} sanitizeStopInput={sanitizeStopInput} getStopError={getStopError} renderStopInput={renderStopInput} diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js index e8dab332e7570..3b66f50c0abc3 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js @@ -15,6 +15,7 @@ import { import React from 'react'; import { COLOR_MAP_TYPE } from '../../../../../../common/constants'; import { i18n } from '@kbn/i18n'; +import _ from 'lodash'; export function removeRow(colorStops, index) { if (colorStops.length === 1) { @@ -119,6 +120,13 @@ export function isOrdinalStopInvalid(stop) { return stop === '' || isNaN(stop); } +export function isCategoricalStopsInvalid(colorStops) { + const nonDefaults = colorStops.slice(1); // + const values = nonDefaults.map(stop => stop.stop); + const uniques = _.uniq(values); + return values.length !== uniques.length; +} + export function isOrdinalStopsInvalid(colorStops) { return colorStops.some((colorStop, index) => { // expect stops to be in ascending order From ea9ea1416625ebdd7bdce4b1c7f9cbf262398c8d Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Sun, 12 Jan 2020 21:26:30 -0500 Subject: [PATCH 007/139] remove redundant props check vlaidyt --- .../styles/vector/components/color/color_palette_select.js | 1 + .../styles/vector/components/color/color_ramp_select.js | 1 + .../styles/vector/components/color/dynamic_color_form.js | 6 ++++-- .../styles/vector/properties/dynamic_color_property.js | 5 +++++ 4 files changed, 11 insertions(+), 2 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_palette_select.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_palette_select.js index b161e9a24df58..5238dda1a1dca 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_palette_select.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_palette_select.js @@ -69,6 +69,7 @@ export class ColorPaletteSelect extends Component { this.props.onChange({ type: COLOR_MAP_TYPE.CATEGORICAL, customColorPalette: colorStops, + useCustomColorPalette: true, }); }; diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_ramp_select.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_ramp_select.js index f8dd7fa11c27c..29f954b56f061 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_ramp_select.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_ramp_select.js @@ -48,6 +48,7 @@ export class ColorRampSelect extends Component { this.props.onChange({ customColorRamp: colorStops, type: COLOR_MAP_TYPE.ORDINAL, + useCustomColorRamp: true, }); }; diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js index 546c9394e4865..39b4cd7b6750b 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js @@ -64,10 +64,12 @@ export class DynamicColorForm extends React.Component { let colorSelect; if (styleOptions.field && styleOptions.field.name) { const onColorChange = colorOptions => { - onDynamicStyleChange(styleProperty.getStyleName(), { + const newOptions = { ...styleOptions, ...colorOptions, - }); + }; + + onDynamicStyleChange(styleProperty.getStyleName(), newOptions); }; if (this.state.colorMapType === COLOR_MAP_TYPE.ORDINAL) { colorSelect = ( diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js index 27b06810c1439..3f59a4cc2acda 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js @@ -21,6 +21,7 @@ import { import { VectorIcon } from '../components/legend/vector_icon'; import { VECTOR_STYLES } from '../vector_style_defaults'; import { COLOR_MAP_TYPE } from '../../../../../common/constants'; +import { isCategoricalStopsInvalid } from '../components/color/color_stops_utils'; export class DynamicColorProperty extends DynamicStyleProperty { syncCircleColorWithMb(mbLayerId, mbMap, alpha) { @@ -136,6 +137,10 @@ export class DynamicColorProperty extends DynamicStyleProperty { _getColorPaletteStops() { if (this._options.useCustomColorPalette && this._options.customColorPalette) { + if (isCategoricalStopsInvalid(this._options.customColorPalette)) { + return []; + } + return this._options.customColorPalette.map((config, index) => { return { stop: config.stop, From 599b1a46be80cdd3117ae4541cdb959f795cb6f3 Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Sun, 12 Jan 2020 21:44:01 -0500 Subject: [PATCH 008/139] delete incompatible props add unit test for legend rendering more tests --- .../components/color/dynamic_color_form.js | 16 +- .../dynamic_color_property.test.js.snap | 242 +++++++++++++++++- .../properties/dynamic_color_property.test.js | 193 +++++++++++--- .../properties/dynamic_style_property.js | 2 +- 4 files changed, 414 insertions(+), 39 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js index 39b4cd7b6750b..71a192d93dbaa 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js @@ -64,11 +64,23 @@ export class DynamicColorForm extends React.Component { let colorSelect; if (styleOptions.field && styleOptions.field.name) { const onColorChange = colorOptions => { + const oldStyleOptions = { ...styleOptions }; + + if (oldStyleOptions.type === !colorOptions.type) { + delete oldStyleOptions.type; + if (colorOptions.type === COLOR_MAP_TYPE.ORDINAL) { + delete oldStyleOptions.useCustomColorPalette; + delete oldStyleOptions.customColorPalette; + } else { + delete oldStyleOptions.useCustomColorRamp; + delete oldStyleOptions.customColorRamp; + } + } + const newOptions = { - ...styleOptions, + ...oldStyleOptions, ...colorOptions, }; - onDynamicStyleChange(styleProperty.getStyleName(), newOptions); }; if (this.state.colorMapType === COLOR_MAP_TYPE.ORDINAL) { diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/__snapshots__/dynamic_color_property.test.js.snap b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/__snapshots__/dynamic_color_property.test.js.snap index 26e36cb97a791..a037748f32258 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/__snapshots__/dynamic_color_property.test.js.snap +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/__snapshots__/dynamic_color_property.test.js.snap @@ -1,6 +1,6 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`Should render categorical legend 1`] = ` +exports[`Should render categorical legend with breaks from custom 1`] = `
- 0_format + + Default + @@ -43,7 +47,147 @@ exports[`Should render categorical legend 1`] = ` - 10_format + US_STOP_format + + + + + + + + + + + + CN_STOP_format + + + + + + + + + + + + + + + foobar_label + + + + + + +
+`; + +exports[`Should render categorical legend with breaks from default 1`] = ` +
+ + + + + + + + Default + + + + + + + + + + + + + US_format + + + + + + + + + + + + CN_format @@ -90,7 +234,7 @@ exports[`Should render categorical legend 1`] = `
`; -exports[`Should render ranged legend 1`] = ` +exports[`Should render ordinal legend 1`] = ` `; + +exports[`Should render ordinal legend with breaks 1`] = ` +
+ + + + + + + 0_format + + + + + + + + + + + + 10_format + + + + + + + + + + + + + + + foobar_label + + + + + + +
+`; diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.test.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.test.js index dbf704c9cbe4c..3d2701cd11d45 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.test.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.test.js @@ -10,12 +10,12 @@ import { shallow } from 'enzyme'; import { VECTOR_STYLES } from '../vector_style_defaults'; import { DynamicColorProperty } from './dynamic_color_property'; +import { COLOR_MAP_TYPE } from '../../../../../common/constants'; const mockField = { async getLabel() { return 'foobar_label'; }, - getName() { return 'foobar'; }, @@ -24,29 +24,55 @@ const mockField = { }, }; -test('Should render ranged legend', async () => { - const colorStyle = new DynamicColorProperty( - { - color: 'Blues', - }, +const getOrdinalFieldMeta = () => { + return { min: 0, max: 100 }; +}; + +const getCategoricalFieldMeta = () => { + return { + categories: [ + { + key: 'US', + count: 10, + }, + { + key: 'CN', + count: 8, + }, + ], + }; +}; +const makeProperty = (options, getFieldMeta) => { + return new DynamicColorProperty( + options, VECTOR_STYLES.LINE_COLOR, mockField, - () => { - return { min: 0, max: 100 }; - }, + getFieldMeta, () => { return x => x + '_format'; } ); +}; - const legendRow = colorStyle.renderLegendDetailRow({ - loadIsPointsOnly: () => { - return true; - }, - loadIsLinesOnly: () => { - return false; +const defaultLegendParams = { + loadIsPointsOnly: () => { + return true; + }, + loadIsLinesOnly: () => { + return false; + }, +}; + +test('Should render ordinal legend', async () => { + const colorStyle = makeProperty( + { + color: 'Blues', + type: undefined, }, - }); + getOrdinalFieldMeta + ); + + const legendRow = colorStyle.renderLegendDetailRow(defaultLegendParams); const component = shallow(legendRow); @@ -58,9 +84,10 @@ test('Should render ranged legend', async () => { expect(component).toMatchSnapshot(); }); -test('Should render categorical legend', async () => { - const colorStyle = new DynamicColorProperty( +test('Should render ordinal legend with breaks', async () => { + const colorStyle = makeProperty( { + type: COLOR_MAP_TYPE.ORDINAL, useCustomColorRamp: true, customColorRamp: [ { @@ -73,24 +100,67 @@ test('Should render categorical legend', async () => { }, ], }, - VECTOR_STYLES.LINE_COLOR, - mockField, - () => { - return { min: 0, max: 100 }; - }, - () => { - return x => x + '_format'; - } + getOrdinalFieldMeta ); - const legendRow = colorStyle.renderLegendDetailRow({ - loadIsPointsOnly: () => { - return true; + const legendRow = colorStyle.renderLegendDetailRow(defaultLegendParams); + + const component = shallow(legendRow); + + // Ensure all promises resolve + await new Promise(resolve => process.nextTick(resolve)); + // Ensure the state changes are reflected + component.update(); + + expect(component).toMatchSnapshot(); +}); + +test('Should render categorical legend with breaks from default', async () => { + const colorStyle = makeProperty( + { + type: COLOR_MAP_TYPE.CATEGORICAL, + useCustomColorPalette: false, + color: 'palette_0', }, - loadIsLinesOnly: () => { - return false; + getCategoricalFieldMeta + ); + + const legendRow = colorStyle.renderLegendDetailRow(defaultLegendParams); + + const component = shallow(legendRow); + + // Ensure all promises resolve + await new Promise(resolve => process.nextTick(resolve)); + // Ensure the state changes are reflected + component.update(); + + expect(component).toMatchSnapshot(); +}); + +test('Should render categorical legend with breaks from custom', async () => { + const colorStyle = makeProperty( + { + type: COLOR_MAP_TYPE.CATEGORICAL, + useCustomColorPalette: true, + customColorPalette: [ + { + stop: null, //should include the default stop + color: '#FFFF00', + }, + { + stop: 'US_STOP', + color: '#FF0000', + }, + { + stop: 'CN_STOP', + color: '#00FF00', + }, + ], }, - }); + getCategoricalFieldMeta + ); + + const legendRow = colorStyle.renderLegendDetailRow(defaultLegendParams); const component = shallow(legendRow); @@ -101,3 +171,62 @@ test('Should render categorical legend', async () => { expect(component).toMatchSnapshot(); }); + +function makeFeatures(foobarPropValues) { + return foobarPropValues.map(value => { + return { + type: 'Feature', + properties: { + foobar: value, + }, + }; + }); +} + +test('Should pluck the categorical style-meta', async () => { + const colorStyle = makeProperty({ + type: COLOR_MAP_TYPE.CATEGORICAL, + color: 'palette_0', + getCategoricalFieldMeta, + }); + + const features = makeFeatures(['CN', 'CN', 'US', 'CN', 'US', 'IN']); + const meta = colorStyle.pluckStyleMetaFromFeatures(features); + + expect(meta).toEqual({ + categories: [ + { key: 'CN', count: 3 }, + { key: 'US', count: 2 }, + { key: 'IN', count: 1 }, + ], + }); +}); + +test('Should pluck the categorical style-meta from fieldmeta', async () => { + const colorStyle = makeProperty({ + type: COLOR_MAP_TYPE.CATEGORICAL, + color: 'palette_0', + getCategoricalFieldMeta, + }); + + const meta = colorStyle.pluckStyleMetaFromFieldMetaData({ + foobar: { + buckets: [ + { + key: 'CN', + doc_count: 3, + }, + { key: 'US', doc_count: 2 }, + { key: 'IN', doc_count: 1 }, + ], + }, + }); + + expect(meta).toEqual({ + categories: [ + { key: 'CN', count: 3 }, + { key: 'US', count: 2 }, + { key: 'IN', count: 1 }, + ], + }); +}); diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js index 5a9ba1d6f03c2..13ba979e6bf40 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js @@ -140,7 +140,7 @@ export class DynamicStyleProperty extends AbstractStyleProperty { } ordered.sort((a, b) => { - return a.count - b.count; + return b.count - a.count; }); const truncated = ordered.slice(0, COLOR_PALETTE_MAX_SIZE); return { From f1285997f5469edb197174692229e5fa046ac2a1 Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Sun, 12 Jan 2020 22:35:35 -0500 Subject: [PATCH 009/139] fix text --- .../styles/vector/components/color/color_stops_categorical.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js index d15157852270d..aff3a7f0d03db 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js @@ -105,8 +105,8 @@ export const ColorStopsCategorical = ({ ColorStopsCategorical.propTypes = { /** * Array of { stop, color }. - * Stops are numbers in strictly ascending order. - * The range is from the given stop number (inclusive) to the next stop number (exclusive). + * Stops are any strings + * Stops cannot include duplicates * Colors are color hex strings (3 or 6 character). */ colorStops: PropTypes.arrayOf( From 4334e9a23bb5f618832867719879f215bec4d2f9 Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Sun, 12 Jan 2020 22:39:51 -0500 Subject: [PATCH 010/139] rename for clarity --- .../legacy/plugins/maps/public/layers/styles/color_utils.js | 2 +- .../plugins/maps/public/layers/styles/color_utils.test.js | 4 ++-- .../maps/public/layers/styles/heatmap/heatmap_style.js | 4 ++-- .../layers/styles/vector/properties/dynamic_color_property.js | 4 ++-- 4 files changed, 7 insertions(+), 7 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.js b/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.js index a6188b317573b..bdcb6f3d86af9 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.js @@ -59,7 +59,7 @@ export function getColorRampCenterColor(colorRampName) { // Returns an array of color stops // [ stop_input_1: number, stop_output_1: color, stop_input_n: number, stop_output_n: color ] -export function getColorRampStops(colorRampName, numberColors = GRADIENT_INTERVALS) { +export function getOrdinalColorRampStops(colorRampName, numberColors = GRADIENT_INTERVALS) { return getHexColorRangeStrings(colorRampName, numberColors).reduce( (accu, stopColor, idx, srcArr) => { const stopNumber = idx / srcArr.length; // number between 0 and 1, increasing as index increases diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.test.js b/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.test.js index 8826c771fab19..1d7fbeb996915 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.test.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.test.js @@ -7,7 +7,7 @@ import { COLOR_GRADIENTS, getColorRampCenterColor, - getColorRampStops, + getOrdinalColorRampStops, getHexColorRangeStrings, getLinearGradient, getRGBColorRangeStrings, @@ -59,7 +59,7 @@ describe('getColorRampCenterColor', () => { describe('getColorRampStops', () => { it('Should create color stops for color ramp', () => { - expect(getColorRampStops('Blues')).toEqual([ + expect(getOrdinalColorRampStops('Blues')).toEqual([ 0, '#f7faff', 0.125, diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/heatmap/heatmap_style.js b/x-pack/legacy/plugins/maps/public/layers/styles/heatmap/heatmap_style.js index 0b4a52997c00e..1dd219d4c4cad 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/heatmap/heatmap_style.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/heatmap/heatmap_style.js @@ -11,7 +11,7 @@ import { HeatmapStyleEditor } from './components/heatmap_style_editor'; import { HeatmapLegend } from './components/legend/heatmap_legend'; import { DEFAULT_HEATMAP_COLOR_RAMP_NAME } from './components/heatmap_constants'; import { LAYER_STYLE_TYPE } from '../../../../common/constants'; -import { getColorRampStops } from '../color_utils'; +import { getOrdinalColorRampStops } from '../color_utils'; import { i18n } from '@kbn/i18n'; import { EuiIcon } from '@elastic/eui'; @@ -81,7 +81,7 @@ export class HeatmapStyle extends AbstractStyle { const { colorRampName } = this._descriptor; if (colorRampName && colorRampName !== DEFAULT_HEATMAP_COLOR_RAMP_NAME) { - const colorStops = getColorRampStops(colorRampName); + const colorStops = getOrdinalColorRampStops(colorRampName); mbMap.setPaintProperty(layerId, 'heatmap-color', [ 'interpolate', ['linear'], diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js index 3f59a4cc2acda..0354fb6b6d576 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js @@ -7,7 +7,7 @@ import { DynamicStyleProperty } from './dynamic_style_property'; import _ from 'lodash'; import { getComputedFieldName } from '../style_util'; -import { getColorRampStops, getColorPalette } from '../../color_utils'; +import { getOrdinalColorRampStops, getColorPalette } from '../../color_utils'; import { ColorGradient } from '../../components/color_gradient'; import React from 'react'; import { @@ -212,7 +212,7 @@ export class DynamicColorProperty extends DynamicStyleProperty { if (this._options.useCustomColorRamp) { return this._getOrdinalColorStopsFromCustom(); } else { - return getColorRampStops(this._options.color); + return getOrdinalColorRampStops(this._options.color); } } From 17d51ac876172cbe716a9e3e174e2325af22cea7 Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Sun, 12 Jan 2020 23:48:44 -0500 Subject: [PATCH 011/139] remove gradients from defaults restore deal with incomplete config --- .../sources/es_geo_grid_source/es_geo_grid_source.js | 3 ++- .../layers/sources/es_pew_pew_source/es_pew_pew_source.js | 3 ++- .../plugins/maps/public/layers/styles/color_utils.js | 3 +++ .../legend/extract_color_from_style_property.js | 7 +++++++ .../public/layers/styles/vector/vector_style_defaults.js | 8 ++++---- 5 files changed, 18 insertions(+), 6 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/sources/es_geo_grid_source/es_geo_grid_source.js b/x-pack/legacy/plugins/maps/public/layers/sources/es_geo_grid_source/es_geo_grid_source.js index 4a18fdc1a2e96..39f7666589a73 100644 --- a/x-pack/legacy/plugins/maps/public/layers/sources/es_geo_grid_source/es_geo_grid_source.js +++ b/x-pack/legacy/plugins/maps/public/layers/sources/es_geo_grid_source/es_geo_grid_source.js @@ -19,6 +19,7 @@ import { getDefaultDynamicProperties, VECTOR_STYLES, } from '../../styles/vector/vector_style_defaults'; +import { COLOR_GRADIENTS } from '../../styles/color_utils'; import { RENDER_AS } from './render_as'; import { CreateSourceEditor } from './create_source_editor'; import { UpdateSourceEditor } from './update_source_editor'; @@ -255,7 +256,7 @@ export class ESGeoGridSource extends AbstractESAggSource { name: COUNT_PROP_NAME, origin: SOURCE_DATA_ID_ORIGIN, }, - color: 'Blues', + color: COLOR_GRADIENTS[0].value, }, }, [VECTOR_STYLES.LINE_COLOR]: { diff --git a/x-pack/legacy/plugins/maps/public/layers/sources/es_pew_pew_source/es_pew_pew_source.js b/x-pack/legacy/plugins/maps/public/layers/sources/es_pew_pew_source/es_pew_pew_source.js index 66d62dd5644ac..e14c42bae5fd2 100644 --- a/x-pack/legacy/plugins/maps/public/layers/sources/es_pew_pew_source/es_pew_pew_source.js +++ b/x-pack/legacy/plugins/maps/public/layers/sources/es_pew_pew_source/es_pew_pew_source.js @@ -29,6 +29,7 @@ import { Schemas } from 'ui/vis/editors/default/schemas'; import { AggConfigs } from 'ui/agg_types'; import { AbstractESAggSource } from '../es_agg_source'; import { DynamicStyleProperty } from '../../styles/vector/properties/dynamic_style_property'; +import { COLOR_GRADIENTS } from '../../styles/color_utils'; const MAX_GEOTILE_LEVEL = 29; @@ -142,7 +143,7 @@ export class ESPewPewSource extends AbstractESAggSource { name: COUNT_PROP_NAME, origin: SOURCE_DATA_ID_ORIGIN, }, - color: 'Blues', + color: COLOR_GRADIENTS[0].value, }, }, [VECTOR_STYLES.LINE_WIDTH]: { diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.js b/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.js index bdcb6f3d86af9..1f4250d3331d8 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.js @@ -52,6 +52,9 @@ export function getHexColorRangeStrings(colorRampName, numberColors = GRADIENT_I } export function getColorRampCenterColor(colorRampName) { + if (!colorRampName) { + return null; + } const colorRamp = getColorRamp(colorRampName); const centerIndex = Math.floor(colorRamp.value.length / 2); return getColor(colorRamp.value, centerIndex); diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/legend/extract_color_from_style_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/legend/extract_color_from_style_property.js index 3b11c7b77a237..d3862f80385f4 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/legend/extract_color_from_style_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/legend/extract_color_from_style_property.js @@ -30,6 +30,10 @@ export function extractColorFromStyleProperty(colorStyleProperty, defaultColor) : defaultColor; } + if (!colorStyleProperty.options.color) { + return null; + } + const palette = getColorPalette(colorStyleProperty.options.color); return palette[0]; } else { @@ -46,6 +50,9 @@ export function extractColorFromStyleProperty(colorStyleProperty, defaultColor) return colorStyleProperty.options.customColorRamp[middleIndex].color; } + if (!colorStyleProperty.options.color) { + return null; + } return getColorRampCenterColor(colorStyleProperty.options.color); } } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style_defaults.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style_defaults.js index 4bae90c3165f2..85d6a8b500b73 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style_defaults.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style_defaults.js @@ -6,7 +6,7 @@ import { VectorStyle } from './vector_style'; import { SYMBOLIZE_AS_CIRCLE, DEFAULT_ICON_SIZE } from './vector_constants'; -import { COLOR_GRADIENTS, DEFAULT_FILL_COLORS, DEFAULT_LINE_COLORS } from '../color_utils'; +import { DEFAULT_FILL_COLORS, DEFAULT_LINE_COLORS } from '../color_utils'; import chrome from 'ui/chrome'; const DEFAULT_ICON = 'airfield'; @@ -114,7 +114,7 @@ export function getDefaultDynamicProperties() { [VECTOR_STYLES.FILL_COLOR]: { type: VectorStyle.STYLE_TYPE.DYNAMIC, options: { - color: COLOR_GRADIENTS[0].value, + color: undefined, field: undefined, fieldMetaOptions: { isEnabled: true, @@ -125,7 +125,7 @@ export function getDefaultDynamicProperties() { [VECTOR_STYLES.LINE_COLOR]: { type: VectorStyle.STYLE_TYPE.DYNAMIC, options: { - color: COLOR_GRADIENTS[0].value, + color: undefined, field: undefined, fieldMetaOptions: { isEnabled: true, @@ -176,7 +176,7 @@ export function getDefaultDynamicProperties() { [VECTOR_STYLES.LABEL_COLOR]: { type: VectorStyle.STYLE_TYPE.STATIC, options: { - color: COLOR_GRADIENTS[0].value, + color: undefined, field: undefined, fieldMetaOptions: { isEnabled: true, From 204155b4e2c159c4a9f7ef70ed07f70b8564b49c Mon Sep 17 00:00:00 2001 From: Joe Reuter Date: Mon, 13 Jan 2020 10:26:57 +0100 Subject: [PATCH 012/139] [Graph] Fix various a11y issues (#54097) --- .../dashboard_listing.test.js.snap | 42 +++++++++++++------ .../np_ready/listing/dashboard_listing.js | 9 ++-- .../listing/visualize_listing_table.js | 9 ++-- .../table_list_view/table_list_view.tsx | 13 +++++- .../public/angular/templates/_sidebar.scss | 1 + .../graph/public/angular/templates/index.html | 14 ++++++- .../plugins/graph/public/components/app.tsx | 2 + .../graph/public/components/graph_title.tsx | 26 ++++++++++++ .../guidance_panel/_guidance_panel.scss | 6 --- .../guidance_panel/guidance_panel.tsx | 20 ++++++--- .../graph/public/components/listing.tsx | 11 ++--- 11 files changed, 113 insertions(+), 40 deletions(-) create mode 100644 x-pack/legacy/plugins/graph/public/components/graph_title.tsx diff --git a/src/legacy/core_plugins/kibana/public/dashboard/np_ready/listing/__snapshots__/dashboard_listing.test.js.snap b/src/legacy/core_plugins/kibana/public/dashboard/np_ready/listing/__snapshots__/dashboard_listing.test.js.snap index b2f004568841a..2a9a793ba43c4 100644 --- a/src/legacy/core_plugins/kibana/public/dashboard/np_ready/listing/__snapshots__/dashboard_listing.test.js.snap +++ b/src/legacy/core_plugins/kibana/public/dashboard/np_ready/listing/__snapshots__/dashboard_listing.test.js.snap @@ -9,6 +9,7 @@ exports[`after fetch hideWriteControls 1`] = ` entityName="dashboard" entityNamePlural="dashboards" findItems={[Function]} + headingId="dashboardListingHeading" initialFilter="" listingLimit={1} noItemsFragment={ @@ -16,13 +17,15 @@ exports[`after fetch hideWriteControls 1`] = ` +

-

+ } />
@@ -63,6 +66,7 @@ exports[`after fetch initialFilter 1`] = ` entityName="dashboard" entityNamePlural="dashboards" findItems={[Function]} + headingId="dashboardListingHeading" initialFilter="my dashboard" listingLimit={1000} noItemsFragment={ @@ -114,13 +118,15 @@ exports[`after fetch initialFilter 1`] = ` } iconType="dashboardApp" title={ -

+

-

+ } /> @@ -161,6 +167,7 @@ exports[`after fetch renders call to action when no dashboards exist 1`] = ` entityName="dashboard" entityNamePlural="dashboards" findItems={[Function]} + headingId="dashboardListingHeading" initialFilter="" listingLimit={1} noItemsFragment={ @@ -212,13 +219,15 @@ exports[`after fetch renders call to action when no dashboards exist 1`] = ` } iconType="dashboardApp" title={ -

+

-

+ } /> @@ -259,6 +268,7 @@ exports[`after fetch renders table rows 1`] = ` entityName="dashboard" entityNamePlural="dashboards" findItems={[Function]} + headingId="dashboardListingHeading" initialFilter="" listingLimit={1000} noItemsFragment={ @@ -310,13 +320,15 @@ exports[`after fetch renders table rows 1`] = ` } iconType="dashboardApp" title={ -

+

-

+ } /> @@ -357,6 +369,7 @@ exports[`after fetch renders warning when listingLimit is exceeded 1`] = ` entityName="dashboard" entityNamePlural="dashboards" findItems={[Function]} + headingId="dashboardListingHeading" initialFilter="" listingLimit={1} noItemsFragment={ @@ -408,13 +421,15 @@ exports[`after fetch renders warning when listingLimit is exceeded 1`] = ` } iconType="dashboardApp" title={ -

+

-

+ } /> @@ -455,6 +470,7 @@ exports[`renders empty page in before initial fetch to avoid flickering 1`] = ` entityName="dashboard" entityNamePlural="dashboards" findItems={[Function]} + headingId="dashboardListingHeading" initialFilter="" listingLimit={1000} noItemsFragment={ @@ -506,13 +522,15 @@ exports[`renders empty page in before initial fetch to avoid flickering 1`] = ` } iconType="dashboardApp" title={ -

+

-

+ } /> diff --git a/src/legacy/core_plugins/kibana/public/dashboard/np_ready/listing/dashboard_listing.js b/src/legacy/core_plugins/kibana/public/dashboard/np_ready/listing/dashboard_listing.js index 827fe6eabe784..30bf940069fb7 100644 --- a/src/legacy/core_plugins/kibana/public/dashboard/np_ready/listing/dashboard_listing.js +++ b/src/legacy/core_plugins/kibana/public/dashboard/np_ready/listing/dashboard_listing.js @@ -42,6 +42,7 @@ export class DashboardListing extends React.Component { return ( +

-

+ } /> @@ -90,12 +91,12 @@ export class DashboardListing extends React.Component { +

-

+ } body={ diff --git a/src/legacy/core_plugins/kibana/public/visualize/np_ready/listing/visualize_listing_table.js b/src/legacy/core_plugins/kibana/public/visualize/np_ready/listing/visualize_listing_table.js index 840e647edcc86..b770625cd3d70 100644 --- a/src/legacy/core_plugins/kibana/public/visualize/np_ready/listing/visualize_listing_table.js +++ b/src/legacy/core_plugins/kibana/public/visualize/np_ready/listing/visualize_listing_table.js @@ -36,6 +36,7 @@ class VisualizeListingTable extends Component { const { visualizeCapabilities, uiSettings, toastNotifications } = getServices(); return ( +

-

+ } /> @@ -130,12 +131,12 @@ class VisualizeListingTable extends Component { +

-

+ } body={ diff --git a/src/plugins/kibana_react/public/table_list_view/table_list_view.tsx b/src/plugins/kibana_react/public/table_list_view/table_list_view.tsx index 2e7b22a14fb0e..4c2dac4f39134 100644 --- a/src/plugins/kibana_react/public/table_list_view/table_list_view.tsx +++ b/src/plugins/kibana_react/public/table_list_view/table_list_view.tsx @@ -67,6 +67,11 @@ export interface TableListViewProps { tableListTitle: string; toastNotifications: ToastsStart; uiSettings: IUiSettingsClient; + /** + * Id of the heading element describing the table. This id will be used as `aria-labelledby` of the wrapper element. + * If the table is not empty, this component renders its own h1 element using the same id. + */ + headingId?: string; } export interface TableListViewState { @@ -463,7 +468,7 @@ class TableListView extends React.Component -

{this.props.tableListTitle}

+

{this.props.tableListTitle}

@@ -498,7 +503,11 @@ class TableListView extends React.Component - {this.renderPageContent()} + + {this.renderPageContent()} + ); } diff --git a/x-pack/legacy/plugins/graph/public/angular/templates/_sidebar.scss b/x-pack/legacy/plugins/graph/public/angular/templates/_sidebar.scss index 6fa51c1ba1ec8..e54158e2ad8ce 100644 --- a/x-pack/legacy/plugins/graph/public/angular/templates/_sidebar.scss +++ b/x-pack/legacy/plugins/graph/public/angular/templates/_sidebar.scss @@ -13,6 +13,7 @@ .help-block { font-size: $euiFontSizeXS; + color: $euiTextColor; } } diff --git a/x-pack/legacy/plugins/graph/public/angular/templates/index.html b/x-pack/legacy/plugins/graph/public/angular/templates/index.html index 20b1059ae45ec..4493d794cb8d1 100644 --- a/x-pack/legacy/plugins/graph/public/angular/templates/index.html +++ b/x-pack/legacy/plugins/graph/public/angular/templates/index.html @@ -1,4 +1,4 @@ -
+
@@ -81,6 +81,7 @@ @@ -386,4 +396,4 @@
- + diff --git a/x-pack/legacy/plugins/graph/public/components/app.tsx b/x-pack/legacy/plugins/graph/public/components/app.tsx index 5ff7fc2e5da93..957a8f66907a1 100644 --- a/x-pack/legacy/plugins/graph/public/components/app.tsx +++ b/x-pack/legacy/plugins/graph/public/components/app.tsx @@ -16,6 +16,7 @@ import { FieldManager } from './field_manager'; import { SearchBarProps, SearchBar } from './search_bar'; import { GraphStore } from '../state_management'; import { GuidancePanel } from './guidance_panel'; +import { GraphTitle } from './graph_title'; import { KibanaContextProvider } from '../../../../../../src/plugins/kibana_react/public'; @@ -52,6 +53,7 @@ export function GraphApp(props: GraphAppProps) { > <> + {props.isInitialized && }
diff --git a/x-pack/legacy/plugins/graph/public/components/graph_title.tsx b/x-pack/legacy/plugins/graph/public/components/graph_title.tsx new file mode 100644 index 0000000000000..8151900da0c07 --- /dev/null +++ b/x-pack/legacy/plugins/graph/public/components/graph_title.tsx @@ -0,0 +1,26 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { connect } from 'react-redux'; +import { EuiScreenReaderOnly } from '@elastic/eui'; +import React from 'react'; + +import { GraphState, metaDataSelector } from '../state_management'; + +interface GraphTitleProps { + title: string; +} + +/** + * Component showing the title of the current workspace as a heading visible for screen readers + */ +export const GraphTitle = connect((state: GraphState) => ({ + title: metaDataSelector(state).title, +}))(({ title }: GraphTitleProps) => ( + +

{title}

+
+)); diff --git a/x-pack/legacy/plugins/graph/public/components/guidance_panel/_guidance_panel.scss b/x-pack/legacy/plugins/graph/public/components/guidance_panel/_guidance_panel.scss index f1c332eba1aa8..e1423b794dcd3 100644 --- a/x-pack/legacy/plugins/graph/public/components/guidance_panel/_guidance_panel.scss +++ b/x-pack/legacy/plugins/graph/public/components/guidance_panel/_guidance_panel.scss @@ -15,16 +15,10 @@ position: relative; padding-left: $euiSizeXL; margin-bottom: $euiSizeL; - - button { - // make buttons wrap lines like regular text - display: contents; - } } .gphGuidancePanel__item--disabled { color: $euiColorDarkShade; - pointer-events: none; button { color: $euiColorDarkShade !important; diff --git a/x-pack/legacy/plugins/graph/public/components/guidance_panel/guidance_panel.tsx b/x-pack/legacy/plugins/graph/public/components/guidance_panel/guidance_panel.tsx index 5fae9720db39a..f34b82d6bb1a3 100644 --- a/x-pack/legacy/plugins/graph/public/components/guidance_panel/guidance_panel.tsx +++ b/x-pack/legacy/plugins/graph/public/components/guidance_panel/guidance_panel.tsx @@ -13,6 +13,7 @@ import { EuiText, EuiLink, EuiCallOut, + EuiScreenReaderOnly, } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; import classNames from 'classnames'; @@ -53,6 +54,7 @@ function ListItem({ 'gphGuidancePanel__item--disabled': state === 'disabled', })} aria-disabled={state === 'disabled'} + aria-current={state === 'active' ? 'step' : undefined} > {state !== 'disabled' && ( -

+

{i18n.translate('xpack.graph.guidancePanel.title', { defaultMessage: 'Three steps to your graph', })} @@ -104,7 +106,7 @@ function GuidancePanelComponent(props: GuidancePanelProps) { -
    +
      {i18n.translate( @@ -116,7 +118,7 @@ function GuidancePanelComponent(props: GuidancePanelProps) { - + {i18n.translate('xpack.graph.guidancePanel.fieldsItem.fieldsButtonLabel', { defaultMessage: 'Add fields.', })} @@ -128,7 +130,7 @@ function GuidancePanelComponent(props: GuidancePanelProps) { defaultMessage="Enter a query in the search bar to start exploring. Don't know where to start? {topTerms}." values={{ topTerms: ( - + {i18n.translate('xpack.graph.guidancePanel.nodesItem.topTermsButtonLabel', { defaultMessage: 'Graph the top terms', })} @@ -137,7 +139,7 @@ function GuidancePanelComponent(props: GuidancePanelProps) { }} /> -
+
@@ -157,7 +159,15 @@ function GuidancePanelComponent(props: GuidancePanelProps) { title={i18n.translate('xpack.graph.noDataSourceNotificationMessageTitle', { defaultMessage: 'No data source', })} + heading="h1" > + +

+ {i18n.translate('xpack.graph.noDataSourceNotificationMessageTitle', { + defaultMessage: 'No data source', + })} +

+

+

-

+ } />
@@ -88,12 +89,12 @@ function getNoItemsMessage( +

-

+ } body={ From a04048b1bbb6a90fd899c3c2c14deb5d26293b87 Mon Sep 17 00:00:00 2001 From: Thomas Watson Date: Mon, 13 Jan 2020 11:35:57 +0100 Subject: [PATCH 013/139] fix(package): upgrade transitive dependency elliptic to v6.5.2 (#54476) --- yarn.lock | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/yarn.lock b/yarn.lock index 96bb533120aa7..3dd7dbe37b2e9 100644 --- a/yarn.lock +++ b/yarn.lock @@ -10915,9 +10915,9 @@ element-resize-detector@^1.1.15: batch-processor "^1.0.0" elliptic@^6.0.0: - version "6.4.0" - resolved "https://registry.yarnpkg.com/elliptic/-/elliptic-6.4.0.tgz#cac9af8762c85836187003c8dfe193e5e2eae5df" - integrity sha1-ysmvh2LIWDYYcAPI3+GT5eLq5d8= + version "6.5.2" + resolved "https://registry.yarnpkg.com/elliptic/-/elliptic-6.5.2.tgz#05c5678d7173c049d8ca433552224a495d0e3762" + integrity sha512-f4x70okzZbIQl/NSRLkI/+tteV/9WqL98zx+SQ69KbXxmVrmjwsNUPn/gYJJ0sHvEak24cZgHIPegRePAtA/xw== dependencies: bn.js "^4.4.0" brorand "^1.0.1" From fb9907e4f06dff0b263219ed0aa38b02fbb6272a Mon Sep 17 00:00:00 2001 From: Chris Mark Date: Mon, 13 Jan 2020 12:40:46 +0200 Subject: [PATCH 014/139] [Home][Tutorial] Add data UI for IBM MQ Filebeat module (#54238) --- .../ibmmq_logs/screenshot.png | Bin 0 -> 256401 bytes .../home/tutorial_resources/logos/ibmmq.svg | 1 + .../server/tutorials/ibmmq_logs/index.js | 71 ++++++++++++++++++ .../kibana/server/tutorials/register.js | 2 + 4 files changed, 74 insertions(+) create mode 100644 src/legacy/core_plugins/kibana/public/home/tutorial_resources/ibmmq_logs/screenshot.png create mode 100644 src/legacy/core_plugins/kibana/public/home/tutorial_resources/logos/ibmmq.svg create mode 100644 src/legacy/core_plugins/kibana/server/tutorials/ibmmq_logs/index.js diff --git a/src/legacy/core_plugins/kibana/public/home/tutorial_resources/ibmmq_logs/screenshot.png b/src/legacy/core_plugins/kibana/public/home/tutorial_resources/ibmmq_logs/screenshot.png new file mode 100644 index 0000000000000000000000000000000000000000..100a8b6ae367c4959e097b895ccc310f08bebf9d GIT binary patch literal 256401 zcmeFZWmH|;mM)6B1PSgA!QEYgyL)hV_ux)~I|K{v?!nz5xVyW1Wv&Z3?t_Y^3NabL-=2C6lBn1|HGL-M0|-l2*}%^{+ZgJll)Q0dNE95 z$Fyh({|mx;F|n)v1E0Sr6No|6_b2B#qr*!6FOH)!i)GCXX>H>>gmXmy&4nK|dVjFz zz2zds*lwL00}D7s%pABS-)I;{bgkR7N7sWQKv=dlzQ?=d8L2p}vPpcuMHq!XJ_{j% zv?a9+CGk9e9=L<{`?4P?vogl7dtvtvcH;`A`0{vt3SKNz5>6@KWY5o2W)2{)eqdm6 zFy@%|mqrX_I&Ll%4;3Se<7>q1`6Jq@v!z%b0$=)zOhPN z%HnTzc6{b<^SqZUG1ZTAf1pI2c>h_aJmYAptmD#617$QDKrAN1m!?mBAiQtkO1LrY z*VT^*^@i?4cgZ|Lm=J$kM3uiUja8OsC?X!FL9+Wt-^-17O$yanXi`a3p_eDtsPIHw z^D)N1%_k$PqxO*PsO|dc9+qIe(_kq|lE24(jKWWbz$$C%>IcNwuJbDVa101)e-B7B z{-GV$30|32c&&Tddk{PehjVm4<(xOxM!;$^GF`0)jk%(F-gtcz5`iL!#v*?el0nQA zJ@eGIMg6)`OUR@mi6ZIR;9th($4#{sLQo)azb4O1!aJSgIsbL=l4HA!Y)bq@<0~u< zcV=qQ8P6NFV-Ut~(nsm8;Q#@I_GuhvNQwWll^djwr%&Auv0iD(u)lRWFG4;i}-)sAUzobt!|KB0XzC~n*=G0ehqaVweW9uWQ|1U+(Ki#M}83K+KhZF~LB zAhQen=KAp&X^b`LE9T|zSU7Zl86LonT_-{8M_IXD$c@BZd1d!IW#7m!Qt9opf4Dza zOO;nH6Z<8aH$Z&F*U>AU(>-Ph1(P%%qA3?-AVj<#w_?GS3-XMlKY9)Utgg1C;8T1M%Nl)E@I8S z>EW-aHZRm6!PWOOmdPV7Ht)B0{HI_Ca14Hh7{%V2ZQ;Kzlf{37Ug11iS4aIg7eSf} zpd7;k_Uqx?9@C%yqUpCprg!{gV5M&Dpy%~R?wSC(bBGJbh?nG&%sw_)JU4iUvL2IUo*+qp7E0t?PL+CFh!Cy}rOIg|#0oSGY-_ zDwO76B@Kv$hMQs7he#t)VG6jR5kB_m2?+)fE|mqoRJyn

qH| z^Et-+Q6HAxageN=z-azcbZPI`yrIflM&Apay~hPPM;p_W!ht&AT&dI06Q1Ysxgq<9 zI1A1DIK76Lq7OS@+M;dZy-fwLUKI)uznm#%1l+T!AnFHqy(JX_Ep%qBdUqGu)sJ2bj95ViR3mha?L z#s-ubi4|GL;v~LLbeb=n=q@w7O%J9UCCC#Z*uNHOm6M-+Gx`TbFp z=x`Tm_*bdVY-1e>UiqXS`Oj>a-er{}YSqDFLvE60Rwm(np9VUIMC&L&4Bz9qwOzOX z{g~>F$$Run^u(G^ZBV3O_JGmqglf*Ci+CAjCXvDV<=i7@`!UAZ=&wxS07g<#2*D;T zX?5s1<#c?`Tb@3a2$$*$PgcO!<;HW5V}YnxD~+1^;AxXMTxy712VJew_ru_hxda*` z<|3b_`WX1|81jRr{Vj$=S1RHp){Tl&C>$AiG+K_iI=rjz@(gMCEq|M<$aIav06bK7W-)b=NR z@q|ZsWtQe3-sj3-V!whwm(VlHeX8*24*d^CEZadAy#9ii9HH#fK=s5#)By^RG%S_*=2>Rsti+bgWJ z19;{u5T1JYaDSN(*j#r*a3w$Fu4rn&m8#E#i66NyQVamF90wXuQ z3MklmR`gIc&2}&G*|n(_-_v|=x;9R=`k2f>T?p7!IFo-*+-17(Ff5m4qz+P{9-jz_ z-36XVqE>K~7e2nOKM%Ttd)s1qq-$Qqn@&CX68?Jgr>xGFCOp|Gw;$lYX$S- zMtEX5%}o)-&8w|=VykMfVdkccpA2M)+3BIOB_1m=HR^99XeE!#z^s=8LQ;(;zDJ{f zQn8U(2d=)ZZ(02`cHA|Z^&AofnP&d*&7s&lh&4mp>YkMj`b_PE$Kt{HkF9#)DDGLT z_R$@06wrabpEB3PNEjIKx2l{(>*!r}Y;G%Zu8Fmd!_0}nwO3&c@tZavv|yzwQ6n-L zpz=J|K4KQ_>rzpjX5QfiqrsV!{C<|yF^QwnJ1#x5G{v`T3VKzkG;zZZ?Axj&A%hQGG3^S(+L`ZG`N{1I9lQa1x>l_ zKI$U#YyG);-qVayp?}CIh4qYu1*Z`N`*mcwD``0gx=BXMH{IiNh2bYzM~v2milYm% zyV}#w=a;vH8&|x;c$46`qBere$nP#~Fybn-94Q2EgntMwu~-R=jJRQhZ)WTBtJB?0 zt6~fI%4SBLL0!ro#3xtSz0L8ge$mOE-2BwXSn?UnCiW|V z`zl!p$XTz4Hvn8vQ|*P}Jwt%7mw;);Ds~AznD22p;m(%q!>jHaed?_eh%SWsvQo!} z_~FrdVE1|Lv5+r8>Ri>`FKQJDwp)~lWO_XH%F*;4ku^zDE`G#{Q2s_R#hRJLeJa{t zsC?@aFlGwt^;wOAw&t!0ro1&zCR+)_SQhk|=DUO-Mrn_2YcP<4JK{6J!OO*tftNe| zK_$538APGrx}LlHA$qexuq$gm;7&5>q|IAb1$e zMBX_=&~)UM9qhr_SI*S*%{?ye^X3DAuQFjFWBjFS> zN8QJOi+Dr_sHP@Zud*~zD<`3@`P zI@3?iXf8ls=hYd5-W^y4ytH#qzl&k2yUYH0xFC^Jb-rZvoR>yTCnctigh1z#r<;|&XJdjz07t^@0R=m)q!eO7oqMxq5jjg?QW8 zhP*uCc2%|NO7Qwe+z0HLh-0q4sQb(`6!Dq?3J3W_k>?V8qW$*RAH_zDr3RYM-K#`! z+idx`RfKA6<0U1S8C5X zeTe9#Dr9CsvFp0oSn+&2={$aTjUHhYiiCZwdW{Ze70`BhT>vL}-M9Pkafj)7#kKZ{ z?w|mdz9u3<9FESsxv;$^)-a5IOIdeTdZt&R@>}v{ZIc#{&4=UQ8mru`n~Ylf)PdD* zTHc@IWfQ`8FBqeh@rAz#gQS?H2Y)U1Q|4y}W!~4Lo zzmFM9!qa?nkaZ*kmXp3vUxq0Z?oHc4X!zlKTJ7)XpP;j7e#!QHHlqZ9@tkz z^~L`iw>2tsC}4kVB`ZRBF;9dlzx|$!v7dKi?ij=sGmT9!0%0w>QL{u)>q?)YY1wr3 zZPI{0d8(3>JMPHw%yI%LsS&8}wHe}cC}>@`ufF8-Ia#qv6DF*-x~kqHs^|JECXq}K zp$+v(!*yc%fbQ@1IzAPBAH3kGOVtx$Kwvf7FuO$gV*l_mHcO;-Xf1C$#4)pI5G z(xyux^l&@ct>EIEQxcC4JV>#?{xipsCLQYh7uNgdX(tBn8$0D=#j;qk)`1O+FryFC zc5GK@6ODY)qCgESLqduIXh zy9!#kFV$LhG#`y+MTWu@rDsEh9VbK3aVP4;2l3J*1Z$VK_Vu~@RD_&lfdujoQw+^^ ztWs|H!*2X5I}MF__WcY?mnK)LnR|rAsKx|z8MDX|lE}j9=re+XZekMZbT(6F;z~(t zEl$XQ^0d}*njtQq@;9af=>sst#yW%ucJkNtOVd-a#8zytg%8pAeZPhSjJqh_zMaG4 z;aj=pJLB8p;CZ8=AI(l|EexK_!Nn}k2xmO5B`mL`{ri0jagVi7OOnac)sm2|*fN9z zOwv2QY!~ACcCPVb_jkV0lKfMD8}EahE!@@#+b5RPIqCgf=&abpbEFStXO{BVKP@Q| z*4c3MPHtJbxi$>Sjgoltaj7EgKAR+}>@m15TZ5|J`zG`JgvPusb!=vX+jz z#hfK^*>R*)5wZ?;QV&JG`lZcLq}Y^?p4!7djd&t5Qn@o`>Z za&QjdU9`5naQQo1UoZp6PtqUA^(-E+Z!C8qqiu}!ItYMh$i69Bt)+;^OwG3va=#16 zbOF;>LXiy^Jqjf>fm~ynvjWnZ_-;I?J4`uM&&ZmD{O-<78cuBq<^>YHQ@b)kv_&5k zxj&HCLng>;yW#0rU1dk)SMLJCPs@vUj-@+u-xK+EndRo7jE)TbM?z-B?Bp(1z-mJBZm3=nzhT0Y@(PC za*YWk=V|FxJbH!CdT{o=WEeJvVImRwO723G)Ct%j3<*;u>6LjLpYG-1*sM<8S9pG* zXuScnK{7DS4|`7T;Any^g>LD*Kl_ZCcSOmXvMPjfg7(_$$bBwXs59023D56k>D%+5 z`O~JX?ao+LEP?|)XnfpCjoS`52!c#+L>C1UivC$=_xzT7cBjms^udX>UU$Z5zYQx| zM7&S2d$X-JUZFrXMA-Br39=UVT8ewJna%+RDW}GLYiU~PH$yEO6C;aRZyO<1G~!vD z9_%j#cHEZuti#D+=R8E&i_HjL+sU(O6#RZTG3JJSX2-ZIuOtR%vFtt&?V5Q#d^rCVt&9WMV#Yf_kMCY<{ zynFrFs%JvWuq*#}KTB`b#C~BzeHPYg>&L{w_D|$w-@846;bUFI+FncMB_2|@z`11>))Ix4-`f&=6;YK8M8Ly3Nn{c;UgFG3F{%G7ab(DSn zIflAVPGOY6n@=uE2ay(x=qu~i(b^;DN(86twHqBXrT>%u_Vpc*swcI}MLrv*4?8|0 zv|zvhu2Fum5tYwW#9hX(-egq)zYKTg+>QUMYHvn@sPgWv`G?&Lw^gZ*BCBGC=ST2? z<1cXizAYD^e&Wy@RC>KBz77)w6&!Tjk6k?pVLj#BNbs>sdQ5oTuQVW`BO}{7t-@XTwBd=`FkPiFt7_#=;Yrk&ny@Moyp(}uq_1ntyeCB= zLTc#3Sc_}ywJ%HI#<{Em*Pkgsq35E+KfIQeFuoxBWXGjsd-%EMi_t{?BDz&d3iXyI zjG-_9a95kpAE;SSXLIYSdw(eMDMrxTYqZW6orG=iP}f^wQ$(_TVE$|}Di8PI4GRPWG|8%0o3Oc0{PMRzI`4C}1F; z{fQ@H5wyX>DL{5Aj%|T#_s3hjEko}Y-_4IP67MtO;DyYPgrm|P+b<#Oq9nwr#7qXvCyxp$Bey@a#zGIT`kG48EDt=#6Z$7X0UnT z&AO3uwP=t^jDuhOyB&TJ<9j~+L}IRmwp>sqeATdiS0RLw2Q;eVRpIH0&t42V>x>zR zrv}sxtRF(FiETrN2Z@h)QZQ|L_t^L8sk_s3hpw2jb2mKm%vlIG3mY<1H-Dom;rc8- z5g$T)cG6ZpKWOhpM63j>4$fQKkHv)1p6ywmI{6a@ExOUrx9hXyBu1qst)L=od3Rse z_9IBdSC+l=D$cEdfluK!+7tJ+QFruEdyAt>(IVtE8BLJwP2Ld`mx=mc;mDO{q2u4d zMx()xJe{$`>Xh`BcSo%E+Rxy^zv7p#cfF4A&p9yx+1+HCRWPeeDcGfJ-me>!dnNJO z(SOQV@MB?_%AYnOdaY@+L-^I#Hste5bK@FH?7`}sj3@@c5THJ=cL!xWu%BL zsP5*sp4ZJ$44=$_RWEaHY+BoszwinPQkw8nXJphtXzo0Ph@QfChV&Rj`pH;av$d}- zd5m?(#Rw!BRb}#}?)K@VnYqC3nxd^$&f+NFaL!^$U^H1{O8Hw!cuVbHBTHE5=rnpP=>55_) zn+F5kl6;?K4LbOWT z&#`%U(UZ-cg6yn>tiYU1A2d=jKV7oP65p-TA6?@I&Nl~d%!P02aembZtC>IZ*XaA1 z1&vWffVE6MEWC=9@D7-zHLobQereKOW0#B5r*vD7^KE<+h1%f!97J3#c2x?dR3?WN z2!r-Ea*X4f&q^Bt%zc7(9VD%if}umC$2-N{W}_l?ldl$}_YDg&qHF8$6$}$Y?a8}) zL1cRMJroU7DiO_jEVUPp+z}0s?5I&Ijd<4gsjLdUl61~lhEF(9#EkFBAir9bwwLZ( zmBLMN2@_Bg4IbI4u=W~Qu|6Ni!AI97Kie<357#8D98`hvo7|J<#;?Xe)8ovRmZYhJ zmB|9b(BIsosX?#)byXNxny|6)RQgFU9vW2i`QATWYBL_HT5DLj@Rc z<*M|}PSsRpoa`^0StEr4y%zE}i=UO{U(YHzRTt_w1(|5&r=&hjNKlS|vm1#>UdA$k z+cH2^Kd}w?SFJ67D>+Y&r&KUJL^Q`u*O2bU+N7_ag(=Cek0Wc{PMDqIT%EYLpn;tF zmBf7oe0LG@RX_aR1-PWXBU3Z)LY?j$n5?=Ai`QwUOuwGFtem|O3Oizyw@z0ivk8-w ze-~-hs&v>dR{KJU#={xeVdl?3`2%{THqEcN04c)!?(RBj09Z!7bM|2|g;yl|j<6o; zOf41MV{-DGndudh$*p9>veb&lSVPjrNu85HqPkBi&z`f{j1dBNwPrkNxEe)~ zH9CW6y}FpWXsr~()2QoW{w*fjnCy%+j+Rks-oM6f9r_^k)~mf;!O=Jg?K~d#oFy^C zNgy2Z{QD!A0YZ>6pvoHA^07g-iG3utgAO3GC&(ioZIZbm`(fTj>sh`+VASb=`L8_` z8`Iy@a5;ihC^d7?!k%i!vErt*zu`A9%ufQj+>c00jSh1`EJ<;IxiT6Ec>3DPIQmI4 zP8NygbYS5B@66AQ-&bIiyCPOysLI!Ef_rCKui90hC_=VB;CAXYDGD;?Y+?{bu#|%+2fy|{GK=Z;gHAh^~EQF|DS38 ze>?N{h!6<;q6Wx6&CUI``r@C@{GNpLyMe&j@3eUJBL5QLe`oqP2XFk#!UFg&aN+v^ z@QJ^3>u);$E-b$^@(u!%(M6Nrlh}Wu^WQ%HKZgI7`~U3{jxiD#?GERv{IsFD$M+ro zAsQq6y^roFuSPa3{C0{5P-vl~lO1vI$K-anj>zeuyX3zY2L6+|_1pVVL)(+#r3b#0 zOZ6@><&8I}D>Bo%0Xv9Y3E8|7oB4;S%K)uS;09#2M4aUnBe`-J0sp9{6ON${mqB@v zN{-3=CnNrs$NEttQS6I0mjj?SgTz*mGYQ@%q!KnK=G=N-n^j|Y=)HrAgSLEBr+0hZ`b+avy2iPPHaxE$8Yk? zs~BF3q$g*Hy^RIPBj+S*_;Pu?Qr#$yK0#oBpodSag6xc&^M*bSIMk!U>^>cpa!Y9G zKKeea3vGbfVviS1f4SkKM^aME7;FI$T~leW9m%6JoT$6{)YS zNKHuLH)*Qw?qoruf~RE$l{ZR6wtT1#t9zmHn($rADfzMSD8w!X6W`>z#;Zcb=<9X) z;51SEgh@7jKGlz(Z$_d8rI$wPv{G%}T>u5}F`^PPY{{00U|$`4QKDY@c@P}swX?S7 z1;plTAeA}Cz&1TTq)0h*F>tpPj?3jw}f~HM=BAix&*NT+W)aIw|Be{V6^I;#` z)ge2Zy!gt|%VBL!4HYZ6!KbaapTVKRbi(?He6hpG^09&3U3R5(3#HbJn)4<#aP#ZP z^Cgr{4H6R{PGq?cmv41wAm*CXin8ZlyD$GC{>DgxTiv6&PxIHsu1#RaQ;H zRy%bjPWaqg2ed0=CMMW)&l?k09yeQ4z-MhPu#I~JF*GY;Gq~8eMX2-Ox90lq=b(+( zJ_A|Yw1jdx!I>4cFn}_74PmRU{n>-~XYttA`)>NDf&2al>1Z?s%C~C}3tEY$C7s09 zVgc!^1GUWv?`H+S`GFf3(gLc)2IrFc z>3Y&?qIizFrFtI`&ZW_xh3iAk>)8TD6$6LzdN(Y4jXMi3j~kvm`6)p*MU3h9Fv2gI zZgC6_?^4lrbT%f(ZtItv%b53nMKF3OEWLmN8;aI^UQ0c%TB3QUz_0d?X2P zHkm*|n8eDPOYfhCKS9bs$F;c;zYEB)DXJL|wfztI65vM!i7@QE{pziRp5fNQdLJ=F zXNx1hOMCCt7SNzwNAVNDbTub5GkRK>uexr=R3a16$m4wAf&eyCDAWoZ)|f)<0jo9~LCahs6#KqM^m7hBQuD}?dXrC+?Ckc_2p93 zQR}78LbtFv!j-~L&Ao_S|OB=yGhFH1wGB zp4t^q-7zO(90kI1B#WLwV|6ko|iGqv-9@DSZg z76`<9EDIY{(a^8_o9L-OL@*a>*)`ztLsgpShrJ$YS{iE^J)22SgRq{T&y{0Q?s7dK znXM;Ka#$1n%QF#+fWA+7AVa9O``2c+2EH&^XUVX|u4K#v8|=hEu(MX;x3qF)ZT9(O z3D$o(W5E<*b^CD8Jh=C>8Cb3c-d+5Rp=TPX%>avF@Rf$yJNvz7;)=lgF;r-3@9&ov zwlz&HAkVFu*>>fPAr6wXCXp|&^t+{l?5sZ2yxQ)VI?sz_yNXrtyy;W;p_0$z3(fCa zbTvaHrGs*OP$XOBV^z1g{wF92n9+**c|wOGUc0yAA>#4=xR+#;TU_qRzLtt;2JN@4 z%ywWfH^$I-KGnP`%2;vWh!k;;3u);7K_NeVLqxVBBfS0 zh#k9BD1I;~%Y5Ty;LQ6KhWCC3zio6NQ2rPOJM%udCE)azLI}#C0z`zf?E@z%lq!HO zwucIy#Fw|VGU9hHTQ)}A6#zRDvTyS?64#Ouk5$OoBmiLHcSicFTx>ofOz{7WV8nh^ zA&d4;OdK;bn7Z-nM%!Mk>q*t@Ge53)(fZYV6{~7BeH9spq&O5H*@1;QS>Y z>&|GsKs&J!vxHNl$CpSt3a15vcK)mw{xe|r1{oA5Bg9`uaKiU zxBRah#1l>KZa)iG3+Juu$^I9~y$DcI%o~oqr`5&A^_U(d%hPB0W3d0oLW~#qg~{r- zO2dDS^Z!C*5(ZFQ%mz68%UA#O5wP+CC@xr6IHXA71iz=lP2beyLZ)^WTd`+M(uOVCfE?7f42 zsT%2jpimL)E99T%-l{{H6CNJUGdTFy78^k{l(2}%_Lr2Zl>Z>!7$o3ez>;l*opG*~ zR`73I{0~pd@>K^8hTs^n{=)Qo(f8j=yZ<6aLqULWrPl0}{}avM)y*L|4%XI|ZLNB{ zP~)%qxlzP-H)g4dT>a11_4IVf0IQ&FbD#I z{SFW?+L!+$qmD8V`^u*uf#Fc_Tz)9zKkP16ZI_yG{l9-75?`cLs~}jSQWYHdDw|`S zzVKbKfYp4iEcB}^U%CNZ3Au8V&D%{36@goIq7T`uH-1*i9nCi*uCEu^ojiead*0DY zhr*)MMjV_d%eQ-Lw~W_(u}`B_sWDA)lr``5heSm3rUD5@!0q*G7qY!sa$9P!o3gY^ zlZfM=F;^b%ulBo8tu}TtENDuiVKz}9NQGW%c0mjcMXXXU{2Ct1=i|+Nt;Db`8oAZ@ z21U8efH`zmTRl`A7{X8~KNE>Krc5#YS}up+xX1k$1^3r%I$n!r(qc2*Zn9UQQV@Eh-0^+-T|Y$#|%Ggl7wtT8=apa z+MY-8eU6s4W1gL_&6&x(8F1TQ>fYyw!ikk?u&`S;3FRhJ{%aIHqKg4+0WkuWn15pw zza?q{9`m~A7swTirzjziw0!3a&sy==_8-%9?E+F#CHq8e1;2cp3FKl)+HGZLT%Q=% zJ7NX70=Mg#w<8qgHHA`q$5@;P0iPp`Ex6^d0;s?Y+6Y6JVX?xF$uJJ&zrIZbSew_A z9X)D~RulZgM2r>K){oPoOrOrzk!N|#6S`s;GW1D0oroW~V||@Hd7dg(35&npPRRk= zB8#H|UZg)RPEN^GO`eB&xn1RGVY7!L^EofP@Er2IXXNuN1!K=6f4wR<&VP*99Zpzv z^uiS37o`Y^Y76T0hqMI)R>b-1PJTFa1UYD)4BH<@u3f$Ob?;gq6aKcVHF2m4^4(au zUDiLLk{>`@l3xXsqBN0R)&@I-_2ukVj0?n%xXrT+*45K(>-#6*5hi~fS) z0lpjc92~BC+F94BkGJ+xs2-gO_=%&5WKEYHvP*$i&(1JD~%3=p7ohr|v_-K<~S=Yu_V&#fdcYET}v#nXDr8~oPq zVls}0Q~*n-7}Z@hhhwd#C(qwKwp@rArSyB%#`+js#vP?m^i<9oBz{w|PZkDIO-HeE53Oaztpbzo0X z_~^7fK~8+?(tUw|%if@eus`EFpDYPb33^swAeOS!F9^ zTjSl#yGv)gX$P0U#V#&(rvti@P%GcIk&!3UCVRL;f7)!{Vr+Bev1pGuz*wFIL%OL2 zDjFFmZu^VtmKG-73@qWfvC`zlfh-^B9CBp?hVHvjqfCMQ4Rg%DUsEDFd+B#M?}^)o z3CiOy0An{9ec&5De@!q2h#mnwhEU%H;sqL0a6Dl@4{hbnb@-7&v-hF_qbCe4FxO(X z1iH@Z5wzNPthTUVBr08CZ!#}O8hyg55OnI7c27W5%S8=l#@c^Am26GsN$U5ff=)Cl zLZZ@WkVvzndbImy+q6Z6qtofvy>fp%mC_``NiI%JYWPIsu1(ed&GwhaDowa*W@O6s}R1Eet<$hfi zsmT|u7Dv*ZmkPPdoh{MG$vg=&nX!Q1-nWGS99tGCTO`Qo%3K~^bYHG__)x0W^df7y ziXSypFP+in#)KnQelVWfiq3sF%U>Flab|T4vmD3-)tcC}6m3U#gp5oz>u+J3oZH{TG9MB8&V9jN$@BKIO z=6Y`t@}hx19BoD7OyP49@~{+7G6ehba&ex{@YtIUP#U~9$q=5r`tucB4t^q_kVjNw ztuc>O0J6JlqokPB%ZB2|Q`yp3xDnTl?skn>CR{+4_0u9H5b)J*z9o863Xr}oQk?^Z z^-c;@b-zo2w=GH@kgF~$d(U8WVd8qaTu;bDW|a)${~~N@nU=4d>++JZ_M9?V6iTIB z6oR=bCDH|PT>`;Ab9F%ltljPsLFZm$t+<684rFhyqX8UHjzIG*sF3?2mznNN;rV;GW=pe>ul2fF!ry_WB8Yr& z4c)a_cSgd+ONZ|pFz9U$hXy*?ys4dTQ?|dgGQ2s$ZHy6QpiY={+=*OzJ}; za?5nnx22E^jdmT^&1-KBRr$%lbf{o3sv4Mi9dFDsKY6?3gZMiO4RZk8KI(l;#`48Skj8s~!|DF&wu=(y(*5M9zv}_NC1SnB z(xj*|moFxAm1R%Bw?emiBbBxRyr&Ui(1<`hw$}@#sH7AxB`6YGk_@o?+$W?Up)S^h z3L9AmO8wC9oj6G-hG4S;tmc-dwf^>TQDBzw`>0h&ak7JVwMU)F!avwh`_DlNWYX)* zFuHYknvGo9`Jf%^%>}gw11T!zk_}f;I-S2gtmkiL?CtM?S8~; z*Bfzo4=yK5${EDe6!u3nI!^#-KcmR6aZk`^;`UO-`JPe%OeAb?I(mNR`rP2W!M`s$ zR_t*olaDV9oi6I>eoE`zDC_pDLd>+&5Y6?Zf{RD~0A*C+>sY8?&Wq3D)SQmnz{m%e z(-p~cACBg^RmaSMSJ}o;&B3(Tg0u$w8h5^Xg5A>BirX_>B})}_YcjvSZ|^e%LJd@H z=@2L=5szEG3#GGWP-I$OOeEX)=juo;+c3r1d};Dsf#?ASxfRH`IJR|Jdo zRv|~f+h(uyQX6j9`oOThJstqNSb(1_x0l0ZnoELv+@APh%`m-C_?cuniL$MZCcRus zjif%aJ)t6_pvVKVUHD=5a$^pMEmiVIx>089MCr2N(LcTqqcr z@sx)eo}~rY0;G;nbhjI%Q&?4^h8P1HTS4F5ER9_( z^V%_Lak!i=x^!%OgtWK5xG)c^v(nhO*I;4PD!AMwuC#i@H@o}MC0meeV%7V_CrW?i za}Qdqk}YL4!ttW!|9y2k2>zgJs2KVUd!2c!UV45lpA_Zs=7#gZWe@Oq;RsShGMU7glN#FHP|z{U zWVN1t7s-v?f%KXvU2k&Ix};~nZO;7pv-5|sY(%c}@_9x{b7M9g8C=m`k1xI1FIhT=b% z)Onjf9Nj!@Y3_`nf?8*GukgWU3#V#O(6oDPb+#>g(<`r4`MSD5Fqps@b_pKyGSQ zt*xOL@oen6@P2w`zT|joW%662H8}1w3R>+wtK~FtaXOi%?yvAW9dJi0jKy`2Xx6iw z4@NScpF^wor`6jm_l~4eidj`9G-`R4tJH?olB6UI>;X$-d3@ThQjT#5P1pzEJG;jl zt2i1>QAzu^Xl9ApPua?z=d%6)-)?pSO^bf22+6VCQ17}gL5kmq**$r6wk|}fMPAlc}@3K2_)y1k$;~Y83rU-MQF~@DzFa zyt{do{5ot!*29gtqy6HoQHxgg{=?dFJw�F*{;F=&})fAI{<>d$es@xRQTK%8&Nm2^^dCB?umy4KR%9VD>t= z&0pOwK0m?UK)f1FeUw86OW@;p>5q%Q zPJGSOCzttjg2-pyG@vm^`O3CkF7Vuh!SboW9wn@Xaz>mQ08yY8y;loIs~)J>!rHGC z9Gby7=ycmYJ01Ge-Zv+?^C=ZS;5=M=ftPC3$%&#?XoOl;oDD#7$RmvC7WsKJcUA5u zZuxupeHwKwbmE~%9Dr%ax|h7I@N$7lc!|RYzu@W3dE!*Eis9@qdq=a7#jwza-(BWg z`cs#H?`)4Dj8_rU3QN)#SuSCf$2Yx7tIhx6i9&quVr6 zhT#YEfov<@O=`s zhsRlXv_uob&f_EuX>{tDmOPiBtDTxY5|>iRHG#v5_Sa_@gfHlH4E<(^o;w15N+9<7 z?B(3ym))U040ace{R}+`;vg9oKJy{19=Ds9(65TLRjE2!s+V73Zzq`?caAtzJcNq& z7274ox0}@+;_##m`dXrQGaMw-Nv1MSSEKvJis#n*M23cMlB%3QkqOd|`DCF#Umq^Q zdOcoEqe9g=an*6dlc zWiJrPyGt(n^K<*7ea?X8E54<7TdRgx;c2Q(Yw%0?b!SW`D2}&KNRzf?xdQ$@twfgg z==f&G_DNg*3lnfM?nZPE61B zMVJ|?&3i;UQmh*;cvWL@UNhl37hq7adO$y?lB{`Kg2a%ufBOEj<-Lv%$q;^)uc93) zE3QJLFH_2$vuG@dGdc6=JmyF&Z=&RVqZ+*9zACX93J%?|v?f%}pz% z?-nUlE@+A=l1crwXr%(4YqB+A&{vwzpiRL;*V>w5yqE!0&wK-;d`OZ5@zdg~iGxa+ zlDtEVA}!WHbrCk}caw4=dVCnU4vM#gYwR413n*s|`n;?iZ0M$r2de}4ur4X{rJr#k z6?rn%+*@e0A5hR})W7V*F54r$=2T{W+6b^a`>s7y1BK~L*G~6xzsug1bP;bq^)ZO4 zs^Z&Kn0A#TDWG@`jON7&1*B7VqFp{rTIV0#g)#bcOkB9!j$o&eSO#;?G4qT@GY>b; zI5(q@Nq6_`+Yo-k(*o9mF(!~>X)J7tuZgAc0&t45MWaoCYQ zN$pVWC5v(U29b?cAD{D109JYR=zVs4U{J5`x&4!M{jxB{V>9(b=5Q?I;Q7vMspj39 z7vINb#^QqEmFcfKZrl0jm?C<&CweV>2ins`g$VvBD=F&D+#X;YGo0v@QONsX0kGWL z0m$YLS30nJa#xsBdZtD1Cp9yuIDWMeeqkzr3lad27RJJlEsYGi^SR%B1QdN6&x*41 z1!B=Vk&JJRXg_j_cj)NBucH}rTAw+c%s&XNnCTFPqwLhI+?l*^L1K=kk8KZc(7~`J z7K4-MRhUhorP8vqU6ho=aiquU}H&eamGNwx+;dz=VBk-nFFENY4ys&mvJx{ zjx-}a))U=Fs|M$TN}2P=toa&RWQ-e+Qz6f*b*LJfIWkR8MCl%J3&Ge&rsvo!JaT_u z?n4S*-V7W-FA^7gs}~+qNBK~xLQmk%`M4y4{hL!ddHTs{dUFz&4Izn|QMveqMvG(M z#gV~)!>cZ2C7>;MGssJcKOYsReGoG-@Xl8|wA^Ia+0|E(Cg-Z^s|n5vy$uoxM$G@m z*IS0g)h+9yKp>=Xcelpf-QC?GNN^ACPH?xN!QCN1@Zj$5?(TLwS!fs^acbqx8L z{LOpUjhatt_c;zdVMUkaGU8CPV{=~i6j~yY&GUBWt0;UL@LwGFPq`3`Mvm=kp~HmQ z!FDQ;Ng86hH5U3qOik1`R+_Kb^+ql(+}5@zc7+#{$|gZle+93nT*zz!&)%q9flP{W zNSn=iB^$_-NGRbsl)GlooVZzJDwG-N=x`nP8UNgPyEv`s9W^JAc;||?={O%bI6ABZMqjNAE0KmQ?@*dL{*Hn?#8}{DErp9Y z-c!eRF0VhW-$|Nez0z3)DZ}4=s?5IX?9HKird;h#6gWwI4?RoD$^q%LZF-*e>B*Cf zUr!b6tJG(|Hj1nb`^4_QN+V8{XXR&2;TlAjU@sy@Q!{`%cBPXa|4QBe(iawJ?VoOZ zIWJtp_HIj69YiL97bmczP$qwseHVOPy@0-h|KeCQ^f`DC9+q`O@MBB@>*6}=1`L7Tp{hurjd>Ipzs#RX4~iv zmV}iV9gmKP>d9=yJ|8vV*BC1hTtgoK5iI^T&%I*(jQg{-9*{u7WdaS2F|0li&wjr2*O@~B%w|Np;{;BkVACoS| z*G|(LW``V{OI|-JdQNw@DBDH&h#)kDUaxOt(TRCBPm;cN@WS^Gg88?f#Pafs#l5nY z*WhulVmbYY95dFo|96gc+En_Kjtm;ILtmj8n6&;CZ=MXT z(iOLFH7hz>s)nbGCUI`oFfm`b-q~owv!Q>=_1%NG^w{iP13R9BhQea_WThE)e7-by z&|!S-HI_ZBB0=RF%Eg@z_*JW#Eq?+P(UeR^u)tb(>GKub{{73^T>ZL9X2&~%lI_f} z;--zR#dejBwQf)2j-$%f)vnexucj4w!n*({^M~jp4Y^n(=qx8Eo5DF-DjDJY!=wp? z8NmMrV%PN+Zbi~b)LW1HR^0WvBY#Gv3A&)fuED1;7|iPCn@J~&#*v66-Z*Bg;{GC3 zY0t>L8JfxXmJ~GA>NK@em8hS49^-|HqT1k0eLKQJsnQs^N3=hfu*vDTV;&MB%S!kC zMm(MX@aK3S5J=QE$$UjSw$+>M;TYVwoxI!a%Vj*V{V%(s(fBN+oUBth_Xq6N{%~ke zkSKX^?4(~_x$BL2@g7mpO;&uC9kx3{31p!D;bFud>aJyGwp%Ff&R?J5`u6lpluV}+ zJP?s$eHFhk5N}Gu^yW*LD~X&bcf3Se1ClH#waY2#^&*FEV$+~SqBr(NbtrWjBNuN`pTeE>kttfqy7ZO{S}e*$~x9`-Pl4zI>!1@ zz+`yls$lQJbD!>Ki@NCB%i~lzHTZL{j5;L;_p+m|^!c-03$ev{g?=4<4~O=EkM*6f zF{`;E;<%cFh(E-m!<$$Bl&AiifEF%PZ#~|f8-p`41AuXfTkQ`wx;ga!B8QtNn>How zr)is&s3hld@~Qi%;n?QQ+x|wAa;{=IC|5*(9?!n9VMTkIWuQbY{O})!GadzzNajE+ zu<_-m`(!Kj&@$&pZVz>5Sus=EZ@+MfvOM7?Hj#jbq)$E&c#xhy#rOsRYEw z<{Hk`$5M4~dNF$;h+yXW3f}S2IilPd@~s=}l@3BXcJqXm%J(-*AabBUQqFunnvUG?NRXD8x#<~UY`cQ z(9=`h1@fw#pMMBtwCh4Ca4omsYxtGo^yQ&s8Y3{nF+nAvFUz8~#Zm0p9I3YUWsW&T zAw3eGQ^fY;!M!EJ*OQ5lrbCHRn^>5x(8RKp3L>S(FU$i?RgX>|Uk#9le z_xf%A7sH^b9;YRZb&I!-jJ5mquRI`zy`?xHP*}&>mcsq@d``?g*{(!+JYQ4dO#w7l z=R31?b)@Ch_7BrE{x3xfe!+++=1mQ!)VEk~ci-J^XR|EC_2RzsQLEc`<#6bW#GEnE zw4KdYyw7&ejgBW1x9Bu_DIJzr@r%uk?6Ppx^`+_jqe-xuh-kbo_3qY{eKn3!;HS4Y zkH96*M>^GSb$^0~Q&cbuifTM)h8vwyQLyG_$Exwf=+tS1zE**1h@0G%op7AhaJ2oAl(nHdtA zhZK0fmDt%Iq#)3jiYSpQ9DGFuk+DV8mB9gx*vVla7m`0ZKqgPRj#~(+xw2YT2w;@V zQ49bD=-8lQ%)@X>m7wiUDZ6<6jPE|HM$^WWWaGqk2*088*5pt(WZU>M{%NyU>5{QwrHh0UM4Nb7IVSFT>uN*rIG(rPrT&lf6l%`<|!&%AG#E zy`@Y*DgihD@~-cpI+JDdA$0Imdka>So&xEy++Y=q`JF?>%)(=~ zc72DFY+R&qSKM;(C!Q}*{(+DmhYzCULq=h6!u2F>)qPLXx~x+4dg1WNt3F7Xb&9h| z+gaeWJ%PrW=uk)pGduD!VNFI{yYKlP_%UDK~XZ^1AlUeJ=O7Ie@_~4g0r(k>gw5Z``Kulr)@3U%@NjICn3w@Rju29(=wuXhh~a z*R@T%+e(g*-fnY7Np0PelE*nM2vzJrB-5$<@n7xAYsh^ILA_E_m;(`QoV!NX#c@58 zx!&Jd{c%)kydJMMgA1b)>l-1@XL!k~Ct6)&zS==1!Y+ZzkHqyvo#orq^3B}oO?EDA z57*iHds9n#p~j*2llJ=BVY1$+Yyj!jVvUH7b8_MQ2j9?*o5Oe3f>B8l_b-Q_-V7R% zuZ2zRD+i<^d@dl%MSqHQc--LU#>DrODQm_Ev#`PZZ`*89OGH9;?&1%)RUKcPs2Vue zTFrD6SK72^zXnQ|z*3KYv{`R=K3cTkA9fH5A!zfMZPahJV6Oe#7YrL$tX39MNK_8_ z;Q7^)Yg7(zjvXlUzPHv0#kH%MsBd^WRX~Zy>$b2|I7*KTa+K<=mZeqjcT!jDrAWP) z&qz&nQf(T+zI>66QFW)UrAvT&Je@9SEA)_T4~9io9wV$pv`M>zJa2NRG}gJAk5_-L zpx1UZ{%5&|F-MC9+yBi_C`2E=%sdzzNY9VY$}wj%_}$`ff;aPDW@2L3n~CR{H$CXN zP(jvGr^9Y(6nga-!hdnxlo(cRRwie)*s{2;4go>_{`WdpiVLNg{rC6kMe8$@IzV$3 zd61y69~e0DC77rvl<4ogh0>d}jBH+kf`3`Lf5ee$AKgIOdgoe$D#`6|8yRx}!h36VLc{ zJgchaa{T*8(G8k{^^6ceq&h^NQba;MkfHU)Nb0=m=H%DTR>Z|)R#mJcr`nZ`a3P_F zev@vkeeg@IUXxMDiK_z@{L^M=V67~2YilcPx|<`L^WX}J#bex{a>*OSV8_-QAp*%~ z$Bg`A;(`t%oR*LGRjm>i?!dm=Mso0RyZM)oX+`pZv@4SECc;TCAA2rO!AD`Ndm?_EGmTseH5;RxkT0Dgwf$6gO%T5>)+tBQiBHxKzz9y!37HCpY6xKi zc|dw_8)Y|iM+^0H^fmJ zOG?KRkh(Zd`JTc6)QPc>3X{~9aP01eN-^B}4REZjFNpet*z+<>ACkzVF!FWhfN7$e z_)70^p!(qIF$`Nk-X$)VxGO;YsIbE(IU^-Vw#}keirzYmob282x2P>qLgV$m0j-ro z3R?6IwU|87Y1h?NT^oJpkuF7B!lYd>G_z-g`tzqzvfKqlxES@-k&JCYiTfIG^U@pON?`_mL%v!PAW0Kiv| zBErZ{;jylqF=x;(|Mw=y8ls_2WS4bEFuWqKd;1DvKs_B0u^6zJrYpp$0f1j1K${T> z0g->}unkXBZS<%d6a?w4Rbk7VDN!RI>f6x)&m*u(XSK_@nTNj0<8spNeZRK24dZDw zv(svMi4J>l3Cz}#kXZs6L{)ZN?mA5CG$&@nY2f_u;RED#ykiy9 z<4hvz);5LE8Dw2bO3KFZM4Yhvlo5~jQ)EWrb~jfYxmAt}eQFRaXxRc3T%_;8wRKf# zKjq@l?PPE{wd^>Iw-Dy%rXUfT;j>xZOPRCVSPG}OqEZPyMdZ~DX)%gX&o+@-#K-sk zSQmKmBdhCGeqx`R9=JVR!$q8;r=z7kqSFe!{x*#wIIiR=Vq(I%H zp{YtMGyEOnc~m<6&l0owu@+;}|5Qzmy-r#2!h-v_Xsp+u-doKoAFr&}tUn5WzT z0Q6)X2>OkP`_^u=XhpybjL-mhL!5|E3vr^VPUwHO%5cm|1xIL~I8r;hxP(+yX_3mv zw`WaZV5ST(BbP*l|0d&U;Oun?3Jrz90Q}xwYpg$D1_GO!OlrqMgG2o4rBC7Cj9-Z~ zj3?GwLLA#KE*K%9(?;u;rpMkkuo&kI8k1Sm(%UaJtS(+6sMp0cOm@I|g#+SQu}f)V2RFbgHN%)R*7$ZJJkCP;9( z#z~psb<1fERWiK?d5O|9xHBsmY<7PAk3>T1=O?cbP?Y74Y|*bUa5kzYgR%Mce2!h8 zlROb!-4jNHgir`Atypr~ zjfUT+{YlcGh5kykk&i{13g+NMihE|vow5A^6tW>4{wph9ym!9i1I%?Kcc~P)=WWjj zUDn}P{W|~3EwK_rF2ZnGZZDq)A>@yz`lBLhWgb#pc=0t18Z_r1(3z#=3kMCn9@(_Y zK_M?yeuJcTr#F0lgTm5tG>RiTN0XrMSw{Jn zxSXUNM{j_Ml;7E?hyY=-Ze$*2v}7fgU;P0ri2$(TxV0~k{A-69<4k7e^5^^RW z68poZ>5LTduZdd+-ZNcpLKbie#xO{E6O*k&P^YHM2T5ys0B5%Mo69E2$*#5)P- z#;j5dMk7|1J|VjfN|yK=?;Jx-yN<*so&Dol>`_bgcKH1m}Kyh|I8z1&mZN$3(U^`7=1B$ zd~_6EU5zw>7e)$kNk>JMq=q)TJ}(&HVnhODW#fQ7pY=ws9x73hU9J+AFAbt70fYMh z!cErj6DpBGEdQE*ZE!~PM92@<`e0c4Ub9yIlwalr)x}u5W;7-ME`R`CDh2#R^@Jkt zeYb}qS2T8Vug2nd?x2-Cwrbr?cRRK679kg)vnJ!pAPvwZ2GZH*-dk$S z`(utE`o$(tluP+1sG4X+Oe1q(rF8ubm1f8hgNKKN@h8@A;;3x*WbYUnx;029F7j|DrPcZQvb-nGGG#9oN&J68Js;JO zPX4ew#8bL?T=mFKQE|imoW0365s3&E$>iz%&`dwk6lPYRm+WHY>P+3*+ZXo_K6JR2 zqhVS|&-8fZ+H5;Xz;AsrX_?ojcuk6_C&a(>ktnS5{^gA~HgVb!y4K@(CNH-SeVcL40GH4=fWo2~_wzJzd zKVlLZz`?>|B)WB}40_^GgjgGMMoigG#vm=V%7-QQJk}^HNy;v16FRcX&OkZZC;OjO zGYm}5asu)uTi>^*GAZ*1;#k*{J+4qnKx;Q-YUd|1!Loa)0gC={1w%!mzG(boMjS`) zA~jW2?tI&$`?mWP|DD#kPwDxgG5I9B7fOjK*F zkWf&7Jv$q=fRV!?rchiIJV=x~N6_;oh~p2!@5bYpo(1HE-=qsrP9jv8D~VHLb(7r( zSPxe%O>z%nTVq#p2mrC-`v&Zl{qHWm-wvgVD%Y>uTDv4vwPznqF2|}NuKWBcY4~}?9;Gu@ORt2OfGjZ@dFb zUtiztBDWv^%g5A_@#vt9voi!lMAtz*DjFIIwT5k0DRK?o0f5#3*8rwpnc1H@|1Zee zDM=)lpsCaND|Gbymzjnuh8{m*3~#-Q>QhWLES8xOC{e1S5P`2hTrMds-oG7uH8w_N zmj5D6&rQn;iM;tae%eWxf^i8jK@tG^uYuSftQ@4p*-TKW(Tq)=qbsYbTqS)aQDx-q z6A}5joE?|qBsxb&(dTu&$t&9}nW(96IelIr@7^y+m17D-if9f~5PUCpIf#6ZVKH@= z7RDZJ(Gwa>F#h;VNLF~FS7lC)qNBDn78Vktd3rVNPNH)OC)2+m&%c&J z&|5ksZyO1OT8r{6t%Ur z@x+BIwYvP-iztfnObYJ?;*8_#K^3mpCut-EG*uXbs~yn-mfj| z0wTYp_%(H$wl};n?g6zAvqIxD8ykZ8_yV8HhUhQF#Cr9%cEn=|7s938>46`wGqZy; z9IF_M{t+NxsOF@K8X7Sg`m289_g=FYK(qZ)@`#T!Gtn814%&YgMUe~%2L_s3=PfaOlY6dL; zn2Zv8n)X}^Kx$1iG&I!Kq{LZ&2JDyH1Ju>cs8dxUJ_XRBNpe^&DxSw*z+7ts2#b7a z^m6Hv&@jVK2x*WBR%=PJ z3i01+vjPUc5)hs*1mp9#-X@m!Gy~tyk!jodc(oQbgCYY#>cPX__jB@nqRlS`z;-f? zK0sP0BT#TW{FKm##LCEPGe9Pm)8>froQos-lc;FWU@d2CruWB|c$D8Biwxx@Gskhx z+&XhmhJ?el_6|nS$kiBL^adVDIk)#?tvZ*3(R#H(nKwQu2?@us_dGg!R_5k{wzgRn z(|TJ{3AekL*+RN2zv=fsatFL<#&@b6{SdS?0BH|DZF`k(8U@GI4F&?bVxSQhxouo| z0fW0i328-&YHG7ZP|^AD>Ddgcx)psIQC&BIrLiBvrvFEYW&|e@EJO8ue_(Ne<+Rgn z2!P7)qWR06Pl$3HUHVS6SWI_c_Lk2TRg7bkidui?+mQDEvU1a;gz%Uoa&}QC(caq` zMTABOkS$oomGr!+)AKZu3mea36Pfs3-6TH-O3bMKH#cxvd+-*>T~lQ#aOn(HlV5E< z{;2xV3tr+JSH0I66Dp`}d>4`cR2aO%mh6t1n8?E1Tv)~c{qYVGQP+kD;tN6ypJPWg zr=a{=ZEc-n{II-?`uBmzvYEe%P*j6m4MduRjiqJ0wp!KU%E}57{d5fXqf*j#S(_87 zB&FNM#&~AlvzP1{iewliTdX0+?SezeU~7J!+2tl_Ni7C-@Dz`4=K{ScyecFt7j!u5 ze9ynMw7(z)S=dj1jqvq#nlnB9i$;uOXIjRK&fG?Q1i_!Q?FSIlBvwdgRu&oBRP}1L z^UbD+wQzm{^6)3@no&|yLs$Y5m{BPrQ`l;n-a`X9J!aaO!cvvi5Z|tIRlS5;KxlZ^ zK?Z|Ko>vN1>;*XFi{2O_I6>L#R>>y`~T4hcIJj;GIO(5k9Or$#~%Zv4x) z&E>yX&ma-Df_|0vIc^cl`9TVQ6rlqFv|z$CKoTxmI8&c)Q5MuU$(hV5cYJ z#A0IFE&!d0^lo#_UWJ8-a3+7)8g8pSiujHNYgd(}r#e8b_{9jraR{<+@IT}hl<67M z0VdgxP%$rWR3IW^iW#D#z8>az-W&)FKmF04_E$dm0+H{}YynNCRd$W+syrV%KI^`INccn>$X1vL#{Q%6_Vy0U{e=4)x~0!Iuegh$UTX z_a-H~o*o{CPhZ{7bMNRs<+sQBsgCimHy5SyxHhgr*p}dVNcRhmWgT2_{R2HS`m;lr zTA9{UU}9n(o3H)5a->0KWMnYadp-EZviq2%O3tU3yXLC|nKqPzl#urX_ zTM;IkPQ@OzS`LytJX`!Obq5h((0TasUW*SSl#zwO#Px!r@(=eNO@nV^Io}@SeAj8M zyhw8Up_tkBc5aL*i`1wyP1qQCc%T~^Ud!kx%Y*`BQ$e%*nx17o$1%{|6d0HyYWF|; zK1|YoQB`PwtB?{##^Q9_6KZWm+drB4Ez6S}?fvX?P&vTg8}~S4fwC@ELE~|seZIYZ zZU+r8@Ps9UBlj(3s9GmF=98@Q@OC1}V8k~Vbl?e9(38ICOq0BIw`>Rg z82_g<{?Tc?fs77YkhJYa{^bGYM$tiDJI|3pK5fAvA>!6P`+R>vF)Lxo3KWRba@v^K zseRg)GM72rO>h1&c*=989r34}cmLS3eHKj!k%%Vf2}Bf#4kh%i?f*7-hVwm@6AE_U z04CjV>rW{j|5J+1`11~F>EN1g;v-C))4bmK-gfGUqCBZ`%gc4$-ll(Ga{1E|$BG3_ zVg;DoeeWChUcVh(d9~k{ZP(ddVW`isJmA@lkOGReP9!oxRE~N2 zj*rjx@03~bVko*PVEi9~5gKpPp?CYNiYn-yS(Ike9U;QeVHI^aUl_THl4QB9^Y z*0eEPHk?k^jf($mhed04QZ$jXuUM7ZJdcFfvUFy4mXx7GP~Cm*n}xFV?2y%Fzjnr) zrdu}Ps|*M>$AF(%9meXkF|f+>JveOF?v1+0SCZDcuNeJ*Y_2< z!xGz`-s(*m#>p0+5>ur_3+N2(lc(~ZYJ0e{;!O9@{h7tuhociUFiZpX7)ZAHF%3vC zNX*CxR$m>tmYpAxGT%Y}sV$kVReFlVpyk}aXO~Uu+-Y)BI~J@_Ah1fC?$-yY)8`Ze zpTLOy(O!_UDhNYTo1b9 z$2fPU4gPG=Yp(|FZ!u=??7I@-u@T4+CjS{@iwBQ$*LY7sZAp;x1fikfVoZd+#3+M> zgA)0NvI)E$GSq6z7Yb&3e&%C;b4M*4PYt=8TxxtFCoc#X|CKco+(>@*#jLkM2ARc2 zm%~h4LbX%VHz+h11_Gyquh2C>?|qr{rTjXUYb!q=n<(L$lxsqmaq8oX%ev3tD%qFg z_n*kE0`DkgzRrOg3QDKj(?S;#OaApp#|ik^pFy?R6n2C@-4ncc%ScO_qwR;%{Y`{TI;ANjFkbb02=`^GtxKN}z?FfedwDr0c4capUK#7HCp+^)re z+?=@65E{b~;SPP{>7SK02vDD{ZTdX}yL)xB@L$#k8u(PAR<#WEGrT{y~8zW2$fq!mJT=|yq0iYF-rfCa|5($1=YJ5qgChXfCRh0KYTj*CEg~w4Mc}dF z>Z0H_WrF{>M}`_4h&{kdC#M{zC4vCD_(q9XH+Ekpx`ESkpBqJa0xQXDA7|o$ zF*Ubpd)lyZHO@IfeG3F^5U7-WD`CXMxI+`!W?+eZ13UD+6Rg)aGoQuMzk@J~H;R4y z9Uh=XQpJO)I}-bwOB-TbbwW_L&f02t6UV#EgEvSi<1uAM>B;jknrWOW1bv@!FZOg*>Z=l#9<+Se6sC!TlPT-W{M$7jkQ^?4tkC^1cER=+_h2w0h}=f z1$iwkAy65stLS-*(U7ZO1tz?O?xFvWpYVqn{9Eiizy(kL<$XGfiA=~*V+XYu_nm@A z-)qx?O#Zu(#95^li0fVsh*$+nHB_2CGlZ~m8u(mdW7yvj8qvE$qEt&nTt6kv*HRrI zyD@;?+oa8TH3h2>i18cFgs7`WMS&j%1;(Bcl}L_}c~uI>-y0q(Sj^nq{KSf>heUwt zG}b;2L{ZUgbsHd>%G(_T<>(VI$W|F@P>r4{mh-_Mk9BMV>OPzeX5mN)H>c=(eN55i zZ7MRU9iMdCo0OP?UvTR4V$hE+%J%x&$;N${`HrX{z`uhLb<-M~z{;uRsdD$;S3Dqi z54B2&_ZJcUit zZ8oGpTQechy*&>1-3AB-20`F00scTSksxPKb4hVUg$;vS(0N?vc~jFnPKWOecx=az zKMYxH`*{|R!@9StKPw6}cdX${7xdX_iWp3Q`UdI!vMI_u0RoOeLp7t_>3KZ9BfN$G zN(2LM@Gz!6yWvv9jGafJQf5`9Z>2${jH~rv)ujP@x$6UuudDN5)UhiuFs*pE6Ve)a z8>AxJz)KiaRa_8Y)K@|M?r9avW63iO@v{IXA7gXd`9Z?sCT}jMZM% ziBx#LE)f{Ho?ew*#&p==A^E@Ne?z^PTW8-&p5=f$s!PD2ifw?ENcS$R9S{>7d2o33 z80E&4H%5A7d%fs*N6SLLgDGcd+adYmMvP>!ISE2#82L(0NVPL@bi8WN>e`oJonBNt zRK7fA>kAKnJq9E#e``N3xK|{#II6)gL-cz{wD+Ch>!vAv`0_7__n$5SXNaFLlQ`oo z_xTT4kQ6e0@#f1fs-@K|0s~CYQ? zC-%;jT8-G(3tM0H#1s|@^t6P?HU@8nmoTX+E1O#VphO2y|P*?q#~`WU{rfLDao~)AAd;* zq|^_bhl{~h-yG3E`JXGsT14L7_kg7M;G}uFo;|vEVUWxaYWTx-7lfbC>Qh3WS{*^o zC%$k3?C1Zg&HuKT|7Iu?RC_0<-cb&{7+m!V!KF*oh1(8>i&a;FoIaxQEtHClEGHq9 zWQJB8lhSZjT4-*?Opt0^uz?uybhU0n2#aIl2wWJT#gQvdFrZ5>{zFv!yg@`|n%_2K zSk@2n0|>nevB(zD^n#q<-&qVD;zB}k)}lAGMVJ0rr^LiUv@3~1ifD7Mr=#$aJXz5S z0?Sbh9Z!uC#4(_^-DG=iT7#M*zA5F|%Ha5eENmMMf6rwKuHl{h>w>o2{M%5RnL$@W^{hKlM8BGW*Nx!q+gIo^( zI6)#(ozMYA0Zy9CpcoE^*;I4BT!FspxX!5OzkniEx^vDc`Rck(9n_e_kqDS@^-xno z2kD(XhbJrndtHMGMcn3-Ajm{SON+MMZ^6V*f#VMjZtp_iVU@3=qobs(9m2B6#d$45 z4{C>qOVOAJ$)=c=Joc+69)LDfHG%x~i+6eK8UYnc9@08WftMY=sBFOI^c&dfu-fb_ zr}q<_eAbAtkC0HPSxagPD6xlq`rX@0^2LjF#*%HECfpvcx}c_^v=nE@uCA~}9Ls>p zHiI38Y~$+wT0~K?GZy`h6HF*OJmSsJ1rP)yJc8>UDu@;uZjlh(5wF{m#`! z6X6t zRu+ZkL)uo=Q{g*zPtt6TH7LXs&(rS>NbeU|Md&uK7lhg>8KbZjhM{O&fYi6J7&ga8&EdmUG*H5 zn;4hH`!7lkK-&0in*T%l_+P%;e^biu#bj=7?nh4br`}#}p-*WJS7?scS4vtXcE>X! zh-;y0G*u1DgyaC(j;AM`nRyw^Jj{_SDxC@Uw-@)93`ew9S6`|UdL|{1Cmw5{g5XWs zxo7#@7vuDoji&n5fU~L17F#ef!~X9-u`>td;_6D&YlUpkrkDxq;&;M0sORj?ub#Oe zWG@-RtI;YZHf1OlhlHdX2^W`?jjQO`zq5K`N7ZT@>9kDLX3@a}{eI#*fA*EcNFw9U zc}(I{S+Q)HI=xQ8S>skHuReDFy}HK%`btqb5m;IKfU*>ZfF4rhEta5nJ?Yvw?T?W1 z5kg_7mA77f$fh^CAF`9AJ2m0;Y?-9TuqPH^C^J?!P6-22DSeBVhKj{)#rco;NRSEH z+z?8SBNT}F&hgU6KiGrLn5IqI+gXvG|KDr*U(WLPlaI+@7Lxjom%3he9enX}1M#s} zi~IB2*L((>jqBy&!os||dU`E3Zr&mvl$E2mR(;=eY8#84g;E%P!hx{;oYF5lpg%Ef z1G48%prHWa&sK;^pWFfJGX<(5n94I-dx3R&aU`A1g;T-V?FIFim#Ij~QSRuBIypuv zy^XWIk5ICVbIGK@HVD&P2gw-^csaNz_~Htv8E=bB(xC&H*Nl1DPDQ`^NTV4n@TBk1 zD~ApK(jvy%*%{oM50Kc@X~ZFAlT+ z>vIul2| zBr>?7%DQ2IqPnfB7urFtimSL$#aQ2L`|9u^-%KkiqN7& z?9$UphF>O#S#+Si6AXdqS;l!t0%P2AutQF@N}3kz1=64w&;}E;YqJ(;`_%`M3)sEMS~UF*U?c;uik(+ zY9G~PD>@7805D<3xnb_F~aVipt=@2@uljn&wFqs%l4{^QAlq zeMJ?VLr6}^!X*Pra=uENQ-}*&l!}X)(j=boD?*#c9e~`_ma$SK{C`Y>d7GljjuA|llQ3Ge&@e~uk{$hIz%PJP!-lP>OF1B|J=w5`~jN6|y zFBTSyK;>m?{{(ugJ5Dr-OffB30?LogD&`;U;gGs8KRuv{`=%j-RbVAmsUYW($Yi5} zmP(||Rr0S;z$!N@xvak`Yztd+f1JK9ba0VC0IPKB(Rl7JN>~XT zBSz17N_lH>D6V$rSt3bzR`tW&c~eq7Ca7;pwqTKzd}$%p-ZZLfIFRn3AvA;HOYWFt zQNWU8_f%~;bJ}s?wkgy%e}1r8wYZo_RG5)8Jd;98TH&Qh;hD}B1FivlP?+R$a3&(Alz}v|suyHt=^osH*ii>mt4A zMHUb7tYv)!56eb}hhKVqgo=XoUn&7F_#v2Z^fjt;=C>kbP%w#(0o;Rom)@k`R1YxL z#v(x*H)7&?G&%2cONos?vb3A$-3x=z(GFVrCWM0Ar+{q|V(qFZ)y&S^Zp*~k4{JZt z&gQN!@KVf?8Nsp21f{jPZdyKy#<&L7FcP+KL$NZcTl87PI`6QSjve{=Assk{=Wuus zjcDg!Z~EW#JW`G_1goRr+y$*^2Cc+%Q+nmap(z9i!Dv5Z@`sF+!k~2#eiqiHK}+Wx z!2(KuWE+s>3Jx!I1iSH_fcWVljEWQHR#8>ZXU|!LFZ5ZB>u3|I=9r>@5T($HPI%k? zX91y5rBDnBB*6J_Jn_fgFI-`iLSpT5`X8Sx1TcRr4l36dtV%~wPUO4ML5$;xX_p{8 z-hzj@R0$X4LP@V$HDk=>^OGlvF ziNo$H1pBo3()C`E_{K)oQhkMg7R_oanOoXQj7=s?pzjD0VlCeZ7~^aQr(&bh@r#!% zz~ovJ`xK^*!S;zPPBd8}3GnsBb9@T#=~uKwIv=)O>Q|CA?aa@0lU4D`KbGd65w0J2Toga=_D8G#d!_hC@YVLHg^~`eG7U1}3~5|! zzHR-#pPT?E3V)mVBEP1vNNM32D z`-mk94ir0vFXn)d{{IMj%dj|?q+u8h79?o!5Q0N+_XKx$3GVI?9FpMfgS)#7F2UVh z5}d(paK1@S&h9?@y}SG8zDD})@~ZCYu5L4@oKK|aS&M!wAU0}ohlm7j?VHZ|^g7ck z(+Jt>n?4wo`Lrzis{p3PCBp!u_Y?2TUu_xTlBsT+l95+>#dR1mliPquibOxB`PIVL zL#9yXZ-wpXQW*+@f(3XzI>jflYB5gF{aaW+Syy1am6CKCSB+2rv7L$@hA$=)%ew*z z6)emHx`#V*`wCd#+DVXK6QXhi9i@Lun$4Qqf{`tv-eAj|mr4Ettfka~17PpIJb43} zf2ZFRD{|SYkwF;HCu@yo&oP@_A{9j$o6y+M*$kpRc|!-ex1gJE)lV%~v`mlT!H$OS z0m3SkV3wCYdTLP=)vJoc%SXf?QiElSaByF8ecTsWO5@pzpX;Kx1%KsGqgw`4E)4%@ zVqceTpKxtTYQ-pVg-$(yY-nP)3JZggGYW)O#c_GFSTeZKzTtm&Qi9gl>@yV-KNrnW zf(Nr4R1`mtGHJx0WzLc{VtFpRUtEo8-!Px;47R}vf_ds@#gS4k<>LI2+PI!{ttQiuqe}^Dv9}s$sRSceQug^LA>e(n;3aomn&1t+qQxG7P!Uf34ztf%o=%;Q)+VihV}245FV@JmP-bwt^xg~U(jbdQOv=@F_ee5jE}A>Nt>h0J zH0JPLBAK=rXGg5Y>dA6&`!e+w%pAj(Ga6k;@#qn!$+bk&;!eF~W3%5GHl|u1`a*br z;Nt|Ea?=;XHPLLtx$AO8XdL2g6S8%Fl9+bkZ<2@~!Uw|y)4@mqX2Op)Ri`va3b+4WPS~p6G$<*wj4v4Y+!(j!ZH{7jK7XgYRN_QGeQ_g zwTsrSngt`rs917V(2%QWqEdoFXi4(imBtYvol}gkfLK~MQ_QJTc=u;t*MsJ%Vk*`g z2Bz3yc`%wDNwAiRoEkjRk?n{5$v~T>5j9zVr5n6+VQXt@0@ko>UMHevR=*G1FJ!;X z4UOlyRFJjGqY#CU25dCXOV1V)cDK!FM3M_?2;%pO7|+ZTS%%g`mzRFv=l08I5~I0+ z;~=ejRt>MVbH}JxY@r4Ksk7fG_svD6Gpo%vw^{zks1exmrev~2R5|K(aGPrF;N`v~g`SXd~7eQ#Rbg1vczIFG^T9tkaD1o&ZT;}jbNMJpeU3O6*o1XAUR>nlhI#em{W zz+`IB=%vlhNdcp=Kye}trb@VUR<;Q_RF+_~M-af>1a+#G2NcpNXalU4!FgF{1%5f> z#=02%l3`GdxHIv1SvS`3v?XbN6I>&cTBQ!5s7D6UHcHg+!l~vz5|vtzVO}Wy{DfI| z6+U~*mAt0;$y(PHD^!j|G-gA5lGMlF=alNX&_Ryr@pFl`aJ2Y{)#>eB34>QfdWMoT(9{7tBv)mtvF(U?qP+M2yg>Gqx_!yk(tKQ78q)9{cQOb!9#hpFEN3}(QV$6li}Ey$%^}iycD~hmNZD@D|vL2;=Fvp8)>!q z(MOhgS6$RMh;qFI!LBW2TLBi|j`w|s=wOu1L=g$XaB#M%=}Lt}*J#)>GyRKy@S9-M z5fCg3$>U)s%w^Y*D7cYZbKshhKb9dqVHv$z(-e>?TM1+`Yo0TVY)TW@uZ>PA{5r@A zwd5d-cnZeAW!x$t!G3^pi~HykU+&c`OQ_)!0|-P4$A!`4<@_XnNnj0nv%v-y*czfb zmAG@!0FSRWJq1&o!jzY_;USo|`BUL)Afd@y_Z$W5Kjjl!} z^+u#LfvhKZvi$<%cZ{LTjAJ!U`}(L7oxzC~#mSt%bl%^eOaTa{DSNzy;cG;`xg^z&QQ{!6((}Moo@$Be z2p15fRj$4W1Xn#u&}`uN1Jx_L4&a%OP#nH9Z$-t$T)*J|=--Rp?mrtBOi@G3Gq=gr zxcBOvuN!g3a#H9r)wh5ptv#O`Mh=_hFdbM777L_`4j1-V9$#Ed{*G5%=vJh9YuS2d zS-ZQ9+^XB-Y1Ia$K!FR5suz;0GFabC&J+KvB6ljhd$WDtzmu#EBpes4!x7wq{sKU# zz9T1CUhh8`Z17yNXw9fbZd|D&LbBN`yji_|VHj23&+CQa2aj&lV~Nv%wCx=AEJEsfdIE+8B706|VCy$XDbA+7-wxE1s+lzKBSfJm?vjvt~qcB;=yCmN290V&U z601q&zOjM`m( zOv~&^KTJ%426*z&nn?01HV?zu&S_C-qemdebA=(x;}h$22~v)B_SUWw>EFuwchF0LM?Hi%7H3843BZ7 zvzEND`-7h~3F)k~tzr@^O!!*s;dn{gklbuo-&l-lmC5R%9gTyk59cBz@V*9(c?4Ou zB(4J*UX`j>^hf;|uIBJyh&98ndTdXtvQ@X+fmi+3W{UHk_l)G)SPL8i&^hTJ1E)GX z<_x#Aito9uhUItM!{NlKYadwkjfva!-US*yrz)ms2K1Z=1goMwc(fAxg&e2pu_-LaT`Z1`go(-{n870EA)=j{Zp2U(KE!(-+wwzt=I6D zn_xSKPqHn3td9}vpB68^ zX0@gERkBN1u12_Uu7st}^`O;H9^9sXRxCe#cxsq76FM2U6MD^u2BK@W ze8I7kQzC$9kU;>svO26qPWT2Ji`2gi0K?WCBt(b>1-Tiih`IrHJvmEBoLqo~koz{m z9yRQPOfh{>e-kaFN^iP(+ z)Kkf=3B0jHKv^OeWgTnI`A_MMiD+9dV1+>yet0#uMOu%JUnFM||##PH&qsT*W z0;Wq{IQt{-Drl<((aOG_F&DD1#dV%>*_E^K;(i(OQb@BI%|kpg*QYG$(++UQ8YdMe z)Ri>Lk|Ch=a)3@C@?|h^HS~+)mg!DT9ppsfT1s*vvzU8nX3JHAtkCHXn^Q2}2Jn_z zPzhl&<-2-ID<_2s1`{tpF?wYm?|$$E1qFA{C&2CDP}9?j+k~;QF)u};@X$vni6eBj z)L``X%XLXMCG{nr3PEQGF0iP0iAqjXp>-xVX#Jzta+q8)Wv~IT6H0cC zZ`Sm4lABCoNgV8R|7^sV*Y9`*ay{ukki1wT;r`;C`KiT|yJ76~dj{Gp2W%J0*}ytu zUrjNt?4)Mx4}BL@wG;W?X6_@CtuO0-M^Zt&D4aNtdHAqN8{|w^bv&Uc02#0PA#p_tNxo3>Ij-{@ z<%dzGLTKc7i`fq`$!zsEQR|7=Km$s*l6b8xe2b^c>}`ztHomebA$8i*Y?awP2cP-l zTGDWuj``{uy~_2AiAmY(RRcN$Kf$lw#2C37LUftajptJl4RUdzm{)Zf3g+cbon;z;=c9x*mN#@ zMhsIVqhWN_Hmj$WbTcB0xduIQd)rc)PJY4+sfH8E5HaMbuY}_>S(M+c|bw- zdmfXoIo89n0CGh9b)F`VcB(R5W|KW!P$O$lHT1T}VjH3_F9vZc!Vr{S3WT$H`#ZFKR*b00{jSbsDg5?jhWA#@c(utsh^}iFVTDslVm(d8;L#A!hJI zLsUcEM6JU<(I>jZlwegn;JGOm(8ptpjq~=AYFIEc>;+jn!$e3Z``o_Q5;#=EFo2b% z)}@F#_kI}Z*njey^@y-5p;-0mBJmPxJ|RpFRkw8r2h7qpPh*_Kx8%Wf`ZUxVQuFj$ zb-m^xBrgca^p5nR&bJ?NfHMjWXz^fr<{ip>=V>Q69ntWLCEd2f` zq5#+J78@A3Y}-PKk=D1bK~d@c2BOAzs6)2P>hYm==euN@fSdYvN~2A1!vu5W{OA$~ zlj=ptlG2Gi&kgdYqp2Pm^jsuk{TVjJ5=|xyhUu5-K>*sI5sgR_LnEy;1EzQ(cXs+> zI8>~ht6X6106@`eqHpvChgvruy(D#ibSSJBfAyh0u5hu&Ob|tr&lCp{MwAJYM6)vq z3YVyDs|h67Zy*xg!V$X6&3Qt}XhcNB1ukc#Bs(z2mcapRB0xmz0RK%dRgEj~^`In~ z%_%0mb{&%Zp?vRAoJjd_n8S~{3`o0riM2ugYSL!zQl^d`Eh71Mx>VTwmdM^x*=MaHr`&$`AfEEA2wGZ4p{>g*$Z6Id{h&N4NmO#` z-_giAVQkI{YxQ2_>t$vcyWld2&yEFpw7v)%UjL}Dd9n1PL7yUab1FzN8bd+8#MZD% zQT|Mls4g-4z$xY~Zfu20l2B%-alOI?e zOqAJwU8*I-5j}_I=KT)n%L{5*I$XxsTxuc4NScYri4gp0=7xPq?Ojxc$TqK*yH?~k zq|64ptd~g3h07YSk6RZb#tVP3lt|mS3#t<+?-o;u~(|m`?c)&zxATX_at4Eg1)|R`!e;#LAt)cDkp~dWN z=*X07iL%TlF~=)OgG4LSgN*ECS1xPSuF2$AL<~2t%PpB)yyT%cj`KBNF>$~oGh0RMWteAe{FY&#OqQ>EIX-xaX*#MNuAqh19MPw@1YRx;N~y#{X_Bso<_WsQxkqNNu6*JweT(8% zef+bHIHxyoR!Qb|GVfwbyZR{YGd(5h)X3_B=i66aP=K zyx-YhVJ&!8QoGkFCQ1dPRem+B89P%=m>_$RY!ee(Nrb74|o;6G+Rvj6SS>>#{2HP8+%xa?fjE_K_QGP;E)KPPa zl{RnBN&EO%G0zi~49MAeip|3`6tZr&Jl}!tLaRq3VqaDGNvT&iWWn;JAB-e%r%(v8 zNCfejb6j(>p(xnJs8?26QjL%5<@)ua1e`}5G>=-KdfYc>|AF<&0-NkvNFlUrS8JhY)VjyoPZn;*Mc>pCI6E*NVtFJ z?04es(*Wk)kHrNE7_mhoVa`pR!m-`s)o=Xe(p9F4FSC@ORqMOA%)jQ-myaG{74X+p z^Tz#^CoYYZ8E-|u(i$|8I$_fHU-kTNvR*@b@AbbI`E&qZ%j^~_s1q?uO-35u z!wi_sEwOkhv23#z4EbZsdL%tNxDN>LsawI zHKg^g^M;z?_7=H{;WA09Nz~0h4+z}}d^*c><$W{7Gdap-mR@a)z#-5<$U`M)@Wafy zn{VUdBzn%`8*|=sQ2d6w3^v=n5fepI8i!i`PrsF2&Ju z+5KnJbFg_XxgME+=bkXgf90P1jr3HU-&UPa*L=5=Mv2@R!W_7fIfPQ2;uZQz^ck|Z ztkax|2_^`TKfs?Jv9i|AD|HSjYbR}^0NH*9 zS@z6Am|#3~J*PZDy~CwGf}_3p1m~ zOb+t4BHS-ID%Rcy@P~D_W%Dp)a%u+Ctnvnhd#9~HIE1J3=c>cwQC$Jc@>UdboevW+xhqtmo?z%a(^F-1-4p7KrhWi_Pil zbtbY6y9#LA#Ad87F8HjMYk(naX(A6#YB@W4 zh4TUCU7A9)XfoDc+bN;2s=|bv7-+2{z_IPVdEp*}YV1-^!!(5b;AJZ{GyBz4vjp*1})p*teZO8Ria1{pKuhIS${sYCWZ0qZ-Y z3FpU2E=nM?V*DW+Y_5kKt6}75hCv9kL4=L&O_&PZ{7f&8p7_362{x_%_AKHUry||N zCq`Z?r5YVi%=FrJDYGsYL7C0CSi7TQ-x558Dk165#~6gO@5*kUcvVid>t3WCYkyNk z*Q^(9gBov}54sxX3pUYS8cu83Vdn#O^2NL?bT9L9U`Jc;z-g>pK`tV%zT5xm;PnW5 zGgnfyF#G%+x3K^8banoRN0^0rdJ(Z)AF%4JXW>oJJiShOi1 zD$&fTZm|03_NjeCKK?E#e0MJ4=driizUOj+M&tqH#8uJ_Rh8T4enBLE42ch{*)O1J zq%fit-YGT{VB{55(VGN!d<#}p*8znJDq_3Ms^W?E;`FNGp@hE8qNc{gCMyy$rU{^& z!qoa8E%E7TJjH8whZ4AtB)P#q?gUgG18`rYk~xik-UaMCe|@@8BOJ}RAmumHd%1q< zxO%n~xb(O{I^3I8WmroD4TnJ;)9Dpeyzb>OPjr8dygEs9^3c5#beUNUmXn?4chf6f z99w@pCcpX_*0}eR$a?@cF|L;H8Kg7PlyY|?&p*=%%uorN`L3R+7=dsyJ)rk&Z-OzS z@v(4h=&Vyd(4X}x6Dw*Tw=kS?bp3cDc@vCtaniV7a*cN6W1M>T*bmf8Z8hB=JEmCD zG%LIngMwfrlw}S7^SQjb`gttDEbr<1j2;!0@dN+R%rkP^4t(hegYR^w*KanUBnxDOMgHy5rIsDr$7)ogukAv8o@*$k_ANpK?QT1yl<0)+UG* zfm-7WCsd^d9kn%`vZ)U&d7aUR$NCp}f*w;>Bz1f!t)|Jx5s`p+m_Qt*=6O~xlhko@ zO`B4Y+r!E3jt51$yN+@*1TRh`$9j5xqZhXmOf3&^=l8r;4Fl^-=T20+QuGQr9oeD_ zq$eO9;lVIR$c-@7omPNFu~*mITQRvqT&e?CHCg91FZ~@c2Ttz3*B1ji2XXyN=oNxM z>5FY|buU7d#OqjjOUV0&Z|*eX*P&EzxfER?DiJH>)8P+D7!ODUj8&XQKzQ)R5Apzr z!U%VrU#@vSX|!FhYOM3Bmw$PDVp&IN+ev*uMvL#Sc+- z-YPCeB5n)+|MCAP*0dc$z!%)I&lo@XNBD1LC#YZ{9RUEo<3`ERdc6qUei z6Kt_jLr&_ooGz%hoGlTpsx8T&FwwEaT4CD_j>ebGd)W%0F3jbY4XNhdTVL zZ2r);F@hLx6+L|zkeS(Gse-P+?&~{S1q%@28Xw6nZ`H02Tz`5xhB5C zE@%d-&h3$1!v6&4AKa#ngz^r?6%VWXkFx&rhr$mSIBvQJ3iE4e3nqm@{vVQqg6VzrWV;k*}$uI)yLhX3PY{v)6KeKTxkBkSA;*YO>F#nZ1zr^SO$0sZ&c#C7k|F_76;E}MMN8g)k!s8^3{!#-~ zxvZ*={9uMkM_w8K-~1^F5)z)z3`kTBNzaY`n-4+)Fz}CKXK>sXnn{a)|M(vTB$ST{ zL9rMOA^5+#GKfm~cf+kfP)u2~gm_NpyE@ec9{NA-+aDQ&Y2Mta-1Um-q%_T=Vi(6= zW8vNJAQ=3d&dxi$zEryxT}$_i&;$(XhhOnkibw)Ec}roc?BQzv({ehH3ew4N8-dBxX=IQ^@$GdN^Okayg)vpJKI{2hB0 zJpH>X}1gX5U+3xX@zPmb!gX!SS_9xz2v`?7F!Tl+;2Xqc^gSZ@!^*gxy0c| zl%;o;tScsWw2n^D?0M$xdwzzendppM1BqMSoe5KPDpf z_Ag@Ks>%ZXpqikSMGYAc5TEjdu6;%!kK(KPX@Ld1R$4%UNTXj6%6Ip{q++S>o2l^oy+}+-mrgn4?FT8wNW}sgx>o@&qIHt3_<(YvJB>4-DkpEAJ02j|1 z8-!GFfBT|%t*o1QstVbBF)G-U!57N)mQN*W<*5&kj~Culg_>VMK%;(6h|r@u zge;!MQgv>%(>fTWe|t2k_X?>Xtoef2mRia`wyaVnWZ?tr5dbiS94q^FuqH6w^sp|) zb+l}O-x%~4oq$ppA0Oaamql|i!|OnhN0$KoFSB(-jNdpZ)6DFs=f+O?ZRgZh{+K$M zO&keV!fyosP{y?h)BAuLPd>1ZJ$I|PC3Erj_zs6b!QGzK4GEaBi)%mt(I0AwtQ%i5 zSzE|OVgvCezd`5YQ9oUUSSjz%4njj(`~pI&m1W-HzjCrQqN$;d67wN7WJ@QQ=5IC{ z!$4%d2%XJ^_{Lrh`Lyx6jIZnv8$zl=K7130>VA*-k3ViP>ov?%uY|PHpEv)LpMnUm z8~$^{R-Sekvf%rF^J_&gFruIj176}qcAi#Dk$;rvkIigoXPw@eM!qpS9x^?)SSK`i z|A*s$99bujVnc<40qiB2zW;#ZIM3)LzuQ6imz;i6`uj0P3|;7>>Fzy^wdG8kypNy4 zlk6$eFAs>{PW3o$sxJHk?C)SGig|i*pBeyGtM8+m3`RH9(K8gGrQfs}yEYizy&yuC4=F@&2&<4>lVBTrTgWsUPJ1^_ zqXe_Hu<1%`LWORAad$i1-a}Ov{|6bN7`RZab!P-_U0DHe9+8^4z3jc@%3GUYk^j>S z3TC&?Zy$;J$h?{0>uf@1rg28o70HNlJ>`U?_q2Af!~ew^;zE&2?e5IXJ}v6bq~Zcz z{#$2=*rJ^?WTPOtccp$?Gn^=$2Cx1v+x^h}yARTy#=JOXr{!7Y@ahGyQ-c3Za>|e{ zWOb)zXht_?nA`e`?e6l7{F z*E&+-0`5%Z&AI@?Q-=4nij0qLais*?Vf-+#3*p^ny1pTgRr@3Gk)q$Ot{ALla# z5X0bGSp3|}AnuQC`xk@DqD59%FAEiqU?KlokAL@;kB3MtiJP{AHg{=q%wCyX;g6t85K32W8{n$tRU;<70cspM`lu7u+A)<*1DVGP&$gUYQ zR3PX3u|GCla&Y)~Iv$v&lFIklhFd&+O+A3c#+>L8uf;(u_Pj&W8#V9>wqH-mtEY{=#-80)kYJY^XyD;#l@R(0yFn7P8sEZLf~+$qcxwyB2k<5 zSXaWJ)aX$4H>7`10}VGO1$~f~uu;_vy0OSF4kVIpIKhgijpDw5o=6B@!_g;X&tMeBJH^6#YP#x&RKkCl@_#P|4 z1%VpxA5swlBF7g|6qbs-YUbk6QZzMevyz(^9G?XkaFd3}XlK5gl~cA%J$aP4cL^5I ztVYjD}8DZLuIU#Bhikw@*|(E1@4QmcgBu}5CM99PiU=gn?zpLA$K zgQV5^xi}V0Dx1M*)>kO68+Hm?&^Kc))$s5^#>s4ca!=b32TNCc@ZxjQC@Z*`>gqTh zsBKGWaeL@iU+$xidI-qd9*&#cY1S}l&GcG(*Bg{i4wp?1P6&1W6MgtzIVd zzw4cmo-ANYq_#B+RjEyBMjP9eRL*=s6Pm^;pB5=vvd&O#Y2^BIKHt+rG604*VjgwU zKxxR+yU9E_cKRdEno;r>HwWU{x~q%Ju~h8(eNH`p!LjLrrH||$_EvZwmpt1p+Di#i znhX>5D!g+k8zq&rY$Op_^Kb_jNhXU!wd?fo8NOONTU+H>85L0C z!yv;v2TE^LlgMzC3{KxX4p`D3*4HkQ%`Irs#-=hKv^sv)SqqtJptHS2wy7C^%s7~5 zToTCSGXWaLzHJzvKTlT@=};t?8M_rsDEK}rUH4G9o}gHp!gEPn^m_MMd&!kSzeZsh z?MpGJ$UJ{c-#l|UQaoe~|AdA0Uxouh)o?|2YLFmKR9VJmqkW*;h&asP?T=2m4hT1#SO3!B*4VI8qg}%DLjA(%QI|UFSzi!x|CaA}%k5 z;sI3(`V}j->w+PB>RE?XMS^%kJ_rPMvmz718WZ0QE& zPMH1UkWV%St2c9$bnNW2kCKf^$M^ODZHGYj;TnK5DdqC859IqS&;kWCMW(JjkG^lt zZo$*(`F^b|$(kW~rQ4FlGr(o@3U*~!OGCD=-Qdx5j*q~OpEECbHqVI@bT_H4-NxHk z#k2mTKVP#-s@a&b??YZz>=se=-o`S~+xVz9ww&?V&X4~{>jcLtR~H%F&vN2pjV6OVG~&4KsJL}~KPX)$ zerU9%2d=-->7TY*zjvvPl8h@jDyxnY*GRes?Ks*kjiut7MOLC?xh*;!<}W|r4Pupn zzBV1DHdOVs*N@gHC263)e(q1yzD`MOU-A4dvwjtmaF9MIFTc3EkWksg3^3tcud3kO zf40a>t}x=h?U)k)pA+pipL?&pKdIG-Sck(?{p!earCfYQiM2dxkeMtx4Vh0LqJ>guy?no2x-rtRCz=t@Zh=P?y7Ar zsX`k?;K?b)v!3RHcrJ-MG{Lsqb7aJAz7p{0JipF&^%-*QKxz0GKZ@I9Bb>{?VK>ii zAC%PqM3`$kdcxDVbJ2sobziRAyWUhX8%2AVl_z&dpRqRL5nR>P2Vid)qmu z-RavWii&23cCZBfy~fg2-)pD!{4{psZ@{F9ZpT?Wl#)g-n`tM(cV6RCdUot!Rvj?; zp%?CBMZ=c`7gg|?Bgc=;ClUYM{Ch5aLD!(!Whc8X?sXY<-sk&wW0ZfEPkv4Pi@5wB z4$=zNifhW8Q%QRkN!2mf#4!e1U}8wjM%e_vJnx_>X%^2Fx}|g$AQ|%rUfVSY)YCES z&o%odlP({X?fTS|tv~U0TTWeCS{-w69u)X$szc01y=ls=U%T|@&+_%i=EQQ(ZdHGW z?YPFbKaq-XvA0I5^~cbC-1G_@w?g1|(sz+nfUr&l5)hs1OMSD6<)GHAjDMEU|LoOs zHwvd5MX3e)`LisdMHfe6m(3Bsi8jSFqgW$#C`1?95#h9gvrDM|e8^Xmuv`RmRNZ%j zV^zwV8^K7Rj+Hfv7OQ)UuFOFi2tH#CbCPKRuflmnJo-nK759xI@$`*X4Vwk{Mh?Ob zuWCCKx+Kh7wa7)^zQ@Yrz;&1#p_7fip|Q$Mu=Mumz;{DfUcD7O^@t>}u3)(vSgwfQ z;b&|O1i+`;agW)>wYf#tb~^FdY1%$8jk$cbW(7Zgt+vxBJw$+CNoa;$E>m@In45#G zxJtk1eCV(rGDPri8$(j}!n_2M9i&R4iWO7}iy?{KTS5qI$k9r|q4)$(FA z9cS)953O{GkY2^HvmSc3=n6UyGPIjw=?j(=~&>n63j@?pndeGv!%HLwU@5#iu zx&&4R)YA$~s;ZBN*P5nY^!a4*s_U*)JCnveoWxkyu94UrC#_g}Th244-@kvK763Xr zw%KV)ifJ=blLVEI^$bV)dk8J@L7l+mw{iRc%_6+OfmE*7tPg;%0Kh~hmN0DoX{n<;+2N74W(=|oG)6mpMIX<50N_4|dR4{nW>3_L|? zdD|V7G_$iQ){&P=d4|VfDmNovXKQ1&?c;z~|-o+UbUe5L&`)I;0*Qu*Z zhJo`W7;@NKlbpdr?iAnzT*g=)z7=)i_?&Gz8D>)TOw%Z{By~wC0qR1w=4O58wfA3I zmGHQha@&@Y-&oD(+_r9kX-4@R2fjA?7DIgAJY1?_yVAM(#04Dt`X+@Xq!p)iZdd2={q^k3 z!e<@Lc-;5ogWU6cyWg2F+EWzRt)p`&D)}mQ8z^XO+m?BxrTF(e(f4NgS9aY+;_t3v zahEjQ<%$Ywv#6){ zpruVSs{$y|SYp#?mOZls;@&YG{B^~3tPiNXf0A3vLM$r(+yq;WWJqUZW|MANgflVC~qW@Nz~;fetqN5p8>3FD#k3M}{vf}$dtu*=n(cQ(s)dLV)1d<0U0-0xa+S3554* zd2^xoOQNZF-g);yF^$)}MH+fWxm{zP`EsJ{(&a6^tnY!GcM3_t$+4C4r-nt8o*7Eo4_a*UnH7MN zqOmhipFw>wasN`9Bpg1;TiNFDARWI(w_M-mFJiDk&{yq!oc}WpgziV7|>A# z!uZAV=MYeNq=#dTH{*c7g)5arut2J{6lPIHFd!*}rXa`8m1or(o#KPbh!}Fw#ZF_? z$UoP=i-=&JaMZ%9%&$o4EuPZu*l0fP57M!DSySmckBe7OVaj%4n(hy3qTnJr&fOH9knu_B zBl(kAZ@GL8owDfC^Nok6$My7Lrb$Jjov0=!pJmaPuab;{S53Hf>lICAnR6GhFM6*p z9$6n3l=v6Q^51)#2hS8#-u3dxGwrNsrRl|C=fgcdX4YbN@C%cU`3Q&MWP6P&N5-at zUzhl36}1$;kN1pF34b&;&og{7)@p7qhCeG-I&fuhFKT&Dz$TsM2q)=eJIsoMVV=az zYykWj2iPkyvxpJz&aIewBl-NeM^0gCY`%U_$ll;hC98X|>@rO^efcmot0nMkG0HA) zA9(=sl;UENN{T?9DG(=_y9^RqU7Ht2nVHat@M)^A`)Pnm>`}NTiL9D-<;1q_kE4`C z)7%C33MYGRUP|k>i3Cuu5Vk8fEv>gJE4-`iUMjJ?wOvRu$1A-H8uT3<6z~mmjNDZ# zB`y7-tW)mVQ>c?)!A*Ed`YeDTyi)Ghpf}0!GV7Ey}G+d-rECXYKLvJ zW2yj(UH8_D1qM%#edM-_iJoij16nPb@sySOezt$)YoK7vK0wxsdW-FLwAY={AUi$; zD%{k{=6-6jvT=$YFpXSdyn`3h%@+)!u(+Ektf#SVy#o(G#!)N-C%p7pffcCnrh*k_ zNw)J1vr(W$GuhJaQtWB>7QK#w{M5*d{Jbja-j^X)m&nF7D0Q6mx*)Z8?j)gO64I<^ zeMBF>T9Hnm8sK~0My;~%>#rZ!$0>Nbk9&IxkSX*$^9{`^F}+plq3C_w)Z_1P&erp_ zPAtsGgBj0`ohNg`t{K3>A7ZL*r^G9gbm%oy$cbNnR9U$>eROT)1KE1CxEs-@0CpI!`79{ocp!z zWqDA3{?6J5JY6D*^m*w7#lN#@Swl!FI?>7o1Wz~GsdMCdZu+yjNtZz7=W=c-I{_|Q z-WyK$5;610f^aX5N-9yy^A!ZPqIT>BlM>TWg8bAAsuHt%z2=>4cNgzV8`)#bA~bcr zEMW$s&886F#16QyBr7qjyqz1cuav{xpYl#bxR(OrZDZEmnXrI;8#1|9!V4AW& zRcSNZ^C1F(ZEu55_P{AvOrTyjkmR$pJUZ*78tKO)4cQD{J>s9FbE-+sO5;cus%BF% zvV?%u(CIRq1&0#THXbP(HGy)gyO(qE6xpeKAok_XvHD)22qs};$;U6(E^g4+MMaX8 z7IS$*k8V1Qx-%DA{I5y#@fqb+No=?TWp~^+6jnO=p2Q=z-9R>%_Nht)YZ$A#3t(DGW8L@kY z*IosTbGiWXG~L8#KR za?tZBYSm@(R8z`|IGqY1la&BGy(bwX<>Q+3-a=5Qvar4ZcGOkNi4RvWYjQO1YCo*f zQoEASrG+X^DT6iR^Xq?ErQVQ1#{SXBbv61Klr|RA{3y?l^E~ldHWjGHjv$y-*x#b> z@WW?gCJ%))0sKS8?D3(ahiwlM!Hn!{GCIzXukg9Wml5P=`=iqCbgd$MenO)Pa_Db* zx=vB3^H<0Q79Px|$vjfaJU+9DG8@pbd9SqH&G>ltd$z5#$B}3xmS*S)sFJ>u+N~W#t2249KB!BI9yZHA-do}^xOhlo_Ea!WQ-JIoAgbk_Rdg{dw zQR(QcBa=eDQr+Pxql?gGQWWBt#DWd5%rH3?63(X?2=U$Q5s~?#`M`M;d zE#I%yM9nWZYuUMZBrE09i)b!jT~hAbzqmbJH&xzaLE=n?7YdkOrDk^x#$}DKVdNhx z6(!Mr`hA1+7X=ExHUQbRpi$Sz#(fAQeYTd?y-+DLZRM4->E@*_sJB2>4<#d)wLn%a zI(eN?N*MDwz#iWMANjJ{(C5M_{(Qr=_mNS!)O59YS6yzZzeDiN$(piL9z!6~g>&%- zS+Ia8VQ6Z*#C@t)oF=~1FrrG4hp#C-n&_%{%Qr~x#}}XOi6Ra!ni^z1q}NxIIH{Ap z=J}STlXE3m6HBi0lAP_^4Q&;INglZ4VUTmI&GPLvoPIRg(W7 zWp4r0<`%UJ7in=TPH~DCE$&j>p+E^%N^y60C=_=IuE7GuT?@tC-QC^cPkW^2{NMTR zoja3Z_9P+imbI5X&)VBWPboN<*=Wm@f5tpCt>seV;dp*{KM<9!hg&5QsqZ&dMJN70 z2#J&|4syH6stwI1=}H2-pXN4E)Y9Rq_b#2hMw>>&z#F$*f=Gq*L^3MkA4_g!4&Nx_ znD$cIVO5w$iO=!lZODJrIa(d}8mn~wL2{vdDmmcn+BoYx72;mJnWU>i{7N@S1%7f3z~;VAq=@(=3;P9!2~TVMTx@n~eghf)y)jftT};B1z0%dlqG$N2 zA&upa00Qp0M#1b-!!TODR+H0Xb0*v9%|`x$=>}DDv#Bpg0$m{*(W9{xLkEE>b5-t} z@8p(n3KK)xb3Nv;L6h}Y3S~1;@+!^Jwu4wP!Rx3NpA|)| zA#8B|`jlUJwLZCYpYLwPOt0=QViCJ#$?0sE)n$%(Hf`~;!xs@ z{e6m~2?v*JcQ?Ma^))vx&RSzX=aKUD<{M;{-yMVy&E7F^54~TRMuomX$}ySCx&e5; z(PDY{QYbp|N`Etbqpq>Ta-dFRZ_+#gaH%?Vs6C$dSclx+{2Ldym zDsI3+@+U9Xi){m=p?~-8XU;lK`q#hZc;(X3{$CkEP_T$US!(d;A^$>m{}#=k$+bU) z)D{84Qq$`48~vRa|L>L%8HA;V1oesKA1>1GQT?O!o)JRpiraHmB>3wgzaRJS7R@^d zON~tE%^!s6e}DG3dW3Y;r#`+6lm0hS{2v_+_{ma(4eIRFyZ1vilo8W6eKYH zXk~D#Fxe_D5HBNrXBo#~KsXwH;f6I=Sw^k2`ISOi29O(<>}J+4mNs)K+1{%v%|n8JAfidThi#NAJtgdLl`qWqL*|Rqn>cFQB z0!kv2Qp>|S$E0M`Va)7V?j*@ac5EPj=Lc^1*galuhQ84P6%ZmrwUqwoEy1Z~OTNop zZ;Z?TA{T!$Iw*0c8#c6;pyU?bAdC77CQe_Rlxl4ck}QZts+cObSYvfPQxxJf@M!=x&n z%TSvNRkL4vrizBFa^68^T4NaISqYOH80$#-E)1CHkgDLQ-jIolGWDQ8Yh*PX8c;cr z*rHQ9$h{>!;n#QyuV!p9i@!-lx3^=9x!B-TI$5e)ItEgp=i>Un?|QDN7)f+@xeqz` zI)1W5yC^mm>*nsRNHh@DbR;XF>Hc`-JLKY%iY^!!mIb=D;*mX zGrQhlZ&p~b!ZU$Ud*8n0{xqbdb`^1=P*tYo@wSL)ma=#YL#G(amc}$AU{pCS zO#&&%MAZbKqgJZ3z-V)*7H^nm(&@6^jUgspud`t4o2jR#$K!mQvG8fE^41<;Ia#Ex z!0U84{uPsY-$9mi9F}WfIA4jPp>w+@hFUdS9K}sX_$d)5>*;RkY5!w^2|ocgHYKJa zJA?ey(UMid9ITccz2e)UhTQERVXqD@Wa%eDn3_MxC3C1k?rdsG+YzX-+Zu#OqlR#@ z5v11SPmycYp!?{F%Sx&^^IY~J@GolQA7+sT$p=6Mzuoxi?Gp0d4xc(#7rj{YWQkzr z3l_IZ#|L8CiaY{~psCr=%Uztr)HjtX)DyRN1e99*vQe6o#tsL>z{&T311V*NOcYew zws))*x;r}nS2~p>vWw5RaNxxY*9Dtn{wCH3vRv8^QGRfA9QX9<^{r~Vf1f9a0Nc7AqNF@*pR|E(dFeJ^oC{&@Ti8|1o|aoE>(XaxlY zj`YgZsR-e~Hdqi>LRaPy4mQtyy@vbSA}pt%lRDeW6B;_c{QJFMmb{f=xFiqD zsSzFZDc&^hj=?v1t!h?Kmgv$#sa;^|)?xQ(cs5L9cXEQ>T(u_fwg#A4I)yfTLgJ-d zq=QEHKCqDkFGG!?z4GIj+RkeAXq$7>wP|$L6Q3-&+H&Fq2WDJSdGqTV_FYbS1ug~w zg{NZfK46i0EyAebP6q;Q_t|6r$AC$>sqh$`WWCB!MCVin16^^mqxF~FX`p8gAv-xYM=e=R)I28R9a{KFivn(4h2OJ} zb~>%BCUVl0fXvoKd4gw+g(RrM-Yq~UBWdd9bkI(VR-Od4vUj z*tsTgCiOM!V6N236!{{B3i*TCDuenIhZi8qywb^-yar87_cx_&>sE`rruB8~N674c zF1{^*DpMB@jW{cKAgP5aqgR?=TPQ2Waw83%y*miSU2xUf|4rcS&NM3IRgpcUXZn@%b?W9+^YA3orrmK686~DsI-F9jop8d|h z?%I>d`#r>!25@p)W`rho>ndURQFFn13ccy#^sL@a*juD1cdw)1nZYF<=);(@it_fx zlv(%Yl>L*33>H=-BYVgM5og_+8W}&E-ZUyd`x*uVJmT=zY_i}qXO(bEy9G+x`@JqF z`(&3H&|81BVbQCrYRwp)ifcwqA6q2b$J0J0$Eotog}7$uNUDz}0I|c_DjAE}%Cd$~ zIeB?CkbLTAfFzL7K(46wr#)C`1!jPftWH^7NCZ9SEj{XthKL*bK7ck1Ok8A_N9~o& zd_j4kc}TPK41%c^iKjsCJQt>X+O4Z4FDoaLJ^JpQ;_p9M>VL`A|7clrz{6@=gVW51 z#dP$?JzX zZ!3iz%LdY3KF;y0TuMHK6WDo4g!MpJ&OpS%w5(jFM$q#)tI?oIsA#W5*CqE-SKhv+ z#XFNpt6`7IwC%K9%&x`;@WpILXZA&Vr_R`=v76kj(WNI_{i$QqvVCAOFYVX{l_I0? zU}Ytn#eD4us^rft*8ctb!4)7cC#Soyul%RtUZ}77>5&X1bIzIY+HWuKpjLa_UH~<&4_( zvOLPWi#N=UbqEp_S9lgP+6VPzM(PY&;xh?aq^l0#lQ{K zCi=!gok!)A7sUYYXIo-WTyN+wp$5xX^CLiJYRm1>d7l6!kg{3F*?L4xD3 z>zKFbNVS)o2F>zUdB~qbvsQy&S6^b|-711xvt2M58z|nHop59Jkp{io=U)ol!tG$& zIn#{ijfj>__BK$0PNA}jVQhJ3Bvn1Y^Luu%DL(2*K&~QNQtkgSL-!x@C=~S^@vxz) zdj^X?(?x>%pIbdnDZ}w#*7fe7=D?{BV$NGwag-Vy4@O>DHG{#LHAPY}KL`XZD`%@L z4qS|_7n7f=mYf7_+Nb%@o|kAh=#VgK<=h?KgoucW#sYzPPlHcFOP*Ivv(*-01kO;^ zHE|UB4NvtiA`iEFrMK%b3ZHe_M#}Uhv>hf?)21xAHh5i5a~3_W76?lRnEU#R7{tQ~ z3kcXvxupK8YwktdzrF|xC+<6q_0qMizobe(mL=hh&rPPTUo3Kbq7cm2Ss=IsmE6sx zm0)fs9ce^i{1uf#sw0f}x-~+}qka>mp833``{6}_JUT&oyFE+U>qLDW=G~L5!+s(Sw zX_W3^*b=-}J!h$6ZEYQ{49d%+~ea%a%N6Y{3z>N*mS zC?unr=t|e~TjqtZatRM!r=wy4`Cix7Q!l$HHSm}&m6XiZ6lD)b?s8A^JM=17nR;?> zviSU|%eP7(*#f((>58r2QX>G{`*!%oZFcDP)0WJvE$QH*ZNm!|g5gs`b|j0V?AP2z zM1nRVAqk!(E%PqPjOJ56bUxHr5-qq5>7MV~F+s+{h{#*&!{1^OLv;(0uKL5-%rsfg zI|iw{%iMhVR7E$P+pqR_RY*;Y5lV`Rat@7L%1gz!YH+B8ue*1Y?7|W=jvgN73XA(f`ADe4=-eEnxX96pAAhx0-v+Wd94OV@Pcx!352=Z=u(lDom~ad zOnheqY{nT&UQgP4Q>8U$hoiY6Kz1|3n(2$UK&cjkJ{;bm)>a{hy-7KU!|T%9iTsCT zoMJLV$zk@h3HPHQlvo{20&l?TIA;-r1F<)+A3ggS{bIImFsdd>9Ej?m(;dc7?^Dol zxOcAq3<-SfRJ=*I>Rje$%>ELzXFkxdjWDU34oG>}Iwo+K%kFv$Tn1@_$DgZc4eE%F z8^L?Y0WWy24rJ6Wb|)M>&)|n{4Lj_a=4x#yAa;BXb3L@Fuw`}XDZjFk!m*|@-e4zL zwFq)6@I$4ec4JfXPRS*c)BJAF-gMd8Pru#QZ0fXMzk|~H{@R8&(FEcK04#u{AOs%E zg?iOy-;|q~2Z$lO-7PA`A|NQFk^|q*`V0tj zJX+*exb0(VnLiYFI$7-u{`z&~@!_uObI;3%i&8Juv(14sdc?Coa(mx2jV!0_C2f|d z%`Skk($uG#qbx~7Tl9`|2E3)h8M9Rd*^Xe*g9rrAN#tU+onASgKl5CWT4D5czPE$s zzcVx$h=|uWaoSGCdCwvBH)AWzXZ_``c=(U{Pj5W7hxL+{%?5xz-0|v=h}MVQbee%V z^?4Wp`}>MKxwzvq!;8kshD#Eze2Y2Hkqs7peqniP@QnaOZZ=yQgp{;-`ilD^Ra#-c zhACx>hw&lFnn_{abDVjg$Rsev-Ee(RWYIql6ufUsV{01_e7YGbR4+}dm_~KxISVJ^ z&6_Av->cs%85_ne~7U#HM{ZLUZ*Q`x!%|dt$wEX0O0`mfS7!t+sFH8W{ zY6m|~vOt*~wYe>>d=IR0yRy7En41zHrivuOz|eEjHe0MSeQ|WoZaN-mGQe#%`Nren zVygbQ9m$|NU3aFjrjP5VRcf7~|ELk|qSFV`L(AIN6gUai?15eNe7y0xy=*wT=o+EeNXRA%{0yBF zlHhLX6v(slL$C*S4DS>%Q7t(S+sM|o+``m1xM1_c{*o0O`B@3sod<}Fj4X{5RLXWU z@D^$WqG@K2cI-zJCsTxlg;@x1rh|&Qx@vetCq1%GG_dAO#ZLo}^z#5m@6O zIr}Dij)v<-7`J7;=52MsIVx{5GxOpiJ#)EhBHFdnptuM(*>(xs+8K+#e`uPkNIM|d zC;7viZ+-E8sw+$0r~HR?4?v1F@~+VKOLRw49A-7jb#>S)R5@k^}?VnB_#+KIN4JvaawEt|~-xG|Q`1u7e^(uU`bj>gwp+(GyXR+SCal&w1q z9lvA=;t57Pg8(sU`aNmC{qI=iR#SH7E$f6FW(w$B|>OH9xjm9lC%OS?U9mSrzgpRy?pdrf&T zx}Wd}UUE8^lt99DiEre)({QNEi7^6VBnbVC#Scw%U3VynxNYA-B8`#to|vg6sa?z5c7R_d~``yVQ1iTyE+8d z*=^14CGHfJHrHznu0bOWiu^P&kn-^l)t@48-bnKm)#osv>`vL-eHH*~2239vHWqrR zOdx&TKIpE3Y=8zk7ryV?HprSfZI}0k@ z15EUJ#i#3FSG%R)VvBnXnkU-rr*MyB*Jq~~b*^<4IqNhlKc!t(G*90|Z#|?y6g7f1 z2gEy|cWFNBKXMv#Ej1h<1wXAwbap-ELmWO@rK$WIOaJEr&&$ip_YXY=c-eBs!ii-FLiytZxpXt~c zR7^~$`PcCAL3}Q;Q<7`q!u5`lcG_=;C%!*ln2t|iyZJ+>DmwmT%MRcSnh(_MUw%#b z2ON`c3r&^iA`04)(YC}CDpW0sPgR)8m-#G!45>edMf3CX8|wcNj4^MI_<3=o=U41! zeF&duX(A^y0*jN~5Ev&DdFC5WW;#LsVRO#B&mC@x@s^=erXfu|2PQftx;X(Ju>BRwB<>%%1x zO+F|v04H8Qi;D>=utlf2Ws0_)=F<3WD1L8-Uxo3PxjAN+W}20*a>3%rCMC(#l@rHp z0~ae2y4xkV>z|00}l zz#fiIrOLq#Sp68Cr=L5|35ukOG!^h*GW&d2Wrj)DS01wRdga$q9U1x1)M&eVPM4-5 zI(=qge#(j{D8!S>P06_EUwWrAri@CIvtL=Mnvd;Ipt-+QR{&e&Y98$}sL$Q)8_Zr* z88+98@>?ZmEDqYS{XbzdLmPi$GZvyz1b4?D#bztYW3jH%7H`|viLy{d#m!`K)vcb7 zsx{qp2i}rFl0Fv@%qI82?ED@{*CgVKHGqDyVV*mlMd>9}si;=;gvReI+`q81!B}sE z&&}Lkfz*k0%Q5f5Ud{AcYI9q@ryuaNFe?lG1TeVVC(cVeTyey$$WzU~vc4UcGB6|_ z`Dnpsf^BpFlLr^#)vEz0_Jjtp<7* z;rF|-c`Zhp!tu5|2y~(IrP>qKg!}8r(PqtDIsCv%{RiSs4vT%M7?;(c(P&7{e{+$* zF3PByKl+<(Tr_H6{+Y?u{TMCawm$^0;QWnhp5q+~bcAtNIoiecIT7%DnOW?GbP~eR z&e!KV1U7T;9g4gp&6eE7#+FFHAn|Heb-Y~Se&vQtC*zLigVoUM_8n=L17@x^GO?CT zTdwRpWvWNb$5}dPjq055UP$6gR0?Lti7yB$Qc=6XTVIvf@n{zWCL4F3uk0?rQStUQ zb)&+gh4D#g0rZlJmj5?w=2MQ%tUU&Nw#mdRC*jQ<*uwvq{m7kNv;ee&80Z5TfvC5_ zCA3GahV~_lnsSO~LZ_|`?1rmMNOoWi&lr=I&OY}Pve#J^B11=zJATy)G2GK026w`v zENF2QykCt6 z`}laqh3rGjWLm4GXA)H$0@@?`FO0i1%_i9Mb8qK^Th^&BBgFWxj3NIQA=Y`?c$H?P*@==im27+e5Ad|NA>qFQj+{8 zQW3Jwj*|hnVLX%mVf^*y8BdAf*#8Oo)9Cu>cU9~!Z*KKDZ8c>24?vv8BLsF6telf< zzz)e%@5ok~5&zipgX1C!dxI9LG#A6y^k<2v2TS=&)gB*m)PUS-jG(U+Qi8qiDQyU@ zla}^Tg;OPr5T@HG;6j!*WW5nwSHyqn$4UQ~H% zEpg!l$1c}5lvBd8+r&Lsk?QXc4&LV(96KG=82*1kvJRIr!R&yYXulJ{@yyU{5wk;s zp?CdEo3hlMqnVX;kf-|-5oPZ4eBmxAg3&4+N5x560zTNIDR{r7c!+d-x~*Fk zxbwPo9U-Y)X~2)8YTen7xvD{MJ_K9OmjQeh;d@+ zu=zuRHo;*NpscGUVyP64X3?}xLbq5}y~c8p;ZUX0$%&u6_i%^9O;lL8(BU{zmhdfW zIrwEf(*({KzORedR#(xwODI)#9>BpOYxp*mZ57xz&T)Xmf4e_5YgYfApTU4wBUgQK zE?Z3eVTr$1wJcarNJN`0s4yC*g2yL}h_2N!8a{7Tg)mvyOyBX=D@ z_I}L=H%k4=4(K|ODaygX{}x@L3}o2*`y2!MOJj)P8jlG<2CNv0q{? zcxPLqJSLA5ubs9b)eydu7C5z6GB-hkg}%+DDOeC}&1Nq0VE&JM{Py`q&e zn@U&oOXLSMct*r(sDyEJm|2LsIh?uj+Zu!93oowNrE6Ui$!m&7c4zt7zy+1FG1~kA z99%iDm_7YO+k9~a{gJMP6a}tRdk$S~SLeOwfw6fX#ZZa!r;kgu>R_vtpIFj3P3c_w z<#Eo3>?jd@?%rdh0dXn7|lg zQg^c{lTe`NEXRx1$CEn_lN^Wsq>xK;HIkAyty#!Nzpu@!yQyDa!C(4-jfmJF1lIgA zoh}Rm-1bv=dC@bvB=dgRNatFk!I5O@>D5-9pLUk}2ZWz9sreibD6@onNnI_T0buK; z{07L(vK%lh5f2O z*88~`%Wookd1iqKi!UbLD=G#NIK%0P?n-HBl!UU5I*71iufIVDSanR6|g7(unY3Gn)oKWdEO}}dtIxKye-J0wW~QSb`!1yvXy`Zm+Uhc zkMK*-1mwqo&ST>s=kNDuUK8~sXwwT1FWfA>ahcGRe`0AyMXi(`eis*-5> z^XS`p=BW@&Oi$Tim!`vElqSE5soCpr%R4$96K%K8Ln_|&o%W;mSGpsMn5k^0pB5t_ zrlafc<#w%Jv}5v)-#w1(;*gsRP2JksX}&@wA85O`(A?Y+p?p8B|B9~{rPR2a|y zW%?#B$-PFq(1g?eeSS;jRfwu|P@^oT^8r-$27TmJD9zGA6z@MGXrtU`ZP^v4-^%|a z_{BDOyFBIXq)j$@ogD_QhRpMWo!VrN4-RRgf)6n^`85TLT_poAt@>Gxv=XfWP8@se z8c*p>Z=oUz`R1Nd`(>kh#Bs`Fo3EU8MC$QN?_YH-EkES-N+ga@IW5 z@L))nWS73>;tr?Kacu)NN@kmkI5dcqP?*|I+Ww5`Lp^3GUqTQIh1jwv&P!4#$m^@n z^~ZbLOP9u4?TA7S|3Pmh;p+|iq9@DA^dHUNg%j^X16pZcgvbe1NwSCJ}fxT|p#u9LJ^nTW& zk1CWU1wuG>+awe@wGGDwOJxXR45tiyUk(z=k43Dlt(6R%Zn*~cEG0keB)2w2KSQwp z(kkP{jY8JWt@&j3Y>omZlC z!=l7(-ft6fj7#iN3}z+TV|UNoyf6(Ol)lpUyrkme^TWVl$Gk~siQBzhd)k&^T)U5V zfG6Zff?2Z+oc)e_HBS^)5F>hg^rX{T(}0xHe)`xo!;H6^1RA3?Wut<6S$l|p3@_3f z;TvfS<}8GaNx8{4^0xH>tUflrSTEIWV5$i$ZU_tr%v1GBUIWaWR?8qLuJ0?S5Qf4^ zdjI!}kmC3Uug3IwrvcxYb0e1NWivJldZtpRUeO0vOb)j3wcP>>8lKZ79PQqr1HY%B zWOV*p&;q$FB9!U@KJpRNh+-iy9kHlM9~KaC}dGv zt0;t`&SuND`v14te~9%qaGo{N;R^RMPxL)jWY^J3@RmsLHCEZK9Bk51N&Grr>GUz5 z(L{{JYDsXJlTYI%Aw}SlPl{c7Rk=-NyO9uEBOG$Tkay8Y~Wrur*BfMYXq~ zv&!RGX>ojt4(d!o>b5<39!9U8m#$*!lAHd3u_i&Mb8$dLyz2N;Q=zD%XYG8g&{B)+ zmx*e2NOWLLLI9EYpHc~tdj_cB6z#s4?5Mxq`Q!cHf4$|POtHk(NJ-Y^ZTz)IkQ-@h6KQE{ zudJ?)nwnM50`Mz*|63FxB3i=YQw=NcA{8N+>QnQSg1k~j>t>IbX?GcFP0Lo80D6hy zAg(q4XsdE4S7)VZMCSXVb0~0h07>clkrS-(5XB0+>F+glF?YA`u={u(oz*Cqq|)@6;x_{R0D6jAU^2KldN!B|tB^ zJuT&f!JWYySCzL7ocs^)0uTF0d?(YTD|=>-#D{{B;T1+hYeq6&wjR)X?b_On&KR22 z=24#69i5#klbTim5ej`zg0GNYxS#e=clY+1ve?PWA|E#2S=QFoRpoD?{1SYjCsK$_ z3A(xxLmfO=s$$B(#@RbLgS(Ux0Ugg{iEP=(;p6m&MGN5<23tFhJ=q}wPELj>tp>aG z&TMYxjlhlE4{+h4>&G`1h{@b{S8LZTj|S?)_NKyWKR|thqJ*|K0rXVQyFOJuF~4&O z)Xzv}dVwqzi|Wy1@Lr1#mdur44t|6_Vx?chzXZE0KfMvLY8I(Qga3tJJKxD=%OE#j zzgLac7v-JcbS9$1f9=;ap_JRW-rf=$EN~tkD8&$$Qgpd%b4LTqOkh z_{v#oj#sgSEeS8XySrO&FZRkj?i@`5R*#k;kP|r>Sz9JHQq(EfY4JOg+CB2s(jC(J z7Vh!|iq-1noZ(vaxMmIu9XX5Cak{1_5f==f!taJNB>2P!K`s3ui20|vY6~u}M?MIZ5yi^t22I__0rYR#U`%P%enmCp@bs0bFBzhLOLE=qSFpR zVn_Oyem~kcnGuP7l%kzXI|Kak8zaMa@5jnDK!bw!ZYW>+J@It(^uHOmq5B6Ep3JAq zXO@(-W!eZno|DH)Y>hz1^uN=GR|P@RoAh|4NOhx{Ap&?Fw#=8*x1-4Me@-3 zI?=pV3N%zz1E!}x6f7((5JBK28U}_q*s;sm;-xH0GkGPa({(A6W?x_E&{v$OtHP1a zbK1?g#2|@q!l+G5vzR8yzP`Sb?`VRO)t^#1=dEFSdwXANo@CIFk_x$Qx7Ae4Q4G2M z;Um7>PKO<*)7?gnQ>2~GuvfiMfS+ggZ-r1}-f!F2QxT+lTqeDC{)uUo3~OYMtrUUh zPWA%T^vAm~M)5p7VUDl$TYk`&TDC%{co=NViiHvIXk9)qJJ%->hsMCY(Og0-931`D zXG?kYQZZB?$Mf+%f3~;SuE|3vi9tH4dCU|IWHz5>exqIg{w4eO_I3zl$RsIZ8~-l_S5=f2wU6_3q0 za=mPB60cq0?OPQBm3z;ZOm4wTif{gqjwZj>X3Mk;AdAz6aOl zKD-haTx>dCuEgRpz{--Zv{-D^C^0?L`tafPgElW0UAdUs2V?m5c9E#$k_dGW3s=i!s$`6;??;=il*_AqQ{@2Ca1~&D~T2WG5A@OifK+v#9u|#5HjQ zbkn|*z=*GAh^pX!-+rf(GlAYB2O*xZSj@7SnD6nBxwqVGCQC|5MR`7%&sIvE5@0g{ z01;#zb{OJU5O}OTmR5z7eAgX);x2@>iJBI!*X*}~|B`}8AZpF#Vq9$;tLngfWm`*CU4FSgu%&%F{qcDWrr+_n zzRmRmWY^cvZV#hdH94vE9^t=jyy;{O$B#XDj*M)3v_Q|XR;ly%9hdpA}~w5M;oDNZfYdDDw(L)GOQ;m~ql9pc-- zQ6UqeklFT%fY5pOOpACMOI@>xjX0lhC=Tz5sN~=~#vo?n=5=o`ieuOKWa9DF)!=G? z5mo!dL}v*<%HM$rkNh$avXA<3ti(b{wz7fqa-s*#R#5v$cSIsbJZUZHjgEy5_D&6onxA&hx__4CsZf$!R(dj zJd{u+&BTw7o(yW~k<7%po>eFa2$yl;FRv zigj1_7Hd>k5Ak2IHNny<+jWbbWB67Xloex|u%4ctT0_`EGQPR!!)R2Yg%tqNUnR&H?JA49Ynb%py+(M%1ESEw!OQ zR^xYOYjZmHK-u;QOkI0Ae{g0NI&Mu<5Lt~t@O9av^KF^4)b^YD!Wx;i>jGA(?fZ># zyoPGFUzv|zJ>i0y3U@kiSBM%?Ua!U=(-XtE64}Ng&pR%TeXbD2RFR)A>58cVpKws+ z;3*a<;*DS>7xkoqRmO3`oDHtY==2K=Q zJ=F@1tkQKqc`opDZ?|KyvGRSu%Q>jR*_d<}Vgg>#E`>RBkp_b~WRO=gTOrh}oOw2K z!2yWJJBLDTFryIabvVy$q7Cs9V;Y4SM5TJFS6BStE$Any7ZY(7Q!p@O-!Pu7B>nAo zB?-l?(9L6~<#WWcsh<|=VtjxQ3tua1SOMVGvj%i9Zr*}GvYoHI+$3Df4ln17*1AV9 zo%ee{%=XJ5|8(A`{K`pcctRe?Pc6Pdw9^gee9Dc!eHF^^9~{EQH+{sS||N zg6WUWZM)tb|0B$4bweUd+%JY&L0ZDm(J@4l-NMnd7;;*QKW84i2EC{L`ue(LOD2RX zlDniZ>CtKRGO9&o-2pqwJUTi$C-xON_MeHP)+(}ZM~W;Q9yT*8J?WlM)B!*h9; zNRK)7pV7)NmI#QeM%8~S&lp$FbPxH0>&%kMQLqxX{!^2EY#L)sy&S+~aA0N<&!fsx zeUXgMbD46VfeTutNeWSy_q>`KJ^EO`ww8{k65JaS80B>gQ*acd*Bm{}%~fvj?#ty1 z&%K9=+SsxCQDryBV(MS}{pXg)^CA8kM}?H|>Fer%(F&NB7%RxSl!b*Q+L(4$OFNle z{bchD!iu3(QXWUrteZBCvFLya93OvwQ{Ab-m+|e*vq zuk6Rs94TezS$!W(abkt@I9g;6YYn^3BK}qdeAnjj`!$rkTPLdbUk`A`Q+H>fceWM zT&}11IF7yCmn~!?S==UF4mH}A`3dOO1?-6g?}$nM%D`s1*+~R*MgSifNqp9Vdyiw!3FX;UpUm8a3+sC7cG+=-iLuKM z&4~i=mC_4yiMpNc8jfka#RC%SmR#RyJ0H0?=i97rvwZ$c`2EyC26!rXdF^{U;!mC$ z5F}4wYYJ!%n$d<|KdxP+RFVk(knDU@4$^HM|2wPuHKbqMUES^UDvu)6SoEjXUXWWJ z0kM+WvhpY&YGU{`Y>G=gfyZ-Ng4*Z#9UEMnU+A9}x3sISP;G4TwQOk6x?7A76j2_@ zVT51y3$og*^vN8Av!9fmz&DZMsovaNfAqY%w{W#`t!I1kXh=74BH|y3#N$J~3Qa`g z43J)RFt}P$)Ep^eF4yB+^z)7y%Qa}ZIx@fCi!l$Z{`PrA@n<|}Z2auaJs07w48<>V zbpgAJcs$TY{p|#)NRst?Q<=3ktL4{kWDb*Qt%7L^qT5V|5`|)s{n7kKtGVaK^H0`@ zfX>&w3jte8y+76``l49BMag@xvtF6Efq0p+p-o|b$akIcuAv*RB&gZ0BQ-Y2`MvZb z@WE6mGnGenH)v@X#k^kkOXUI-`WXrF;k=O%E9U-2^NgQy{}zixM*oh~byE8S2W7EF zt3{0!j)2Rh3SrglGwS&Vu0vuA)gH}c*x9=#TAm(~%mJwSa+Wu5iggiEw0pw!|5o+q za?q|S>{?n_iuJYGv)w5v9%m~1+C@0f(cKhBySu(p2$;uxs(rN9m%|dTJ47*(#BomQ z-2h~kJapE3wyl<=r(=ZqjQa*WY$u}QFw$hphfVLiq zu7sUEgXdG)v+cUU5$pjV>^e>h$d`~;R%R5Zo~3_d4o%^$VIp&M1@DMapR||NC|VSo ztY6^q`F-K$58saTTGq{{?T@~F+@~H%WFs5S{1vR-jfK!!^SlcYhlr3zu#h%J^X*dT zBs6Hcqt4X){)W+ARdMMso(?T%<-G;|B@xS3YCK9C1w9K9?2y1bj>nba>Sr*zxv zdV3*d7aM}Be)KFKDqY#r+?~k`>+Ia6$fp_@quTJLkSYI>Up-l3Z;q?T(DmxSm zV=5dsTp?kyYMYP>DLbrbY3r5hbiN80=r$*8`Pjwl%)UV41inF;1WSo6KXRVzrkS3# za@+wGl}bcbUzX)<>MsUuHXRq9!MbX#@83srL;soQh2(S38KBA0K!NQ@bm~s;Cv*-p zL$*x+3YvbPz+i9XgOJP`L4PWSca=D`nskw}aNvB^BOt6kojsRL3}3%z+h?>Q)^hgTlm+^} z3o$1qki+>zO)0csPNf|tEA7ql7HM-znG_+BL3TGpiL@oK7kVZ0{9T;zBNEX5pOaI93r)>t zFzuuWaj@LfWpKqrooyjOpY`hlFN;?-V+0UzO8+HsG~nzCXSr2n^FHAqu|_lX=24@7 zL2pC4_KuB`#B6G@Uf90@C7lZ+My(_^TvOK_<7~-Ul;`u@-6vdqlYXLFvu%b%b{c$g z3B%AObZ44*gBW7|(xGYZ7|PAa3Jeu5pVpDLsc9|Md?W#ZoWVhDiEewO{mtC{nJfY` z?g%c=*->Zy2<~s8efr>t{y(TG}7JO-6bt84TqBMM!HiZ zr5j0UL^}L#{Qrz+eeYTO2p9^iB z-18w1ZYdcVp?gy!XN;wZPN-!qy|brcmN!HTp0DYuWM)$&Uo~b;GF(f6%?MVWKcv6K zHQwN>8TrixH~?-wO&I?)h--nbm6g3KkDg;}Q*>Ix_SXo^)8ud@i)`$5 z{44()X7mXl`Td$*LGrn=J!mUGr;ra^#HJVj-MZ0s!LOpAEA8BtDOl1>GID4IWHib0 zdY$m2$19Z1o5Imtn1Mc0vtylbX9L+N(H;w(^&z*x&sDSo{iQlOB}{RA49*Q9#jI9K z4JW0c$myt#)?0E-&U*~OtJQc2T+CQRKbK23WY{{x2D`{kNd&~d@7!DQ%w|XU@Lak_8C}RZSjYbwCRvywQPw)QZVWCjRuJZyqMTMZ zM*+dvPD?{^FqhHpYUuQO=8kytpy7?LsmIlWpph$Ro!1Ko=QCW->;RSIm}ZPPNoVXu ztbM2wc5q@r9gE(V)bTI!`eg45ANPgxVYE-OuXM!&$j#N`x48c?4=51vVagk&tdZab z+kOknB8swqZLk-Apqw^SUbU3Dd*%*HL(O|#$43aPo#UFN!NnYUAnZS^Bgr1z+opJR zOe5Gm94jDVo8;hZ$+Q6vkN5ul+uScjGP$-H+C2W)J1?LeN%K9+d;5zVn)a|_Qtl^o z7Le7KoTeOVe=y8aFNfuvo#z6Tw8pMx(D`KtVl0Fq9NfFmq4AqT#KEJ=A0tQ2QXOP? z5tvX%i&MWGgcon1(y-7XHE$Wx#XvPFeFoc$`Ca_rnvk>!tn?)qXcLNueE5h21{3;D z%Fj`cL~cZBA?e10==?_?PsP*v4Wz|T;d=^|HM^Sda@e5=RzC@UhjJ(9p-1EpH51;e zmdJ$9WlR3ryb!H>ps;zeCT5t9MgrXK+grH)Sfrdjz<)WO8QwA3W|1c!eHKY9_JMGr z-2!)3Qj$VTW9jffBRH(^wdW)mB$E0Pna!ctU!xO)Se1zoXoV}5Z8{Zph zEx4R$(a^$tqjEC}&O_#)SELXl_FpzOQ}laf^qo5zH%fHZcHn>0CkgQKVek>J%j}4j z*(xD`uYZ(q*)$J%N!S1(dZh;EIM?SkZmvWxcGQSe%mnb zW_fr@N=ls~-p$4*af={1h}E`35fv4MiaF9ZUuue0BXf`k--4&# zT#ABFDoz$Vd1LO+psA}Ag3&lbXo|SqDJ9JbWKJAr46+@)l~?cGv|= zWw_Z;0!eP5o&u>0B(a}TSP?O!s40OkGE605WSF_OXXV^)B8~gVQ9m{5O&*aHv%*`@ zv9R&^9wj9O)F3qtStH{|{wq8NZx3RD>m_Rsiv)}g1b!D+X}pAF&X9}!0h0%E+xcN}Gu`m$a22+1qSA?n#)I2mn86Eh*3m3PU;CYw4n?o7cuNyr`+Rj||4 z{CqTw0~E>xb9O~lL&MG6%??}24_3&YNat_NUkEWkYyQRvB5!A2c6uSa@Xm6vqA?3Rzfvr1Q&d(A%IuVOF73=4 zU|W+8Y|R!YXP4x?jMHtXfmzd8h&%#$x0()^W0D9}^8j2QSO?Q_ZTaz6_hT0TzaiA$ z$Ag&Uarf=YBNWui*(c`+IO09Sxn!6pTRU+8ud=(Ip->y|mV-miTQg_izg+9WZuhPh zgSFM0f||_1OQ?cwV0Mn{!%m~B2Fr5KoPwSGc{VS=wh=lqHMDPD)#7(SKrLRfY5X$h zM5xCrm(#wMVU)uuh*D&30Q;1?{r3~-2CqW!Dd#)KpuMBINA9BHB8~W%8`lub?>7Kg zNfFWn|B1C*iFr1HWk49^wSDv2Y4~8eYhFF5lg)y&cgSy85=M zEB^h2=LgC4MZm7P6JRH9)J?B>W9-eb8z12 zGnVwzWb5@*sY!QZ*e=$_Kb=Z1euxvP6~PZRf-v51RHk8WAC8L7Aa zS4sb0Jxk~#h66ip(NK4@fn8#KvNO$^tC!qloRJ7yVTkZRlYC$yB-^=9(g~h3GgDbzm^S%5vK8Sl_l@S};mG*PcjN|EYMiL} zYY&J_gF6iIVOEyiztB^K$#+ql(L0DbfGa9^X55PRC{eI8<8H;4e>i)DL_3xG+b!~1 z6mxA{E}*C4kr;felGhJg@kTsaoctg60{Az_77`1zw9}*YkDg#as)k||Cym+<(Cexe zmok2PUju^s*Hw*U?uFy-4vUWSwkx6+swIA}!ydZfocs28Y zzp}q*D1HgDom-s}LQ&SXFO|IgX{y2LdaV_n4j&smn7TdYN#o|xLwwj|ac$egPggKv zc3-wbfp;M1aE>h8wf90kI-_-$ar%W-92!Z$wB{whsX`W07`Mis6@h7ho%S?46#nbu zQ83Z;GMohDCx=H>N5No}FL`ADtWN-PsdK!p_2q~T7v`yM6ey_3eOM2{TG}CJJ(XRpt2oW!D$>Dfd5WYX<D=em`r58_AjdnFp>O_A^l#2 zf~scj8_9a$v7N7pz0+!X#XTX+%nO+#S%C}=@A$xT-f6rZUMcXIBw2TmNugFvbSr3k z`CR6clL|`q<^4^s9#OV;u*i$_^xfP2`IbrkduSKX6Rj&I5$X@oD^7?luynCZv8gzn zE_jIc|G$`QyXM1*4?vCfU7a4-DRnWl1;*rlqgd2=fpuR2vgk9wr(h$uOSI>8U3H_9 z+dm;mfE-^(mya$O^rjXl$rFq819CWoN5BH;4v>_e!uHE&7#{zQ^Jp4Hl08z9Vb>nBjOpV;7w!i zuELmqGz_~zSDe^2(mQ7lLSIc3EBf#2$CW~#&S&Rc0inlrGo*-?OjepGW4>w4Wt$KC9*~W>Fm1FvUG++Io8(fM_ z5ElkePw5$z-f~g)5T364`wF1jM393DNejA%hZ((; z1eu&9xA=q33<%8fsN)9VI$)Zgr8T^K#5MEPpxe)Ztl%d#;N$Y zpJ-)3^vmuqxarW@h$Okpk7Q+uY};@-&J(Y2o-90!C+Of(^vuWO7*U0wK@pV@AzSzi zB~~@{OrL#v&iFPFEg0H+{!m?gEG^|i)8lg`LDou+cyravQ_L^7fqcCzlcr}`um30;B zZwvGk0~Eo**~__ysF!_HsXQ)b*RfR{NBA2L0J4@8(l+k7K~#0aO$K98E&xbCgEc+D zOI1C%$aLBjGd~yk%HxSNLn~Wjf^S?{38Di_oV8zCs@985Hlk>X_HyXQl5hK?IS@A* z3qf8Vrq$S%o}6foJ9=^JJ7Wcsk3c}0qLD8?M&a#Pp3||yp-wE-Te8S{$UF7@Ia*#N zLK4Vwer2GQHhsl%h_>pjJaJZiD-CAFncj+k9ocU%@ihCEgFD(Fz!^jxbp6wj88u+aY2P2HQHp&DdXOc}Ekrz!` zhyk@^1O%c-KC`X1eh9X75S%NNH!IKHRjhK&$;fz$5!%WSo$2n};0fA_1d5in-_zB(pmnn67yH9kS% zIm~cY`Zn0`{_UOP zng+7KsvV93N0t_uo_L<8q%rVhbuXb>WfH3Q#w@N|=+SvRU*U+E z8hjk!8?1qPG3xv9p~k=vLwbt!vxu4HD`^-x;eBrZ;$?m`kS7myqP|2-fwJ}a8_yYJ zXr9Na7O2Q(uM4`4hfD4HT}Mx#D33(Qjds2}KFIiS`R($uj*6u1xOgujBI0mR@e!bn+NZ?S7!PV?oM!z+5?Z1I&_F9X1$b19I}Yj| zA8M1cz>GPkzwE>RB0(=&h`~1Qpn{o1EM{iHSy~14;kxuKbGUgzeCf^a!`_l9;VrV~V@!&^jdL!*6ME%T39x{}#n-x( z!kIpa#-K^TQg3v7C!oE&V(g5vxi-!TXFOdkXhlOneg3(3cXubVVdKh^Im#)C7U79XA`k_zSYEGY_ViAF z?`Ue$NH+$^!E(ff;^I4k@*x#_9|2}BFr7ivqa=&Z^Gz+LUY_}QmMzy|C53g~pSYsy zLOf?t10ml3OA8RS<#M>)%lRIhdHj!c_h0Pm3oUPP_;ZDNcax#jYpNvV8kM~>&VS>4 zXU|L?`I*qxS3>qo@}j)uV6LK+QrCKH$vgiPZz0x;h$#2^NE7pkbbTi#jlzHzr0Y&_E2I&vE8O_7C7jI&>Kkdjp(iXmxsJAi&oVvpVMIu7b)Dw24hyd zD5)hh=dtrh$4PPxaa6w-Xd#bJv4;P=9T*r8I$u#UdAD~??!UWh$vtbK?$CgjYq%44 z?xgOh|HcFdgjfkfHhs^eZ0w9i9u%o$^l;n)mvN_t4~aWkizd5`?s?1vxkBf(s8x?f zaN)%d&>K?LH#aHZ!#;H6=0Y$rF-@UK7hn(*6Tc5Ds^C1h34TczJlxjC_YKWgyaXV# z=LiQ;p2(B+X|2LSLrdx9J32bP$Ne_SwZ`BXKRZ1w<=cHIgO-j@ zzW=tr<8Q_zC4`2y3S8OjO^-*e!wBRV8vo`Q?e7C9vcQv~Z3PV}xV%|(!~W~sC9x#~ z(7H4|2{BE;Z75r_+PK(T8*8-o^60g*iuS=}(nl&oTDBdatj#{hOYyN@ERgrXT-X7S zJXe#i?;ER5?o{wjLsbws#rcVa3C;QBlYjz^B~XL2hJ;#@jEn7k`1r0!f+alUvOwX! zdaqMwdWyzKIs#42Vr36#_oG;DuSJ`tN~jt8(wmI#jaRhF{q9|T4*W6S5QK~f3HoDU zee}sK$*)H0fa=@vLEAIu?`XOTt12+=K;zb52rzb}uXX~5T}XSZMMI}!57>e8KO!@V zDJzWca5XZVgsju{sRC?R%Y`0!!k$(YEPH!{<)GQ7t@7#3HdBWLl-rtl(|? zo%_3Ha2ql*vMmOcxUagG);m{VT%;748_-n@2~eGYAva2kL2WQMKA=IuD*cWVnccS{ zBR^rU3X+^FR$c>G<8l5-&2xYga?QU754rNdPhZ&vt+4$}MWqpii>hy&gb5s6R7>kD zs$i4m{BJhFEt~@sMCN$>%01u^rsrN9E^6Ulb9g!7kTk@&n_HUR@oa?}6t`6_Z1OKf z9`siP`Sze65kwq*0;5!XUs`?$KO=x#>yF`D;Zn$DZYAH|c2RmsCNfLRXLIK~K0G6G ziFQ0ez7X*%@C@iW4KW;ANQu=lzDsESNr@kX&A7xd$d1Qti=14LNWLF7`Fi!{9 zGU%%uTwJ&m5>as?1Miko&d$!>2*{&bHGcR2>F4M7KKx~{9GMovMqNAS0f@(mSxij{ zAdsbM2bW-novxRcm)pF`KmCejyRotHzGCQzc9uHU(2@{);iEIf51=d952x*z2l8Ie zg-9l5niJU3#hsqTN~(#>H8$leV!u_2^@CNdp&!$?Jid7xwTq62@mSxtR9E8!o z9ehqFT6pBe;H6w0smLr2&Ns(LqokV_4d%?}VTPig^}r3cv&@YPUnzGt+rGCi&`%`W zdfSR@nS8?w1i(=u9FX{smU271v^rHA#Xv64T#Zh71GeWWTzJp?q@SDk*a!JwmSa5h z%U@vNE__pHOz#$r%lw@WD9RQtvy@lD_!86x@A+x>nqIGHM&haJUT&FkPilQVEoH^YbV#cE4iVo?-<%@- zMOThWxhD1sw+tT6y%CPy-2tM9Ndl}a5664;auK7vqCz;=*6&|4JRW}%Sse2gy@D?` zL*zWf&9xKkp>TSy0ByLMfXX>)+l;N}&L2pO3lf)?A%l4bPVNmumGtuB83ThTws)Rd zuqb`r*~YwJg8>FeCAl$(i5gZZrf&Ob+a`wtQ?_b=sj7v`S-@yXJPxbGg4bo%uOww< zqw1MJE=PS4m<4eSv*bmmTYSJ6&U!zx4uG=E9@1>f!SWYNy(NN(cULY@{Mc*{Kz^mj zQ~`6RoJ*SjB-xY>NAT?I&zP73;3Vl|w(^q=_kyp#t?a$FWLN11+7?UcYLA$7#s)Qu zs)8m19h#1ihZGx*;%oGoMP}_fs(U*Od2zNw>5zV$hPB#<_mUTN@Tp^fdPNo=qYXf+ zldA38jK7$yIdd4NQJoNMYo9}QI&qa;nsCV7iVjExgMYeEN=SI-CNX{EfuaA&U3lTA zV_dy;6}{1CE*Rb*hhwNw?Z%J8z5+{jF$|k=oF5s$&EUz3A|v~^*|x9H`Kj3!!vR_3 zQ+q6hxSc%$#}c=!1_rTC3UrXfcZRG_xJZHKBF4TM@iycJ8ah6wb0A9ODIvJhSIGo-0QAG)p{Ir%TIkBM zva)*E=IDRYl?nV$8?zGf^1>2Z+vTOM$F}|$R8Oe4Pj_P5Z!W-pzHLtvGL}CxaI@%B zwSgX1sF)`Op9-U=otMYU9K|N7o}xB#{hxTtESsv|)Zj92)5%qm%=5HbnC!^>KHYGa zIq_tY=P z6I2k`A<{KN1G$+j{%oZ3>|GMEqD-ke+8dIl&I_aTMQyGK{G=4gCFBpY@@tp8wFSKJ zKf;GBn;|OH5dHmsQlCgqnlTz_ExOl_Iz`3km8mdZ++Gf#i_rdQynP0*fiaO$y0QNu zpr_%elO~bLu9!1f%WdO-tjqsu63i5&d>rBn_1jJv^q60F+eb$AXk0__n@aiCzka3j zbU~;Z1E4$Y9|`>mlho2T&F^rI#+IS`(wzf&zJxV0!pq`uxAc;mS2n^?Jbc*LA((Pf zByhhiGh<$>Hh|>=(K;=X4paXpW){pnM^`3>@>goF1pm|@fHsC0c$F8GA{DH==2q4j z(&}7ZPL0n)UH^t86OnK#OYl_meF~ae_ZxXT6P|&_X5B0HXv@Aq>&GPU>LCbB2&xI! zwDyiewn}J{+x>KV?_A_|)5(dX6(R}sk5am7)Iej4T&6O-&=Pm3y~&YlAHP_&^0czT z0&uO1^wu;^Ruas`nNs(NGQ4ec$;xY>2kNM?Ch)f*?vl+J6qkSdhuKRS_$ZXKsE7c- z60O?U8&>ql;zx~jf8Gwj2kVO%4wO2@Ltkj6MT3TfW_6_HKV}{{0?;N<{0Q~`%sxD? zp$(hV3fUp*lTWb~nw+Z;a;m9ZE?QD3iy_R|uaMn+)TubvhM~7Wj&?Zdn0p;oi#Ro5 zw+glKwNyydH?yK7eK9z*8kfx4RAHk~A`+3TdTvkllzmXQ-eTiV?LGj&M~h_N{&Ot$ zM1B=ebe6`qNh81w{kq%~VSlSZ0KzK`86tkk|E;b4bL{MXbj-Fwc~dG%LdP2nkn4;@ zd0L&WmebcL79@OuXT3%b=osIgE7%uM`jrOFpoI-}T51Mgmso+9YP06X&`;lZid6gv z7~7iPH3zlKss!DJdNs8)Nw0z%wmp+akM!mUTos$VDL%&x(Zal>o0VxcSR#r-{%_+a z#-G~WclDpyW&hrW9B;UApA5PX+xR*u>#^Z4{PgR^f7L_?GLy`JS)~GRsZ7bjrkKsm zj4t0lg_&qJXdXkb!q#)`6{IlnW0OwiTJG3wiLJA}N5U&Q8r zJG^%SAo7=2_Rp^VBybaq(4|%~Kp$WOZ(~LozLv3P>ygdh3g@q89Geh~By~=kaF9uP zZmm#dt@kAY5$(bjxUANCDeL+svSHJ)w;ZnZ!O|dGD2^uwI5wWPNt8}4chJ3$MV5Mz zxh;6dejD#;irQzebzN6`r&m+|TM%jBK}5j8Mg5E8kl(TZ;1T0ag`1D*Pp`8e z22j)@5p+HN+Z3<_ud)}J^QNBJiB3lqC}9g%yk0u8-hlpB=qsY6e&wC)4%^##C<^Q7 zXjBV&!<8;gu?>b>4*CaltL|}KLJc=;hf-IB6$?RgFXF%CbKUvSVKKQCsnA{T&HjO@ ze^^7_r_}2E-!Jq1u7n5yARKFAm+m)9XAjg6T(M*Me`*oHAr$SJ8NDZ8o>`9ZHumyj zgHl!ZHRjnI)>PN0Va&^2-8yyB!QM&4p;m5R5kM&LC7V7b{oMx>c#sOzq7JTmw`c#< z%qoc>Dr!EPHEGqba)scQB4L55R*L%4{v{tt<;m*}YGRK7BfH(bBs#sU z=Y{*-1hvjX4NN@Xd30#z_?idc-VlSZ!WXP(|Lcnv8P||kwFgJYE91&04$P^pgf?t z!B+Fn!~E|*x5N;dTjlQLIu(&q3{m)UKei6Nv$@s(M>m{Uf@2Brx4#o>BL1^d0R1~{azjF!tzy?*z49_hD7$K-Qi+|dL#?a7u3Wh#fRu$_kD=BH4j7J^)t5d$I z0g^(LSajosL_>2~9cHl|g)n+QK#-*gTC%48nLt$qB)L%whsBP)jJ%YdAykQT1{OXr4!TvGv&=Z%rKyvdjOnIWz`9G#3%s#Qkd*;6(hJ%+-^V@_|;4wl=Xc#m2^@ zduP-hH2zQn@2phAa3Zz#8bq&;mY1f6(6%MUc@XrV~6^8 zzRl>-;)+cF1ZByssvUYraU&IN!O6N`s+g7#x?=vO+Qem~;}_a})qQWH7z4Rx~I(0*^1Sgwb zjQheb*WGf3tKw2T1YMn$IzG=z#fF|fP*Ng}@jN*0nJ;8~ncMhN-Y0>B`4A}7TV|vG z!{F?q1yJlatvB5L0msq`SeDE@9Gubro^Y?wuBVwaVHEwNG<;8TX{{#v4P5=qear zb-!e|_JtH#frygr|3J&Ut{?U;o|PAlO58L&-H&DfHr%l{j*kK-qhlltT{zlWt>?=i z!6hdCaO=i`CQu>Hq>}LdZ9V{GOf=_{12*|uVLLe=sA1rZx7lwW_ABIT3WcuMQjT00 z*SEpxC#PszKiP%xl|y$L^JQAV-abh=)^@3FiXeVaMj~p!gK77TANfGQ+#1o=1~z?nuu%fr@-T2}I~8z6DV_I{R7QvM%4oyazNZpE${o>^b7v~Hs}Hk1#I z$7PmllC>bJQc(ZC_le2<*7`XOfIes3<=(T_Zp4ZiW@U$g1C>%~pvMMST{N%|ro_<} zNulL+V_>&oHqz3aUz|qTNzLp1OwCj}CN5Rgk+g>UN()1Meq|8DNll%PqTPyuZIv#-KZ|G5$y#LH{9uI=&9? zx#uHXrtPF$hf3LorWQ=DF@PJdldRc_?}V#F{V0{#0gz*u`mrlok+qJb&@ORn7L_RH z20W^bvp4fvo*Kcy6!q0e&xJ;A?{()-D+G@{r&uE`a2_uX5wA6l30a9^morSFMeMel zp`J+b&+uFS+Qa}xNbFnkVx4WIizDq)9ezdYsSlO8C*Ve;ZJP)ak273Db2ZRHaW8BDh4~r zJisJ1rK)a8xa9EKz3+JaSEvxkM7mB5rabDP$3R^RoK4s!eF#ShRQ?|CM@ho+mq^`X zJ;fzJoaN6AHwxxO&+tUMYkPmH0zFY)aofvPjf9_T!ddi#T|vz}cyf@0oV(3xN~D~2 zC7f%nLY%4%o%f0}ALhiS`6Zb{M=iwQ*W*FVO?-WwtBWvu$5+w}9E)Gcv7jYBV$q$u zZ``PJ;C1f!McJQmzl6EsYscHv9_wpmqU`dgZAGL0H*2iOek%n~W zjQrNzkec0`HMbcK32sQ@_I26mn&0cx7run8F)9?kCyrtYGPR%VOT>P}k(y*#MYSoW z2O|5=M;Y_vus-pgdnoN?^2UNEUdWs+M;@HrM#gSFmPlh+Ut4+|0E)e)C=SQ zuE}@>b4^iQkMtY|eTTjZNA$>iY>oECzWnBi{|u?w3_`vZV#O%MS!u=-34ywrF!^^Z zo%8dFrXf`>7NRz;GX1bIx%;izL-f=8fCIK2ybBh)G>&7{(&A z*5naimp0y8k3nJ;aLAvoXk@?@*>kCHq8nwB26z;RZ1eGhdQ78SL-A*LUJ)&$j6rObz33 zmuUQa^erJEac^_JHgCR-ZpG5)KALz~`2)d8-D&rTc0dSyHEH_KQMy`G9GjgkmW83oOl}*o1Ab@MR2SsZ( z1#x+xX%95u2iCScQkPNWoHE__Wd+9YI>|6HwP?OOdcmNk-0HO1Xs=^Q1o6h#UGV&z zZ{mL*mD{4=c2eFUWjUh2^Tc4{O6&3b{A z2Yz^{t7iChxb2ATI6uq?aaI`W<0U@vVt#Oy2&!%-#z207l)h#tN zfSMmA&_>_z0L1)GJ^GK&;szUvznT_3X&W$f?|)+ee$hjcq46gI@Qp)6K_GF3q#h{M z1|P&uD)H5SSWG9Rz}PSe!}ueILO_Mk`1@eV(3O=^TL*JP5bfp3oCcy$_o|0pE69f_ zF0u0{yRDkFRt&&ZDV8)he&|ZpjO08yot%1TmOx#{iB{vn0#yW@0_y$*6cYNAB>TUD z3KO`;^_%yGaD9d)s{G3BhA5RgKl*;Q(zyD2tg+U~AP0<$pZ#T9-y!TI19GTg_u_@d z#54t52@v+W(C9+<84f2nY8YWa7Qs%J0`Z?O1!tyq$n)N$0Bf{2$G(KLPOajr3Vlp{ z2mV^~PJAQ0u1Lpz-z}F5zCaxlD{8`3)X2- z=|GO!U+CEnJc#W0rj3*X$6jV{n}J4}H(o-F4|RCK)3C?(wog;~hV`PQM;+=f@pL2I z5JzvcWXC~&L&)`8az)dZfnif48*(LB$HnDG*S*+bG#~!qHN^#dfevlh4m9F;2Tu7i zxJLMHy7cB}ojdWmqv{~>PkZL6O0SdtMwSVY!YL_r@B_&@|%Y5tH zubAmwNPx)%Fwyz!KXO>Rn?F(d3NXdd~ewSsJZF##}5}16O(}PUGF1j{%jg~ zu#m5>Z>Jq6Fo1wF@l$*egyW3D-S3YBp4S0L+>ZmoPrMN@U+KeCM5vY&{rj|H2Ic5d za>N3r#cc1DUw-G$fYmN4r9wr21=8@+#h^prm8^G3u5GM&6Ljs;vbIexBoK?*J`>*m z>b$zdjYgKUu1fT7Tdi-`>27gAWWJ&!b{C#`0tAGxp2}Rd9*BgSX;`@-xsYigl68I7Hc|}%I?zgm=5Ft~5e!IGb zu19D{h$smPT*qN@j)lTEC2@&~ed2bto7dMK^^J{A^78h+9pG1mVd5Tc?(P(nl+XZK zz{1AnP%w+b8V4Ar1kjnfK^kcZi48T;;#sxq%|t{*se=9jV&v#C#QX@6{g5Rp2sCm9bnk^Wd8}5MG5|gxRbPx9)f5FZX zxnm+fmj8M#Z$gr$sPu+~dc27sH=cC}N_^sgA#2*()|}S5>fy#@2$E^RR-o!Kx?#+& z;(7nJmdQ9$sMt#hvpq^#L^(;BDg(<#2= zxP8Z#H@UvQ57@5c`g`BI8m$U&onqOH2z7#Ee0n4fqlke4sVuc}XHWuT>_uI%0_T8o zHZM|UW+qtq{l#lajNs7A8EymlneCAj(U(|GW6E=zmzQoV8MBqTBMV*N%%r3w16t>W zWm;NVoki`!^XU@hR4#ksBK5pUhli~#7kBF7--_S0Et)epj}kAmbN)6hLD~M>nPwJr z#4p?M-#KJr3M`hoTp4RkIG<3$#xau=dcoRnz8Q7vRxMbv!PmpIG(ZzvvzsLl8D9N2-B{Z=!m@FPG7RQL8#n_;j*t zr9u2Lz}mdTipVWP`-OY7FztEsPTpV`v#Rg~_X>JG=Wl6=!v6@7N3rc(XJq*9IGWDU z^!*ckGu#lsyGl$>c8d9o$PaSPXN4_tcIG#;bTl?LzRN6U5NC2Ws4Z6JlweBX4Rb_U z049_;HHd1e6n%+UWESH6t+3%;rhs+$_RLx5w&l!I1n$}hj{#plEROKWO8zGaKxrsh z*qpCjYR9A$B3wK))xW4RN;dWO&r!E<-nDn0pX1|sRrtlWF2fY_jDmv_DwgcrNl#R8 z_53>Ve_rQ=F1bHb42P^{=Okd(KU?##7&r=#yLc|gty%E$YqPH0ilh0L>MD^E3=vH< zFZN`^ytiq!`Ou%RxENG0ey`%$I=JWrW7A+v6sKgE6UTLUs)vUwsQVdl>>%g`{{_fY zS3m8`naJ#xtc=Vi;RlA>^Y!kaRCY^@6tlS*m|Z_#(K=`M<@UzLl7Y-olhY6yp}GDL zbD!pMp}F~OzvnvO3;pnea^*Rs8reYNvc+BTaL+f1bJ-H%-2J<+D1W<+UjlJ(gflUP zLFHA_ZiSd>(8{N#k4wE2omRKScSFJ~u38Qbt|uWCA`{U`hm=#*${s+*`Cu{DEw)TT z!t<>|R!ld6`0!+j-!_$(A8&!}EjlJ`e|?+_AIHx*i^;N6-4#7~S{YUANmn6Yn3x|1 zSB28K-{*#7{`s9kcLU6_C6K@Tb(aLsZ(Aw^y^Qf>OxyKPah`+Rk98`us3Mb1EG_$u zUa5Q6RaT;OcXxy9>T+`fWiUt7y2$DIFPe38v!j7a^DOM_Bve$ea7Tx&0_c*YE8U9A z=yrll8~D>OlV(s&fxGJJJzSiqsry<`NZju>R~{WPrOkQSmVtq@VFJm* z*h^Ql${7lk7sw@w8*I-@gyBt7u_C&S@9ug${47Rx6NKOX(WGbScwzwsWpXk~0W&K< z8fz@%cebMBwT|l&5(>(W_FsxfUArt_cd6VzOy;c?o-Pi40O3|fOKK#ZXo|PdfekW8 zk0c1WcOHbrf+h!sS(=Aw15>&9@#>16lSvQ<>dQX7I*jSaL9*Sn?A&{aVdnV#4h8vS zOD7Q%erGTL_t^&)k<~@z>{L56+Sey$v(y;vOj`S+0dOp= zwDWk|)ms?mtD$%b@OgX#8;yyZ+oeG~*&slfcyLC9hO9Q;2`6ehyYXRaaRKg&0tTZR zOcr+Rk(7tU{4pni5#mDj-!AEO8MWKRNQ1_{K9+os5D!xm{Vy5;)GF}obwEKm(b(|t zzLQ=j6MEn$%1)exHy?wXo#e9?+)qZTx|wc%2Zb zq)h_$@@i$3b8G=*FTv9DwjZpqmuMOXJ^10MFNLMJ6c&}pfdNq=P>4Y?b|9+9=%hh+ zp^M&$0ye4$>bI2<>tYL(+1WCorlO=I6%fdZoHaoa-yI+fXEPt`i+aJpN#$=)YKR35*e4KXj^C0Y<;F2@yrEo5W}(o2ATb{Ui9M zHh8=Wt1`w~Z3(8cH?Fx`MDD=|`Quc7K$oB8Fg zVX5uOxKF;ZLuFOVed5mV`h1wuo#!Lk;Hv8zsvaNlklNLl-=s*U$lLSV!_rV(U1ydT#%!sPSg(bh`E8f4zQOJe&OdnkS5b6(Y`#DV(1|8zh ziVbWqCemkgeC7NrFyT!mQiq1WF>}4A`6Gnzu71kum%JEZ-`o7nt*yBnTyZtG%s(Y& zD0zK1&6ahMa4s}i?kPy;&rWQx=?Rra7VvGxbAQ~G&ECl_7RhjL$Sqj$&>M+_!=~Ub zVSblTP~f^EyE1Aq`V;zyhKror7hQy!Igp)_7~++3{A1A1z+S7JzAGYp0o4jwx~{L! zl`8iwe<>P^09@+9WVIs>XlU}a zgfs~noIDE#`X|Ad$B9#K|Cb9rSsxj3A@gJCvZ`+<)aakO->ghY{54Gw<1eQ_3S#BxcWBEC5ZTSUe!wJd0MDu21`Fl6$! zd(=ht>D%#^pluk7mwrs6!P1!5-ypFAjl;V7?}Gvls>`Y`LOM5k2Zoz&)H{1HW0%8| z?x8$xOR5xY_Awjq>L=IE<7^~at+=@t`fUb>nOi1_e{oH-?(7lmI6Q=Fy z5)5r=p2yw#=@Nxz?4nMk5xG@gTtSZ5{qy{YsfbPk9}Y=-4cVIG+PiBH8{bNZtr#NvSR1Sig|Y#1||Xc~7|g8$CVmunMIM)efsms^JWiKO=@3C^dJ8Ig|X7sKEv za>d~1=e^Cv3fVMd!cWJ&3y*YS#b=D{+a%$UpGyPEAtMu$0siyKcQ zY2PLYYqHQoTf#fVD5&2EbaMAIb`bCd!WEeE&$|~R+xsg>qJ4H5KAkx8O0*9CyUIV!!RTb5_s0@ryF-jI5<7ms<%A6p) zx)9?0+}Ehu3BKCB^Gn*|TcW$DR6)VX(e*kxM(?xzF|_65-k{f6Ns8khWPmizoC=5J z|4QRCrhzL*KjhC$u#MrHT*&f58r%Ql%#Aa;_UTtvl87wotl7FnYZ79xR<7>?=MEBw-{2?H zUVUYGq94+~tcncuwLlUEN|-~}xiFbxsB7*8nC5)>y$y~A78xAR9OU-rv^bJ6(N|@i zn(1Mp5Fm{gyX5OFOSQP;70d(WclO=o@he%5GZJ^30nb37!S2`On12jI;F++H`8UFv z1Z4&|z@%JrkD5^ZJw|Dm8m^`ckWj(BZyY3?KS3I;`?K#xR%`u;dk%MYs$UnDIYL|Q zV9Q7BVaCK&+0YxjJI=$M`S84e-{T=c%f%W-h0ED3c4Uqz`Z6(I*KP0;Cx_Ion) z^IZEfp{1Jf`>z<@{h8}$A>6uCqvDP&1Ui~|{nqv=n>3yCu_=0jy%F9H5+qTi5anjh0or!JRnAqkw?fu-(^B&)y{Foy%*WTA&d*NK? zT5I;Na>tp0%CB6PQA|cC6vH}Rrj@X8fEtb%e#YaE-I?p~3Wk8pp=Ayg;)R*2+y)^L z@g4}CilA0%7Z@r(cSR1D&sVt(~!4Z+1ot#prfBS45m^`CaI91YCFrcY_Z+Q?+pxLw5z*V979PYqoRDlDdS;q_z4Jg= zW<5B+EALw??j)@|p_&8P$Ts_d-nbQ6$$u5tf8K>MSq^6zDLPD)T6!FHNC+9P^k^*1 z|3ya)J~r(XVq_PtRy7lWV2TSj2&3^=)a?EygiO9GIbZK_Qz4E0W$5p))UsIAdDxhTv%(s`qbp#%nk!PvX!({=6io7JQA}-ROE#Q&mL5_vRyubs<9)@V zUqeG(jhMADf_d4+_470`@|?rth(M-+i4VT4bgsxYHMm&BPmMDzRrD-cAZRba!{9KVOARC(7y{~AbYjz_1pjFE zcobilKRWNOBRFf>%QwWahSt&t5ug?_eMQvvs8gW0v!IPRFa!@JkiGlqf6B#95fsj! zH7orad;6n*q)|B)sjWm~C##f{+ssEl{^h?D>DQkhkm5@epW%h;F}Ax)plh00{?GCL zeLrA4)WEwnMl(xpx4vJ;_1lUQncceCX^~+m&|wjpQ4NK!Is-^&U!jo8AuXz(eyTcG z3F*c}($(qtT16rxkWh-o%m#r`3=E-v;J6BXNf9!6PqiQ%E_Kc@tkt%@>dRM-w|BM! zwNT)0DMNj(;O4q7iVLCYwyNG4yQj~_V6)-PtmwQsZ}hxW1}hN_}YS)9DL^N8m@~6indM z{Jq72r*p%%Io&j;rb?9YWOCx1vh7YgS>oy6a%qv9pCX&@xYsK>4}YAIvYp{oHq&KU zQo$DS^Znzqkbp9G!VtT=H?i2C{$2RRXA#>R|o+&opLze*^6ZX(oT1ZXk5;e`(toYep+FT9mV*n6K04`cPU+O{WJSVn^vHR zALNxv8Tp(9taR;MRymupb9n;!zKe=Z~Rj=%Vt}7G6LkJ<)HvGAxFyp*@ML9G#cpKI7TCC-`MWpFZTwG^{XKTjG@A`GoP2 zdToaNovrKwGDhWbQZxQH%2`T&sUULWQ(rNXZ#lUdBLyY5lAk`Skesz~j$teRH_;>l z-5 z6B0<{;GW2MsliY*ApVtE(0gIx|Kkx3jFkvgq|cqd9FO#6FqBR3I^T(l_p`zRGy2{= zxg;wf8AFBrKv*jn@3$=z4q_i-JDxZU>VX~CBGiMTKp}|cTCvMe*g_H^jegELY%4M8 zsbuu6@GMvI-T1?*6+%683r>wlMUS(`LkcL^aPJ?Kr2jpVPVPUl75(v(wgkkv&%Ljk zO^@P5U*!Vxb~y*;pM`F|z!f9QKh*7_rhIUL4q}R_JVd9T%AxK4X*`j!0mb1V_tB2$ zghits4gM($;ohix?&uXJOpPXVzWk0OWBI>v!XNqT=K)u>bktV}QdF&(ZTQ`;JwDV= zQ6ctKOV?X^e$&a0Ey$cRp<=!As=avQ8lhYYnXHGx?W&6wlvi@0_vGbz zJ9&aywflyY|3PSU*@ff8o3QlDMig8ynLd{oo2rB1hTCrl=pyft?yE@tX;xd8#jyQ+ z(f?iokkSWjc{Id>2^>7I1RFVku*u*}B@qVz)@m+?|98&@Xf$7~yWT>$r_8O0rkt{q z->^R<&Y)At;;{Kh_0oMUj@>+t=s-Hm3km-d{RDm8ZElF^Gw8qH@Qr2$Jb)!7d2`pS zR%i`=bmZh+yH)=CtN&iY&IgiN1u#FA5hR*hL&ShRge)@yA$_Z{Sp}5|{!@@i;Z#17fzV!Q5oz<90fT zQvxiLB_BC_$l$9vh3za6!~!L%G^5Ohp5daOH-ZXWjnuycP;2`)(ffcC>H7VNp?}_b zmxP2GCgTwMdHQ^&4GP_nc>Pyur2ZHja!TnPsm#u|fHAk{n?RZ+^X^n+gv2wh%{_AA zo=f&;DQ_kf9v8TiN*~;76BEcO zK*+Scry(cNvl>N_#KHQ|kjkvj`FlZ0wa5 zxM`%^2!d#KuP<7C`QXvFRI>Lz{Vzhkhy^*0uRD^{*kPS_Z4(#vdpnbuA!M1pnBA0z zDZL$d?FFCP?5~6fcsOeeF0co+RQM5~-kyd6o6g(ioK`gLOU<#Js07y;z2PQ&oHl68 zIxgt$2sWS^LOwiGH=RYaPSUMJ60Hqp!L?t^$3)}CWV{jaTj+%L+4xN@N3O}+>W^&2 zPK-49+IqtJL)2l)OakpZ_0H;0xipnt`x? za$}4Lht{>lLp}5njx-J`%ksieaX~98&DvMgvx}+{LrJ0->i&%a*H!B$*e|{9H58;o z#OC_f^Sm$d7%TVfTHl&*oi{qb#HA~;Z^pwzjdg-kPBgn}uC11)ps<{ek6nO_=4vd= z1TL*3;kV8#Lx1s#ep2u<0C;r4fYLV)r06jdwSg_X!QD$~k&94afk$c+uIJ9vDLgdX zLLBb0swJz<>w!1yTB2wyQPG{y<4wd(v6c5Rf7eUxXZA^=NRhOr-)^llAxb`c8k(9) zOiu_Z-V7=`g?z0{Lzdo_lmQT+bj?|J1o^`~U}IZiNnzJW%W?gQDL5cr3p?6+?xADi ztncSHUx_cWgl?QeVJBMt`ybdPZc`_@AS${O7FFI*XH~gKOqWY#t2u1O8!D+@9FN6$ z98B1I;ksSji8m8oCw8tsPHa8z|Fo~MhfPbzC&m0cX+-O{WYPUoT31rsnSEbT+kWVT zsO;nW+bMCL(gkTt}zb z$p)ZHW7k)A{GuTwOZaTk#Z3BmT zb>s@Hna@+Jzl{P;)K0Oy?DttQoUQzaEJOkv_ER*M>=sgg!+dul6b=1F^sDCKjdX4< z$?fovJ7-e9XIoPCX@#7e9DOjh3z+Q_l2S*~+uwhCzjR_!eB(SA-BHqE&2Sop^}D)` zswNl|*-eq=9LUG9@C?H-y;*_Q2dB4QW!#LC z{j5|zUce(I^a@O&^Z zDz@b6G^>eLyH~@(!6fZtJl?ijE5+%RkRjc?)>B%@-MjESpxf}&p^`GH5T9Me2O~n= zu(IxbS`he|i6bzzy(%N%rU?U5VQ} zq@|QE1p=GAJHfKIQhW)(e7WDcv9;1ptu#s6lQ^Utm+kymeBTjR)G@2~*@i6uM%-dK z5~#C^ymGT7<3crG!@Ze~&7I@?Lw04;-bsK7-tD=amnky?G|F(X*^wGF5K>uJH@2#Z zMWz5~LsDDYYt&%7F%HVqM?@f`$Wc|{M`C;8pL0Vo=fCQn_#k`MF^f6!Ae8)|U&~5U z62;RV@{Ds3_;V zO6W_Qm{F{FQ3~@y-+Y^5)$=ZJ^4RmTn;Vs6;)a>yyNj5LAmrtIffB;A&B;hGX-1$l zX_QzP=|^qGcC+~1t(7mof0fCHswZGQ2Hv+Br?Pv#y55s9(qq)1;WsP*!fVoI4s2M( zCW!)bk{{ttvqI6XzryjWOu9?KDU;V~Mq(YJTQRwLOSt&9?ND0Ly%7^IuZ6BgSx$Ho z8j5z|ZwLhY?roqthvH5DAm~K^24tER(7>F$H{|fbSL}btr~<_9JPuS-9EZM|c((Kl zE#5)sY~14TiN%nJ5P-Gz1gIu%mJt$n7FQc+47d3ZX1S;(?kAW2L=PFFS=J3z)Om(U z4&j;2WXWy#8cfLFKq^23Gt7e9FxL?TX3z2=i5;f+xn=ve((Sx~!+}_3dtDulX2(*9 z;(I;x-M-t`J)!p}9b(doh;9(D-96+@p^g#|v~B|In=HTPlp<`ru~o$PQ6`1a zQPf_iq{iU$gT}>0pScgXTpo63se?njEp4Cv_=-EBerlrwqoZgif{QS43xahT^ty(!mUMSQ3XNfi`4Fk~eJ@%kSa(mqDqc$SL3vXJa{|Sh{ zuipq-+ga5Sba?W7^!LxbuJMQY=e|LMYvM<^3IrwVj43&uB2RK<29X+ZlEG3_|IJta zyvQWSZrrHBD#I=!&o|-Md8&hlM`TB%h2k)NzI?s>yqJ(oLT`}sv~4TgJ5EP(8$pl{ zt2U)kMNHh$jt;y0D5KrG3^P14^+2_GdQUZB)WAo80?VL^f0Q;mn1R7x_}#L;zP$$O zUoL=#{mp^0TsjvrhybKi^7YTKT@Y`B1P$)V+Eih@riN`alOJ2`S5?QW%E>G@2RW<0 zmE&#yp4ig+)LjSp#v4q_T`!5cM=I75|HskJqV@&! zF#i>r&{EL1gfmf{8K4;t@{7|Uaa_h0}@}T;(fgeMzB>avyXqLUR*(t~qUi%T;0B|c zAcZ@ggtwm7dsNnZlHL`aMr8Hp!S|QZdP(uy=TUG7*TT?DbI?Ocx&mRqH_huWRS9gQ`t=%voQq)1>xY~MNLhqKMyP9efkolUbYk8 z!h&W#rT(DYPmE53&}Tk}VnyeRby!ot<6R2Z+QAD^#)lTZl?ob#4DqZrXQ7Vai+19| z9}yWjHT@;V#*;8vN06A^#DtVXHAcY@-l{5hWfC!REhwt0FNLU@09Rj@1S{%A6ybLj zvl#I0>At$`jFAaqKA&BDa7Pp!2R2;<^_wj+MBlHJkL@Vx@nz^tifwRM?pfWpeAf(| zUK62`9f3UT?kZu<*V?2sK>S*jiUWrJ{T=xMd4{zXR9H9%Ifr;FsR}3rg#yZ z^IR&(RHyIo$?FT@x?5v6bGz@0HWt>N)(Z(@M-+wrpFpCM2K|8VjYnY?_2VJY1y0R( z=3q;aqP@jux0hZH0nc--Caibb=aY#CB^T_h7A}~I72WQq9Y0C~+^lwf#MjuE6okv8 z8P6On@ayw;&Up!qDGiN)tT4FQwoBd%#CfjIh!mWL0e(dr>7z~dz+I#9k+d{CCc1zE zPd$Z+kJJiw3KN~3jg^tqFu%NahvGen)Ov4H7<0-6=Q&UqJ3N8uh zuO!(Z8u^cegyw@u5T(nmhC%+U&Hef*@00q`YRQ)(GC{%2XXSH`{efrXE=2uz{tdxU zgCSTYU*b@T5?5d-{fNel4-}(Km)Ip_llxv^rMAue+?w^Ea4r6q1QT-F{@R42zUccd zvvV=22aDOV@thiV;(Za!pbxN4(PE4I7@O*nGHH|{I)>t{Egwl|Mp^2I;xHTVI$E~W z8?S4nDgdy)?^oPryTtzLh>Mnnab(&MNxzUB^r3pac#lq=d4NdS)FNp{@I-G@h;b3x z8|#9lKt4MB2()q}X*Z=h*RJc63Ts+%ogtJAR-bV71V^QHA0*6g@@O)raWL?DoV0m|S4tVHQ&BlY?*!eIg~_~tuGRWqgJD`xh6Vh37KouLc>YzLI6?F~ zXvFam`3FO0R=>OE*_p)-;5x;>zkhTnIhF?UMl)MA;d{6XA`yx?9Xr_tmFRIov^#&0 zakiI<8wUopjv;S~!xc0!vmIx^Y}}QO@{?pwftw|UA%_R5k#w~M;VaE(1k^ML++5)2 z$l2u-O~DwJ;d~Cp_%tJyvyiI1F(2TkL?m(K#*poT?^E@lutC)xq+;v+jI=yPJ(a5> zp0Vsd|LTx`U3oW>i?;(VQ^+aC^n;v%0?GuL*gDN6OpNh>HeRG8JxZqJzHaWepS-G% zODx_ju$-JQvgifJ`RF4WZBTK;snkx1PNJ`+w2B(meU@;BKP4q)u{o{SYJ^TcBa#%3 zFj4>*|7X<0s`DNP3aAN@{`|wRaNIXO{g{cGE0wyVVG@KHazkYvD-*r(8%i0OaM7R5 z@Y?-Yb+@Ye4rWY+(&d{+Zd|tn(k8PSatODtuMSPl+F@_rx99fb@&!B)tl(cJm8N2L z24d{aAAKOiLyHGu#g%jC z(f4M~*wxvtp#k@z)6gA~AVY!Prilx^>n?h-=QXIQNc<%+KtuFtR!WxH^GM=`wQv7U zIroE3(P2fe0==F z3eEUQt(YaDpn$ULzze)_;?q*kM~S2}E^(C1eKSSi@wT;cL)p^b(#bz~cw zi_ztOc06`?Bd9kO%C6#IKNpaVG__^5n0!x*H)pKIw&Nl987F0Wind2*WBCPx?i(~q zfATNW?;k!GFIBDyoi5;^l37V2?vAMsMrrzGm%rS`*)yz}iEC2c&9(=`siC*H<*w56sDTLW%Q~uo6Xf-s7kV!90g~-ff`Qwu_{p$gpnh$BBYVr{x}k;_Pz|XzS^Ay_mbzDqa1)w&Tn-NF7uRtFDse z%#`>#Bw3T+_>(|^;$r4rZ0a{C{*4GFPpnZ@a*Mg5Upw_;7#1+Pa0eO$VUh6SUIs{C zt+mY-%OpsIA;7y?;2u8|(Vf*VsljE*#VT21Q2_00vzACl7)9(-FgOcN%_>;^nQH@> zYeh+FMG4?!5(R>2AX)fLDASzxXi8}JrgJaVP+WyNf!Ceb7hnKL_+L{G>htMt$v4$rnQu;r`v#v(Cb+?$}l)GAn$J zm)lcosG)5_X+t@vY=70iHwADn;@WNNbuB$8A=>0UM*g~1-eBe4^J%v9^VGa%VAZE~ zwNxMOhNM?S>y;nqbf3}SbRf)Ga6+*w8mvVe+eta2ZB*KdxjZeCqBcB~{`AJ86*p!Pi>?_a zQzL+Z3WX)(6Z)Wh`3p`qLF9u)C|hp`=Fq*q^j`X4#3L#8BMx2kj)gGam%JKY;f+VS z@AuQ3Egn^j(0iduO6`bKU59ErdxG9OS=>{FB|VvzKIfPIk$06QRst8OauKPhppjJk zr5j*T24)tIG<=hO(>rrYVFo+{#Lq9rFLHM}2aK7MnzJ%8(PCa293M>R&@-&WT&^r; zZ!^SV=VPJ{w0h~N$i=e4?A#rE%s` zBcYZU{S*Y7i$L)}j7~LQuD}Sq-)KP%2Af&U?^ME~x);=1s3Q@*J5x~`o>+*?Exhl1 zTi;Olq{I=R;sA0RA*;8w4kCxFLQ7|&BKQbV2)>Btwerwfe>61uQ@UaP2^y zBA37`tK9-&TnG2!uTKgJ)LY?qM~C-Rnn2^jT>+mLo2nNY1%>?!BlHZcNa)e{ zp=o5kW3QUDEC!22UKZ^yn|RSu1VUa-8>GWF+kAwj#t9qR%8gi{Txul;)Hn3Oz$*mO+71j}lLEln}-U7@4L1y+?0DEXpZ(3DZ=+)U_jH z5QfkOKF(OwS;TW_2k1%i3=fxrMUNO_FwHFQou=?{A`3n-eZ{^LW5QF}##Rl*)i?L( z4JyoSX@J;AxmUnW$RV6Dq3kl7+Pnxs$&XZR9^KurDR4%_dZQsy0U!-1Bz6uTX~>MC z!SIkEe(0RF+{vX%_>jv&?}HnmiIRIzh2WBhRt3LVb=B2~*yS3g7YIG0Dnk+vuiSze zhW$irzi3< z9Zo1_8@}dLAXF_!S6zT>dX1(Ez#@p!#C$uIzQ+AXfXADkY)A755BK3- z5J#`(Hn+M6Cw`cs5|Ha_YHKvj7m3i$g_)Z_BS2ToO3*nw=cP6Z%Im3;DdB))5stvh zruV-EZ3dz`T9IOen-nXIpxK;6F5eV8Ves+E*N15=uewHCZ{31OTzM^hZg?%7bWn=y zhM&FY0(RqR=qsR{&NjZFEymD(Sp=m@X0dQdF_EGz>X+r=WVy+>7|<~}IjdZPS~!O& zPM$kfEGKh{i}3_XkioYEa9XTcTrTxz;PmGr;)GQO^B=)MhsfnSjg0=3y3>Ow!yY60 zp`Qx22t<q;=z?a4Oz6JJG05v4wTq6~t$ZwVr` z05!nQ&1;0Gj{Uwh%7tuIp&SMmv!zm30~@?(YViF#_Wb}6lYylXe(Tm)4JFF}^|PY{ zm)@TC5DV_;VskZ|0W=!H*gUPINK>4rh`+X>Ju9gUoT9X|HYHL8X&}Qn|4Dr#xuwqs zITP~F5f)w87h7>^Byk#~aVz>${Cd;N@uS{C3I5mtxUeM@Xp((8wiRdhK{ zvVtJEpRnMH!hAzR?(P}B8h;qAZ|Dben!K>4+JPwd0$#mEUA))bm#v{ij`jSE?G_w_ zZuspLfQ9fI;}2OPP{!K~gL#D{EGBd*I}^@^3KObH@RECii;iDUmpQk+RTbI!#1Qru zGk)NO4JyG0bvr7^7p6#B9IXt4c&&bbb_lLo{odk%oN;1<8Fi<_nIMYWR?=pgC zl*jKg*YU80`eVbFnx(^p*neDjKez|6&EAED+!3w}Bf4D21@hXBO#QxJzOSeej@kW! zfjb2nE}KKXkr$mGW&LXv#)XZ3?lgB4+nus6kk+2i3p7wdCehKn;c&z%jaS_UnZ{>*Hk!qa5NPG!kf{cz^5d(h<4n!1J;0x7Uah=LP+ z=3LFAqN?bB$dZawbrpiuz`Z07)+xu(>-g4?r<`f zpv@ItZ~ILZyb`d@rN#Qnr*JOww&bl6u5+v}((RSLHHf6`XD3OJE1rN(%nO}c%YCMp zc-~vGvx45M>t|}yys`6@vGg;C>)dw#v#LkpWkFtP3D|)A?@n~Muw|9Ylgx={w$Z%N zXXyJ}oK`&>#O{bv&TsoyTlG&|YjN;2*Z=1|_`P_2@b;ls<+aI^XAsXl2D8h+>Us^E8(Plq}A_gBxZz zw|{r7;NmYQdOu$V7m9uEFmFiVF}>dmKNUb+=zWW=btO=IcRgjJ=O&)$5)Weh$UC)Q zpwg`cB?HU%u;?ivIRpPQihQEUrcVqGxkf6dB!4_V%< z+|x-JlM3ro(R)zoKErreYw%vdBJlCV#~N#ey%(-Qz>`O9Y4vPc7$0{jzO65wCxD=G z%tj&L&YOD$1}@qFiGuX{EJsZ~mbd-d5L*hQAHD1YUN)JTDJ}%hTI>mhrix#rHErxn zydRXQ@7zOx&n_(NT>oB|R8vA)_q-BRfYvnq{++v}wI%1sN+hxpqoGP{oXaGey0zTP zMcXm^vz-$?I&FFgm?I5D^p+A%E*c4Hkbp*vb?964Sgtl&x`F+5fUwx_1@Yf!lCjm8 ze3r0C^9mgJ<2RB)?9q6~Y~? zx%LACznwJGbfWOciG@LlqOlZFdddV+hoF&-KbD&R?xr2!GPCFnt1-4mC19m42GvIp zsxG>zszLLO(+&Yp-QG~P!G4}(j{*0*J0k$+iYJpQtV9AVK5oER%fXZ+a(O1PSrrQz}J30qR|L3sTT{tTmI#?4q7(NiU zo*TdF;@5GUh7OAN)n^u8v$8M7b||X(Z@8X{CtKzJ0&{}!-2h^zAj-$w9-HLaDd%I(QHB{79l z&$<%U*7uns-+z?|MEooYNO<5r+PVJ$FSQQ7gDmO_bEKzLeiy35k1fK zqT(x7ZEK4gIjucPZAMSx;xCx`x2ybdyOi3e$GXDs!5kQkm2YE`YNYb4A0V<%y`W9X zz#DaMQwFwzF+=ThEvU(oN}4>jDv0&~%lB9strm8`<@c+UO4Yfw0Oq^)Alm9BwKG!r zh5>k~#p>J10kgxB-tt*`R?i4i=4)zxooynQ$El=_8@`X8GQ+9$T?v~5{5k>ai_yB} zp3@0%3*&%~NN+Fqe4XN^jSA6D%cOSH#pXco3?uSW#2*t5}MbwtGKd!G@vCRJ9P!9@vJ^LPQ zcP`E6kYJ!r7WOOhC2F;~=RS~*a1Dgd1Z#5u$)G3BC6X<_l#+}Yb`lpnBmGZ-9?~vm zjX3(OPCcc<$BR}>0oAqoM#C>Sl!?%!kEH`7@JAyF4}FDvFUM;L!W=i@Z%1de4_kBa zKCyY=f1{~zvCj1;Mie3+smGC3(et8Dn$ECADNJ z7EaEj^o6;hq1_b7St}D|W)ulYNm6!pN15T}k>{(txqsQAB!AoiP!z~A1@HDW^$Apv z;j?f4hi0C^46d4Y{pg$cP_aKup9^}Mv@%hsoBc;=k$Q0C9eRzVs1|5HBkClm%HSX1Dj1YQp)sDTnZt#vS<&zLy; z1Km&E&d&R^TE6@4BdA2!uSC-}ouvU}#M0GKzil-tVcT9yj~SDf$)$xB^Ky%npU~TW z`MMmv@U9(GgAl!ebOsx=*6L{fEFa82U?%gS#~syJWv2;>_LMeA%EsVz$ZeA7R1xRs(=@Ms5e7^3l^K z!8H|+r`sMxGS#h&PI6-8Ql68mMZZbYJz00+5XM!V_(1hfKJga6dvP)GRw z0mk{%7?Ry%T^=s24oa*#QS*8|&^p6$Mz>Ny4@ACRb@s%o0S57>AAt1Wf1ZK^YNz<) z`a?z#D6y5nV;|t?00RR+5EpaEXA&Yalrd&EQUiho>j+qk63gDG$%$vDaB*)pDMdP}1kVF<$Q{CkpC& zLDE42WOsLWJuYc!X;j?x>FIzx=~xE^?E;nXlM^eM0&iW8_FG;|R@gvluJsd#7-H1l zA1_-jZt-rNklpytD}l3X@3Eki-0b|k7z37LE~tx>-onXVTl9kE=-T7lq0_2o%#_*g z`pDvQw(z+iKu1&V9W)wia%Ki{AI#BPH;d+6Fz?aVpiRdRCeZ&m%3uMrm1|X7(aQS7 z(Q4=i<*Mm{o(=F>Xn%H~lK#$p7=X@>Qf)dxRCSJI<>*5RCwlZR7r<37`}H4A zT|WZ2qT+nbg#Ddq^|I1JzSMsHVzmL=63BG{aW872I5ZI7o>W+`VqBvZ`;$ftsz4Z- ziD~fNp&gIjLHUk_i^Z{GjM}*x5ly6wWbaLVoV2M3NwR%m7SCMxZ-8ZIyw_ZqylyKU zN=K6*;pbqpUOqDt^nWi4ivtLmvt^6M7~*xPB*!aRI0j9%ipHc@^;^rZ0yQIXcjq-3 z&wzIcOkC5_ZnPnECHLbM10ky^UoQUi-!P0ntsS%Ca`Z@M){XJ=19Nh6vh&y<&m0*- z=8ECGH8`grxvnPa#1{?$y~eJcifdPvU>LsY9OSRRE;zTnBpNuMGv{zjmuH7g+| zCZ^2i&!7=#5TFF^`3PQgNV+Ro+kMpjyZ@y}boG7Y^t6gxCLbn9a95psh<70s zsA+g5!CJ2op>xwEt66Axhhcqj3nl|+?1ip^qajI0!>q3P%n=9oiNr`|^Hs}~ZHOXu z2!VCv+)Jn@gLlOH?AcQxgx7J*c>}nuah+%`>{N5S{`~&+S$G2?3(Lq<3=A9!P2|s? z;%5jfInS&6*PEjkL5-RhkpjGzu29;VfldEkHGaUst>K$~6ahO{Tb6W>XJ<_LVwl#?OXgtnoNo;M35rS&#-+(8J+tZas5}8Bz z?L`+ZcUWfcL-qaw=yV2}!_*hTiQ4t&B{o@x$U1S@dszOm1ZeS@nVHN^Q;-04@twa~ zt+VBvG+}Ml4b@aI$mr=VCpU}(zBYu)za434v}X`n4hcJ7w$Pk&YAkbZp0}---)a#9 z-h>$7_77dA8)}JBXYWfIbPNIGzm3<_vFq=|VGv=KxOzg6za&se`hL@#vmB|!_1vfj zE0Uj=Y!p24D5XCa1YVuzg1+RUa4N78>tiFz%EHQ8|7scQ?L)IQI^WATpd zLG|oAzkVM9%YN!TTItxjUIB!n`p-d#fcdvDPgdzez8;Ndc|28vM>ORd7vQ(KTc%}s z+y5+-+t_tl@L=Qr?oWD(;nR0|FTw^VrwsOV@DyU7C>3 zX>e$h!~NKd_}0rg)ICh-$l!^ROH0ga8QpBBbCp9|;%^{*+s7;wWhfBmj&I!Gj& zeD2D|&)8Zk{t#?2b1oHp_sYDN$ya$ozCrU^R?lb8(@ZA$eWW28GH|wLzz*8^Ag>Tx zCtu3{>=(hwCM;^^Wax2+D-oCOocZ>HO%3e7PoDJx56BRn=B)wKb#SPeY0ow0(oiZS zOR%=p_Fo2o<_0;p_zBu=`prO>d!yU#ge)0>gW(H&4u9kSIEij84DP=7q!qTS$rKE%#d#8?Z~ z8XapbNTJr53IDHd63ID3R8uX2UW2)_+=Jrdwv{b&%Igqz7=};L;BLY?AYd!5htZk; z434c;OqB^sn}1D`ImTa+VMxo@V4FAX(yn=E_|14A1R1}~cmf^aY*BGc!&x=2Fj!Px zv6TM^Tl>q^NaTsB z?v2JpC!p<4E}0TIh zMvkp-aO$OgbMbc9bu4(5Pjn$Vb#qx;>Zwe95}0eS99?Lx>2OCpbAyP!vjWbs(YFU? z0FRby?j=TYYC{PJe83E}{T2%DiFC)4v{f~Kvp)L{v$?eUBI)m#te}Q6Oq!odCX?DE zKnu3FR#qI^(-oB$72osf3j9nD=r^KK;%t_a7UH7PI;mj6f5DYG zG&Fm7vg2S}NCyn<85VkqR`9wn7~jQ0X;(^OM_(kR*6fD?X8>sVC3=ska`c|uBj;zp}w&mH;hvh5%PO1r1Q76t!a?JZNYE z(dzA$g`W%cmw4CCHUR+v8N_~z?hW@p%F7vmuM_-kHqYN~mursu*g#H+)N$!-3+jDa z?A)KT?EmL15$(=an`hwdmOX<_Ys!a5m|92O&EJ_*J+**)(@%{BK5cQc~@BerM*$|EEvqPD4j}z?*REFO$V@xyV zOMQ!YQ0dDi3K%nyCP*R0=PG2Y@Hm}?%hT1I@zm^^Kx*?~^zh5@n9!NP`2HTBdXDLp z0=5va#ffU7p!RV>Uej4cPezjykduT5&Go&f9~^oQGrKxxKW5kI^r@S0akW*r?1Ac= z4NG{mF4vG&*`OR6`bYVS{%>~3`v4AXlAPf@DX4HtWI@x*KbxiGQ zOISVg7jOBy;L-}sYJ=cw=o0TonL-yPN;G)q+xZ-U-Iv-kS zB#q%h&oH$8{q1=iyBRC7ipj~E&N}lxC9+_yzUJ>iHUpS+u(8l+CjK}JO3Uu|0HKI% zdit3bb)Wk+*G$XtH>S#_?FfWdxE#0C`d4RbK!3!FrqW=|BDdAzCRD(Q20ovYSvbjE zb5jF@;l%nq!=TYXwMfG2WKUts#rl`k2D;yt$DAfzz1poVhaj(5qt+x^To2qv@%wp} zUM@7r>AUqYUmo@d^qmh*&7nRg_+oDjh^XKzfr< zqS6UXAhggGQ4mmi?>+S10tf<1@1cbbA%r3&lmOwyZ^oH%zWJQ@-+OCivF;7I=bT;6 zKEM6D`<{Ek1d>|(=1E-gQq=Ympq|QB3f(xW#oH$-&iox{{f4%9{fd%a?S6UXMOs%< zX=m9tVk#pC`ONBBI9fg>ARRsL}O z+ZHBy9%gF=mvKiwv#s102X1y%74bCfyBX+$8ylvR7lvPhy0v1q#Z!Vog%u0hBN-KC z`hj=_Y3tl{?|Tm3xRTEjLML)+;juxv1{+|Uve(s#J^2oZP6sn6V{7v3l-a$hp{@Q;_G7ZXNIW1%_wj?kUH zcIQDAxa+QQxA+f>JR|VgPtY~Wm4~rwk3jUq4Ll*Pwm(1m)C&_yBFW{AHixWVmhO4ePbJ0h#SjTpAWb=08V3!Y0{#A}z|E&K5G`lVEAV|_u zOlC;FlD*X43Ug7SPJ{Pk>1}#)jm*`%dt8PN-(WGA?fq6klX)|aK?~^(@`=Qnr;1;t zRxLu^*fw*crEqb}-Wr1~Q63L@B}-(AL|VaGZmqZJ5_@~KeuQ zRl*B`3r80{o*N1y4w~&LY!kejRCycN5xDv}l4^KJf)ch<#O_PnaaoxZ9ID2vv)7*h zMxIR?zKuL@YuqRuX5aXbT&*6kE*@B5(T8`P@ryaNf5L@7k1)!qa*uuO=!VAK*Tyif zB$aV8$;b(=0aW_3YE`zG?cT;nx{z={-S>D_sX1HkDz#5D%VpVZ6=NJ%tS9p!L{6eJg7No>jO5Q}~#*?(I?jMnVD@>>`yu385c02o4{yXpvpj5f}xSGU+VE z)=R;w?1VX37Hz#s*zvoJZ&#pw8?o6r={}PxX}tq2f@^#ABQJm^NxCM2q?f}ZY~m45 zRA`mB{a+cd#Wk{T#vJM5-WpnGX81ar+e5+Vymtl}gWa&! zRU|KcmDkW^Fxux8_PkHVYoB%XcAbxhpE^k?CsyeSy*BBe44{>X@a_0vSsZ4e z+ZAJ3XW2EqIZWm**GI4Jt2G*Z^JuOK6zIKv%vr_bISj)hbf~Fp42t56O~889teEZd zbF{(>e6H<_afW6o4|K*bHVfG#R?$o>(6#$cl0$EdBm`|jfBs=m^uDm6vIq+P! z%K^c+ez_2^TV;NXdppcwC|gvkF(BJYsR_`vdPmGS@M+iqV{h<64hEF|P(BSLJcG~j zz$EzU67-Ool+MxK`bdr%6S6-?HEA#g=$(gur7P#Xd+IU99(gUTts~87Rc=;R1v+87 zVIpe7RD!d_xf&VrBl@-ITiRq<~JW1fV{JJ9oU=6$P|}AcXV|V%Pq&u&aap&d@#L&nR#t9PZVlvPen5 ztnqprP1ja{8~5321t7sV7%W88(;jEIUuON3aFDb{aH$LN?74>c_eyhjUW0c?6 z(pyK#heX%1i&;sG0(tWRmR!e(8~lZyqnVz?|&Qfbd(si#o4-094zp z54ZWp;7=onr0QMP^A|e8&53T56`iD&w}_6H@CcQc!j@H(?Ny zKm0$ltx`I5|BT`(Pe%GJnN_28zgn${Z|!282PiL(gKhiWmZ9J%ffY%)K(dj|9Ya;E7Thmcu!4)$?U zM#J^-Vp(0&b=vk>a@G^PlaI+J*_Lw*cBc~P1lOu%cRD)76_6`qmu)3!)95ytpl|&* zEW+4O<9Zb?t`&Cn^>VyYm=O8nzDHzTO!A^8pfVTNmCP;5f`_N*Vx2)IB)agj>q_*- zo`h}DprmoGu&e8kM73T?iD-rUSNlG+`hq3N_kn5n;YoeliHffmSM{3*>%tLLwh2Xb zs~q6XX(Rk*^4~G`^>YFgyKy~|FK5(rtytRg|SMHwSB#MY6>9S#~(M3ShwA?P&%*(dUIm!Ke6Nko3I}JBKyq8TO1#TsRYt|}BTrezl2OGlqxM#a8 za?<>RozJrZkEmnXacB`3QY910xnE#*GpV;{2xmV;G0-Z}?}o4wDwM@9IG%XUXK8z> zD`|_5+s#r&RZZP#tmL`snPGoFeE4aqi|TtX76G!6N1IKX=bjl<*`O-Ec2-Ci=5TQ~xo%FY)>2)lbhI((!!GwE zh#eU)aHU!ksF#UISiH9Q9T$G1dOYp)G)e4rzT$$sY9D2CY1_JS#F2_U`|@v0>u+@H zD?*yUs0!1jXrK5DE=3vY%Hck{%`}aqc=)Gw-E76$&R+4Xp^yZQ%yE$~65S$MYw{{! zo}m0EpnM3^_aq|BDODfQGv|g6bV&xAHepj>z?Z7ntcQ`53HJf(tyT*HP9Cy zPL#u{mZ)mDKxKO#dzBkjg-|23vFrW@LN%sJNHW)gexR)Lg~acP%^yzr8_XGI_WQ6G z)Y!#{$?c)Ew*HQzG|NfWwL07VRQincv*@#h3T}VTbgq5RbgZdMy5;*!$Inw8lsBh? zZ%sn=c#XUdmsGC|SCu{?QmgW}NC^@*Sk5$i4sfkzmVfV1CeB&bWDCNSJ=Gn4o=l|!iejmD2ytKqd-o64q zvKb#bNY6E5S29DT9iL9>9x% z#S)Oc2Q)DqVN9-du*&;_oSNBY-V;v~#9TMD0f2a$ODddV;^KzXh7Nua0aj*!dK-ET zQe$jFSy@@)hOMoQW*2c~sa)Zu{|dE#0xo=R7ndlw^aKwfuHp2blWyjHKBmc5He=!*Jg*P%TtVC z=|z{}tR|}p@x%p*7Z#PHN?krGSBN)wwAnXX8ri6XG_6ZKe1`x&}?~PC5)C01~L4ElmZgTsqc&Hq=fop{J!n zI-d-6(YXBcrGF7-o$BTn{rWzpN`*6iPF&9r4bu*-WW7%#ku{b<-(%FD=K1N!&*_fz zhaGwu%}e->$^7uEX}%YvZoP=kB0~3X6Xnm-VI2ZueJIo-+U3@Nhx)%H4>#2nh%Pve z4qR6*|Ebge9!)Ovd*=Q>vyi`Zt%2v(z`LIZx&D_#zc;>`e@3Ra&cob_`hThHcjbY# zeQ#PYNR$eY{`atcOCNsIo?jgY9&i^W>rea*DgRvs(hQV%Qz)o$_58_F{bo3g%|0Wa|IbVt8SY2B{U0&cV^7O%DyppOq)QPW8=IO&>pML{G-v z->&v9!MhG1T|2bQ~AE{SK{N@*{4zQ~lWb~rT1e%{}#F@9iv~rB> zk7@NEK~j4!3RtS!TvA16SMBOLHtE-qgMMm^;9O$St4^<`xEZ6ugdQ)g)jO{M&RQXf z3B!CF+E;(4ihs13n?q=JURdJZl)c9tx4%&gYzC=oM?JUksLwAzI3@Y+Ur6oWd`ulo zuptb!dwlUH2R%cmDSPE#q9UGpn7A{`kKYwlSIO4;0{CYe{rAOw6FllJdX=Lsw`F?g zKlRKPgTyXk{wB(Q%{jk#w%Lnz$x&kRDEIaHA|kvX(mUF{R#{9^X%XW*NnqYx7_0K% zboUQ^JKgC|l{stF&m~<55YQWHW)X#q`lOcop`DGrxpoS;n%!6GnTCs0-U5h$srVb5 zi5VOk_(kW>(Eg7{v%uNzxN^~Gcg-1wul;iCJkEqk;hWMH-XDgN_Tn5DV;}m*iwBoh?x9Go{p27F&_uY4(3K`i~VA^EmaT*+d<>l1^aZQtFL|7T|bt-D}RD8E~>_goS2XZd@NA;WX4(s!e=mclZkF=uh1dZEmFM#jBZme-J>hME3LhQa{C=$u zX+=LJGsk6mwNY#(gP=zzlK>`vLv!P5AuyppVkSmh`f1ZUk7L|<@cLapqDcmE4afR< z<(?16_5fX%TWc9 zuSRMGYZoT(yx(|Nr%bx9xNTGK(r64hefH6V(d|^{q^DCqA%CG(PM0#az{jErSNW-) zSOjpoXH)2~$5}Ax_qiU7Sqa1(TjvmoR&MF2)S@^-f+qoGIHJJLm(>fT`;tV#eV?AJ z`h`_`ufvtNr;A>g)fdN=RdZI+@%~GoVY{WC_e9l|ongdv>>gPewE;qz=X4$90k#=< z-}1ijeAY6JXtKuqSg-$kFVJprltEOQ(CW*Rry;A?G)-Hz6of42q@;A^p`75I!d8mq zyq6nSZQWTlQnF3i?s;a)&)h3E#)qQ(uNP^F6*}kZ+X1<#FXe_aYtn|tLe$$>bio!bIUn9=t7JY{DA#XKkX}k zCWTzP=3Q7VJ*?u6VnkrbN9GU7nORP-SIN;=>z?qc=w}T3?OPtUNLi{okrpuyx3Dt{ ztfO);qZnm@H09?5UK<_?!5d|81I(aY_3B|7x%CFHgW9|u%Rd#9*;M#M_e;MR1=u<( zdgDR*2X9x)mXdVjs7UzrDf(=b&pWs!6OC2ZcvF5yEP+CYjyX`jKG6|@b%2D7<$38Oj}cPFbN z@;dQbF8I`(bAh-B#EzLwNr@l4+lZ+#3`F;7YFx`~J zS|a^85jrYV@mB^x?3)X~EDElKdy)VTr$(Haep>kD1}Pw^*{4Z=mB_m1aa2lmJJniK z1gZujH5qn?hYYGWhx`kdl09!+u34h7E#;crE$kIBz~%r!Q%=FV#Xj956)*LylwJ&6 z(h<{LO(P2zT|FqW5LibFuOv$~5(y;TKX!*UO1)I)ToXM6K zuFXxhLU;LhDT?Q(-2r{}A^k(a!d3(RuDj1$UXd7Vmly*RGU&m>uba3A%9fOOTh{J+ zJP(SjGmVp!7?jUQb~C%gHl$Z6^EE z$BX=A{Ced%_o6O6^jJ4C9ksoY3vBaVywOMp32doq%oo|Dh%S{}yUY#5g+@2g6$2~3 z4h+_qP3UA&u(QGmqwK9wN_id48={TdGzbdJ>(QgNaJN_4a_&Xs#dfcDy1Hq$G8;uI z^z7enK6QvRTKCB_3*57wY;E0zIZZ1Um+$ZSv3~`4JfiiQiSY28pof)uzFVF~$g05R zSBTEP`1RVCI(orP)JKAqGPJ=bG@HuViZ+{36L%0L8KfqaTg<)nt+IY(U2qc>C?ErrK;MVw0!J-5bsf9)v`uD*MUSqTlG$-2AGQMdTk zgIAaZ~>YrzC4vx{5^rPgCa#x6#*zHMsA%%Nw5*YqT!%WR(JwV@)5;IKNMqbO2i`0<-psnaHR!o6$uyUgznKG?7ph+sI8= z35V+Gl0>7)v$rlVp@$2}mxecS!m4WI=v;}d7|SVA9EV2SlAra}YxCz$vG3z@2ZrD) z7(u#7z?H?w7WwxB=McqK*ST*%0;xhSebkNiDv*JzXrxe^gVIAXMCKKZm~Js_kvP7= z+{l##WSs8fXc1DTA6$BBb(*HcG{Rh;IM%&~9f!AE`cf9UEc9fAT}{_yt2qxG2f3pY zPNb@)*ozId*0^IAmv%P61@&wpw9fOH0@9OM$kpCKyhE$RRi$OvssEmwM+*Puh*@_` zPOn^$rKEb3L4~X<<1s)iLf8`3)wlA|;4+7U(Lkwk@LDVBFCnNOEw6)WJ+x3AGfx}-7{h7?8KA~FI22X0 z$5ji|+iz4VW<|0gUxTYBG?MB9^H4A8(B)4Hxy-BgoeF0>)EiqI+N$=p9D}EW5(=Bz zdPd)$--M&XvAgJu+ergeL8CodQz-xETHg6xT?ryL?#sJ|Ix{&A$9^QDc~2Dewnmm5 zaW!|irXJi=Y=IuS{@l8B@uEtcllt>&$=n2GroHmi8wsfU^NeJgW#%VVMOB_j1z9hB z21vlevdko;~RSo7F63xhs`2PyxbPjh3+2bp=&D z=Si|kZI`4h3}{L&W*1fr#_gEit>Z!D!&6*bW1vE|0@mB~5?*0hh8|(MG`U~sa&r5o zC8NEEC@2W&LsMd&P!Rri9xmzPV)crv^|6}fD6 zT5T1yGSJu^WFI%ABMiGzm_x0i9abV4v}T-1KE$`rTPmaahL0ls!)<+kV*`D?JnxoL z5gHMa-O`MvCF3k56cBV0^A#Yx?+vTiW8{|FJ@4+CXka=?d(bk}{$5aRC8jugb(wY9 z@*%I!TO8did(N}q!oJ*Am167NDHS|=rPJ>#Ka{njveA6OBCJ3o;zwd-{G!KQUp>7y zi}9`k4UOj8Fm&cH;_2UbmmjIp?}^m6j0<-*MGATu9*$(bWEQmSZ+3Un`>eLo4~Yoh z@#DTtAu^w;+wCP^XZPlIJvmpchFtWyx{jLNdS&*?UCP-C$760@$M>=z3NhEXJ0LZ> z{Tpd=Lb>C-;OSka{3duQH1T!(O@- zOMia-?Lcq`;V*4{#*dc0zeIjCNa@$3`aUha@r)(b@A>_INlft%hu~>w!JP(m&R@n& z{J6d`OMe(5zZCp0d5v_c`FAon4jBOWw^8~s;rsS}_VoR))5SA{f?9ZHyGNXNnB>>` zAvkw@;mYFf+13~TCQNP|o~8#ayQk^?I&r^nb5G-ZkF-w6k$3#O)~kxz98h;H4w zMTyAzvS;c@H8=Y+>-je?|9(2`{M`a4mo%jQZP56qG(VJIIM4fcto(QOBQ={8Zvm9W zTkOACK>8}aZ@CBmmayY3V1&1Tij?dy`M+5p2yX$dmQTN4hVhN$1~ubvG(*cEwR?BJ z=<~1${W>kfGl*s9#0gaUob)I4TqI`~5E>Mu$Q27{@%!$O_`r>~13j4oJ zFf7+BZz{^(U8j&%uky^^zfz7^ZigWiVI5BVeZrB>o=^X3nS8w4K{>wQ{>|&u3%~y` zD&f_?T2KdnV@g-&!+*+Wf8{`_fbT!#6h8lJyouLyK8Zk)HNnz^lx={ys&ao!n{cSd zql@>iw#94%!qNR4-0}O_;d^F^pOPpf?8@2=$Mrvj%*y<^B>mITYzOsNqZcHAbD+uR zlw@-O6uA0zvD*o?Ld`yr6utnx%*DwvJ8=~no6@7b)_LMMUgtGQA-1j>;_ewR7-ZX} z{43G$9j+!wV@w@AwC&xrFKQ9H881m~!sGR>Va(8+0@-Tux<0W*#?{7I1$WzG+AJNq zxYkb|Xeg%SC>9>EVe8nyWK}ObqpoIrN^85ULub5vmvheNT4lBVYeu7cdL}J*m&~ko zrY_dmKQCAgsns0{JokY6>r|7H;^xMnM!;%WN~n%0GS#07Ym9tJn-*(8{AJ~`&kd*< z5Hk=93FKHWbO*Rrgr#>7qlP}KQP2zO4^W?foHtpq2CEeHG+2Sh6k0WnHb8 zMf1>EX_`vu^QR30Qdd@>@BLeci{f}C`x_|oP8PpzoXHt!)c8Og#!zfbinQ9wHdSHb zlMbATOP@4nQGPzRI>Du~wPnw?{SGdO#D3EpT@o`I*I%%Ec|KvtFQ&l!o+Zs6}qeU4m%n;#HR&WptkDCCSG4{0YStSejUg7H?iHppa+g z|#8GQTa4z1ZF%uDXwpH z8sPJ4bYyqLP67nJJlO}8nnfAYX2_k2DH_o!)-Tv=cXzu3P9qc#A?MLm`pV7*NUp*Z zFm%HQ6fk;fQReU3CQ8sdiK}=tRD3BMG{gjUosus+YRT$99jkLtIq4v5Gvq=AKM1Mi z)V-J>55f{1RZ1Grdd@J%dmC8P+99$T0&PENDsG(9O{p~hUQG87tJm+}NuONJoxW)? zd9+|+Kioyf?L;M{8uI1xx1d6^uBY#pyQgfkQeklosnq*W*kyqP?a#(`;{-J zqx1?!-Ffy866exLB%`xi$HTD-5BwDJ%G<@OrA=&Nh98}xD+-^cH5wa3HB^0vMzhf0 zcp$3%HDAsZhcpchm?X!Xb$;ihg>J&#kTs?> zUwIIMOe!uaWp-t7&S-MiR#nVs@b1iKc%954I@F9^Rx`KES)kIn)z>`SLrt?~$RyaA zn(jtoUR2gP?K6$9&b3@OKtrVx6URDr59=;{NCYPddf|eDE_VU#)u_)Y63oRPPfP|W zj%V;nojwXi-eubpCTIJWQjD$&Zm2S&`sK=AiJfGrU1t#s6Rj6fwp|wM_Hm2nm>!)SDj*H*d zu)24Z)*JMp!YnU(T`8h$&vL8VKydZ+vz6=Clc5)FyRS^^qs`u4JA1Ige!Mj(v{7dZSQB|Tw?Iqpo`HX-(W=lQzzFz32e5Xg z;a^zCYQm9(ueG3z`J@fC9hix{<+k8b1vwow2bY)~n0 z7NC9_TXRyB7%&{#<8d;-37`;FQ0pHV|H|j;Qp|OB}_&Xj#y_&W^5LgP$7fbWwdqk#}{Vn^gcb zk<|NgxGXRmXH|wJHeIFjsn-uVdNPtoV-=6H@!tTl=IPh8i=PyT(e0!w#_w3hGbTuA znIzr^oE32E433}Tl_qeH5JX3x^|0Qfkn8K6*&I+1c*E7JS)u>SN|0e*KVp%hDg3i$ z$s?#K@%2+7m8%jHa5n-y^XQ>UD`{`)D#6AUo!n<}wqP?6lW^iA+VZjrFlC`uvT|I} z86t!IO3FmT4nq=46x2U_2JF%hp;^-RMyG_(CiIuk-=X&$AD_*$M^^Y^a7vzXpHp0~ zBpzI6Z6q`xOGI5S=tQ)K4CC+BBIjVT7;{GtrdpC6f=@C!WB96PfVsh0e~PtYMf?*A z)nQFbAsp1R74yeL50s58I(8=S`9zuit$gWkLy`8nk~@801pSK5_Sa5>hfF*8ikh8< zZOsS243hW`58UVzt#{wA|nC5H<7heS>pc!k*+)_#$(Dp zPTl}G#7{hiubi`ZR&+W4xOeTHwEMYyw~%P$mA}@2Nc;J6D#uMNQ#joFsWK#r+S2gQ zh_f;0XDI02dZ+CXM%^JJD5jEs4(Z{ooM4hRm z-DOc4rSHbK{`N9`mzH{hP#xQ1M}eZ5^(pgaMAbw7oVzPs$JVc%X;PoRDjLDS$<-|@ zHM2QUX$F|FXg1jKMg}dt`kP?HT1q70t5+2LkChBW25fm@g(%t1iQ4yNFgntPzJS`_v8fyF zj!$<7K3?V5e@SkfHR~w!8O)_D5<*BpZ<8Wb&AyRC&W4-+3fOB}7;a27i-hSXdmn7P z)l?PGL|?Y07_Gp+l;x-7#JWkk(#)~WR7sHNEUp!9i|H^N%)Y&~OJY$A3q+Cb7^`;j4xh+?(<(TNgaN-v5!a_22C8fjKg0hT*Gjv!fCWIj;R`E1Tx$|nq6UgTC zkf275m-SN$BZZ$UJy*32cB`Vx@$aPna zlc`A~BYmM_NFP`V8n*Z-Nwv+md^SMtcM#!VM-=44c;uaM&0L}&fl+CAjtMQlF;!LK zn5DD#U8TjWaV9C2O9p%Tf^zlLr^+ej(bXQ46x3cB@)C^?t$KMR1Ximv!27S$tc|8` zcTVw0HOINjTl6K4ezXr`!)V8el@k1QG7b~?ea|?Qbz4sFSlgFhkf?iB)c#tzvuhAL zUcHKY-4XRIq8eX}vtI^dV&y>X2;_m8GLmj%J0^ z5=o(0V%F>)bCBt}*~U!n2$NTOD{Iy$tb+sF*(+DBKuRc;{BY-Nl4hlaGu65CB>D4~ zos~?TJsx+Sc(!IJ#qu?ei`(L#aY~NP1vZJRgBTl>RL4rn;7?YCxFPn1ms2ij9;Ian zW~UhSA5|_#J@OjIl7yflvPYP*q3}YJ5rL5`-w0HvcJv-hPz@crr?LB5bpmD+u$Lbw zA3{@T>=MER$Z}`ea9yoqzONfBs5qeXG2RT7+tvVx-rJuO*}D)zw=uZ-Sh z=O$7DDkM}2kHUs*W!Gr8?`N@aS|QF)K(wt9OMsA|AP2tde6C!YE$tLW+e3=hO-Cw) z)2v{ac|$scxR&(mRB_KKPC7+&Gf0>Yhq=Ov^5kHS=>TI%f1)9BH@295nDel^8Yngkyo)G4C|PIBj|%1I&T zfw+L`$2e%k+73N9gtmBvCvKv_=A)zpZGKlryQM?y(GKjWTuY>idnwk;dqZn!Ga{-= zrAxPH)12f2ulEKY?a#J-v2W^rcO`4|JPP#{kBfov>1 zMg;gg3)?GS8}FVJv1S_t+ab7{Nt~w_^NaxzlUqZcW4*OwGJ*|$s)993Z(JAAUchE@ z+5yt%S;TWP^JEdi+TnwPF{M$6@pDMQ3%&gFknWx@x!f!l>8PDss^`alrf;SIJ?qec3ASqLlPEm|U z<4^9ICCGe;hH(>NCG^+;EbvX z?A5^zERfXa2F&P|{(YG%Etz(=R!>gkv8sRL(RiUxO4X8_jFC^@XzlR+ zC%uZ5N+Q5+wc=_*Qh`3HWOx_mV{}`V^4tPNle6Eo=wAF&ps!r%jcK5-Pv+vWP4=8~ zl|)J&?umfnV4W707{2}W0b?So?nMPbFqRV_ekvm2W5!u4#s`KoS9pnG8Xrt`WY`K4 zKPcq+v^v$JC($xe&ri^sZXH{#0t_6=>@?y(s$A=f{z#uCq8!8a9QUy2-9^3T zjugvkF-i8U*XTVWP=$L))BOiS0-l|dO0lO^*BIBh*42j7$@Dc-6oX*ZfkU6~`#eom zAoZ8u(2c?F&-sZ6No&P47H0auicns6;E+vflzjfOAu^c+?uTsSPvUt~m@wB;^yU?X zJJM9nI%D~BkM?ob(TL=-M%&XW4_rn4`U7rnCqF9gq_oNS+6r&ubQg&3vQ+)HD0&YG z9G({j!V8eb@SSSKA~2I>d3_461vE7UmOIilGa4@?$1aTm?7b{==6f6?b&z-sSNfliRY`<+6gj>KqAJ|{(ucBrww2KUB>=8y-h?o7ZPR(| zP$Q16SyC*j($;F9g;72w$IAhe43l$9& ztXVokhI^N(!({2@Ep`GSwp!d|8o9w)dU~fV`i5)cH=Olo0%_tARKNP1rTxQ#XazWe0$O}=3;ugn*S;6xwtoGfxX&`Q;%0u=5;<&!tRaot0J8m| zo!t6txOK^Oo2a_IiX!KI5XNV3C6CRux()}>TAc}GZK`g{F-`)%BPw$-V{dK0*|WJ_ zi}y+#K%X>5L1nPZWa^U@)C+xF%^MIhG7O=%GF;qfk-lOkF zi`WjG2k=@sD95iP-zY;Vs47ynUS9VPuelDN&%Xnc}dQ@&^wVu@`+5Odc zro74eZ%A6|gzVTR7&P|SOoWyDE{}BQPG-A4yy|c*PpB$Q%-m_W1QEGp@rHOTmhm@w zsA>yer%NQG+5EHz3%AT-P#TR9lj?66=iD7@rw?dEM_C~qQGq740VZy4d-fE$*=fnt zBRgxN?n)@h^u&+^;g7CE`8h)16*hJzHmf9}&hx8fXRLr(MRBK^zC^-dc;YJDh&JwY zJePOKf4JvsC})^nP^bsbyy3p!G^XVRO>bim`}$@pe6KNj1fP-VVXT+RzO!fZ%+g8K zz?7o0`#NVSJ|q=j3u!4NeQ`m+o0PG`T#Oo~22e&RevQ*v_?f{B?y^?{HKpI&h-z=yd$V zb`Q{Gz68iRF||?T=j}5#oBB-E)YQ3!V{Ar0#aZ;NnwnRYHF#fGnXdASui9l?X!p5T z@K*xgZ-P@@LL}%XdTs1@<26fL_G2%W)oe*eJ|5--#b9K&<{(aDf}R>_`bAEjOviHN zjNIPG-RZ6%FHn?F6E(Ev^TSifD>mDsup8$)OMZh1eFO^SR{r~+HleU*`-p#TyxF45Z-3(KGCYP{5C z3aU$%x}!MM`@tg=a;M^|=n<48x8n>t3*N zFA4ljk2pLQmNUK}>#FNM0r445G?EF5+o?0hJyMDnQ%jKWlT{1^hUrW}=qkNm7R*;u z5YNC8);cRnC0j=@^A1F&UYUZ>1~@jw)ojw6V0EHA$=~Rx5+}QP#v+w432hT5R6Lnc z@d8MU`IBNyI*O>|+90#l{qUkF=$lXTZIBx|=b!g9@e$^x9B!&^P)*O!Fnuk<*(zlp zCbd&AQ=t?L^pxH|;ZaSgC0v9RIi>`1OfTY#2(7JjYScDHPC1C!ly}TKIKEz5hUwq& z)pwYZrK=p|GqaCN!=w}pm?O8U%=Kd`nS4^gc^ofvr-nLT62=|5SRq1B+PtNaUOts7 zkfx`ZHSqn%b0&fuP5TM{9tR0lH!^#T9#Sk`JP@7K_btz=tGE?B#6;Ki*M*An`$AS}H=_EZ9c6p#?$mI(`~w%<7`a4?PB9m8xi zO4&nJHP*c?qoaG`^P*1Ltu!Mmb{O`pF02SEIx(sYnUq^tzaMH+^(9tw*N8YGVoOC{ zQbFKK=Ccu~4UZf%aux46NirU)NJm0xr4h-lm2Pr}s(c}a&91Kuclu8)HoclNI5tjB zh1>1U>C=|8Uy;7v|1Ia1wC@F>mMAHbOzRi0cjPxX!-c#}wunoKZ3sZu^rVUMhF5hWt&KvS!v}PTFEz4WB=wF9i0fq*7BlB3 zzG*_~$lb>bPh@2nH@zWx@vzqFhHw0ti+AS+UZy-l`MjOEPvL?k8BDtFHY7n4yT9?G zz$hZnsa;Gx^?1J2?&!hwXVbj_y>`!$1kfoMbDd3ho;lXkRONs+;IPB@DEis-%HtcY zjIvYA0Z$L@t_5|7%-=OLkgEz%X|?bBc|) z(8PM@<+lz;;-sIgcw3O}RwA0`32rQUkG}L_s|jE2Q7OpTHI++i-7)2Ao;U`Vc!glxHXoMjqKUCWTabK2e09mqQWG4Xm>IJN7| zO~sq(+c`mmG*^)EK<-EJG~xCQivgEVU!E6ldT|W86J-Ucrfw|~RaAA6CQ2OMea`!& z;SRyIn}2-#Kp&;UgeLc0>Jgzn-ZP=?_FQj6X!@6yB3;-pt7NY_s<{#4s}j}Yi8*sM z8IadDNZWg_-3y-u-B=fTYD;`0id2D-oq>AB3)CiMFEk&h=c%*BWGONeD*0U4$xkaQ zS#(D?(1t}C;)ou9UuLm<(_W2a)H^)n0qTbOD|0%BoE>MI_Ogk0RYCg>%wqY+%tK)rjc6gNhLgU<{&&JiEqdrz9k;p`TC z?y>KmAJL@d0Mhxu6JOcD%S7Ce?i(GYP%rH6fC{9b@uJ3Am4ide-CZIBhZo+@GW z@X~#^wbY^aIos03Ub&C-U?W~@hB`3xa&{B$iSNo6LS$BE#2l!KRK$NqZST4F)%%3M z%lDz#>{cog?!2q7$6k~ZW}J*WR#K^rxyP$9q`=Qq`K1#QBieMW%&sQR$?~q&8^ynf z^>|kFrh^=nNb%VsuG<&guHL(KYk{)iz8L+0v6`DZ!_~J+Ep(?dkEWcVC{Yf9V5Q$3 z`VY_k+d-0=Z*XE#U*t7K=>T7Xv+}Caa3PMf`A(KRo3h4w^BF zc$wf9u=3%*3H#5d4kOoQZzFXKz}kubcf(O56n1eb4I2>#S3T}z{-vmYOwF1n=U$i) z8)hepCadJ|IvSG&Y&_t}{%P|5?}lmy&$$_{M->q)tNn{Pf0ytI1p$vEaX|3LpFHP> zKL148S;r>}gKf>Z4|CPBqd)q?2=0@EAmBt>=DqY8``2T+aip~;#4}@?T z5&cJh39Elt#t$0ZYzADk@$k7d*aMk6>|MMOlpK3@N2ag-a=y@-aG#9Fz~m>!r^>f+BZ}Q|%-PgO%&+lJP&-8S!TGdsxs_uK0=Z#gri9Fw>B!7Qr z8!^)<0yvgdrws|nc&bA&^Q8&x)B`0um0hyspv>ZDoIaOt0|sA`A0hyfC(cvcbtRB+ zmTlq90jY6Kdn1LhFb`kP+qOVMzW=Ffd4jF~rekEIIX+)!l2L&C3v@UI#BFp%q&84N zIcqv=al0ne(^tCKT73NDLX*mbhvMamoWI>~SmY|c!qAn6*>K8^-g+}__S-FcV~L`M zZ7!FTtYV96Z+{23;KZ^1N$mlvZq?3<{4#o2#Ui!v4*#sbMW+EznGbXlgnDe`3JJ{d z4NcIATB@(p1(jN?DG6l>$9w!xojb^Q7mz81=*Dz=qv?ZjF3m%;p%Xucxl5~cQX5{X z&)DZzyeiAxj%FseKBq3e**kVYWW!{i%eQ~y%sJ?LH7RcJx44G zeNp*s`pGFMSanJ#PR5$_wYCsEC2?fdVkvcVi7(4g-g(_7`P$N^Te{wQ&B(7Aq)9sW zy9YXy7{#%7L+n09{TLetMcXrFz!(PZ)bCDV zeOJYF=OapRnVWe!R-x(ej+>L1QD%sMBTBiC40N9~HP?o_9EGUzWhp{syos+7lmAxw zGFQ{c+@QH9pJW(#29H^HsuhzZaZB+UYb)vFjwBWB_u(qYJ&|h)Rsrk%tj$NK4WKzy zD^7~-LZ=t=TE`!i(~0E%!FzQQ@m**5!aj9k9$s&HxO&O|#sajKM=ya>90r=qSfIu` z<4mQ1j=wwsu=`}qF z&#(T}4sO>Oh=}G(0Fn3OUh%$RBeKfHT(6V#j@?`(YBa(~U2T)cR_ zFpPm2`U(seFkq{>d&va^!`+w6$>x8cG7#rH!47~J&4qCnlMUlqCGB@Sfo5H!7 zD>x1csf0G?`r!%q*P|>JhOU!85t*$iwM(pyyR~p0}h|>W!Eu+SJvC2JViKrmRg`H{Mq0eSvo^KdvH^1Tj6X(1jBYb0Xe&Z z`f-iGOtw4weXV6bB%54z=+1AUjg(&7D;+*NjE(slsC2B2%>}1z%bjkB)&nxjV`Rti zgoy;Z9mj-GV$P@ZT95obmLnH&K7g_MlMc^2VBrkZIX--=mms86zuCv{*CZkjl=o-wZc`AKgp zF9-I;@Dp?c?y4V`C_ep9-OH*|-P<)g4u06*HQ!ikG1rKHIZszn&SJHF{@Yn;as?(7 z%cngnrED0y)@|z?OI^QpGb)A6v#0#gEEIw(gKIK<56|Wr(Prrm=e;h7Z1PI5AYDS% z6rX9OdM{u0G*6cGku-W#pnn7;ZL59BY<%@Gfu9j6p9g<}fe{X~^jc!KKGR4cGbZo{ zv4`&!g6XR{|HJCLkQYlVY5Zsac6`^hlV@z?Q-?lWadze$q_Fl3*+J>^cxw?0*+{E%@?7(@4P`0ejWJ3*+nU094>-IW2nm28+-Tzg0zE^MC>GY6Kfn##f5C2sl_X7=LU!u zblYH4LE{@GFTImz<|^#)ox&wGfE#dZ86cgNcPV5JT1uz`uX7CKn2#A?^N

Ju z%AIAa`aapIVuu4s{A9-){lX82d-Vwc13pZ2Q24TNQI^C^{6JB9#raW7a;77QvUyCb z?XyGMD^X@H&&K9FiRd+|IGVF6o_%y~#3s+p0F!TQZ8oipiVek{{7V>mGg3_djyGlP z&FfQhufc~v&9$+PU3iq$P<=&!s^jT6JS(dw#RK2SuK8qCD{8s!OB6g?_JjSBUQF_U zqmSMuNwV&CW;oirx9Df*P0F@U0&vpd8(lx(Bx52%z#o@_YIEb43k;WOmd-4?stQ@p z4Q|S4>3R&}JmNl-KbO@yq2hDtoABi=+Pf}=hbR>y%Z^GQm(elw7>uQ}KDc47n3tD< zNY%QZVqoJtQ-k{u3U>?$9^?Dlx5td{D-0+vy0!2^6-ll8nR0W(=selsT45GzU&k4o zj>3()67W&{Z~RdWk9h#HueU0!VIf@}I#eAx&4}cv3Ikm(-WRVOan29(&iy0LGD1p? z^aIX~7qUpI;cHTQ%4~a4Zc`E6o#_#N;wf>@A4q$^s5kxY-jIi-+A0$4P;Yd0YPeqcR^c=^jLNd-5Z;UwfwGM2oaY<*YkNuM*7|2(4U!>YfqmkMXza* zkY+FbH25%d?>N$N+qvBZLKlX29oUW^btHf3a?y2b;F9A1271?G{ZQ|hZWG5d+y*q$ zs_}>Ps`qyOc$Rh$adspPZ~G#FJp2MAQZzDgl4&{U!*+o!eg$uRYNk_u)j9$_j*AZJ zPok1uT}$L~=YC1s9+vJGNm(}A2^KmB9Dv$=%varxFp$b1241^!cs$~vaXRB0+>7v< zy2~94u}6p~uUko%!2Yl!->%L-L~;62?1SBL4?Nm-lFRx}*THq-B+q4dh7Eh^Q7{y- zQ4Us%ns3c}WQ=F3E+4aSW`48<*Z6bdKs#tCQx;i6wh5j)UVO&987DF<7@~_3(>ei5 zy)qY?w*(y}rVd7lcdb6LaynRk30{Qm2RM-~0`rDf`6PH4JP7SG17V$yW2-rCsmfGT__f^OJV6WS6# zQmHfl^zq|IY?)O8R>K__q~l|K1*|Eg#0%L38WTNf5Z%Jp;GCBi=(Tsd{q^ z;|N8wFKbbiQWG zc`EKhHk|e&=s<#nOhWkK-k7rd4@;h*GF3?l6?p+O>ec92-SHb#le(Cri<1*4xHkrm zhzEUJ57SmzkFW_VuZ(T(kItB?Vzn+V35B+!X*<3=V!W}(R|0eCd6WJ^&xJEVzj5aV zEEz0|hV4w%diG-&pivCJC=4C+vu2ALQx?69!Q*WE8QBOTj#^MsH}>@-;WlBP zN}`4)6^<_Djx6MOo^d@}X7#h=op7KUh>r~X9HUCYO%O@RVo|VByL1}FTy8K_qG=4C zlvPmt8BxNOk$$TnT>hvia|x5THDp%C%QCzQfM{t_Ejc13O;05_0?>X{R22F3)!7Mu zHKWvsq|HWxc%^Sjl0nwwJ!td3_o#C-}5HSE1SnS<7f5yX5Y)9zdV;18Euhv12N? z>qiFO7HynDoJYNjS2j)FhN+av$>MqqWyL|ElJ>~^5kKT}`6 zd=(tC(~WFa_A2>Njg*KWWH(UFLOfmxzb^5zB(5f)?9gKMs2A?08{;S;=)5BpM`^b;iG4?w;PLE!`kV`rP4i8XYJ3P4`0b{|Sau34AGdHv z_PAFEmYi+$dyp}{sJN<;R^kI8^leaoR}mL?+2|_S!*inyF^K*+7Ih5p*|np(SMeJ% z(%<>TE?2Ri|d)l`S^fc0bInG^~QxZlO!jO95qYq=CM zi`iFS2qM(n^Q}ie2q~$@6H(LxL>LE7zhtF71uWib(UW zCgg-kDZ?%Q$`^tk|EEcWU-RX*zS^5cH1}4S2w*vZ;b2HOvw1I&AqDZeaD}*y;l3WG~wOa z!lrl^ut=hvR+RgUe)?7eK$Y-B`N_OO&-C!Feo17weO+J6qIvn|GO2KR`Q-7%G1s?W z-=Y`&c09ZG?6Jp)62jg8T!IX#ggsjvkL2x{%ULpXZ+t*p2Frh4tMxzKIAy%e!x z8S_}t_mNxq;vnFxHW@as|JKEl%lQ_z)s-AEL0IZp*km2jd78Oy>$CFGH;_Dqe8!#M zrV+OKi-oC(S~Z1ZWYrQ3fxfSPp*eS65-L}slPDMXO_F`&eMElLm#m^Q`}Hx{;e!tD z(q`<@g0AORg3STb{%*; zQ(9<#-sgbK;NLE)=IWao7`RSx*+)3HKH*BeFnhZ!ttpcvJR^YiAGBpm(UmU+Ivn06 zR$zIzf_9pruQk~3NJq}Ui}?Af`PBVE`PAFZJM*~^`_}UTFSp&uf5NKyl>d8?lYx6X zQ$*W}Z)NSxqMN%5&dqMM!!BCciHwlh0vNZ6#Tk;gX7amW_2I6@4G8o-NL$YQoz%d7 zQkC|YL0dY_gT~EtwCUfxl&gAOc&T+zjp%Mow__%wuZ*3h{~WI8E$F;l5Cl{bp?@Ne zcapk$sS_!h5QTx&kr83Cz0id8G~@6+J68Dae|66Wx_-IdRr)3@h`kMvanm;m(JMvz z%3o|m=TkxH-!`5DlxHh-jDvmXNH#3RO9KZ*PUEW6A5K^I3+|~t^4Pfnb9{XFh!28O z`SmVp^E!rj-b!vSmr(tV^1I8NGHBh;An6G97Tz2mhuomHyJ`$x zT5LzX_c$uow10N$l@a;Pa&=CVHL7R(wCmnkdX|q@iY4{M^EL0JGxa5gG8ITV>p*G$ z=vd^U2S1`Yy6<{2RmeyJ$tNld$sTfH2kMbv7B&2|YO@opy->9g-cPsSHT^!21p=bF z$Itf61(kWv>&}XOU9^be_dbQ*Z~G?bcGKw9v|o$g%(7KU9t-FOL5lCwGn22!M(D)7 zG^vk|g}CYVkNHjNm;Lm_@&8e*APZ!sJb!CIwbb9)`EpYu_L@BXpsG}<6LljGh@+e1 zuzR(=y>nmmOP+Q+uc5`qjO+{c1{g4sqS{F=%EZdPWEf`}$ueSCFiLNp;!v%?pD->* zUtfP>T@ZF<;SJAVJu$7nuHre1MSQh{r=aMI1FgyGB?dQ+a3tQ@5XQKd8kuQe$i?yZ zrJs(9&Sfhl22a)QxZ_ZD0&%aTm0ez?O9f=IzaZ7U6PU6@O#0=GP;)mW-=x@F@3*1`HRmSN_0Kz_oL*Q&7wSo>j-`1FN*U|k4VRh6V$p?j8-_}erN z#c}B_p5MHrLPlzw+99o(Q`Qoj?Q#?LtbnkDsyE?Sc9i6gyS>_7B#Z*$<(lFw@gAcn zw>>K>X>hlksgTOf*PgkRs6P0-+%$$JSjAEkRz__A^deR;j0H402;YvOMza5cqsv`` z6KT+~I7AGvy@(eVVV-G%TM?0ep}_jKu{}yZb1^Lv>2yT4ar6LLvt`v6@s)U?={SL~ z>^}kadV{6RL*g$wdFYw_BAH8^#hu-cyHgG#p9(#y*XOgd>rg+GbK?Oo9wwP5#; z>>HNa>VP#k)7e*iqm&7pBx)+lKLotl%GieC<#q2Docx;^HX=0cN!{SaIjWQ@+3t70 z87J`1yax>Tp48L%NNcmJ#TIoC6E7Aqup-%Xww3P~hC4$>H31KPWN?-3#;os|f1 z1nmZ1nsa&;_2Ye+p?^7q!s8i51>F=Zw3hR7y~oM2i4$x1%A`sK_h`E3yM4J3BtshQ zh}Y&WEN6XqTPTM=5FyJ+?7kGD0mO!sFABe>Z4Ua)!*#!8c@+N)-#-^Y;}3W23wI)ty0d>PzS@&=Q%MxR z%9cgGipz+0l!oUBz315LIR#n+Mx#U>kwkY$r}m zR4K?B5`ufrMu>ZS$=YkV@fnvR57AY%_+GucDPb9`6V^9Z6dL&wnsD9(Mlqaxap*34 zCY(||)a{1$V*NjjIU_^sX+9R0Hkohe&Jt;H7=V&=7*x0o`RAfSc`qy?#4k@gs7{2# zDifDjbchq*SSQa*m;sacHCwT!scDfBeJT6v-6?K_jHMM{QXX03Ozp+SvfJ4heUaV9 zn!1;Kkg&HFMy6{_z~i>GUgc^nc3tbTCS4kS9DoG05VASffqsepHxZ?l5I)>c3j@v@9o+ep}DN zjZS2DAY}HLCzReFu>!ZAV|cB+-xVuuI;%8(ai4vH{i<|)>chBj>!8(s?rKVi+_m|h ziWX=48P|I_-2L%xk5E+K`)f zfL|&!l7w3;8w~if6w&&TV^3%i;VScUnYSxBWWD_(pT7r60fCJ{ZcuiRID+9_wfYg9 z>GX~6-Bh`Vs89`OJYWV{8y#a5+uv?$DbH=M9XW~FS;(6Sj$YCOwlJa57lpwcf z{SJjSY8bosG|!_*I5)WDFtuzXMzaP}2U&Pc2&&K&UP_{29Na-S_(wNp=e1J2dI>ew zlLn!sqaBmJ#&@|&@rnU`_qvES@pG%&=9McYKP5K5?9rarx5#}VeNd7JVUk2sz3K#9a9!+_axT@rOcphCCkh?R|W$B`yMF8{e@R%rrUHBKPG}b{ zuY$pjUs&WY`uNM{f*s-$eI;Z~g+cAPWI5e*Lksk04Ets62z%Tt0S2H0FGrK~2xC+t zfUo*gK6FY%wOc{`Ax6CgMX*W$k0t~CG7^6LLwKINyO6>-+t{~)7j^GMg-BJ~PQzuX z=Ckas_8AE-%Us?LF(Jk_*1B$5691*2cji@i)I`(~@v>R|)Rt{;nt_0ye_cDefcs#l z)nVCo-RezsOH*$FYL)wfC_-M2QcWeZN=~5Y(^~-zl8g3SH*DaIc(gVyVXuxcb*6Hv z`+Wd8QtBbd1MBCkALh7xj;nw(>8Shdy7B%?x7^9oXQZ7!4f#iK*21{x=q&hz4rDIfrQ7ZTVc~w>Q#c<@AUpqSsNhCfMt_ z%v?L$Em~_u2nhFy@R-<6G%FqO*`CyIxGE!eKDguaV0t65yyjUzu@F(DvRT)|k+@)E z*}JAuETrU4pA7|byj!#>5qe3;&vsempF7&#uJU$LtF570f%^%$1cjF?#HtKfoHE&d zGn*1A{C+jMrgvt1!zk9fM4=ZP9Ro*CU_7SSi??VXndM7uD;&q!_qhAD&q4#@XW?SH z$0=gV&DK(ODkMd8(&Ms79Sk2-3&*>RT_1RVcBuZf=R&k8o7?c}RX_dC_-L#$Ze%}wmvFt@VwX_W?zmd9yW7HoB!H6erM@He8ai%WE) z?qsLIM=h>3g|P;gV~aNxugL%Vs7-0ew$9=2=zvP^HiHiSh)nbLpdN@1qpu^}*y<8t zlWLDuG-xVqi{Bqo{U3W*5fgai*SK&S*ylyxi$FMOkv;3v z$oKQZp;T#YaSYWU6|%Sjoc6g9P&Rued(xB?6L31$lv)5PB7{hpt@WJ#;P`a($qMAA zgh;Jtc#zWK4DOuCnuH4)IZmK`c0dTJ06Iib>}90usEv=d0Wwe)PTD=nHrD^Hmx|E? z41**1@NSfvvTwOo*s8{`k(aqnPk_a27fDt>uF@wT6Aj(E|F;flu;*tiLsPBm%YvK=Ix`4JHl&i$E4`k*dTAR0YwLX5-i0BX{3dXxL5dY3Gsyr$tAxk*c2r{0G zvfWQpeww+7pkhP=?{^DnJwPxNE}AB5vC=im+7obF^|~LxhTcSOn)MZm3mqI}PW|+K zg{3MeL<@9VE7Q+juT^g9|mMkP!+@teT!}OnVmFk+LU_=(&9IN&*0OdZCCT+Eb$Wm zW=JZ+jh+ev7KF+=<`CM&M9DZ0FwnLtJ0Wofyy=bXxg)iP(W_4*CSFKhs7g(UQ-<}=`Pm2B=0o6+yAyaUb@0R^OZ5qc^Z&uj#QKb=Ps$F(;%DS1A zjCuQYbJEpw@Sz_+Z=K3iIs24<>|4#s&&7K|$DNCn)_z&VQJKCk&>eg>5@mGAdyi^Q zzZ0}ZeUMnw1e8TCez-TFU5##yz#%3c@OKL0$aBNLxFCwTq=1$G)QAyW?lDU~D3cBZ z$O1T?$yb;f*&Ow$i%rgXk9%(*` zHQJ^y@>`l5-vV+Y<cFuh!L=6NfIb`&}Ph}~;SySxS3C)hHI9ug%uo_3|wP?-CR>oWl zIWg$Lk+1GF8|s>ioXh2>jl$%}q=Vncp79YSHBtanAxTCad41tatRLZILt5PVEI^)z zw4F_^kKORP$b(S}rc$4rly8G2R;QKda{kO_Y~K`WtDa*|P|j1|XlU+zwKp3}lCKT} zt9c;kF*hVZ`P|=6|6Qib7}dDSwe7e(v0>5N0$CgdBpdj9>iA~8TDAkq-*rdUsCN@N z8n7|2ZlVbZLGhg&;;~pG{~J?!Dw7v}m#_5CkbS3DW6fLDc}>d9S-9ZIcgsc`&P}NO zQx>J3Cxa=uk0mJ`Tc|n_TMOE=vYO{5f1F~XjlQ?gGcw(r$X~~tKD6U zQzXm&Y5HLI2g7P9zN!F~*l+KgIX$CGeyQUotq@=-RQAm%*P&b3fYk&0VH(gZ)-1WrdUUaL!6mFI63=u@z)88Yk+QQAV&Cs*WI9R2s z3pE{A+h%I}1uz)n!o$oreMx1@kG{I05uSLMOQj^ea&RK@?6_{kLN$=*0GlwJ0abYf=m#l#nz7yWd3kw z57Hh4!DNWmBk^~nnggfnDhyqxjzBj%k0xu~!o0GxK+W$}7lK+$&j4hNoCp?E`Z$TR zhzQYX%cT|(D6ieqgO>a>3$ptm-}*QrP0!#P2mS?V-Fw))%px~3H##jC0n}qr0{>Qc z_B3>}k5oCGZJZTqO^u>=<=4wo%AXaMLQfL;Un+9Io(v^P;qF+o$0#%L3DZXQ<#OlL z|4kxz_W?$EqbC&cYk@>~mW(zWx$$T^+t(9e--m+|evS2zvOwymjRCalgGq^pQU%9v zZqD=^CnvR98(98fli#$e>ZBC?s(;qp=_$>^ukMs|PZ&M-#VNnQ%80&kA0iGGmpy0V z(*%PDp3$IV)<9_5Zia`LZwA;8r{rzFtP{506^;)M(W^hBME-b956dTNe6;>sZL)!d z!Jnx?vpY;nE_sNhtL?}mp|f{LMOi<&^U0_8n|>(XNzQcUFQ*;R-1rd02y3?ZaV^@U zid86v}ACGtIP^f!Z zUhanN^MRjgo%9L?(%o&d9{csXM#eJ$ESngraCR>#vjdYLJw5PTJj>uN143>W6rk%w zNox*b+E9mcO^;4R)sbtzAI=5`{+TbSVZNAgO-F0_e;g4jf&RBWO z*8aIDsjjq9zCPrcdR6)`j|pW%33+uDK;dkppzz`^QHlvvw16~NsreR`5Nss9B&kX2JI}9}^yE%(; z=^%MzqNZA@_6uoaAc3A2hSK4%R({tjE$ub}yE>u{^<#T?;hTEAOM3yU-_&<1NmxjK z;7Bp))n67Z&|V@>AfE8rp*1!`_p?-`!D&C=Gz=1o+vJ@b{hzkK*$8=r=m#hQe7^@5 zW08W&{|-6-AN&qccbW-e96pDG(}Xh8zh8m>_qDWdOcT}5!AAcI%>NGy{Eve``@h&Q zs~u5gWdFMx1SGw~$UYst)=k&v|n_= zwHAmtRQEbs=7FW2^$M~!yzo!j@-JoC<@(nU=i5K%X1=pVB<&je3``JuSYjlVcP;+V zU^su-U)FJqUHK;_=w`%tM_4r=b8S>Q3##h_2fH)Vp#C!shSyvnBMYYd@|x6XgJaiR zP{|c$!gDDSQd%@RJ&Q4Sq46Oiuj6{ORwg!d7Nhi7%_X|_rMCjxaN_+x;er1~%l|XA zq-)#S3VNO>uw)gMRv3nenJK_i6}fT@Lz~b&&r}g=RI0d4s6y5D4gblF-PKltW)_~= zNZG_=(uq}rFkAWthy~&`QgFPXSh4OObenk!AY z1StA)#&QBYsO>6Dwn|bow(k@JsNnc7@0xmH2fglT;YMX8oU@S4I&fwgu>l5*?BcTeX6F53WKCb<8W|17mdMF|DzalVQC5BdA*P^0Peyf*B z-@jpZo6dx=l(d6Bi9~|}I@r?rUeROt54|e!Yl#{AmPKBw81#$>T+)AAK$q`=OUmi& z7GB4^V!U2%Wr>MlRcAO&cNHXDol@ zKRJB=Hxp~a>r>bIPMf~XODnxQ;?KANlOr_!`Q!259{@N?oAV-K65q)-RoofGpme{hM! zGaEe;>zm5WefgFtYg%O~F@{-O1{6W;-C6ckt$j$w+IV71+4&RxdtPUdU?^1yA64XU z6aRmY@vk${Sq*{5Apyv*XfmO#I3Mh4L+_XgzPaz4ba(jo9);FWE?d4s!6g#|ko^iV zOZJyn?ZDqS1Qc@U_Y)3X2Bl|dovf*b_y(yAY6IY`hkOby2h1oZu3wBRYt8cw#ROO8 zOvU@EVlB~b=vbU{9Hb@EKd4Gk=`d6tARFmVRJ$56kT!)grH_~EEQa$ZT ziH|3@F?}*)z~!L$S7!U4>f)zL0iap8TY>^VVoF2SE^9m2lGuLbug%+FyUWD9sT0*#eIlsTYSi>;JKK0>Sb+7-qMhV%L}|$ieT%Qj zl9}N4Z6KZ7wEBlt~`zs4;9H_>j_m)&#{L%zmD-H%bl3$KwA)5T~IuXgg z1m;&SAbp1oEFm6AsQ2c-#8n9TtpB#R;ZbbgBTZgeEtcX}q2_|7GPHdX`6M@M?TX6; z`!&RhX}F(FRWjd>v_Q;bXXOd6SMN{K;#uq+`Zt5QWMkrz-0*pbtHqLSUG!9FhyM*h zF|Z=!ox8LCCu}LMU`jL|O6WZr(t*)me6&LuVIid&`SvQ*<~W4tljg7kjG}&ZTD+G} z9Eu~NE6EwM3|u`E_M%(afE@Il3Nfp}Od#GBi6$b9xqty$4HVK# zLJQaPY3DO>R4LEvoJa{*n-=pJwJ8*@&FWxR5v1_YxF)O>D11f@n|W2GLsQGq*lmu~%WL=Q-2g}^f2!lvpD_;rSa1yIcz*DBaizLdk1TZ_aa)6v&`O9_ zuYOX4xzxC&Bs;2D-4On%@hg9g!>QaZkGm{oi1ptDGP-c@ahY`!ocZ3G$WQ!^#pjTg zn=Vx*U2OmzWukFSgpjV_1(67O$-bt1Xi0vHq&97GMaS1z;l9WP1Ki&M`q1l*137BT z)&N2J8(8m|$wkhdJbm#IA|9r+Y3IG+$P5YFkopaA{3|7I-zIVeZ)n@`(sR83?2@V~l&E-p;Vpr@W12jahtlK$fc^C*8Y zb_HCAlK%Dh{tp4XJ^seP81pXRp=1o_v*-V62%_)PB1LUS14dF*LG_2%QezeQ6U3nY zl>g<$nm^ygSF}%Ybv^w%pYUJdK@dfk)L5P)8~guCUYB4ZNIGB-`DBdvb6JDkp&a?w<4%{hciOc!zrCL(m~z)&#CUFYJ&F-5j*G6HjuE*-&%^3<^S#Ru2FpaZHOJ~UndEt8~r!WiBTAN<^8Fx<}ZO)4?Ze$A^-hpoymLHU(69a+m+;{Pq=I%A}Ee703W+E zJMfnaN8+Q=Rk79nbO|v2%+U(g%;Lt)n4{SpWF*KSvC8>YPt%*|9A%YaWP zY;U4cjeuU~>fQ3Xx9@$Kb$P2xsGK%-#)$XVT(0b*u)bD^{H!e{*x5~2**B(?`*iBw zGqMlSK=nSs()TliEBEGTV$zAR8=eg*G*@7%JjCLn>l5qZqyx>4)k|}msD-Vh@jeDe zGx53uVq2@;b&s4qP{x8$F=q(W4 z?CGVlD{|43>))2*Lh=O4&eP%-5DwU~)YdC*UEbv&L=xW=`2>qDhu01KXF1(j9N~BM zmxw%apO)-+-RHcKRHYB>H@l8Y?A_U<+iTIK{Kv#~Ws#CxG>z6m*0Qzox?Itd^Og3A zA{5LXC+U92$LiLYB%j-eG!#^SXZiWv<3eQ~;~XGk<`%fn&fcMM_i>@cBDbhm3wPy= z(Oj&8`e}Pj)=wYOOO$Ix`A)Kw?6wh!iXik0_A75!2ZLp5tIm5pfwqq=2eYba56jsg z>E_NudkDpGVgKsaxMI27mioPU=MLfAz_CDI47V3#ChsdF49U4xFb4u(Hg@Cm#{ zs8;C8H#QVx;F}&t>u8Srh9SH<^lv!1OBzP|4?TXLfN%M&4Sb5>0aqzZd4zdhjrqKg z_R=u@$W4~_+dY8$Xj-WTo=^ygi>(-+@7OCan2qge<$BUvL3odnromoxq)DQo}Oqg7VT-`uER=idJIJY?%Z%*l%GIYau4S!k( zgJa#dw?diz07UA8Ac@J=$o5eqNe#vt;o(tVy|?wg1ROZHBoMa~E2_A#0Xh?2_=NAC zt@>EJkO1ug3Flf!g0C3D_xVqPtjN_bT0J=(J!M5Wl@+m)mo2iq<(exFeH#V}k|HXD z|2M6e^T%@)&9F)xfJjENEt61XcovG|zp(({`G>9I#g#a$N1_2%?$}EDF@1K>y=X@% zCVVP!RfHodo=-^jMlKP(umd8+zLhADYHU;HNwqa}M{;f?;8 zn#+mvEDn`bCAR3@zi=~zTPuasZKt$s{TC%QA8sZEdy~aN0nZmWG&EL~5WeO+Zg@@&Wvupt38j~cOsS~{>{~fl#k~A_zIbJ<;6}uJi?Up zcf63~qyL{=Wa6>|9aq}{32y)g@H-Q?rZ1FECwa@o^w%uTNPgSCYA$$metQI>ukF>1 zEs=UhZxazojrZ!?LJ`Sri z-9W4Hybz-Yhi%}{nJD9@#`=T04#-)DpLhGEPhJfvxhopzCf8;%4jQCX#)PU492Ub| z&q$#PWQ+`1-uk_|^YA`SmN1QPucFs%%=(j}6yg!ub8p5)sI~*OsXV;_kEBF56tp91GRcB5d6gm09O(8ieiB5DF9@|)B z!D%qP;a7|>h6mVh4DoJztNWG>26R zGCSh>%5-+!rh}G}+|O^~2aNMJidB{PbPiRenm{i1J-yWrTRq2CQ#fcHA3$eTKQ!!JAL>ORE- z5YF+p8wNN-<;uluit#h08M~7GS-JuPUC==6WrYi?(Xh>@Ze6+103Ws zcj~^HS9faO``O)JcUM>M{=VI7@3q$L75A6c2R3N{{fntZ9#&<)2*F49$S?_5-A`ot z1>>zw@uSFc#lThRX;jMChXSTZ-f>4hGiz%uM(o-@*l_=4ueddkh?qL|5c$oD%)Itr zV_d%}Q53)YReP#t=j}Oz9UJc9>R!cO*%u>H`kwA6V%a;03TE{q~O}2q&x6ckVvh`O#l!kU5|8OcHaV>rFG$!Y<061^D zmCF9)2=zN!&oR+H*WV7R4f1??s))wzE~+uz{=I*e953f*&zs@?Q?x;ojT=5TY*MJ{ z%C1F2icq=bPw=$fzZ+0}jTg1lP1jX^Y{i4{<@>f8Ef{s!mm*EbwQtr>qEVl~ zlRol+Qf)@}{oXOD(%YxC5fY#t)iY5;+$uv@%gI(mD5E0JId z37bGE_F4L{si&w`VhP!FhW5EXA%9aFS<+rmkv#2kzKm0i$>W4{@%r|6Y(}=$Ad5{p z#~)5sNS#QI!84$y7rMe`#wh?^V`e3vj}typ#n2~IVPL94gU5Nm`;&hCH;ArKBhNjk zCA(5eUs_OhrCR*^_kvNCR*z;4X*^reOK|Ae?5x;)IF5Ksbg0?PMoeu_%+J4*6zPbX zh56+~9zuFb*!Z4Q))n79*0ho8E<|L$liVUkIrC7Fz^g>%kmG^|x(LQ*vLS|jScC9} zwtSJ6!P$DTJ}Z9dlcQ@a zNw6>iRDNyp<*u)hZ*_l2u*`)`4;wLcPDlT>Pi@+zO?2W!|f;Gq4x;&?o}8IUjoD z`$TrF)DE42^w@-K_+m(z#2?k7Ronxhep?OY|6P`^7G$0<6}!wFt=|V zco*F^U@|{2Iqk%WQIhH3S^*`z5FW>Q>mg6M;qF1tmoBKH`Jcd;kBtU^S;q%|Q_x@v zzDe*-vlu`0JI9c6K#F0V{}x?ri}{ovq7$87GqMo5-P+Evt_C0Qav#6Kc2=_EoCZ#aWczJxM|7-jpxubMP+~L&d>~j>FgmwwWXR?fEd(GQ z2q_+B_#p%(Wc*jEZv6x^dyY?Vhe4#!;*WE2q;oiNq@0KwF)%o$TlGfCQDmG16C>$2 z>zO{eYTC8)6NHsq{qB5<^+{GpQ*vbA$g_4w5lkth-mosj8IZMwz}E?QtF~q zAue;@A#_~XPT8o@_E?6SM;YE!pLPl1VogV{4{QOs3a7KS#h7V4oil*|c1?Ig>fs zteEApT2j zCL@FRK+h8;4}Szx8)hb&7BHIKZ!gYJM_2cAVi(`(c$`p?Blis62_8tsRTwvx{QIvk zyF1Z=rLrJV&Hi7@D?*S!ZSzNVI@8e|L=)z^YemDVYlvCu) z(pLN#RLJ5o1}<2J-pBG;+Kuy;Aw~%e+P-n%;t$3bUKH38p@WUg__b0rMn~Q*)~b7x zz<Kw^lAhbt~*;4>W3X%IOZcVN_gMv$-kxn6ql}_v@w}9(BNo zki1iMU!y5z_G`EKT)_N^P+y;LUmuMuNW*{a;lNKln;54Xo7 zU)J?Ko^)!YMgVTUS0G$L$}Az37k`ToG4aFsn>MhK8Zs8OMxv+-z=jtWBTVO@PJE~~ruZkmGv}?TO5PZB10=j((5J=|#E6}1Y818fEjVM)lpt5TMef^i$=xw1#oJP#chv3O zIK^tuNhnpZ!Ff4cR&@FL?~Xhu`NCQ57V+vqozqKhwRiJx#aPZ&%6#WF_N<)KTmRju zmE-I&+|GUS;r4k2-`Ik;fV||)Ubuk9H8JQuzD7C^b40n&od5CRT2)31Hk@5p&=Lrjcr(1I z?l>k_%F)M)KkhpIH;E|tjbFb|I@N0VyW&fr|3w8|_EiQ?b9qX6l}TUj&`N@h_=o8wPRZLAaS3Ub zJI&{)hu-CGIEnp^q><0(0=3X^0lU@83AmM;iISq4_SRR$QYLfV5-#9rRP^ves1j+$ zk_Z3zL;t8a)Z^rB<^6@0eHKt_ zm;@;0BT#)Iv0>g@WDC8O+hNi5o{fackhSTkjdR@Yx%O5%%6x7=GNc};Ib-4HdptQ9 z&SkOBQtx_ud5}MPXEWU`lt=#PQvI=a_EYKF#TVtnvLHV8j3ChXh}8Wxc{L5jdV^*5 zHu>`R3ojdY$@^1vv&ZCWG&kwDU|rm9&-|f#>*qjl!P4<0`qSBCGxpJB>JMAtBntoc z6^z-1RzJ?UcrPl+I4Ejj7Pl5&Hv}x_!qONq%Bj9aNu)h#|UjaIB`mI0dFoQM&ynG_jf5 z^zsrn4dzU-U56f#zUiN`lGhp;UXLIEv)wmZcC-m>km{TOr$8C5ox=79sOmx+`zrBz zSRYKMXM~6uZU=HBuT4BPT8aVZw|*VhZA-INw4XWb_cfNKNnEU6z&C57`EzTfd0~qKey1jg~<-&71v++LoM*)5?cQ zSzSjY>&;r&f7tY2alt{rKE~OL;U3>w@KxZjoAy+yLDlcU_kFW^1-HYut}CNMq4jD5 z7(51!qe?KMXYF(S@!cIseBN6l_%Bp@UT5FSzs~T}&*1&QJvCJEC(Zv8-@iW~XBnWi zToIasIMt|yZ_EA|W%PKscXP6-hQAT>*b@&j z;d>)Zi_bIoa*2z*VL8B~$9;=x`M$ekIqP5P%baEfHk3<}kxHZp9iFV=i5A@UrK z_m+A<>|vQV$?Ta7iCR|L4Mm)S`km(eYgVmL_rIO@Pa9M)s7&~c?jTTBSFrt+7vMC0 z!~ztc&YHz~w-R}{4!6Y2|K+W~^N+?JpY+!fG$`@ zEr_Xia2*P~q78aO(K(3FPkvnwt>%6t|7dZ)DL%~Apw0Ytno|Gj;{MSH&5!FS62=5e zhZvneK@-~zqD#(chno?`C8IO&NntDb2cy2_9}JcOQ5Ee@Ls8XRxKko1cldo{Z)qm4 zV#Vh%{1vqbcF zz+s)!CY%-eXy5WL%Kb9(6+L%EN7;x`JEM9px#yR2F;G2Eu?s_Q_3AL>ZIlT}%V_tm z!((iJ+w)Qo8;0L^<0D+qddo0+WXs`10Qx=vW-4Qboii=cEXyRYV7v;*GWJjL?~fli6TBZgLhhe@ zpvl4LU3KPwOHt60_eA15OH~oHud&gY0!%>}X$9y+s&`>V7pq6Up7h0@W$neSvqxk? z+Ge~*yCs5lO%hf`mcucd*zOxlRa)}QPtu!1LW0xQGp!h}QsRx)4@f43ynNqX0UzP$ z;H@k+mR~7!IxRk}i>b=YCuu?%HwlnIR6TTguBnSXD5+SAn}Le?Y555HE&0 z9>MbPm>s7J%r4po2z z!*P7{tvd-|NWNUaQ|`HJ%nLgAcRA2(sl~i3-zC=5q1!ZCQZO)J!gst6J|9-su*}*Fe_%n6Z0x>OJ-&ivjHNcxTdxl#;kFKjHeKdeSfm32?Rgp3y7=AlW@+uxV$@uP1eZq<)t|_c#sMHwg@Y zZfJV*WJPd3B;LEsnp#g`OqMH~7@57IK=;*az#A@U4jlTMdSkFwvFW2P;-9@7hirc% z{TB?E^7}iH^C4m+A`PDhQY&WCA&oTN9d$>FQ^uXegV|A_QYyPHrQK`RQx)Q-zka!g z<#4l)W7^^lYxyK>Pz5SSa@fDO!eDvI591@$nf5vKq_J3+B4;tAIg^CY51VaNjvb0o z)=9N*AQ(^)ZNr!Q%H+7X$GoTLuF zkX;+|M};+;9Orz52$XC$Ka^k}2%?0x&aW*qOyTaH6N}t)84mloOxZ62Fdy$z>OQI= zTQ_;}IgSpfOYgI7b1rTat!a&&T1273iQ6w=eU!9fgR^E}pDWB7SW9+Sv zVJPC?b!%FWfn)3K_viF8*2&ou-Zai_4(1}=-`Cb?Bh>e=8{v2K@ZMXC!^^Fx{5xCW zOM%&ugK)yh4Fm-7?_vHYJ=}4f-ytz9nIx}kz4F1D`Hz#sw4~6xXk}Xw;>ARpF)JLv zF+A#gvq@PVN>V9cwGa_7Cnn^Z{W&kBqa6Ef-cFbwZ^il6;h3^x%glpVo%jn$I&$M* z*j7D1XXAQFQ*|satuYeM5vb!s2l-GAD8|iJwm&U+ZL{_M{O%;o&bDyGT_Xr~G05|q z+A)XZ5lOcG)|=YVjsTUqCP^&1dx-Ao=w0T`px=a`d?8P2039kHqsy3XdQ9@xWnFxV zW8JTneSWNYz%kvLuy#ZxYSi)uEy@_UYRp1#Hjc>$ER1N3d9od^)-aB8b=~q4_n#_` zaDxdhxW3Bon{HXP)XiO$aWjMzV5(2ii4QZw3~~4M4`;=GEQ)tD&2vaVZqM3L0nZu( zU_i;DWwggz)CEzM17~F1%5<5bDq%n==9AZMkfDZTHBYs3<3)vK{|3K)nY3JLB|jLE z)g@7b@sG~~tGg(Pt8Nv-B3>xE>n~1_gUoFV z5gXLW<*LXo3i1Q0vSS{BOPj?2yuHv`c(slSS{%R1tt6FZviYFDHL7LIO4B4;#u)e( zo->+=|+bXa8#|=zEvThNL{7 zY(O4L_WAeYVBO?trtr6JjACd1SXr3vU-|x}hNf?BS6eCC^&ff4&92Z<=|uwSu~^R~ z=;t}YgXKnmqB}*z79(!V#{^jcrVk} z>`?q>I5%c$c8|{_S~Tc;J7+x-O6<9YlO2CES|gw+u0n`?X0b~csYr>?dbDPhNjiNo zG#+Kb-$$N^APZzNOsv+Psb+`wG^UL^nGV&pqz%!(6&fcAcT0Nlb3a9Y= zk4@9|k=Vwm9eN=#E*$ow@&#ciG@iW6P8`d?znJ-?9cX#Wm#Y4nVo&R_+DAoeJ1{`r zvPzx6QHeW5$syyBqFS?&Ac)mdOP^J~PUM&~=d_;pWLQqK{vCT}k%VrC(`-CA7Ie9~pVju)m4b#Hrk=tX#- zwSoQ+!eJ^+3#^OVNe{Uuc_g1*1sT=S;=ZFoQ3<;qYN|-v*Dz0Y{g2U-@4;Jp1kccq z)e>rOdvDvu5bP6blpC(GrKGF+tAa?Y;b#bHiUc65;8BVwq>p<2a)&J%__}R2%zD)G z*zk63lSWp2kjviiZu&;z&3(8v{wM4ef}uSkN%6q#U|sJYp@P}aJqYcB)?>du1a^D345>g8;IgV+tJ!`@4+3A>j z7td37e&}DYy~9O3#kN(hf$+4YT}+Mqy<_Q9at?=dyA*%nrP&*3ktcT-UCE0sO1MzW zIkC988e$~X|6D+hhp~`8Ae|R*!QNgwmk(h~B}L5f!w4nP!v8b12nOJDRrS zfsh+J1xein6wa%(Udr)D)j%^i_K`YlMipsaQ^GT&?XRQJ3%!MTQ24!T5rq{hB2(5e z{2ow&8bX3xbMY(Pz6lexu!v$MRl+h@meq`5;Bna{`cQl~e%BVKM_`0%n#^V;7Mml* z)dVouE3^1o(KMfwNr4}Wt}Zq&%&CPdU#;Clcoo*lf{E`7_e_Vqv~&a}4G)kTR=2xK zaN5Erl<-T;ojLqkele=!Fzgx~piO9zCZ69cfn7u7?F!TIbfADheI-vhUani~Ij9(9 zw~-Q7V%fh9doDoN%J3+teQl~vw^f7cwS;sw_7jZS~UDr{FXmIhVe=Z z*kwourGBH68n)5cWmk1w6K(mYh|r>G@W!Rxet(3yOUS#BIL+o+j=%{|pa0z& zAGX`5qr?NEN8905#w`MLqidxbSIV?R%DQgOHMo+7(9dDITF`}E6d`kr^K&wdv`5_V z-$6g$+}gEc2=h*gyV= zXjndbW+So>xufmpdnshTmH2fW7nT>G0&L3*D}BpRw7;eUsQ?_$p(q$X=_O{49mreE z#2G=Hd>Kaci;v5;4%$`Q@M4uNfu~rO`8NX$7&N05g-q^yZs8af`V8AkUScsZ#}X zvj#-$Yxi@oE{|E6Nue!w6k<6?EycPBtv%EetHZ~r1$K=QX9p_l{U;#fE?qG^L>8HiEH(kd@{76Pm8crrRvEKNp%jw$6N z@nDIldU$M4@aGj(;}AL5tIo{l0||L19e8vKo9tv8hGr7%Aipt981PH?y zMD~W;7Qb|d z<{OE9NVDM4mhA|s?QPG4D#xqBgj6ngiz>*@9cT->dWV_Da{O}f(@o$>Hyg%)mHk{o z%!0=)eMW@%fnZJyww%>|Galhg2SuV*JqgEw1{r+&dE(2It9h4=#62&rvlSbC4n@qjHc&e@9 z`e}&Vc%vVKjFU!~O2?oqWQ9g!(q3qw(Qk4}>%Rwm;itW_&W_DsC=iE@D(gYl7UUvv z){$(go6vBf<9EL+YR=;jAw(KkeUV|$O?c`g&OCw3?wf(S7ABIIWEI(84#rIU*!8oo zM}}lfO88Ax_8lTamb1ucP(bG=ZSjm!*js^bo!fZhT2q2x!sJj?>|`Pv2s*h(^C!N} ztg*`><(M{vII3X$cCdJLO@tOOC1BYYG8!!4LAP9GwmNL9G3ni@N7TfKz(sXX#8<% zZ`_8=8+t0OAr4!Wh9SJ`#O|8A7W3*IE&k@RPgT50z>3Zaz_n-&9ed(!#5P_^Hs36z zBFv4QC=0H2JXN(Vorq9ccU*Z64lC{ktl6g$~*dV${;6AVN z`ID&T(ZM04$nY@#tU^hN=PrVt9+Um^XgKEUjT_Y!dYhXHee_NaILBXOAnn&*2?&>V z7*`?x17)@vv+g+%g2xj;{><;^Pf~>QN2+FfQ1TDoM7^mNtPqEdCnOQ-jFhA2 zba3rut;^guE6J>~W1i(GHS?Gv4aPSn%!LON<;7+If1B)3J^qFD&zwU#j&eov4j_!8 zezH%k=UY$@cd>D**pL)wXUD0Pn1=IDXOjbe){sqdFpu8s266;x4awq_dRoYuO$C3W z!GB*R9fF|VPc8l#IO^Za5dId-5_Dc#Nb6AQbsoSGM_;0&$Dn_{T(RmQh+yc4P=CRJ z`S%`|{%7L}isiGhqa1L4#l3CR5c$TzA6RHEGmqakuRp`5kY!=T;sgqhS*ntqglr& zzH`$_@l{KCuJNa^SM=YTOGyvaB1{^6VSC5=bG~*6?+-t-%|CijI~Xhqy}iJ*ks_*= zDv8!x3QSd@IR;{^x6S@cu1K2mx2GD31nuL*WTC~+?ACRNW7sa+?u;IdzOu=fiiN9 zBm-!M0QctPN6f}%?1+x-G(a!mkrp15W1w6*h?)NI^#uo0xLB5U%Zwn7&V7$SFfiTh zhf#qV4fQPB6XUN3n9`o<>bH#;hb49D+G5AG%}+FYiQs4K%ZO+PzT7O*K%ELlps`<| zgQ227a!DhjaLN|)WY}%?BxBBx>G(7mgvJ-GZ)O(WIQOr5Fo#jXPmo~cveEti4?q5( znpp$s7?6L-zo^yRKTs}+b=pj5D7?yDW}LF5GRKcyAcIw==s8sKpBpWjm@>vry zN(t55Wh(qlvF~U*WQhLPHkwxfr(lK3$ise(>rM&!xgsXCe*>`9D$qr1sOiz)11*DE+Nw-mTWC7jJ zFy%#L;sz=zKP!cu1jjeJg$Q1~$_5T`k`4QRo4*7iYo|E8|5Wg*A-(!atY_jB=X;qC z_kj8bI#-zkpYtt6NYr|;bo4zaezN}MOC8%U- zNuO3E752SrnV1F121!dZTViS8M`~ zWBDzxjtKegYh&+M5#`ow$b}y)Sxqpt-E{I@k)lX=4_?7TAqiKa9$dGSxMvJd*f$ME z+_qZZX)Ue2Bp*pbg;yr72q5!AcMFg*BPR7Qe_HEFQ4K&?M#_o-2@&H&Xz4;}5lAzDs2R5eK2h8QKTF>J&8*3V*b0f+TLY5^fBop?3N4PbyHut^i;a0P`*o}NYSkswamvm!E zg$)HUD#6v9hAd~t_TP_#Y3&S-NI0jM_7?yzrD+AZkt=R$fNQ&uA zp@ns` zLY~dJ?$zgPyX+auF3HX{|B3=PJn~vB`wqYZqpCYe z9#ex+0`BPS}U!JWEKy&#y5 zGOlDZ%OYIm)k2>F=jBu>zW@h7bV1T*YG1Sc8Na_{LEM|JVOcX-F8?40UsfZ&0&=PG z(JXZaW@eRwuXiG=0=^xCYA4Ev#CH)WoR7Zf8UTtns~Z*8v5Swq#IPZ^q&9-*$0Ly4 z^zU+Zcdtax^E`Kpt^&m4vm=}Chsb(8o^xmgv44I=3pW0$yn}^QlCa+v$7O7F2Y-(e zJ2+Iqk%)o2DQ8MEiq{B7v*ShNIjbgi*|d=y4uPP z9F%#{-&J-&Ggb?)Z`B9IGK!1zh0)?cU(p~bM8169mJI5D-1zsUCPZeYcOScu_5W+= zf4SnWER9G~ww4caV!;1+_5X58(AV;>b5vyraK!(wo&V#8a|vd?%nUV}ujuIP4>}>{}Eb+NI!L8)u01kv2(BYBqRQ&g0 zmyU+vr11t0i@3)4dGKethR`rn)G1iCzpVe&e<61SJ3#)1l`~Iw)mO0l+lP=`ELB1E z)Vvx@($u38y90Qmnc4FxW^AGq79?5u3Q+@_{80&~vwrJ*8FQ$%)JWC_;GT<*qlUBH zwie^2V59GbV8BuQ8GAU~VAk;dgP%TcTC!T!4x;Q_S^tIYNZL`=y3BBd+8Tsu(GaGV*XExVYhAjG#a!f_bUd8%rvnqknX+8FdDk z%UWPLehuEc4%ggtiHp4~Ht20$p0@I40q-t~`aK3iarA5lhioOkCRzKw>f2nn!K^xD z=*UBj0%Ug3-SMOg{RdOBeEfZHwO3f9+b3Ri&A)5hV)w?zo{B~31hv|t$X(zghOFBg zGgR(-K|3Rxx{e0%@sf6CaE}h{Z|z^CY8yz<9^jx+LV3q^K3C31Ls~4%+#+>%?*spf zr_2;X+%JdrXD2Bh0etk@)nGa9pD9Slt6IpaWeNk{Q}J!FQI)zwx~V!_%D}WZF{@)M zOry(Ri{#Io`e`v;e*El`=S`^dT6{MZF)W_)e5zJf6z45?EXvI}M)5AE9Em9@kzX|7 zGVfIj^YTS*j;Y@g)>wExD2@jY6bG|)fYPe3Jog)-Ba{nm$*0Z07bN<|y{?Xipfm}2 z=m~|_R(kaRK0cpv(LY1+S|>EnDcZLbt|pjFHqaiG$V_fdRRDXhXe|99A`Wi|Ua=G^ zOPp7XLE=|Aa+Ise*RRgR=e@MQ#c+ITP`i1q^J1K8kJpv`19>+QWtDGD1*%0+b+>;& z>0BS1PTm3QkiVWRGobFw%sjxX9>Mx3_r3%y#WPFVgc8r=;3{_O#e!12IE6`~KC|lD9KnObsxZ9#Ufd~W58LDAKPtX*`}spX%rb_XjaAig@bfK(EWovx zZblQb*ZbD_U-IqF zBadNhh~PaGMyLiDAk+H8()zRM`HUNz111dJ|At-Pf1zRU!@J2G@oE1x>ML0Nl(JDgi7241=2 z;d+L}>7hV3I$G)fZo1#~l?tNf?e)@l7o=nL9RuD|d*(u!US}S+?oDhhhm3&Y3caj} zN@<-o@*IB_)gV7r!*LP%vRarhOFlO3v+gB)ve!UYx^2Hp_p*eS_lgV&Kig#~JwmQc znrh_nx%DbEdcj}N_>tW>XAgU5xNf%?j@p@<0GEAITW=9PT!i>uBi>pPCi!quE!@Vn zN14`Q@Z(Qi6_7cD94f2~B&oIQ${+6}?tu=2Z9t%O>>Uv6$*!xry>sq%l#l2t7VDDV zjGrz>JI-=7T^>{L zhsVRf)<%`fN#3g2V)q0>+7ELq2M7|QpD+8sG1AgB`YyMDU;=eimhWZ-ufL%w5|dj= zmZ9%dZX8Rs!bAA?=ho(8y4Yj|9+5inAFhYVQ}UjOFn+}}#Ns_qxxFC3Pdhudkyz+O zCroJSLDiu!h#cNQxiXw5+{o4(bdFG&F8S)sXQoA9d6VP$T5qq{K^I*e5KUw-yT{Ll zzO~Ta1P5Fs!;Cq1MfM`x4n_6gECB5&Ot3v7LWWHt!z2bOEhb;jz+7wIm8A3gZi#Mi zXo+UCX%;3sr`vq-*BkFSFJ0%BCIsUip+1==Ju?H5nwbP*))J z*+5grtHy%PP;aVm+nxed(l zHA0UwA}9))YEf@hcKfME`=o@%v9Jj@Uid_@5li~GA(Y0MWsov8bz zU)RQ8%U0g+?H|tp_P{RaoU)+ISOe*C#(@}g=4{({#ITsir1iGMIP!HS;VT)!wcvRB z_VmwM^|nE5Twa~ux2JV8{~3d|<{K7iTKTk5<;;Du%f-<+4fO>7v~o+_v%tl$>(iS&mOu)vf~pZ__>#rB%cTrrS8X+N$L{W*lBZCYPceCY%Du$4O*kz@i8U#4^o}5KURICTVe`T z{=3%X{MdFv{3{!ETpUylVRYpFz6l}J*SyQ`lU9yw_2(y_t_r7Eq=x1SeDO@ttNDfj zjoZr9zNM>8usST+eYAja&Q~*@O3+hs!Q8Tpi1n}i_mm$>ZNxh5Ks@h%@K`(>B@Gc( zkfh%QJ5zJu&wEm6%WW`8L!topQf%L#4nIJ!2_;<0oRY-isyggzJb z$X4jM4icBbfdB0KN9NO!ZFJ2!7mePBR}Vz{)pQ{*?v+frL!J_?Ac=3Nc1oTyUly)p zAe5|LhwSNMcS_O(&`aQw@E-Ux6eT*+;c$k{GEsu~bh)+@Qtj@zr<$6=>Q53P+}i(* zRH}?cWTyVln)gUrhA&8y==~Tb{cjFl6Pf1)6%`U_M)rk*p}>sPY%)8~hlVF*5ich) zJ6MpX+MLIp`bzH~u03$;IQAz8f8F7Uz`;Mgw{>=v0VgTnqc13dgukp^TDoRZ@ zGZ6g6CKH)Q7ia&eT~(B5!N*l~g#;+w-dv$!uV~?$b8fQvm&vK7_~j}NAZc`!-kV=F zOv`*E9@kWqicAvQjiin2iWZAMPggrpiBlUZ8$Y4ire5NmHbfS&tDvJy)GrThqLJ9V zn8ZC_#?Miw<>u!;d|~#jn{70{)Q)`0p$*eQdbg)6^@s7Xyl#9^<4jlZzmw{`|SY@04`_C{f6XMT7*U}JOZ?sZ=6(kq5 zgfmuYG=rohlTL8g{`3i&nzQm*i7P!_%BmMttIrOArG(otHFf zYzi-|%xOR|vrZ_|V;@ru#3T4R_)c25VZnf!opSyJOZn9_G1~|->ULd)bZM|XIzGzv zYf{iR{Ksi05&g_BWS#-kg$zo4%~a@`02MSdsr~MS#~<|!@5DtYZ3hZE8OVa6+3<`; zkbhWs&^rAHT^-FhzPi+qO>XQIuB8; z(MU5$xzTSY%~VBEcU+ksr&HG3KOFaoLV1Uxbw~}ivMvHtz?+AEYn{E1g>N4(t z+cc`^Dj!qCw1UIq5mXzG|I-UVTIlA@j-kEXv5MjH_%MwJI?)?L*WwxJ|Ewo?_u5Hr zueqm;RQ|F%ST-_FV!3IX1RHQ@FkaZU7O=Y!ryC>?srRoy(Z_qBb~BQYWFta_Q8ENZ)22sKH~`JcN!whi zr_G0h325$C#{n5(j7* zzDjavvyg?ySZk>nlvDOCEADE;NOSTHjV}TR(4zJee=Xxau_l30$6It+5-q>_V>}diKW}ke(!L*zzsVB+eRIvJWM*M z0>=@G1%-@AK>sG}1}$4EVke0kJx$j<+kf~abi1S1T|?!ssVm{?N-CvlCEosIZ1XG+ zx?%wb*Kf|i`C&2JtMI zz1}#nTqszt)x>x?G41W1<~RI2&fc=$Wt93i9F_WRswCF-9Mm?woDQ4n-AJTn&ZKsE znpC!rG<#UTzHcaXUoS-Fnok-0W^Nf*xw9&K?cTWgsLNqTi~l){Ov?|1j*0xP+E3^_ zK;duaCC=PXxcXNOH=%C?kG%CXa}}8S)}upcB9wED*emDp z-Gco80--+j+c?L)@$=PEaWnexarsO!+L>+&KO1ik!u|bEgx2Fy!*Tm7%5Rzxx73d5 zq>g&^qa#~}`~BmXAX$@u;a6rZ(n&P*>CWdKE)WW?nQlD@H63x>#=e6joFrhV&knko zH7FIk&+d0){Q)IEOh9$`RiYs8~#Zw%D1W?OE={gs{*|ahDQsT9k=oiWvqKlE`-Zr7U^fXH;IC#X&?Wl^A}M zaJP#YcLu#r(f@CU)t{F0d7oXx93&vo4?=vOVm7OyPBNdlOmHr7+<%w1Z5dZAXV^a?rRYgAjt2yIRF1XYNYGkCmOG`uP zFu?~M?QsJ((yTM&H{naUoEkjDyb}1#&EKW!vPb9l zWRX%UgCs^Tp2oD0!3#E}elBD%d{hAq3b%+-KR?q>Pv4@#K0FS&Yq}fC6-40bBc1B@ zF%cTO+hO>Xbc#TYK)f@-7*#wJrIPk#xSQ?1K(#XX1fP06?tL*pJJ?|uNLpQ|-hIbM z&%021-+UU_`d?kU`EMojkdXh~xf?9#@70JVW+^2ER;>a8dKRX21}V!@cb1|mu}83~ zXU`dJ+#EskIQX9O{u6PNp2G^o{uDZ^GN22B((7LH;JYGtPx(NknK3JIo))WNbr#TH zM8V%%)D`u_hKzu@6(%DA|8r-SER#Ej)_5OvS`=sxoI0m`AUFB%MTbHBbq{gD|&zqRZjn|kI#5&pFDn*T0@+O ztN1$>eYs#qW-;1>vFT_q9Di z&G0|)$eV+mRl`R;*zxL@U@9W9NWdCDKOl1#Wx5|TJjr)T<97d445TuFyO-4g1$MyV z#eA2JTLllh%~o?!*-@0oi`26p_%wu0MAHL-EvRY8Yv@2!=-%O;4Z2F=AEsQcgaB*p zfv8k731ot4-upPwM|Hc%$n>F6>o$!Lv~=Yv$9vn&Kpkw+^~nf9hDrSm)WG-n4?Lcj z0~(kR2QRFeIyh+x8oszLH|jcZV0EF!d&Q*O8_t5$lm3p~q%%O;cdw(pj~pSv*@|6d zR-eEmBQTPhVlT!QTd(QEQO}JHE#2B0DhMpjw;B}9)LmAoxNxU$*6omoCyY@g3Xpu< z56=fW4J?k)5F;fyo-=fw*$j#mvTy_ChZe&5?DRqzK77+*;%DN)F$uAXf5g<-3H*yI)ghqVa0S`g$PF^`i$fub)?@iS-{h8YV0Q|CU--u&i~(^4 zx)J}lyWzM)D4*uHfFD1Xcmi87qv5&2msEwZXxaGY1Zs|?aMU1rAwo^9ej@N(%c*>ncxBweHc4BPJ zhQztKil%(Z=niSR4yTEaQNPTp{hu!^RB4jbNzzK#=We-whmjHL9J3X8A@6k;p-B(d zi7NG?=tg{OmYZ5oW-fDrlLZiqT@Ebd>(DvH<)rIv8ermYwzX8QE`hC2H5_{UBhf=B zwHSJR*?UCElMDr=Oxd*9s)LQ}*y_nCQAO5qe~x%(668b#a&jwZErG2Fped!H_kQ$C z(f-nb&sW%%OP99&&4}pXWu?&QKyb_a(StYM4ZM8Qky6@At#VXb_4@wxeEX^ge>@4k zSa(wK6^>z2oLVKYr4Xa`2(&tj@h`G;`KP@soY>ayh{goH-a`m$0IN++2||rcZe&FM z>ex3UIkcWXPnKo%|6-C(FG|}kw@+KE!RnxAh?G22uTW&Mk1enr<9O!0kQ$W^676p# z5}Z_3mJ7r8_)kCcy&n)JODP4*O>g;$e3(3~*t|ZJo?Icblzl^0nsfiIOqITSuxh1v zBDMVi&^L!z4?eEFzMWt{PrVhxTVvYrxZnamN3qs|gbfsw~Yub7p=AAFEn@+0# za=RXwCKm;EnohNn+f{y~Gj9fQ{6g4~a%pI;2w(n$SaNfSAWlqBr_HP1j6i4shkoLV zjgXDgUmLKR<1njh6o$B#Z!0pi&qKt!PA#nDMDM{XHlJ*qK=w^ z&;<6ncNQt!Z_d^?rb}o!AP(8&;2bNv-el7+Bl0z3dXY#$xAkUKcZjMfMrjj#rV7cE zP5f{7Gcb97HAje~`9&Tio*2^rl>U@E1 zu>L1RiF91lMPoD*-xOAd11Iygp+{C2qa!f2RDplEagp!XJO>i*Jx_4>SgGf>Uk4BW z8asVxVX%*a8aGk7IcRUCwsxaJpiJCQN*rNOio=P=Jp!qrOUNf!R`urITIoA`-tE|n z1h3Hmd?2jZh-u*kS;xJs;+6;(MK(>s{subw=&!it!w8Q1qaT&ed&;Y-KcO)mtCrFt z>rThs5|r>Gz@+)x!3nwSK$$x?ydCRDjENDOR=c0a@>~>KJYW-HKJhAiTOc^gQo`|V z`i}LWu?#0dj8bFeBPB$J4SVNmu@3jy;W%|P{+h$z;#q@ukSTSU$cl_{k7Gmxws&S6 z?BR#%j7+NcxZ~1XbwDEEY@9E|SUKg2q8r(;SQ;frq$7cjFkJOvq#m8$VKtfaIu1$l z+H6FLY)73Z6tHhtsc49nK$5)#!bV{Z$ zuB80Ls`#GO5*uv0m-XnAqqNBO-GV~1HJfGV8j{a2_@*Y9I1~FRLt|fC0j_Y)PH2HX z#T)tuoZr-&sva}OOlutaM3+5XSlH?#`!TnSoT|wDL>;3Tb7-TCvU3mO@Hx-*U*cciS=^z zA-p;7CR2_@JHgdU6)1GNv*8NUrfW1}S;U)trMMQXxIVCg83vwrJRdZ3&J>vDq5N?& zD|{N3fXc1IR7zBAmwP>GTFsQqw~NX)9$d% z3UH4fJKCTMY)^D39N_W%g%L9tE+iYZ)SbvJVk(RjD}@{z^)O_)J*E@-dCp*)6`cGl zDBfVXdhPkZBCp&V*>W=hi`@^Hd3b`s<#!YEl$4wwH-ZpDq|kr(Gt~v*=V0(Yzj5bz z&b5P_eQ1M?xT)KYLL&rGX9b>mH1st=e%%uz?c~0H5rqN-N67STG5AnOtTnU2-6S8t zkl6o2fq~-8+uoTMb2VfJNN99zNINFP+%ifJkcrpcJpUB)xOEVMXTc8??TPLiM|mX@ z5s|8343tH+5#0@DJwobep#&?h2ChHYLOx|7fym z=Gx${z83rtKKG|c#*8Y$6|yBEq7qAp_&4+-Evk&d2wmPu&|b1}c+(j|ei7+LOsR&bu~+E(v4)Pak0KlDPgsmKl@!oy~GZ4O$Ts za%&*;>b&CPy8P^G3Et}3X52}FsJo5izKN!RH@GtK(*GR)kGz=K-^RGE^I$UY|1?cn zoxv*EsN66K54|*;shR)h!{0{Dt`yN3=6% z2(i9h3fORDk;4CBrT=G4r59cJJ33mEUQQ_b@521&AwbAbq2EG62uJKA{db7X_ha@$ zNdJH=#nckW{~;3d?^fKu-W*8uO=l5@pp<-wxKYkg(f{|VP)7`^Z~l?O_Xqx@@~^{NW`zxG!YWJpNA0C`2W?K#ZJb6x7d^+-T?f4-K(O%A{lx}Yf>49nU ztxe=O?}umhSZ6ISHL8uvCr=nN2yL^#+uw`@K_lMhFSS8TXuRrG2iytdaxI;btJE0W z!YaPH;%tI;PkeG!4pqma{~hZn7dBTm?y6?O2`7R*in={IBG@mt|m2vleD7gdF!#z_VWLOdmYbAJ0@nPH`Rcv#YQ4Q52=~1SH8Fm{bnYtLhDiw|ejOS+bT2yzaWmHwqOa8s)ahIBPxV z5k-&9p;r;#i+Ys>J#+6ejp2ZAR74#5B2NCpP;^}@$G8>m_W=gW+(eD;1q|P7EcL6)|AUwNiG}kq; zWJg>HcGYE-(3}U6O@twCUtzOf@DxXMhN*Qg?H^mrbEv+FR zdf0i78C-~P@L|n&fyiYad^b=)jv1vG{{eZ;Pk+fmVG2v5SmW^%F<74@!Vl7Z)t7?ffx)X%ntP1%n}y6kwZHx( zK`1+70dI|c&|lc#-hGOGnnbXE(Lv;zenx@%W~JYv`1K_o0rs7($V-nR&dCfSbx**W zh(Dy$3UAs$ICMSmV#%0RZ+m}SaFN`&+UNxZJ{c+e-9NYQ*6?3#7fPm1;upffouHn} z{v>7Vx}}zym(RZdhU7Y!9{G9M#^)SOhvZ`D8S#}m6HHfRiD6%4%83gKtMGVxzIs2% z(@On?{%r%sv&d5V=+hXcS@#yF<%)=zal*8YRW;JF7zzOILK-b{+KdVBZM4Y@e^ z*vhs~hsf|IgXlSv{iMqbbJ76V!1QO~J$c^BT%~HE%B|$P@a{ms8%c)Tu&#H7*RpLk zT9~LQpml@N^=kbgem{$NpXdAVT?eln?-6F%7hjxyd(cN3ulu<&tHWy6eKM^O<;=YY zq9c}S@^$vb7e11JR=i3bQ_{|NUPTh;tj5N&t|ew|7NO?OBLNy0rD zv%!ZkUcK5%{x7d2YD>I4d48R!g84!TpL!QoFfk3})U}=$MyabeuPd@J-nNdJ$`sEEt1rTuU|ju8O1!S;g_OP0bTj93jNka z{jtGD@`Pq|PsBUu{Pc{q8&Q{l)rnu802ZV5`4pNle9%)*&6>MUk9ag}xJPk3i3$rG z(vW^+)QH8v2g*!T0y#q|r#~oIgWZ26rg-iDGOX!dctu6g@t<(LUF~#eTsICVvLO}* zn)VYv>c6eCu1@zvd)K{<#NWfR-jY?Cse?+r+$fZm-`)h_vA~(;cz>4v6+IDuzwZuy zD5BmteFF6McTAWSUTa`L z(5M<9{vy+4B%E|pT#oOKjfSrclD0S;q{6G6-GA8-bmq}+^;rYy z=af5Ozai>9zJ7y|!^w{*zpWP4GBYWa0}c-(Zj7aRAV+*VfYt4Xtv##30Jo9C{i=-i zlUr}RA8we#vX(U$FEV!F+s#PYnS<9{Qo1XzKLNbB;XKm&h@HHV<1ihTXCuZ$cTSj} zUOLpoj%e>IzyfPcCs0Qi)9Chrx7fm=6L|Vlg*F$1;%vwnhgoF9>Ser`fGe!V0oL>n z1%M0oyQLkNueC)#2Ij&R%u4KoJBbCl)E5;5GP2scyCE%?-%_9zraZ=kr{@YpYhom$ zP0>(=@Zg{9@nwc(GF~fV61EHN4n+RXG>~rxNo`8p4}m`k&oP{;AajyTx-Pj4B3) zTmi#k6rZb`u~!7cyQ$}YT<5wvFiI*FpJ#?;-Ai5=kg7YN`McHXjT)>fpRcOPJC!@& zy<&X=2z2~ltKT4@$JO8b!lql_n0~JnKGhK5U9*BJvp7ubun*kS!b<0d8+t`0%+(Z1+ruuCLj-p%-qVnOf>j3NOU?Oc@U-|R zOq;Z?r#9}MGn|9D&3liKqdh9;NZ6~MX zfn|&C8i44D`t~*}1#Z3ZhtQaV*&@cjgL)7y#0Hr}PH%Y@!BsVz!#S|#IqPADa=GdQ zAY%kpvEXo^PVQ=s>iP_X-P7T9!XoP&-fW+k64M>ppByFvym8xIi2FtLOm+$nyh3ge z*BzWEO1?8m!72^?S~|`Y+uJ~5s5{|nk?K-Li!F%13(jSV&HG|zR75JYR{*K^7Kz@;2jlfs+`98s&+=?f5}!fd<})4tZKv@dAgjqPVRGGc8w5 z#QSth7J9+GLg~FS!*Rr>?0r;mE0&~q{q`k3hKEWQw}zEu?|*b=9$uyW+hfCch5H3W z-uwl;Mi-c!SaAc5$mion#D?Gt*OQ9^_YB`#%jmcG(S+(iir?0X`jR=MF&sBYf{HwU zi(+X@asy@WcwBK3?gM;R013q3XmAiON6U@dJ0gWp=nAbPdu>og11wFE*cutE)=^jQ zM4LK)18b-MU~Pezm95kI5#SO2-CMIy9@+2cOel^HxF;Q@Zv(QY*L)SXW_Ok!`m@Sp z!!fJ#OSLElABevP7z+h2F2NT=Ll|T?4hZhz^Xu=<7fVzmJovo5EhfzNMnq_;>#h)m zFB*0X(WiB8xs~2v@iRdx?L9L+(g8bKHE85^G%k<-^|-={ZAL3lt(_O}b&Myx)u#z* zC28|_CucXgtVja_-Y`VpcS@Admn|@dfbPwC2NXJT?+gR^=;5qI5(>M~$F~t1NH9Ctb4BWx-P~3MH=t+EI&jfi7_^;4qKX$|kECJ3-te zkir1V2LSw-X|}B}qDg~s#;iCK3a5*SG;C-Lbc)HKM~RDP|dw}XT&r5Fk;Wr z6D#aHBrZO}pXImHY>PHK;g`mI2Lupf%~YM?RKhy>MnT^s)DDQBH0b!37O+?ERx8VF z9H;nv3}WfDD%)c%mX$BrX@aTkNM6Fvk!a8puEi`w^$mObV^iy;D1Zeo!ref=4IR`E zblOn_=_4rQ%5G9$vbHl&J&9p=Kv?ds%$s_x+pEz*slG401&3Sy>B8_SO3Xo8pV9RZ z{n@GxFF#W|#bCp$!w&mTH-oW&=}yDdUiwu;l|1hbq$mh@f`ISfjM!A+ic?yTU*y(X zPyc0M;NCvK=>tm?yP5uHR}b*@%Flv_`LDbo^yt=FAOk#u6WZscB+hg$R|*$RD;%i~ z!$=}-+ne=WhQHm@ov}-CzkHZ;let%-S%m3d_A5Qeu|eh8;-ioKY{g^&$0x1c5YBK#!Rp}}5DJ4CPGu-!MNIkavDU@#RakQS(!#aJ5`>p}ZH0~SE zI{ZUsZv|1cE`VHZc1e_XZ3!WRTHbiiDO&PkaJX2XGzJmlL9=4w)yWfDeZ2;ny0Qm? z#%&8{(!~hKhnxC|BnB7{N0&t-sdzZxZ(p)_8z{jCxRtlYoiWJ|EUw|C;oFdd;uhEW zysXc5f(R2ToD!oN($(ixFlD4;+L2*I*N&R0ANO=keP7J>PPp{LZ@FJ+Mz)yCfiIk* zK?DU6J%){Rb0RrkSf@I6E0<7Rp}yin>2|-bYz>r`LSQkyE1>jG6!rqbdwQ&qT{fO` z2uW?2XZi*%Ek|#8xuNy|M##j-yF5W>y!52es2IfjUl(Be#8gLgZp4@94vg$!pBoU)qi2;-m`OC7DTV}#ShQ!0pXv8Lm z^n&CJsRlQIiaBNu{nv#Fju zGYt((<`{tX%Hj+UieWs`SWfF-28g3&e3Ct#e*Uod`W=fEk(0yrlYJ{T&o7alvS$j? zmB`}NIOYmi@rfU7Wd#1VZboo{KyRn)lc2GeewV`FkfT(%#b`@g_A@;;g*P zE1Pk&+Uv!P%0!1~DQtRRk!InX;xn4#V>mbd3tok^;#E72bs{xRVS>-`Or(ZZfo#_mYXll9}uU4o?%t z>@HZQ6mo*2dprj#O7Q2=NzR*P=hpBrY6ttXc@gQ1eEpYTp!3H#oOT5-2+YF<=9(;s zZIHoCt`!vtKDy$@aHFwyqJAo#1_F9cObL5Xq<@NuuPlj_ZY^K%f~R$6NSttx(z0TU z`rc}vTgaqn1?sM-%9@m=JdAQ}JFJL>_^K1)hFY$x0)4W=ch*=+aR_ABlwrlT(F2au zi0~tR@M4EOUSi6DoSgRe@v^4#N`)iBZIC?zoOy>g^9NC48_bXZZV-RY)k*k!;$Ol1 zbLg4~jh%T4ASy0tX#2w3DTHn$G2INFMiv})CaK!cVkiJTDA-~oWK76t{F5BX`W=`zSBpN>!uCs#PFy zr=5t!{cS1hgY2>BqR2sXfkPg(JG*4``aNP zfS2iqlcDnH7|vcpVglnc6wIv^8uVg=O`;yZPH(PK(6cdVjAOyip3&n%h?Lk#v^anK zZ8*JxTNX6$!R7b!47NepxKx`I=S*z7lU3TX*uP#MOeoi0kcc5)IYKHExyBaa4;!j~ z5s{CgMdZ$>VNeB)GRML#BqnbrE6j0oq8kq)?7L*&o2Om97@S2T;Da?NONwCk0LA(; z;X|`I((T2I>LilZ7v=BFt-};X8BGwHGxSJ?Yl9-eEeD35Vsm`hv!l_Vqo<%f8z9m0 zqFRQGXQ}i;RDBs)ulI{67o-l}mdyRJ-9=gDBBu^#&$h|c-sqy=fnmj4&s)k<{tAW+ z9lSPX{1sy3g*vvS)CV(EWL7Y!$gFVa1mQzg)a6YOh-byATiDb|tSWUUOvJjo7%n%a zM9`MDC|KF^+`)ZB9jwgs*rL6WGUY+2udb|)a7T*Mc-`oN=xp%jQS)F(4P<;4WK`ec zN_rK{)LuSnY{?rnT&97h0gVUdHPvQ9h_e>G>f^S#?O_c3 zJwapwQ+_Q(u;FBD1QZEm5!Qovf@oqW6DTaV-COcS6hig(y4-r4wwp|aID4EpI?VVw z6FC!h62#R=q@JWWot2?$5Gzy@50}ETv_sXDzE0dxOuXRnZ{Gk`@(c&oMBvnq!^{(g z=*CX~1}MMSf#~foG(G$k40AsKot(;>(0pL+BLD8qLWLq>6?obB$pjdutR$j(lQ!eB zzRyq=HfZf7PT8SR`<5tot9=MYX;599F$KR=|o6#x;e+nF>Fa>`wxZIdKe-Au|Cso zRB>FD+rePXcGU*@Z}2jcY0Q%xJ7WX9>^v8E&R7b{JiRi~Jz`Jq&f zXDH2^(%B_c8m9ae-Z6}FLmTK;|HIX*we8tCtM=0zk8OW$92BM`mtBvF;={)C@mt%W zs$BlZeOQ}nlk47Rn(Aix;@ctHcmJA1X^*bRbHYaL1}85)zw}IjSBgI#T)BHv8Is(% zZf$Mh6P;ha^iG+xsft^%HZ%69ro5B9pNl*%3?1V{v%7a+U`cOn&^LFjhZ}NEAf&F< z)=V*(vy^+>*OZbQZJ^gj4rJVMPRCy@DOQ`EfzpywfFCu_n=ey3eF9>}!`++xCiI(w zV<>($J%mAq0k(<|FBkdRny&7Zh+|duxt+Y~$(*r9J64BM^SOtv?=?y_9j@R{yBi}f zu;b5EPp4=J717L!si!z9TJn$KxW$u+#=?2>iALq+To(R#`O32l2`h!TPm+5Bo8_L8 z1`)BSALtL7Tg)R4a@998cg8wOJLL5rR&r^w%xYtHj=A=@;?JZ!+S@O*PxnV^b)Qj-G&HHq&G{!tdhgWJSTU|Zff?v zlL*Uy%r#Tji)JW%ESw5+A35tz;fSw6$$sI6FvS!$_e`j6Ix2p`*C`-Zos>GS(fs%o z)jFbTbh+#LuA4}}EQjb6Lh%QKGxqJC?&=0z^_5u?okVi}%ZZ!HPa>vHEoaL(cMz^K z)+uX)SCb+7#L1pJbs7-q{u><{)uii&fu-$YE3oJIdX!6mMPOL&w#zw#T6oyz2BSKt zy+|(6Q!AG~nM1EGI&)~JBR8{lSGHQQ5j?R=xk>myZ9dEjp}Ov`q-~&v+j8XPrbnc& zT1OGD7QRGx;V0eI)YL|s{4`hFojAM0S{b5~hd7nCId%&4d_x=V2r?~{Y(&q|c4gXd zR&w^lpCSf8WNfoz+6?|)q%XhvC1NyV(M$1xAaO`4Y!!l($+Mo+Rq%Q64#}p+{%~Xa zv59tG%Fcx9#NwyU%F(un12F$%qhB5p8Gv{lNV3@Wz15$n1??BEnX&w)Pc8G2v2Wp{ z52kcP{Z7>|liWbao&@UYmt&S_58^=iKf-vh=| z#DRK|UK!!nd1f_~1Bs1%w8g@@y6Q?ILy`?`A8Y0Y&D5T8uAvMG3xfGL;A*0JpI+Kq zx+fUQv%q|3(ByBs)V+H#2L&e8pZoNxFWeFA2T_))L>i+DIG_ArydGad=iSgI9yg}p zIP$nun$LFJ!nO@rIosU9N8RBo+d39HX%+2{s%f3*!(O^&LV>d97AF(f)AXeMgy^0Y zC(JoN^AXh>_50C;#tys1@!6Mpy(kBq1l}h2!WFjU)EE=-jc#tX6%xQ8KGeCFt)t|c z*Fal}I-5c?0hOQ4Vs0S3B=!*8@am0*#p_}mgY*6`$uHi2PWW&q$TkGtkq0&W%{s>? z=;U{tGp3lL*sLtxe%5txGl5L2^(#s~CG)81^EYrrBcX%?NeE+p>7|6E`s>7MB+cRr zpgGksG4~kck+vbSpN#bc%5e!Ws2)?Ac~M7#RTJ9)QU}U+6h6@nvz>266AkG_(pv#= ziFDPM6U;N*KW@k6$~@G}4fN$;YHJtj3aRl``LxB^PunQSAYX4wEj6{%3e8PlVGD0g zw=$sN!wQUsyW>xw7EBc@+fGr?)k}RSMm$=sBw6W)$5HDm4p;?WHB(xC-a3|P2^X$N zb5_48(5KaxM_SRou%>AeRi5MA9HwkPcy3LPUYFLL%3f8}bnlPuh!gl6+~umQDEAz+ zk$Lz^<`^X&|E~7CFa5OrD8`>|NAL@tcj%Mg(2ff#S{P+ZzP1sbA6U%X^PQ7Of8c?6 zawfJVSJ2UoYivBMZH=WghFC>fTA#jlpZjk9aE?z%8Q#gq3Pn{>Uu$p(Li#=peqN+f zIV~Yl_PiAlU)1Do3y5;}7DLEdHaC8^Aet}AOdZpBzeYHy@&UWm!?yiq35p&n5D&pey*+ySr zwLMPj^oo%%!i}(SYb(2_)?FA_F{Gv9ha7Au&vuY0N$hZ9@dpG+(Hr~cVVWgfKT^7J z56<4INN-LC-QJga^#rlY_;Yi35s0RU1Eu1PH z>j$MB$Yj@*;6hj7qRKWDKyybE&K&yum;t4X;3RNyy{iCLp4`t^*l^gwX~##BM#bzo zPZ@fgTlqUE{ar$Ey>iKxqGrSvkPKL6JAXqG3G8-17$eKgm(-Kb$^a-!H|P!oUW0t1 z0mce(02yRP(CHR+02T(^&pY@8hcltE@eu{OG08Yox@KpCFpxdD_Ua7>#{B}YmqR;c zBiw?rbMiN+p-~5$QrBJqhIRN8*ulp8Q;m1KhFVr;4Cp8R;Km|%-xiBWP|f!ie>1!A z;l|%A@yW^Il$Y)&w}ovI7s>fQPhal!KjE*2WP5tKU26J{AUO~ZNC1b-2R%7(+mGyJ zHa!Er5Q@TyFVmS(elh*PHTmta7dhXK)*!M`YPjK0@Vb-j2Of<}OCyT;^vfJ)<4uy= zpFHRjUnc_dUJvQ~&6p+NaB^bXpT@iM(8))%LVdk0LwNT(>G7X1^TQ}Qh@$IG*yi4) zV6sjuDO;c7AROiLD`+L)FU~>-YeR@y8`PjdmYG_&!*SO zOxM95DwM^F-7{RIXh`zE4c`19XYpZh=$@PPEiqe2YmRCdpq>w;DftIR@~cEOnrl%F z7_7yjA4$<8pa$H9sRy4QsKgB4bT^7bz<7T}rG^Rb`Q?EKmRV7~kw099OeIIo_cUXV zrgwv3e`yCKJjo3%a#~32@#6_&-pZ;6XE@Uy{AOG4p68vg7#~g)(0Y#y_s$fV61#zA zLBL9h%(9VAxK|(|m&u5=7>hG>En?gu87aIhEfqX0gY8A9&=Q(|Iq59q1u?ki37t1; z{sd(_i82&Px{tP+0rY5i>Gif1JW#emUJTS%A-Zv?|sO}E}(UzyG{VA+w$%3%bF336SdgYDXG z0w;#!2Xsxg&XI^US9@l)$zQ?I4-b^n$>~d(BbtoF)F9W|q)BM&FNvvLP0F;?Sm~(D z&PG6L-1yZC?Nl2YE_gm3Drv}$KQdfa+M|a{*saKE@mL;1LfN9Uq8t{;sH+)upFmHr zBW5uL{&0gqR%Pp;cO7&*io&H$1f%nxba}j$$Dh{p2CWzj6sn#Jm+Dhfm?_ z?WEss!7o{i8i z+6*1M0h1*!|nSlB8J{q zS`4~1mTvlpC-KQ}z0TVW`&KDd@|D^pn>A)|;eEF{M?$XRjg7lfqG{`F7utoQe^Wsf zD(YBDMiH-$kmheeYy7#M(+o_A=fQgcf3TmF6q`kY)w;;;HFv0MEx~)7u@!GkchPa| zBVHn#k+JSO3$y1-bW+ApAA=eSsK5vB;SI9zlT?na{9`LEd7Pt7%lFsmfKD?^#&Pqs z&U;W1v8c$g`(wJ-$&NRSV;~IZl}_slD<*jJ!+bhi6iw$#8@qnH$xw6I`6IHct-L=r zU(dOt5GCR9P`Z={6F%9Q_%dz|=*J0)_xfkwoyOs$z~{ckc);w?C{y&@D6cojZ=*us z5&DCptl=zv6T(Uh{^^mTJ490BAOc2Esw8}YmpyT&re-*3$qjvUgtsD`E`tT5g_YeY zQX9fzq7_8@7i*RFTCXV-+^j|n%^H44;%+|vljZn6vt#3Y4i?>Ogtv7n$U#uE7v^dj zxhJFk!*%*R@#(*8xbp=C1haF0fQ6D&Egw<8q#$=}$0=w%B`xEAXx};p-7=tIS1b$5 zJDY5&z*s3=*6JzcI3!)OyGk2XQc2d+tM>G+@M7!{mFMf$o(_~ccWVAdNNa$fN&!#* z%49?9O!=<;eyZ`Qw-8WqY0jw~cme4YU+2WRU;2`a;9;AF8)jwis~x(*)aA|7e}Bp{ z`>e=|f{%=EpD0%KR77k7s95!4!j@#i30z;_6RCVhDl6=Q-^)Lc9EDy?0XI6+Bi29s z2n64A$`#NSg3rJd$r~uuITc)Djf|<#vDbv4LM#Wh#yWByN31PNydaIxs|Hd#P5%qz zcrlTk{(1v#939(hvn&XO(lap5ZrEh7y2Nt!cm?A+qM#!*+15Kze1JM8Y&txspt^-v zYi_LVlAG|NI|6RZWdDwhhIc74KPk{EhiUZU6;$i)!JIW>$;g^Wd!_u<&Ef#Ok%P6t z9b=sc*|*5=^R*M}SYXq*MZ!E4o?d!1Sp*4|-aR-v6VC>UQg_yKHN0%5E8;Q9h1cVj zeG@9rgz^gmnGxK{w;3pGog5TBApMc+fjI#NCq~=Tgawj_+J?9MxNX;(KVbX;mho$o z%Q{a_;pk0&!K{)7C7>%`w*35(AybSI;IA*^v!^3->Cop;jWM(qm*>#OX1o>|uLxz_ z^Y_R6Xx*hTo&j0@0KunkwtZx-=`Pj6NnQ76Qet%X)eTy-H|i?#E8JfIHu@J!^xR3H z^DCE2gl(jppOq8ljH5sjbe7;vztC=+pTKmdzQ+5y;^#%h88N%@^hOhW^Tle{eubTJ z)+sF9vD)^!fSXwQM;rRm-;zk|)zvmuP=5Uy(qpVauzg`T@QC1Gh7sdXg&Ldv4N8!pga?!-czE zt)?!Gx(ARylezoI{#}h<`c2V?85ui@C818>eZm_d?pKrom5;D8h}AP(5du~JEk6bk zr3*xI%jFP=Z=J-1BN2NE)|4D<0sbc_`Gr}Y>$LOoTyF2Pjtg0k*B|j!6a<=NIuXWS=B}W#G;9dZ>M62-0PHpwzz{7i@ zogr_R$n#OyYV3ywX!|uv_Z&Lw2edO9M!sa0z?vIcp8GsMNr2zR9$4gQyE=}-YxOPf z%sJ6{ad|}|a>6ZsJqa6T$8{8|cdw*WM>`iXnhU1TV95H>z~WP~C%DMZE9tWSE1z)^ zg16WuN)AGw<0aw3Ak+lD5*V6WSLhvGlA&xfg$#9|ubVnudMKQSIdEblS7K%A3yoLN z7WBxqvH;3Yfb_fV_*!`jYKY^b4g;~(4BP>I&g8X9fmO#eYu;&=f0T_Wm+7@Pa+}u% z@P;$3?|6u66egil6)d*X*nskDF1SO)Sn01GFmSJ=grD0B#6UVv8?qb2vVAKX)U(8N zrn)u)4z|!4OXqpDLo$6U*QulJvCW2)UnwQm;9L%C2Er;TlwbZy-UBzg4}5t9F6>IK z@9-}3Pd;Ajif!}+ki2r~-)*inl3#MZFAUmIMGor@q(;cmtz-0^4Vv#)q%ZLwvBb$U zU70JY8_(EKuU5#eQ6HR$$$9srR&Z|teqGhH7>(Y`!0`_Vr1BQm|MM_|+JKqQ?0C;D+-7Tlq~e(+9a zxP<}cZoIJ$@#sm*2>4roH&2T#5(dTTXiL64L2x`b1XaDrE2nzY76l1oAkRoNDMJF9 zVbHy7;v+L!@*tpZj5HNm)LjNgYs><4pZ|F8hsut$F7Dkd{pj?W`OjQsZw03@9^)H< z_~CDx#sjrG=c3TBO(|+q?+B0=tS65di)Sk!gtgYi3x(>7A2W{kU?15Wx8igP&N6@b z$F*_Q`W93tg5gQ8ucW&{xInMyiI3qVrV~eUuvEWqNaJ~+C>|Pken5? zx{0CS-WiiN!9s(lTk837YZ}{q-}h2DW}CUs0YO{a82l?+q= z&2J9zN}=0sy}m?<<3+66hTL1UcQ!3vBYMy5*%!pRb?Qe{^dDq*Gly=Js4)@uaQ0DH z^fWG$TnhCh)b1e(>m6<=Xs2r-i*3tfalWE;QCc@}M7AV!hO7#K=}@gtaFp}E8l+Rv zqE2Cy8;*dkCG;|2#74=X>hqOwF<0DO9y!A-w%!?#UnkBy99s|_g|H`QLei_|FCB}q zg>Rxd@FJV{0?D>0$5y=A9IaI{zUrA(UqB5E!re8f+)?0iB`CtR9nAgmI#GCqWfNsi z_|B3#s~wvy-#+tHP&bJ7U2|Ab6;h90$z~|l-C4yar4K(*?f6tfjsXPlwY$#dy{?NB zH@9qNdN#`w*yy9*x@!XUzCwl?kn~YERf>L=eBht=Mi7Xrrw^w?uYv7f-Q(XU@s$R) z(ry#JxKaNm_3T|>`=;hQdl5XqjX&?Ofg#vKQXZ$=O_B*~g25dNH4^*U#J`-BjMa!n zXZhpd2Z^jrF~LG|VMC=x0R2D-@9qIdP*6!zUGOgwAP^=ONsKIp;{uWPsXOTzz~I9b zmIHmktp`9VY?-M{5!?-v=kE@*vc^s%7pN1YY&uT)r6K`@S>cnu-zoO%I@OClPo}I8W zckh#A+LMr-72AbwE;p@kEhNlXJQX3ZzKxnrAX$hRZXtOystaMjs z#=`-N$BzTHqKT3>VmMT>PtVk2Ui3kQ5tW-0;udJrdVv+(sA|Qe%EL!(xowqRdqE}R zwGtX%A-9?O`s21ZDwK&3ISTVqd|4O~s1L*WUc_jvT-|sb{v72tGL2A*Kg@+I=KcP3iqt|vSu zS=5Y5a0l3x0*^JGNnJZpq^$SW!Ab1}L^l-t7$3%|9P$vS%6je8!9omUuFv*7{52+`q8&DFoR%Hb2(!IaXN z7xaXbHh8Ae+;ImOqjPc*62j1~JU8`~x%ZbiY_iVo+fk#QC&;}=h-si$No^1o>&K0a z)f?|~dsvb8?7Dk;@9{Z;ZFgAFobsYZpLY0yWm5#TgCz9BUCHw5qsZHKS;PAy1Ofq5 zFt=dgEx$dD3M@G=I69#$&b1A*n?{W~6YvuoQLw)|#qJgg#P{S8)a&46MQ`#0dvM0( z&vHT;;d`Jpj8Gx2tLPLEJgd9)9*-sv2~J=T8u04l(>9DLtyYI-Kaq#FZnv8)0d zlRg9`yo{=9JLWHQ3NRV-7|ym``|MD%I}8Q;%bUXc2wR6C3wK)rX9iPjgZY~=%I*^q zwAP>Bp$~XC&^xK{7@?S+C`bU=D@fvaie)NE@AcjCaZ)-_WgZOr>p=qHRXBLD`bAwY zKMY5~F!LqGbi==s@Z-sNLClAd%UXW#e83{wp;YjnOn!w(KPSxr#)$018 zOc&{I+oE!zsL}Ud$f|+qkU5BBI3|_OKvTliDKDRDWVwLN{F&@O)5n>;5>QyT(ja@K zI=??0wbctu4!cGE*$ey@uYy*o6g%MJ?FzD-F5=KcJ1^3?$+1OJ~^F9d#k`i7*J>)!-(= zrZ38$J9~VQBG#HQO+(}!Y}Gawo#+vn+xEEzHdSO8>ULV!ktXi$Wbc{{TGnm?YX!om{Pbr zrOmfnu*OE8w1z)$QBx0r?)I@iS65A$0U^5@q~4N-4Itac9q;7C*Dh!7cE}~$r;%Xw zOg2ho=O3&EOp(Zt8W3_KP}l=g##hVm>Z^qsO*}|{rA1xGKqf!Q+7N=}BZo8+1en9L zmXgBId#DFZ&UGXtvtwJ8_hm^wdV=QChyW{LI+K;oXzxeJlR2p&N{A&O*n1_!bF#tl4=YFcnTj7 zB_DZeY~1O%+i|5n?uoYxH=L5B$G35&syZ73YGnn-TSX=ON-^&A{BSH17CrI!!%AKY zPeJzL@K~@6OIAwQ&tc0y->6AqlFU5pN5=gjs7#+)A&4I2$Hsgn66BYgv@cwEH$Jc> z*6P3(KCx@zV?s~Kd3$+%SmGh(;4!px7VXCOoek& z_>{U6Xh|e2wl(-noN{OyuyFQI1`sX`25b8`-&ncNGhPgc@*z=?E>G@QRwoLnfahg{Lvx3UOHQ1^W8i$W4(GLxdM% z3-3-Gr^YEYMQ5S~xu0LDYr&L$)!Nr5LcHg64sWCZ@*Jbh}tr;8lz*U1t_uOP9}^hrsmg@-4*trs^Y4mQlM$W(9ld}tns!kwmUwD zcSHfQ#S%6+`p`2XD58BsdXhB-hyD2zjRsBzF2z~xsi|Yfelh2Uly}W-Ij6OUTF9_# z42*i0i|Ro;;$eG(WZ1lx)LmH(epBqdn}wcqgM{WO_N?xi+(+E^&;mK^ zu91UN%|%`s*9+G{U|C7Fo!{NTo3;}3*ZY!}k48eoXrd-hYoSP~JSO7_)LK8E0pz?t z*9+ZKf_(kXU3rx=7GO_XmDVbFj!YxxWwcb|X7JNT!Y5RbBeElAZaP*SD!gpXjT;79 zZG1`RsQ(@r=@swR-+y5kZy?dR>8*n4nq}HjJ zKPl9&z3oHdR(!_38=|>a$LjQB0}iqPM^PdgI%DmVBWH|ZGTo^xBem+Km$crb9!d>F zxbM(;i@bB6Pn!ywuD8e`f*+@?S@-%+pPh6}~iNwirK@VaeGTbjmrcithoGHHl67F-dlrN`^g5g zMXJWmM?D5bhp+coFJLnYowel%3A$jz?>hRt(|q2l?_Vu$iHqjM7#HBj4S-nXCL29e zmo7ry!jZQVijD7SZXgaPNKw4YQ;G=I3GydZ+!H1%ZO8)Ul>d2_oyG8}otG~hmj@z~ zpe48T^)&d@|Dmnl!mq=las%w<^3B-{$^Ped*&*ERHT=|pXOp0X0r5XHzjR`V8`8rG z!C)#lD#-t-ZPG)Jhh%J)Z-4*8@vp)Emje)yP4D{89X}JX+0XG#;%tlRfYr!w283)_>Q?DLU$;LxpFbRr@9P}&2 zz;i+7@u#l2`+W<;WDc*kQ~8g73y`Q4E2!57sQ1#mcGj8p1QnbNA=KM9KT(gp-`3~a zY<$tz!0yzIq{0UCThjpar-{3RilUhFuE`emuY?OMEOKmaM(|A|8=N)@+*4EtHQWxn zqW+v?td$%K%M>3p{#hU~4AcNbq8KO0?bZMG$N3*x&G^!nJ;=-!;6t(HtHclZk!b{^~+-=54mA zEv4_0%^aW?2p}Z+zobw0&S+|Rr{x*%8 zQBK>6cCD20#97}aU|jE*n`w(rk91OnxUV+_$v!qqCEi1U`NtD?N7k^{EvtJ}N%eWF ze#|IGuLSXF8icrXS7f5gIPSpnivyrC=~28%duheFLx=f7rDe8%t)tf4DtMfi69Tdc z2+f{Gkp}-5DWtLuRg%??|Hs(7Vs%#-?)=ufqDo^uHd*G}?k{%V{va$VsW+qlE7>0X zrn>Ni40L?$QZKjLbd%U*)QYX(uwoah^qfZn2I0|#nnvS@77Z@5sx^bxC+DlRSXS-f z7oCsFiuH^bqH}Zx?VW+zS=H5*;4e{m-uLpW%uJl(YCo-;Hba;MjC9dLBYQ`8tf5d7WTNJr*UUX zD-(;)TzoFkP;){(K=%N$4Z~Gd0oe1W*8J z$_DBS6MmA4dA3e_N!ilM|Ay<1VjIMi;`fBJ0}Kq6NSJl@j`7+VC%NId z%}`G-rKIgrL_o*I(Hf(qiK_xBodTsXn1+LPf*9NAp;VFLXa&W22A`aIM9B75!jgV# zq{?Ckq14tOZh9QqyAoKv?>Ux`OvBh%e?Fgl_no@fgDs?S`z!%{2D|kw4IW0xBTAqu(l-j{lGFWpK0m2h!{=F}( zVr5~Y5NRzX{C51z`MSnzNhxrXGvoZrn|UeXMX_pq=Nz~!KqYt(l@0;X^-)^ym7MhU z9URlAF-!qcGI;XW zeEl0?U$1!gvxsmuZ`EWzDA&DPG;ouOp|#0N*Z;k0J?g*(@VSj#b1>>~0xy)Aj?>Vx z(my7!PwvUH0U6HKW>CG7;gStnHu42AX#g_#N1wzNwJ3bgV9HQVG149muDP!WL04azc@bldjHmPvnQOB6t1}R1eZIk*FYCYKNUUJI`<~IvW z9h7{Y+rQA20U>+CjG=I)=K%%Q;5*UrDadzX1i-)XFBVGK;g`2h&C;tE|BC<%vzoP@ zX~kfNY=VP#sEUuU)#S{bDHe~C<(1bkd^tem^vsLD>)YY-Qj1a6&-VID{pAMmj@kAA z2wD^4J>XIgerUQ7B`i!=Rsw4z3bGYJxfAJz9zEfL-qehze5RxGbp!^wugC*osDrIf zk$f_Sq-nIQeK!O@lf$8Yin;plqzDH3MezX+!^$O#0G(_auuoY7GFkpJ)u^vbv|p&F z1ELKhPspW#TtC{UVnLvZe!Hl>^gPxVz=Y5E}|c z09w<#;?aOo12$-YF9b^vH8?vPt4RU=#~A3uZVdy2RrDIQ;AkLoc#{wDPgk}dsgKWJ zpa424BXjOSBefebN&O;}nHi1^z>p|U;0-r5BQ&mG1LhS&_x*~AV9tyr*4n+V%syT$F!qxUR@Tax?>x|BZ z`ak9dnC(p%$i-{Zj=30u;gN%Ac`u*Wp?UEmqfhRZJ#MihLyv#(V@-XH!Y4E?v+De= z|81HXJb*+_v=Dl0JsHXbtFKKw75yjZk>30gXIa{)RpsO{JbG8_UV_<&N@Qdft8^li z8Sx5?(}R2S&B6v4Ry6B+HJ|_*WH~1Yrj59`+RgN%Q^-xGwFmbOm7k*a8HA%tzS8Zx zdmHy-8)c03Mx-$RZ|tDpA}+elRJi*Q58DKT9?n42*?0Pc1JVF{Q-h8jW7;s2(+;Ew z;;O#ftTy{%x&FV0pIy4tP&H(s{Y^CQtj07DeY^}Xv&0>t3|=3_Xcs9QIRyz;7yU_C zT@qL3YUmfgqq6d-H14Sj-}`xc2PRO{By7!2ky8!%A!y7_lr(qAdEuZgS;^!Wa1Vl5x3z<0B9LxSt|f-VxwJ)i{cM{?GEAH%OXKb8M`v;mf?%h`QA>5<&3Av&C=)OI`PaXDMvpL73zNwF z72irPi{JeEvlqq9ud{ZDvUfT2n!MWOhD;KPT7Ke3kuFskBP;Ky=tIE^?dn+f5-h1j z_?r>BU7s^hKx?_{SP^<~`mln@)T^E#5m3eZq)!OXdldw@;dEv(KPPzqL4td?D-9Ju6 zH)FahB}S)zC)iO5g!hKpB-m=0F({R7i18R5p}gRB+3Qa7+aJ8 zgPR>*-)}h2s24cv=u5=tRLy!k8qGO$Mb;j7LzM>lD1%wSQeW{WWF4wkN3*JqqlA|} z!?NUHz^~VU=}RfTNthy%g&h!3_U786w!d?2Q(|HVV2iFAvU zAZR&kFpr?ZZORW}WF&QO-9K?Ns4s_rQDE$mCqpV7f#-exGJBj)u0yYQ zsgEyCRb+I(wL9!XMJ)Fk=V;|M(jOOREUe1IdPF7E;z)GQw*e~1;gdH zk<@t=zo%+7c!$$4bw)`=R@p*p@zLzXb?; z)ovkBd{(RifL9Ru#iY-n{;r3W*i&D&EDmP!2ee+z%vb6Do5@=Js)feJL!=b2a0`)( z%iT#7RXpG$VV1+Ax4f~>qva3K(}jjCeJ17@1nzt+Rq(Uiv7-7C;*$B$tD3@yzu+z2 z;Kvi6BXKLu*iaFYzA8e;E32TpHlWeEH?&_I&3x2EA1lkBHuhs=!`p^X4;+&1 zhko*dQqLx9}Ac|6Z&v%1tYiknDUfnl_mMB0d4SwP9a?*lp*vVb;JR}5Txi~u zpLW$7iYL-!`6x>~IdOU7n|@$OqHD`S zbcowC0zmzJ&KfHz8yYSf9>$(};-PqSvo-qVZw#T1NrYq6`uCgWof`^DDaz)d^hChW2r&7``;Ex_7nHjE$s_Z}w&Z4tWaG?6 z$~4E_DvIdv5ndv|PMAB-MTo{o91e*(<|C)8Y20W+XSjpoUo4f_G%lD&J6i0{O)96O znaPrKZQH>>3*%4FasW));>H~9j7{{s49~`#D+8hdRgYq3M}kl4FBPZFn!y7x)#77Y zq6Jh6(BGMR5sy{a#CfV_@C7E(t+Oeh8vj(2dKOLUW-Sz_R~jxikWFwYUP1SqY5pW~ zL8aLBA~i1!W=GXO{=<6gUr$OC1ZvIrk;fmygGarlj7 ze>y81B|GH~(0r``#&Jr2{BRvW^XQ3_PeH$dqZ(ndqS6Xc&CwG2MVWp>#BZ2|o&{44 zXa+h#v%9FIrXD04NW5}`fBze2`pIqgrlXEO&F0QTKitzCkWGMkctF6wT-9?(VKdh! zIagm*xrqNQ`6AXhbA%@oxC$3aB=>=+_HL&7S-%pDio0Or))$j0&0_WWsB(Pbly!*H zVKUn3^YXJvx}>R8sB;b-_N~{KUAq5%&h3)7tJC3@e%l{u|M{#b{metAR_kI-B4^Dx z>ZSFCIO7In;5ej^eK-!Fg4~3G#(Vb?OmS7+DM+H10>smE)9-UvwF#uBKYJiARqB3G zHn7=d!?D>hk!x7Ti>@d3YcXcvj44JPe|vke9@ALvfsNR zw?20a$w;`CwawPF!X2Iej49)i{SV#I#w{;cWi#|X+SGipinShK zOMJ+6@qxKzj}gWm3r=EDG4GZ!Bbg?BXLk=*-;#e)b}0a}#u%#| z=x}TXRXHj7@8xs{cNlfywgVzXUJ-3TSV5&zG6!M1X1>*=!K)qw5`&!ik;BkWW{0EL zQ@e@VRQoV3`?mNqbhDMisnhp!>0&FSPEzd%nP0)xN$AR&a`Z#?Ar37F00H6p@DDz# zPj_3YY(!ymhsZ!_AdIYdeR`O4X|uKT9OQu2#P=k3fgwE8U{j^Dh#t)wTfB_lP?2Ci zd~h$FC%lSTL-C!aF!m_p5wvPibwn$+R4~@g7v_xj&XzC+lsiTi3((Dyj|Ia|IB;t- zV|}%+3t1vqr@kwGVm(6gsow>({QhHZE9#xQFEbcgq-GMnh@O9y%WAl47zB{BuX-^j zdU%{=TzCJYjN^=g{uIb~;RP^R3XUW=E7-~|M!c^ao%XvN=t1}yey`>D_~*>W3JvyQ-9!pY!hO(E*aZuVzR`hF0ioH=y6+!q z4bYW&ZGmDl1ftB|?tv>i3$WKZUv3?69Jj~tsy9imcVHZ{6a}k#akX@;IJOAq*#`5? z8gHUnNHYg6X0AWwOElkX@HmL4EDV3{Q4st^bzQx9c$1#JSAZ+kcqjhY{6uQ37q_-& z%xel3eoh(;6Q9)_mIA*RHfR`92Gn9H(agt9t_;o{4O5P;ooF(n#6&t-NZkPX$%}ZN%56cSUFCe zmK=(*%D(DGaJ_rkq@z#NE0h2ctE6ny81P{6){8uFs+Exftu$Hk)#vylie}-#t`=s37K`s~E z_UCck6azf*0Kv4WU6|-s zxfuOb#bD#D>~|-nv-3WD%0vIRjP?w(=`7Wt_oP7?vnaVH;@K)vDm;EFuan6eRn^Pd zkEGGpTq-;iBfjlS)ixrd$0KS=7%eg{`qug)P0P5IYkTqOO#duW8jy@`4r1V-JD*SJ zqhGymXCwsPrJVVldIXy&rkF<@Wv}_>?qY}*vY+H8ZQr@;q<(afPb0isY0BbPIhi2f zN3nvqA2V%iJe?V^eIBR{Ru$YimfWu(2Sqn%+mnVjKmUuap{kCHk{6q7ER^&pLBpVu z8>-)vVC9W}{*^x4@PiK5UTHpExsROX-VM2Hj!v|yuy5>Ab6bwF)-tpxvptAQDA&LS zvLFhh#PgmNQwFE{U)WS?-Il~PE0*8iAm?p1_Zz80CyY`af^%~`P8h_@kNu7CZeAP& zt{t6##0G@gpkDW+Gub;V@|Gc6{vXjY>q<%iqbfMQ^z!wA1@!Du#8Gy?i#6O#_)dNo zGQNEFLT06qo4X6FVz}mt^CDqT%|>MHor#v!KK3_S{Z5PiV`?#Pe_Qd9xI}0=qoH?F zD6~?IQH;~M97Q6Uee(ZrWH{A)aCUFrTfG#t_qm;2m;ZjQ0pOwMviDfY#ofW+(WP*F7{Q)1*7~I4E`fv0R zc?ZSY1~1a{xK-1VYt_U!RjoJr#u|j z+`eh}qSSeKnuH;pjBFZT3h+x!79fmxx5jQ1A0*obhr}jhPJzsgUp}HRs-|=kZPuG< z`rgQpbW)IkHfK(4l+_a`i4m=>@FVu_6k;sb81tUEWCnH=;}e<%#E~YHT?sWP z4(oI}JFQ{+ana&_%j=U2{`wJr!_LB!jX3F;5}T*Ng9GbgSJE!3*+R~|TMfuvdqR$O z>{!AuMw%?sQ-_T8fTY5oPU5pee|0E3{74y*94O6GhF z^c^BHVM$FGR`!9>0iBO%zs5fs&ToX~xm*OUqem2J*RJ`k_Sgo-;CBH}q(7v92%>|X z-wO&pIe$p)-&%JB3x4sBHH)JZgzvekG9NOF*91|wn>?{4TNGs)Pg@lv$Pd8;q89Do z39@zN`Y9G`dBpV8q-H*ojiR=padr~5p;C}r)U?`w9By&Hj(0enXFw62qr>Nm^0wex&mJq|fdcYlX3E4tsD+Iqko?S&@n0dg7Au6K_~?W2f-V}Vp)@4?f_O>ofqNP) zTV~@wZ#sly!c-j(xAC1F2Ts)RKCdCQ1KuvvQs`+-Cf3J+I~=E98LXlrF-{d3u4ogR zpeSzbueZu?VPd9wV?>@lI+$f)EE-<%FfKGb_aUAf6~g2$a+IVC4}n@>8~7+K@H^W% zGvj35-q&lj5Ef3S?NbO;Dt7>Zhh@pGcw-ErfJxZ`f_nCe@)?13+q%qv*zZBtbt9KfUIHx?b-| zY0xKcF>1kxqoe-U&WUi- zqzL`kCuC+K?S(FWsHu)Sf*lIJJz->r(L>Rg=UlN5o*{B-?!F}kzp&RVXqX1N*1!$f zVoy`bp}k)^oU85flV0mi>y9WqfUgLT{J8UVjTqM>PwgT@I+ldf1RbS84wep*_1yXQ z&rrHW&JjhEiae-xV8d!xtJK_l(1vC5)>c8ou*VyB>`!ZL&ZM-c z7qALL*Y9a4y4Dh7+h0rsQv)J1$I#78eyuJrJL-0>B7B}bDkR>zCP~W*gVKC;YhWo{ z^Fzw9W|~1IOfS(<^SnyC_m}VN_^f4_G3;i{ZB+lJTPbF-ojJTr_tm_#6Xu5qgL#cB zWWE^xu|>#R-5Pq85`M%)a89EO7dm}4w^Mx+DWB@cPG7?an2*EJ1hNI8e8Q^7yPD#a_0O7!uSuIx}M= z_JLkkerL5EO?7OfSs0GBiWy%)`WLCxL>uL|D_DZvc|95yZ82WMA2?RP>{F4Htl7*> z8-o|7e@P-|D`c$LJ=*o`N(c5CE*sR-tv|(rcC~2+Hy{^pNd|8K8@MyjG?r}PGM+DZ zNLGzk>lA+!f=&L`bPW9~>Q>+cC^~Ol9x?|aCrGu^fQP7siDEhKk*dBj6H**Nj8Kd|w7lEsVF5;AA=VK{~?o4>{li)XoUJj zVmb>&Blt>Fw3tjvYJp$T8zNBf<#mi{+?^r+jcf2Oj`+~%$}gMTc7(^|3t!AWc{Jeb zVqNruxrnfSKzC`Wrm#eHuv~M`eYqFe_c9QwmrlSplAM(Lf@2M$AE^rs$J%p3OvrdDa!)LC8k}FQOw&{8D-rT#jmI=wpX{J#*RoPvJdM?-!ubF7Wf=NHnl`JLSt)c*bkLwJ) zAjYUK&KeuM0J2Lym)K9;;vIi;P2#vo&)8gud+WS0t?52aOs2@QH;~2xu8?{^R3OQv zb8er$7)0hJhMe>n_{+d?|OSjY^|3Z8; znrxr9_+K0l5&~0tW<4J7r1vC zqq3C(#%OiDO);YhZ$A$8XIk?|X6;F9p5oys8?|gESaO?Mq(TyXv4 zhC(d8Ai4hfzeslQ*(Yk@7Ah}ge>IfP%aNC#H6qgWSB=;kD=Tqt0EIUl3f60?Kv$ps zQ4`YLc&L;OA~*QjtI1#cyoD}C#_LvOV$kGY9VFP(rld$%5F0?kleKiRdJO~!JW~Wg zdKn5dsEM9DGhSPt3HXKPZ>gu1G$~$SU!ox~6`su~E_pH93&HS9yr{O1=mVOjbvLU-Q)JHk!rKgL?&!c5^=rmBRC&MjHw-y{jd~yLe+a z4$uDNV^bWVb#7=l1uEBwzXTKtVIjyf;XWB86xlKbqurzEQR2(;FeqpU6JaM63g7AB4=5X;xyHc$Kfk(aTM>g6=$ zaM!jZ!6~PhFzNK#KK9IrbFZcg{>$1wY);u@9d=8dqusP=fk@}9YS3?<21Hq&rgk@B`2eroc(WCYf+OPs-Q2RkL4`6d;S{gz}dVI=KB?;&mqvNiSS+g zc`Te(b1BLw&0IEZ$#-_bEYMc3byX4UlO$Qv)czraIqs~F+7n6oVDVTqu8{X;|KX!> zAbjfB!)Udqwj5_%mmkz~<;h@#HmbCJ&PFJgYSwQ8??rsgieu-z+g!TNp$M_ip+8jf zLS5Ly49VkDzwVmq;#uYG?Eoqm``OL$S*iWl<0$BwvL>U7-QsuqGrHvh`C<$F)kVk! z!ovs28YDSnPwX{`%I9no$8O~x_Hf>_lOaOH|` zrX>USu9X+w$5;qUc=H0-L? zR$R&SJs~TDH(aleY~iH2r|)>OsCwu}mI|UF5CMQDd2ZT+`u=88FkdEm& z^Q`3{KK4aITYke(;pFO`zKP4nRtz31ssAM!h`@#{lhmyjCAFOsA4&nbDoC6yemI0d z7_M#*S{FS2A~)<~``FGd{cnxIV|2L7_qV^0kQL3il>znvu7|=iZA_a6A&50|jNX0+ z(i5BhiGxNawpe4Q!{tT+k466Mg=L^-ptF6D^0@F!(HxC7EAavyB{ULC%_Z{QeJiWe zKyw2Q)sd36n(rBLxQ|fpIJ<28l6f%7m4rH}ZNw*g%-;oIH7g=!)GgyD?XR%(6j`+fd_}C-8-Mn;552x9v1VC8dLrjE3O_;JK&}pH&h#1Jk<^BL-$8EhezHNXyjXe954WOD{S|nZr!=+ldB{2$nF8Ge&MY0WOrdL3^~n zaRFysLzfe36bviy9k*h>^chRNiCj)!Q%FDruh}UbuY+WOIhlLT72(bb=n{o)c2!go z*K4{x=H;0E>aHNZ6&*UGHI_udh@t*Q^kY!kk(vQ<`91SQqYpy4`uPo#kv-kwGv}zH zCtisj3%;o`o;$w1WX7+FC7q0ejpfUPjp>VZ#L9JM?aOu-Bt{mjB+~1<7)35hl$Jtz zrN&>Zx9HNk$$(&z<)?+HXmv^|fjyrc6*{U(jh@Rf8rAkHq|+Wk4X-DE9^|yH&;#+8 zCmK=Np@XG?QsSAHy5j2W{M>rameRKy_1_6f5R+Y86jLm10{KC1zgTwB3QPz`|hC4ak7+9_V-7G|rV zYZw_ca($JHVWDU5>$hBn5PguobDJ@3k6a~Z1mKRxaB6VGo-}!I+QxN zotxQwyPp-3-ig!)eI?4RFW>J=F`<@NBXxUG>5^m?-{;%^4$N>8=S-oIAYUHMS@-_} z{n0LPc)W#Zf0>GY`Lel0p#TjtOFSxcg=csJD@YjVYrX!B1H@6d`I4eEU4Nq^|y@8BxOaCD!G7EFj|wY(XX^0gU`0e z53QRwKq3m1w5RWhOUH_559+fo+8Nl(bD7TB$*MQ{1HoAnH14fmQj#7>HL`~wlDzj+$QAkx?%D}!8Z&fzwlo}P!2C67FRy_F&EsmKcGa?c`fd5p6-6Nb9*CP6 zz|qAOcIa@JCtT?-{E9%ZPmpLcY=7G_ko`kb6Rr>S05V@~m~q%&JXzYK{p+Bq%rrXb z1{8Ly*(|(UW*p_0g3bMxRM8)ojs}$cW5!cIyh_RgsvR7Q9S13 ziNCL86478tp_a7CAMpYbPg=tYop3h5rruLa72J!o@HpkG<&;z+KUEv21mdE1^S}*o z?ZtCth9~hIa#^<#I%$zcR<{{`C1C?~e(d+D@yupN!J|;NMmFDc%PzU;P!YB&_Cn4% zV$Ompmk9UieDUq;uf3K&Ae?r@egyU^=myjE&`{Y|AlA&pV&bL^(ZX^Vz~6~+HJ5#! zr1|Jg4FbDVQ<&mI>UEj+G`mG0e8vEj+^pGl4FKLd;4%%gV&jj%Y8^TiObkpg{z$qt zJ$UH*Zcy}Y=9{GbO}{F9*;a=JT8NL=irX_9;DRuqHDQ7*dDu6D&^BN3d|TnaYtAU3 zRzo80)KiR>Tmq*0=reVUIF?zPjRJDuH+Rx-KLRbMn*tIY(Mrg;0%F|BU1GNDG=vt; zRJr1+cg}d#Ov~}NF(LP-$Spv=os@6y(p|qoV(eOoBi??z98Za`MFf;;vEAuzaoWYi zj&s=%zgU5%M2XDKe0nwMbx_oBGICxp9`Byr&-$M|bVA!1tMmo8%nP}X#osaCS|8ZU zdT~rOeSBzTTYS2#k!e5Vi+l6bn zS{N>DQUfI62?eKEIbNLK_4?bwl}%l($g13XFsFyCDD(PI=Z;vUnwkA?xjwML7>jDY zemZFVf0X+-Pp>ZUq04u>v3ks;eWu_5=i_E{KztoVR&Qc9R7^6pzdu4Rm29hNe7xIx zS2RSpHKNr>9N(eLZ*SIut4zcIfCuU-As_7C5AQkC2?UukEBSsu|A5J8>NXwOgakTG zUJH$%+_0pt_`VCC?8+D!An3(d??mFxa$8jOjyk|d4}dp6?VnE>`NluU771Ew$x1~M zAJs98yKHH3t)z9`EEzoY0WZd7c&a4yMV@gS2~fAB296Z;o}H}|5x2nfS>+n!BB1KA zseJvn9p9y|u2~()z5G-=_ytf`8)Ck@Tg={FYi~Y-u!2J`9$CS6EelBe!>}_{(@(e* ztzJ!=4zQ1Wu|uFahricwT=(9i%t8g7LbBy!?u|K zWwL)jNk4=D%IK`mW{U`=zLV zZAZ!w@~xYeYN_}hU0R1AhbKrUJ4f`bQ@%8pV?8E*v!47$8#o>`6WoWl1wFl>8IbxK zby2)#YHpDEj`t@4*3NehI1K6aJbtvEq7qy5 zyp#?Wh}HVdUA&xepQ({gPq*UeFFN`Xx-9v3hEQdV53nSUy2B7lx z8)Q3zSG~Shn}@5f_$S=Jr5pB&DMnB$oDPmPWM)jy&e;76qnYm%l-6x0BP>0@*Lbt( zqaer0=~a?);$+>jdv%`fsv9}@nOC8YF~S_Q0jgooF)4r1bbK}Rh2@=Ex|zyw>=-GG4xm&{bg z7Q6NK!~49}WEAs~lqAPG1$`)q$7Cur;MxP(;h6@3^G-$RmFLAv58#7Nj^a z3B>V;PWFf%y6?94oA!uV__`znqM|RP3xs{njDM;{*c(8SO;>4~;$-u;pFwr&sn38w%$!d!G(!KnoBy|;hUQ4?p93;BzpjS(HWdFKFa58!Y&alL9Du(i zBKHgbf3NOF!`UJ^M6>-=A@G0d!~e5kWW5{--vzorqAXI{|K4-I9$FG0{^jD)t&;wnWT`h5tC+!4{gxd@5 zvG>|v{O;tX8=SPm4NhR2&#K|Zf;E2$liqVTU>3Ifh4zn^{WC7TXk5m^`u84ZS4(gy zl%`Ks9Bjl|pGCALIL>6o*lzW2@s{z2ebQXjmyEn~p8b0f$ghdC;QJ8CwLPoEq&nsj zAKv#~tjs-3nQn_*o(8wZI*9VHK=}M1<^bv)-oX8j@+z&+13D+u*uri1nelGf9)!gA z{00F#rdV7QZRht|Rh{c&!EVtZ9s&sJ_<@~`ZKqBsI`Z>5MwPpsp-If@JJT@PY5Mp9 z^=80yH+TD_e>;|657j@9+(lH2I7DblYJRamh?fyjh?7U4T=XiOO*Jzf_S>h7@4beY zIe=|Os~0uWqQ*|&9lf0#BgEVE#$KA2u7lii#YnWdc(AkaR0K>3Q3C32y6sQBMXf{u zYf+u*^diMxgd-m1fbb+38rzFOQ!~79DQ?NCGN(j_@&@^{0@e zUdnF_9VbNUh$8HEg5v?9v}U-540^tSB-_HP{4~+kYpbh@!LQ^G#vAFphT5D^)`HA^ zSu)*1))Fzu)+tr{EqJp^#w7nWF5O$$p-Z_=Dgx}Ih70VwH+lwrmj^E_9R&e&nwOR} z?}6xlk{GKJ;p(#wr0?*UJ}VmhwYJ5g>bw+?eYX+%-Os^LO>g1)KGiVNi3TGF7Ehd% zxm_o)notgjzq<~Rhtb@7Na@*mS+TX&j94#|+^fU@$u#AeUxSo(Zh*52kic}$q&eR1 z?#d=_^{_^nm%oSRv7NRC7p5Y7Ln6G{`j4pR~VcVy6D6Zb^h%H@b{i=QV_aL&x zV_#RFX6Us&RGSw*ryr}|KyqGX_T>M04Fe=d@(N7e1S1xn0Pi53*OWU%@p6A4B}&$6 z9aVrv&Yd3Lhr<8NiNlw^+2pI=Ej4ks_1YBq_VF<;RJX$|d4`NPUJI>K=%Wq$1%V^N z+C6H({foV#mx7<<@w;o<)%}e|uHFOg#cNfY4xxKY^d&<^d>tsou=u z!?k~z?^9>AHG)v@FNRj=f3LfHvXc!+;8rk}fO~^^gMO)Y8HDT}NUr-d;gJ^%;d_j8 zsn#JAU%ZnCvgTh+;7nY+dRiSl>S2NNeNb0D2I_LHA6!&9>vQPYi2A0~w{_Q5vYa27 zb`5p9X2V3XJ7ZAcW_4{ahu?*fe!HswobnSC4sAhl6{p{0B^(31k>3+MGOu&%M@ia8 z@J*(+*&Rv}+gD_oKkr$4)xHmR4VN)I1nPF8eUE_o+T$eNi6dz6MnU)XW5XX6~cQFKwNx^u^sP5c;i^wEqH+ ziSv(pym`{DssYg=J?vM{eSrT2 zeq9VdP^!JtAu+4bsGj2U`OWI|bI*6Lztx0?R_|dbKca3Q%}FFT-78FSfZ#_iG(q$} z6!q;22TZVT7cw!?@!)WvX#cCmx3W!l;uoHf?WzL%i_V5Z!n-@FSMf8MjiSL0%uiS>N_T53`(2y8@Yb!aSw{X`LPmS3rx@h>&VwSJf$Be?|0P_eeP8a#15FF|-ZzTvxtU+`- zPa-sa@s5k>tW5=Vb;NiNy$435tdU0ki4Kf2$bVYOR22OFxeEhXfqN~aFbt{ zw0iQKGc&mZSe(zn6`HKG-1mC&C07d1PcjKn4_U{q`Os%Q-ys_Dq273^I-RtDiVRj@ z_PxB?A>0(<+^42eg8l13>(b4|!&o@-ZAO2{zWQFWY&UNMU?9Kl*GBlZa|k}s8$S@PTE@|0>tc}?kflc3X9d;y$J zV|fc+e8qxTFLBgdM&12}&G)3v%FZhN;)*_6^FV%cp+fVzg?OtKh8C^1-PgsnS|Q1x zPh8;a?%4?9)jRBbe-DvQogBN6du@O@ZoXpvPk_LL7uh;lD8HXJ0K7Tl))4#{igy0| zf3f#fQE_Ekv^c@t9THrFyK8VKxD(uhyE`NV3GN!)-Q6v?OW_179A5S9PT$*o`@Zhq zH^%#`8g*))vt_Nl)|_+glP4x2Lu9co{b=5RHANvwy2ZQRRcY9B{IW}ypN)LS!Kkv4 zh_lbN8Wrw3zvO%m*tEy9LB4v#RT%`)Ec^F=JF86{oSmXlh+P!o)s%G@dw;u zDIS|#*yN-?wY@3qY`b}rbMnpFLyN^kY7;XoJa-IuvqeZ`#wFQ3=NTDR=?ky~K-A5l_mk zWEUD1{^!MWx2kOON2tD6&^zyD;(?1RGv#Bi@2Nye=P90K-Z*lexe}^4Aw~E!V~CU> z-#1wjzKDa<#tf|~CVoa6sp^L&~f0Q+*xMe>S&z$biixH#N`6Ch|EWI?8Lrv&JK_gq84@p8& zc%cd-G+o7}?u6Y)`;Ln1RJQtrm4cCWR*00z9S!npsIp)Y%UQk#ivl$D*|<>k75=~- zZEKAcHsu<-{W43JU;iVU`$3cJZ^2=wAAwx9}=d<{RY}osLGl9ICTI$vL70jwBJ8G(tly*s^0o!XlE~i5(}$ zrTRs}Qy3N5#?HuB%?F(irHa#&NMftu#nQQcEEvom9m!RN#Xh`Bd z%$YGP_(pEFmPzbCV>NQQo;K+f9vZ~!2OSXFRO6vrY6Er_+8 zbdg>n4qlM{5T-^QhiW5!Cpk8rsRnMJgPgDa1|8FH;sIKJ_saCdq2m_6K3$Q5)tslf z9^2rKHHM>b4D3+jn`B$5j`CfauflQ2ho!(|wgYerZ9(C9zLgIYSAx$_gOkF%YY~SL zC#RWHl_Wii7l`MLBjZ%(WeeT0e$KiAwYeQaQ?aF!&?NKV<_}Dz)ntYjkjc2EV75El zUWYeD88?slTvTIz()_pm+E73EcQ2%wn%( zH;Vn9O4!o;k_jk>Mg}9Pbpml%(T!FilZCgxS}7Vuhz^NV&_tFWhkiKXXXc|tO6F0n zPUg)HPwJ?KD>{|x&34LApbx?yx4WBlm`r2mZEp=%6gps6r0d6sQQb;^$QWoIm_g;` zK}&fA#69(ST732ycq0+ItH1*^#rf9T8v+R=kloynpB?ueLbKC>uPufD#DKNqMa1#- zQc)=`IB3d2%DWXeWM5`B17=bybT~s~pxq%{%D4KJ`;8P@=%BthKH~EF#|7~LGH*j< zqnP>@-|b?iJ!0q8eGBNfAiUYS7JsNods34P0sa+NZBN*O+EE-Y4RT2%J+6#17jT5f z*}eDXJ-07Jv@{Ait2EMXBR%Gs8$#1|YqyT&z3Xh+K@SuaOE!iCW)L)L_MxT?6Mib?XCeKc` znrMBgyK~8PvVTj_Hb5s594myOU=)xEcwlZ(nUg-9DgoP_f|vY^iqCX@@YPDvDbn$S zVdn;BlfoX%pl`alkB2yyfu}Tby|%(3yX;LLA9{h((9O(> zRx(91X<3;2tV)HN9(MJx1@;ksx-cA4<6;T+Y`Kq~&7i4mJqc1&7#=?s_)H{y?jxjE zc%0)aey~FwHlbQdycTw^&wX!Ma_+$gd@>_Eb588yBN|cP<+^`Rz>o6sP2Tq+RD zj{4)dp91_0i-1i*Ak^B^mxCmvkjJ5M?ubkz7{53k1C4@s;sc&kSmLxBScn(V=YjAW zSr|UFnSkvrun$=eG&CibcE{V=m4@$mX*EX0_i`Yl@EZlHZmalF2;?z2RE4b(aJ!cFq$(WtF+=A}=35&)$^#U6LD3q9_o4`CZYBEjTH{ z+I&jxq`qy}-%sG`Zq|oFWz{JWJFC^v4l+9~mKQ$0>GS6TL%Z2PVSkvqF5)V(=n{7# zRJ|b3OnA?MpnP^opU3w^=&JD*EN`3%6zK&It|bPHh6032$AqgvC%$|iep%ZH zJAQy(&UColhXXSsTq@{ig@xa|(NjS7vvp375G}AmC02|HhwKea=%cZHaBKH4>B9Pn zxlr53!woiHaB2-{62f0;Y@Ct3w$F#gvT~vDo++Jd9-t#at2mbYxXaJ%weNGGB%_qA zOja<1NH?vs4z9!IN=_#4Lj@azFE29>SbvypD=fN(=c0K*dMwd^?p+tZg5R&By>hdQ zE1RGTDP|U}?`m?BO@kl497*VKFP!21zOm$3fF2@~b!A>bu8?M?nYOf_Fj;~-sgoFF zC9hI+I{FC8<|8viC7Le7>yDai{_-y?cGwS6nh~*Hu5@+2A{I1-%g4aRsdv3nq*YMdT}3?dt$0 zx6PZKR*f71r!@Ik4J}s!DV3b#)Q0Jl;8(?f$*ZjeOG4&!xOV z53%-C)p1SDXXd&8j=RirM9KMwu(e(rbnwe^qg$SQ`z@;)i1s24n7)IYRAW!J}8JTx1 z-#i6y4K6%nt{Y?S_*A*d#4vnsEBSJ_3{e!pJ zG7iW5SDeO+X}yYvnhsAr!pC}O8lD&BpOCA+wyfXG+?o+=R3DNYDex4tHa)3ecZ|D9lCh5WL738kG**KlPJL5= zVaX-LwI1;OQcs1fDH2TQZLVm(BU0Y5tMo|85Xy!f$y~N5{%!L#go-=X65p9=-bQ%` z(2dt}lCqCiC3J~me0BRw^0a)tv9R@oCD-R2G;%m+7totmiAmsu@wtY>Kq1=6z38!O zaS~0i>zcPDF&EaJI;a_z?IvtJoZnP}u$f#QG<&m>zJ6D%TeW?bc@yYA#vjJl)u1Qq ztavR++DL|o&-pdJQPC>tEyIaXAFHegB<71G^_8xsSBNgwKLNpIb{p9&NaRJA`)ntI zJj(Jn9-3Ot#~BZFYO=4NZhkbJ6>`JuVc|{67K`3t6BHCkfTPhQr_^F#En`i}9(a#m z%jmU}`MFD7#}}IFtCMk4pq1#w-XqQeQOD2pOt)Zunss@dU#_5fu=!gIm0W?5xSv82K7MxEBi$`44Ar0Fo<1|5K zu&$wO%mg0#Ev`=@OXSD`y44%i&M%nM%Aimp)@{|o%Z7}@m+UB2JN3M!jYcYN&4MU1 zuvO(OduNsDQ){=GyU{glEbiKVbYQ|&}}(z)AIG`ps?BFeB}bbBU;QvjPo1#o_E_P z0JFq|u+MkfFV?nx;+Fa%RF)®Y%s*w#>!4to=o5f30;qD2Ex!f_?joBEl!^0s0i zq#$IqTnKzQAfG5y9=7Gh=}jN>&rznfpLun4?{QN=gNGpE@AGQG?yBKmsu@?m%8w70 zxP2s?S}Y{x(pu)2IX>~owEA`q@c%<0Q~#^B$fGrBDlEeH<-vpoU<3Gy3 zH9+Pbg4Y+BHgH7%%|^gMu7;TF4IOe}e!f6XN;w@7ImLs^8P+kf{gQccdJwkS48M35 zx!VR$=7YxZEnZHIUP7%<_!5Ujm%>N_B-LUeO4V1m%q;Sbh4^p97hT&^vC#cDM9`i! zAm+KOWU%!`%sIJ`LYE_0IZl?a1u{8QRq#yq+t`A-YRrPZPsA>U2`{Xr=PN)1y$0h? zpJU$!)%&d3<)I;Xl+#MG9{aYa`r=b_4%j{Z8%%z9ivsCDr7h6_Zff)gqgZeM&#vDM z>*+HW1g=g@ridcj4%x8pQuRdWbC}PHG3oWIQ0Gddgg*H@dxlnPzzcKk@aOqCETTJ$ z>GbtwV18TNXq7~}JUwa)Ti=d@IcZj+*5kqHmx3<9W)!E)3q6FuWZ!9b@neHHQReqs z87htIFc3`ac*eefK#GEG&HQZs7JjjGKHFwY#N=5ycmYjg%2ZwCpI|(6nR@k8tU^W92^w5$ z%#&-V#3a9lZs&o`1K5e(@eO=YDG5a!T&=_Z8Vgo3#mzh#uWPI`hjuoh*SCok`N>9^ zY|j$2wwe1h^%@LdHE*ZiKO90h`y6@J;IFG?@BcgdwqgR&Qx5O@0{o*w#L6)~_1i2x zGIRiZveLt-RoGP{HzIzq0ytDDSny@|i4YtpM^2aEJj~QbD&1rNd=Wh5e@+Z~2Z1@| zAJXF0dyHm)g{gS|^+L6B$q!Abt?&o>wl^fTXi-b74(vby9fu}G4xvJSs7fyBUU^=x zy}HoBQ8GM-rf1G0F{cLpMX=)Va*}f&pNO=!USd1r_JMTKPb~oKFx6yx``&=t&pjVe z-e2hHo6qcm-8#2siuXz2(9E?4mGAPdgQynv4BX_)*=1W;$FnW9=>?Vqy}925fxc4t zZhhQx&_YsM$&bYw(19=T`EJCiB-i)R3CyuJnK4Sf_T>wt)Ltv^fK+3sTOP9Dgd%S4 zadELpe4iWnPyv;!WBy$7U56~F?rs?N=|3r_Y%2S^3scYhSYm#Bmt87_4C`1{$DKhx z2Zef9vQrnVc28}n5F`S#7pB}YQg zw+@bJh-@G7eyu%^z;dZP;@X%j&OOWfY4EesPr?#62*Uqf>#3-Gz1^vj?O_QvzVN6* z{<(f+JEWSv03+*V9pH)P`?RV!yh9hIDKCg(e-H0d))2fx+1viDA=p6T2taAQMhtx- zTLCU#wP8rSEI^d|42IP444G!+fHmbk!MU@&d-C>w4H7u~$}4br4Nr>MuYhYbsbSF% zSu{cA3N-f_Bm0EbJ{+_gYiBb6{lDP7|cG!GSlGDP&8?kp#L@dS`vRAfu95V zTR3Px25sB2$IT20zak6455cI{_!S;Ai~gco@1S2?2MIN~<$v7$Cjs6$i3S>sN$&5W zr3D&14n>BX$gYd1PMOGytXo-8_82;KY`OPOkd3&k;ERHTA_2-P^Wpp?&c<7^;L+?c z-b?OUVMM1<^TwhBIP66)(-5Y|kjb1(NVJ|QF>XWgqZZZ{lCp{5_}WOwk^s{B6MnXg z=w4M_;_1+a-1d58A}O%~4%i_eA2<|EY0E4aBO6HT;OFjMljV3?Nz9rJw8XwBDCQ4v z4F28a{q@8ms)JS~uV(DAVtLXe#I{Q5d9l4veG?%|lNua)8U|Qe{E=n6d?XEP5S<4O$BvC&}ywnNqr4`3}&_RK44Yl zs+f&*+-PSymA7Glg*^Lwit^Y1k;FneJeC6?(*#&&#!|CA(!H-w`)+*5pJ0zrS?zMI z4&Re>HHH7(I^h9<%gD{5!|BzmI5RFwTtM6rKJ$T+4Yi!yB=(B7w-|Ca>(qT3z{mjmON3s84 zcK*V2pdADDB%7!ktLB$n2z+P@tnjvAX9|+*HGp|O`#Ef^Dt{nKS8Z%k{@th0{WiX5 zpPkdCnD>Bh^^Ma3heQx;#ZQC=i0a?h-c)s9rQGd%Gu!we)k!17;hnsCon|L|l@SjQlMIA0BV@HrcuWy`sib%t5G-S>C>z2-OEVqdJ(ff2}C zP4&N$@ZU5r2PVu(D)q`m(4dH1UcNPOfFTrZf{1Brz!q<43*rx+<`DeU^!0BhWM%6w zBbev8F6~xZ`e#KPkTR8>93J@9!dpwHN?1{>>#~8>8~SR6Ql}bx_{X+;!B!piw{Ln~ zQ!@b(l0dS{c#%AhM_{3=Q2F1el>Gg%8olnS`MYu@V?)w^>stb#}@2ln5yy8g{}@{4hk%7RQJ1g?MMKW_WKK6Xa`vXw?( zo1gx#EB?bx2ql9yJVcDBu0IC{e_=fS1au(%55dvI%0Ic78QKAp5s|rbqwVBN`O_5#_d6)7N>HO&yj{UlK zIdEm_ceVsP0-i{HM(u)H2s58-=jGq^+^_9ApCB1$7ZQZZT2)O;5(8DoIYBBlO(4V< zuSp22So5Xsu6dXO!i=Fc4=ewruwO-cju^8gbG1+f7;Df6{TUkHjbp$0eV_R_zTFN* zr~j=t8{w4ec`1X>#-Zt3*Q(xXl{YBr9j zjnBY^Ny>D6qX!Q59&)R7phtO`a1vdB^`;k6M3Q^TCP;KRI81&M*LVD2L`qd()miR; z45Ld>lYNlTG?}^tnHtonQMp7qI39_b+Z5p5Zx?zH>ZDXZf5bYAm4fiAk@}~q3AKjm zM8B`l<`!CEJc?ZV)@R=IhYbtl2C~*6=3V1z0Iv_}mJL@Q2na86Com1TP5bLnTzZW8 zl)kOyuNL_%N7cVOebrqBzwi49NB(i5r||)|`~Y#&*HsE#%8 z?RZO7!8UA9MsC+k4)TsG`f6VwcD>E8q_rHlj8357>cXWFcu8NQU3>6HEpw&&S~Qz+ zrY~hkrka=TnMmyT{8@Xp`@o;QKSgslA)R^95-(n$ zXYkA|lkgQUuH<_KnxL20ywDbjOb3%-{Fv%;*J|-c=8uW}9Iwi*IN#B)+nA6=xNt8^ z#eyh~6`RA5#D~v|#-tNUiKUHR*#t@HC*?=mYLo3#F~uRA$2LCc$VJba-5WLv8NfHJ zjCxJ@wI%H*JAfoNy_6{+(9`0}IE_Zhs>Nd#j7?!4IEF)|3q#5&hrx2HUA8JoxNAnS zP$|i5*<^AFWLeYhY>5G(ChNn#@5E|;{a-l3(g#8JtLC$DXy5TE@k?Wy8gu2KVr73 zPKgB3mZqaMGthR?BIth3yFO^%t%bF!9`weP%p6)~aoX;zy3qgZ$As3Q%g;yw2i`@Q zT2a+$W?qf!5B;prDRw1_XV?9v8pc>bcr?}cE;+y?hCv2jxTbherVtZA%Lp6%((>vP z0iA;sAz#yEl*foN=3api9ys*?AbVjldTD|PQl~6)&cITMh0PKgbBbp0>0H^_t99aB zeLdK_h#wGDsz~Z$#sXhBo3(aVu&Q;Ld7i8n8ng*dtx7X_c-oacGrdvrE!kTS6P10J z`wN47pbR**D&C-OPWPrt3?F^wnV96W(;$%`JbW;I3JH$kp?1sEAt9nlK6dx5hkT|J z2_f23-6s+1`tMm|YSQ313iDmHbrAh1eCxPDAiWuhYG-2|dfmXvK!cSX)_Vps!s;{D z?1R=8BG@G=vkxcMLUqYW#V}>n4a~ZI=MAJF9m0s_7hA?4N_iW*%c}SbrS=cVho!(9 zALdSd9x|I7b1L4Bv;zyXS4Ear9?s8?wyNIo5Yco@tnEBWkWZ~*)R^!^{YP=BvjKv) zMIH8e=vcY)n=hCqWQNX|UqD)evE{IcZ>tMeRlJ!ycn(Ds%V&2Sjg=&Inf=17YY8l< z-hzlP7wA{ja*z%C6X7=Wja7mzU90`y_Tsr1b(uUsio_MD?eFl(0=DPpae*r5Ahn^~ z)<>!4?+cUn{&1e-E=ChTc-$KqKroUntX0~4HH>p(2KFIHG53D*W4}Xsso=~BYkQqB z=hAUtLClXtgs~W_Ias9qW^&#fAZHmJ(R?4qY9(=LH*v*;wU)(C#IQV2i2S167yV5F zLx#7g`?!ywYoPCG@Rd8mMC8byBL#b1=<*{{b1PA#g7IOY!ze;RyA=RCSA5t?-%Zv% z>tb!~R%+(*nQ*xt5I7Qy%_hDlgaO#a-6vnn!GK5E&U1K56_n;A#A4w z>$J^*M(QPp$QKnjwe>*O}kia`bR|P{Jj&QHK=)c=QM%v7K!2&g8Mei z;2@e0VF?lDHj>+V;3-3vp2NO8PUs+ZbC~W__+lsiHlE7@Gd;}NVdJLW2WRWMe5W13 zkno*6~U*{uEW`AHTYSdUfbjVHBoPHzUP`rJRt zem){EKrd0XUz^|d!S#;MiKfzK0SikN&y2GaXz{c9Ta)zq_^Ljn--F(l`vjJ$uh9NP~e&XDlmDDJABd?`UBqI*AcAP$Z|EH$N>m*V{Hl`zW987Ri+nvMVBzR zddzOYL>^&x^5RUzEFRlR$exm+8+>>PU-Vfy4z)~73M96cwBR7+yy^V5; z)T%v=<@ECa;*T)Dh0Zz@;Luyw6Wif46aJ)*51u(im zSTRWN)4P~?Kse?K^cMP`<7dRI&TE1lOrY`n0CzH{IQZ*b(uz{#XuUu_ibBvi!iBs< zcE%C z%l3}0kwkZxw{V9rMib1%(8caFIt`-q`Q}BX>iT+XlH0*=_A-;pUhRHYnLhI)L&2Su zaNpIU)JqqF#fS&-l7rEjnRB|FaI10aj215YX>$vac^f_dJD%R}kM(Fwp$p=g&n7VF z{cl9#Gf_?ksO;4d-~N}L=F3Ag%~<>d8LvFjxs6PZN;=mHt#`Ij;F39%b-JBny1FvUcLOp+r-Oa8O!A`xb z$;tEHe>C(hDnXfq<0&>9_BHX!z#WE#tOx2>X-nz>(`>f^?LneKq2nO7UddRI#~sAH zb$*#vWm5JR-DIBv$-_qKUileO0w;9exb|Rng@I}#ezuuuRNfU0FSzA94aAN=p(q^7 zTA?zf;1!GOwb(aUn^m|6OMnCzjo;Fec@~yC=T@a~^*cl;BfRl>!x<%_;k=28 zf%$Ajn;_}Kj{AodjBSvBY%@XwQPla3Wj?HBh51u5&YxG^EmouL*(02!Pvqf{r9}+e zcAREfp8TxO8r;ctbptwua@N-t>;%u2PtVMgn#)nGtsfO%b+~Gfz7O81F?&dTvv#KN zTm~B!4tif-PFzbi?y??@-(Dfa7uIXHvA96Xhc7iC%}+a#zLuY=284d@(Y~f^6wH^B zDy~^tWQ%4=bOzlMDdJqGBw<27es%v{J20!YSu&1p<9V>MyzC#H#F+4AY)=mT8;iP8q+8O8|2@y&OrGxQODmczY7^@jY^-D^<$X9ku$a+jQPAr=gJV zWzY+LfXWl4o2FglJ&WbgzWS547D+$U3W+FQ<}WjQq-I(~OSLesBUO-Nr+V0sH|Nw6 z^%f$*)A**12rf4&E1)U~@NKLy-~N{#Xnx?+YYx5G>e!567vVPr5qQL;9Ah9GV;B=IC+Ksk6x$Y=P}2DhF?o> zkh`n{LvD2DUl!g<{wdc5hbo^*O#?-sjd&?9hCSyXzWsI|T!-+}D{WoY=2rNm#~;c% z- zKA&}qM2DCPsv_nOF4FMs*25a{k$yB(0tlYFa(>j>x3ma>hVPA1%E~R(UP8D^p8B{a z-y6ns^&?ZXGdFrrF~|&8BRRl_#%@(RCTG3)Q;P?J>`Ogl!LXc2PY5<7SiXYbI#@1H5z+!l$G7v!IHF>}Gt6S|=EnB|Xn0Vtt_^e-@rv%Z1B0(B!kLt1A9y+H!?<>9(;m=6%j{hYl7BWx!9Kx ztKK)h%l;+z{M2bX6oj0A#w0tDFd78{(~^+0&PNDwBj63G?Vp*vkQJyKa@RbEGaa0= zNNR|Vp51wkuAEF1R(Ybyr{gr}vsy=kI7%UgVg+N1ktU3GS&x(i?P%VfbPUbM9Fmkv zlx>@{fm^Z4swoZDD&*opkLBVqtI2fq8Htt_qvIs)aru-grODhdB`i=r6+||{^p_y= zQOZeM*$OSDtR}Y^60x=Ewc+_~<4(mKnwBbgucfQcS7Gb4O|T5cr`2KN&^5Fa7#%K| z27TD0n7m4Po+0ubWN@!VGe7a{!<408S)^_Fy#ggrTi?OE?M8xZjL9{a}((Zg*WK zt*>G{w_!lx^#vsHC2*M>Np@XLFfFVXjMgiZ(yya9vwxF3U*o1`N`X$8Cot{4!>-M6 zZ7d=lmjo6bDKW~kmJN$csX%aGVrALqg7xIC1s1~R0rn?rKe9(<9%W$_cC}}`@TH~U z)kH&cL0B8xrpX`Eux?FaImjGx^$n%bCWY@sV zwX7KK0;)afl77qY=T!_a%_b34wvey z#G1Vk^9io)zAXAi=DT!Rf06DRU&g)Ac2~xH@l}btxre0I<;F?aTFy_R?~D?`jZ6>Z z+rFZv(~R8`NAR}*$I1Q3Z2RNf)ApGa7v0mN0Sz1@sXUNn!n5)lXDID|o=Rc%{s&i^ z$|pM|Qtw@f+A^)E<1(4vPD?>sEP_^mX~MuKrpS(_n+mtnle)pVFBFv0{uPWxS-N%5 zZ?xJc(A=%>990(4^IGs3v$Pr@Q%RmFWW`Oxyq+j9<(0A;(&z8qD4_aXWJ6E3D#Kvj zx}{Dl2VMYfa*-ag=TsYw_S$F!;F$hH!~z~njufJgWxO1zK-NYNKLk(E3`I(5hfu9M z1F9$m>ur!y3f6t6f7M(+*saskw+2EC$T^oaDQDx(R@2I~Jvx|^OD&h5GF9sA-0TPl24yoPxQO@tp z1O=0fmaU)%9}rM^OHsdG<{enJjhn_kHj4a8hcw1OOleWOZz8Y>Y_m$uG5^#8jH>)9 zsj=wuQZ4<0O5fSr%^7#J-NhHHEOVZbjFKw@_Ztn-Cr~`OHRTEn8~C@%@;BJEvHY(H z1YA#Dgvs^MU-S;j;G4;4eJ$~d7uJabsW#I-nRj6-JwWOWFT)CrI6nu^;C2{-U-SYw zgmwToDyBqTMIr9VnOzS6>#Oe%9)!@PNVuB=9TkiLNa|vDHcr{Em*?+;KG(bA(lCL% zgzGK1cGCFRE7rpiy^xRR5<8T-fCl!SqNp8A2~1DLdKRH-0!JHJ>uq%*Jfb{Z{a;S( z=w=s{JtGi0ID=$Z=|7-ry`^kAHp~~rsyS~7<@%V(L~EP-3vTY8svy*80{Lb0=A=T} z_hfI|F#Jy_T@b^+BnxS|l92KY0M^x^c%qIbcE=s5%!mAF5E_o^+5*4c#sJY1f>iU8 z1Pu4JyAzgoH*NgAHisP*6$Gwcn5K;lNuJ(THM$-0<65a|ULJ|$!Qd6P!Q>l${&T+m z6YlOr!fwQa;jS2QuH#(zy7-fAnIr)hhrd|!g0w+G0u`x43@=D3-ZSAzZGf5ks^TU6 zFC2V76oh_1_zx8QhE(_a!PYajyR z3VZXPu=DmRAn5+GK!ER$B85MV|4%Y{gP~Jc-VW{WD5rm!183bYIR9Z!PxrO-MiiX; z;!)MWQsF|zCl4sivH(E6{rA=_Z9)CmQSpTRS5!zLe_Id#19gM65EfPgCRnHyIY0Fx zTM1dnhW;b9mOkt|{rHQBiZnyNDra!?`xN5sKL-W>LC^g9af1V2(O?ozOw-=wg#?XT z0J+L&m$5brSmV8aFA*Hh&12CoeqHVui$tV9oAvw-;Y$^Y!CEU@QTqqsYvAfW7lNwo ziI|5xnOQ8P!3W7FyQ4`57WgVW?n%&QHB$pZiZ=JT!+5HRLM!A$pOv8T+qPe}=ec|! z!sPIw7kYk^2tXTkbbu|v<*t~vOhz51{7ZeXx&0B` z54myev*fB?VQ3J*unae_ob(GWJd@su$$#NEYvJL7RWflSpEafm;`=eO=Z-%4z=bSq{vY$D(UfE|~H% zVk&Y-Y=SSCP4T@y9H@0x;7-&h8g>5Vk$&~(e`#ByY9QT$==C54ur_#dQZZv7KlrLTRyx|>xuQ>l}?^O{(Ffsg{`Epuf#O?&jt5rd7x={VN+j{H(pfaZU@oeTCSE<3bNjjg()gWRIDMhI(~knuoyJG`Z@l(0JWs#Y z0O-+3A;kP%q579bfIU$H)aF(-^o@0qpa&Ujz(uU>#m2hZY6vYpy5I`c8cd{k5w?OY z94m!&JV;92*2>+F*750{SbY1ST>b&DAO8v!oLmSh4D7c@`RgwlXy6{7FKG{t zORI{31n4YYJw~tXswg1R?PGmVkJM>9G7omqf)})xCZvFy2m0TIP$%H zh-WA#IUK0q{Qd|;_Q8k&_h1FjDK4|SAtNA{_Sk{_{p1h~1{vZdH6oPzaE}n=J4OYkh(ztCNh%{h`1eJ?{~*j%6%R|B<5SFKCUWI z7mK#v;GGXK==1}>5NrqI9~zp;a(;PZze>9BRL9s0~@9&*QW6<|;Q&l&v7G5GC?b;6;_+t3pz)BjP|g?_QD##$&!xfJIi%>C=sw1JfO zOj^c8Mt^T~KgY^Lf|SwBZ34;*A>R|^B@!n0?fmJ~g#XTFfBrp8hy*Qbedm~>@^#`r z?IfyyI~i#FA42G)-~8h_%ZhykS|kDx?~MNW(CiaHILFu6HGWq8=i_l7_RGTlf2TW8 zk{cqhE4p1+*(<9Q8!k;P8gVjc{&fCecc1C9lcXfcH^}Uz_g-IM5I=wUbwBvUy6=;P ze4}{pjZ^Oz5bu>A8+_txu9-&SKItPpeV=B*6aXFKj&d|Xi{!d(@GLq=%~t@hFTf90 zU=ry!Mj3lHXvZzu{_rnZD}SNj07rNcl}s3n=^tm4?RNobf4oi zZ@FH@80&3{Sbb#Wg7+w6hi>>7O>mWD;8<5%)?SHbj`#f=1EiCa_wYiLogGl$H$K0n z4Oz7;J@Bf#;N6nU{PSG$odI}?r!>OMoi6bubkY3bzGY8WHKDA&I_`Zd`dG-S5AVw+(AicOaLCDe6H^J)1it=O{-A=p|(q}8;GzFpu zuBjFSszK*9FLNh18K60?S=C_97hV>bj~L2sjiYco0r5;IK%ML&!Hll zm;7Nw^R3lG!eqT|A7kq}r&XiJ>GF@lHq%fqR$L5Qxzj~fAKCPzmcFQpEP@ZZD|68o z>yDpJ`^fzJiQ49I3#isR*4P>Vh9C8Z4CuUTe4XC(F1F26t%u}UbwtbXeRL)gbr;6a zsqfgb*kgOWP)lda72A;gBOTsER@z^ecT8YHE$bH46EinEzvkFIvh7&;(T6d+Pb9m3 z52fDJI_xAZtQ@2_aS@x-Oo=HE#~l zqi&nw@~v7VN_~l4$gH_7aU==lAYgy}H zLeCe954w}1tb5zQZE0zb*BROm!+d){n-P9OAj->!c;K54y6D)+t=z!HCrLhG=()Nd zg9V*KL}`L_AY{Dx)&y%ov5^|t93?5+O;jL4zLzw$0dJTK&S}x~%$&*}N;O?0fS8P@rYASiDX2MrCq$NcX53{bl!PVhD6 zRGX^PBP2nbFDFJn#1+8r&EX?NDte7hk@#8wyFGs+I-P!mfBG1&-4k;0S$^*A9UE8j z3GoYf^>C6AImV0wVlemRrxpW*YCE-UC|3sL44Ga&4m%wS$!%`-Q^NzeuM6qia<0G`AM9h)lF=wLB zK?y~}8ORE_v|pCS5WF6mX>#Tx!nY#y&Zm6#{PnEFNZ<~!V7&9RUHdYMCESlFsNHyb zI$n-O+-qCzVYSBf`LOf2>|AnfbmWbfN=?`EoNYSz_MDGG`bpUV;*B9tEqll&V{?)M zr#b}VA;m{fBiuuIKA#jCLh?HBD}Obvtof3&ScyV1z#A%weU4PG(zyYQ_W6orR$Zbs zP31yolEsAb7`lxOnN-N&r$yLr53f1SAo-cH2kE*MoatOPpW2}}?0PbRpNS6Nqj3TH-Iy4M7z;ILy79REMB9(nf1n)?W(n zd8?qUal0~^#Z1*F$>-kJO&F4>Biw+PR3xDK^m`y8@X7PFeDHddctd4sD1)2%u6CGq ze5iYs;j5=|B*-44I5&Xev8N-!@c}DycN0Q|H9_o~j<3<#^I+NQnPK5Ta_dJg+Rp<^ z4qH#ruTrnIAMM3niNGKWk9OuR{Ln&F9tiEyIwxO?@P#k+!3~c?<&}^lirLdwGyFjj zj_WbDu5=AJVm{KSVc~lX1=%4812iU>BFx?QD%krt>+LI`OvPi;mTa57eqR43YnJom zR?-3;d-SyXC{wc71}3GUqF2(DFE9#jp6vAw4`Os`hyxkNLg@0Q?OA7$=N<(x{>J}+ z2KT1T&+>5KYcl^_*SRJ>C6D#1rwmBWe#tD`lTh6Amp7yVb&s+PG7Z?EQ@a#4VsHbM z3?mqtW3V@$#;F^vIC9--Hvc)*A}^i!LZM>8gmvC-J=*CPTAPu8?wM>{8);jKTw=3p3L%|8^;mJ zep3t&_;EFAe?msFwG^GIB?on&qDanW04k*hZg)5M)@qlfR*xXup=W_;_C4kc0QxpzhHeI+2>4AI3agvicXxNOFMe+t=| zkhb@T7r5`7FwoOSz0qm*m{d;WWBtyABESJKbAiCXb$g0!Jrm6U_VS3k``}MP84HPP zJR0ZCLua?9E?)g3MT`ICYL{SaFHh)URJLG|7o(YH^3ezFxzq~LxYUADKQQF((-eGegw5O22UQR*2jp5i^z0KS54tkVI*KaQc zvs-<(YGr@cYW>kM&^5m2!*TX{Ej-&-J6d#JFlcD~33t~{x3etLe8a=V`-jx)C`(CT zy)W6*ILn1wU!f^=BL^A+CDJEvsZH)Tr-sjYl@xH1=3+xW0|Mk|#^d~f({`uZThtt{ zJd8k|(^`0^4f4k`fp+CtqeDB!GW4jm7F!Hk){>@tvmX(RZ$T7ivcp22v;*k7?9> zzHCobkw7jVq`uNi*IYmeQH3#VB&6HAsd_BOsk|3*5-s@ZME z9=>7DrwD27eq)(d49imS1K*_VYtO**AzrnuCS|MIuQoa+=b?Sc*kd&*vL`d&)|+{6 zY8-PKJ2PbqQ0&%I_)}`VH;UKNXSC+b&Vxb*E#4KQfX z!5xM{FTdwG?>*))r;A>JXj!E_E`-zotD>X$cF6J!gG8^iO8Y)Y5wbROPY;opOhi$vFn0#DI8 zKJbQwIs>YxFPL9@%|_>*Hs!@FD;}tH%w&K#!4DDi-5bXR=-^YX{;k|cHjZOs#cVLc z%2E^#ZeboK|HAZFJii+sIg>+x*!ahq1#lDXAxwOMgQ5TxOs0L^V-Yj&tRniYdyK=^ zaOIXe!qTrCKkO(-xA_Ryc0E#?!crt)**dNbm2Z?dZO%|2<);e*FY&q;QfRv!FdEC{ zdmdnkoA$0S;W)4ecv72_x)bq za>6c!{AP8&9iZ~WFGkh7Y`#X#0ee=db*=Wo=?I+w-^Nep9Csm`sqd4W?Wd$Ns%h`H z6mGTGBPe8SKsjnn0eugR)skD82A6&T?TQ7*XGv%M5&zYS3igOqUW4YTg?rvg#oI2< z3g4+Emk)lft~U>2xl>AzgW#%%Tvx(AWNe9H?uCCxaYP!L-)w@eHQRmF(TWvvLvFQI zlv=zft^jYt|8&B63vPu^ni`KrKoh)1dIB(s;dHH^!NruHM)S-TooPWY;&a>sxId4n zO7NJP%SEF%UhX*^$6QJEV)!oZ5F4G22l>HiF1dK0hC=JHmg)}+{BnUcU~F4mvjCSt|jtP2YSSmfCy&U>=9q%fij+Nxd~gMa(Q?7 zc#}0!iVe#98IE{?ZA7NWZ#Y^=?Pp+q5*`}p{#U+|A{rMh`Unb5{~xNXhCYFkh6juG z277Phvhff@o3J-4I?87z0Ctk9ix@?d>AxC~&^v3UIU2HGn+b;WaDLRdJ9DxiPYAeb zlrR`Gsx+$U#Uu-HI9IL>{bsmXBoRgaX0b+5;z)_o$cDN&hK%lBq~S@$rkczpGq?Y) z$JxMY)MgRJ+Mh6_o_DswRWuncc8MNYd)``rPJ*53v|vDDMk#EHe72V8{*X=3n`@g6 z2^(o06STV6PU|3mqo-`>@-)xPvfT}z#_dC!*3E3ez>ud5TqIHDp`223-0maf5|BIZ zA!odt_`++lQjmU7RxEXVR!T@_7E)SEr-UzNjiqiqz)FUY^c#2zQV#-*d*FFU;j2}8AE3*J zyRsw6wrw`P`T>$-S2A7`u^*BlWC z>IrYlW*qSm@5#gvaD}W?W%cKl7o5*J@=fJKabAzGODP&Vi8#f1vo-J+AyZ`snF|RC zo*y$58jE>-&Xd1I5>tL8)m2x*AbBJZ5-sY7>_Rge7oUO(D~1nODZfG%I!Vh__sOrU zK2HNU^~g53n`6%7xlnq}V8}(aD+{S#*b+iQEabE&8ah|ja_-Y@ly!QmHTOT(OC>g6 zI#s9Fpt&j#4&ut0R`5g0vl{Z>xLnZYU%|^;veGhALY8&4*-v?`yni2}pM2R19QV#L zjH(d%R=q@9ylKU*m~nPv##N!;Mm(-HZO+1$?uKZ52)1=HG5i0t0CLTO{`%8K)#8Eg z*Hol7<5wsIjUTBJg(+jfXStyl^Kn3V5MB6OuE}(?;LJ--ppA$K$(=sOd~wJp94J?8vu))sOYuUnVl>^o=@ zYpTl9>54-{lkK;0p9X-$8KSOg|60w-EwSo9k;g|RBS+I1(CI|2!B(F1jAaIP4w6__YV(`!DDe{RVwm#654*&#$aKIXP(=to;wGo7p|uh#?5|ZgEbE#N$E_!SQ@G7 zuVG1Crq{^|TSrM1ZMi#!mf+Uqz(u!So6Gbp#E5ImUtA=a{5tv?;fLh^ZGEsx!b7iz%RNkj5ga3 zh6d6ATj!IdL%Iy*EH&YZ#h^w~%V$xY8IPOOG32tnk&dEddnv&ca zrP0U!kJ*nF4UHy~j+VT$OB0j(56xL4Es9C?K%PdKkFgc(!61#Dp@!fIBIolx z3pt|8x;x(n@tnluN)}7M$<-eS4P$rLGq(KrGaeHJO^Opa-bUQUrlT6ui=*eI<|k?w z7voV*MG6_%gr|HdK3t+|tmI0YI;yWu>2Bfv*G+9zpV^Dy?uI^}W7wm%W@nLCh3v>k z(1y};iMF-^I)1yHa*B>Q>#*YEt<(T#Uw#viwEi$qMope5xkhUAkor>tKkwF7ejvFNXbgGGi zn*nY~?b)5{XnvC}e!miZ#t7)^Y>h&F)U;#IvKTau6lhHJWg6*aMB09mkx$9Ob0l-D zOsuUTx&ykXB?n5FG18>I_BgA+a_vQnz#|;7kW6bIz)?Nd^j5SRZ(m1`!pnF|3ZzIn zdlRgyIfNtPN|nz3{#2OgIHzP{My}h4vD;eC*PX{iCY72Pk<~`BQO?_@cT9k7?=8MSU9~ciUJv*#yf#_rM}g1-o6XOXN#^(N0?n z^z{!pt!*kxJtuaLB2cLs8JN{QgQSR>r~6G0X1nY|)@XH^)7RdopF2QE=L*N{&FxZt zY}Mh7L3BHDS~^+AM33b9Xw`N2ba2=*gGH2b=Q}@+F?Zo=nKBaS+}rzQc`rY zx;IiYKG`NpgLXTt=y{_v*G2%e-AwTS%4B?C!aCdbKrHMbkz!pj6?xCkP!G zM}j2_aipyP44*@;%Ql^uZd8S2bl1Xby6HBM_E^j#8r^ES5!Pv- zzjo+C@kA0q|BZUzo*Sz^0@$4A?DtZ35t`$T8ZJJQh0n0K923;>YxOsHcvu51^Ip8h z$`ETH$0o5y%=RJRiC6cF#G8BJ7_qb#77~&Lmaj84E4Ax6G0^%SN-KZy`+po|zDC!7 zmGb-vvwx?BmhT-7BuL$TB`n$%}>v@vN z^N$_5C%tpyqLf>7H_=H9CPK-jEHjT)O2KG}54=8W-$L>aT zEk4J_s(`Etb4clWK%8NY#phV!@an#i=8>NFv$%L8fRg<~B70(@Er~D!?z-csV#vUH zV)V=oHl>F#so5GgNm<#aFz{Mye(H(W0GMziEa339*HK@)$kyT|zKprEt8>+S?5l=s zR+$_zWEf^?1ATw|V0T&NVFOlHm0?ZCYG@$6;Hwhc*2w#8J=uXLn@Qwr=FEsB|3E(N zd2|J0kgzl;$A;pWM+`_3|x)>~Y(-~>FY zi>)nqi~Ts$yK3GGL6G6wM>W!iL1$W0I0@G8^-vp<-fgtwXv6ItDpF2PbHjaBsKN5$ z$oKXw5tAYX6<-*5H6&0lQmMOzU;;|{%yY0Jc1vu|D_w=BY!=|4zhLXo-e; z+A~WS6C5+Y#h$jGeu{8E#qh<8CP*_;4is#BdrQ#B@eCTdn9vIEq!;-C%<#cW;N+o# zrr3YXJftE0N}Y1x{fd60riQvA|BDE_`xTSW4b(h7uM;hMY&#RfuA1W($+q=wu>#ZB z$oLHSVgB#;x{2Fz+{F)S>l;49p5vUxeXH~Sv;?8@--j}e6{)YgU(0p*5SSGUhi%vS zFGtqA{sSqk?);aPzdSb{<4kQ}obO&;Q3Gel4@HXl)y!(y_j)(-@w|1;`Vc&%kRE+8 zYCPPXkECi0kUYVo+!|(QLaP`&(e?|&00V=%-M!yE+5&+ku~*I3bLwuSa;sWmxp!Qd z7X4ydq!x_c@g4bJ|t>MSQM zujq+p5r$B|-Ye}|ZM64UotPh7cse-vYp~K!q90EeJo?TfJ4!b=pa#Yg0C9bHO$_-9 zC%tn+``OzOp*}`7J|FV2XUq{bC?a<0dFU^F44IZQhe*vIwb;Y1>1q^vZQx%wxkO_% zIXEMT{5Xx;7R_!k6P5KLEYORNl-)GSch6+s$=h~M?zGpis&*|C`6P5J_^`E)c!?eZ zNM|Jt>4sSM(o&3xI{z`=7{4c3OqwMnH@mR-1xs?h#~-1s!bmtT3VHYwL(qH@74_pc zmuyoqCkN{B#D5!d2{?(qPKUD>`w-%xVy=cLEot4wUBI!IW=#)Vw_^jbkHa8qDo@O-0xS!QHR@*s^XH8sf-E^2r3v|>4-Y0X5;-~90x7HMa z9&Jz7oq5-$ti78k_Q#7(4H}JM`sMLgkC0M9$1i1O1{eaP<H_eO+ z1_6e?HkDqoM#hf==39~}?~w@W^|Zp>LGnx_)FDe#D@#~%O1$J9FGh5qL82m5PUlcx z%^;f*{iW+TIsn6-81{80=Fg2-*k9jF99I-c9g71b$fK$R-ifyf+7C#`B^ggq&1Z3A zD*~gP=qLu0s^wolxm`EVhHFSR6*Y=h4=U~&nbw^lash6~2R1_2ODf+{ooT)?7T-Gu zt`3LN6^>!H@a#)Y_Kk{yUb8gj!|ib#Pjmw--PEbYmW$>`(5`w5y1#r=5>a{0Yuf!w zeF7tH?06|N@;A5Wz@2H00h$;0&a@D%J+EY2WkAvJt`!n|Lb0VjvtkN4lEm&N;>QH? zL?r5DJA&`Ha~neJ=}v^V*00Lfl+XnbbzoOWW|x@-v)d}yr)JelDR0f{1+#a!2{gsRhk?Ot8lte~Mn)c`QIU*-$;@z4OhX zC+wS~;Yt#njmS*QTt}+`f*t9&eh^TQhe}+}zSsclm*K}gvU-M)0q~M&%ePURUS(8n z)o8=9bA=q}v>c5vOc}f&or}et6)P)dGcI-6%314MZ4d?>jtN?A+LMRt%+`i6Oei#& zVcg@DOJp<6JwX+se8jCVSf1pXGv*ukW~C)lngH(A&{^QLxrkceu#0_vn;HKwgjhHrh zN5afHgbrxOhLvE*#moMFcKMQ_e`2^AX`S7lQ^a1>@rZ@%KoSYip_+Q7QzA)nU7Ho~ zyH{z4;21|)FD}$+GS^vsPZMW@*l$8qIf+$c9s_RlhC6}d+u^(PiD{#i?&~?Y_wOCL ze1_F3eh$cWRQr&-1w2!s!xmUv*EJr|3vB&w0fyv?!CHe|+kkI(3twB+4E0BO$4Tbz zF+r3_(1^a(Hlo}@G71oQUMZ=rBtMVGu&SmS#RoK@4t82@|(kNc<=eEM4r(j z62(ZyZip_Bk8yp*U{_HdI{0Bf>-;c^oB`W)8P96pq* z5q;4XTe_}i{q!c^G6zU#KJLrd!Ebe1m7zUfcSd+8c!-n5ycp$q z4WrO<+bul1p`elWX)kbDurfK#j$ZjaoBt^3$_qhJws}|l#D=vaSh4W~adkdBQ`vLj zO%&GGQPoVBBN`2k-*4c85Nr)eYQuJt-(Fq3VXIQ;aoS7U9toW96k?<~&n7azkqa93 zh@Ar`_tQQ<-w>nUENxso?AegoWvcrNQ@E$vRte^c`$pddX88X^{RSj)B+>B4nge){ ztgrBB!mASdxEV}ElihV`3jp$e#-~d*k`8$f-Yc2@GW8jaR$Fen$xB1ha`FSwFHhcZ za9Kyrqc<^(Gk+}Z#}>cm>Vks~Itvvf*jf$%wuVnfN5E z+*C1hx$JdP_>loC-9Nm3{mNL|h7)8=GurB990_ZYGNo{ZO?01jobG+O+(XM*|KLi_ zpC|Ol%7sx;hZ9=nrv8h9SGCP4X`QQ~e5jXqN+d8@PVc#nmnIqhQczH*RKo6pnA90@ zzB`z3Gt=yHVdz`Mxn#djYod=>n2%*Ly!_RX{K#s6u=T~xx@bM5@SPtlHty_`ms0>b zG#hIGC^^E*2LWV|ZUb5mZ4~2+9spooZxPY`cX{wxP!hbR0;$8zvZrmz-!uR8l18PQ zG;|rdP~a|`NWHuoFyr?5^{2f=dJ$pt6GHXE+aMlf1n85FP>UP!dx@Tr5ot>yoyc@v z2SD@RYNTYY2Hg!E{JiaRUgMleJ!|EMViM_d8$@Xn&I3ZnDBsaanZU`o!+XZ^M*hYM z%$=I;jlUmy!M(eO1e62FQgcizf@A(_C8IhPp=QZeP)~zGf-Q|iyBo{><%zeq!VB_# zfX%`QW15P8QkJ#y;xkDc+ubw%W#@sv;`rpqI`BO*ZNJYLIimMiLe_oTUPUmUcc--I z9%=x~?Ur5SZ#5o|S=Hr(VdxZJGf{^ImRJ5ldv`aHG#H+NP2Zk<^g_5v7g} z%g*~&2b_)So`b(61={t^=2&?-!ZCU^5)%rarIL45Zle7wS}Wxadru&O%67{a2_GrB zsCMO==lU};bRd%ckj*v+NMG$s)krx+UVil$p<~N7uH?TOswz4M4$0R39RK-Q&BNZd z;bNWm?U+!zdtcvrJ?nf220CBW>(!Fvr_ClAd+XP~V{AK;==G<;{^hy_Y0a!hN+HTz;cGDvMi2;KeT4D&VMZuv4R! z8je|4$Y#UA%!>z3vsTLr{t*@|%KWvW{d91MyzjcD+HRdlZ+sf$T|goWl+nma35ePP z7=yJb4A(08J_e4jP`lz@Cx^SQeyVtSn;AWK4xl*=ejnB0)eJ3b>U|6X6D?R8IvC&s zoCbrOQrg$+RkZ05C%ncUjtcD^z2Y#k5~V-(y*S#2N+NaYy9Qm|o2@drAlPuM9~Us| z&v;#TGTLMqlz8kqL5RGiK=6zLhw5tZmV0 z+2p1E0B&7Zv)@*{Ee^o_LaC3!AFv~>0Da=%Dz;Rdw)|YT@OpsK_?ew)&h}M^vDpFF zHWNzy$=}?tsZoTOHc&wxBVol!c3{H-cECLzdI-HSnDZbpnaW}KcFTmx#|CRH%=vGp z(>sp&t}wwJz;{IHmD z-OnL~64sJzA@T7?;zeV^@a-%)Q=2q@rPk%U_d;J0EF6W~I#O#vTH#sErfF{a7Yh>?a=ojGo=r)_K}ATK48FCmR2$T&Ke;fIkNCVF!G4W{DCp44h&8q__y$Hs zzotN%&o^ds^qUY&|KhM-^_rMGK9C>zUTNB7QG^B!=}T-~z`w5;iQrWHkslITAAY03Pl>Md-zO+k%_cx{U;~zULx}(M%6} zhENx!E*c)zQ|%LQpP7FkjS=h z=W}mTdXfwp{9R=W9*O~Ihj)HDB8eurzCFXN1T9u@A{ z++xeF_i-;X@jDXlwqMj;=9F~S6r)Y8;W;RWbv4PSKd0IH+KSJ#6XL|$53q#w_vH%z zGLm92$P5W`uX!!Ge5qG=LIMyuOxlWJ8eeY1;Pk`b3n`+suI3>?7Tddj?OD(lay$MU z8mg}!SecuH9HKCkklxU7-mZ0%vBb6gq)!RkM~QQu^vAKIpH%!VK3M@=9IC8hzP%mB zpfyR?MZd^OKel3z2EABd8(c3_5$l|XJLmX`wEIu9#6HeyLqq*A%G?P{1w!N!(a3A@ zSDC^%{g9Q0V0frPtCVP%3uCgzv_+`DysU7oGA>JwgUyoCPSI~b3j=+3Q4`fLQU8Ec zq!G;qUtq4sufg}TCHdF47II1YJ2w3TpV%$zWUspIAbo%(z<=8j9OsQEX>(g-vz1 z(Fcdsjqkc2VveMCDMjZ(%4Es^$d#^Zu$O_1ae@42cT#aZKf*VH*b6Yf-z7|B!W}yg zu%rj>pvm;@6F%GvuFNBPpqnor>V3ITh&FpWzcs`a>0WxbJ6s*(Yj_@0)S8bp{@pZ; zjbdcL;U+7qe*LIp`E#95Bx(V^^#!WQc)vHY0y^v~sk*AKl`@VJou*N_-uV zgn1-3h!>3IF&V3wQBmqE2P@Ci^A!NAcX!hIRPXKq*K`D44S9nPMp5(< zPxHEok=u6^g;w!BytW#!X#1-7eaEu!=nV}r(B>3qm*!>r4Vx7EE}w}BcN6m_f@gNX zU(dH+@`u7KV!u_C+&>NS?1!ecdtG&+D7*AFu!WZQi)w`>va>E-BSV`WWq=g*q^xnCw(NhGT;~G)m@2y1+ zwxh&#ENuYf=G$PdM zwx?zR-ZL6Lz17EBSY_e0aV1%ix{TLlC#cBD`t7xv=_+iY3*o(7;aQx}DBmX`|d$p-qFhH+>39-((hA^Sc_fnZfnQ; zxv8{`Q+aCU*#pzsXoU1kTakM@`^+v;1*rSH#j5BC6$ zV^%ejaddIBc@L_{QD)3hzZTn%BOhwNxw|MqoXN(22WA!ksZ-0K{E?vTJLrrnRHbs2 z_v-sfq92+o-iOkV%qk3LWNbe<`6Wmj#y+Mu(mCS4VsnkIO5G;Rzn<8=b%5`9@)541 z>iA>t`K~X=lTu}PaFOyvW08kNacYG8)=N>hk`?J3;I_0Mf5>V$xPFi!+IDblcepmu z9(=7i;a~8Co4jA>Ku9^m$fr#rlk5JE(s>l5b!8;`I@>(>W?IVU^PH@S_EVa(laBj9 z#L_SLUO=s1FlNHHC);eLIzMg|pW2GeiOnR|sY;43xBPm4 z_R9s^qx>xwp=i)%d}f@F^{@L^axuwI)Vgv9JXbj8hH5?%uCuf&ncqB40I+D(CvoL)Azs^P}^R;91#) zV25N;xbSuC(>99ZYCzM}P1>41qU$xYlL+`KVAab+YY#dyI~JY?6S#ML-sPx0J=qlY zd-8UR^c=-}p}!J&WJ#^9zRjVcbUWFiB4ZFyKEE^+KIi3!1C=uVjpca8{sI>i!mOyI zCI0@vu`jH9iG?T>Qy%*BN$|zKNYK$pA(?U9RAHDEIpu!UXxD@V?SRbgr!%E=wXCza;=(UR&C ze(?#ZWC(5~2iC6ndppSE53>yi+Ax;jlw*r({$I8vZw)|eM($&Oe@}%T(7udNzu@uG zx9Jt-D`^R_pY&hud5d)=c=_e)rlkLk@3fMl)=u&J z$o5vH1SI)2>F$2jM~w#U--wpKtXMBx48c_Z09PNJ7d`s))g}6o zWFRh1%YY8M=+IX8-;iU0y8tawUO6j0eH=cO@IF{p>wY!Yz?i7zlsY~<{!k?3LcXaM zBrX2F3gNN0VC-KA)IW&VCo^&N{|Dmuzj3J-UJC`${Y6KVaQho%(nB|HIS&_UeCL1ijg#D|v^h`=59IHQ;09ujQQ+ zear(;RofJTo4TK!fvB~1DoHi^W2O9K9)D^V$k{P(ivx^v7WO~mrd<1X^?Y*;rkS~NY-%dh(tNvu{&EX>k-sXghr zq7(C`SSL3lJ@=r$16d9hH8lR@aIUXTf<;i>yXDwzI_y=0#&R6;G4iD^Q>p(>YY+ZrpfAU{=i@ zX7RNr0!20c=@-?iddi3mg6t!Ck1$D?8Yhv)rY+n?zbx9p{iixk)aXCA(p zfHYRm$imAm(=_-Nd{|4xsLpq42#>tutm0}XCqL7vrA|}isr%lMd12zu+@&QIN5aco zPsb9uKx4eR^nI>&K6hj#q-ucjfQ}S!1YNf)pl^VJV%PH&7=OUu*M=+qjNYl%3?TLH zePx55%zY|Uo*UTrv02JmW)z%fGoRbLR?F+>a&_Rcc2nu&(_#~GE&6QQbaHWSF4fLX zyeHB?5l60zNP79?e5I1@nyz1C4c+5>_4*|zj9=Gmt2_S%o9Ph!=kQK$tevCYlaB7|!sF*I$7~ndv>=p+b(O!Cu;vI? z0v`b9bat`JU}l8M*ky;c#aLatEaAfCnS+!oS=Hf^)7M9rvcFGFRZo)zsu2VDP^HsZ zsm<-85;~|TIMJ;TKSQ25T{a&+;OhSxOM>9@6eH&PJ&t$07QZ_82=IQ~y*l?9&aHjF z{PaLau(n;I+NroT>l*>@8ecX5jB=|TG4+>&ePA#A3knbA^T(T0%OWh&pgDc(p;*eC zeaCzP4{T;&2O`CQObS4kz$o?^t85HR@_|W@?+MXlgoDRGcXz_V$3w(X^zWwBzbTmk zDwzj}yFxT8OJkwK*J7>b$l;8+fK+n5z|X!az~RCk@?7h$9vd7?I(i7$6pe-OuGc2d zHkc8&?hg_o98L<<@P*9U^WSn9teQcpIjk(r#-Q0qB_S?cxZhGxa)Sajv;=OEv?b&( zL^JDzzqpbTu+7lRE{uCAq8l5443JyYXhhyoAs2I`eKmPQf==;G;WD=NLNPP$*@8C0 zul=>xWLaO6cYH(ql_|MQ8%ZAUpvidX$_C8CLuvh$gwD*WIX$|l_R9iCMkC_`Cs8i6 zq)g-z>2&NN318o?|0%m9{!>E80%VjVFanZ<2h8?%U2;>^`gn3bnl-k4PsueHI@E%}2 zAH8?le^JF4P}ec$1s83CrT>0K$Lj7tTE0=++z$R8MT`?N^x6tVRsnbs`Ib|MX6Uyjud>CKUQ8Lz9`}~qm#f-HXBv;;r`}=l#{uR&)f(g<% zxWbTa1Ybn^n^H!3Wu!L~XVLEF`eX_@_Y_H`GJAa)A@2}>TlZpR7_7T^rU+Lp31_6c^9>1|1FdDY}SElEf;OwctJcDo~r z-06phk&nkLE2*~P>VF$D+-uss*{J-~E13JuX!AOw$Bbibz`jC@nm{DSyMs zZ1+c2m)^Z_BBlQ25-Z$*o3vyKszCM6>OdL174A&s&O@5Nci}|mr*uh#4Gxf)Khx}C zaYIaAavlF2i#h5|x5Bft1%`zy%lL65#}X9WHk=w$gZ%U3hOVE1Q|%MCHM&iDABa(u zNg5BAO47-fxZ$%lI)1^zr(861YLPR~EaKLS6Rqq*Z~jf8jC-#@`p-4tk~S3&Z%*=! z*{o`fXsC0y?@UP{EVRxPL_ z38)b*MJ^`sMrgqI8y7m*TUI%Aru1w?Bny3eeitJg;$U9fu&IKDv@wLM^ZRA?ygDxn zc~0L9E8KiEjK8h4L2Onf51bVt;1&2uVs!j|5wT-iNGrgt`O{@__4+MGhJ40&&u)9g z<;g$ngDUj}Kl$#jbWlS^O>2SUOe5L2t7}%u780b1D3N3t_Gi|G+h3&O!7*{uUkv(JYYPDf_F?!27rvMwSe20jj2=@);0%OR37 zwS5;IT6r{6Ne+AzZ86YaU3a+g#$6Ey!@&WfH3Aanl)3wYJVCyxk4{^O5ip#KLM}Py zTH}u?R{xFDx$pt`li;2XO!ZU&^A9QdwoiSdE?QXr&JS|h3wMaPzkpm#G+xU+alTL@ ze%HSL1a*vS`{qm(or+O2=P5N{ z%$*57VS|B*=I`^9I)wKb>mFG&V8C$qBI}IkH8NI@dmLVF#4JBLY=I)^&a<~ zL-{*M4c4CvFwDRrjDVBr%O=eF9LPa<;^%>|X+wqj_#`n9VmEMT+cIK}c}j%#r`DRd z_8<=NlD@8Ejlhp8!*=Nm99pyWbDVmds45G+O)?tlMZ8>gNlVcajmjOXX)0d@Od5_w z8>;Y~yb4F);-V9Y9b}}|zds%t)_UP(Rmj#{GAxBghw%Dstj0&?6POnpHrT$FMESqZ zb{aDC;Zj=h#U!~;(zI~cH00KMDkmOv9OwQQa8#{6;cef0-f*3vIUnAFZ707qy)d`V z=ty%)_6wFiIfTjHQzmTnn6J<4){$eqWN&gvPgHu1xsJsQJV#Z3f8kESgF*#n0$xQ| zNiP&GEGR`CMQoT62&wNfpg&t*Put+oQ$lRpx2MkcCy z1ZaGXk*)MD&{|=#J8EjW_+ab(h)eU-A6-uDEBdFeC1Wu;J;%;go@2b2Vjbv`x4$&( zZNnGa84NsZyp<_3{`I7#E$cUSQ=>`TfWQwV_FEG2o#Q~>r@l6M|CMqgBcYBDCNDaKG=2 zo*`8qg`3TVL*0!_U%_;nTK(6dt;094l`xXofD2~RQY$nAtgEesaiB%b?Rz`c`bd(? zVjk)Y8i~guAYSo3&5GwL^Qmek2xnYNhkms4o>5%EcnE=aQ*tb`Ad9_D_$#kb``VE9 zv#p7p2))L!aILWLM_)rPNh-d^t`9gixmvb~EGc9R8RA#nD--^p0vlClCPSb`_Xc2ml&nMXSp2D6hm<%etW3q|@2~GMm@#z@VOR|`0wOpn zU=pLrkcnZfI4b9MdO z@&d4FA(O{Cgnp>IX05tMooE+J{5!RgrsoK0*QR`Dcp`(TYg$Uc28D27rT0xaJ4r}r zqv508PLtD-r0z8OM~2%kKDNY}L9o|Y9i{pRL-vBMgg*;Z10BpL-mW#ha8od=|H0v? z=hD`0+RnSld0%E`D&zAYmO0V=wfXb<)Y_8iV0tb=bb=4Bv_{9+nDN<7!;gho z?bQZ!N{AL|-!i;6WpH$sOgx0j8GzvGm6K)hZ-Mm?pjIup7xLs6&(R5cfZu!B z=K?IxL>>#Df<)>W@zfC;ot8qoOXA8;2Vbs=KBV!jAVVhy(_mi{g-&KlT9vQRPZO!? z$%J%Kp-Ij~3WpNsG>l5+F(bgQyNNHSzMPmK^cTiO&tsL`Skq+`34=Je%(&k_AD7ML z2L>q zs4u|AZOU_WpK3U=#i-q3i;mV}p!LFACI}X7ktwyyFp9=qB=uly_HwXl&(d2tX(>q= z+VUKoC?lQ|jLRAgH>}cR&_;baT&Mv)>UM%0bj-F_F}t3Z+U5CyLsh@DW+6NvmnlWx z!xBPIZ8k3H_k?jESxiO4jB_Gi30NsMUNA2FOt{4!DyyJ1DeS%b%lm_V@5)Wmxn1in zQ?C%S+Iujr0LIp4p#gSe-+**D(F8dc+gU2q#Fk}KwJrh$?wzvFLt5ELb$!DiUTse+ z+CYXrM66&Px&V2X{~Pk~lAz?3kJy?FOXTtDiO3tkS^%U`H5RzJn#u%8~+W$c7nogAvChR)qxK1m$Yq`%r#lZ)e6ZO)-2wij>?y*;RhhBB??u$OR@o^rr)-o; zeEOUJMjN|9rHWO;b#hF7_J8ngI&6o6%p&a3tHF1kjNq|tBW&fKa@XM-s`8M@l!f$Y z{#feM()yM@o1g9zCZb>F*K2aRtx3DqM)}l^H1Oyfcu2hQC}cIN+`3u~2zcwqgl|gd zFXEpf$$A^PielXI`2Y9LsR;%EokNGWYGPYX7r zI^1yErI%pytB0k+dgQkQq7n0(U1b04TJwCk&t+90pC#XV3^<_4Ku1O(A(V>}3iT*e zU&o>*2Y7xO2l7Cx|M1jy#eL}YQrtXun|ow#Akxv+MnBTfbIPnT-xijbxJknza0-+9 z=0tK0p3s;}A8T9Tkc&xqdMH~`_Q8;S-PZsR6du>!3>FMjabsfY=jk7>=9%46b zVn>L3tL-xhI+=7iLoe@X z;Z{%)%hfE>GRd*epD$ndjBu@|qnlh=+2)qd^{lQk*@R72TE7#9{8*B`M`A>i<`pwp zZJ#7M=%lkxq2F7&9`d~lPId%~uBB+D1+JT~76Go`p~4WInWwCd-vN>!wAnYaR233n z|DD>T+0V&L;Hw`4Bi9t068bN)_0x^1PhcUx)B=js;E#yb9kd=x^r@ns@J&UijvqqR zHOzND@2|;YUZ7Fvc0yP#@ea2-iuhy4Um^~@k6zn$`#fMZfeNS2X1bP;I`*fond_;DqFo;ouvtk+~}&I z^_1ImshUEg*u(NBvGOIaVl7~ikbaAAWo;dszL7<;=zQqmZ-MJDil>B5G|Jh|Q_fOGV+iy z54!MJBZxY-je9%uGqe6G)Eh}sG7Fn`2@HR0X}VM~Gj!nIrEU(YwCjomTj6ldI$Gq0 z+^}^Y&Ut)RS|rvF`lRQ@DZYkc!G*P&2_5YdxxA9+fD&9RW`;@2)a z3hB3zf1I^x_U&@kRtR?16Py>pysS}j^H@^_Hv9%nAE=66i^N_|AGqj?R_nZL4xCk= z93i_OZr@81sTQHiPL(?lzRv%-uw*HW9hR28`k7htEaR#UsB~}gb{|-6sK>iV3<74F zb<_Vkx84}Lb=Zg>gM@ueYoN)s{tvjPbT(kh-0>)V+~DXdGz?DkLwWM7XPTm6EQH;b zfr^6Tv3TeE{qsh`WP_hR&-ZVNYagpBr-1m06?fcCfF!v3eoGlhonhzcJ%Qkp96# zk%PAb`>O>7{<1CWP3txdU9-VKNl9hNl&-#M`W)OL|ITPn7xtw$ZZ=0W>G|&Rz!r5- zz{q&~jdgzO9}##priiau{Wt4f%4221T+TLco$*2U%KXlmPT`Cz6wo)lmNz=s3xux) z7e;u(K|Ks`(Sz>5&CvAl^@T_{3)oj$yYO1s7C&~q#8OpmiHlEiD?llVSi zq`ua8^)B?#EmEVely_Y(he+0ID97=e4v*6Panemqhjx$a^PcLy-o#|3cSW#n`hHne z%hi^4Lg(R^$fo#_#k0AM{*=fK?@g+@9-aem%T3Lx=6tMHl&Nhj(1oi((cfW%pkh(!n zps|-v-D!CwiQG*E3;ACo*+=JsOR|u*1o4mbUA9WqS1YNd?d9EpBPzhoVaY3aIzfu{ zM`O7^$FXO|z(uT8p}b@MQntyS`yjWKGUzt88sW0nd8MI;7tbWx1Gj3}(0sZd_mS=8 z6L^tMO^4U6jelToEG;|i#`?B-Z~NT$OD*zQ5_far?BJ{jGv`pR(Mno1KNn8d6&$Rt zFD?8CRm68)Pgw0Sfw4m#G^;@2mK3Blo}ay~r(Pdaxk}EhWLG5)2@+{>f}XrKUrgMpu{3qq6TN9v2FdM;0Le zhvUPb0s=mEh}R4xmEj z?0%rTHq=B#XGIm&nk%`{y+mU~#b$)lYsp5$vl)?^`*W$T|1k7w8W~c=r~NO+-ZCoA zsM+^~0Kp+R1WRytmxcs)cc;3yGdmiS*y~OwWLKF-q1MD|5 zqq=AYs{`=;%!NwS2C3NZ-p)+vGEIkB!0 zI`CUB2HYatovamwnb~CTtifbYV@-UV^N`Q5WG0n$71@Lz>G5;-qHBEihvaBR)x_6k z7G>CnA-m2<)*5AlC*SArkDVP4Q9i$Y*0L(g+w^Gcm8&VbglM`Bi3ro7r6@Y$Vm<6n z&Gn7G^P-14D14r92yupL+~kjktKbJx``VAEKgxQVM9PO|CLbyKlVPZbovGsN`&*WE z0+S!q2;nXZq;gqOPVNVT*U-j;bNTWch4KY`_rFzhBeRttNfPigztGQhULosar{*Rb zC)Ih1^eQUgf#e0w>JehfLz2o{Bh$N%Wv{C{=;^QbLGW+;{*7Mzg{K96$J*<*7zxHF zlR*DeAXlv!qsT(+7|Z#B=o&9K48)d|00{W{*^#XK3b{ssvtr;^d)QZ>o^L2!QlNrQ zRn+)x2z(?rma06Vv35V`ois9Ro=ik2ud^N`31aV*Bqx`GiI%CBo-+Ww-zkhshRxoe z=xVmtyMpKR>R<+TsmU!b)KB#}kV^)0@ehPgrA&Rcl)$pcXyO~?oxcAxD{4>& z!2!hJgMHh6S4YMdfn)P?oEX}Gi~FnOEue)uzmT~jtG`A2Fp|!*J1;UG;mDBh8yF|1 zmG9HNWvg)>OlRzu?zE`ne4tU-UD;=E+&gF8sa^A#G!M;gE7T786%0G_+7S!9J&mE% zb1Zj9*!VAtyK!XIPE#&`9tU*PnFS&BM#7EgrA##oG8K>@!&747-q{8TM#RGIMw3aZ z0egwe7lSLBcFU|9QhwZl5r9J|caotBXBD>qV5TfUZM5Aw$I6s?vQeyOI~59whpfX6 zr~0}gk7rt1>+Gw!`G(8ZH{pH-dh@&EKCW)g^wh3{n-iU9ZY#+zhdhGN0e;w(177S& zxY2&#+Y~pSibju7SWzc0ifckjIxSh)cP|g3#=lpg9lx*a@^6V)27ejInhZf#nTtAw zH>x8z`uSVMQjbg(kaUe#Mji?)EPulkgiz*1igN9wZ#q`=*FuPzUorA2I*B)UKSXIm zK$dtNyyY-)XzHkf`CT3AZ`!L>p$z!tg$bv}sobLV$L z4=Ewqnb`PN>jvhmFZ#`gQCk7TEM6 z4QHp*d0blpDwd>>y%6^Gq0Epd{BG$$L1yNXvt_~g6J0^Vkt^LW;JvHEDIm6V81jmq zH?c$Et;vUn3iven)8rGvPgoQdq;f-XIeaGf86LXv0m3jX{PiDh@F|&ym6!&X1eK4& z@|whX`n@?nhWydc@kIAIxA)0&2zSUG);K`U;(I7H7e(^-$CXY`s<+4T@IQPXy|0h? zTuM*gtL$FE25Lob>}Z6x&PKy(|6v(~-5MH*jy^kL|5<2{I6Ts_kX{bZ%m zct{gHP(nfXvb%I&ro1X_%6qYSaWa;X|0tjiU@oZUP`Tj*$wG$<|1W6eld z6Adj_RwxSBH{7@>6FuKt9C626J;{|fo4jf=6xA6Foqr22IL`R3Z(im5G6$3>Kz{rj z)mmCB&_3R zGr>Exw96a{FvKeZHraQt1^qn?O5(b%YWCP-Q9l!m+yU>i_H|c|E?YF;Stg|6aeQb{ zHV;F&>-SH068+&ff9`TNmD#biI6#*kO5)iQJ$f8bY)RY|$XQ@R(7?vmHMksiH^6rE z%g5JY+h0Gv^yR7CFC%I6wt=Ru}hk! zhkpeK1TVODlV0)n98j4U@F=wsh$ST=`#E<~4;9g$+H~&F$#MD~J*kGakzzF!@(ryl z5v{1T4oQYpsXe;K7L>#n46Ly>y(fUHWH>tgZ-M z6tPfrn@Dc&sTq1B4GWj?@hu_55RNG;uBKYu-G6uSrLS!tO}GB~GG-FzBkjPDm3!+u(A$^|hwU=psYck~tCXr&Qj=>MydlvQiYL z-*Z+bQ2(fQ@-9eMtm^D%WZtqRpDRco0X`;JQ7SB+8SgiTc&`WXFv*U7eUhie9VBxC zy;AM&QpbEsEd>kH>0E@`5=dawlT?1$=X))an?ZXJ*5O?U*g)4TQGQZ;(ye->qAW2N zqw=8UzYszi&3bXUtk(9`XRx0sBZU@TKg1IJ9)5Np0o}I=TB-IX zaMgktj^Kjj^cA9$(~-SVkI`2f9ntJXSlI?iY`<l<6ACv^R zRFTHyvE8ZV8m}AKJ+m}6f^fGnFPVn+E*2p+HIKxHxji)5tccm`09ry0o_I6#TAQkU9=gH)LRFLAK0+*ZYZ2YNn4`ugYvdl#}iTd6mqP_RAtj(5f_nW+gAfU_VG^I@0~%p z#bGVHo_j2B>}&^IT{Rf1O^aW~#9(u2780v#xWyP)a=#qk&zJJqeY zMTtD&TRHiX;84L^d_Pl9uEGN2scl0lBs-#rlhT!89>ymJ9Bn&hq$%pp*ts`TYMPcl zkhTKcL{4%Ch$eWjK=jDb{;`{iC}KlyAyki^Zd&&aS@s;&L@ovNSlmA=7t={|;0XMs zWciqhb*ri6f?Z(ibhV{ae_)a)u^0ILQ&u}R<5I^@XTMHR8xxz08;R|4}%UiiN zJ9W>@_66~;6?D$Ka8U@@WKU9A&6SB#>dU|7O0)CIc@4q)=_adBYI+Lbo7go?s_4Z^ zF;Q|C*YZ?qs{_oLybjpeb9gey!EMc>#xB^U#!BPsW@!Wcl;>#T!sXm8>N=4;6JWo3 z()UlzJC}Rw!rwD)efl^<#;nGc`qDRywrfw+f&w(cJJEx(Ge%8=j~H14WEI%@hC5~a zTxe5c_5Jx*4Hb|m^nu)peZYmafY?ias(A2=l#razALWoBsq*E9PPRB=kMn$~s1I%w z1A~q*;=UtmQM%F*Q|tgZ9_3lC<;Bx}&XHDq9uj>bYiH9>IMZMtsQ=WV;6N;C4(?E7 z$;DeJ-w5_^SrClWV_r1QRxX`{r(?I2r?`ZXT1t}(pFBKyk}JKo?wxvp0gQMYG+}Vc zCUxf=(^REKj|h$aL#G{ zc4p#;z>ATHNc&7X0%^Y+40|>Nl+3V5#265yvnJ)f|ND5`8I|f&-M7k{yOcMUq_o&e z!lk$Lk|l#1y3x-g`>nwZ`!_$g{~6IdkH{@~5A|vCiZleIf_l?e6qPgr9}%lcj==!; zSq9Y&L7e!ZsiCw-EJgdNU5jSF&s0@k&M-u+rZ5?FjMuj*=ZA_VZrcZr?mp58{A;Zp z5`2D*aLlPO19f;tZ;UF?e%$q+*_598cWJ6ilRg4{!Ln%{fmy1SK9)hvkQ|qC8x82b zF!~|1zV_#U0-5rk0e}JY?YqclmPg!g&w=q4Hd8~dGEWkADYHh-jhRdp=DdM@QDP}V zl;b@JP$CC_(AktxK2|fIQM&WKi9Eo1@107ENqNze1#*)76ZLrSR+~A{(+1c341k>$ z|D^e8^YSA9G8+$uUHsR6l0H~uU#}^TwQooNqsnUTVI42(+0Ws42VP3Gr-A2QON~u+ zQyBQ_$KB112^W-UxfbIT$K6W#t8OqEfX(Ew<~=&>DOH|oWr%T5krFh*-4zlt#nkOG zfd0LO>pFL9B`)QnS}$EZ>2=cwYvG~JaCw5`SS_#dW+5PPYQ9Q4qQ7b*c7)c($Y{!K z12ju2E0#^RA+Ztv-Ln&n2HM1b&IKp9J}z|ha; z3{-BHh9j`seSfhahzd7odMda?rSlpl%nBOK4qe4I$P(?+AsuoS+G;bzenLpsrXP%m zXL;HPq(t@%$+k!qrFTi5{f3ymd*iWv^^1#Y(d7H;*S3#AZpKuqw_n`&ljSNzmNykX zc|Nn++`(dNw+=)j;u$Sqb%~QcOb-!JQ?@KJbhELd{aWcyE-*}DMG5i41=P(F!9+zV zX+9M{WBI*Vjj`CgcHqCmbZ@pHm~s~%AgELJ+wHu8*OSFY8=fkx{9>01oGUMr$NGRJ zlWxyLMk~|2DV(N+W`HLSX?S-c(4Q>yQR~0<7nrIq201$#DoXC-v7l(E7<9THkMXA4 zZ&Z}g=v>>c9lMHOovp>pP$g-_V=wymt zE*KMXC|L>AoBLr+;)8=L?rixM3-2&hNLK#bb?&z7rO3+^aoCc{UNj%JKB(X2sh4!C z7eWf5OcCMV_u^};Q-5~9@6Ff^@hY{qE+vY;%ft`ef$Ly-zmqCHJ?IN>X#xtAmj%kB zRy=uW#`D(E#b6zSZQjcD*}V?%4=-?#Ko%9TZj)8SKw~yX3Y-L2rh*yxipKZ@#GRF& z{eC3}=hG)(WiylWZSET|Sx2R4*+%$^kMm@2chz$5PvvpabS z(>rO-)QYuhca`qc`@JbDYJ!-tL(jX+kp$rzfgn)rUj;jdPv5MPG5x|*<*ufzCg%6D z34V)rA3=Sq**n6jU)0*5A}gi}{Wg(05>VN|5$4T0JAA=d^b)5O#OMpCL&pz94+rO? zL$vtwAT%2{N(V-2aX=LUH3cTP#mAhVu2o9*#g+rYWmvh=Z|rOEf2OL=H+d>PteF;* z5C)Pv@OkRew~R_*ANOr(y@#%5X+_nN`hC{r!F3u^Q0=O8b!SSWw-Y-al5{7Qyj0Tj zy4<{ENvdZa=q1(Ic3-$>v3Y{UZZDcuJA_g5aK1u(@t<30*C(w#U7k2>w5o*pOQ)bQ zz<#NVca=M-NE6(Z^-E%|2zu{c;l>!mUX8070lS6}PW_#otxtiiCDRQg!==y`u$3&F z^vDOF{3)6XHck^>MBtI8vxka_Bi&C<(`k|J#^V<>lA!J92{r7Zv$NWxz(5j#0qR-X)G- z?&e55D$KO$ztGE$v~-Y+`BvlX8l-}HW&mHu%#n|uLL}6s1+4=Gh!8wVmh?*>|5)bx zjIsEx@>t(pwu*_gf98?7izPWZpC>(8k)a+0>YPMMK4yp?n!Geu3Q^VmfZPrNn+(st zMQ6_}1=Y$4#`N&5n^x-2jd+Y#n+qye%jvz(4y!dr(8Y%O>H5S+UoQD2@>%WC+KAj( zhA>O2$56K^I?Nwc3YgaS3`_QgMNBaWoJkD4+-ywe|GUuT|NdmyrqBXl3Hd_IC zs1$2@-yS`p;ITaHN_!+qh?2b`|5aUnp!LTT`K<;<>#(Yri(!BYmi=O--G8>p%Hf?Uk`t@`L<6RN@m0yYd3;T^%Pbi2uK@g;d+zcA8}I?jNW;$zL|1-Atlyg!wn{l z|F*J_NJqs!B$Ep@h6My7IkRE0y2QcZiro2010!C=(3?Ej-a=grL+W4~QldQ8)NNb(lbRXJ}x5gaX(Z(JS zqLX6=_bBcMc1Ew19rEGeU2T6(l*(cY?K=diB%~Lg%P*5?@ziDB4h6;^;1ubfBrCTe zwaie%wM$B|%3(SxZ){c1lp8q&3L{3}ub#v{>cInKo@5un~H zF!m}rfcz7em}!RCwAUNcOCL_Dl`>^t-a0=>JpQFRjmWR;;4n>pyKuf?<|bZqmhXuL zKjl-q{^ZUDMFtI$B-ordpe!6SkwentCxM}Y;J84Wlc!|y%33*95001J6EH7X%Ujt$ zEpi1*LSuZzhrs`&50G&*qR&TFjCZ9yX7_`cN$YH<EfmW3 zEZGa}*~DU`Lure*(kLf(gVH;trvA&?W*W}b_l|3!WwIXR!erG5h>z(b+16LoD&?g= z>@8tbc{$23w*`=&CiC}iP_nH4nFjag@b7~j9m9Vz)AD3x_l!I$a9*5D|gE;9=SlMT8zkL|pe(RF()-AmKDug%1ZA$b; z1glY_BJd&<=LA(=sqjDMmtl-WLOlX7@=*R%Fy&(O-Sk-<{*mIasntWPr7p?;;hSR{ zdgq)2<1WOe*q70tzKXfW5Te#%&d5n8|H+cdFvrM;^3FWb@cKyiOl*b&`RxwZygdk2 zVUgTQ84<}zW$D|~-JfI43HdrwJUnKdSMnL=M7f)o`Gl4(sZXa}n-o5yfMmq*wr);^ z?5r^h&3pDZsKY69<1$5R%x?kg{@qQ^Og8oZ@}VE`Go1LC46~rmByp6Zii}~`G#14*ta`EFmu_eqX{<(l~ij$PQgh@-n+;Jn- z_m6=RT^mVxX3CAi#JEDL@XT_I`+Sf<_%h>NIYW4LfIYqRMJok z%}S;cf=BDDLD;n``I%2SHdbZs(~f<2CWqyIrXTg*gOb2lDd@A?$GyR|xwW>Ubk9Cn zYyDK zZrq-9y$LCkF6TdL2TX@Dq6_-p22@WjeBHRYpJ}hFu@_@RqoInfY4xnffTzC@-Af=b z9nr!+{{p@KM0NJsAd)tkYDvw88Y-2;j$j{O$6j13`yZR-0U;0-w<0FaM5oJQPkIvV zbKfW!pvn`8fg|D($LhdwEGM6_;%3upXq;;emqX5Kip&}up9BXRfx6OyhS?I zzDn-Unf3BR+Q#WPQs%B>)6jZrk>K*?=0-OJX?{GVHz}g`7n&HIbP=?;YonqEG%bIG zd&VD+Sapgi`vNm@zzY{yE$O2A=;=bC$T8BP@wimlGTezJ+nig7T|l<29da!9*@fZ0 zU}AUFe(~EG()dXylIf0Fy7K__40m2sR|WL4E9N6@EXwKI9>K1TPGYsPY>`J)UgbP{mY5Jn{j?V%9xG=8y0M}hgA7%dU^kzCrrys} z^;^-m*}11B4aILRh%ZGYy_?>v-cC;7=GJVg1O0)eTbW%Viri0`EE*R_?up;JGI5{^ zreri9EdqN~G;*#Huiojg4Sq-L_|?YP4H-fWcABQV&1pTXt_#_rDdpFV3aN^#1Mnk!_BUW*N z&k@C*HNy3k8`cytYUO_^er}jhDt(KmBFoX;bpGil_ZM^ssmGcsPWcV1O!2$Meml<( z!=vksFPJ%ydU`c`p^Tfhbin#Q7u7x#%fe1%H=XmrkFYT(w}6o8%@&QR+LrLKodm33 z-jmcMb+?=jm)t$@NUfYPKv-ynT z=QM-Ue912i0gqjdTV3qhkKtJWR!}ui#sjW;z)QXYc#n7?w`g28y)vB4tJjE(=>}Cj zapn3C7Jbs~^=B~nc=|D8o}wpooSP9ME=!RPDFVV#%r+JqT463#?U844en0LglXvaf zTEH`Ms!G&t>FBrM(yO7V7bE#Uvh*}28l-JVbybr;>Vq^g?bVpl-*vXqs3kJ(+3+Y zN89s2?rc3!#RaigtnX_a<5&5Y56AW=oOCWG!=|LTsRMNrj)^!B)CGt_wfflotNf$w zYauGUzGeho z-JRO)m&!}$%;#RbwUZiPvN6>pk37USeLYYzk#EoBu1Q=u&Pd8G}rRX9uX+Is}@ zeO2!}mJhg{NY_CL>26~qP_H3L=s22ra|Jqzu@`3(am)$0ebD#knz%!#7x|BY?H8Zh zJSK}J{5z}}uJe_^4rX6}fpuIojMlBtJkGx(40UcBMxowwlB;Jw~R^CETm&x}v+o&*)$=pVLD}2^= zCxK(|x|oD2>+Wg0AJd*t&SJZ8cDHMYH6d-EUn-UXP=L+QlW2*Vi%23^ff%))Vr~Z{ zuglqPTbqE{6YM zhUik1KemrsKOoPx;8gpEgLpEe!k(|1`NUd?~rDkl>bje5muTVO$ z&ZT_rhm-tWDu#yx#K3C98Ujk*Z5Nu~2^S*8(}p0**d258brC*jx%)aEVZr7@;x&JA za15n&AXYJMI8}3_AMuDdD`(34G#iM;~a~RYr#-a1OvP-wO z;oh28mc|!X_^6)OxXfH_^5W+*o%P+;>`^oo8#ityyk_uup@Cvnki}D}Ye(q_9vAX} zuAot8xKc~OGiWtUT2^>%DDrYm5WXT^W2>M;&)#G6-I4TyZ#8D>K6iC9+z*D-+8c|& z&mi!-uLFa1H6k;EJINy`*+^SofqflL@EQ2e#n)QD9wzy<>XQlR>gf>+U(lS031|PN z85S;?c;F@ZE%JC#kAx&2P%bj>k#B!Ey%GNOQ0COT-S~5yAlWJ@)8&dr*Z1^C`SUNN zK?4$Gxyo+s35<8ZnYQ%6 zf^gPG&-un)T1cRHOeg;teSV+BkfYv@#HqT>rTHxk#0(r*`7GHNLz%ot zXD}}JbG7MXRsN5gQwM0aR#&lPCcSY#-hhVs-@Eu!{}rT8V}2AyMwe;)K2lRM()Ok~ zNOR}0?b0O$xRAFiG5jDI79VA_yLYfP!zx~j$d%|vod1S7wlUiC@Q2KVn_+N#)Dyo` z_aP`zvx)nTVk{sz`TG((UgsUW(xlb@umHH_ZSR0`_R60QQW#I|&)-H%PmBtq5}KS9 zn4|FdFq7|Lzm|sRzbXm%@FB^o8m-LQn5}d_@uu7@8Qr9E5YL4X7C#=tEIFbKw>o2A zGr`uvNA-q7hhPmPB0i=MF_>QYaQMZR&s)>&o-h>fS`H#Gp3TRxc9^g_cx*ZX^cPS(pJzLWXcar!J?+B)K1<9 zMJT_RFV`rYWd#35mhj$+;L9yk00tpF$KF#TEp)IO3EY#ph80O$xOZUE)9d%V4J&S3 zYEx?a@OB?Iq`0k;Tb$|zA5-T0H#k+ZTtE5R_=OuUJbWE!W;&p_x(&z0M{6D@g@Gr3 z<^99qT0Zx^hj+}p^q}i!(kY&dI9anRE3T^DfM2U%?rw3Y$I-%_G9M0T@KD{zYs!Hp zivyuT%}v~(gK<#G3ava%MP>jd&vrF!yrnUjOHQ4%sb<*+rJ)M1)^!b}6;~s1yvot3 z!+EfBaxUW>0b0P#N<`{JP3?fRK^ou)T!dp2)uY-^?l*m+8t6 zpI_$WJ^b%MK}%&_o1wjs*7ua6qx zaL9*r@;xppUNRemppiUr^b7r01|k3!7NAeuYPE2pI1c~t?hF7nmaKhlKZ=^UGZD}TPH!T8fwj6u1efxNqla+IuAC|nXade#qq{v%WGFe zh?p#RObBtpr-c_Ai5PKyyp>!P;!rM-8(UD6YUg&k_N=gpuU*ZG4+;-9-VgctJ)LAC zcg4#Wv-H)8Csz;s`?GoO?K?63`Cem4ZhAIao&9J`L2X#@DMr_0JOOR5X+xg=cGoW9 zMQoD!Kx!9!QfMXZCO)6-Rju!SBL~*#*=y1CY#dH*rus^Uj0ky>=*rxn>fWPK@rj<) z4ty8tdZRs1lEd;;fr%e;)svZ5eN8B$ z)~l}SVLTcv(z|icf&VLdkpG0}&x#5)bD9uQbyGoBYzJz(NCU(y_*aZ39Fk8`=v`Rv z>tOBNrPgwiSZB(5$eFHX>I}%i7&quIArMqeUjvGob>z zDa}yDqrLR~+;p4HbHn1&{$JGSZ{K#NFdK^MP&0j1Sy~y*RJXaf$6}T>X!h!Ta;=t_ z!QPFXF>I(sRS7i_Q({i((D4O^yE9>@8n-Zqnyw$S zJ$xP?%7j4m^CQ!QG9M@9`Sd2~hZ4%g9QF9wJiTm??)ia&eKD%SmEta6<>NG;E78|) z|E=aOSY+ebq!+rkaggx7Bvdkos@~Z>J{Aip0e!ko2B-gUhmhjFSy~pCo`l7DBwoVr z=W^@nx>&f0Im_prqI1Qiy)ivou*a^)N<0@;v=0Z=O||^vPcq048pI2IHF1}9eOms_ z@s8trl{PFe@$Wq0^m#o2eF)LOX5wP}+6IE<)v2jx?6Lotv&NLSc1g4Z>`FeJ)JYdV z!2A=uAIjTF<+ajdZwtW%aPVc9>3vl9Aht7I!+??lCV zvG6b8+rsCsAJb(JQ8uh++6)?2245N;sVxO+PZuhxsOmZ$?iP8vsJ%_v-|H(u9&@*n z#Ru|M(O)OOFHj_Pth}bk5a)xXk5`l=Yq8QX1-=E;g>~Z@cw?L#`Q@!d`pDGy(cZBR z_!eF*x~{%^NS%hU(f(KN)BoESi=Keo-DzrRax9-pqR%;SZGhw0_RiVNkmQ@8MEIsO zh4++WpUx%vzFN=kZ376KA^a9(((n6Xr%%V4*r%`Pr&$0vh>!3VWa`rLEQlsCYtT|~ z7TI)x_}tOsDCDY+%5XzSwpRuwH1~3amWGjp;4LP4CQuJ-RlR-d$w306Ed+1d%%u%2 zwndYMj@I`eV_f9p18+183An`KBGdjVR{Pq5ko6^&Qm^032{)|(**>jh@9{G#@Z44@HNWLbvheW1k)e=fY6HphiTZ^qnE?~Kw(7@GF`D` zeLPDdn(wE6YHQ8jC3#p)>F0;7sc>G*^F*Cz-P=L){DZg>Ul3_=T`|&9<1pA|vku49 zP0X^_!ct^g4ocOd+|$C3*rid{;07a6py@i#HQ__q8Y;~Epu53C^zy=vGV;tH;m1^o zzY;u=S3=>1R<_f#V3L{N`e~i590~k9x|MzaTz^$z^)Lkt8VF$w42TWKZyeC!ks`Mx zc#N<>+PKN0-BBl>S}T?=H_W?}e{kHT;!M!7JFc`m^Wu3qJylv9p9cg&&$@a0_=UCS zmR)5BKy8g|1Q>3y-+Xix8Fs*&DhtF*r$|yI_G#WoV9AQj0 zRPb5Jf4m$Tfp+#86XDP&i{TOOY<-mE1!TNKDAbs|iN1sv-Iu2G@mhhWFE&EISHG=P z^$Mu@@LC=5m>=<=%5rdkcEb2qB5 zd2tpW@sjG8#U^-T_&X2iI6i=-g%|O1YyB4gtdT=P75YPME)3t?(yM*C)r#@a63%_# zoxB!+kfV$If6nAK7VEV75v@3FG4;^B)cQg*42r9y)?_%Zg0@U_Q&QMIYD^mEPLAzX znz=!|F~^fqAtTp+AFD1wa6Se1maE=f2|^P;JQ(^tYym=#z84*GyY#!23Ol@UYRYTv z)cJVVl`&Bzben}Y>m-9pGSv{bn{PLD2Ti}NYjyHGa;+sMf8GLrxa;F(Zw{)m8bl>y zlLG0fe|@;KK?bEpzgQ=e3iPqBp(As6M(ZRnaD8ruW0RQJQ=p}qU(sLGMYYTN513~A zzmq@-jAN)+x?MFOq=J5z&##MdV(bs#wN64i{sWtZ(6Fz71lWz(0HT8G;d$0v#dC5_ zlj`E7uH|%HMWh}Q+T&p21?73cV=jj0<+g2Jr3KRz-6xJwMj;$;yf#)Oh$=W=2oO;l zq-Itl_$1%0*X4x|x6K^W4Eh61?39@UJTW)UdRzBCChSY|;PdYd zh-sMb{urFK$+UaK&zF9B@S{+b`s$8)zFq7~?XnV`uNo(bmfZJa%*-n4y3U%>n%B`Y z=x==!ek*Lj=n1VPVi2!aR()@NuIpqMBPM$q$DDEVf<|A{4hnvyTWEShKPi9M1Xv2Z zJlQ_1|E{301)y{8f4>8$TG*MqI5F|CWj@AMqo6X4r#pY7J!a3ffj%0 z%>_fLL3&J@E$v?yxb1PX)>x3ms}WHN=~yA>RH|={2&n%L@cYU&`9I|MK{2deceh3! zU;z%~3KQxKt)0yNwq~TdsRH*h#$4?#j^<6ksCi!pzZ)+Gq}n;`dgc8Pq|ZFaqnYe& zwfcFYEjAD$c-NxN@2k}K-HoL%>!V*-+{f=M75UkDw>P%X=+u6)mHR5Qin`8*l96CT z>#01%isey2U+obZU^vFV^i99xzo2X;f5L-&&+}mm+8TedDfE5fK+RuM-wWDBDT^O9 zS4SeGzZ{~%w^gn9#Dt`N$ce4x<}@6s40|r9pgtPlG#7o|=VlgPE<;w_a@A8)9$Q>j zDs(yTqf1bO-haPgk@kA-trGPf=1V=Xi|nK)tNeiD8Jil0xebZNL|xssc>bLo|NFOW zc9;2XvO<$uFVD#5TYkOV>wD``Z_;EWQwmt!&X;|+!J&UIoS*Wz`CjV#4ZM%($_BdI z-{@1sFYkZLWL)BQB|5k}4*>_NEp<^Nw^e0^f3&D6$-fz2A6ht`oshqxgkN=1 zF*j4_ka)`zY6cZb&z)(f@@ShY8o6sB^B^v1mB0HCkuPj!l9h4Y&VnMwi`&o2uZKah zIw(gR%kU3?GEArveAdAKW&GjepN<0#GI9IIHhQZte6bnUssH13$(DE(dY#ybvkJvRvQ6fK+OLDM)%8E&-6_0QeN*k6w5cdNn8}E=;Ein#y)jL1X|DfYX!A%7*EL}`%zu={q#a*{*+oP`tcrQ#~%Q#k?a0idelVg z@V|iBk1RM4RiKUQdP0_!7w6cvUHX*~DMD={c=gJ6f=s~69;uQLAF%x)3^VA^#e2*` z^~bs`t}Ol$#2NeN8b)rZwi&Zc9;&lk7p3#+Lg_NMxr{A*7h350+HnF^{^~VfZ$XSJ zZu3xt1^>~uxT4)#m)(XuOON!iG3()NZe{-AB+cjqE}XFol7kvhsJn;yg)n2sY{c_) zgTA2V7$d1;zam9{0!;d2UtR`}mULyhy^3UFVXor31iQBkARdS)O8DqpjXMO(Tm`)~qV;rt!1Rz2Jt0 z?*1?C7$ft4bH@_ot?wVe@+P{77cv)vL8#u&ryx27)jmn#`sEs^m^Q}p3`;q6B#+7Z zMqrh#OQLK^TVC#wz=oS;GOhr`)Yjd0(rbx)^4?(r9NNosdr#Uv@=Re!0k} zY)0zDKC><_48rm@=)m;q0(JQ>$VDHQ`}%vU@0YnTg4z3h-Kdlsj3jmIDDOU6c#+CS zsIjC4;Pw1Q=P`DC5wP;B4zOkYXD@v05tbjnYwOO8FE%PaI{DTBbsO!24an(%R?k3n zrOVJ5Lj6^;GmeHxKP+!>h>^~8EL>8@-|Z%>6)Ji9SO#anID?ZghBSJ`VDI7PKt19@N|6?MKkZJq z;(}lgkrH-%lB+^an{=0G=d{wqQtl$)Jf+Mlsfc!yRlj5?GNrNcH+k1t29IJ*q|DL! zP`_y+Ia_G1b7w&0z`RBEg2ox+2ltC)-C~wf1pbEVb;9~4-6SWWr5I^cP~}uBjfI|= z1~ZuJJoW1z5t6|sOWLm*vkp4eYM;5rrIlX>j0+}FeP6(6n7rweRPhO^^^BvQ!`oOk z;iOa?yKxzd1YF=l8y~E$NjF?vUJ}jV+53z)75TC`PEw%RKj6elA3`K=^GvV{vvrio z!hZbNVlZ#lV)r&J<}}t;e1<1LK;}OT!xgMIko6)$B*pDsPIGrE5CaOyuSMWRRsBkY zrmPvAd-Ict8**NQIU-$hRP@FkjzJ2x(}?8Sm-7Cnbl(_X^&85$8uvl6@oYAnOE-2? z)YNCqJx&XCGB7uuN4^frdy?b|vk#5#HP7dd=<0lYXuPe+IJ%2)i!dUvN1ep*@~>8L zyB8f*Y<4Usgt}k8J1o$PM56Dtjd)lLzM&1RQ4Q0-^1&O_AEz+9xN0&1N zQYRkP;XiT)uMZ@8_$OB{Lo#E{xmnbHkW%c42WaMOCYjZ(*@ZvT88BkF;3knf70H{@ zu0AY?n18{jS(}5mHG7`NSUAw}rpjEca3#{*u>+9B<#Ozis&72peWQHcwHEzbw>(?W zl|!u}t=_D;hx$;KqAcUB@S)r}yH%WGAx_{RLlY4z=YK<~)K@_PDfp0aJy zFiVj`!-WK!l*gkv8cuGM%m}g}TzYPgNCx$KjgLWyiv}}xX3UXyAq&D(AB~{}uJ=rs zvE_+FYqQsaC)@<064|fGUC(lBFaZ34s`ACPhCC#N7JvsG#N zn-)eZNO(+G%f7``E9Gpa7&Wscu@)$1bc}S4iL567Z^*j#m<)1eu0?W2oHudaj#nU* z5((h-x7+#;@2oapyuBe#`;1oh;QV&t-PjmYi^<#kW4CTUp|SeNP3A2)wP`*0B!dB8 zORTv?wB4Kjjk&^Ce&5a7m_7Ft-a)}hlAytd;KSdv-iq zbyr~LQ1oi`A1*&B(qN1z#LI`Z-`g}5T_p5g0ytKDM1S*wWoC4_UdP(Oh1}^%ij<#z zk@jYYlYO-K)x4mkSb*B$Nz6sCH?Y4zR)S>g5Y}|8a@hC|4);;fPy_L7Q zrtVWb`U}*md7FS5rvTnWVpHA?P;`-D+r!c1ETOl3+PbRwX#~P&$9O`i_CaZ=RL{F% z)qHVTsDyS>()<@1*@`(H%QSIg#aKjlT~l{nJ2gFtA@;qb-fL~CYH_{9K-CRY)QcxR zHvrdu=WwVi_{Qgd>IF3B*ykUj-`B*TpTKoIa2xkXD7Ov?Mi+R-Pi}Wicn=Lzn%55q z;a2zwE=XkoaIx&&!4)$!aBc1Xo3zK;*yKlpJKwB!ppt*n+y!Tp&kppdNo}$u2zv0V z1K0=){60TLWrD7_X#n)lIXQM9pbh8ZD=OIv;CF`Xhr*yiJW>*7)sG$L8Kf_^{Eaul zwvw^PDOl`Ppwh0t$odrQEul5jr;EL@cauF6e}Gkg(vX54Wd2HM>t)6|>ia@qzpXh= zEW~= z^H}NG-#Amm2?Nhkhp(?owPV-*1L+D1TJNN~X~Jkt)|a|7Uk|Li6Qpia|LFL;Sb*W_ zjc6j4Wj#&FIfa-c8Gjnw`xiEikA78eG>e6X2fwrbqb5X2ETKl?P?zieOT(L4bq$W; z-ST>PPgjYF1N86uO3e6v$^Po2FB9@TZ8?uO29O?ZJ2;2+Q!ny1rrAuy`{$$*l{h_Ew^t zoaB!G8=-D*j0Sz>+x$kY@x;O#M}*7gkqJNih#9hOO}T!y0lltr;ze9dt8o2?X0uF? z;#Xn9B(h+~13r2P;SU%<71&!Tt2(#nwK(PCYS12?ubIlB&R{V(&ci&-eMxj_kl%2z z7JPZopz~1^X!^BH!P)e=Xnlh~Dd|r&iTW%=x3(n6KOjT#sA6Bg(ew z%Y|tl&pk|g68Gl#&*!NNyr=6u+drq#zvz?+c$T(Nh4V*M)cpm;DPK}&`5Rg$S(m)X zY!3D~@j=o1pIn=2sA&G&>wnAqlWSY#KD|9?wewMo`UW4BOE&9QZr*g)R#e7Q#iHUS zOZe6J*nles%xV8v&Q<&MCiNa$5AO*VNXd zM_#Y@>w7on`lp%iq!kyu>6ZHKzkJcILW8CM9t7ygrdo8_)B-OJiKw`q^<`#o+ehF^ z_x#XBo2mup*$SIku(pc)s$IUN{lekXa{`yH*NVFm_#(lfIXRimOBdhC zUa(!d?>gh`Pb&JIpZ4BrZmz20Yn>NY)5D(WnOo5HspjX5(&}}W(kldB>Ut{up6czX z+@G=WnDvT%&mCnnXSHTB>pQ)!ULCk|Im>tTiY8OZd4*;(H~Ad>+LV!M!uVL(B+g3e zRH9O+UE*Y=PfHK4m(;b`P%NAkmb&PN=Jf3?C!JzTO)q@-lQTtL)9L1wniTeX2WN?X zoncv@r?WhJ-;K;R(DKQ4hWSt4$gIhP-(lP%N?f0v! zoTm3b2j;h9oXq>)>CK+==+H++h5P`&=lNkZ%BIT$!kKc)!*zO87{i&~>So;7!a2L2 zWx~~T5w89ALVsh--t|nYGEtCkE{>^Ln|*MWN57G&s!I8)yA2oL3D0k{HU1A;D07`@ z$EROHJns(hhBkhGwW0EM;+D7x-Ga&LixjpqOCL^G)68;Z@)WcXp7-R5T6&Q0u_KTX z4|K9mrr3~yf&B^SjsUcEr3HDy7Q$whyXW2ZJ#cF>F>6{GIOpU7SG87d+bZ!@m56n= z3XR2c7|bot7cwV&1&+-SUTOOvM;W+&b@SSzEA)w2VheQ6V~}(Dq#0KGV_7qc9u^Kv z>C%jOMe}lX-D-(*j*L3cImLGvB5DaQDh93KybWB>`8g-s@D;fEi)lZa$a9Ov&*wh= z+WZSm92Xb32>7^cxrTSevzh5ro(I_;RJROPJzj%LIhwc{<5jn1TKg8?*m3e^VAC1m zLQI9>dE2tj7IQm*i<$jq>2wnji48305}B?YTlV#Kqz2Hc$dpJu;v%ydxSzN=SmCMK zbIXi~HAci~ItxkxX4~aT)rm`x6F>>_pj-M>;!;2kXhHSnonKd26X%>}kaPIVtX6|t z8E7$p$xSx~CCIaD-R~0T92u2@dzKODVKa$}2M+~TCSVQcVVM4F(?`#9UpA(AVmbk< z$nr*qlF6I7cgfAQ=&o!yCCMCBLIviE18W$&}|nX}MJCtTbK zER84B(#1QrUoCrii8a1n)=SBH@+9I)uL%ynI6D4%ZOoVacWc>ib@Q{ne#XAj^?pd- zue1>RV^k}(L4{a%do(rNSTFK>TGHa+H_5yHmYSA3GM2n$N~v8gZTEZqV~bx${<1HUu(+zKRx}& z>FI2KTkCrT?#F0vPMSenI#@87qhq<*`O`1D-p4#}?tdTC@cFzwf9&qA<(7}-pWEoK zaTYIm%QdGwE<7dfg6#A36o;IOZS}flR{Pn$TUoDM8lgj6>VM2~L@W)s&~4(yt*du# zyt#Jv`8(T1q~}cJFFqz{WNvx%S-OUbnU(Pa>;2roC2@|s-`CXW$~`qHw>W%z&Yd?s zkB@T@7ygYR97pDzf0Ohswe0OBR!Pa&i4!L_u6xAkyJG*z%zf*wO_Hp$&E \ No newline at end of file diff --git a/src/legacy/core_plugins/kibana/server/tutorials/ibmmq_logs/index.js b/src/legacy/core_plugins/kibana/server/tutorials/ibmmq_logs/index.js new file mode 100644 index 0000000000000..4ffda2d7a523c --- /dev/null +++ b/src/legacy/core_plugins/kibana/server/tutorials/ibmmq_logs/index.js @@ -0,0 +1,71 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +import { i18n } from '@kbn/i18n'; +import { TUTORIAL_CATEGORY } from '../../../common/tutorials/tutorial_category'; +import { + onPremInstructions, + cloudInstructions, + onPremCloudInstructions, +} from '../../../common/tutorials/filebeat_instructions'; + +export function ibmmqLogsSpecProvider(server, context) { + const moduleName = 'ibmmq'; + const platforms = ['OSX', 'DEB', 'RPM', 'WINDOWS']; + return { + id: 'ibmmqLogs', + name: i18n.translate('kbn.server.tutorials.ibmmqLogs.nameTitle', { + defaultMessage: 'IBM MQ logs', + }), + category: TUTORIAL_CATEGORY.LOGGING, + shortDescription: i18n.translate('kbn.server.tutorials.ibmmqLogs.shortDescription', { + defaultMessage: 'Collect IBM MQ logs with Filebeat.', + }), + longDescription: i18n.translate('kbn.server.tutorials.ibmmqLogs.longDescription', { + defaultMessage: 'Collect IBM MQ logs with Filebeat. \ +[Learn more]({learnMoreLink}).', + values: { + learnMoreLink: '{config.docs.beats.filebeat}/filebeat-module-ibmmq.html', + }, + }), + euiIconType: '/plugins/kibana/home/tutorial_resources/logos/ibmmq.svg', + artifacts: { + dashboards: [ + { + id: 'ba1d8830-7c7b-11e9-9645-e37efaf5baff', + linkLabel: i18n.translate( + 'kbn.server.tutorials.ibmmqLogs.artifacts.dashboards.linkLabel', + { + defaultMessage: 'IBM MQ Events', + } + ), + isOverview: true, + }, + ], + exportedFields: { + documentationUrl: '{config.docs.beats.filebeat}/exported-fields-ibmmq.html', + }, + }, + completionTimeMinutes: 10, + previewImagePath: '/plugins/kibana/home/tutorial_resources/ibmmq_logs/screenshot.png', + onPrem: onPremInstructions(moduleName, platforms, context), + elasticCloud: cloudInstructions(moduleName, platforms), + onPremElasticCloud: onPremCloudInstructions(moduleName, platforms), + }; +} diff --git a/src/legacy/core_plugins/kibana/server/tutorials/register.js b/src/legacy/core_plugins/kibana/server/tutorials/register.js index 53ec16c1ca593..69a6ac76e4a8f 100644 --- a/src/legacy/core_plugins/kibana/server/tutorials/register.js +++ b/src/legacy/core_plugins/kibana/server/tutorials/register.js @@ -83,6 +83,7 @@ import { awsLogsSpecProvider } from './aws_logs'; import { activemqLogsSpecProvider } from './activemq_logs'; import { activemqMetricsSpecProvider } from './activemq_metrics'; import { azureMetricsSpecProvider } from './azure_metrics'; +import { ibmmqLogsSpecProvider } from './ibmmq_logs'; import { stanMetricsSpecProvider } from './stan_metrics'; import { envoyproxyMetricsSpecProvider } from './envoyproxy_metrics'; @@ -156,6 +157,7 @@ export function registerTutorials(server) { server.newPlatform.setup.plugins.home.tutorials.registerTutorial(activemqLogsSpecProvider); server.newPlatform.setup.plugins.home.tutorials.registerTutorial(activemqMetricsSpecProvider); server.newPlatform.setup.plugins.home.tutorials.registerTutorial(azureMetricsSpecProvider); + server.newPlatform.setup.plugins.home.tutorials.registerTutorial(ibmmqLogsSpecProvider); server.newPlatform.setup.plugins.home.tutorials.registerTutorial(stanMetricsSpecProvider); server.newPlatform.setup.plugins.home.tutorials.registerTutorial(envoyproxyMetricsSpecProvider); } From 37e3f63d0d6227c253cdc5cefef12e0bc8e71af4 Mon Sep 17 00:00:00 2001 From: Jean-Louis Leysens Date: Mon, 13 Jan 2020 11:43:05 +0100 Subject: [PATCH 015/139] Handle another double quote special case (#54474) Co-authored-by: Elastic Machine --- .../__tests__/utils_string_expanding.txt | 30 +++++++++++++++++++ .../public/np_ready/lib/utils/utils.ts | 14 +++++++++ 2 files changed, 44 insertions(+) diff --git a/src/legacy/core_plugins/console/public/np_ready/lib/utils/__tests__/utils_string_expanding.txt b/src/legacy/core_plugins/console/public/np_ready/lib/utils/__tests__/utils_string_expanding.txt index 88467ab3672cd..7de874c244e74 100644 --- a/src/legacy/core_plugins/console/public/np_ready/lib/utils/__tests__/utils_string_expanding.txt +++ b/src/legacy/core_plugins/console/public/np_ready/lib/utils/__tests__/utils_string_expanding.txt @@ -52,3 +52,33 @@ Correctly handle new lines in triple quotes SELECT * FROM "TABLE" """ } +========== +Single quotes escaped special case, start and end +------------------------------------- +{ + "query": "\"test\"" +} +------------------------------------- +{ + "query": "\"test\"" +} +========== +Single quotes escaped special case, start +------------------------------------- +{ + "query": "\"test" +} +------------------------------------- +{ + "query": "\"test" +} +========== +Single quotes escaped special case, end +------------------------------------- +{ + "query": "test\"" +} +------------------------------------- +{ + "query": "test\"" +} diff --git a/src/legacy/core_plugins/console/public/np_ready/lib/utils/utils.ts b/src/legacy/core_plugins/console/public/np_ready/lib/utils/utils.ts index a7f59acf1d77b..0b10938abe704 100644 --- a/src/legacy/core_plugins/console/public/np_ready/lib/utils/utils.ts +++ b/src/legacy/core_plugins/console/public/np_ready/lib/utils/utils.ts @@ -84,6 +84,20 @@ export function expandLiteralStrings(data: string) { // Expand to triple quotes if there are _any_ slashes if (string.match(/\\./)) { const firstDoubleQuoteIdx = string.indexOf('"'); + const lastDoubleQuoteIdx = string.lastIndexOf('"'); + + // Handle a special case where we may have a value like "\"test\"". We don't + // want to expand this to """"test"""" - so we terminate before processing the string + // further if we detect this either at the start or end of the double quote section. + + if (string[firstDoubleQuoteIdx + 1] === '\\' && string[firstDoubleQuoteIdx + 2] === '"') { + return string; + } + + if (string[lastDoubleQuoteIdx - 1] === '"' && string[lastDoubleQuoteIdx - 2] === '\\') { + return string; + } + const colonAndAnySpacing = string.slice(0, firstDoubleQuoteIdx); const rawStringifiedValue = string.slice(firstDoubleQuoteIdx, string.length); // Remove one level of JSON stringification From ccd36b3d57e1c8510c82e9eb8c3ebdb356397980 Mon Sep 17 00:00:00 2001 From: Jean-Louis Leysens Date: Mon, 13 Jan 2020 11:43:59 +0100 Subject: [PATCH 016/139] Fix floating tools rendering logic (#54505) Co-authored-by: Elastic Machine --- .../editor/legacy/console_editor/editor.tsx | 2 +- .../subscribe_console_resize_checker.ts | 11 ++++++++-- .../legacy_core_editor/legacy_core_editor.ts | 20 +++++++++---------- .../models/legacy_core_editor/smart_resize.ts | 2 +- 4 files changed, 21 insertions(+), 14 deletions(-) diff --git a/src/legacy/core_plugins/console/public/np_ready/application/containers/editor/legacy/console_editor/editor.tsx b/src/legacy/core_plugins/console/public/np_ready/application/containers/editor/legacy/console_editor/editor.tsx index 40b9cc4640eef..761a252b56a87 100644 --- a/src/legacy/core_plugins/console/public/np_ready/application/containers/editor/legacy/console_editor/editor.tsx +++ b/src/legacy/core_plugins/console/public/np_ready/application/containers/editor/legacy/console_editor/editor.tsx @@ -164,7 +164,7 @@ function EditorUI() { mappings.retrieveAutoCompleteInfo(); - const unsubscribeResizer = subscribeResizeChecker(editorRef.current!, editor.getCoreEditor()); + const unsubscribeResizer = subscribeResizeChecker(editorRef.current!, editor); setupAutosave(); return () => { diff --git a/src/legacy/core_plugins/console/public/np_ready/application/containers/editor/legacy/subscribe_console_resize_checker.ts b/src/legacy/core_plugins/console/public/np_ready/application/containers/editor/legacy/subscribe_console_resize_checker.ts index 4ecd5d415833c..1adc56d47927b 100644 --- a/src/legacy/core_plugins/console/public/np_ready/application/containers/editor/legacy/subscribe_console_resize_checker.ts +++ b/src/legacy/core_plugins/console/public/np_ready/application/containers/editor/legacy/subscribe_console_resize_checker.ts @@ -22,8 +22,15 @@ export function subscribeResizeChecker(el: HTMLElement, ...editors: any[]) { const checker = new ResizeChecker(el); checker.on('resize', () => editors.forEach(e => { - e.resize(); - if (e.updateActionsBar) e.updateActionsBar(); + if (e.getCoreEditor) { + e.getCoreEditor().resize(); + } else { + e.resize(); + } + + if (e.updateActionsBar) { + e.updateActionsBar(); + } }) ); return () => checker.destroy(); diff --git a/src/legacy/core_plugins/console/public/np_ready/application/models/legacy_core_editor/legacy_core_editor.ts b/src/legacy/core_plugins/console/public/np_ready/application/models/legacy_core_editor/legacy_core_editor.ts index 608c73335b3e5..6262c304e307b 100644 --- a/src/legacy/core_plugins/console/public/np_ready/application/models/legacy_core_editor/legacy_core_editor.ts +++ b/src/legacy/core_plugins/console/public/np_ready/application/models/legacy_core_editor/legacy_core_editor.ts @@ -297,30 +297,30 @@ export class LegacyCoreEditor implements CoreEditor { // pageY is relative to page, so subtract the offset // from pageY to get the new top value const offsetFromPage = $(this.editor.container).offset()!.top; - const startRow = range.start.lineNumber - 1; + const startLine = range.start.lineNumber; const startColumn = range.start.column; - const firstLine = this.getLineValue(startRow); + const firstLine = this.getLineValue(startLine); const maxLineLength = this.getWrapLimit() - 5; const isWrapping = firstLine.length > maxLineLength; - const getScreenCoords = (row: number) => - this.editor.renderer.textToScreenCoordinates(row, startColumn).pageY - offsetFromPage; - const topOfReq = getScreenCoords(startRow); + const getScreenCoords = (line: number) => + this.editor.renderer.textToScreenCoordinates(line - 1, startColumn).pageY - offsetFromPage; + const topOfReq = getScreenCoords(startLine); if (topOfReq >= 0) { let offset = 0; if (isWrapping) { // Try get the line height of the text area in pixels. const textArea = $(this.editor.container.querySelector('textArea')!); - const hasRoomOnNextLine = this.getLineValue(startRow + 1).length < maxLineLength; + const hasRoomOnNextLine = this.getLineValue(startLine).length < maxLineLength; if (textArea && hasRoomOnNextLine) { // Line height + the number of wraps we have on a line. - offset += this.getLineValue(startRow).length * textArea.height()!; + offset += this.getLineValue(startLine).length * textArea.height()!; } else { - if (startRow > 0) { - this.setActionsBar(getScreenCoords(startRow - 1)); + if (startLine > 1) { + this.setActionsBar(getScreenCoords(startLine - 1)); return; } - this.setActionsBar(getScreenCoords(startRow + 1)); + this.setActionsBar(getScreenCoords(startLine + 1)); return; } } diff --git a/src/legacy/core_plugins/console/public/np_ready/application/models/legacy_core_editor/smart_resize.ts b/src/legacy/core_plugins/console/public/np_ready/application/models/legacy_core_editor/smart_resize.ts index b88e0e44591d8..7c4d871c4d73e 100644 --- a/src/legacy/core_plugins/console/public/np_ready/application/models/legacy_core_editor/smart_resize.ts +++ b/src/legacy/core_plugins/console/public/np_ready/application/models/legacy_core_editor/smart_resize.ts @@ -24,7 +24,7 @@ export default function(editor: any) { const resize = editor.resize; const throttledResize = throttle(() => { - resize.call(editor); + resize.call(editor, false); // Keep current top line in view when resizing to avoid losing user context const userRow = get(throttledResize, 'topRow', 0); From a899df3f3df92f6ebe0c59521d1ecd4766068210 Mon Sep 17 00:00:00 2001 From: Anton Dosov Date: Mon, 13 Jan 2020 13:57:26 +0300 Subject: [PATCH 017/139] [State Management] State containers improvements (#54436) Some maintenance and minor fixes to state containers based on experience while working with them in #53582 Patch unit tests to use current "terminology" (e.g. "transition" vs "mutation") Fix docs where "store" was used instead of "state container" Allow to create state container without transition. Fix freeze function to deeply freeze objects. Restrict State to BaseState with extends object. in set() function, make sure the flow goes through dispatch to make sure middleware see this update Improve type inference for useTransition() Improve type inference for createStateContainer(). Other issues noticed, but didn't fix in reasonable time: Can't use addMiddleware without explicit type casting #54438 Transitions and Selectors allow any state, not bind to container's state #54439 --- .../state_containers_examples/public/todo.tsx | 17 +- package.json | 2 + renovate.json5 | 8 + src/plugins/kibana_utils/demos/demos.test.ts | 2 +- .../demos/state_containers/counter.ts | 22 ++- .../demos/state_containers/todomvc.ts | 57 +++++-- .../kibana_utils/demos/state_sync/url.ts | 4 +- .../docs/state_containers/README.md | 17 +- .../docs/state_containers/creation.md | 2 +- .../docs/state_containers/no_react.md | 6 +- .../docs/state_containers/react.md | 2 +- .../create_state_container.test.ts | 157 +++++++++--------- .../create_state_container.ts | 44 +++-- ...ate_state_container_react_helpers.test.tsx | 112 ++++++------- .../create_state_container_react_helpers.ts | 2 +- .../public/state_containers/types.ts | 32 ++-- .../public/state_sync/state_sync.test.ts | 25 +-- .../public/state_sync/state_sync.ts | 6 +- .../kibana_utils/public/state_sync/types.ts | 7 +- yarn.lock | 10 ++ 20 files changed, 304 insertions(+), 230 deletions(-) diff --git a/examples/state_containers_examples/public/todo.tsx b/examples/state_containers_examples/public/todo.tsx index 84defb4a91e3f..84f64f99d0179 100644 --- a/examples/state_containers_examples/public/todo.tsx +++ b/examples/state_containers_examples/public/todo.tsx @@ -41,6 +41,7 @@ import { PureTransition, syncStates, getStateFromKbnUrl, + BaseState, } from '../../../src/plugins/kibana_utils/public'; import { useUrlTracker } from '../../../src/plugins/kibana_react/public'; import { @@ -79,7 +80,7 @@ const TodoApp: React.FC = ({ filter }) => { const { setText } = GlobalStateHelpers.useTransitions(); const { text } = GlobalStateHelpers.useState(); const { edit: editTodo, delete: deleteTodo, add: addTodo } = useTransitions(); - const todos = useState(); + const todos = useState().todos; const filteredTodos = todos.filter(todo => { if (!filter) return true; if (filter === 'completed') return todo.completed; @@ -306,7 +307,7 @@ export const TodoAppPage: React.FC<{ ); }; -function withDefaultState( +function withDefaultState( stateContainer: BaseStateContainer, // eslint-disable-next-line no-shadow defaultState: State @@ -314,14 +315,10 @@ function withDefaultState( return { ...stateContainer, set: (state: State | null) => { - if (Array.isArray(defaultState)) { - stateContainer.set(state || defaultState); - } else { - stateContainer.set({ - ...defaultState, - ...state, - }); - } + stateContainer.set({ + ...defaultState, + ...state, + }); }, }; } diff --git a/package.json b/package.json index 0ed74dd65d1ab..6b9640d214a5e 100644 --- a/package.json +++ b/package.json @@ -166,6 +166,7 @@ "custom-event-polyfill": "^0.3.0", "d3": "3.5.17", "d3-cloud": "1.2.5", + "deep-freeze-strict": "^1.1.1", "deepmerge": "^4.2.2", "del": "^5.1.0", "elastic-apm-node": "^3.2.0", @@ -314,6 +315,7 @@ "@types/classnames": "^2.2.9", "@types/d3": "^3.5.43", "@types/dedent": "^0.7.0", + "@types/deep-freeze-strict": "^1.1.0", "@types/delete-empty": "^2.0.0", "@types/elasticsearch": "^5.0.33", "@types/enzyme": "^3.9.0", diff --git a/renovate.json5 b/renovate.json5 index 560403046b0a5..7f67fae894110 100644 --- a/renovate.json5 +++ b/renovate.json5 @@ -210,6 +210,14 @@ '@types/dedent', ], }, + { + groupSlug: 'deep-freeze-strict', + groupName: 'deep-freeze-strict related packages', + packageNames: [ + 'deep-freeze-strict', + '@types/deep-freeze-strict', + ], + }, { groupSlug: 'delete-empty', groupName: 'delete-empty related packages', diff --git a/src/plugins/kibana_utils/demos/demos.test.ts b/src/plugins/kibana_utils/demos/demos.test.ts index 5c50e152ad46c..b905aeff41f1f 100644 --- a/src/plugins/kibana_utils/demos/demos.test.ts +++ b/src/plugins/kibana_utils/demos/demos.test.ts @@ -38,7 +38,7 @@ describe('demos', () => { describe('state sync', () => { test('url sync demo works', async () => { expect(await urlSyncResult).toMatchInlineSnapshot( - `"http://localhost/#?_s=!((completed:!f,id:0,text:'Learning%20state%20containers'),(completed:!f,id:2,text:test))"` + `"http://localhost/#?_s=(todos:!((completed:!f,id:0,text:'Learning%20state%20containers'),(completed:!f,id:2,text:test)))"` ); }); }); diff --git a/src/plugins/kibana_utils/demos/state_containers/counter.ts b/src/plugins/kibana_utils/demos/state_containers/counter.ts index 643763cc4cee9..4ddf532c1506d 100644 --- a/src/plugins/kibana_utils/demos/state_containers/counter.ts +++ b/src/plugins/kibana_utils/demos/state_containers/counter.ts @@ -19,14 +19,24 @@ import { createStateContainer } from '../../public/state_containers'; -const container = createStateContainer(0, { - increment: (cnt: number) => (by: number) => cnt + by, - double: (cnt: number) => () => cnt * 2, -}); +interface State { + count: number; +} + +const container = createStateContainer( + { count: 0 }, + { + increment: (state: State) => (by: number) => ({ count: state.count + by }), + double: (state: State) => () => ({ count: state.count * 2 }), + }, + { + count: (state: State) => () => state.count, + } +); container.transitions.increment(5); container.transitions.double(); -console.log(container.get()); // eslint-disable-line +console.log(container.selectors.count()); // eslint-disable-line -export const result = container.get(); +export const result = container.selectors.count(); diff --git a/src/plugins/kibana_utils/demos/state_containers/todomvc.ts b/src/plugins/kibana_utils/demos/state_containers/todomvc.ts index 6d0c960e2a5b2..e807783a56f31 100644 --- a/src/plugins/kibana_utils/demos/state_containers/todomvc.ts +++ b/src/plugins/kibana_utils/demos/state_containers/todomvc.ts @@ -25,15 +25,19 @@ export interface TodoItem { id: number; } -export type TodoState = TodoItem[]; +export interface TodoState { + todos: TodoItem[]; +} -export const defaultState: TodoState = [ - { - id: 0, - text: 'Learning state containers', - completed: false, - }, -]; +export const defaultState: TodoState = { + todos: [ + { + id: 0, + text: 'Learning state containers', + completed: false, + }, + ], +}; export interface TodoActions { add: PureTransition; @@ -44,17 +48,34 @@ export interface TodoActions { clearCompleted: PureTransition; } +export interface TodosSelectors { + todos: (state: TodoState) => () => TodoItem[]; + todo: (state: TodoState) => (id: number) => TodoItem | null; +} + export const pureTransitions: TodoActions = { - add: state => todo => [...state, todo], - edit: state => todo => state.map(item => (item.id === todo.id ? { ...item, ...todo } : item)), - delete: state => id => state.filter(item => item.id !== id), - complete: state => id => - state.map(item => (item.id === id ? { ...item, completed: true } : item)), - completeAll: state => () => state.map(item => ({ ...item, completed: true })), - clearCompleted: state => () => state.filter(({ completed }) => !completed), + add: state => todo => ({ todos: [...state.todos, todo] }), + edit: state => todo => ({ + todos: state.todos.map(item => (item.id === todo.id ? { ...item, ...todo } : item)), + }), + delete: state => id => ({ todos: state.todos.filter(item => item.id !== id) }), + complete: state => id => ({ + todos: state.todos.map(item => (item.id === id ? { ...item, completed: true } : item)), + }), + completeAll: state => () => ({ todos: state.todos.map(item => ({ ...item, completed: true })) }), + clearCompleted: state => () => ({ todos: state.todos.filter(({ completed }) => !completed) }), +}; + +export const pureSelectors: TodosSelectors = { + todos: state => () => state.todos, + todo: state => id => state.todos.find(todo => todo.id === id) ?? null, }; -const container = createStateContainer(defaultState, pureTransitions); +const container = createStateContainer( + defaultState, + pureTransitions, + pureSelectors +); container.transitions.add({ id: 1, @@ -64,6 +85,6 @@ container.transitions.add({ container.transitions.complete(0); container.transitions.complete(1); -console.log(container.get()); // eslint-disable-line +console.log(container.selectors.todos()); // eslint-disable-line -export const result = container.get(); +export const result = container.selectors.todos(); diff --git a/src/plugins/kibana_utils/demos/state_sync/url.ts b/src/plugins/kibana_utils/demos/state_sync/url.ts index 657b64f55a776..2c426cae6733a 100644 --- a/src/plugins/kibana_utils/demos/state_sync/url.ts +++ b/src/plugins/kibana_utils/demos/state_sync/url.ts @@ -18,7 +18,7 @@ */ import { defaultState, pureTransitions, TodoActions, TodoState } from '../state_containers/todomvc'; -import { BaseStateContainer, createStateContainer } from '../../public/state_containers'; +import { BaseState, BaseStateContainer, createStateContainer } from '../../public/state_containers'; import { createKbnUrlStateStorage, syncState, @@ -55,7 +55,7 @@ export const result = Promise.resolve() return window.location.href; }); -function withDefaultState( +function withDefaultState( // eslint-disable-next-line no-shadow stateContainer: BaseStateContainer, // eslint-disable-next-line no-shadow diff --git a/src/plugins/kibana_utils/docs/state_containers/README.md b/src/plugins/kibana_utils/docs/state_containers/README.md index 3b7a8b8bd4621..583f8f65ce6b6 100644 --- a/src/plugins/kibana_utils/docs/state_containers/README.md +++ b/src/plugins/kibana_utils/docs/state_containers/README.md @@ -18,14 +18,21 @@ your services or apps. ```ts import { createStateContainer } from 'src/plugins/kibana_utils'; -const container = createStateContainer(0, { - increment: (cnt: number) => (by: number) => cnt + by, - double: (cnt: number) => () => cnt * 2, -}); +const container = createStateContainer( + { count: 0 }, + { + increment: (state: {count: number}) => (by: number) => ({ count: state.count + by }), + double: (state: {count: number}) => () => ({ count: state.count * 2 }), + }, + { + count: (state: {count: number}) => () => state.count, + } +); container.transitions.increment(5); container.transitions.double(); -console.log(container.get()); // 10 + +console.log(container.selectors.count()); // 10 ``` diff --git a/src/plugins/kibana_utils/docs/state_containers/creation.md b/src/plugins/kibana_utils/docs/state_containers/creation.md index 66d28bbd8603f..f8ded75ed3f45 100644 --- a/src/plugins/kibana_utils/docs/state_containers/creation.md +++ b/src/plugins/kibana_utils/docs/state_containers/creation.md @@ -32,7 +32,7 @@ Create your a state container. ```ts import { createStateContainer } from 'src/plugins/kibana_utils'; -const container = createStateContainer(defaultState, {}); +const container = createStateContainer(defaultState); console.log(container.get()); ``` diff --git a/src/plugins/kibana_utils/docs/state_containers/no_react.md b/src/plugins/kibana_utils/docs/state_containers/no_react.md index 7a15483d83b44..a72995f4f1eae 100644 --- a/src/plugins/kibana_utils/docs/state_containers/no_react.md +++ b/src/plugins/kibana_utils/docs/state_containers/no_react.md @@ -1,13 +1,13 @@ # Consuming state in non-React setting -To read the current `state` of the store use `.get()` method. +To read the current `state` of the store use `.get()` method or `getState()` alias method. ```ts -store.get(); +stateContainer.get(); ``` To listen for latest state changes use `.state$` observable. ```ts -store.state$.subscribe(state => { ... }); +stateContainer.state$.subscribe(state => { ... }); ``` diff --git a/src/plugins/kibana_utils/docs/state_containers/react.md b/src/plugins/kibana_utils/docs/state_containers/react.md index 363fd9253d44f..1bab1af1d5f68 100644 --- a/src/plugins/kibana_utils/docs/state_containers/react.md +++ b/src/plugins/kibana_utils/docs/state_containers/react.md @@ -9,7 +9,7 @@ ```ts import { createStateContainer, createStateContainerReactHelpers } from 'src/plugins/kibana_utils'; -const container = createStateContainer({}, {}); +const container = createStateContainer({}); export const { Provider, Consumer, diff --git a/src/plugins/kibana_utils/public/state_containers/create_state_container.test.ts b/src/plugins/kibana_utils/public/state_containers/create_state_container.test.ts index 95f4c35f2ce01..d4877acaa5ca0 100644 --- a/src/plugins/kibana_utils/public/state_containers/create_state_container.test.ts +++ b/src/plugins/kibana_utils/public/state_containers/create_state_container.test.ts @@ -19,18 +19,9 @@ import { createStateContainer } from './create_state_container'; -const create = (state: S, transitions: T = {} as T) => { - const pureTransitions = { - set: () => (newState: S) => newState, - ...transitions, - }; - const store = createStateContainer(state, pureTransitions); - return { store, mutators: store.transitions }; -}; - -test('can create store', () => { - const { store } = create({}); - expect(store).toMatchObject({ +test('can create state container', () => { + const stateContainer = createStateContainer({}); + expect(stateContainer).toMatchObject({ getState: expect.any(Function), state$: expect.any(Object), transitions: expect.any(Object), @@ -45,9 +36,9 @@ test('can set default state', () => { const defaultState = { foo: 'bar', }; - const { store } = create(defaultState); - expect(store.get()).toEqual(defaultState); - expect(store.getState()).toEqual(defaultState); + const stateContainer = createStateContainer(defaultState); + expect(stateContainer.get()).toEqual(defaultState); + expect(stateContainer.getState()).toEqual(defaultState); }); test('can set state', () => { @@ -57,12 +48,12 @@ test('can set state', () => { const newState = { foo: 'baz', }; - const { store, mutators } = create(defaultState); + const stateContainer = createStateContainer(defaultState); - mutators.set(newState); + stateContainer.set(newState); - expect(store.get()).toEqual(newState); - expect(store.getState()).toEqual(newState); + expect(stateContainer.get()).toEqual(newState); + expect(stateContainer.getState()).toEqual(newState); }); test('does not shallow merge states', () => { @@ -72,22 +63,22 @@ test('does not shallow merge states', () => { const newState = { foo2: 'baz', }; - const { store, mutators } = create(defaultState); + const stateContainer = createStateContainer(defaultState); - mutators.set(newState as any); + stateContainer.set(newState as any); - expect(store.get()).toEqual(newState); - expect(store.getState()).toEqual(newState); + expect(stateContainer.get()).toEqual(newState); + expect(stateContainer.getState()).toEqual(newState); }); test('can subscribe and unsubscribe to state changes', () => { - const { store, mutators } = create({}); + const stateContainer = createStateContainer({}); const spy = jest.fn(); - const subscription = store.state$.subscribe(spy); - mutators.set({ a: 1 }); - mutators.set({ a: 2 }); + const subscription = stateContainer.state$.subscribe(spy); + stateContainer.set({ a: 1 }); + stateContainer.set({ a: 2 }); subscription.unsubscribe(); - mutators.set({ a: 3 }); + stateContainer.set({ a: 3 }); expect(spy).toHaveBeenCalledTimes(2); expect(spy.mock.calls[0][0]).toEqual({ a: 1 }); @@ -95,16 +86,16 @@ test('can subscribe and unsubscribe to state changes', () => { }); test('multiple subscribers can subscribe', () => { - const { store, mutators } = create({}); + const stateContainer = createStateContainer({}); const spy1 = jest.fn(); const spy2 = jest.fn(); - const subscription1 = store.state$.subscribe(spy1); - const subscription2 = store.state$.subscribe(spy2); - mutators.set({ a: 1 }); + const subscription1 = stateContainer.state$.subscribe(spy1); + const subscription2 = stateContainer.state$.subscribe(spy2); + stateContainer.set({ a: 1 }); subscription1.unsubscribe(); - mutators.set({ a: 2 }); + stateContainer.set({ a: 2 }); subscription2.unsubscribe(); - mutators.set({ a: 3 }); + stateContainer.set({ a: 3 }); expect(spy1).toHaveBeenCalledTimes(1); expect(spy2).toHaveBeenCalledTimes(2); @@ -120,19 +111,19 @@ test('can create state container without transitions', () => { expect(stateContainer.get()).toEqual(state); }); -test('creates impure mutators from pure mutators', () => { - const { mutators } = create( +test('creates transitions', () => { + const stateContainer = createStateContainer( {}, { setFoo: () => (bar: any) => ({ foo: bar }), } ); - expect(typeof mutators.setFoo).toBe('function'); + expect(typeof stateContainer.transitions.setFoo).toBe('function'); }); -test('mutators can update state', () => { - const { store, mutators } = create( +test('transitions can update state', () => { + const stateContainer = createStateContainer( { value: 0, foo: 'bar', @@ -143,30 +134,30 @@ test('mutators can update state', () => { } ); - expect(store.get()).toEqual({ + expect(stateContainer.get()).toEqual({ value: 0, foo: 'bar', }); - mutators.add(11); - mutators.setFoo('baz'); + stateContainer.transitions.add(11); + stateContainer.transitions.setFoo('baz'); - expect(store.get()).toEqual({ + expect(stateContainer.get()).toEqual({ value: 11, foo: 'baz', }); - mutators.add(-20); - mutators.setFoo('bazooka'); + stateContainer.transitions.add(-20); + stateContainer.transitions.setFoo('bazooka'); - expect(store.get()).toEqual({ + expect(stateContainer.get()).toEqual({ value: -9, foo: 'bazooka', }); }); -test('mutators methods are not bound', () => { - const { store, mutators } = create( +test('transitions methods are not bound', () => { + const stateContainer = createStateContainer( { value: -3 }, { add: (state: { value: number }) => (increment: number) => ({ @@ -176,13 +167,13 @@ test('mutators methods are not bound', () => { } ); - expect(store.get()).toEqual({ value: -3 }); - mutators.add(4); - expect(store.get()).toEqual({ value: 1 }); + expect(stateContainer.get()).toEqual({ value: -3 }); + stateContainer.transitions.add(4); + expect(stateContainer.get()).toEqual({ value: 1 }); }); -test('created mutators are saved in store object', () => { - const { store, mutators } = create( +test('created transitions are saved in stateContainer object', () => { + const stateContainer = createStateContainer( { value: -3 }, { add: (state: { value: number }) => (increment: number) => ({ @@ -192,55 +183,57 @@ test('created mutators are saved in store object', () => { } ); - expect(typeof store.transitions.add).toBe('function'); - mutators.add(5); - expect(store.get()).toEqual({ value: 2 }); + expect(typeof stateContainer.transitions.add).toBe('function'); + stateContainer.transitions.add(5); + expect(stateContainer.get()).toEqual({ value: 2 }); }); -test('throws when state is modified inline - 1', () => { - const container = createStateContainer({ a: 'b' }, {}); +test('throws when state is modified inline', () => { + const container = createStateContainer({ a: 'b', array: [{ a: 'b' }] }); - let error: TypeError | null = null; - try { + expect(() => { (container.get().a as any) = 'c'; - } catch (err) { - error = err; - } + }).toThrowErrorMatchingInlineSnapshot( + `"Cannot assign to read only property 'a' of object '#'"` + ); - expect(error).toBeInstanceOf(TypeError); -}); + expect(() => { + (container.getState().a as any) = 'c'; + }).toThrowErrorMatchingInlineSnapshot( + `"Cannot assign to read only property 'a' of object '#'"` + ); -test('throws when state is modified inline - 2', () => { - const container = createStateContainer({ a: 'b' }, {}); + expect(() => { + (container.getState().array as any).push('c'); + }).toThrowErrorMatchingInlineSnapshot(`"Cannot add property 1, object is not extensible"`); - let error: TypeError | null = null; - try { - (container.getState().a as any) = 'c'; - } catch (err) { - error = err; - } + expect(() => { + (container.getState().array[0] as any).c = 'b'; + }).toThrowErrorMatchingInlineSnapshot(`"Cannot add property c, object is not extensible"`); - expect(error).toBeInstanceOf(TypeError); + expect(() => { + container.set(null as any); + expect(container.getState()).toBeNull(); + }).not.toThrow(); }); -test('throws when state is modified inline in subscription', done => { +test('throws when state is modified inline in subscription', () => { const container = createStateContainer({ a: 'b' }, { set: () => (newState: any) => newState }); container.subscribe(value => { - let error: TypeError | null = null; - try { + expect(() => { (value.a as any) = 'd'; - } catch (err) { - error = err; - } - expect(error).toBeInstanceOf(TypeError); - done(); + }).toThrowErrorMatchingInlineSnapshot( + `"Cannot assign to read only property 'a' of object '#'"` + ); }); + container.transitions.set({ a: 'c' }); }); describe('selectors', () => { test('can specify no selectors, or can skip them', () => { + createStateContainer({}); createStateContainer({}, {}); createStateContainer({}, {}, {}); }); diff --git a/src/plugins/kibana_utils/public/state_containers/create_state_container.ts b/src/plugins/kibana_utils/public/state_containers/create_state_container.ts index b949a9daed0ae..d420aec30f068 100644 --- a/src/plugins/kibana_utils/public/state_containers/create_state_container.ts +++ b/src/plugins/kibana_utils/public/state_containers/create_state_container.ts @@ -20,34 +20,52 @@ import { BehaviorSubject } from 'rxjs'; import { skip } from 'rxjs/operators'; import { RecursiveReadonly } from '@kbn/utility-types'; +import deepFreeze from 'deep-freeze-strict'; import { PureTransitionsToTransitions, PureTransition, ReduxLikeStateContainer, PureSelectorsToSelectors, + BaseState, } from './types'; const $$observable = (typeof Symbol === 'function' && (Symbol as any).observable) || '@@observable'; +const $$setActionType = '@@SET'; const freeze: (value: T) => RecursiveReadonly = process.env.NODE_ENV !== 'production' ? (value: T): RecursiveReadonly => { - if (!value) return value as RecursiveReadonly; - if (value instanceof Array) return value as RecursiveReadonly; - if (typeof value === 'object') return Object.freeze({ ...value }) as RecursiveReadonly; - else return value as RecursiveReadonly; + const isFreezable = value !== null && typeof value === 'object'; + if (isFreezable) return deepFreeze(value) as RecursiveReadonly; + return value as RecursiveReadonly; } : (value: T) => value as RecursiveReadonly; -export const createStateContainer = < - State, - PureTransitions extends object = {}, - PureSelectors extends object = {} +export function createStateContainer( + defaultState: State +): ReduxLikeStateContainer; +export function createStateContainer( + defaultState: State, + pureTransitions: PureTransitions +): ReduxLikeStateContainer; +export function createStateContainer< + State extends BaseState, + PureTransitions extends object, + PureSelectors extends object +>( + defaultState: State, + pureTransitions: PureTransitions, + pureSelectors: PureSelectors +): ReduxLikeStateContainer; +export function createStateContainer< + State extends BaseState, + PureTransitions extends object, + PureSelectors extends object >( defaultState: State, pureTransitions: PureTransitions = {} as PureTransitions, pureSelectors: PureSelectors = {} as PureSelectors -): ReduxLikeStateContainer => { +): ReduxLikeStateContainer { const data$ = new BehaviorSubject>(freeze(defaultState)); const state$ = data$.pipe(skip(1)); const get = () => data$.getValue(); @@ -56,9 +74,13 @@ export const createStateContainer = < state$, getState: () => data$.getValue(), set: (state: State) => { - data$.next(freeze(state)); + container.dispatch({ type: $$setActionType, args: [state] }); }, reducer: (state, action) => { + if (action.type === $$setActionType) { + return freeze(action.args[0] as State); + } + const pureTransition = (pureTransitions as Record>)[ action.type ]; @@ -86,4 +108,4 @@ export const createStateContainer = < [$$observable]: state$, }; return container; -}; +} diff --git a/src/plugins/kibana_utils/public/state_containers/create_state_container_react_helpers.test.tsx b/src/plugins/kibana_utils/public/state_containers/create_state_container_react_helpers.test.tsx index c1a35441b637b..0f25f65c30ade 100644 --- a/src/plugins/kibana_utils/public/state_containers/create_state_container_react_helpers.test.tsx +++ b/src/plugins/kibana_utils/public/state_containers/create_state_container_react_helpers.test.tsx @@ -23,15 +23,6 @@ import { act, Simulate } from 'react-dom/test-utils'; import { createStateContainer } from './create_state_container'; import { createStateContainerReactHelpers } from './create_state_container_react_helpers'; -const create = (state: S, transitions: T = {} as T) => { - const pureTransitions = { - set: () => (newState: S) => newState, - ...transitions, - }; - const store = createStateContainer(state, pureTransitions); - return { store, mutators: store.transitions }; -}; - let container: HTMLDivElement | null; beforeEach(() => { @@ -56,12 +47,12 @@ test('can create React context', () => { }); test(' passes state to ', () => { - const { store } = create({ hello: 'world' }); - const { Provider, Consumer } = createStateContainerReactHelpers(); + const stateContainer = createStateContainer({ hello: 'world' }); + const { Provider, Consumer } = createStateContainerReactHelpers(); ReactDOM.render( - - {(s: typeof store) => s.get().hello} + + {(s: typeof stateContainer) => s.get().hello} , container ); @@ -79,8 +70,8 @@ interface Props1 { } test(' passes state to connect()()', () => { - const { store } = create({ hello: 'Bob' }); - const { Provider, connect } = createStateContainerReactHelpers(); + const stateContainer = createStateContainer({ hello: 'Bob' }); + const { Provider, connect } = createStateContainerReactHelpers(); const Demo: React.FC = ({ message, stop }) => ( <> @@ -92,7 +83,7 @@ test(' passes state to connect()()', () => { const DemoConnected = connect(mergeProps)(Demo); ReactDOM.render( - + , container @@ -101,14 +92,14 @@ test(' passes state to connect()()', () => { expect(container!.innerHTML).toBe('Bob?'); }); -test('context receives Redux store', () => { - const { store } = create({ foo: 'bar' }); - const { Provider, context } = createStateContainerReactHelpers(); +test('context receives stateContainer', () => { + const stateContainer = createStateContainer({ foo: 'bar' }); + const { Provider, context } = createStateContainerReactHelpers(); ReactDOM.render( /* eslint-disable no-shadow */ - - {store => store.get().foo} + + {stateContainer => stateContainer.get().foo} , /* eslint-enable no-shadow */ container @@ -117,21 +108,21 @@ test('context receives Redux store', () => { expect(container!.innerHTML).toBe('bar'); }); -xtest('can use multiple stores in one React app', () => {}); +test.todo('can use multiple stores in one React app'); describe('hooks', () => { describe('useStore', () => { - test('can select store using useStore hook', () => { - const { store } = create({ foo: 'bar' }); - const { Provider, useContainer } = createStateContainerReactHelpers(); + test('can select store using useContainer hook', () => { + const stateContainer = createStateContainer({ foo: 'bar' }); + const { Provider, useContainer } = createStateContainerReactHelpers(); const Demo: React.FC<{}> = () => { // eslint-disable-next-line no-shadow - const store = useContainer(); - return <>{store.get().foo}; + const stateContainer = useContainer(); + return <>{stateContainer.get().foo}; }; ReactDOM.render( - + , container @@ -143,15 +134,15 @@ describe('hooks', () => { describe('useState', () => { test('can select state using useState hook', () => { - const { store } = create({ foo: 'qux' }); - const { Provider, useState } = createStateContainerReactHelpers(); + const stateContainer = createStateContainer({ foo: 'qux' }); + const { Provider, useState } = createStateContainerReactHelpers(); const Demo: React.FC<{}> = () => { const { foo } = useState(); return <>{foo}; }; ReactDOM.render( - + , container @@ -161,23 +152,20 @@ describe('hooks', () => { }); test('re-renders when state changes', () => { - const { - store, - mutators: { setFoo }, - } = create( + const stateContainer = createStateContainer( { foo: 'bar' }, { setFoo: (state: { foo: string }) => (foo: string) => ({ ...state, foo }), } ); - const { Provider, useState } = createStateContainerReactHelpers(); + const { Provider, useState } = createStateContainerReactHelpers(); const Demo: React.FC<{}> = () => { const { foo } = useState(); return <>{foo}; }; ReactDOM.render( - + , container @@ -185,7 +173,7 @@ describe('hooks', () => { expect(container!.innerHTML).toBe('bar'); act(() => { - setFoo('baz'); + stateContainer.transitions.setFoo('baz'); }); expect(container!.innerHTML).toBe('baz'); }); @@ -193,7 +181,7 @@ describe('hooks', () => { describe('useTransitions', () => { test('useTransitions hook returns mutations that can update state', () => { - const { store } = create( + const stateContainer = createStateContainer( { cnt: 0, }, @@ -206,7 +194,7 @@ describe('hooks', () => { ); const { Provider, useState, useTransitions } = createStateContainerReactHelpers< - typeof store + typeof stateContainer >(); const Demo: React.FC<{}> = () => { const { cnt } = useState(); @@ -220,7 +208,7 @@ describe('hooks', () => { }; ReactDOM.render( - + , container @@ -240,7 +228,7 @@ describe('hooks', () => { describe('useSelector', () => { test('can select deeply nested value', () => { - const { store } = create({ + const stateContainer = createStateContainer({ foo: { bar: { baz: 'qux', @@ -248,14 +236,14 @@ describe('hooks', () => { }, }); const selector = (state: { foo: { bar: { baz: string } } }) => state.foo.bar.baz; - const { Provider, useSelector } = createStateContainerReactHelpers(); + const { Provider, useSelector } = createStateContainerReactHelpers(); const Demo: React.FC<{}> = () => { const value = useSelector(selector); return <>{value}; }; ReactDOM.render( - + , container @@ -265,7 +253,7 @@ describe('hooks', () => { }); test('re-renders when state changes', () => { - const { store, mutators } = create({ + const stateContainer = createStateContainer({ foo: { bar: { baz: 'qux', @@ -280,7 +268,7 @@ describe('hooks', () => { }; ReactDOM.render( - + , container @@ -288,7 +276,7 @@ describe('hooks', () => { expect(container!.innerHTML).toBe('qux'); act(() => { - mutators.set({ + stateContainer.set({ foo: { bar: { baz: 'quux', @@ -300,9 +288,9 @@ describe('hooks', () => { }); test("re-renders only when selector's result changes", async () => { - const { store, mutators } = create({ a: 'b', foo: 'bar' }); + const stateContainer = createStateContainer({ a: 'b', foo: 'bar' }); const selector = (state: { foo: string }) => state.foo; - const { Provider, useSelector } = createStateContainerReactHelpers(); + const { Provider, useSelector } = createStateContainerReactHelpers(); let cnt = 0; const Demo: React.FC<{}> = () => { @@ -311,7 +299,7 @@ describe('hooks', () => { return <>{value}; }; ReactDOM.render( - + , container @@ -321,14 +309,14 @@ describe('hooks', () => { expect(cnt).toBe(1); act(() => { - mutators.set({ a: 'c', foo: 'bar' }); + stateContainer.set({ a: 'c', foo: 'bar' }); }); await new Promise(r => setTimeout(r, 1)); expect(cnt).toBe(1); act(() => { - mutators.set({ a: 'd', foo: 'bar 2' }); + stateContainer.set({ a: 'd', foo: 'bar 2' }); }); await new Promise(r => setTimeout(r, 1)); @@ -336,9 +324,9 @@ describe('hooks', () => { }); test('does not re-render on same shape object', async () => { - const { store, mutators } = create({ foo: { bar: 'baz' } }); + const stateContainer = createStateContainer({ foo: { bar: 'baz' } }); const selector = (state: { foo: any }) => state.foo; - const { Provider, useSelector } = createStateContainerReactHelpers(); + const { Provider, useSelector } = createStateContainerReactHelpers(); let cnt = 0; const Demo: React.FC<{}> = () => { @@ -347,7 +335,7 @@ describe('hooks', () => { return <>{JSON.stringify(value)}; }; ReactDOM.render( - + , container @@ -357,14 +345,14 @@ describe('hooks', () => { expect(cnt).toBe(1); act(() => { - mutators.set({ foo: { bar: 'baz' } }); + stateContainer.set({ foo: { bar: 'baz' } }); }); await new Promise(r => setTimeout(r, 1)); expect(cnt).toBe(1); act(() => { - mutators.set({ foo: { bar: 'qux' } }); + stateContainer.set({ foo: { bar: 'qux' } }); }); await new Promise(r => setTimeout(r, 1)); @@ -372,7 +360,7 @@ describe('hooks', () => { }); test('can set custom comparator function to prevent re-renders on deep equality', async () => { - const { store, mutators } = create( + const stateContainer = createStateContainer( { foo: { bar: 'baz' } }, { set: () => (newState: { foo: { bar: string } }) => newState, @@ -380,7 +368,7 @@ describe('hooks', () => { ); const selector = (state: { foo: any }) => state.foo; const comparator = (prev: any, curr: any) => JSON.stringify(prev) === JSON.stringify(curr); - const { Provider, useSelector } = createStateContainerReactHelpers(); + const { Provider, useSelector } = createStateContainerReactHelpers(); let cnt = 0; const Demo: React.FC<{}> = () => { @@ -389,7 +377,7 @@ describe('hooks', () => { return <>{JSON.stringify(value)}; }; ReactDOM.render( - + , container @@ -399,13 +387,13 @@ describe('hooks', () => { expect(cnt).toBe(1); act(() => { - mutators.set({ foo: { bar: 'baz' } }); + stateContainer.set({ foo: { bar: 'baz' } }); }); await new Promise(r => setTimeout(r, 1)); expect(cnt).toBe(1); }); - xtest('unsubscribes when React un-mounts', () => {}); + test.todo('unsubscribes when React un-mounts'); }); }); diff --git a/src/plugins/kibana_utils/public/state_containers/create_state_container_react_helpers.ts b/src/plugins/kibana_utils/public/state_containers/create_state_container_react_helpers.ts index 45b34b13251f4..36903f2d7c90f 100644 --- a/src/plugins/kibana_utils/public/state_containers/create_state_container_react_helpers.ts +++ b/src/plugins/kibana_utils/public/state_containers/create_state_container_react_helpers.ts @@ -35,7 +35,7 @@ export const createStateContainerReactHelpers = useContainer().transitions; + const useTransitions: () => Container['transitions'] = () => useContainer().transitions; const useSelector = ( selector: (state: UnboxState) => Result, diff --git a/src/plugins/kibana_utils/public/state_containers/types.ts b/src/plugins/kibana_utils/public/state_containers/types.ts index e120f60e72b8f..5f27a3d2c1dca 100644 --- a/src/plugins/kibana_utils/public/state_containers/types.ts +++ b/src/plugins/kibana_utils/public/state_containers/types.ts @@ -20,12 +20,13 @@ import { Observable } from 'rxjs'; import { Ensure, RecursiveReadonly } from '@kbn/utility-types'; +export type BaseState = object; export interface TransitionDescription { type: Type; args: Args; } -export type Transition = (...args: Args) => State; -export type PureTransition = ( +export type Transition = (...args: Args) => State; +export type PureTransition = ( state: RecursiveReadonly ) => Transition; export type EnsurePureTransition = Ensure>; @@ -34,15 +35,15 @@ export type PureTransitionsToTransitions = { [K in keyof T]: PureTransitionToTransition>; }; -export interface BaseStateContainer { +export interface BaseStateContainer { get: () => RecursiveReadonly; set: (state: State) => void; state$: Observable>; } export interface StateContainer< - State, - PureTransitions extends object = {}, + State extends BaseState, + PureTransitions extends object, PureSelectors extends object = {} > extends BaseStateContainer { transitions: Readonly>; @@ -50,7 +51,7 @@ export interface StateContainer< } export interface ReduxLikeStateContainer< - State, + State extends BaseState, PureTransitions extends object = {}, PureSelectors extends object = {} > extends StateContainer { @@ -63,14 +64,16 @@ export interface ReduxLikeStateContainer< } export type Dispatch = (action: T) => void; - -export type Middleware = ( +export type Middleware = ( store: Pick, 'getState' | 'dispatch'> ) => ( next: (action: TransitionDescription) => TransitionDescription | any ) => Dispatch; -export type Reducer = (state: State, action: TransitionDescription) => State; +export type Reducer = ( + state: State, + action: TransitionDescription +) => State; export type UnboxState< Container extends StateContainer @@ -80,7 +83,7 @@ export type UnboxTransitions< > = Container extends StateContainer ? T : never; export type Selector = (...args: Args) => Result; -export type PureSelector = ( +export type PureSelector = ( state: State ) => Selector; export type EnsurePureSelector = Ensure>; @@ -93,7 +96,12 @@ export type PureSelectorsToSelectors = { export type Comparator = (previous: Result, current: Result) => boolean; -export type MapStateToProps = (state: State) => StateProps; -export type Connect = ( +export type MapStateToProps = ( + state: State +) => StateProps; +export type Connect = < + Props extends object, + StatePropKeys extends keyof Props +>( mapStateToProp: MapStateToProps> ) => (component: React.ComponentType) => React.FC>; diff --git a/src/plugins/kibana_utils/public/state_sync/state_sync.test.ts b/src/plugins/kibana_utils/public/state_sync/state_sync.test.ts index cc513bc674d0f..08ad1551420d2 100644 --- a/src/plugins/kibana_utils/public/state_sync/state_sync.test.ts +++ b/src/plugins/kibana_utils/public/state_sync/state_sync.test.ts @@ -17,7 +17,7 @@ * under the License. */ -import { BaseStateContainer, createStateContainer } from '../state_containers'; +import { BaseState, BaseStateContainer, createStateContainer } from '../state_containers'; import { defaultState, pureTransitions, @@ -89,7 +89,7 @@ describe('state_sync', () => { // initial sync of storage to state is not happening expect(container.getState()).toEqual(defaultState); - const storageState2 = [{ id: 1, text: 'todo', completed: true }]; + const storageState2 = { todos: [{ id: 1, text: 'todo', completed: true }] }; (testStateStorage.get as jest.Mock).mockImplementation(() => storageState2); storageChange$.next(storageState2); @@ -124,7 +124,7 @@ describe('state_sync', () => { start(); const originalState = container.getState(); - const storageState = [...originalState]; + const storageState = { ...originalState }; (testStateStorage.get as jest.Mock).mockImplementation(() => storageState); storageChange$.next(storageState); @@ -134,7 +134,7 @@ describe('state_sync', () => { }); it('storage change to null should notify state', () => { - container.set([{ completed: false, id: 1, text: 'changed' }]); + container.set({ todos: [{ completed: false, id: 1, text: 'changed' }] }); const { stop, start } = syncStates([ { stateContainer: withDefaultState(container, defaultState), @@ -189,8 +189,8 @@ describe('state_sync', () => { ]); start(); - const newStateFromUrl = [{ completed: false, id: 1, text: 'changed' }]; - history.replace('/#?_s=!((completed:!f,id:1,text:changed))'); + const newStateFromUrl = { todos: [{ completed: false, id: 1, text: 'changed' }] }; + history.replace('/#?_s=(todos:!((completed:!f,id:1,text:changed)))'); expect(container.getState()).toEqual(newStateFromUrl); expect(JSON.parse(sessionStorage.getItem(key)!)).toEqual(newStateFromUrl); @@ -220,7 +220,7 @@ describe('state_sync', () => { expect(history.length).toBe(startHistoryLength + 1); expect(getCurrentUrl()).toMatchInlineSnapshot( - `"/#?_s=!((completed:!t,id:0,text:'Learning%20state%20containers'),(completed:!t,id:2,text:'2'),(completed:!t,id:3,text:'3'))"` + `"/#?_s=(todos:!((completed:!t,id:0,text:'Learning%20state%20containers'),(completed:!t,id:2,text:'2'),(completed:!t,id:3,text:'3')))"` ); stop(); @@ -248,14 +248,14 @@ describe('state_sync', () => { expect(history.length).toBe(startHistoryLength + 1); expect(getCurrentUrl()).toMatchInlineSnapshot( - `"/#?_s=!((completed:!t,id:0,text:'Learning%20state%20containers'),(completed:!t,id:2,text:'2'),(completed:!t,id:3,text:'3'))"` + `"/#?_s=(todos:!((completed:!t,id:0,text:'Learning%20state%20containers'),(completed:!t,id:2,text:'2'),(completed:!t,id:3,text:'3')))"` ); await tick(); expect(history.length).toBe(startHistoryLength + 1); expect(getCurrentUrl()).toMatchInlineSnapshot( - `"/#?_s=!((completed:!t,id:0,text:'Learning%20state%20containers'),(completed:!t,id:2,text:'2'),(completed:!t,id:3,text:'3'))"` + `"/#?_s=(todos:!((completed:!t,id:0,text:'Learning%20state%20containers'),(completed:!t,id:2,text:'2'),(completed:!t,id:3,text:'3')))"` ); stop(); @@ -294,7 +294,7 @@ describe('state_sync', () => { }); }); -function withDefaultState( +function withDefaultState( stateContainer: BaseStateContainer, // eslint-disable-next-line no-shadow defaultState: State @@ -302,7 +302,10 @@ function withDefaultState( return { ...stateContainer, set: (state: State | null) => { - stateContainer.set(state || defaultState); + stateContainer.set({ + ...defaultState, + ...state, + }); }, }; } diff --git a/src/plugins/kibana_utils/public/state_sync/state_sync.ts b/src/plugins/kibana_utils/public/state_sync/state_sync.ts index f0ef1423dec71..9c1116e5da531 100644 --- a/src/plugins/kibana_utils/public/state_sync/state_sync.ts +++ b/src/plugins/kibana_utils/public/state_sync/state_sync.ts @@ -23,6 +23,7 @@ import defaultComparator from 'fast-deep-equal'; import { IStateSyncConfig } from './types'; import { IStateStorage } from './state_sync_state_storage'; import { distinctUntilChangedWithInitialValue } from '../../common'; +import { BaseState } from '../state_containers'; /** * Utility for syncing application state wrapped in state container @@ -86,7 +87,10 @@ export interface ISyncStateRef({ +export function syncState< + State extends BaseState, + StateStorage extends IStateStorage = IStateStorage +>({ storageKey, stateStorage, stateContainer, diff --git a/src/plugins/kibana_utils/public/state_sync/types.ts b/src/plugins/kibana_utils/public/state_sync/types.ts index 0f7395ad0f0e5..3009c1d161a53 100644 --- a/src/plugins/kibana_utils/public/state_sync/types.ts +++ b/src/plugins/kibana_utils/public/state_sync/types.ts @@ -17,10 +17,11 @@ * under the License. */ -import { BaseStateContainer } from '../state_containers/types'; +import { BaseState, BaseStateContainer } from '../state_containers/types'; import { IStateStorage } from './state_sync_state_storage'; -export interface INullableBaseStateContainer extends BaseStateContainer { +export interface INullableBaseStateContainer + extends BaseStateContainer { // State container for stateSync() have to accept "null" // for example, set() implementation could handle null and fallback to some default state // this is required to handle edge case, when state in storage becomes empty and syncing is in progress. @@ -29,7 +30,7 @@ export interface INullableBaseStateContainer extends BaseStateContainer { /** diff --git a/yarn.lock b/yarn.lock index 3dd7dbe37b2e9..ff098b7b9c891 100644 --- a/yarn.lock +++ b/yarn.lock @@ -3439,6 +3439,11 @@ resolved "https://registry.yarnpkg.com/@types/dedent/-/dedent-0.7.0.tgz#155f339ca404e6dd90b9ce46a3f78fd69ca9b050" integrity sha512-EGlKlgMhnLt/cM4DbUSafFdrkeJoC9Mvnj0PUCU7tFmTjMjNRT957kXCx0wYm3JuEq4o4ZsS5vG+NlkM2DMd2A== +"@types/deep-freeze-strict@^1.1.0": + version "1.1.0" + resolved "https://registry.yarnpkg.com/@types/deep-freeze-strict/-/deep-freeze-strict-1.1.0.tgz#447a6a2576191344aa42310131dd3df5c41492c4" + integrity sha1-RHpqJXYZE0SqQjEBMd099cQUksQ= + "@types/delete-empty@^2.0.0": version "2.0.0" resolved "https://registry.yarnpkg.com/@types/delete-empty/-/delete-empty-2.0.0.tgz#1647ae9e68f708a6ba778531af667ec55bc61964" @@ -10034,6 +10039,11 @@ deep-extend@^0.6.0: resolved "https://registry.yarnpkg.com/deep-extend/-/deep-extend-0.6.0.tgz#c4fa7c95404a17a9c3e8ca7e1537312b736330ac" integrity sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA== +deep-freeze-strict@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/deep-freeze-strict/-/deep-freeze-strict-1.1.1.tgz#77d0583ca24a69be4bbd9ac2fae415d55523e5b0" + integrity sha1-d9BYPKJKab5LvZrC+uQV1VUj5bA= + deep-is@^0.1.3, deep-is@~0.1.3: version "0.1.3" resolved "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.3.tgz#b369d6fb5dbc13eecf524f91b070feedc357cf34" From e7472e2f0073d8ad0bca291244b9093bb65915cd Mon Sep 17 00:00:00 2001 From: Jaime Soriano Pastor Date: Mon, 13 Jan 2020 13:25:48 +0100 Subject: [PATCH 018/139] Fix icon path in tutorial introduction (#49684) Some icons are included as SVG files with relative paths to their location. Add the base path so these files are correctly displayed when Kibana is not running from the root path. --- .../public/home/np_ready/components/tutorial/tutorial.js | 7 ++++++- .../public/home/np_ready/components/tutorial_directory.js | 2 +- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/src/legacy/core_plugins/kibana/public/home/np_ready/components/tutorial/tutorial.js b/src/legacy/core_plugins/kibana/public/home/np_ready/components/tutorial/tutorial.js index 314ddf2196f06..c7aa5b0f5b2f9 100644 --- a/src/legacy/core_plugins/kibana/public/home/np_ready/components/tutorial/tutorial.js +++ b/src/legacy/core_plugins/kibana/public/home/np_ready/components/tutorial/tutorial.js @@ -363,6 +363,11 @@ class TutorialUi extends React.Component { ); } + let icon = this.state.tutorial.euiIconType; + if (icon && icon.includes('/')) { + icon = this.props.addBasePath(icon); + } + const instructions = this.getInstructions(); content = (
@@ -371,7 +376,7 @@ class TutorialUi extends React.Component { description={this.props.replaceTemplateStrings(this.state.tutorial.longDescription)} previewUrl={previewUrl} exportedFieldsUrl={exportedFieldsUrl} - iconType={this.state.tutorial.euiIconType} + iconType={icon} isBeta={this.state.tutorial.isBeta} /> diff --git a/src/legacy/core_plugins/kibana/public/home/np_ready/components/tutorial_directory.js b/src/legacy/core_plugins/kibana/public/home/np_ready/components/tutorial_directory.js index 06da6f35ee42e..697c1b0468cd1 100644 --- a/src/legacy/core_plugins/kibana/public/home/np_ready/components/tutorial_directory.js +++ b/src/legacy/core_plugins/kibana/public/home/np_ready/components/tutorial_directory.js @@ -129,7 +129,7 @@ class TutorialDirectoryUi extends React.Component { let tutorialCards = tutorialConfigs.map(tutorialConfig => { // add base path to SVG based icons let icon = tutorialConfig.euiIconType; - if (icon != null && icon.includes('/')) { + if (icon && icon.includes('/')) { icon = this.props.addBasePath(icon); } From 14df4c096c7b41be3aec803b5d80d639d88acba9 Mon Sep 17 00:00:00 2001 From: Nathan Reese Date: Mon, 13 Jan 2020 07:28:39 -0500 Subject: [PATCH 019/139] [Maps] refactor isPointsOnly, isLinesOnly, and isPolygonsOnly to make synchronous (#54067) * [Maps] refactor isPointsOnly, isLinesOnly, and isPolygonsOnly to make synchronous * fix jest test * review feedback Co-authored-by: Elastic Machine --- .../__snapshots__/vector_icon.test.js.snap | 8 +- .../vector/components/legend/vector_icon.js | 91 ++++------- .../components/legend/vector_icon.test.js | 126 ++++----------- .../components/legend/vector_style_legend.js | 67 ++------ .../vector/components/vector_style_editor.js | 22 +-- .../dynamic_color_property.test.js.snap | 92 +---------- .../components/categorical_legend.js | 36 ++--- .../properties/dynamic_color_property.js | 24 +-- .../properties/dynamic_color_property.test.js | 32 +--- .../properties/dynamic_style_property.js | 10 +- .../public/layers/styles/vector/style_util.js | 4 - .../layers/styles/vector/vector_style.js | 151 +++++++++--------- .../layers/styles/vector/vector_style.test.js | 109 ++----------- 13 files changed, 199 insertions(+), 573 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/legend/__snapshots__/vector_icon.test.js.snap b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/legend/__snapshots__/vector_icon.test.js.snap index 57368b52a2bce..5837a80ec3083 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/legend/__snapshots__/vector_icon.test.js.snap +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/legend/__snapshots__/vector_icon.test.js.snap @@ -1,6 +1,6 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`Renders CircleIcon with correct styles when isPointOnly 1`] = ` +exports[`Renders CircleIcon 1`] = ` `; -exports[`Renders LineIcon with correct styles when isLineOnly 1`] = ` +exports[`Renders LineIcon 1`] = ` `; -exports[`Renders PolygonIcon with correct styles when not line only or not point only 1`] = ` +exports[`Renders PolygonIcon 1`] = ` `; -exports[`Renders SymbolIcon with correct styles when isPointOnly and symbolId provided 1`] = ` +exports[`Renders SymbolIcon 1`] = ` ; - } +export function VectorIcon({ fillColor, isPointsOnly, isLinesOnly, strokeColor, symbolId }) { + if (isLinesOnly) { const style = { - stroke: this.props.getColorForProperty(VECTOR_STYLES.LINE_COLOR, false), - strokeWidth: '1px', - fill: this.props.getColorForProperty(VECTOR_STYLES.FILL_COLOR, false), + stroke: strokeColor, + strokeWidth: '4px', }; + return ; + } - if (!this.state.isPointsOnly) { - return ; - } + const style = { + stroke: strokeColor, + strokeWidth: '1px', + fill: fillColor, + }; - if (!this.props.symbolId) { - return ; - } + if (!isPointsOnly) { + return ; + } - return ( - - ); + if (!symbolId) { + return ; } + + return ( + + ); } VectorIcon.propTypes = { - getColorForProperty: PropTypes.func.isRequired, + fillColor: PropTypes.string, + isPointsOnly: PropTypes.bool.isRequired, + isLinesOnly: PropTypes.bool.isRequired, + strokeColor: PropTypes.string.isRequired, symbolId: PropTypes.string, - loadIsPointsOnly: PropTypes.func.isRequired, - loadIsLinesOnly: PropTypes.func.isRequired, }; diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/legend/vector_icon.test.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/legend/vector_icon.test.js index ee0058a6ef1aa..9d1a4d75beba2 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/legend/vector_icon.test.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/legend/vector_icon.test.js @@ -8,113 +8,51 @@ import React from 'react'; import { shallow } from 'enzyme'; import { VectorIcon } from './vector_icon'; -import { VectorStyle } from '../../vector_style'; -import { extractColorFromStyleProperty } from './extract_color_from_style_property'; -import { VECTOR_STYLES } from '../../vector_style_defaults'; -let isPointsOnly = false; -let isLinesOnly = false; -const styles = { - fillColor: { - type: VectorStyle.STYLE_TYPE.STATIC, - options: { - color: '#ff0000', - }, - }, - lineColor: { - type: VectorStyle.STYLE_TYPE.DYNAMIC, - options: { - color: 'Blues', - field: { - name: 'prop1', - }, - }, - }, -}; - -const defaultProps = { - getColorForProperty: (styleProperty, isLinesOnly) => { - if (isLinesOnly) { - return extractColorFromStyleProperty(styles[VECTOR_STYLES.LINE_COLOR], 'grey'); - } - - if (styleProperty === VECTOR_STYLES.LINE_COLOR) { - return extractColorFromStyleProperty(styles[VECTOR_STYLES.LINE_COLOR], 'none'); - } else if (styleProperty === VECTOR_STYLES.FILL_COLOR) { - return extractColorFromStyleProperty(styles[VECTOR_STYLES.FILL_COLOR], 'grey'); - } else { - //unexpected - console.error('Cannot return color for properties other then line or fill color'); - } - }, - - loadIsPointsOnly: () => { - return isPointsOnly; - }, - loadIsLinesOnly: () => { - return isLinesOnly; - }, -}; - -function configureIsLinesOnly() { - isLinesOnly = true; - isPointsOnly = false; -} - -function configureIsPointsOnly() { - isLinesOnly = false; - isPointsOnly = true; -} - -function configureNotLineOrPointOnly() { - isLinesOnly = false; - isPointsOnly = false; -} - -test('Renders PolygonIcon with correct styles when not line only or not point only', async () => { - configureNotLineOrPointOnly(); - const component = shallow(); - - // Ensure all promises resolve - await new Promise(resolve => process.nextTick(resolve)); - // Ensure the state changes are reflected - component.update(); +test('Renders PolygonIcon', () => { + const component = shallow( + + ); expect(component).toMatchSnapshot(); }); -test('Renders LineIcon with correct styles when isLineOnly', async () => { - configureIsLinesOnly(); - const component = shallow(); - - // Ensure all promises resolve - await new Promise(resolve => process.nextTick(resolve)); - // Ensure the state changes are reflected - component.update(); +test('Renders LineIcon', () => { + const component = shallow( + + ); expect(component).toMatchSnapshot(); }); -test('Renders CircleIcon with correct styles when isPointOnly', async () => { - configureIsPointsOnly(); - const component = shallow(); - - // Ensure all promises resolve - await new Promise(resolve => process.nextTick(resolve)); - // Ensure the state changes are reflected - component.update(); +test('Renders CircleIcon', () => { + const component = shallow( + + ); expect(component).toMatchSnapshot(); }); -test('Renders SymbolIcon with correct styles when isPointOnly and symbolId provided', async () => { - configureIsPointsOnly(); - const component = shallow(); - - // Ensure all promises resolve - await new Promise(resolve => process.nextTick(resolve)); - // Ensure the state changes are reflected - component.update(); +test('Renders SymbolIcon', () => { + const component = shallow( + + ); expect(component).toMatchSnapshot(); }); diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/legend/vector_style_legend.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/legend/vector_style_legend.js index df302c42d48ed..a7e98c83468ae 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/legend/vector_style_legend.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/legend/vector_style_legend.js @@ -4,57 +4,18 @@ * you may not use this file except in compliance with the Elastic License. */ -import _ from 'lodash'; -import React, { Component, Fragment } from 'react'; - -export class VectorStyleLegend extends Component { - state = { - styles: [], - }; - - componentDidMount() { - this._isMounted = true; - this._prevStyleDescriptors = undefined; - this._loadRows(); - } - - componentDidUpdate() { - this._loadRows(); - } - - componentWillUnmount() { - this._isMounted = false; - } - - _loadRows = _.debounce(async () => { - const styles = await this.props.getLegendDetailStyleProperties(); - const styleDescriptorPromises = styles.map(async style => { - return { - type: style.getStyleName(), - options: style.getOptions(), - fieldMeta: style.getFieldMeta(), - label: await style.getField().getLabel(), - }; - }); - - const styleDescriptors = await Promise.all(styleDescriptorPromises); - if (this._isMounted && !_.isEqual(styleDescriptors, this._prevStyleDescriptors)) { - this._prevStyleDescriptors = styleDescriptors; - this.setState({ styles: styles }); - } - }, 100); - - render() { - return this.state.styles.map(style => { - return ( - - {style.renderLegendDetailRow({ - loadIsLinesOnly: this.props.loadIsLinesOnly, - loadIsPointsOnly: this.props.loadIsPointsOnly, - symbolId: this.props.symbolId, - })} - - ); - }); - } +import React, { Fragment } from 'react'; + +export function VectorStyleLegend({ isLinesOnly, isPointsOnly, styles, symbolId }) { + return styles.map(style => { + return ( + + {style.renderLegendDetailRow({ + isLinesOnly, + isPointsOnly, + symbolId, + })} + + ); + }); } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/vector_style_editor.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/vector_style_editor.js index 8e80e036dbb8b..dffe513644db8 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/vector_style_editor.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/vector_style_editor.js @@ -86,25 +86,14 @@ export class VectorStyleEditor extends Component { async _loadSupportedFeatures() { const supportedFeatures = await this.props.layer.getSource().getSupportedShapeTypes(); - const isPointsOnly = await this.props.loadIsPointsOnly(); - const isLinesOnly = await this.props.loadIsLinesOnly(); - if (!this._isMounted) { return; } - if ( - _.isEqual(supportedFeatures, this.state.supportedFeatures) && - isPointsOnly === this.state.isPointsOnly && - isLinesOnly === this.state.isLinesOnly - ) { - return; - } - let selectedFeature = VECTOR_SHAPE_TYPES.POLYGON; - if (isPointsOnly) { + if (this.props.isPointsOnly) { selectedFeature = VECTOR_SHAPE_TYPES.POINT; - } else if (isLinesOnly) { + } else if (this.props.isLinesOnly) { selectedFeature = VECTOR_SHAPE_TYPES.LINE; } @@ -112,12 +101,7 @@ export class VectorStyleEditor extends Component { !_.isEqual(supportedFeatures, this.state.supportedFeatures) || selectedFeature !== this.state.selectedFeature ) { - this.setState({ - supportedFeatures, - selectedFeature, - isPointsOnly, - isLinesOnly, - }); + this.setState({ supportedFeatures, selectedFeature }); } } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/__snapshots__/dynamic_color_property.test.js.snap b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/__snapshots__/dynamic_color_property.test.js.snap index 26e36cb97a791..8da8cfaa71e2c 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/__snapshots__/dynamic_color_property.test.js.snap +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/__snapshots__/dynamic_color_property.test.js.snap @@ -1,98 +1,10 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`Should render categorical legend 1`] = ` -
- - - - - - - 0_format - - - - - - - - - - - - 10_format - - - - - - - - - - - - - - - foobar_label - - - - - - -
-`; +exports[`Should render categorical legend 1`] = `""`; exports[`Should render ranged legend 1`] = ` { - return isLinesOnly; - }; - - const loadIsPointsOnly = () => { - return isPointsOnly; - }; - - const getColorForProperty = (styleProperty, isLinesOnly) => { - if (isLinesOnly) { - return color; - } - - return this.getStyleName() === styleProperty ? color : 'none'; - }; - + const fillColor = this.getStyleName() === VECTOR_STYLES.FILL_COLOR ? color : 'none'; return ( ); } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.test.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.test.js index dbf704c9cbe4c..0affeefde1313 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.test.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.test.js @@ -24,7 +24,7 @@ const mockField = { }, }; -test('Should render ranged legend', async () => { +test('Should render ranged legend', () => { const colorStyle = new DynamicColorProperty( { color: 'Blues', @@ -40,25 +40,15 @@ test('Should render ranged legend', async () => { ); const legendRow = colorStyle.renderLegendDetailRow({ - loadIsPointsOnly: () => { - return true; - }, - loadIsLinesOnly: () => { - return false; - }, + isPointsOnly: true, + isLinesOnly: false, }); - const component = shallow(legendRow); - // Ensure all promises resolve - await new Promise(resolve => process.nextTick(resolve)); - // Ensure the state changes are reflected - component.update(); - expect(component).toMatchSnapshot(); }); -test('Should render categorical legend', async () => { +test('Should render categorical legend', () => { const colorStyle = new DynamicColorProperty( { useCustomColorRamp: true, @@ -84,20 +74,10 @@ test('Should render categorical legend', async () => { ); const legendRow = colorStyle.renderLegendDetailRow({ - loadIsPointsOnly: () => { - return true; - }, - loadIsLinesOnly: () => { - return false; - }, + isPointsOnly: true, + isLinesOnly: false, }); - const component = shallow(legendRow); - // Ensure all promises resolve - await new Promise(resolve => process.nextTick(resolve)); - // Ensure the state changes are reflected - component.update(); - expect(component).toMatchSnapshot(); }); diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js index bac3c96581967..cb5858fa47b3e 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js @@ -165,12 +165,12 @@ export class DynamicStyleProperty extends AbstractStyleProperty { return null; } - _renderCategoricalLegend({ loadIsPointsOnly, loadIsLinesOnly, symbolId }) { + _renderCategoricalLegend({ isPointsOnly, isLinesOnly, symbolId }) { return ( ); @@ -180,11 +180,11 @@ export class DynamicStyleProperty extends AbstractStyleProperty { return ; } - renderLegendDetailRow({ loadIsPointsOnly, loadIsLinesOnly, symbolId }) { + renderLegendDetailRow({ isPointsOnly, isLinesOnly, symbolId }) { if (this.isRanged()) { return this._renderRangeLegend(); } else if (this.hasBreaks()) { - return this._renderCategoricalLegend({ loadIsPointsOnly, loadIsLinesOnly, symbolId }); + return this._renderCategoricalLegend({ isPointsOnly, isLinesOnly, symbolId }); } else { return null; } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/style_util.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/style_util.js index b8fc428a62a52..7bd60ea6502bc 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/style_util.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/style_util.js @@ -17,10 +17,6 @@ export function isOnlySingleFeatureType(featureType, supportedFeatures, hasFeatu return supportedFeatures[0] === featureType; } - if (!hasFeatureType) { - return false; - } - const featureTypes = Object.keys(hasFeatureType); return featureTypes.reduce((isOnlyTargetFeatureType, featureTypeKey) => { const hasFeature = hasFeatureType[featureTypeKey]; diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style.js index ea80b188e1646..d1efcbb72d1a7 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style.js @@ -143,8 +143,8 @@ export class VectorStyle extends AbstractStyle { styleProperties={styleProperties} symbolDescriptor={this._descriptor.properties[VECTOR_STYLES.SYMBOL]} layer={layer} - loadIsPointsOnly={this._getIsPointsOnly} - loadIsLinesOnly={this._getIsLinesOnly} + isPointsOnly={this._getIsPointsOnly()} + isLinesOnly={this._getIsLinesOnly()} onIsTimeAwareChange={onIsTimeAwareChange} isTimeAware={this.isTimeAware()} showIsTimeAware={propertiesWithFieldMeta.length > 0} @@ -218,43 +218,57 @@ export class VectorStyle extends AbstractStyle { async pluckStyleMetaFromSourceDataRequest(sourceDataRequest) { const features = _.get(sourceDataRequest.getData(), 'features', []); - if (features.length === 0) { - return {}; - } - - const dynamicProperties = this.getDynamicPropertiesArray(); const supportedFeatures = await this._source.getSupportedShapeTypes(); - const isSingleFeatureType = supportedFeatures.length === 1; - if (dynamicProperties.length === 0 && isSingleFeatureType) { - // no meta data to pull from source data request. - return {}; - } - - let hasPoints = false; - let hasLines = false; - let hasPolygons = false; - for (let i = 0; i < features.length; i++) { - const feature = features[i]; - if (!hasPoints && POINTS.includes(feature.geometry.type)) { - hasPoints = true; - } - if (!hasLines && LINES.includes(feature.geometry.type)) { - hasLines = true; - } - if (!hasPolygons && POLYGONS.includes(feature.geometry.type)) { - hasPolygons = true; + const hasFeatureType = { + [VECTOR_SHAPE_TYPES.POINT]: false, + [VECTOR_SHAPE_TYPES.LINE]: false, + [VECTOR_SHAPE_TYPES.POLYGON]: false, + }; + if (supportedFeatures.length > 1) { + for (let i = 0; i < features.length; i++) { + const feature = features[i]; + if (!hasFeatureType[VECTOR_SHAPE_TYPES.POINT] && POINTS.includes(feature.geometry.type)) { + hasFeatureType[VECTOR_SHAPE_TYPES.POINT] = true; + } + if (!hasFeatureType[VECTOR_SHAPE_TYPES.LINE] && LINES.includes(feature.geometry.type)) { + hasFeatureType[VECTOR_SHAPE_TYPES.LINE] = true; + } + if ( + !hasFeatureType[VECTOR_SHAPE_TYPES.POLYGON] && + POLYGONS.includes(feature.geometry.type) + ) { + hasFeatureType[VECTOR_SHAPE_TYPES.POLYGON] = true; + } } } const featuresMeta = { - hasFeatureType: { - [VECTOR_SHAPE_TYPES.POINT]: hasPoints, - [VECTOR_SHAPE_TYPES.LINE]: hasLines, - [VECTOR_SHAPE_TYPES.POLYGON]: hasPolygons, + geometryTypes: { + isPointsOnly: isOnlySingleFeatureType( + VECTOR_SHAPE_TYPES.POINT, + supportedFeatures, + hasFeatureType + ), + isLinesOnly: isOnlySingleFeatureType( + VECTOR_SHAPE_TYPES.LINE, + supportedFeatures, + hasFeatureType + ), + isPolygonsOnly: isOnlySingleFeatureType( + VECTOR_SHAPE_TYPES.POLYGON, + supportedFeatures, + hasFeatureType + ), }, }; + const dynamicProperties = this.getDynamicPropertiesArray(); + if (dynamicProperties.length === 0 || features.length === 0) { + // no additional meta data to pull from source data request. + return featuresMeta; + } + dynamicProperties.forEach(dynamicProperty => { const styleMeta = dynamicProperty.pluckStyleMetaFromFeatures(features); if (styleMeta) { @@ -291,24 +305,16 @@ export class VectorStyle extends AbstractStyle { ); } - _isOnlySingleFeatureType = async featureType => { - return isOnlySingleFeatureType( - featureType, - await this._source.getSupportedShapeTypes(), - this._getStyleMeta().hasFeatureType - ); - }; - - _getIsPointsOnly = async () => { - return this._isOnlySingleFeatureType(VECTOR_SHAPE_TYPES.POINT); + _getIsPointsOnly = () => { + return _.get(this._getStyleMeta(), 'geometryTypes.isPointsOnly', false); }; - _getIsLinesOnly = async () => { - return this._isOnlySingleFeatureType(VECTOR_SHAPE_TYPES.LINE); + _getIsLinesOnly = () => { + return _.get(this._getStyleMeta(), 'geometryTypes.isLinesOnly', false); }; - _getIsPolygonsOnly = async () => { - return this._isOnlySingleFeatureType(VECTOR_SHAPE_TYPES.POLYGON); + _getIsPolygonsOnly = () => { + return _.get(this._getStyleMeta(), 'geometryTypes.isPolygonsOnly', false); }; _getDynamicPropertyByFieldName(fieldName) { @@ -393,50 +399,44 @@ export class VectorStyle extends AbstractStyle { : this._descriptor.properties.symbol.options.symbolId; } - _getColorForProperty = (styleProperty, isLinesOnly) => { - const styles = this.getRawProperties(); - if (isLinesOnly) { - return extractColorFromStyleProperty(styles[VECTOR_STYLES.LINE_COLOR], 'grey'); - } - - if (styleProperty === VECTOR_STYLES.LINE_COLOR) { - return extractColorFromStyleProperty(styles[VECTOR_STYLES.LINE_COLOR], 'none'); - } else if (styleProperty === VECTOR_STYLES.FILL_COLOR) { - return extractColorFromStyleProperty(styles[VECTOR_STYLES.FILL_COLOR], 'grey'); - } else { - //unexpected - console.error('Cannot return color for properties other then line or fill color'); - } - }; - getIcon = () => { - const symbolId = this._getSymbolId(); + const isLinesOnly = this._getIsLinesOnly(); + const strokeColor = isLinesOnly + ? extractColorFromStyleProperty(this._descriptor.properties[VECTOR_STYLES.LINE_COLOR], 'grey') + : extractColorFromStyleProperty( + this._descriptor.properties[VECTOR_STYLES.LINE_COLOR], + 'none' + ); + const fillColor = isLinesOnly + ? null + : extractColorFromStyleProperty( + this._descriptor.properties[VECTOR_STYLES.FILL_COLOR], + 'grey' + ); return ( ); }; - _getLegendDetailStyleProperties = async () => { - const isLinesOnly = await this._getIsLinesOnly(); - const isPolygonsOnly = await this._getIsPolygonsOnly(); - + _getLegendDetailStyleProperties = () => { return this.getDynamicPropertiesArray().filter(styleProperty => { const styleName = styleProperty.getStyleName(); if ([VECTOR_STYLES.ICON_ORIENTATION, VECTOR_STYLES.LABEL_TEXT].includes(styleName)) { return false; } - if (isLinesOnly) { + if (this._getIsLinesOnly()) { return LINE_STYLES.includes(styleName); } - if (isPolygonsOnly) { + if (this._getIsPolygonsOnly()) { return POLYGON_STYLES.includes(styleName); } @@ -445,16 +445,15 @@ export class VectorStyle extends AbstractStyle { }; async hasLegendDetails() { - const styles = await this._getLegendDetailStyleProperties(); - return styles.length > 0; + return this._getLegendDetailStyleProperties().length > 0; } renderLegendDetails() { return ( ); diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style.test.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style.test.js index aa0badd5583d5..3d2911720c312 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style.test.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style.test.js @@ -159,11 +159,9 @@ describe('pluckStyleMetaFromSourceDataRequest', () => { const vectorStyle = new VectorStyle({}, new MockSource()); const featuresMeta = await vectorStyle.pluckStyleMetaFromSourceDataRequest(sourceDataRequest); - expect(featuresMeta.hasFeatureType).toEqual({ - LINE: false, - POINT: true, - POLYGON: false, - }); + expect(featuresMeta.geometryTypes.isPointsOnly).toBe(true); + expect(featuresMeta.geometryTypes.isLinesOnly).toBe(false); + expect(featuresMeta.geometryTypes.isPolygonsOnly).toBe(false); }); it('Should identify when feature collection only contains lines', async () => { @@ -189,11 +187,9 @@ describe('pluckStyleMetaFromSourceDataRequest', () => { const vectorStyle = new VectorStyle({}, new MockSource()); const featuresMeta = await vectorStyle.pluckStyleMetaFromSourceDataRequest(sourceDataRequest); - expect(featuresMeta.hasFeatureType).toEqual({ - LINE: true, - POINT: false, - POLYGON: false, - }); + expect(featuresMeta.geometryTypes.isPointsOnly).toBe(false); + expect(featuresMeta.geometryTypes.isLinesOnly).toBe(true); + expect(featuresMeta.geometryTypes.isPolygonsOnly).toBe(false); }); }); @@ -241,11 +237,9 @@ describe('pluckStyleMetaFromSourceDataRequest', () => { ); const featuresMeta = await vectorStyle.pluckStyleMetaFromSourceDataRequest(sourceDataRequest); - expect(featuresMeta.hasFeatureType).toEqual({ - LINE: false, - POINT: true, - POLYGON: false, - }); + expect(featuresMeta.geometryTypes.isPointsOnly).toBe(true); + expect(featuresMeta.geometryTypes.isLinesOnly).toBe(false); + expect(featuresMeta.geometryTypes.isPolygonsOnly).toBe(false); }); it('Should extract scaled field range', async () => { @@ -275,88 +269,3 @@ describe('pluckStyleMetaFromSourceDataRequest', () => { }); }); }); - -describe('checkIfOnlyFeatureType', () => { - describe('source supports single feature type', () => { - it('isPointsOnly should be true when source feature type only supports points', async () => { - const vectorStyle = new VectorStyle( - {}, - new MockSource({ - supportedShapeTypes: [VECTOR_SHAPE_TYPES.POINT], - }) - ); - const isPointsOnly = await vectorStyle._getIsPointsOnly(); - expect(isPointsOnly).toBe(true); - }); - - it('isLineOnly should be false when source feature type only supports points', async () => { - const vectorStyle = new VectorStyle( - {}, - new MockSource({ - supportedShapeTypes: [VECTOR_SHAPE_TYPES.POINT], - }) - ); - const isLineOnly = await vectorStyle._getIsLinesOnly(); - expect(isLineOnly).toBe(false); - }); - }); - - describe('source supports multiple feature types', () => { - it('isPointsOnly should be true when data contains just points', async () => { - const vectorStyle = new VectorStyle( - { - __styleMeta: { - hasFeatureType: { - POINT: true, - LINE: false, - POLYGON: false, - }, - }, - }, - new MockSource({ - supportedShapeTypes: Object.values(VECTOR_SHAPE_TYPES), - }) - ); - const isPointsOnly = await vectorStyle._getIsPointsOnly(); - expect(isPointsOnly).toBe(true); - }); - - it('isPointsOnly should be false when data contains just lines', async () => { - const vectorStyle = new VectorStyle( - { - __styleMeta: { - hasFeatureType: { - POINT: false, - LINE: true, - POLYGON: false, - }, - }, - }, - new MockSource({ - supportedShapeTypes: Object.values(VECTOR_SHAPE_TYPES), - }) - ); - const isPointsOnly = await vectorStyle._getIsPointsOnly(); - expect(isPointsOnly).toBe(false); - }); - - it('isPointsOnly should be false when data contains points, lines, and polygons', async () => { - const vectorStyle = new VectorStyle( - { - __styleMeta: { - hasFeatureType: { - POINT: true, - LINE: true, - POLYGON: true, - }, - }, - }, - new MockSource({ - supportedShapeTypes: Object.values(VECTOR_SHAPE_TYPES), - }) - ); - const isPointsOnly = await vectorStyle._getIsPointsOnly(); - expect(isPointsOnly).toBe(false); - }); - }); -}); From 05c48cf153760c20e21b7d9a114085304240d711 Mon Sep 17 00:00:00 2001 From: cachedout Date: Mon, 13 Jan 2020 13:42:33 +0000 Subject: [PATCH 020/139] Display APM server memory in bytes (#54275) * Display APM server memory in bytes * Add tests for helpers --- .../__snapshots__/helpers.test.js.snap | 48 +++++++++++++++++++ .../overview/__tests__/helpers.test.js | 42 ++++++++++++++++ .../components/cluster/overview/apm_panel.js | 8 +--- .../cluster/overview/elasticsearch_panel.js | 3 +- .../components/cluster/overview/helpers.js | 13 +++-- 5 files changed, 101 insertions(+), 13 deletions(-) create mode 100644 x-pack/legacy/plugins/monitoring/public/components/cluster/overview/__tests__/__snapshots__/helpers.test.js.snap create mode 100644 x-pack/legacy/plugins/monitoring/public/components/cluster/overview/__tests__/helpers.test.js diff --git a/x-pack/legacy/plugins/monitoring/public/components/cluster/overview/__tests__/__snapshots__/helpers.test.js.snap b/x-pack/legacy/plugins/monitoring/public/components/cluster/overview/__tests__/__snapshots__/helpers.test.js.snap new file mode 100644 index 0000000000000..ea9d312413168 --- /dev/null +++ b/x-pack/legacy/plugins/monitoring/public/components/cluster/overview/__tests__/__snapshots__/helpers.test.js.snap @@ -0,0 +1,48 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`Bytes Usage should format correctly with only usedBytes 1`] = ` + +
+ 50.0 B +
+
+`; + +exports[`Bytes Usage should format correctly with used and max bytes 1`] = ` + +
+ 50.0 B / 100.0 B +
+
+`; + +exports[`BytesPercentageUsage should format correctly with used bytes and max bytes 1`] = ` + +
+ 50.00% +
+
+
+ 50.0 B / 100.0 B +
+
+
+`; + +exports[`BytesPercentageUsage should return zero bytes if both parameters are not present 1`] = ` +
+ 0 +
+`; diff --git a/x-pack/legacy/plugins/monitoring/public/components/cluster/overview/__tests__/helpers.test.js b/x-pack/legacy/plugins/monitoring/public/components/cluster/overview/__tests__/helpers.test.js new file mode 100644 index 0000000000000..fea8f0001540a --- /dev/null +++ b/x-pack/legacy/plugins/monitoring/public/components/cluster/overview/__tests__/helpers.test.js @@ -0,0 +1,42 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React from 'react'; +import { renderWithIntl } from '../../../../../../../../test_utils/enzyme_helpers'; +import { BytesUsage, BytesPercentageUsage } from '../helpers'; + +describe('Bytes Usage', () => { + it('should format correctly with used and max bytes', () => { + const props = { + usedBytes: 50, + maxBytes: 100, + }; + expect(renderWithIntl()).toMatchSnapshot(); + }); + + it('should format correctly with only usedBytes', () => { + const props = { + usedBytes: 50, + }; + expect(renderWithIntl()).toMatchSnapshot(); + }); +}); + +describe('BytesPercentageUsage', () => { + it('should format correctly with used bytes and max bytes', () => { + const props = { + usedBytes: 50, + maxBytes: 100, + }; + expect(renderWithIntl()).toMatchSnapshot(); + }); + it('should return zero bytes if both parameters are not present', () => { + const props = { + usedBytes: 50, + }; + expect(renderWithIntl()).toMatchSnapshot(); + }); +}); diff --git a/x-pack/legacy/plugins/monitoring/public/components/cluster/overview/apm_panel.js b/x-pack/legacy/plugins/monitoring/public/components/cluster/overview/apm_panel.js index 3ba04359c2672..84dc13e9da1de 100644 --- a/x-pack/legacy/plugins/monitoring/public/components/cluster/overview/apm_panel.js +++ b/x-pack/legacy/plugins/monitoring/public/components/cluster/overview/apm_panel.js @@ -8,11 +8,7 @@ import React from 'react'; import moment from 'moment'; import { get } from 'lodash'; import { formatMetric } from 'plugins/monitoring/lib/format_number'; -import { - ClusterItemContainer, - BytesPercentageUsage, - DisabledIfNoDataAndInSetupModeLink, -} from './helpers'; +import { ClusterItemContainer, BytesUsage, DisabledIfNoDataAndInSetupModeLink } from './helpers'; import { FormattedMessage } from '@kbn/i18n/react'; import { i18n } from '@kbn/i18n'; import { @@ -153,7 +149,7 @@ export function ApmPanel(props) { /> - + diff --git a/x-pack/legacy/plugins/monitoring/public/components/cluster/overview/elasticsearch_panel.js b/x-pack/legacy/plugins/monitoring/public/components/cluster/overview/elasticsearch_panel.js index fc23110f940e8..7b08c89f53881 100644 --- a/x-pack/legacy/plugins/monitoring/public/components/cluster/overview/elasticsearch_panel.js +++ b/x-pack/legacy/plugins/monitoring/public/components/cluster/overview/elasticsearch_panel.js @@ -10,7 +10,6 @@ import { formatNumber } from 'plugins/monitoring/lib/format_number'; import { ClusterItemContainer, HealthStatusIndicator, - BytesUsage, BytesPercentageUsage, DisabledIfNoDataAndInSetupModeLink, } from './helpers'; @@ -291,7 +290,7 @@ export function ElasticsearchPanel(props) { /> - diff --git a/x-pack/legacy/plugins/monitoring/public/components/cluster/overview/helpers.js b/x-pack/legacy/plugins/monitoring/public/components/cluster/overview/helpers.js index ae7cc1b4e965c..0d9290225cd5f 100644 --- a/x-pack/legacy/plugins/monitoring/public/components/cluster/overview/helpers.js +++ b/x-pack/legacy/plugins/monitoring/public/components/cluster/overview/helpers.js @@ -6,7 +6,7 @@ import React from 'react'; import { get } from 'lodash'; -import { formatBytesUsage, formatPercentageUsage } from 'plugins/monitoring/lib/format_number'; +import { formatBytesUsage, formatPercentageUsage, formatNumber } from '../../../lib/format_number'; import { EuiSpacer, EuiFlexItem, @@ -88,10 +88,13 @@ export function BytesUsage({ usedBytes, maxBytes }) { if (usedBytes && maxBytes) { return ( - {formatPercentageUsage(usedBytes, maxBytes)} - - {formatBytesUsage(usedBytes, maxBytes)} - + {formatBytesUsage(usedBytes, maxBytes)} + + ); + } else if (usedBytes) { + return ( + + {formatNumber(usedBytes, 'byte')} ); } From 2d62ff2cbfb0bed6f5658e8dd39ef1207273ca46 Mon Sep 17 00:00:00 2001 From: Mikhail Shustov Date: Mon, 13 Jan 2020 15:04:06 +0100 Subject: [PATCH 021/139] [NP] Remove observables from es internal contract (#54556) * request context always uses the latest es client * update integration tests Co-authored-by: Elastic Machine --- .../elasticsearch_service.mock.ts | 2 - .../elasticsearch_service.test.ts | 40 +------------------ .../elasticsearch/elasticsearch_service.ts | 2 - src/core/server/elasticsearch/types.ts | 3 -- .../core_service.test.mocks.ts | 5 ++- .../integration_tests/core_services.test.ts | 22 ++++++---- src/core/server/server.ts | 8 +--- 7 files changed, 22 insertions(+), 60 deletions(-) diff --git a/src/core/server/elasticsearch/elasticsearch_service.mock.ts b/src/core/server/elasticsearch/elasticsearch_service.mock.ts index 1b52f22c4da09..a4e51ca55b3e7 100644 --- a/src/core/server/elasticsearch/elasticsearch_service.mock.ts +++ b/src/core/server/elasticsearch/elasticsearch_service.mock.ts @@ -74,8 +74,6 @@ const createInternalSetupContractMock = () => { legacy: { config$: new BehaviorSubject({} as ElasticsearchConfig), }, - adminClient$: new BehaviorSubject(createClusterClientMock()), - dataClient$: new BehaviorSubject(createClusterClientMock()), }; setupContract.adminClient.asScoped.mockReturnValue(createScopedClusterClientMock()); setupContract.dataClient.asScoped.mockReturnValue(createScopedClusterClientMock()); diff --git a/src/core/server/elasticsearch/elasticsearch_service.test.ts b/src/core/server/elasticsearch/elasticsearch_service.test.ts index 9f694ac1c46da..5a7d223fec7ad 100644 --- a/src/core/server/elasticsearch/elasticsearch_service.test.ts +++ b/src/core/server/elasticsearch/elasticsearch_service.test.ts @@ -21,7 +21,7 @@ import { first } from 'rxjs/operators'; import { MockClusterClient } from './elasticsearch_service.test.mocks'; -import { BehaviorSubject, combineLatest } from 'rxjs'; +import { BehaviorSubject } from 'rxjs'; import { Env } from '../config'; import { getEnvOptions } from '../config/__mocks__/env'; import { CoreContext } from '../core_context'; @@ -91,44 +91,6 @@ describe('#setup', () => { expect(mockDataClusterClientInstance.callAsInternalUser).toHaveBeenCalledTimes(1); }); - it('returns data and admin client observables as a part of the contract', async () => { - const mockAdminClusterClientInstance = { close: jest.fn() }; - const mockDataClusterClientInstance = { close: jest.fn() }; - MockClusterClient.mockImplementationOnce( - () => mockAdminClusterClientInstance - ).mockImplementationOnce(() => mockDataClusterClientInstance); - - const setupContract = await elasticsearchService.setup(deps); - - const [esConfig, adminClient, dataClient] = await combineLatest( - setupContract.legacy.config$, - setupContract.adminClient$, - setupContract.dataClient$ - ) - .pipe(first()) - .toPromise(); - - expect(adminClient).toBe(mockAdminClusterClientInstance); - expect(dataClient).toBe(mockDataClusterClientInstance); - - expect(MockClusterClient).toHaveBeenCalledTimes(2); - expect(MockClusterClient).toHaveBeenNthCalledWith( - 1, - esConfig, - expect.objectContaining({ context: ['elasticsearch', 'admin'] }), - undefined - ); - expect(MockClusterClient).toHaveBeenNthCalledWith( - 2, - esConfig, - expect.objectContaining({ context: ['elasticsearch', 'data'] }), - expect.any(Function) - ); - - expect(mockAdminClusterClientInstance.close).not.toHaveBeenCalled(); - expect(mockDataClusterClientInstance.close).not.toHaveBeenCalled(); - }); - describe('#createClient', () => { it('allows to specify config properties', async () => { const setupContract = await elasticsearchService.setup(deps); diff --git a/src/core/server/elasticsearch/elasticsearch_service.ts b/src/core/server/elasticsearch/elasticsearch_service.ts index db3fda3a504ab..aba246ce66fb5 100644 --- a/src/core/server/elasticsearch/elasticsearch_service.ts +++ b/src/core/server/elasticsearch/elasticsearch_service.ts @@ -152,8 +152,6 @@ export class ElasticsearchService implements CoreService clients.config)) }, - adminClient$, - dataClient$, adminClient, dataClient, diff --git a/src/core/server/elasticsearch/types.ts b/src/core/server/elasticsearch/types.ts index 22340bf3f2fc6..899b273c5c60a 100644 --- a/src/core/server/elasticsearch/types.ts +++ b/src/core/server/elasticsearch/types.ts @@ -77,7 +77,4 @@ export interface InternalElasticsearchServiceSetup extends ElasticsearchServiceS readonly legacy: { readonly config$: Observable; }; - - readonly adminClient$: Observable; - readonly dataClient$: Observable; } diff --git a/src/core/server/http/integration_tests/core_service.test.mocks.ts b/src/core/server/http/integration_tests/core_service.test.mocks.ts index 3982df567ed7c..6fa3357168027 100644 --- a/src/core/server/http/integration_tests/core_service.test.mocks.ts +++ b/src/core/server/http/integration_tests/core_service.test.mocks.ts @@ -16,8 +16,11 @@ * specific language governing permissions and limitations * under the License. */ +import { elasticsearchServiceMock } from '../../elasticsearch/elasticsearch_service.mock'; export const clusterClientMock = jest.fn(); jest.doMock('../../elasticsearch/scoped_cluster_client', () => ({ - ScopedClusterClient: clusterClientMock, + ScopedClusterClient: clusterClientMock.mockImplementation(function() { + return elasticsearchServiceMock.createScopedClusterClient(); + }), })); diff --git a/src/core/server/http/integration_tests/core_services.test.ts b/src/core/server/http/integration_tests/core_services.test.ts index f3867faa2ae75..65c4f1432721d 100644 --- a/src/core/server/http/integration_tests/core_services.test.ts +++ b/src/core/server/http/integration_tests/core_services.test.ts @@ -133,7 +133,7 @@ describe('http service', () => { const { http } = await root.setup(); const { registerAuth } = http; - await registerAuth((req, res, toolkit) => { + registerAuth((req, res, toolkit) => { return toolkit.authenticated({ responseHeaders: authResponseHeader }); }); @@ -157,7 +157,7 @@ describe('http service', () => { const { http } = await root.setup(); const { registerAuth } = http; - await registerAuth((req, res, toolkit) => { + registerAuth((req, res, toolkit) => { return toolkit.authenticated({ responseHeaders: authResponseHeader }); }); @@ -222,12 +222,15 @@ describe('http service', () => { const { http } = await root.setup(); const { registerAuth, createRouter } = http; - await registerAuth((req, res, toolkit) => - toolkit.authenticated({ requestHeaders: authHeaders }) - ); + registerAuth((req, res, toolkit) => toolkit.authenticated({ requestHeaders: authHeaders })); const router = createRouter('/new-platform'); - router.get({ path: '/', validate: false }, (context, req, res) => res.ok()); + router.get({ path: '/', validate: false }, async (context, req, res) => { + // it forces client initialization since the core creates them lazily. + await context.core.elasticsearch.adminClient.callAsCurrentUser('ping'); + await context.core.elasticsearch.dataClient.callAsCurrentUser('ping'); + return res.ok(); + }); await root.start(); @@ -247,7 +250,12 @@ describe('http service', () => { const { createRouter } = http; const router = createRouter('/new-platform'); - router.get({ path: '/', validate: false }, (context, req, res) => res.ok()); + router.get({ path: '/', validate: false }, async (context, req, res) => { + // it forces client initialization since the core creates them lazily. + await context.core.elasticsearch.adminClient.callAsCurrentUser('ping'); + await context.core.elasticsearch.dataClient.callAsCurrentUser('ping'); + return res.ok(); + }); await root.start(); diff --git a/src/core/server/server.ts b/src/core/server/server.ts index 611842e8a7de0..7c3f9f249db13 100644 --- a/src/core/server/server.ts +++ b/src/core/server/server.ts @@ -17,7 +17,6 @@ * under the License. */ -import { take } from 'rxjs/operators'; import { Type } from '@kbn/config-schema'; import { @@ -216,9 +215,6 @@ export class Server { coreId, 'core', async (context, req, res): Promise => { - // it consumes elasticsearch observables to provide the same client throughout the context lifetime. - const adminClient = await coreSetup.elasticsearch.adminClient$.pipe(take(1)).toPromise(); - const dataClient = await coreSetup.elasticsearch.dataClient$.pipe(take(1)).toPromise(); const savedObjectsClient = coreSetup.savedObjects.getScopedClient(req); const uiSettingsClient = coreSetup.uiSettings.asScopedToClient(savedObjectsClient); @@ -230,8 +226,8 @@ export class Server { client: savedObjectsClient, }, elasticsearch: { - adminClient: adminClient.asScoped(req), - dataClient: dataClient.asScoped(req), + adminClient: coreSetup.elasticsearch.adminClient.asScoped(req), + dataClient: coreSetup.elasticsearch.dataClient.asScoped(req), }, uiSettings: { client: uiSettingsClient, From ebd2c2190bdcfbbf1eb530f310b5458877d2805a Mon Sep 17 00:00:00 2001 From: Liza Katz Date: Mon, 13 Jan 2020 16:26:33 +0200 Subject: [PATCH 022/139] Management advanced settings telemetry (#54369) * management telemetry * Use getUserProvided --- .../telemetry/common/constants.ts | 6 ++ .../telemetry/server/collectors/index.ts | 1 + .../server/collectors/management/index.ts | 20 ++++++ .../telemetry_management_collector.ts | 63 +++++++++++++++++++ .../core_plugins/telemetry/server/plugin.ts | 2 + 5 files changed, 92 insertions(+) create mode 100644 src/legacy/core_plugins/telemetry/server/collectors/management/index.ts create mode 100644 src/legacy/core_plugins/telemetry/server/collectors/management/telemetry_management_collector.ts diff --git a/src/legacy/core_plugins/telemetry/common/constants.ts b/src/legacy/core_plugins/telemetry/common/constants.ts index 7e366676a8565..cb4ff79969a32 100644 --- a/src/legacy/core_plugins/telemetry/common/constants.ts +++ b/src/legacy/core_plugins/telemetry/common/constants.ts @@ -75,3 +75,9 @@ export const UI_METRIC_USAGE_TYPE = 'ui_metric'; * Link to Advanced Settings. */ export const PATH_TO_ADVANCED_SETTINGS = 'kibana#/management/kibana/settings'; + +/** + * The type name used within the Monitoring index to publish management stats. + * @type {string} + */ +export const KIBANA_MANAGEMENT_STATS_TYPE = 'management'; diff --git a/src/legacy/core_plugins/telemetry/server/collectors/index.ts b/src/legacy/core_plugins/telemetry/server/collectors/index.ts index 2f2a53278117b..04ee4773cd60d 100644 --- a/src/legacy/core_plugins/telemetry/server/collectors/index.ts +++ b/src/legacy/core_plugins/telemetry/server/collectors/index.ts @@ -22,3 +22,4 @@ export { registerTelemetryUsageCollector } from './usage'; export { registerUiMetricUsageCollector } from './ui_metric'; export { registerLocalizationUsageCollector } from './localization'; export { registerTelemetryPluginUsageCollector } from './telemetry_plugin'; +export { registerManagementUsageCollector } from './management'; diff --git a/src/legacy/core_plugins/telemetry/server/collectors/management/index.ts b/src/legacy/core_plugins/telemetry/server/collectors/management/index.ts new file mode 100644 index 0000000000000..979bbed3765e2 --- /dev/null +++ b/src/legacy/core_plugins/telemetry/server/collectors/management/index.ts @@ -0,0 +1,20 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +export { registerManagementUsageCollector } from './telemetry_management_collector'; diff --git a/src/legacy/core_plugins/telemetry/server/collectors/management/telemetry_management_collector.ts b/src/legacy/core_plugins/telemetry/server/collectors/management/telemetry_management_collector.ts new file mode 100644 index 0000000000000..f45cf7fc6bb33 --- /dev/null +++ b/src/legacy/core_plugins/telemetry/server/collectors/management/telemetry_management_collector.ts @@ -0,0 +1,63 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +import { Server } from 'hapi'; +import { size } from 'lodash'; +import { KIBANA_MANAGEMENT_STATS_TYPE } from '../../../common/constants'; +import { UsageCollectionSetup } from '../../../../../../plugins/usage_collection/server'; +import { SavedObjectsClient } from '../../../../../../core/server'; + +export type UsageStats = Record; + +export async function getTranslationCount(loader: any, locale: string): Promise { + const translations = await loader.getTranslationsByLocale(locale); + return size(translations.messages); +} + +export function createCollectorFetch(server: Server) { + return async function fetchUsageStats(): Promise { + const internalRepo = server.newPlatform.setup.core.savedObjects.createInternalRepository(); + const uiSettingsClient = server.newPlatform.start.core.uiSettings.asScopedToClient( + new SavedObjectsClient(internalRepo) + ); + + const user = await uiSettingsClient.getUserProvided(); + const modifiedEntries = Object.keys(user) + .filter((key: string) => key !== 'buildNum') + .reduce((obj: any, key: string) => { + obj[key] = user[key].userValue; + return obj; + }, {}); + + return modifiedEntries; + }; +} + +export function registerManagementUsageCollector( + usageCollection: UsageCollectionSetup, + server: any +) { + const collector = usageCollection.makeUsageCollector({ + type: KIBANA_MANAGEMENT_STATS_TYPE, + isReady: () => true, + fetch: createCollectorFetch(server), + }); + + usageCollection.registerCollector(collector); +} diff --git a/src/legacy/core_plugins/telemetry/server/plugin.ts b/src/legacy/core_plugins/telemetry/server/plugin.ts index 06a974f473498..b5b53b1daba55 100644 --- a/src/legacy/core_plugins/telemetry/server/plugin.ts +++ b/src/legacy/core_plugins/telemetry/server/plugin.ts @@ -27,6 +27,7 @@ import { registerTelemetryUsageCollector, registerLocalizationUsageCollector, registerTelemetryPluginUsageCollector, + registerManagementUsageCollector, } from './collectors'; export interface PluginsSetup { @@ -50,5 +51,6 @@ export class TelemetryPlugin { registerLocalizationUsageCollector(usageCollection, server); registerTelemetryUsageCollector(usageCollection, server); registerUiMetricUsageCollector(usageCollection, server); + registerManagementUsageCollector(usageCollection, server); } } From 2b863f7818efb76f3336e4efb930ebcf30a455ab Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Mon, 13 Jan 2020 09:27:57 -0500 Subject: [PATCH 023/139] initial feedback --- .../styles/vector/components/color/color_palette_select.js | 3 +-- .../styles/vector/components/color/color_stops_categorical.js | 4 ++-- 2 files changed, 3 insertions(+), 4 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_palette_select.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_palette_select.js index 5238dda1a1dca..32b23409a3865 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_palette_select.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_palette_select.js @@ -33,8 +33,7 @@ const colorPaletteInputs = COLOR_PALETTES.map(palette => { height: '100%', display: 'inline-block', }; - // eslint-disable-next-line react/no-danger - return
; + return
 
; }); return { value: palette.id, diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js index aff3a7f0d03db..b110361e108bf 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js @@ -56,9 +56,9 @@ export const ColorStopsCategorical = ({ )} value={stop} placeholder={i18n.translate( - 'xpack.maps.styles.colorStops.categoricalStop.defaultCategoryPlaceholder', + 'xpack.maps.styles.colorStops.categoricalStop.otherCategoryPlaceholder', { - defaultMessage: 'Default', + defaultMessage: 'Other', } )} disabled From 0c0e5a690ebc4ce1367332335b3062250cd0a96b Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Mon, 13 Jan 2020 09:47:56 -0500 Subject: [PATCH 024/139] add ip fields --- .../legacy/plugins/maps/common/constants.js | 2 ++ .../plugins/maps/public/layers/layer.js | 2 +- .../es_search_source/es_search_source.js | 13 ++++++++--- .../public/layers/sources/vector_source.js | 2 +- .../components/color/dynamic_color_form.js | 7 +++--- .../vector/components/vector_style_editor.js | 22 +++++++++---------- .../maps/public/layers/vector_layer.js | 4 ++-- 7 files changed, 31 insertions(+), 21 deletions(-) diff --git a/x-pack/legacy/plugins/maps/common/constants.js b/x-pack/legacy/plugins/maps/common/constants.js index ab8b853377b3b..b3cefbf5c0b41 100644 --- a/x-pack/legacy/plugins/maps/common/constants.js +++ b/x-pack/legacy/plugins/maps/common/constants.js @@ -147,3 +147,5 @@ export const COLOR_MAP_TYPE = { }; export const COLOR_PALETTE_MAX_SIZE = 10; + +export const CATEGORICAL_DATA_TYPES = ['string', 'ip', 'boolean']; diff --git a/x-pack/legacy/plugins/maps/public/layers/layer.js b/x-pack/legacy/plugins/maps/public/layers/layer.js index 80da9555b384e..09475e638de55 100644 --- a/x-pack/legacy/plugins/maps/public/layers/layer.js +++ b/x-pack/legacy/plugins/maps/public/layers/layer.js @@ -344,7 +344,7 @@ export class AbstractLayer { return []; } - async getStringFields() { + async getCategoricalFields() { return []; } diff --git a/x-pack/legacy/plugins/maps/public/layers/sources/es_search_source/es_search_source.js b/x-pack/legacy/plugins/maps/public/layers/sources/es_search_source/es_search_source.js index 39015f85ce875..b8644adddcf7e 100644 --- a/x-pack/legacy/plugins/maps/public/layers/sources/es_search_source/es_search_source.js +++ b/x-pack/legacy/plugins/maps/public/layers/sources/es_search_source/es_search_source.js @@ -19,6 +19,7 @@ import { ES_GEO_FIELD_TYPE, DEFAULT_MAX_BUCKETS_LIMIT, SORT_ORDER, + CATEGORICAL_DATA_TYPES, } from '../../../../common/constants'; import { i18n } from '@kbn/i18n'; import { getDataSourceLabel } from '../../../../common/i18n_getters'; @@ -125,11 +126,17 @@ export class ESSearchSource extends AbstractESSource { } } - async getStringFields() { + async getCategoricalFields() { try { const indexPattern = await this.getIndexPattern(); - const aggFields = indexPattern.fields.getByType('string').filter(field => { - return field.aggregatable; + + const aggFields = []; + CATEGORICAL_DATA_TYPES.forEach(dataType => { + indexPattern.fields.getByType(dataType).forEach(field => { + if (field.aggregatable) { + aggFields.push(field); + } + }); }); return aggFields.map(field => { return this.createField({ fieldName: field.name }); diff --git a/x-pack/legacy/plugins/maps/public/layers/sources/vector_source.js b/x-pack/legacy/plugins/maps/public/layers/sources/vector_source.js index 0dec50d77dd70..b9d8ae86c5850 100644 --- a/x-pack/legacy/plugins/maps/public/layers/sources/vector_source.js +++ b/x-pack/legacy/plugins/maps/public/layers/sources/vector_source.js @@ -107,7 +107,7 @@ export class AbstractVectorSource extends AbstractSource { return [...(await this.getDateFields()), ...(await this.getNumberFields())]; } - async getStringFields() { + async getCategoricalFields() { return []; } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js index 71a192d93dbaa..208adfa36bddb 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js @@ -10,7 +10,7 @@ import { FieldSelect } from '../field_select'; import { ColorRampSelect } from './color_ramp_select'; import { ColorPaletteSelect } from './color_palette_select'; import { EuiFlexGroup, EuiFlexItem, EuiSpacer } from '@elastic/eui'; -import { COLOR_MAP_TYPE } from '../../../../../../common/constants'; +import { CATEGORICAL_DATA_TYPES, COLOR_MAP_TYPE } from '../../../../../../common/constants'; import { OrdinalFieldMetaOptionsPopover } from '../ordinal_field_meta_options_popover'; export class DynamicColorForm extends React.Component { @@ -42,8 +42,9 @@ export class DynamicColorForm extends React.Component { return; } const dataType = await field.getDataType(); - const colorMapType = - dataType === 'string' ? COLOR_MAP_TYPE.CATEGORICAL : COLOR_MAP_TYPE.ORDINAL; + const colorMapType = CATEGORICAL_DATA_TYPES.includes(dataType) + ? COLOR_MAP_TYPE.CATEGORICAL + : COLOR_MAP_TYPE.ORDINAL; if (this._isMounted && this.state.colorMapType !== colorMapType) { this.setState({ colorMapType }); } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/vector_style_editor.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/vector_style_editor.js index 83f081b7e3a10..a80fc5edd80c3 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/vector_style_editor.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/vector_style_editor.js @@ -31,7 +31,7 @@ export class VectorStyleEditor extends Component { state = { dateFields: [], numberFields: [], - stringFields: [], + categoricalFields: [], fields: [], defaultDynamicProperties: getDefaultDynamicProperties(), defaultStaticProperties: getDefaultStaticProperties(), @@ -77,11 +77,11 @@ export class VectorStyleEditor extends Component { this.setState({ numberFields: numberFieldsArray }); } - const stringFields = await this.props.layer.getStringFields(); - const stringFieldPromises = stringFields.map(getFieldMeta); - const stringFieldsArray = await Promise.all(stringFieldPromises); - if (this._isMounted && !_.isEqual(stringFieldsArray, this.state.stringFields)) { - this.setState({ stringFields: stringFieldsArray }); + const categoricalFields = await this.props.layer.getCategoricalFields(); + const categoricalFieldMeta = categoricalFields.map(getFieldMeta); + const categoricalFieldsArray = await Promise.all(categoricalFieldMeta); + if (this._isMounted && !_.isEqual(categoricalFieldsArray, this.state.categoricalFields)) { + this.setState({ categoricalFields: categoricalFieldsArray }); } const fields = await this.props.layer.getFields(); @@ -117,8 +117,8 @@ export class VectorStyleEditor extends Component { return [...this.state.dateFields, ...this.state.numberFields]; } - _getOrdinalAndStringFields() { - return [...this.state.dateFields, ...this.state.numberFields, ...this.state.stringFields]; + _getOrdinalAndCategoricalFields() { + return [...this.state.dateFields, ...this.state.numberFields, ...this.state.categoricalFields]; } _handleSelectedFeatureChange = selectedFeature => { @@ -152,7 +152,7 @@ export class VectorStyleEditor extends Component { onStaticStyleChange={this._onStaticStyleChange} onDynamicStyleChange={this._onDynamicStyleChange} styleProperty={this.props.styleProperties[VECTOR_STYLES.FILL_COLOR]} - fields={this._getOrdinalAndStringFields()} + fields={this._getOrdinalAndCategoricalFields()} defaultStaticStyleOptions={ this.state.defaultStaticProperties[VECTOR_STYLES.FILL_COLOR].options } @@ -170,7 +170,7 @@ export class VectorStyleEditor extends Component { onStaticStyleChange={this._onStaticStyleChange} onDynamicStyleChange={this._onDynamicStyleChange} styleProperty={this.props.styleProperties[VECTOR_STYLES.LINE_COLOR]} - fields={this._getOrdinalAndStringFields()} + fields={this._getOrdinalAndCategoricalFields()} defaultStaticStyleOptions={ this.state.defaultStaticProperties[VECTOR_STYLES.LINE_COLOR].options } @@ -237,7 +237,7 @@ export class VectorStyleEditor extends Component { onStaticStyleChange={this._onStaticStyleChange} onDynamicStyleChange={this._onDynamicStyleChange} styleProperty={this.props.styleProperties[VECTOR_STYLES.LABEL_COLOR]} - fields={this._getOrdinalAndStringFields()} + fields={this._getOrdinalAndCategoricalFields()} defaultStaticStyleOptions={ this.state.defaultStaticProperties[VECTOR_STYLES.LABEL_COLOR].options } diff --git a/x-pack/legacy/plugins/maps/public/layers/vector_layer.js b/x-pack/legacy/plugins/maps/public/layers/vector_layer.js index 54618dc8d5b44..96223aa536170 100644 --- a/x-pack/legacy/plugins/maps/public/layers/vector_layer.js +++ b/x-pack/legacy/plugins/maps/public/layers/vector_layer.js @@ -213,8 +213,8 @@ export class VectorLayer extends AbstractLayer { return [...(await this.getDateFields()), ...(await this.getNumberFields())]; } - async getStringFields() { - return await this._source.getStringFields(); + async getCategoricalFields() { + return await this._source.getCategoricalFields(); } async getFields() { From 641c67091f8bc30e557fdd5a7dcf7b117dcc677e Mon Sep 17 00:00:00 2001 From: Frank Hassanabad Date: Mon, 13 Jan 2020 08:09:55 -0700 Subject: [PATCH 025/139] [SEIM][Detection Engine] Time gap detection and logging ## Summary This adds utilities and logging of time gap detection. Gaps happen whenever rules begin to fall behind their interval. This isn't a perfect works for all inputs and if it detects unexpected input that is not of an interval format (but could be valid date time math) it will just return null and ignore it. This also fixes a bug with interval where we were using the object instead of the primitive since alerting team changed their structure. For testing, fire up any rule and shutdown Kibana for more than 6 minutes and then when restarting you should see the warning message. ### Checklist Use ~~strikethroughs~~ to remove checklist items you don't feel are applicable to this PR. ~~- [ ] This was checked for cross-browser compatibility, [including a check against IE11](https://github.com/elastic/kibana/blob/master/CONTRIBUTING.md#cross-browser-compatibility)~~ ~~- [ ] Any text added follows [EUI's writing guidelines](https://elastic.github.io/eui/#/guidelines/writing), uses sentence case text and includes [i18n support](https://github.com/elastic/kibana/blob/master/packages/kbn-i18n/README.md)~~ ~~- [ ] [Documentation](https://github.com/elastic/kibana/blob/master/CONTRIBUTING.md#writing-documentation) was added for features that require explanation or tutorials~~ - [x] [Unit or functional tests](https://github.com/elastic/kibana/blob/master/CONTRIBUTING.md#cross-browser-compatibility) were updated or added to match the most common scenarios ~~- [ ] This was checked for [keyboard-only and screenreader accessibility](https://developer.mozilla.org/en-US/docs/Learn/Tools_and_testing/Cross_browser_testing/Accessibility#Accessibility_testing_checklist)~~ ### For maintainers ~~- [ ] This was checked for breaking API changes and was [labeled appropriately](https://github.com/elastic/kibana/blob/master/CONTRIBUTING.md#release-notes-process)~~ - [x] This includes a feature addition or change that requires a release note and was [labeled appropriately](https://github.com/elastic/kibana/blob/master/CONTRIBUTING.md#release-notes-process) --- .../signals/signal_rule_alert_type.ts | 22 +- .../detection_engine/signals/utils.test.ts | 258 ++++++++++++++++++ .../lib/detection_engine/signals/utils.ts | 66 +++++ 3 files changed, 341 insertions(+), 5 deletions(-) create mode 100644 x-pack/legacy/plugins/siem/server/lib/detection_engine/signals/utils.test.ts diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/signals/signal_rule_alert_type.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/signals/signal_rule_alert_type.ts index ab2c1733b04ca..774afb6d7deb0 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/signals/signal_rule_alert_type.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/signals/signal_rule_alert_type.ts @@ -6,6 +6,7 @@ import { schema } from '@kbn/config-schema'; import { Logger } from 'src/core/server'; +import moment from 'moment'; import { SIGNALS_ID, DEFAULT_MAX_SIGNALS, @@ -17,6 +18,7 @@ import { getInputIndex } from './get_input_output_index'; import { searchAfterAndBulkCreate } from './search_after_bulk_create'; import { getFilter } from './get_filter'; import { SignalRuleAlertTypeDefinition } from './types'; +import { getGapBetweenRuns } from './utils'; export const signalRulesAlertType = ({ logger, @@ -57,7 +59,8 @@ export const signalRulesAlertType = ({ version: schema.number({ defaultValue: 1 }), }), }, - async executor({ alertId, services, params }) { + // fun fact: previousStartedAt is not actually a Date but a String of a date + async executor({ previousStartedAt, alertId, services, params }) { const { from, ruleId, @@ -70,7 +73,6 @@ export const signalRulesAlertType = ({ to, type, } = params; - // TODO: Remove this hard extraction of name once this is fixed: https://github.com/elastic/kibana/issues/50522 const savedObject = await services.savedObjectsClient.get('alert', alertId); const name: string = savedObject.attributes.name; @@ -78,9 +80,19 @@ export const signalRulesAlertType = ({ const createdBy: string = savedObject.attributes.createdBy; const updatedBy: string = savedObject.attributes.updatedBy; - const interval: string = savedObject.attributes.interval; + const interval: string = savedObject.attributes.schedule.interval; const enabled: boolean = savedObject.attributes.enabled; - + const gap = getGapBetweenRuns({ + previousStartedAt: previousStartedAt != null ? moment(previousStartedAt) : null, // TODO: Remove this once previousStartedAt is no longer a string + interval, + from, + to, + }); + if (gap != null && gap.asMilliseconds() > 0) { + logger.warn( + `Signal rule name: "${name}", id: "${alertId}", rule_id: "${ruleId}" has a time gap of ${gap.humanize()} (${gap.asMilliseconds()}ms), and could be missing signals within that time. Consider increasing your look behind time or adding more Kibana instances.` + ); + } // set searchAfter page size to be the lesser of default page size or maxSignals. const searchAfterSize = DEFAULT_SEARCH_AFTER_PAGE_SIZE <= params.maxSignals @@ -155,7 +167,7 @@ export const signalRulesAlertType = ({ // TODO: Error handling and writing of errors into a signal that has error // handling/conditions logger.error( - `Error from signal rule name: "${name}", id: "${alertId}", rule_id: "${ruleId}"` + `Error from signal rule name: "${name}", id: "${alertId}", rule_id: "${ruleId}" message: ${err.message}` ); } }, diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/signals/utils.test.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/signals/utils.test.ts new file mode 100644 index 0000000000000..d6a3da5a393f8 --- /dev/null +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/signals/utils.test.ts @@ -0,0 +1,258 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import moment from 'moment'; + +import { generateId, parseInterval, getDriftTolerance, getGapBetweenRuns } from './utils'; + +describe('utils', () => { + let nowDate = moment('2020-01-01T00:00:00.000Z'); + + beforeEach(() => { + nowDate = moment('2020-01-01T00:00:00.000Z'); + }); + + describe('generateId', () => { + test('it generates expected output', () => { + const id = generateId('index-123', 'doc-123', 'version-123', 'rule-123'); + expect(id).toEqual('10622e7d06c9e38a532e71fc90e3426c1100001fb617aec8cb974075da52db06'); + }); + + test('expected output is a hex', () => { + const id = generateId('index-123', 'doc-123', 'version-123', 'rule-123'); + expect(id).toMatch(/[a-f0-9]+/); + }); + }); + + describe('getIntervalMilliseconds', () => { + test('it returns a duration when given one that is valid', () => { + const duration = parseInterval('5m'); + expect(duration).not.toBeNull(); + expect(duration?.asMilliseconds()).toEqual(moment.duration(5, 'minutes').asMilliseconds()); + }); + + test('it returns null given an invalid duration', () => { + const duration = parseInterval('junk'); + expect(duration).toBeNull(); + }); + }); + + describe('getDriftToleranceMilliseconds', () => { + test('it returns a drift tolerance in milliseconds of 1 minute when from overlaps to by 1 minute and the interval is 5 minutes', () => { + const drift = getDriftTolerance({ + from: 'now-6m', + to: 'now', + interval: moment.duration(5, 'minutes'), + }); + expect(drift).not.toBeNull(); + expect(drift?.asMilliseconds()).toEqual(moment.duration(1, 'minute').asMilliseconds()); + }); + + test('it returns a drift tolerance of 0 when from equals the interval', () => { + const drift = getDriftTolerance({ + from: 'now-5m', + to: 'now', + interval: moment.duration(5, 'minutes'), + }); + expect(drift?.asMilliseconds()).toEqual(0); + }); + + test('it returns a drift tolerance of 5 minutes when from is 10 minutes but the interval is 5 minutes', () => { + const drift = getDriftTolerance({ + from: 'now-10m', + to: 'now', + interval: moment.duration(5, 'minutes'), + }); + expect(drift).not.toBeNull(); + expect(drift?.asMilliseconds()).toEqual(moment.duration(5, 'minutes').asMilliseconds()); + }); + + test('it returns a drift tolerance of 10 minutes when from is 10 minutes ago and the interval is 0', () => { + const drift = getDriftTolerance({ + from: 'now-10m', + to: 'now', + interval: moment.duration(0, 'milliseconds'), + }); + expect(drift).not.toBeNull(); + expect(drift?.asMilliseconds()).toEqual(moment.duration(10, 'minutes').asMilliseconds()); + }); + + test('returns null if the "to" is not "now" since we have limited support for date math', () => { + const drift = getDriftTolerance({ + from: 'now-6m', + to: 'invalid', // if not set to "now" this function returns null + interval: moment.duration(1000, 'milliseconds'), + }); + expect(drift).toBeNull(); + }); + + test('returns null if the "from" does not start with "now-" since we have limited support for date math', () => { + const drift = getDriftTolerance({ + from: 'valid', // if not set to "now-x" where x is an interval such as 6m + to: 'now', + interval: moment.duration(1000, 'milliseconds'), + }); + expect(drift).toBeNull(); + }); + + test('returns null if the "from" starts with "now-" but has a string instead of an integer', () => { + const drift = getDriftTolerance({ + from: 'now-dfdf', // if not set to "now-x" where x is an interval such as 6m + to: 'now', + interval: moment.duration(1000, 'milliseconds'), + }); + expect(drift).toBeNull(); + }); + }); + + describe('getGapBetweenRuns', () => { + test('it returns a gap of 0 when from and interval match each other and the previous started was from the previous interval time', () => { + const gap = getGapBetweenRuns({ + previousStartedAt: nowDate.clone().subtract(5, 'minutes'), + interval: '5m', + from: 'now-5m', + to: 'now', + now: nowDate.clone(), + }); + expect(gap).not.toBeNull(); + expect(gap?.asMilliseconds()).toEqual(0); + }); + + test('it returns a negative gap of 1 minute when from overlaps to by 1 minute and the previousStartedAt was 5 minutes ago', () => { + const gap = getGapBetweenRuns({ + previousStartedAt: nowDate.clone().subtract(5, 'minutes'), + interval: '5m', + from: 'now-6m', + to: 'now', + now: nowDate.clone(), + }); + expect(gap).not.toBeNull(); + expect(gap?.asMilliseconds()).toEqual(moment.duration(-1, 'minute').asMilliseconds()); + }); + + test('it returns a negative gap of 5 minutes when from overlaps to by 1 minute and the previousStartedAt was 5 minutes ago', () => { + const gap = getGapBetweenRuns({ + previousStartedAt: nowDate.clone().subtract(5, 'minutes'), + interval: '5m', + from: 'now-10m', + to: 'now', + now: nowDate.clone(), + }); + expect(gap).not.toBeNull(); + expect(gap?.asMilliseconds()).toEqual(moment.duration(-5, 'minute').asMilliseconds()); + }); + + test('it returns a negative gap of 1 minute when from overlaps to by 1 minute and the previousStartedAt was 10 minutes ago and so was the interval', () => { + const gap = getGapBetweenRuns({ + previousStartedAt: nowDate.clone().subtract(10, 'minutes'), + interval: '10m', + from: 'now-11m', + to: 'now', + now: nowDate.clone(), + }); + expect(gap).not.toBeNull(); + expect(gap?.asMilliseconds()).toEqual(moment.duration(-1, 'minute').asMilliseconds()); + }); + + test('it returns a gap of only -30 seconds when the from overlaps with now by 1 minute, the interval is 5 minutes but the previous started is 30 seconds more', () => { + const gap = getGapBetweenRuns({ + previousStartedAt: nowDate + .clone() + .subtract(5, 'minutes') + .subtract(30, 'seconds'), + interval: '5m', + from: 'now-6m', + to: 'now', + now: nowDate.clone(), + }); + expect(gap).not.toBeNull(); + expect(gap?.asMilliseconds()).toEqual(moment.duration(-30, 'seconds').asMilliseconds()); + }); + + test('it returns an exact 0 gap when the from overlaps with now by 1 minute, the interval is 5 minutes but the previous started is one minute late', () => { + const gap = getGapBetweenRuns({ + previousStartedAt: nowDate.clone().subtract(6, 'minutes'), + interval: '5m', + from: 'now-6m', + to: 'now', + now: nowDate.clone(), + }); + expect(gap).not.toBeNull(); + expect(gap?.asMilliseconds()).toEqual(moment.duration(0, 'minute').asMilliseconds()); + }); + + test('it returns a gap of 30 seconds when the from overlaps with now by 1 minute, the interval is 5 minutes but the previous started is one minute and 30 seconds late', () => { + const gap = getGapBetweenRuns({ + previousStartedAt: nowDate + .clone() + .subtract(6, 'minutes') + .subtract(30, 'seconds'), + interval: '5m', + from: 'now-6m', + to: 'now', + now: nowDate.clone(), + }); + expect(gap).not.toBeNull(); + expect(gap?.asMilliseconds()).toEqual(moment.duration(30, 'seconds').asMilliseconds()); + }); + + test('it returns a gap of 1 minute when the from overlaps with now by 1 minute, the interval is 5 minutes but the previous started is two minutes late', () => { + const gap = getGapBetweenRuns({ + previousStartedAt: nowDate.clone().subtract(7, 'minutes'), + interval: '5m', + from: 'now-6m', + to: 'now', + now: nowDate.clone(), + }); + expect(gap?.asMilliseconds()).not.toBeNull(); + expect(gap?.asMilliseconds()).toEqual(moment.duration(1, 'minute').asMilliseconds()); + }); + + test('it returns null if given a previousStartedAt of null', () => { + const gap = getGapBetweenRuns({ + previousStartedAt: null, + interval: '5m', + from: 'now-5m', + to: 'now', + now: nowDate.clone(), + }); + expect(gap).toBeNull(); + }); + + test('it returns null if the interval is an invalid string such as "invalid"', () => { + const gap = getGapBetweenRuns({ + previousStartedAt: nowDate.clone(), + interval: 'invalid', // if not set to "x" where x is an interval such as 6m + from: 'now-5m', + to: 'now', + now: nowDate.clone(), + }); + expect(gap).toBeNull(); + }); + + test('it returns null if from is an invalid string such as "invalid"', () => { + const gap = getGapBetweenRuns({ + previousStartedAt: nowDate.clone(), + interval: '5m', + from: 'invalid', // if not set to "now-x" where x is an interval such as 6m + to: 'now', + now: nowDate.clone(), + }); + expect(gap).toBeNull(); + }); + + test('it returns null if to is an invalid string such as "invalid"', () => { + const gap = getGapBetweenRuns({ + previousStartedAt: nowDate.clone(), + interval: '5m', + from: 'now-5m', + to: 'invalid', // if not set to "now" this function returns null + now: nowDate.clone(), + }); + expect(gap).toBeNull(); + }); + }); +}); diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/signals/utils.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/signals/utils.ts index f25ce1d905466..5a4c67ebaaa36 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/signals/utils.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/signals/utils.ts @@ -4,6 +4,9 @@ * you may not use this file except in compliance with the Elastic License. */ import { createHash } from 'crypto'; +import moment from 'moment'; + +import { parseDuration } from '../../../../../alerting/server/lib'; export const generateId = ( docIndex: string, @@ -14,3 +17,66 @@ export const generateId = ( createHash('sha256') .update(docIndex.concat(docId, version, ruleId)) .digest('hex'); + +export const parseInterval = (intervalString: string): moment.Duration | null => { + try { + return moment.duration(parseDuration(intervalString)); + } catch (err) { + return null; + } +}; + +export const getDriftTolerance = ({ + from, + to, + interval, +}: { + from: string; + to: string; + interval: moment.Duration; +}): moment.Duration | null => { + if (to.trim() !== 'now') { + // we only support 'now' for drift detection + return null; + } + if (!from.trim().startsWith('now-')) { + // we only support from tha starts with now for drift detection + return null; + } + const split = from.split('-'); + const duration = parseInterval(split[1]); + if (duration !== null) { + return duration.subtract(interval); + } else { + return null; + } +}; + +export const getGapBetweenRuns = ({ + previousStartedAt, + interval, + from, + to, + now = moment(), +}: { + previousStartedAt: moment.Moment | undefined | null; + interval: string; + from: string; + to: string; + now?: moment.Moment; +}): moment.Duration | null => { + if (previousStartedAt == null) { + return null; + } + const intervalDuration = parseInterval(interval); + if (intervalDuration == null) { + return null; + } + const driftTolerance = getDriftTolerance({ from, to, interval: intervalDuration }); + if (driftTolerance == null) { + return null; + } + const diff = moment.duration(now.diff(previousStartedAt)); + const drift = diff.subtract(intervalDuration); + return drift.subtract(driftTolerance); +}; From ea4a1ac12c03f3f312a0c734acb9e73da4d4266e Mon Sep 17 00:00:00 2001 From: Brandon Kobel Date: Mon, 13 Jan 2020 07:21:24 -0800 Subject: [PATCH 026/139] Fixing the spaces header aria-controls a11y issue (#54512) * Fixing the spaces header aria-controls a11y issue * Updating snapshots Co-authored-by: Elastic Machine --- .../__snapshots__/nav_control_popover.test.tsx.snap | 3 ++- .../__snapshots__/spaces_description.test.tsx.snap | 1 + .../nav_control/components/spaces_description.test.tsx | 1 + .../public/nav_control/components/spaces_description.tsx | 2 ++ .../spaces/public/nav_control/components/spaces_menu.tsx | 2 ++ .../spaces/public/nav_control/nav_control_popover.tsx | 6 +++++- 6 files changed, 13 insertions(+), 2 deletions(-) diff --git a/x-pack/legacy/plugins/spaces/public/nav_control/__snapshots__/nav_control_popover.test.tsx.snap b/x-pack/legacy/plugins/spaces/public/nav_control/__snapshots__/nav_control_popover.test.tsx.snap index 5cad4e794cfda..45daa03e94c2e 100644 --- a/x-pack/legacy/plugins/spaces/public/nav_control/__snapshots__/nav_control_popover.test.tsx.snap +++ b/x-pack/legacy/plugins/spaces/public/nav_control/__snapshots__/nav_control_popover.test.tsx.snap @@ -5,7 +5,7 @@ exports[`NavControlPopover renders without crashing 1`] = ` anchorPosition="downRight" button={ diff --git a/x-pack/legacy/plugins/spaces/public/nav_control/components/__snapshots__/spaces_description.test.tsx.snap b/x-pack/legacy/plugins/spaces/public/nav_control/components/__snapshots__/spaces_description.test.tsx.snap index 079dab701cc1d..8e78f64ac59cb 100644 --- a/x-pack/legacy/plugins/spaces/public/nav_control/components/__snapshots__/spaces_description.test.tsx.snap +++ b/x-pack/legacy/plugins/spaces/public/nav_control/components/__snapshots__/spaces_description.test.tsx.snap @@ -4,6 +4,7 @@ exports[`SpacesDescription renders without crashing 1`] = ` diff --git a/x-pack/legacy/plugins/spaces/public/nav_control/components/spaces_description.test.tsx b/x-pack/legacy/plugins/spaces/public/nav_control/components/spaces_description.test.tsx index aacf3845e0e0f..157dcab3e0be1 100644 --- a/x-pack/legacy/plugins/spaces/public/nav_control/components/spaces_description.test.tsx +++ b/x-pack/legacy/plugins/spaces/public/nav_control/components/spaces_description.test.tsx @@ -13,6 +13,7 @@ describe('SpacesDescription', () => { expect( shallow( void; capabilities: Capabilities; } export const SpacesDescription: FC = (props: Props) => { const panelProps = { + id: props.id, className: 'spcDescription', title: 'Spaces', }; diff --git a/x-pack/legacy/plugins/spaces/public/nav_control/components/spaces_menu.tsx b/x-pack/legacy/plugins/spaces/public/nav_control/components/spaces_menu.tsx index 96ce18896b426..4d89f57d4ccf1 100644 --- a/x-pack/legacy/plugins/spaces/public/nav_control/components/spaces_menu.tsx +++ b/x-pack/legacy/plugins/spaces/public/nav_control/components/spaces_menu.tsx @@ -20,6 +20,7 @@ import { ManageSpacesButton } from './manage_spaces_button'; import { SpaceAvatar } from '../../space_avatar'; interface Props { + id: string; spaces: Space[]; isLoading: boolean; onSelectSpace: (space: Space) => void; @@ -48,6 +49,7 @@ class SpacesMenuUI extends Component { : this.getVisibleSpaces(searchTerm).map(this.renderSpaceMenuItem); const panelProps = { + id: this.props.id, className: 'spcMenu', title: intl.formatMessage({ id: 'xpack.spaces.navControl.spacesMenu.changeCurrentSpaceTitle', diff --git a/x-pack/legacy/plugins/spaces/public/nav_control/nav_control_popover.tsx b/x-pack/legacy/plugins/spaces/public/nav_control/nav_control_popover.tsx index f291027e15232..59c8052a644da 100644 --- a/x-pack/legacy/plugins/spaces/public/nav_control/nav_control_popover.tsx +++ b/x-pack/legacy/plugins/spaces/public/nav_control/nav_control_popover.tsx @@ -32,6 +32,8 @@ interface State { spaces: Space[]; } +const popoutContentId = 'headerSpacesMenuContent'; + export class NavControlPopover extends Component { private activeSpace$?: Subscription; @@ -71,6 +73,7 @@ export class NavControlPopover extends Component { if (!this.state.loading && this.state.spaces.length < 2) { element = ( @@ -78,6 +81,7 @@ export class NavControlPopover extends Component { } else { element = ( { private getButton = (linkIcon: JSX.Element, linkTitle: string) => { return ( Date: Mon, 13 Jan 2020 10:21:36 -0500 Subject: [PATCH 027/139] use last color of ramp as default --- .../color/color_stops_categorical.js | 8 ++--- .../components/color/color_stops_utils.js | 6 ++++ .../properties/dynamic_color_property.js | 32 +++++++++++++------ 3 files changed, 30 insertions(+), 16 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js index b110361e108bf..6161b4540f14c 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js @@ -11,6 +11,7 @@ import { EuiFieldText } from '@elastic/eui'; import { addCategoricalRow, isCategoricalStopsInvalid, + getOtherCategoryLabel, DEFAULT_CUSTOM_COLOR, DEFAULT_NEXT_COLOR, } from './color_stops_utils'; @@ -55,12 +56,7 @@ export const ColorStopsCategorical = ({ } )} value={stop} - placeholder={i18n.translate( - 'xpack.maps.styles.colorStops.categoricalStop.otherCategoryPlaceholder', - { - defaultMessage: 'Other', - } - )} + placeholder={getOtherCategoryLabel()} disabled onChange={onStopChange} compressed diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js index 3b66f50c0abc3..8bf0ab7babf55 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js @@ -140,5 +140,11 @@ export function isOrdinalStopsInvalid(colorStops) { }); } +export function getOtherCategoryLabel() { + return i18n.translate('xpack.maps.styles.categorical.otherCategoryLabel', { + defaultMessage: 'Other', + }); +} + export const DEFAULT_CUSTOM_COLOR = '#FF0000'; export const DEFAULT_NEXT_COLOR = '#00FF00'; diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js index 2172bb192c2a0..b813f168d3967 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js @@ -21,7 +21,10 @@ import { import { VectorIcon } from '../components/legend/vector_icon'; import { VECTOR_STYLES } from '../vector_style_defaults'; import { COLOR_MAP_TYPE } from '../../../../../common/constants'; -import { isCategoricalStopsInvalid } from '../components/color/color_stops_utils'; +import { + isCategoricalStopsInvalid, + getOtherCategoryLabel, +} from '../components/color/color_stops_utils'; export class DynamicColorProperty extends DynamicStyleProperty { syncCircleColorWithMb(mbLayerId, mbMap, alpha) { @@ -141,13 +144,21 @@ export class DynamicColorProperty extends DynamicStyleProperty { return []; } - return this._options.customColorPalette.map((config, index) => { - return { + const stops = []; + for (let i = 1; i < this._options.customColorPalette.length; i++) { + const config = this._options.customColorPalette[i]; + stops.push({ stop: config.stop, color: config.color, - isDefault: index === 0, - }; + isDefault: false, + }); + } + stops.push({ + stop: this._options.customColorPalette[0].stop, + color: this._options.customColorPalette[0].color, + isDefault: true, }); + return stops; } const fieldMeta = this.getFieldMeta(); @@ -163,9 +174,10 @@ export class DynamicColorProperty extends DynamicStyleProperty { const stops = []; for (let i = 0; i < maxLength; i++) { + const isDefault = i === maxLength - 1; stops.push({ - stop: i === 0 ? '__DEFAULT__' : fieldMeta.categories[i - 1].key, - isDefault: i === 0, + stop: isDefault ? '__DEFAULT__' : fieldMeta.categories[i].key, + isDefault: isDefault, color: colors[i], }); } @@ -185,12 +197,12 @@ export class DynamicColorProperty extends DynamicStyleProperty { return null; } const mbStops = []; - for (let i = 1; i < paletteStops.length; i++) { + for (let i = 0; i < paletteStops.length - 1; i++) { const stop = paletteStops[i]; mbStops.push(stop.stop); mbStops.push(stop.color); } - mbStops.push(paletteStops[0].color); //first color is default color + mbStops.push(paletteStops[paletteStops.length - 2].color); //last color is default color return ['match', ['get', this._options.field.name], ...mbStops]; } @@ -271,7 +283,7 @@ export class DynamicColorProperty extends DynamicStyleProperty { if (config.isDefault) { textValue = ( - Default + {getOtherCategoryLabel()} ); } else { From f3cdbf20cef013e1a10b3aa883862f1a44c8b29a Mon Sep 17 00:00:00 2001 From: Bhavya RM Date: Mon, 13 Jan 2020 11:14:37 -0500 Subject: [PATCH 028/139] Discover a11y tests (#54209) Comprehensive discover a11y tests --- .../saved_objects/saved_object_finder.tsx | 3 + test/accessibility/apps/discover.ts | 72 ++++++++++++++++++- test/accessibility/services/a11y/a11y.ts | 6 -- test/functional/page_objects/discover_page.js | 16 +++++ 4 files changed, 90 insertions(+), 7 deletions(-) diff --git a/src/plugins/kibana_react/public/saved_objects/saved_object_finder.tsx b/src/plugins/kibana_react/public/saved_objects/saved_object_finder.tsx index bd2beaf77a305..1522c6b42824c 100644 --- a/src/plugins/kibana_react/public/saved_objects/saved_object_finder.tsx +++ b/src/plugins/kibana_react/public/saved_objects/saved_object_finder.tsx @@ -346,6 +346,9 @@ class SavedObjectFinderUi extends React.Component< placeholder={i18n.translate('kibana-react.savedObjects.finder.searchPlaceholder', { defaultMessage: 'Search…', })} + aria-label={i18n.translate('kibana-react.savedObjects.finder.searchPlaceholder', { + defaultMessage: 'Search…', + })} fullWidth value={this.state.query} onChange={e => { diff --git a/test/accessibility/apps/discover.ts b/test/accessibility/apps/discover.ts index 38ee5b7db39c4..e25d295515971 100644 --- a/test/accessibility/apps/discover.ts +++ b/test/accessibility/apps/discover.ts @@ -20,10 +20,12 @@ import { FtrProviderContext } from '../ftr_provider_context'; export default function({ getService, getPageObjects }: FtrProviderContext) { - const PageObjects = getPageObjects(['common', 'timePicker']); + const PageObjects = getPageObjects(['common', 'discover', 'header', 'share', 'timePicker']); const a11y = getService('a11y'); const esArchiver = getService('esArchiver'); const kibanaServer = getService('kibanaServer'); + const inspector = getService('inspector'); + const filterBar = getService('filterBar'); describe('Discover', () => { before(async () => { @@ -39,5 +41,73 @@ export default function({ getService, getPageObjects }: FtrProviderContext) { it('main view', async () => { await a11y.testAppSnapshot(); }); + + it('Click save button', async () => { + await PageObjects.discover.clickSaveSearchButton(); + await a11y.testAppSnapshot(); + }); + + it('Save search panel', async () => { + await PageObjects.discover.inputSavedSearchTitle('a11ySearch'); + await a11y.testAppSnapshot(); + }); + + it('Confirm saved search', async () => { + await PageObjects.discover.clickConfirmSavedSearch(); + await a11y.testAppSnapshot(); + }); + + // skipping the test for new because we can't fix it right now + it.skip('Click on new to clear the search', async () => { + await PageObjects.discover.clickNewSearchButton(); + await a11y.testAppSnapshot(); + }); + + it('Open load saved search panel', async () => { + await PageObjects.discover.openLoadSavedSearchPanel(); + await a11y.testAppSnapshot(); + await PageObjects.discover.closeLoadSavedSearchPanel(); + }); + + it('Open inspector panel', async () => { + await inspector.open(); + await a11y.testAppSnapshot(); + await inspector.close(); + }); + + it('Open add filter', async () => { + await PageObjects.discover.openAddFilterPanel(); + await a11y.testAppSnapshot(); + }); + + it('Select values for a filter', async () => { + await filterBar.addFilter('extension.raw', 'is one of', 'jpg'); + await a11y.testAppSnapshot(); + }); + + it('Load a new search from the panel', async () => { + await PageObjects.discover.clickSaveSearchButton(); + await PageObjects.discover.inputSavedSearchTitle('filterSearch'); + await PageObjects.discover.clickConfirmSavedSearch(); + await PageObjects.discover.openLoadSavedSearchPanel(); + await PageObjects.discover.loadSavedSearch('filterSearch'); + await a11y.testAppSnapshot(); + }); + + // unable to validate on EUI pop-over + it('click share button', async () => { + await PageObjects.share.clickShareTopNavButton(); + await a11y.testAppSnapshot(); + }); + + it('Open sidebar filter', async () => { + await PageObjects.discover.openSidebarFieldFilter(); + await a11y.testAppSnapshot(); + }); + + it('Close sidebar filter', async () => { + await PageObjects.discover.closeSidebarFieldFilter(); + await a11y.testAppSnapshot(); + }); }); } diff --git a/test/accessibility/services/a11y/a11y.ts b/test/accessibility/services/a11y/a11y.ts index 7adfe7ebfcc7d..72440b648e538 100644 --- a/test/accessibility/services/a11y/a11y.ts +++ b/test/accessibility/services/a11y/a11y.ts @@ -45,7 +45,6 @@ export const normalizeResult = (report: any) => { export function A11yProvider({ getService }: FtrProviderContext) { const browser = getService('browser'); const Wd = getService('__webdriver__'); - const log = getService('log'); /** * Accessibility testing service using the Axe (https://www.deque.com/axe/) @@ -78,11 +77,6 @@ export function A11yProvider({ getService }: FtrProviderContext) { private testAxeReport(report: AxeReport) { const errorMsgs = []; - for (const result of report.incomplete) { - // these items require human review and can't be definitively validated - log.warning(printResult(chalk.yellow('UNABLE TO VALIDATE'), result)); - } - for (const result of report.violations) { errorMsgs.push(printResult(chalk.red('VIOLATION'), result)); } diff --git a/test/functional/page_objects/discover_page.js b/test/functional/page_objects/discover_page.js index 3ba0f217813f2..85d8cff675f2d 100644 --- a/test/functional/page_objects/discover_page.js +++ b/test/functional/page_objects/discover_page.js @@ -63,6 +63,18 @@ export function DiscoverPageProvider({ getService, getPageObjects }) { }); } + async inputSavedSearchTitle(searchName) { + await testSubjects.setValue('savedObjectTitle', searchName); + } + + async clickConfirmSavedSearch() { + await testSubjects.click('confirmSaveSavedObjectButton'); + } + + async openAddFilterPanel() { + await testSubjects.click('addFilter'); + } + async waitUntilSearchingHasFinished() { const spinner = await testSubjects.find('loadingSpinner'); await find.waitForElementHidden(spinner, defaultFindTimeout * 10); @@ -117,6 +129,10 @@ export function DiscoverPageProvider({ getService, getPageObjects }) { await testSubjects.click('discoverOpenButton'); } + async closeLoadSavedSearchPanel() { + await testSubjects.click('euiFlyoutCloseButton'); + } + async getChartCanvas() { return await find.byCssSelector('.echChart canvas:last-of-type'); } From 3ce2025c75c2989af6fae36fc610d264bdee03b9 Mon Sep 17 00:00:00 2001 From: Corey Robertson Date: Mon, 13 Jan 2020 11:53:47 -0500 Subject: [PATCH 029/139] [CANVAS] Relax workpad schema to allow existing templates to work (#54019) Co-authored-by: Elastic Machine --- .../canvas/i18n/templates/template_strings.ts | 2 +- .../public/components/workpad_templates/index.js | 3 +++ .../canvas/server/routes/workpad/workpad_schema.ts | 12 +++++++----- 3 files changed, 11 insertions(+), 6 deletions(-) diff --git a/x-pack/legacy/plugins/canvas/i18n/templates/template_strings.ts b/x-pack/legacy/plugins/canvas/i18n/templates/template_strings.ts index 261f67067cfaf..5ab6a908641de 100644 --- a/x-pack/legacy/plugins/canvas/i18n/templates/template_strings.ts +++ b/x-pack/legacy/plugins/canvas/i18n/templates/template_strings.ts @@ -42,7 +42,7 @@ export const getTemplateStrings = (): TemplateStringDict => ({ defaultMessage: 'Pitch', }), help: i18n.translate('xpack.canvas.templates.pitchHelp', { - defaultMessage: 'Branded presentation with large photos"', + defaultMessage: 'Branded presentation with large photos', }), }, Status: { diff --git a/x-pack/legacy/plugins/canvas/public/components/workpad_templates/index.js b/x-pack/legacy/plugins/canvas/public/components/workpad_templates/index.js index cf07d1ed229f0..139d0f283bf1a 100644 --- a/x-pack/legacy/plugins/canvas/public/components/workpad_templates/index.js +++ b/x-pack/legacy/plugins/canvas/public/components/workpad_templates/index.js @@ -24,7 +24,10 @@ export const WorkpadTemplates = compose( cloneWorkpad: props => workpad => { workpad.id = getId('workpad'); workpad.name = `My Canvas Workpad - ${workpad.name}`; + // Remove unneeded fields workpad.tags = undefined; + workpad.displayName = undefined; + workpad.help = undefined; return workpadService .create(workpad) .then(() => props.router.navigateTo('loadWorkpad', { id: workpad.id, page: 1 })) diff --git a/x-pack/plugins/canvas/server/routes/workpad/workpad_schema.ts b/x-pack/plugins/canvas/server/routes/workpad/workpad_schema.ts index 0bcb161575901..0c31f517a74b3 100644 --- a/x-pack/plugins/canvas/server/routes/workpad/workpad_schema.ts +++ b/x-pack/plugins/canvas/server/routes/workpad/workpad_schema.ts @@ -24,11 +24,13 @@ export const WorkpadElementSchema = schema.object({ export const WorkpadPageSchema = schema.object({ elements: schema.arrayOf(WorkpadElementSchema), - groups: schema.arrayOf( - schema.object({ - id: schema.string(), - position: PositionSchema, - }) + groups: schema.maybe( + schema.arrayOf( + schema.object({ + id: schema.string(), + position: PositionSchema, + }) + ) ), id: schema.string(), style: schema.recordOf(schema.string(), schema.string()), From 8e7ea11657204b6eb5968e99c97640f68108fa20 Mon Sep 17 00:00:00 2001 From: Brandon Kobel Date: Mon, 13 Jan 2020 08:56:01 -0800 Subject: [PATCH 030/139] Adding tests to ensure src/core/utils/merge doesn't pollute prototypes (#54511) Co-authored-by: Elastic Machine --- src/core/utils/merge.test.ts | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/src/core/utils/merge.test.ts b/src/core/utils/merge.test.ts index aa98f51067411..c857e980dec21 100644 --- a/src/core/utils/merge.test.ts +++ b/src/core/utils/merge.test.ts @@ -61,4 +61,15 @@ describe('merge', () => { expect(merge({ a: 0 }, {}, {})).toEqual({ a: 0 }); expect(merge({ a: 0 }, { a: 1 }, {})).toEqual({ a: 1 }); }); + + test(`doesn't pollute prototypes`, () => { + merge({}, JSON.parse('{ "__proto__": { "foo": "bar" } }')); + merge({}, JSON.parse('{ "constructor": { "prototype": { "foo": "bar" } } }')); + merge( + {}, + JSON.parse('{ "__proto__": { "foo": "bar" } }'), + JSON.parse('{ "constructor": { "prototype": { "foo": "bar" } } }') + ); + expect(({} as any).foo).toBe(undefined); + }); }); From 6826ece3b0e6279bb822f9be1715893af78c7242 Mon Sep 17 00:00:00 2001 From: Walter Rafelsberger Date: Mon, 13 Jan 2020 18:14:36 +0100 Subject: [PATCH 031/139] [ML] Fix appState/globalState (#52987) Replaces appState/globalState with a custom hook useUrlState(). --- x-pack/legacy/plugins/ml/common/types/jobs.ts | 16 + .../__snapshots__/index.test.tsx.snap | 108 +- .../annotation_flyout/index.test.tsx | 31 +- .../annotations/annotation_flyout/index.tsx | 117 +- .../annotations_table/annotations_table.js | 10 +- .../anomalies_table/anomalies_table.js | 6 +- .../anomalies_table_columns.js | 4 +- .../components/anomalies_table/links_menu.js | 4 +- .../checkbox_showcharts.js | 52 - .../checkbox_showcharts.tsx | 52 + .../controls/checkbox_showcharts/index.d.ts | 9 - .../{index.js => index.ts} | 2 +- .../application/components/controls/index.js | 9 - .../{select_interval/index.d.ts => index.ts} | 9 +- .../select_interval/{index.js => index.ts} | 2 +- .../select_interval/select_interval.test.js | 30 - .../select_interval/select_interval.test.tsx | 55 + ...select_interval.js => select_interval.tsx} | 60 +- .../controls/select_severity/index.d.ts | 13 - .../select_severity/{index.js => index.ts} | 2 +- .../select_severity/select_severity.js | 139 --- ...erity.test.js => select_severity.test.tsx} | 49 +- .../select_severity/select_severity.tsx | 141 +++ .../job_selector/{index.js => index.ts} | 0 .../job_select_service_utils.d.ts | 22 - .../job_selector/job_select_service_utils.js | 261 ----- .../job_selector/job_select_service_utils.ts | 156 +++ .../{job_selector.js => job_selector.tsx} | 190 ++-- .../job_selector/use_job_selection.ts | 88 ++ .../components/navigation_menu/tabs.tsx | 13 +- .../navigation_menu/top_nav/top_nav.tsx | 14 +- .../explorer/__tests__/explorer_directive.js | 64 -- .../application/explorer/actions/index.ts | 2 +- .../explorer/actions/job_selection.ts | 14 +- .../explorer/actions/load_explorer_data.ts | 139 ++- .../public/application/explorer/explorer.d.ts | 12 +- .../public/application/explorer/explorer.js | 1010 ++++++++--------- ...orer_charts_container_service.test.js.snap | 11 +- .../explorer_chart_distribution.js | 6 +- .../explorer_chart_single_metric.js | 6 +- .../explorer_charts_container.js | 19 +- .../explorer_charts_container.test.js | 37 +- .../explorer_charts_container_service.d.ts | 9 +- .../explorer_charts_container_service.js | 1000 ++++++++-------- .../explorer_charts_container_service.test.js | 130 +-- .../explorer/explorer_constants.ts | 13 +- .../explorer/explorer_dashboard_service.ts | 151 ++- .../application/explorer/explorer_utils.d.ts | 27 +- .../application/explorer/explorer_utils.js | 50 +- .../explorer/hooks/use_selected_cells.ts | 67 ++ .../explorer/reducers/app_state_reducer.ts | 89 -- .../explorer_reducer/check_selected_cells.ts | 23 +- .../clear_influencer_filter_settings.ts | 11 - .../reducers/explorer_reducer/initialize.ts | 35 - .../explorer_reducer/job_selection_change.ts | 23 +- .../reducers/explorer_reducer/reducer.ts | 82 +- .../set_influencer_filter_settings.ts | 17 +- .../reducers/explorer_reducer/state.ts | 15 +- .../application/explorer/reducers/index.ts | 1 - .../select_limit/{index.js => index.ts} | 2 +- .../explorer/select_limit/select_limit.js | 80 -- ...ct_limit.test.js => select_limit.test.tsx} | 18 +- .../explorer/select_limit/select_limit.tsx | 40 + .../select_limit/select_limit_service.js | 19 - .../application/routing/routes/explorer.tsx | 227 ++-- .../routing/routes/timeseriesexplorer.tsx | 308 +++-- .../public/application/routing/use_refresh.ts | 30 + .../services/annotations_service.test.tsx | 4 +- .../services/annotations_service.tsx | 18 +- .../services/forecast_service.d.ts | 7 + .../services/ml_api_service/index.d.ts | 6 +- .../services/timefilter_refresh_service.tsx | 5 +- .../__tests__/timeseriesexplorer_directive.js | 40 - .../entity_control/entity_control.tsx | 34 +- .../forecasting_modal/forecasting_modal.js | 12 +- .../timeseries_chart/timeseries_chart.js | 35 +- .../timeseries_chart/timeseries_chart.test.js | 1 - .../timeseriesexplorer.d.ts | 8 +- .../timeseriesexplorer/timeseriesexplorer.js | 909 ++++++++------- .../timeseriesexplorer_constants.ts | 4 - .../timeseriesexplorer_utils.d.ts | 2 +- .../timeseriesexplorer_utils.js | 3 +- .../observable_utils.test.tsx.snap | 13 - .../util/__tests__/app_state_utils.js | 71 -- .../application/util/app_state_utils.d.ts | 16 - .../application/util/app_state_utils.js | 70 -- .../util/observable_utils.test.tsx | 43 - .../application/util/observable_utils.tsx | 67 -- .../ml/public/application/util/url_state.ts | 91 ++ x-pack/package.json | 2 + 90 files changed, 3160 insertions(+), 3752 deletions(-) delete mode 100644 x-pack/legacy/plugins/ml/public/application/components/controls/checkbox_showcharts/checkbox_showcharts.js create mode 100644 x-pack/legacy/plugins/ml/public/application/components/controls/checkbox_showcharts/checkbox_showcharts.tsx delete mode 100644 x-pack/legacy/plugins/ml/public/application/components/controls/checkbox_showcharts/index.d.ts rename x-pack/legacy/plugins/ml/public/application/components/controls/checkbox_showcharts/{index.js => index.ts} (76%) delete mode 100644 x-pack/legacy/plugins/ml/public/application/components/controls/index.js rename x-pack/legacy/plugins/ml/public/application/components/controls/{select_interval/index.d.ts => index.ts} (57%) rename x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/{index.js => index.ts} (77%) delete mode 100644 x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/select_interval.test.js create mode 100644 x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/select_interval.test.tsx rename x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/{select_interval.js => select_interval.tsx} (56%) delete mode 100644 x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/index.d.ts rename x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/{index.js => index.ts} (73%) delete mode 100644 x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/select_severity.js rename x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/{select_severity.test.js => select_severity.test.tsx} (55%) create mode 100644 x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/select_severity.tsx rename x-pack/legacy/plugins/ml/public/application/components/job_selector/{index.js => index.ts} (100%) delete mode 100644 x-pack/legacy/plugins/ml/public/application/components/job_selector/job_select_service_utils.d.ts delete mode 100644 x-pack/legacy/plugins/ml/public/application/components/job_selector/job_select_service_utils.js create mode 100644 x-pack/legacy/plugins/ml/public/application/components/job_selector/job_select_service_utils.ts rename x-pack/legacy/plugins/ml/public/application/components/job_selector/{job_selector.js => job_selector.tsx} (74%) create mode 100644 x-pack/legacy/plugins/ml/public/application/components/job_selector/use_job_selection.ts delete mode 100644 x-pack/legacy/plugins/ml/public/application/explorer/__tests__/explorer_directive.js create mode 100644 x-pack/legacy/plugins/ml/public/application/explorer/hooks/use_selected_cells.ts delete mode 100644 x-pack/legacy/plugins/ml/public/application/explorer/reducers/app_state_reducer.ts delete mode 100644 x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/initialize.ts rename x-pack/legacy/plugins/ml/public/application/explorer/select_limit/{index.js => index.ts} (79%) delete mode 100644 x-pack/legacy/plugins/ml/public/application/explorer/select_limit/select_limit.js rename x-pack/legacy/plugins/ml/public/application/explorer/select_limit/{select_limit.test.js => select_limit.test.tsx} (59%) create mode 100644 x-pack/legacy/plugins/ml/public/application/explorer/select_limit/select_limit.tsx delete mode 100644 x-pack/legacy/plugins/ml/public/application/explorer/select_limit/select_limit_service.js create mode 100644 x-pack/legacy/plugins/ml/public/application/routing/use_refresh.ts delete mode 100644 x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/__tests__/timeseriesexplorer_directive.js delete mode 100644 x-pack/legacy/plugins/ml/public/application/util/__snapshots__/observable_utils.test.tsx.snap delete mode 100644 x-pack/legacy/plugins/ml/public/application/util/__tests__/app_state_utils.js delete mode 100644 x-pack/legacy/plugins/ml/public/application/util/app_state_utils.d.ts delete mode 100644 x-pack/legacy/plugins/ml/public/application/util/app_state_utils.js delete mode 100644 x-pack/legacy/plugins/ml/public/application/util/observable_utils.test.tsx delete mode 100644 x-pack/legacy/plugins/ml/public/application/util/observable_utils.tsx create mode 100644 x-pack/legacy/plugins/ml/public/application/util/url_state.ts diff --git a/x-pack/legacy/plugins/ml/common/types/jobs.ts b/x-pack/legacy/plugins/ml/common/types/jobs.ts index 07c2be3e7f0b4..47f34f6568eed 100644 --- a/x-pack/legacy/plugins/ml/common/types/jobs.ts +++ b/x-pack/legacy/plugins/ml/common/types/jobs.ts @@ -4,6 +4,8 @@ * you may not use this file except in compliance with the Elastic License. */ +import { Moment } from 'moment'; + // TS TODO: This is not yet a fully fledged representation of the job data structure, // but it fulfills some basic TypeScript related needs. export interface MlJob { @@ -63,6 +65,20 @@ export interface MlSummaryJob { export type MlSummaryJobs = MlSummaryJob[]; +export interface MlJobWithTimeRange extends MlJob { + groups: string[]; + timeRange: { + from: number; + to: number; + fromPx: number; + toPx: number; + fromMoment: Moment; + toMoment: Moment; + widthPx: number; + label: string; + }; +} + export function isMlJob(arg: any): arg is MlJob { return typeof arg.job_id === 'string'; } diff --git a/x-pack/legacy/plugins/ml/public/application/components/annotations/annotation_flyout/__snapshots__/index.test.tsx.snap b/x-pack/legacy/plugins/ml/public/application/components/annotations/annotation_flyout/__snapshots__/index.test.tsx.snap index 29831190824ad..dba73c246c3d0 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/annotations/annotation_flyout/__snapshots__/index.test.tsx.snap +++ b/x-pack/legacy/plugins/ml/public/application/components/annotations/annotation_flyout/__snapshots__/index.test.tsx.snap @@ -1,109 +1,3 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`AnnotationFlyout Initialization. 1`] = ` - -`; +exports[`AnnotationFlyout Initialization. 1`] = `""`; diff --git a/x-pack/legacy/plugins/ml/public/application/components/annotations/annotation_flyout/index.test.tsx b/x-pack/legacy/plugins/ml/public/application/components/annotations/annotation_flyout/index.test.tsx index 7fa47f3518b81..d71a23f478282 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/annotations/annotation_flyout/index.test.tsx +++ b/x-pack/legacy/plugins/ml/public/application/components/annotations/annotation_flyout/index.test.tsx @@ -4,10 +4,11 @@ * you may not use this file except in compliance with the Elastic License. */ -import { injectObservablesAsProps } from '../../../util/observable_utils'; +import useObservable from 'react-use/lib/useObservable'; + import mockAnnotations from '../annotations_table/__mocks__/mock_annotations.json'; -import React, { ComponentType } from 'react'; +import React from 'react'; import { mountWithIntl, shallowWithIntl } from 'test_utils/enzyme_helpers'; import { Annotation } from '../../../../../common/types/annotations'; @@ -25,11 +26,14 @@ describe('AnnotationFlyout', () => { const annotation = mockAnnotations[1] as Annotation; annotation$.next(annotation); - // injectObservablesAsProps wraps the observable in a new component - const ObservableComponent = injectObservablesAsProps( - { annotation: annotation$ }, - (AnnotationFlyout as any) as ComponentType - ); + // useObservable wraps the observable in a new component + const ObservableComponent = (props: any) => { + const annotationProp = useObservable(annotation$); + if (annotationProp === undefined) { + return null; + } + return ; + }; const wrapper = mountWithIntl(); const updateBtn = wrapper.find('EuiButton').first(); @@ -40,11 +44,14 @@ describe('AnnotationFlyout', () => { const annotation = mockAnnotations[2] as Annotation; annotation$.next(annotation); - // injectObservablesAsProps wraps the observable in a new component - const ObservableComponent = injectObservablesAsProps( - { annotation: annotation$ }, - (AnnotationFlyout as any) as ComponentType - ); + // useObservable wraps the observable in a new component + const ObservableComponent = (props: any) => { + const annotationProp = useObservable(annotation$); + if (annotationProp === undefined) { + return null; + } + return ; + }; const wrapper = mountWithIntl(); const updateBtn = wrapper.find('EuiButton').first(); diff --git a/x-pack/legacy/plugins/ml/public/application/components/annotations/annotation_flyout/index.tsx b/x-pack/legacy/plugins/ml/public/application/components/annotations/annotation_flyout/index.tsx index 84c16360795ea..6668518822710 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/annotations/annotation_flyout/index.tsx +++ b/x-pack/legacy/plugins/ml/public/application/components/annotations/annotation_flyout/index.tsx @@ -4,7 +4,8 @@ * you may not use this file except in compliance with the Elastic License. */ -import React, { Component, ComponentType, Fragment, ReactNode } from 'react'; +import React, { Component, Fragment, FC, ReactNode } from 'react'; +import useObservable from 'react-use/lib/useObservable'; import * as Rx from 'rxjs'; import { @@ -23,16 +24,16 @@ import { } from '@elastic/eui'; import { CommonProps } from '@elastic/eui'; -import { FormattedMessage, injectI18n } from '@kbn/i18n/react'; -import { InjectedIntlProps } from 'react-intl'; +import { i18n } from '@kbn/i18n'; +import { FormattedMessage } from '@kbn/i18n/react'; + import { toastNotifications } from 'ui/notify'; import { ANNOTATION_MAX_LENGTH_CHARS } from '../../../../../common/constants/annotations'; import { annotation$, - annotationsRefresh$, + annotationsRefreshed, AnnotationState, } from '../../../services/annotations_service'; -import { injectObservablesAsProps } from '../../../util/observable_utils'; import { AnnotationDescriptionList } from '../annotation_description_list'; import { DeleteAnnotationModal } from '../delete_annotation_modal'; @@ -46,7 +47,7 @@ interface State { isDeleteModalVisible: boolean; } -class AnnotationFlyoutIntl extends Component { +class AnnotationFlyoutIntl extends Component { public state: State = { isDeleteModalVisible: false, }; @@ -73,7 +74,7 @@ class AnnotationFlyoutIntl extends Component { - const { annotation, intl } = this.props; + const { annotation } = this.props; if (annotation === null) { return; @@ -82,31 +83,30 @@ class AnnotationFlyoutIntl extends Component { @@ -116,7 +116,7 @@ class AnnotationFlyoutIntl extends Component { // Validates the entered text, returning an array of error messages // for display in the form. An empty array is returned if the text is valid. - const { annotation, intl } = this.props; + const { annotation } = this.props; const errors: string[] = []; if (annotation === null) { return errors; @@ -124,8 +124,7 @@ class AnnotationFlyoutIntl extends Component ANNOTATION_MAX_LENGTH_CHARS) { const charsOver = textLength - ANNOTATION_MAX_LENGTH_CHARS; errors.push( - intl.formatMessage( - { - id: 'xpack.ml.timeSeriesExplorer.annotationFlyout.maxLengthError', - defaultMessage: - '{charsOver, number} {charsOver, plural, one {character} other {characters}} above maximum length of {maxChars}', - }, - { + i18n.translate('xpack.ml.timeSeriesExplorer.annotationFlyout.maxLengthError', { + defaultMessage: + '{charsOver, number} {charsOver, plural, one {character} other {characters}} above maximum length of {maxChars}', + values: { maxChars: ANNOTATION_MAX_LENGTH_CHARS, charsOver, - } - ) + }, + }) ); } @@ -153,7 +149,7 @@ class AnnotationFlyoutIntl extends Component { - const { annotation, intl } = this.props; + const { annotation } = this.props; if (annotation === null) { return; @@ -164,27 +160,25 @@ class AnnotationFlyoutIntl extends Component { - annotationsRefresh$.next(true); + annotationsRefreshed(); if (typeof annotation._id === 'undefined') { toastNotifications.addSuccess( - intl.formatMessage( + i18n.translate( + 'xpack.ml.timeSeriesExplorer.timeSeriesChart.addedAnnotationNotificationMessage', { - id: - 'xpack.ml.timeSeriesExplorer.timeSeriesChart.addedAnnotationNotificationMessage', defaultMessage: 'Added an annotation for job with ID {jobId}.', - }, - { jobId: annotation.job_id } + values: { jobId: annotation.job_id }, + } ) ); } else { toastNotifications.addSuccess( - intl.formatMessage( + i18n.translate( + 'xpack.ml.timeSeriesExplorer.timeSeriesChart.updatedAnnotationNotificationMessage', { - id: - 'xpack.ml.timeSeriesExplorer.timeSeriesChart.updatedAnnotationNotificationMessage', defaultMessage: 'Updated annotation for job with ID {jobId}.', - }, - { jobId: annotation.job_id } + values: { jobId: annotation.job_id }, + } ) ); } @@ -192,26 +186,24 @@ class AnnotationFlyoutIntl extends Component { if (typeof annotation._id === 'undefined') { toastNotifications.addDanger( - intl.formatMessage( + i18n.translate( + 'xpack.ml.timeSeriesExplorer.timeSeriesChart.errorWithCreatingAnnotationNotificationErrorMessage', { - id: - 'xpack.ml.timeSeriesExplorer.timeSeriesChart.errorWithCreatingAnnotationNotificationErrorMessage', defaultMessage: 'An error occurred creating the annotation for job with ID {jobId}: {error}', - }, - { jobId: annotation.job_id, error: JSON.stringify(resp) } + values: { jobId: annotation.job_id, error: JSON.stringify(resp) }, + } ) ); } else { toastNotifications.addDanger( - intl.formatMessage( + i18n.translate( + 'xpack.ml.timeSeriesExplorer.timeSeriesChart.errorWithUpdatingAnnotationNotificationErrorMessage', { - id: - 'xpack.ml.timeSeriesExplorer.timeSeriesChart.errorWithUpdatingAnnotationNotificationErrorMessage', defaultMessage: 'An error occurred updating the annotation for job with ID {jobId}: {error}', - }, - { jobId: annotation.job_id, error: JSON.stringify(resp) } + values: { jobId: annotation.job_id, error: JSON.stringify(resp) }, + } ) ); } @@ -219,7 +211,7 @@ class AnnotationFlyoutIntl extends Component ANNOTATION_MAX_LENGTH_CHARS * lengthRatioToShowWarning ) { - helpText = intl.formatMessage( + helpText = i18n.translate( + 'xpack.ml.timeSeriesExplorer.annotationFlyout.approachingMaxLengthWarning', { - id: 'xpack.ml.timeSeriesExplorer.annotationFlyout.approachingMaxLengthWarning', defaultMessage: '{charsRemaining, number} {charsRemaining, plural, one {character} other {characters}} remaining', - }, - { charsRemaining: ANNOTATION_MAX_LENGTH_CHARS - annotation.annotation.length } + values: { charsRemaining: ANNOTATION_MAX_LENGTH_CHARS - annotation.annotation.length }, + } ); } @@ -344,7 +336,12 @@ class AnnotationFlyoutIntl extends Component = props => { + const annotationProp = useObservable(annotation$); + + if (annotationProp === undefined) { + return null; + } + + return ; +}; diff --git a/x-pack/legacy/plugins/ml/public/application/components/annotations/annotations_table/annotations_table.js b/x-pack/legacy/plugins/ml/public/application/components/annotations/annotations_table/annotations_table.js index f270d14b53e56..6c4e8925f369f 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/annotations/annotations_table/annotations_table.js +++ b/x-pack/legacy/plugins/ml/public/application/components/annotations/annotations_table/annotations_table.js @@ -42,7 +42,11 @@ import { isTimeSeriesViewJob, } from '../../../../../common/util/job_utils'; -import { annotation$, annotationsRefresh$ } from '../../../services/annotations_service'; +import { + annotation$, + annotationsRefresh$, + annotationsRefreshed, +} from '../../../services/annotations_service'; import { FormattedMessage, injectI18n } from '@kbn/i18n/react'; @@ -136,7 +140,7 @@ const AnnotationsTable = injectI18n( this.annotationsRefreshSubscription = annotationsRefresh$.subscribe(() => this.getAnnotations() ); - annotationsRefresh$.next(true); + annotationsRefreshed(); } } @@ -150,7 +154,7 @@ const AnnotationsTable = injectI18n( this.state.isLoading === false && this.state.jobId !== this.props.jobs[0].job_id ) { - annotationsRefresh$.next(true); + annotationsRefreshed(); this.previousJobId = this.props.jobs[0].job_id; } } diff --git a/x-pack/legacy/plugins/ml/public/application/components/anomalies_table/anomalies_table.js b/x-pack/legacy/plugins/ml/public/application/components/anomalies_table/anomalies_table.js index d1beb360793f2..bc3ce88921110 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/anomalies_table/anomalies_table.js +++ b/x-pack/legacy/plugins/ml/public/application/components/anomalies_table/anomalies_table.js @@ -146,7 +146,7 @@ class AnomaliesTable extends Component { }; render() { - const { timefilter, tableData, filter, influencerFilter } = this.props; + const { bounds, tableData, filter, influencerFilter } = this.props; if ( tableData === undefined || @@ -175,7 +175,7 @@ class AnomaliesTable extends Component { tableData.examplesByJobId, this.isShowingAggregatedData(), tableData.interval, - timefilter, + bounds, tableData.showViewSeriesLink, this.state.showRuleEditorFlyout, this.state.itemIdToExpandedRowMap, @@ -224,7 +224,7 @@ class AnomaliesTable extends Component { } } AnomaliesTable.propTypes = { - timefilter: PropTypes.object.isRequired, + bounds: PropTypes.object.isRequired, tableData: PropTypes.object, filter: PropTypes.func, influencerFilter: PropTypes.func, diff --git a/x-pack/legacy/plugins/ml/public/application/components/anomalies_table/anomalies_table_columns.js b/x-pack/legacy/plugins/ml/public/application/components/anomalies_table/anomalies_table_columns.js index 75941edddeb56..36faac45164f4 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/anomalies_table/anomalies_table_columns.js +++ b/x-pack/legacy/plugins/ml/public/application/components/anomalies_table/anomalies_table_columns.js @@ -55,7 +55,7 @@ export function getColumns( examplesByJobId, isAggregatedData, interval, - timefilter, + bounds, showViewSeriesLink, showRuleEditorFlyout, itemIdToExpandedRowMap, @@ -262,10 +262,10 @@ export function getColumns( return ( ); diff --git a/x-pack/legacy/plugins/ml/public/application/components/anomalies_table/links_menu.js b/x-pack/legacy/plugins/ml/public/application/components/anomalies_table/links_menu.js index b4821ddb564c9..8cbee27bdd9a8 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/anomalies_table/links_menu.js +++ b/x-pack/legacy/plugins/ml/public/application/components/anomalies_table/links_menu.js @@ -37,10 +37,10 @@ export const LinksMenu = injectI18n( class LinksMenu extends Component { static propTypes = { anomaly: PropTypes.object.isRequired, + bounds: PropTypes.object.isRequired, showViewSeriesLink: PropTypes.bool, isAggregatedData: PropTypes.bool, interval: PropTypes.string, - timefilter: PropTypes.object.isRequired, showRuleEditorFlyout: PropTypes.func, }; @@ -146,7 +146,7 @@ export const LinksMenu = injectI18n( viewSeries = () => { const record = this.props.anomaly.source; - const bounds = this.props.timefilter.getActiveBounds(); + const bounds = this.props.bounds; const from = bounds.min.toISOString(); // e.g. 2016-02-08T16:00:00.000Z const to = bounds.max.toISOString(); diff --git a/x-pack/legacy/plugins/ml/public/application/components/controls/checkbox_showcharts/checkbox_showcharts.js b/x-pack/legacy/plugins/ml/public/application/components/controls/checkbox_showcharts/checkbox_showcharts.js deleted file mode 100644 index 89a5fafc491b5..0000000000000 --- a/x-pack/legacy/plugins/ml/public/application/components/controls/checkbox_showcharts/checkbox_showcharts.js +++ /dev/null @@ -1,52 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -/* - * React component for a checkbox element to toggle charts display. - */ -import React, { Component } from 'react'; -import { BehaviorSubject } from 'rxjs'; - -import { EuiCheckbox } from '@elastic/eui'; - -import makeId from '@elastic/eui/lib/components/form/form_row/make_id'; -import { FormattedMessage } from '@kbn/i18n/react'; - -import { injectObservablesAsProps } from '../../../util/observable_utils'; - -export const showCharts$ = new BehaviorSubject(true); - -class CheckboxShowChartsUnwrapped extends Component { - onChange = e => { - const showCharts = e.target.checked; - showCharts$.next(showCharts); - }; - - render() { - return ( - - } - checked={this.props.showCharts} - onChange={this.onChange} - /> - ); - } -} - -const CheckboxShowCharts = injectObservablesAsProps( - { - showCharts: showCharts$, - }, - CheckboxShowChartsUnwrapped -); - -export { CheckboxShowCharts }; diff --git a/x-pack/legacy/plugins/ml/public/application/components/controls/checkbox_showcharts/checkbox_showcharts.tsx b/x-pack/legacy/plugins/ml/public/application/components/controls/checkbox_showcharts/checkbox_showcharts.tsx new file mode 100644 index 0000000000000..70538d4dc3a91 --- /dev/null +++ b/x-pack/legacy/plugins/ml/public/application/components/controls/checkbox_showcharts/checkbox_showcharts.tsx @@ -0,0 +1,52 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +/* + * React component for a checkbox element to toggle charts display. + */ +import React, { FC } from 'react'; + +import { EuiCheckbox } from '@elastic/eui'; +// @ts-ignore +import makeId from '@elastic/eui/lib/components/form/form_row/make_id'; + +import { FormattedMessage } from '@kbn/i18n/react'; + +import { useUrlState } from '../../../util/url_state'; + +const SHOW_CHARTS_DEFAULT = true; +const SHOW_CHARTS_APP_STATE_NAME = 'mlShowCharts'; + +export const useShowCharts = () => { + const [appState, setAppState] = useUrlState('_a'); + + return [ + appState?.mlShowCharts !== undefined ? appState?.mlShowCharts : SHOW_CHARTS_DEFAULT, + (d: boolean) => setAppState(SHOW_CHARTS_APP_STATE_NAME, d), + ]; +}; + +export const CheckboxShowCharts: FC = () => { + const [showCharts, setShowCarts] = useShowCharts(); + + const onChange = (e: React.ChangeEvent) => { + setShowCarts(e.target.checked); + }; + + return ( + + } + checked={showCharts} + onChange={onChange} + /> + ); +}; diff --git a/x-pack/legacy/plugins/ml/public/application/components/controls/checkbox_showcharts/index.d.ts b/x-pack/legacy/plugins/ml/public/application/components/controls/checkbox_showcharts/index.d.ts deleted file mode 100644 index 4d6952d3b3fc3..0000000000000 --- a/x-pack/legacy/plugins/ml/public/application/components/controls/checkbox_showcharts/index.d.ts +++ /dev/null @@ -1,9 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -import { BehaviorSubject } from 'rxjs'; - -export const showCharts$: BehaviorSubject; diff --git a/x-pack/legacy/plugins/ml/public/application/components/controls/checkbox_showcharts/index.js b/x-pack/legacy/plugins/ml/public/application/components/controls/checkbox_showcharts/index.ts similarity index 76% rename from x-pack/legacy/plugins/ml/public/application/components/controls/checkbox_showcharts/index.js rename to x-pack/legacy/plugins/ml/public/application/components/controls/checkbox_showcharts/index.ts index b7957b807591c..d868b9570f337 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/controls/checkbox_showcharts/index.js +++ b/x-pack/legacy/plugins/ml/public/application/components/controls/checkbox_showcharts/index.ts @@ -4,4 +4,4 @@ * you may not use this file except in compliance with the Elastic License. */ -export { CheckboxShowCharts, showCharts$ } from './checkbox_showcharts'; +export { useShowCharts, CheckboxShowCharts } from './checkbox_showcharts'; diff --git a/x-pack/legacy/plugins/ml/public/application/components/controls/index.js b/x-pack/legacy/plugins/ml/public/application/components/controls/index.js deleted file mode 100644 index 26cb89d672632..0000000000000 --- a/x-pack/legacy/plugins/ml/public/application/components/controls/index.js +++ /dev/null @@ -1,9 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -export { CheckboxShowCharts, showCharts$ } from './checkbox_showcharts'; -export { interval$, SelectInterval } from './select_interval'; -export { SelectSeverity, severity$, SEVERITY_OPTIONS } from './select_severity'; diff --git a/x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/index.d.ts b/x-pack/legacy/plugins/ml/public/application/components/controls/index.ts similarity index 57% rename from x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/index.d.ts rename to x-pack/legacy/plugins/ml/public/application/components/controls/index.ts index 4a8273972389a..f3e1ef8358867 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/index.d.ts +++ b/x-pack/legacy/plugins/ml/public/application/components/controls/index.ts @@ -4,9 +4,6 @@ * you may not use this file except in compliance with the Elastic License. */ -import { BehaviorSubject } from 'rxjs'; - -export const interval$: BehaviorSubject<{ - value: string; - text: string; -}>; +export { CheckboxShowCharts } from './checkbox_showcharts'; +export { SelectInterval } from './select_interval'; +export { SelectSeverity, SEVERITY_OPTIONS } from './select_severity'; diff --git a/x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/index.js b/x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/index.ts similarity index 77% rename from x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/index.js rename to x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/index.ts index aec48f4c626ca..32a0b53077818 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/index.js +++ b/x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/index.ts @@ -4,4 +4,4 @@ * you may not use this file except in compliance with the Elastic License. */ -export { interval$, SelectInterval } from './select_interval'; +export { useTableInterval, SelectInterval } from './select_interval'; diff --git a/x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/select_interval.test.js b/x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/select_interval.test.js deleted file mode 100644 index c99d25a68f722..0000000000000 --- a/x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/select_interval.test.js +++ /dev/null @@ -1,30 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -import React from 'react'; -import { shallowWithIntl } from 'test_utils/enzyme_helpers'; -import { SelectInterval } from './select_interval'; - -describe('SelectInterval', () => { - test('creates correct initial selected value', () => { - const wrapper = shallowWithIntl(); - const defaultSelectedValue = wrapper.props().interval.val; - - expect(defaultSelectedValue).toBe('auto'); - }); - - test('currently selected value is updated correctly on click', () => { - const wrapper = shallowWithIntl(); - const select = wrapper.first().shallow(); - - const defaultSelectedValue = wrapper.props().interval.val; - expect(defaultSelectedValue).toBe('auto'); - - select.simulate('change', { target: { value: 'day' } }); - const updatedSelectedValue = wrapper.props().interval.val; - expect(updatedSelectedValue).toBe('day'); - }); -}); diff --git a/x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/select_interval.test.tsx b/x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/select_interval.test.tsx new file mode 100644 index 0000000000000..e1861b887b2a9 --- /dev/null +++ b/x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/select_interval.test.tsx @@ -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; + * you may not use this file except in compliance with the Elastic License. + */ + +import React from 'react'; +import { act } from 'react-dom/test-utils'; +import { MemoryRouter } from 'react-router-dom'; +import { mount } from 'enzyme'; + +import { EuiSelect } from '@elastic/eui'; + +import { SelectInterval } from './select_interval'; + +describe('SelectInterval', () => { + test('creates correct initial selected value', () => { + const wrapper = mount( + + + + ); + const select = wrapper.find(EuiSelect); + + const defaultSelectedValue = select.props().value; + expect(defaultSelectedValue).toBe('auto'); + }); + + test('currently selected value is updated correctly on click', done => { + const wrapper = mount( + + + + ); + const select = wrapper.find(EuiSelect).first(); + const defaultSelectedValue = select.props().value; + expect(defaultSelectedValue).toBe('auto'); + + const onChange = select.props().onChange; + + act(() => { + if (onChange !== undefined) { + onChange({ target: { value: 'day' } } as React.ChangeEvent); + } + }); + + setImmediate(() => { + wrapper.update(); + const updatedSelect = wrapper.find(EuiSelect).first(); + const updatedSelectedValue = updatedSelect.props().value; + expect(updatedSelectedValue).toBe('day'); + done(); + }); + }); +}); diff --git a/x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/select_interval.js b/x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/select_interval.tsx similarity index 56% rename from x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/select_interval.js rename to x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/select_interval.tsx index fce538c0c8c7e..cea3ef2a497b0 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/select_interval.js +++ b/x-pack/legacy/plugins/ml/public/application/components/controls/select_interval/select_interval.tsx @@ -8,15 +8,18 @@ * React component for rendering a select element with various aggregation interval levels. */ -import PropTypes from 'prop-types'; -import React, { Component } from 'react'; -import { BehaviorSubject } from 'rxjs'; +import React, { FC } from 'react'; import { EuiSelect } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; -import { injectObservablesAsProps } from '../../../util/observable_utils'; +import { useUrlState } from '../../../util/url_state'; + +interface TableInterval { + display: string; + val: string; +} const OPTIONS = [ { @@ -41,13 +44,13 @@ const OPTIONS = [ }, ]; -function optionValueToInterval(value) { +function optionValueToInterval(value: string) { // Builds the corresponding interval object with the required display and val properties // from the specified value. const option = OPTIONS.find(opt => opt.value === value); // Default to auto if supplied value doesn't map to one of the options. - let interval = OPTIONS[0]; + let interval: TableInterval = { display: OPTIONS[0].text, val: OPTIONS[0].value }; if (option !== undefined) { interval = { display: option.text, val: option.value }; } @@ -55,30 +58,31 @@ function optionValueToInterval(value) { return interval; } -export const interval$ = new BehaviorSubject(optionValueToInterval(OPTIONS[0].value)); +const TABLE_INTERVAL_DEFAULT = optionValueToInterval('auto'); +const TABLE_INTERVAL_APP_STATE_NAME = 'mlSelectInterval'; -class SelectIntervalUnwrapped extends Component { - static propTypes = { - interval: PropTypes.object.isRequired, - }; +export const useTableInterval = () => { + const [appState, setAppState] = useUrlState('_a'); - onChange = e => { - const interval = optionValueToInterval(e.target.value); - interval$.next(interval); - }; + return [ + (appState && appState[TABLE_INTERVAL_APP_STATE_NAME]) || TABLE_INTERVAL_DEFAULT, + (d: TableInterval) => setAppState(TABLE_INTERVAL_APP_STATE_NAME, d), + ]; +}; - render() { - return ( - - ); - } -} +export const SelectInterval: FC = () => { + const [interval, setInterval] = useTableInterval(); -const SelectInterval = injectObservablesAsProps({ interval: interval$ }, SelectIntervalUnwrapped); + const onChange = (e: React.ChangeEvent) => { + setInterval(optionValueToInterval(e.target.value)); + }; -export { SelectInterval }; + return ( + + ); +}; diff --git a/x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/index.d.ts b/x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/index.d.ts deleted file mode 100644 index 006d23da56f82..0000000000000 --- a/x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/index.d.ts +++ /dev/null @@ -1,13 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -import { BehaviorSubject } from 'rxjs'; - -export const severity$: BehaviorSubject<{ - val: number; - display: string; - color: string; -}>; diff --git a/x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/index.js b/x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/index.ts similarity index 73% rename from x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/index.js rename to x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/index.ts index f26c16c6ff77d..1f524dc1c2ffd 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/index.js +++ b/x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/index.ts @@ -4,4 +4,4 @@ * you may not use this file except in compliance with the Elastic License. */ -export { SelectSeverity, severity$, SEVERITY_OPTIONS } from './select_severity'; +export { useTableSeverity, SelectSeverity, SEVERITY_OPTIONS } from './select_severity'; diff --git a/x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/select_severity.js b/x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/select_severity.js deleted file mode 100644 index 53d65d6622b94..0000000000000 --- a/x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/select_severity.js +++ /dev/null @@ -1,139 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -/* - * React component for rendering a select element with threshold levels. - */ -import PropTypes from 'prop-types'; -import React, { Component, Fragment } from 'react'; -import { i18n } from '@kbn/i18n'; -import { FormattedMessage } from '@kbn/i18n/react'; -import { BehaviorSubject } from 'rxjs'; - -import { EuiHealth, EuiSpacer, EuiSuperSelect, EuiText } from '@elastic/eui'; - -import { getSeverityColor } from '../../../../../common/util/anomaly_utils'; -import { injectObservablesAsProps } from '../../../util/observable_utils'; - -const warningLabel = i18n.translate('xpack.ml.controls.selectSeverity.warningLabel', { - defaultMessage: 'warning', -}); -const minorLabel = i18n.translate('xpack.ml.controls.selectSeverity.minorLabel', { - defaultMessage: 'minor', -}); -const majorLabel = i18n.translate('xpack.ml.controls.selectSeverity.majorLabel', { - defaultMessage: 'major', -}); -const criticalLabel = i18n.translate('xpack.ml.controls.selectSeverity.criticalLabel', { - defaultMessage: 'critical', -}); - -const optionsMap = { - [warningLabel]: 0, - [minorLabel]: 25, - [majorLabel]: 50, - [criticalLabel]: 75, -}; - -export const SEVERITY_OPTIONS = [ - { - val: 0, - display: warningLabel, - color: getSeverityColor(0), - }, - { - val: 25, - display: minorLabel, - color: getSeverityColor(25), - }, - { - val: 50, - display: majorLabel, - color: getSeverityColor(50), - }, - { - val: 75, - display: criticalLabel, - color: getSeverityColor(75), - }, -]; - -function optionValueToThreshold(value) { - // Get corresponding threshold object with required display and val properties from the specified value. - let threshold = SEVERITY_OPTIONS.find(opt => opt.val === value); - - // Default to warning if supplied value doesn't map to one of the options. - if (threshold === undefined) { - threshold = SEVERITY_OPTIONS[0]; - } - - return threshold; -} - -export const severity$ = new BehaviorSubject(SEVERITY_OPTIONS[0]); - -class SelectSeverityUnwrapped extends Component { - onChange = valueDisplay => { - const threshold = optionValueToThreshold(optionsMap[valueDisplay]); - severity$.next(threshold); - }; - - getOptions = () => - SEVERITY_OPTIONS.map(({ color, display, val }) => ({ - value: display, - inputDisplay: ( - - - {display} - - - ), - dropdownDisplay: ( - - - {display} - - - -

- -

-
-
- ), - })); - - render() { - const { severity } = this.props; - const options = this.getOptions(); - - return ( - - ); - } -} - -SelectSeverityUnwrapped.propTypes = { - classNames: PropTypes.string, -}; - -SelectSeverityUnwrapped.defaultProps = { - classNames: '', -}; - -const SelectSeverity = injectObservablesAsProps({ severity: severity$ }, SelectSeverityUnwrapped); - -export { SelectSeverity }; diff --git a/x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/select_severity.test.js b/x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/select_severity.test.tsx similarity index 55% rename from x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/select_severity.test.js rename to x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/select_severity.test.tsx index ec2fe7d1cdeac..e30c48c10a194 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/select_severity.test.js +++ b/x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/select_severity.test.tsx @@ -5,16 +5,25 @@ */ import React from 'react'; -import { shallowWithIntl } from 'test_utils/enzyme_helpers'; +import { act } from 'react-dom/test-utils'; +import { MemoryRouter } from 'react-router-dom'; +import { mount } from 'enzyme'; + +import { EuiSuperSelect } from '@elastic/eui'; + import { SelectSeverity } from './select_severity'; describe('SelectSeverity', () => { test('creates correct severity options and initial selected value', () => { - const wrapper = shallowWithIntl(); - const select = wrapper.first().shallow(); + const wrapper = mount( + + + + ); + const select = wrapper.find(EuiSuperSelect); - const options = select.instance().getOptions(); - const defaultSelectedValue = wrapper.props().severity.display; + const options = select.props().options; + const defaultSelectedValue = select.props().valueOfSelected; expect(defaultSelectedValue).toBe('warning'); expect(options.length).toEqual(4); @@ -53,15 +62,31 @@ describe('SelectSeverity', () => { ); }); - test('state for currently selected value is updated correctly on click', () => { - const wrapper = shallowWithIntl(); - const select = wrapper.first().shallow(); + test('state for currently selected value is updated correctly on click', done => { + const wrapper = mount( + + + + ); - const defaultSelectedValue = wrapper.props().severity.display; + const select = wrapper.find(EuiSuperSelect).first(); + const defaultSelectedValue = select.props().valueOfSelected; expect(defaultSelectedValue).toBe('warning'); - select.simulate('change', 'critical'); - const updatedSelectedValue = wrapper.props().severity.display; - expect(updatedSelectedValue).toBe('critical'); + const onChange = select.props().onChange; + + act(() => { + if (onChange !== undefined) { + onChange('critical'); + } + }); + + setImmediate(() => { + wrapper.update(); + const updatedSelect = wrapper.find(EuiSuperSelect).first(); + const updatedSelectedValue = updatedSelect.props().valueOfSelected; + expect(updatedSelectedValue).toBe('critical'); + done(); + }); }); }); diff --git a/x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/select_severity.tsx b/x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/select_severity.tsx new file mode 100644 index 0000000000000..a03594a5f213e --- /dev/null +++ b/x-pack/legacy/plugins/ml/public/application/components/controls/select_severity/select_severity.tsx @@ -0,0 +1,141 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +/* + * React component for rendering a select element with threshold levels. + */ +import React, { Fragment, FC } from 'react'; +import { i18n } from '@kbn/i18n'; +import { FormattedMessage } from '@kbn/i18n/react'; + +import { EuiHealth, EuiSpacer, EuiSuperSelect, EuiText } from '@elastic/eui'; + +import { getSeverityColor } from '../../../../../common/util/anomaly_utils'; +import { useUrlState } from '../../../util/url_state'; + +const warningLabel = i18n.translate('xpack.ml.controls.selectSeverity.warningLabel', { + defaultMessage: 'warning', +}); +const minorLabel = i18n.translate('xpack.ml.controls.selectSeverity.minorLabel', { + defaultMessage: 'minor', +}); +const majorLabel = i18n.translate('xpack.ml.controls.selectSeverity.majorLabel', { + defaultMessage: 'major', +}); +const criticalLabel = i18n.translate('xpack.ml.controls.selectSeverity.criticalLabel', { + defaultMessage: 'critical', +}); + +const optionsMap = { + [warningLabel]: 0, + [minorLabel]: 25, + [majorLabel]: 50, + [criticalLabel]: 75, +}; + +interface TableSeverity { + val: number; + display: string; + color: string; +} + +export const SEVERITY_OPTIONS: TableSeverity[] = [ + { + val: 0, + display: warningLabel, + color: getSeverityColor(0), + }, + { + val: 25, + display: minorLabel, + color: getSeverityColor(25), + }, + { + val: 50, + display: majorLabel, + color: getSeverityColor(50), + }, + { + val: 75, + display: criticalLabel, + color: getSeverityColor(75), + }, +]; + +function optionValueToThreshold(value: number) { + // Get corresponding threshold object with required display and val properties from the specified value. + let threshold = SEVERITY_OPTIONS.find(opt => opt.val === value); + + // Default to warning if supplied value doesn't map to one of the options. + if (threshold === undefined) { + threshold = SEVERITY_OPTIONS[0]; + } + + return threshold; +} + +const TABLE_SEVERITY_DEFAULT = SEVERITY_OPTIONS[0]; +const TABLE_SEVERITY_APP_STATE_NAME = 'mlSelectSeverity'; + +export const useTableSeverity = () => { + const [appState, setAppState] = useUrlState('_a'); + + return [ + (appState && appState[TABLE_SEVERITY_APP_STATE_NAME]) || TABLE_SEVERITY_DEFAULT, + (d: TableSeverity) => setAppState(TABLE_SEVERITY_APP_STATE_NAME, d), + ]; +}; + +const getSeverityOptions = () => + SEVERITY_OPTIONS.map(({ color, display, val }) => ({ + value: display, + inputDisplay: ( + + + {display} + + + ), + dropdownDisplay: ( + + + {display} + + + +

+ +

+
+
+ ), + })); + +interface Props { + classNames?: string; +} + +export const SelectSeverity: FC = ({ classNames } = { classNames: '' }) => { + const [severity, setSeverity] = useTableSeverity(); + + const onChange = (valueDisplay: string) => { + setSeverity(optionValueToThreshold(optionsMap[valueDisplay])); + }; + + return ( + + ); +}; diff --git a/x-pack/legacy/plugins/ml/public/application/components/job_selector/index.js b/x-pack/legacy/plugins/ml/public/application/components/job_selector/index.ts similarity index 100% rename from x-pack/legacy/plugins/ml/public/application/components/job_selector/index.js rename to x-pack/legacy/plugins/ml/public/application/components/job_selector/index.ts diff --git a/x-pack/legacy/plugins/ml/public/application/components/job_selector/job_select_service_utils.d.ts b/x-pack/legacy/plugins/ml/public/application/components/job_selector/job_select_service_utils.d.ts deleted file mode 100644 index fe5966524c7e5..0000000000000 --- a/x-pack/legacy/plugins/ml/public/application/components/job_selector/job_select_service_utils.d.ts +++ /dev/null @@ -1,22 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -import { BehaviorSubject } from 'rxjs'; - -import { State } from 'ui/state_management/state'; - -export declare type JobSelectService$ = BehaviorSubject<{ - selection: string[]; - groups: string[]; - resetSelection: boolean; -}>; - -declare interface JobSelectService { - jobSelectService$: JobSelectService$; - unsubscribeFromGlobalState(): void; -} - -export const jobSelectServiceFactory: (globalState: State) => JobSelectService; diff --git a/x-pack/legacy/plugins/ml/public/application/components/job_selector/job_select_service_utils.js b/x-pack/legacy/plugins/ml/public/application/components/job_selector/job_select_service_utils.js deleted file mode 100644 index 7f5c146568648..0000000000000 --- a/x-pack/legacy/plugins/ml/public/application/components/job_selector/job_select_service_utils.js +++ /dev/null @@ -1,261 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -import { difference, isEqual } from 'lodash'; -import { BehaviorSubject } from 'rxjs'; -import { toastNotifications } from 'ui/notify'; -import { i18n } from '@kbn/i18n'; -import moment from 'moment'; -import d3 from 'd3'; - -import { mlJobService } from '../../services/job_service'; - -function warnAboutInvalidJobIds(invalidIds) { - if (invalidIds.length > 0) { - toastNotifications.addWarning( - i18n.translate('xpack.ml.jobSelect.requestedJobsDoesNotExistWarningMessage', { - defaultMessage: `Requested -{invalidIdsLength, plural, one {job {invalidIds} does not exist} other {jobs {invalidIds} do not exist}}`, - values: { - invalidIdsLength: invalidIds.length, - invalidIds, - }, - }) - ); - } -} - -// check that the ids read from the url exist by comparing them to the -// jobs loaded via mlJobsService. -function getInvalidJobIds(ids) { - return ids.filter(id => { - const jobExists = mlJobService.jobs.some(job => job.job_id === id); - return jobExists === false && id !== '*'; - }); -} - -export const jobSelectServiceFactory = globalState => { - const { jobIds, selectedGroups } = getSelectedJobIds(globalState); - const jobSelectService$ = new BehaviorSubject({ - selection: jobIds, - groups: selectedGroups, - resetSelection: false, - }); - - // Subscribe to changes to globalState and trigger - // a jobSelectService update if the job selection changed. - const listener = () => { - const { jobIds: newJobIds, selectedGroups: newSelectedGroups } = getSelectedJobIds(globalState); - const oldSelectedJobIds = jobSelectService$.getValue().selection; - - if (newJobIds && !isEqual(oldSelectedJobIds, newJobIds)) { - jobSelectService$.next({ selection: newJobIds, groups: newSelectedGroups }); - } - }; - - globalState.on('save_with_changes', listener); - - const unsubscribeFromGlobalState = () => { - globalState.off('save_with_changes', listener); - }; - - return { jobSelectService$, unsubscribeFromGlobalState }; -}; - -function loadJobIdsFromGlobalState(globalState) { - // jobIds, groups - // fetch to get the latest state - globalState.fetch(); - - const jobIds = []; - let groups = []; - - if (globalState.ml && globalState.ml.jobIds) { - let tempJobIds = []; - groups = globalState.ml.groups || []; - - if (typeof globalState.ml.jobIds === 'string') { - tempJobIds.push(globalState.ml.jobIds); - } else { - tempJobIds = globalState.ml.jobIds; - } - tempJobIds = tempJobIds.map(id => String(id)); - - const invalidIds = getInvalidJobIds(tempJobIds); - warnAboutInvalidJobIds(invalidIds); - - let validIds = difference(tempJobIds, invalidIds); - // if there are no valid ids, warn and then select the first job - if (validIds.length === 0) { - toastNotifications.addWarning( - i18n.translate('xpack.ml.jobSelect.noJobsSelectedWarningMessage', { - defaultMessage: 'No jobs selected, auto selecting first job', - }) - ); - - if (mlJobService.jobs.length) { - validIds = [mlJobService.jobs[0].job_id]; - } - } - jobIds.push(...validIds); - } else { - // no jobs selected, use the first in the list - if (mlJobService.jobs.length) { - jobIds.push(mlJobService.jobs[0].job_id); - } - } - return { jobIds, selectedGroups: groups }; -} - -// TODO: -// Merge `setGlobalStateSkipRefresh()` and `setGlobalState()` into -// a single function similar to how we do `appStateHandler()`. -// When changing jobs in job selector it would trigger multiple events -// which in return would be consumed by Single Metric Viewer and could cause -// race conditions when updating the whole page. Because we don't control -// the internals of the involved timefilter event triggering, we use -// a global `skipRefresh` to control when Single Metric Viewer should -// skip updates triggered by timefilter. -export function setGlobalStateSkipRefresh(globalState, skipRefresh) { - globalState.fetch(); - if (globalState.ml === undefined) { - globalState.ml = {}; - } - globalState.ml.skipRefresh = skipRefresh; - globalState.save(); -} - -export function setGlobalState(globalState, { selectedIds, selectedGroups, skipRefresh }) { - globalState.fetch(); - if (globalState.ml === undefined) { - globalState.ml = {}; - } - globalState.ml.jobIds = selectedIds; - globalState.ml.groups = selectedGroups || []; - globalState.ml.skipRefresh = !!skipRefresh; - globalState.save(); -} - -// called externally to retrieve the selected jobs ids -export function getSelectedJobIds(globalState) { - return loadJobIdsFromGlobalState(globalState); -} - -export function getGroupsFromJobs(jobs) { - const groups = {}; - const groupsMap = {}; - - jobs.forEach(job => { - // Organize job by group - if (job.groups !== undefined) { - job.groups.forEach(g => { - if (groups[g] === undefined) { - groups[g] = { - id: g, - jobIds: [job.job_id], - timeRange: { - to: job.timeRange.to, - toMoment: null, - from: job.timeRange.from, - fromMoment: null, - fromPx: job.timeRange.fromPx, - toPx: job.timeRange.toPx, - widthPx: null, - }, - }; - - groupsMap[g] = [job.job_id]; - } else { - groups[g].jobIds.push(job.job_id); - groupsMap[g].push(job.job_id); - // keep track of earliest 'from' / latest 'to' for group range - if (groups[g].timeRange.to === null || job.timeRange.to > groups[g].timeRange.to) { - groups[g].timeRange.to = job.timeRange.to; - groups[g].timeRange.toMoment = job.timeRange.toMoment; - } - if (groups[g].timeRange.from === null || job.timeRange.from < groups[g].timeRange.from) { - groups[g].timeRange.from = job.timeRange.from; - groups[g].timeRange.fromMoment = job.timeRange.fromMoment; - } - if (groups[g].timeRange.toPx === null || job.timeRange.toPx > groups[g].timeRange.toPx) { - groups[g].timeRange.toPx = job.timeRange.toPx; - } - if ( - groups[g].timeRange.fromPx === null || - job.timeRange.fromPx < groups[g].timeRange.fromPx - ) { - groups[g].timeRange.fromPx = job.timeRange.fromPx; - } - } - }); - } - }); - - Object.keys(groups).forEach(groupId => { - const group = groups[groupId]; - group.timeRange.widthPx = group.timeRange.toPx - group.timeRange.fromPx; - group.timeRange.toMoment = moment(group.timeRange.to); - group.timeRange.fromMoment = moment(group.timeRange.from); - // create label - const fromString = group.timeRange.fromMoment.format('MMM Do YYYY, HH:mm'); - const toString = group.timeRange.toMoment.format('MMM Do YYYY, HH:mm'); - group.timeRange.label = i18n.translate('xpack.ml.jobSelectList.groupTimeRangeLabel', { - defaultMessage: '{fromString} to {toString}', - values: { - fromString, - toString, - }, - }); - }); - - return { groups: Object.keys(groups).map(g => groups[g]), groupsMap }; -} - -export function normalizeTimes(jobs, dateFormatTz, ganttBarWidth) { - const jobsWithTimeRange = jobs.filter(job => { - return job.timeRange.to !== undefined && job.timeRange.from !== undefined; - }); - - const min = Math.min(...jobsWithTimeRange.map(job => +job.timeRange.from)); - const max = Math.max(...jobsWithTimeRange.map(job => +job.timeRange.to)); - const ganttScale = d3.scale - .linear() - .domain([min, max]) - .range([1, ganttBarWidth]); - - jobs.forEach(job => { - if (job.timeRange.to !== undefined && job.timeRange.from !== undefined) { - job.timeRange.fromPx = ganttScale(job.timeRange.from); - job.timeRange.toPx = ganttScale(job.timeRange.to); - job.timeRange.widthPx = job.timeRange.toPx - job.timeRange.fromPx; - // Ensure at least 1 px in width so it's always visible - if (job.timeRange.widthPx < 1) { - job.timeRange.widthPx = 1; - } - - job.timeRange.toMoment = moment(job.timeRange.to).tz(dateFormatTz); - job.timeRange.fromMoment = moment(job.timeRange.from).tz(dateFormatTz); - - const fromString = job.timeRange.fromMoment.format('MMM Do YYYY, HH:mm'); - const toString = job.timeRange.toMoment.format('MMM Do YYYY, HH:mm'); - job.timeRange.label = i18n.translate('xpack.ml.jobSelector.jobTimeRangeLabel', { - defaultMessage: '{fromString} to {toString}', - values: { - fromString, - toString, - }, - }); - } else { - job.timeRange.widthPx = 0; - job.timeRange.fromPx = 0; - job.timeRange.toPx = 0; - job.timeRange.label = i18n.translate('xpack.ml.jobSelector.noResultsForJobLabel', { - defaultMessage: 'No results', - }); - } - }); - return jobs; -} diff --git a/x-pack/legacy/plugins/ml/public/application/components/job_selector/job_select_service_utils.ts b/x-pack/legacy/plugins/ml/public/application/components/job_selector/job_select_service_utils.ts new file mode 100644 index 0000000000000..1484f0a391b67 --- /dev/null +++ b/x-pack/legacy/plugins/ml/public/application/components/job_selector/job_select_service_utils.ts @@ -0,0 +1,156 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { i18n } from '@kbn/i18n'; +import moment from 'moment'; +import d3 from 'd3'; + +import { Dictionary } from '../../../../common/types/common'; +import { MlJobWithTimeRange } from '../../../../common/types/jobs'; + +export function getGroupsFromJobs(jobs: MlJobWithTimeRange[]) { + const groups: Dictionary = {}; + const groupsMap: Dictionary = {}; + + jobs.forEach(job => { + // Organize job by group + if (job.groups !== undefined) { + job.groups.forEach(g => { + if (groups[g] === undefined) { + groups[g] = { + id: g, + jobIds: [job.job_id], + timeRange: { + to: job.timeRange.to, + toMoment: null, + from: job.timeRange.from, + fromMoment: null, + fromPx: job.timeRange.fromPx, + toPx: job.timeRange.toPx, + widthPx: null, + }, + }; + + groupsMap[g] = [job.job_id]; + } else { + groups[g].jobIds.push(job.job_id); + groupsMap[g].push(job.job_id); + // keep track of earliest 'from' / latest 'to' for group range + if (groups[g].timeRange.to === null || job.timeRange.to > groups[g].timeRange.to) { + groups[g].timeRange.to = job.timeRange.to; + groups[g].timeRange.toMoment = job.timeRange.toMoment; + } + if (groups[g].timeRange.from === null || job.timeRange.from < groups[g].timeRange.from) { + groups[g].timeRange.from = job.timeRange.from; + groups[g].timeRange.fromMoment = job.timeRange.fromMoment; + } + if (groups[g].timeRange.toPx === null || job.timeRange.toPx > groups[g].timeRange.toPx) { + groups[g].timeRange.toPx = job.timeRange.toPx; + } + if ( + groups[g].timeRange.fromPx === null || + job.timeRange.fromPx < groups[g].timeRange.fromPx + ) { + groups[g].timeRange.fromPx = job.timeRange.fromPx; + } + } + }); + } + }); + + Object.keys(groups).forEach(groupId => { + const group = groups[groupId]; + group.timeRange.widthPx = group.timeRange.toPx - group.timeRange.fromPx; + group.timeRange.toMoment = moment(group.timeRange.to); + group.timeRange.fromMoment = moment(group.timeRange.from); + // create label + const fromString = group.timeRange.fromMoment.format('MMM Do YYYY, HH:mm'); + const toString = group.timeRange.toMoment.format('MMM Do YYYY, HH:mm'); + group.timeRange.label = i18n.translate('xpack.ml.jobSelectList.groupTimeRangeLabel', { + defaultMessage: '{fromString} to {toString}', + values: { + fromString, + toString, + }, + }); + }); + + return { groups: Object.keys(groups).map(g => groups[g]), groupsMap }; +} + +export function getTimeRangeFromSelection(jobs: MlJobWithTimeRange[], selection: string[]) { + if (jobs.length > 0) { + const times: number[] = []; + jobs.forEach(job => { + if (selection.includes(job.job_id)) { + if (job.timeRange.from !== undefined) { + times.push(job.timeRange.from); + } + if (job.timeRange.to !== undefined) { + times.push(job.timeRange.to); + } + } + }); + if (times.length) { + const extent = d3.extent(times); + const selectedTime = { + from: moment(extent[0]).toISOString(), + to: moment(extent[1]).toISOString(), + }; + return selectedTime; + } + } +} + +export function normalizeTimes( + jobs: MlJobWithTimeRange[], + dateFormatTz: string, + ganttBarWidth: number +) { + const jobsWithTimeRange = jobs.filter(job => { + return job.timeRange.to !== undefined && job.timeRange.from !== undefined; + }); + + const min = Math.min(...jobsWithTimeRange.map(job => +job.timeRange.from)); + const max = Math.max(...jobsWithTimeRange.map(job => +job.timeRange.to)); + const ganttScale = d3.scale + .linear() + .domain([min, max]) + .range([1, ganttBarWidth]); + + jobs.forEach(job => { + if (job.timeRange.to !== undefined && job.timeRange.from !== undefined) { + job.timeRange.fromPx = ganttScale(job.timeRange.from); + job.timeRange.toPx = ganttScale(job.timeRange.to); + job.timeRange.widthPx = job.timeRange.toPx - job.timeRange.fromPx; + // Ensure at least 1 px in width so it's always visible + if (job.timeRange.widthPx < 1) { + job.timeRange.widthPx = 1; + } + + job.timeRange.toMoment = moment(job.timeRange.to).tz(dateFormatTz); + job.timeRange.fromMoment = moment(job.timeRange.from).tz(dateFormatTz); + + const fromString = job.timeRange.fromMoment.format('MMM Do YYYY, HH:mm'); + const toString = job.timeRange.toMoment.format('MMM Do YYYY, HH:mm'); + job.timeRange.label = i18n.translate('xpack.ml.jobSelector.jobTimeRangeLabel', { + defaultMessage: '{fromString} to {toString}', + values: { + fromString, + toString, + }, + }); + } else { + job.timeRange.widthPx = 0; + job.timeRange.fromPx = 0; + job.timeRange.toPx = 0; + job.timeRange.label = i18n.translate('xpack.ml.jobSelector.noResultsForJobLabel', { + defaultMessage: 'No results', + }); + } + }); + return jobs; +} diff --git a/x-pack/legacy/plugins/ml/public/application/components/job_selector/job_selector.js b/x-pack/legacy/plugins/ml/public/application/components/job_selector/job_selector.tsx similarity index 74% rename from x-pack/legacy/plugins/ml/public/application/components/job_selector/job_selector.js rename to x-pack/legacy/plugins/ml/public/application/components/job_selector/job_selector.tsx index b86118c451bb7..f1d9dcb0ec795 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/job_selector/job_selector.js +++ b/x-pack/legacy/plugins/ml/public/application/components/job_selector/job_selector.tsx @@ -4,23 +4,9 @@ * you may not use this file except in compliance with the Elastic License. */ -import { isEqual } from 'lodash'; import React, { useState, useEffect, useRef, useCallback } from 'react'; -import { PropTypes } from 'prop-types'; -import moment from 'moment'; +import PropTypes from 'prop-types'; -import { ml } from '../../services/ml_api_service'; -import { JobSelectorTable } from './job_selector_table'; -import { IdBadges } from './id_badges'; -import { NewSelectionIdBadges } from './new_selection_id_badges'; -import { timefilter } from 'ui/timefilter'; -import { - getGroupsFromJobs, - normalizeTimes, - setGlobalState, - setGlobalStateSkipRefresh, -} from './job_select_service_utils'; -import { toastNotifications } from 'ui/notify'; import { EuiButton, EuiButtonEmpty, @@ -33,15 +19,42 @@ import { EuiSwitch, EuiTitle, } from '@elastic/eui'; + import { i18n } from '@kbn/i18n'; -function mergeSelection(jobIds, groupObjs, singleSelection) { +import { toastNotifications } from 'ui/notify'; + +import { Dictionary } from '../../../../common/types/common'; +import { MlJobWithTimeRange } from '../../../../common/types/jobs'; +import { ml } from '../../services/ml_api_service'; +import { useUrlState } from '../../util/url_state'; +// @ts-ignore +import { JobSelectorTable } from './job_selector_table'; +// @ts-ignore +import { IdBadges } from './id_badges'; +// @ts-ignore +import { NewSelectionIdBadges } from './new_selection_id_badges'; +import { + getGroupsFromJobs, + getTimeRangeFromSelection, + normalizeTimes, +} from './job_select_service_utils'; + +interface GroupObj { + groupId: string; + jobIds: string[]; +} +function mergeSelection( + jobIds: string[], + groupObjs: GroupObj[], + singleSelection: boolean +): string[] { if (singleSelection) { return jobIds; } - const selectedIds = []; - const alreadySelected = []; + const selectedIds: string[] = []; + const alreadySelected: string[] = []; groupObjs.forEach(group => { selectedIds.push(group.groupId); @@ -58,8 +71,9 @@ function mergeSelection(jobIds, groupObjs, singleSelection) { return selectedIds; } -function getInitialGroupsMap(selectedGroups) { - const map = {}; +type GroupsMap = Dictionary; +function getInitialGroupsMap(selectedGroups: GroupObj[]): GroupsMap { + const map: GroupsMap = {}; if (selectedGroups.length) { selectedGroups.forEach(group => { @@ -73,17 +87,20 @@ function getInitialGroupsMap(selectedGroups) { const BADGE_LIMIT = 10; const DEFAULT_GANTT_BAR_WIDTH = 299; // pixels -export function JobSelector({ - dateFormatTz, - globalState, - jobSelectService$, - selectedJobIds, - selectedGroups, - singleSelection, - timeseriesOnly, -}) { - const [jobs, setJobs] = useState([]); - const [groups, setGroups] = useState([]); +interface JobSelectorProps { + dateFormatTz: string; + singleSelection: boolean; + timeseriesOnly: boolean; +} + +export function JobSelector({ dateFormatTz, singleSelection, timeseriesOnly }: JobSelectorProps) { + const [globalState, setGlobalState] = useUrlState('_g'); + + const selectedJobIds = globalState?.ml?.jobIds ?? []; + const selectedGroups = globalState?.ml?.groups ?? []; + + const [jobs, setJobs] = useState([]); + const [groups, setGroups] = useState([]); const [maps, setMaps] = useState({ groupsMap: getInitialGroupsMap(selectedGroups), jobsMap: {} }); const [selectedIds, setSelectedIds] = useState( mergeSelection(selectedJobIds, selectedGroups, singleSelection) @@ -96,20 +113,12 @@ export function JobSelector({ const [applyTimeRange, setApplyTimeRange] = useState(true); const [isFlyoutVisible, setIsFlyoutVisible] = useState(false); const [ganttBarWidth, setGanttBarWidth] = useState(DEFAULT_GANTT_BAR_WIDTH); - const flyoutEl = useRef(null); + const flyoutEl = useRef<{ flyout: HTMLElement }>(null); + // Ensure JobSelectionBar gets updated when selection via globalState changes. useEffect(() => { - // listen for update from Single Metric Viewer - const subscription = jobSelectService$.subscribe(({ selection, resetSelection }) => { - if (resetSelection === true) { - setSelectedIds(selection); - } - }); - - return function cleanup() { - subscription.unsubscribe(); - }; - }, []); // eslint-disable-line + setSelectedIds(mergeSelection(selectedJobIds, selectedGroups, singleSelection)); + }, [JSON.stringify([selectedJobIds, selectedGroups])]); // Ensure current selected ids always show up in flyout useEffect(() => { @@ -121,7 +130,9 @@ export function JobSelector({ const handleResize = useCallback(() => { if (jobs.length > 0 && flyoutEl && flyoutEl.current && flyoutEl.current.flyout) { // get all cols in flyout table - const tableHeaderCols = flyoutEl.current.flyout.querySelectorAll('table thead th'); + const tableHeaderCols: NodeListOf = flyoutEl.current.flyout.querySelectorAll( + 'table thead th' + ); // get the width of the last col const derivedWidth = tableHeaderCols[tableHeaderCols.length - 1].offsetWidth - 16; const normalizedJobs = normalizeTimes(jobs, dateFormatTz, derivedWidth); @@ -145,21 +156,12 @@ export function JobSelector({ handleResize(); }, [handleResize, jobs]); - // On opening and closing the flyout, optionally update a global `skipRefresh` flag. - // This allows us to circumvent race conditions which could happen by triggering both - // timefilter and job selector related events in Single Metric Viewer. - function closeFlyout(setSkipRefresh = true) { + function closeFlyout() { setIsFlyoutVisible(false); - if (setSkipRefresh) { - setGlobalStateSkipRefresh(globalState, false); - } } - function showFlyout(setSkipRefresh = true) { + function showFlyout() { setIsFlyoutVisible(true); - if (setSkipRefresh) { - setGlobalStateSkipRefresh(globalState, true); - } } function handleJobSelectionClick() { @@ -174,8 +176,8 @@ export function JobSelector({ setGroups(groupsWithTimerange); setMaps({ groupsMap, jobsMap: resp.jobsMap }); }) - .catch(err => { - console.log('Error fetching jobs', err); + .catch((err: any) => { + console.error('Error fetching jobs with time range', err); // eslint-disable-line toastNotifications.addDanger({ title: i18n.translate('xpack.ml.jobSelector.jobFetchErrorMessage', { defaultMessage: 'An error occurred fetching jobs. Refresh and try again.', @@ -184,14 +186,14 @@ export function JobSelector({ }); } - function handleNewSelection({ selectionFromTable }) { + function handleNewSelection({ selectionFromTable }: { selectionFromTable: any }) { setNewSelection(selectionFromTable); } function applySelection() { // allNewSelection will be a list of all job ids (including those from groups) selected from the table - const allNewSelection = []; - const groupSelection = []; + const allNewSelection: string[] = []; + const groupSelection: Array<{ groupId: string; jobIds: string[] }> = []; newSelection.forEach(id => { if (maps.groupsMap[id] !== undefined) { @@ -206,68 +208,29 @@ export function JobSelector({ // create a Set to remove duplicate values const allNewSelectionUnique = Array.from(new Set(allNewSelection)); - const isPrevousSelection = isEqual( - { selectedJobIds, selectedGroups }, - { selectedJobIds: allNewSelectionUnique, selectedGroups: groupSelection } - ); - setSelectedIds(newSelection); setNewSelection([]); - // If the job selection is unchanged, then we close the modal and - // disable skipping the timefilter listener flag in globalState. - // If the job selection changed, this will not - // update skipRefresh yet to avoid firing multiple events via - // applyTimeRangeFromSelection() and setGlobalState(). - closeFlyout(isPrevousSelection); - - // If the job selection changed, then when - // calling `applyTimeRangeFromSelection()` here - // Single Metric Viewer will skip an update - // triggered by timefilter to avoid a race - // condition caused by the job update listener - // that's also going to be triggered. - applyTimeRangeFromSelection(allNewSelectionUnique); - - // Set `skipRefresh` again to `false` here so after - // both the time range and jobs have been updated - // Single Metric Viewer should again update itself. - setGlobalState(globalState, { - selectedIds: allNewSelectionUnique, - selectedGroups: groupSelection, - skipRefresh: false, - }); - } + closeFlyout(); - function applyTimeRangeFromSelection(selection) { - if (applyTimeRange && jobs.length > 0) { - const times = []; - jobs.forEach(job => { - if (selection.includes(job.job_id)) { - if (job.timeRange.from !== undefined) { - times.push(job.timeRange.from); - } - if (job.timeRange.to !== undefined) { - times.push(job.timeRange.to); - } - } - }); - if (times.length) { - const min = Math.min(...times); - const max = Math.max(...times); - timefilter.setTime({ - from: moment(min).toISOString(), - to: moment(max).toISOString(), - }); - } - } + const time = applyTimeRange + ? getTimeRangeFromSelection(jobs, allNewSelectionUnique) + : undefined; + + setGlobalState({ + ml: { + jobIds: allNewSelectionUnique, + groups: groupSelection, + }, + ...(time !== undefined ? { time } : {}), + }); } function toggleTimerangeSwitch() { setApplyTimeRange(!applyTimeRange); } - function removeId(id) { + function removeId(id: string) { setNewSelection(newSelection.filter(item => item !== id)); } @@ -315,6 +278,7 @@ export function JobSelector({ if (isFlyoutVisible) { return ( { + const jobExists = jobs.some(job => job.job_id === id); + return jobExists === false && id !== '*'; + }); +} + +function warnAboutInvalidJobIds(invalidIds: string[]) { + if (invalidIds.length > 0) { + toastNotifications.addWarning( + i18n.translate('xpack.ml.jobSelect.requestedJobsDoesNotExistWarningMessage', { + defaultMessage: `Requested +{invalidIdsLength, plural, one {job {invalidIds} does not exist} other {jobs {invalidIds} do not exist}}`, + values: { + invalidIdsLength: invalidIds.length, + invalidIds: invalidIds.join(), + }, + }) + ); + } +} + +export interface JobSelection { + jobIds: string[]; + selectedGroups: string[]; +} + +export const useJobSelection = (jobs: MlJobWithTimeRange[], dateFormatTz: string) => { + const [globalState, setGlobalState] = useUrlState('_g'); + + const jobSelection: JobSelection = { jobIds: [], selectedGroups: [] }; + + const ids = globalState?.ml?.jobIds || []; + const tmpIds = (typeof ids === 'string' ? [ids] : ids).map((id: string) => String(id)); + const invalidIds = getInvalidJobIds(jobs, tmpIds); + const validIds = difference(tmpIds, invalidIds); + validIds.sort(); + + jobSelection.jobIds = validIds; + jobSelection.selectedGroups = globalState?.ml?.groups ?? []; + + useEffect(() => { + warnAboutInvalidJobIds(invalidIds); + }, [invalidIds]); + + useEffect(() => { + // if there are no valid ids, warn and then select the first job + if (validIds.length === 0 && jobs.length > 0) { + toastNotifications.addWarning( + i18n.translate('xpack.ml.jobSelect.noJobsSelectedWarningMessage', { + defaultMessage: 'No jobs selected, auto selecting first job', + }) + ); + + const mlGlobalState = globalState?.ml || {}; + mlGlobalState.jobIds = [jobs[0].job_id]; + + const time = getTimeRangeFromSelection(jobs, mlGlobalState.jobIds); + + setGlobalState({ + ...{ ml: mlGlobalState }, + ...(time !== undefined ? { time } : {}), + }); + } + }, [jobs, validIds]); + + return jobSelection; +}; diff --git a/x-pack/legacy/plugins/ml/public/application/components/navigation_menu/tabs.tsx b/x-pack/legacy/plugins/ml/public/application/components/navigation_menu/tabs.tsx index 20fa2cca41231..ac83d598f2382 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/navigation_menu/tabs.tsx +++ b/x-pack/legacy/plugins/ml/public/application/components/navigation_menu/tabs.tsx @@ -5,8 +5,14 @@ */ import React, { FC, useState } from 'react'; +import { encode } from 'rison-node'; + import { EuiTabs, EuiTab, EuiLink } from '@elastic/eui'; + import { i18n } from '@kbn/i18n'; + +import { useUrlState } from '../../util/url_state'; + import { Tab } from './main_tabs'; import { TabId } from './navigation_menu'; @@ -67,6 +73,7 @@ enum TAB_TEST_SUBJECT { type TAB_TEST_SUBJECTS = keyof typeof TAB_TEST_SUBJECT; export const Tabs: FC = ({ tabId, mainTabId, disableLinks }) => { + const [globalState] = useUrlState('_g'); const [selectedTabId, setSelectedTabId] = useState(tabId); function onSelectedTabChanged(id: string) { setSelectedTabId(id); @@ -78,12 +85,16 @@ export const Tabs: FC = ({ tabId, mainTabId, disableLinks }) => { {tabs.map((tab: Tab) => { const id = tab.id; + // globalState (e.g. selected jobs and time range) should be retained when changing pages. + // appState will not be considered. + const fullGlobalStateString = globalState !== undefined ? `?_g=${encode(globalState)}` : ''; + return ( diff --git a/x-pack/legacy/plugins/ml/public/application/components/navigation_menu/top_nav/top_nav.tsx b/x-pack/legacy/plugins/ml/public/application/components/navigation_menu/top_nav/top_nav.tsx index 523970dfe12f8..ca6146f3e23b5 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/navigation_menu/top_nav/top_nav.tsx +++ b/x-pack/legacy/plugins/ml/public/application/components/navigation_menu/top_nav/top_nav.tsx @@ -6,11 +6,14 @@ import React, { FC, Fragment, useState, useEffect } from 'react'; import { Subscription } from 'rxjs'; -import { EuiSuperDatePicker } from '@elastic/eui'; +import { EuiSuperDatePicker, OnRefreshProps } from '@elastic/eui'; import { TimeHistory } from 'ui/timefilter'; import { TimeRange } from 'src/plugins/data/public'; -import { mlTimefilterRefresh$ } from '../../../services/timefilter_refresh_service'; +import { + mlTimefilterRefresh$, + mlTimefilterTimeChange$, +} from '../../../services/timefilter_refresh_service'; import { useUiContext } from '../../../contexts/ui/use_ui_context'; interface Duration { @@ -29,6 +32,10 @@ function getRecentlyUsedRangesFactory(timeHistory: TimeHistory) { }; } +function updateLastRefresh(timeRange: OnRefreshProps) { + mlTimefilterRefresh$.next({ lastRefresh: Date.now(), timeRange }); +} + export const TopNav: FC = () => { const { chrome, timefilter, timeHistory } = useUiContext(); const getRecentlyUsedRanges = getRecentlyUsedRangesFactory(timeHistory); @@ -74,6 +81,7 @@ export const TopNav: FC = () => { timefilter.setTime(newTime); setTime(newTime); setRecentlyUsedRanges(getRecentlyUsedRanges()); + mlTimefilterTimeChange$.next({ lastRefresh: Date.now(), timeRange: { start, end } }); } function updateInterval({ @@ -104,7 +112,7 @@ export const TopNav: FC = () => { isAutoRefreshOnly={!isTimeRangeSelectorEnabled} refreshInterval={refreshInterval.value} onTimeChange={updateFilter} - onRefresh={() => mlTimefilterRefresh$.next()} + onRefresh={updateLastRefresh} onRefreshChange={updateInterval} recentlyUsedRanges={recentlyUsedRanges} dateFormat={dateFormat} diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/__tests__/explorer_directive.js b/x-pack/legacy/plugins/ml/public/application/explorer/__tests__/explorer_directive.js deleted file mode 100644 index 4626ee48b53f7..0000000000000 --- a/x-pack/legacy/plugins/ml/public/application/explorer/__tests__/explorer_directive.js +++ /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; - * you may not use this file except in compliance with the Elastic License. - */ - -import ngMock from 'ng_mock'; -import sinon from 'sinon'; -import expect from '@kbn/expect'; - -import { - uiChromeMock, - uiTimefilterMock, - uiTimeHistoryMock, -} from '../../contexts/ui/__mocks__/mocks_mocha'; -import * as useUiContextModule from '../../contexts/ui/use_ui_context'; -import * as UiTimefilterModule from 'ui/timefilter'; - -describe('ML - Anomaly Explorer Directive', () => { - let $scope; - let $compile; - let $element; - let stubContext; - let stubTimefilterFetch; - - beforeEach(ngMock.module('kibana')); - beforeEach(() => { - ngMock.inject(function($injector) { - stubContext = sinon.stub(useUiContextModule, 'useUiContext').callsFake(function fakeFn() { - return { - chrome: uiChromeMock, - timefilter: uiTimefilterMock, - timeHistory: uiTimeHistoryMock, - }; - }); - stubTimefilterFetch = sinon - .stub(UiTimefilterModule.timefilter, 'getFetch$') - .callsFake(uiTimefilterMock.getFetch$); - - $compile = $injector.get('$compile'); - const $rootScope = $injector.get('$rootScope'); - $scope = $rootScope.$new(); - }); - }); - - afterEach(() => { - stubContext.restore(); - stubTimefilterFetch.restore(); - $scope.$destroy(); - }); - - it('Initialize Anomaly Explorer Directive', done => { - ngMock.inject(function() { - expect(() => { - $element = $compile('')($scope); - }).to.not.throwError(); - - // directive has scope: false - const scope = $element.isolateScope(); - expect(scope).to.eql(undefined); - done(); - }); - }); -}); diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/actions/index.ts b/x-pack/legacy/plugins/ml/public/application/explorer/actions/index.ts index 1528a7ce7eee1..a16081892cdc8 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/actions/index.ts +++ b/x-pack/legacy/plugins/ml/public/application/explorer/actions/index.ts @@ -5,4 +5,4 @@ */ export { jobSelectionActionCreator } from './job_selection'; -export { loadExplorerData } from './load_explorer_data'; +export { useExplorerData } from './load_explorer_data'; diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/actions/job_selection.ts b/x-pack/legacy/plugins/ml/public/application/explorer/actions/job_selection.ts index 76d66bfbbf12b..994d67bfdb02c 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/actions/job_selection.ts +++ b/x-pack/legacy/plugins/ml/public/application/explorer/actions/job_selection.ts @@ -10,13 +10,10 @@ import { map } from 'rxjs/operators'; import { mlFieldFormatService } from '../../services/field_format_service'; import { mlJobService } from '../../services/job_service'; -import { createJobs, RestoredAppState } from '../explorer_utils'; +import { EXPLORER_ACTION } from '../explorer_constants'; +import { createJobs } from '../explorer_utils'; -export function jobSelectionActionCreator( - actionName: string, - selectedJobIds: string[], - { filterData, selectedCells, viewBySwimlaneFieldName }: RestoredAppState -) { +export function jobSelectionActionCreator(selectedJobIds: string[]) { return from(mlFieldFormatService.populateFormats(selectedJobIds)).pipe( map(resp => { if (resp.err) { @@ -32,13 +29,10 @@ export function jobSelectionActionCreator( const selectedJobs = jobs.filter(job => job.selected); return { - type: actionName, + type: EXPLORER_ACTION.JOB_SELECTION_CHANGE, payload: { loading: false, - selectedCells, selectedJobs, - viewBySwimlaneFieldName, - filterData, }, }; }) diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/actions/load_explorer_data.ts b/x-pack/legacy/plugins/ml/public/application/explorer/actions/load_explorer_data.ts index 6d4edd909fa8f..ed73405134224 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/actions/load_explorer_data.ts +++ b/x-pack/legacy/plugins/ml/public/application/explorer/actions/load_explorer_data.ts @@ -6,11 +6,12 @@ import memoizeOne from 'memoize-one'; import { isEqual } from 'lodash'; +import useObservable from 'react-use/lib/useObservable'; -import { forkJoin, of } from 'rxjs'; -import { mergeMap, tap } from 'rxjs/operators'; +import { forkJoin, of, Observable, Subject } from 'rxjs'; +import { mergeMap, switchMap, tap } from 'rxjs/operators'; -import { explorerChartsContainerServiceFactory } from '../explorer_charts/explorer_charts_container_service'; +import { anomalyDataChange } from '../explorer_charts/explorer_charts_container_service'; import { VIEW_BY_JOB_LABEL } from '../explorer_constants'; import { explorerService } from '../explorer_dashboard_service'; import { @@ -25,35 +26,82 @@ import { loadTopInfluencers, loadViewBySwimlane, loadViewByTopFieldValuesForSelectedTime, + AppStateSelectedCells, + ExplorerJob, + TimeRangeBounds, } from '../explorer_utils'; import { ExplorerState } from '../reducers'; +// Memoize the data fetching methods. +// wrapWithLastRefreshArg() wraps any given function and preprends a `lastRefresh` argument +// which will be considered by memoizeOne. This way we can add the `lastRefresh` argument as a +// caching parameter without having to change all the original functions which shouldn't care +// about this parameter. The generic type T retains and returns the type information of +// the original function. const memoizeIsEqual = (newArgs: any[], lastArgs: any[]) => isEqual(newArgs, lastArgs); +const wrapWithLastRefreshArg = any>(func: T) => { + return function(lastRefresh: number, ...args: Parameters): ReturnType { + return func.apply(null, args); + }; +}; +const memoize = any>(func: T) => { + return memoizeOne(wrapWithLastRefreshArg(func), memoizeIsEqual); +}; -// Memoize the data fetching methods -// TODO: We need to track an attribute that allows refetching when the date picker -// triggers a refresh, otherwise we'll get back the stale data. Note this was also -// an issue with the previous version and the custom caching done within the component. -const memoizedLoadAnnotationsTableData = memoizeOne(loadAnnotationsTableData, memoizeIsEqual); -const memoizedLoadDataForCharts = memoizeOne(loadDataForCharts, memoizeIsEqual); -const memoizedLoadFilteredTopInfluencers = memoizeOne(loadFilteredTopInfluencers, memoizeIsEqual); -const memoizedLoadOverallData = memoizeOne(loadOverallData, memoizeIsEqual); -const memoizedLoadTopInfluencers = memoizeOne(loadTopInfluencers, memoizeIsEqual); -const memoizedLoadViewBySwimlane = memoizeOne(loadViewBySwimlane, memoizeIsEqual); -const memoizedLoadAnomaliesTableData = memoizeOne(loadAnomaliesTableData, memoizeIsEqual); +const memoizedAnomalyDataChange = memoize(anomalyDataChange); +const memoizedLoadAnnotationsTableData = memoize( + loadAnnotationsTableData +); +const memoizedLoadDataForCharts = memoize(loadDataForCharts); +const memoizedLoadFilteredTopInfluencers = memoize( + loadFilteredTopInfluencers +); +const memoizedLoadOverallData = memoize(loadOverallData); +const memoizedLoadTopInfluencers = memoize(loadTopInfluencers); +const memoizedLoadViewBySwimlane = memoize(loadViewBySwimlane); +const memoizedLoadAnomaliesTableData = memoize(loadAnomaliesTableData); const dateFormatTz = getDateFormatTz(); +export interface LoadExplorerDataConfig { + bounds: TimeRangeBounds; + influencersFilterQuery: any; + lastRefresh: number; + noInfluencersConfigured: boolean; + selectedCells: AppStateSelectedCells | undefined; + selectedJobs: ExplorerJob[]; + swimlaneBucketInterval: any; + swimlaneLimit: number; + tableInterval: string; + tableSeverity: number; + viewBySwimlaneFieldName: string; +} + +export const isLoadExplorerDataConfig = (arg: any): arg is LoadExplorerDataConfig => { + return ( + arg !== undefined && + arg.bounds !== undefined && + arg.selectedJobs !== undefined && + arg.selectedJobs !== null && + arg.viewBySwimlaneFieldName !== undefined + ); +}; + /** * Fetches the data necessary for the Anomaly Explorer using observables. * - * @param state ExplorerState + * @param config LoadExplorerDataConfig * * @return Partial */ -export function loadExplorerData(state: ExplorerState) { +function loadExplorerData(config: LoadExplorerDataConfig): Observable> { + if (!isLoadExplorerDataConfig(config)) { + return of({}); + } + const { bounds, + lastRefresh, influencersFilterQuery, noInfluencersConfigured, selectedCells, @@ -63,19 +111,12 @@ export function loadExplorerData(state: ExplorerState) { tableInterval, tableSeverity, viewBySwimlaneFieldName, - } = state; - - if (selectedJobs === null || bounds === undefined || viewBySwimlaneFieldName === undefined) { - return of({}); - } - - // TODO This factory should be refactored so we can load the charts using memoization. - const updateCharts = explorerChartsContainerServiceFactory(explorerService.setCharts); + } = config; const selectionInfluencers = getSelectionInfluencers(selectedCells, viewBySwimlaneFieldName); const jobIds = - selectedCells !== null && selectedCells.viewByFieldName === VIEW_BY_JOB_LABEL + selectedCells !== undefined && selectedCells.viewByFieldName === VIEW_BY_JOB_LABEL ? selectedCells.lanes : selectedJobs.map(d => d.id); @@ -89,12 +130,14 @@ export function loadExplorerData(state: ExplorerState) { // annotationsData, anomalyChartRecords, influencers, overallState, tableData, topFieldValues return forkJoin({ annotationsData: memoizedLoadAnnotationsTableData( + lastRefresh, selectedCells, selectedJobs, swimlaneBucketInterval.asSeconds(), bounds ), anomalyChartRecords: memoizedLoadDataForCharts( + lastRefresh, jobIds, timerange.earliestMs, timerange.latestMs, @@ -105,6 +148,7 @@ export function loadExplorerData(state: ExplorerState) { influencers: selectionInfluencers.length === 0 ? memoizedLoadTopInfluencers( + lastRefresh, jobIds, timerange.earliestMs, timerange.latestMs, @@ -113,8 +157,14 @@ export function loadExplorerData(state: ExplorerState) { influencersFilterQuery ) : Promise.resolve({}), - overallState: memoizedLoadOverallData(selectedJobs, swimlaneBucketInterval, bounds), + overallState: memoizedLoadOverallData( + lastRefresh, + selectedJobs, + swimlaneBucketInterval, + bounds + ), tableData: memoizedLoadAnomaliesTableData( + lastRefresh, selectedCells, selectedJobs, dateFormatTz, @@ -126,7 +176,7 @@ export function loadExplorerData(state: ExplorerState) { influencersFilterQuery ), topFieldValues: - selectedCells !== null && selectedCells.showTopFieldValues === true + selectedCells !== undefined && selectedCells.showTopFieldValues === true ? loadViewByTopFieldValuesForSelectedTime( timerange.earliestMs, timerange.latestMs, @@ -143,10 +193,22 @@ export function loadExplorerData(state: ExplorerState) { tap(explorerService.setViewBySwimlaneLoading), // Trigger a side-effect to update the charts. tap(({ anomalyChartRecords }) => { - if (selectedCells !== null && Array.isArray(anomalyChartRecords)) { - updateCharts(anomalyChartRecords, timerange.earliestMs, timerange.latestMs); + if (selectedCells !== undefined && Array.isArray(anomalyChartRecords)) { + memoizedAnomalyDataChange( + lastRefresh, + anomalyChartRecords, + timerange.earliestMs, + timerange.latestMs, + tableSeverity + ); } else { - updateCharts([], timerange.earliestMs, timerange.latestMs); + memoizedAnomalyDataChange( + lastRefresh, + [], + timerange.earliestMs, + timerange.latestMs, + tableSeverity + ); } }), // Load view-by swimlane data and filtered top influencers. @@ -161,6 +223,7 @@ export function loadExplorerData(state: ExplorerState) { anomalyChartRecords !== undefined && anomalyChartRecords.length > 0 ? memoizedLoadFilteredTopInfluencers( + lastRefresh, jobIds, timerange.earliestMs, timerange.latestMs, @@ -171,6 +234,7 @@ export function loadExplorerData(state: ExplorerState) { ) : Promise.resolve(influencers), viewBySwimlaneState: memoizedLoadViewBySwimlane( + lastRefresh, topFieldValues, { earliest: overallState.overallSwimlaneData.earliest, @@ -183,7 +247,10 @@ export function loadExplorerData(state: ExplorerState) { noInfluencersConfigured ), }), - ({ annotationsData, overallState, tableData }, { influencers, viewBySwimlaneState }) => { + ( + { annotationsData, overallState, tableData }, + { influencers, viewBySwimlaneState } + ): Partial => { return { annotationsData, influencers, @@ -195,3 +262,13 @@ export function loadExplorerData(state: ExplorerState) { ) ); } + +const loadExplorerData$ = new Subject(); +const explorerData$ = loadExplorerData$.pipe( + switchMap((config: LoadExplorerDataConfig) => loadExplorerData(config)) +); + +export const useExplorerData = (): [Partial | undefined, (d: any) => void] => { + const explorerData = useObservable(explorerData$); + return [explorerData, c => loadExplorerData$.next(c)]; +}; diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/explorer.d.ts b/x-pack/legacy/plugins/ml/public/application/explorer/explorer.d.ts index de58b9228c076..b8df021990f58 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/explorer.d.ts +++ b/x-pack/legacy/plugins/ml/public/application/explorer/explorer.d.ts @@ -6,13 +6,17 @@ import { FC } from 'react'; -import { State } from 'ui/state_management/state'; +import { UrlState } from '../util/url_state'; -import { JobSelectService$ } from '../components/job_selector/job_select_service_utils'; +import { JobSelection } from '../components/job_selector/use_job_selection'; + +import { ExplorerState } from '../explorer/reducers'; +import { AppStateSelectedCells } from '../explorer/explorer_utils'; declare interface ExplorerProps { - globalState: State; - jobSelectService$: JobSelectService$; + explorerState: ExplorerState; + showCharts: boolean; + setSelectedCells: (swimlaneSelectedCells: AppStateSelectedCells) => void; } export const Explorer: FC; diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/explorer.js b/x-pack/legacy/plugins/ml/public/application/explorer/explorer.js index bcac1b6405ff8..7907131996578 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/explorer.js +++ b/x-pack/legacy/plugins/ml/public/application/explorer/explorer.js @@ -10,9 +10,10 @@ import PropTypes from 'prop-types'; import React, { createRef } from 'react'; -import { FormattedMessage, injectI18n } from '@kbn/i18n/react'; +import { i18n } from '@kbn/i18n'; +import { FormattedMessage } from '@kbn/i18n/react'; import DragSelect from 'dragselect/dist/ds.min.js'; -import { merge, Subject } from 'rxjs'; +import { Subject } from 'rxjs'; import { map, takeUntil } from 'rxjs/operators'; import { @@ -24,7 +25,6 @@ import { EuiSpacer, } from '@elastic/eui'; -import { annotationsRefresh$ } from '../services/annotations_service'; import { AnnotationFlyout } from '../components/annotations/annotation_flyout'; import { AnnotationsTable } from '../components/annotations/annotations_table'; import { @@ -36,7 +36,6 @@ import { ChartTooltip } from '../components/chart_tooltip'; import { ExplorerSwimlane } from './explorer_swimlane'; import { KqlFilterBar } from '../components/kql_filter_bar'; import { TimeBuckets } from '../util/time_buckets'; -import { getSelectedJobIds } from '../components/job_selector/job_select_service_utils'; import { InfluencersList } from '../components/influencers_list'; import { ALLOW_CELL_RANGE_SELECTION, @@ -45,12 +44,11 @@ import { } from './explorer_dashboard_service'; import { LoadingIndicator } from '../components/loading_indicator/loading_indicator'; import { NavigationMenu } from '../components/navigation_menu'; -import { CheckboxShowCharts, showCharts$ } from '../components/controls/checkbox_showcharts'; +import { CheckboxShowCharts } from '../components/controls/checkbox_showcharts'; import { JobSelector } from '../components/job_selector'; -import { SelectInterval, interval$ } from '../components/controls/select_interval/select_interval'; +import { SelectInterval } from '../components/controls/select_interval/select_interval'; import { SelectLimit, limit$ } from './select_limit/select_limit'; -import { SelectSeverity, severity$ } from '../components/controls/select_severity/select_severity'; -import { injectObservablesAsProps } from '../util/observable_utils'; +import { SelectSeverity } from '../components/controls/select_severity/select_severity'; import { getKqlQueryValues, removeFilterFromQueryString, @@ -58,9 +56,8 @@ import { escapeParens, escapeDoubleQuotes, } from '../components/kql_filter_bar/utils'; -import { mlJobService } from '../services/job_service'; -import { getDateFormatTz, restoreAppState } from './explorer_utils'; +import { getDateFormatTz } from './explorer_utils'; import { getSwimlaneContainerWidth } from './legacy_utils'; import { @@ -80,8 +77,6 @@ import { ResizeChecker } from '../../../../../../../src/plugins/kibana_utils/pub import { timefilter } from 'ui/timefilter'; import { toastNotifications } from 'ui/notify'; -import { mlTimefilterRefresh$ } from '../services/timefilter_refresh_service'; - function mapSwimlaneOptionsToEuiOptions(options) { return options.map(option => ({ value: option, @@ -97,571 +92,484 @@ const ExplorerPage = ({ children, jobSelectorProps, resizeRef }) => (
); -export const Explorer = injectI18n( - injectObservablesAsProps( - { - annotationsRefresh: annotationsRefresh$, - explorerState: explorerService.state$, - showCharts: showCharts$, - }, - class Explorer extends React.Component { - static propTypes = { - annotationsRefresh: PropTypes.bool, - explorerState: PropTypes.object.isRequired, - explorer: PropTypes.object, - globalState: PropTypes.object.isRequired, - jobSelectService$: PropTypes.object.isRequired, - showCharts: PropTypes.bool.isRequired, - }; - - _unsubscribeAll = new Subject(); - // make sure dragSelect is only available if the mouse pointer is actually over a swimlane - disableDragSelectOnMouseLeave = true; - - dragSelect = new DragSelect({ - selectables: document.getElementsByClassName('sl-cell'), - callback(elements) { - if (elements.length > 1 && !ALLOW_CELL_RANGE_SELECTION) { - elements = [elements[0]]; - } - - if (elements.length > 0) { - dragSelect$.next({ - action: DRAG_SELECT_ACTION.NEW_SELECTION, - elements, - }); - } - - this.disableDragSelectOnMouseLeave = true; - }, - onDragStart() { - if (ALLOW_CELL_RANGE_SELECTION) { - dragSelect$.next({ - action: DRAG_SELECT_ACTION.DRAG_START, - }); - this.disableDragSelectOnMouseLeave = false; - } - }, - onElementSelect() { - if (ALLOW_CELL_RANGE_SELECTION) { - dragSelect$.next({ - action: DRAG_SELECT_ACTION.ELEMENT_SELECT, - }); - } - }, - }); - - // Listens to render updates of the swimlanes to update dragSelect - swimlaneRenderDoneListener = () => { - this.dragSelect.clearSelection(); - this.dragSelect.setSelectables(document.getElementsByClassName('sl-cell')); - }; - - resizeRef = createRef(); - resizeChecker = undefined; - resizeHandler = () => { - explorerService.setSwimlaneContainerWidth(getSwimlaneContainerWidth()); - }; - - componentDidMount() { - timefilter.enableTimeRangeSelector(); - timefilter.enableAutoRefreshSelector(); - - explorerService.setBounds(timefilter.getActiveBounds()); - - // Refresh all the data when the time range is altered. - merge(mlTimefilterRefresh$, timefilter.getFetch$()) - .pipe(takeUntil(this._unsubscribeAll)) - .subscribe(() => { - explorerService.setBounds(timefilter.getActiveBounds()); - }); - - limit$ - .pipe( - takeUntil(this._unsubscribeAll), - map(d => d.val) - ) - .subscribe(explorerService.setSwimlaneLimit); - - interval$ - .pipe( - takeUntil(this._unsubscribeAll), - map(d => ({ tableInterval: d.val })) - ) - .subscribe(explorerService.setState); - - severity$ - .pipe( - takeUntil(this._unsubscribeAll), - map(d => ({ tableSeverity: d.val })) - ) - .subscribe(explorerService.setState); - - // Required to redraw the time series chart when the container is resized. - this.resizeChecker = new ResizeChecker(this.resizeRef.current); - this.resizeChecker.on('resize', this.resizeHandler); - - // restore state stored in URL via AppState and subscribe to - // job updates via job selector. - if (mlJobService.jobs.length > 0) { - let initialized = false; - - this.props.jobSelectService$ - .pipe(takeUntil(this._unsubscribeAll)) - .subscribe(({ selection }) => { - if (selection !== undefined) { - if (!initialized) { - explorerService.initialize( - selection, - restoreAppState(this.props.explorerState.appState) - ); - initialized = true; - } else { - explorerService.updateJobSelection( - selection, - restoreAppState(this.props.explorerState.appState) - ); - } - } - }); - } else { - explorerService.clearJobs(); - } +export class Explorer extends React.Component { + static propTypes = { + explorerState: PropTypes.object.isRequired, + setSelectedCells: PropTypes.func.isRequired, + showCharts: PropTypes.bool.isRequired, + }; + + _unsubscribeAll = new Subject(); + // make sure dragSelect is only available if the mouse pointer is actually over a swimlane + disableDragSelectOnMouseLeave = true; + + dragSelect = new DragSelect({ + selectables: document.getElementsByClassName('sl-cell'), + callback(elements) { + if (elements.length > 1 && !ALLOW_CELL_RANGE_SELECTION) { + elements = [elements[0]]; } - componentWillUnmount() { - this._unsubscribeAll.next(); - this._unsubscribeAll.complete(); - this.resizeChecker.destroy(); + if (elements.length > 0) { + dragSelect$.next({ + action: DRAG_SELECT_ACTION.NEW_SELECTION, + elements, + }); } - resetCache() { - this.anomaliesTablePreviousArgs = null; + this.disableDragSelectOnMouseLeave = true; + }, + onDragStart() { + if (ALLOW_CELL_RANGE_SELECTION) { + dragSelect$.next({ + action: DRAG_SELECT_ACTION.DRAG_START, + }); + this.disableDragSelectOnMouseLeave = false; } - - componentDidUpdate() { - // TODO migrate annotations update - if (this.props.annotationsRefresh === true) { - annotationsRefresh$.next(false); - } + }, + onElementSelect() { + if (ALLOW_CELL_RANGE_SELECTION) { + dragSelect$.next({ + action: DRAG_SELECT_ACTION.ELEMENT_SELECT, + }); } - - viewByChangeHandler = e => explorerService.setViewBySwimlaneFieldName(e.target.value); - - isSwimlaneSelectActive = false; - onSwimlaneEnterHandler = () => this.setSwimlaneSelectActive(true); - onSwimlaneLeaveHandler = () => this.setSwimlaneSelectActive(false); - setSwimlaneSelectActive = active => { - if (this.isSwimlaneSelectActive && !active && this.disableDragSelectOnMouseLeave) { - this.dragSelect.stop(); - this.isSwimlaneSelectActive = active; - return; - } - if (!this.isSwimlaneSelectActive && active) { - this.dragSelect.start(); - this.dragSelect.clearSelection(); - this.dragSelect.setSelectables(document.getElementsByClassName('sl-cell')); - this.isSwimlaneSelectActive = active; - } - }; - - // Listener for click events in the swimlane to load corresponding anomaly data. - swimlaneCellClick = selectedCells => { - // If selectedCells is an empty object we clear any existing selection, - // otherwise we save the new selection in AppState and update the Explorer. - if (Object.keys(selectedCells).length === 0) { - explorerService.clearSelection(); - } else { - explorerService.setSelectedCells(selectedCells); - } - }; - // Escape regular parens from fieldName as that portion of the query is not wrapped in double quotes - // and will cause a syntax error when called with getKqlQueryValues - applyFilter = (fieldName, fieldValue, action) => { - const { filterActive, indexPattern, queryString } = this.props.explorerState; - - let newQueryString = ''; - const operator = 'and '; - const sanitizedFieldName = escapeParens(fieldName); - const sanitizedFieldValue = escapeDoubleQuotes(fieldValue); - - if (action === FILTER_ACTION.ADD) { - // Don't re-add if already exists in the query - const queryPattern = getQueryPattern(fieldName, fieldValue); - if (queryString.match(queryPattern) !== null) { - return; - } - newQueryString = `${ - queryString ? `${queryString} ${operator}` : '' - }${sanitizedFieldName}:"${sanitizedFieldValue}"`; - } else if (action === FILTER_ACTION.REMOVE) { - if (filterActive === false) { - return; - } else { - newQueryString = removeFilterFromQueryString( - queryString, - sanitizedFieldName, - sanitizedFieldValue - ); - } - } - - try { - const queryValues = getKqlQueryValues(`${newQueryString}`, indexPattern); - this.applyInfluencersFilterQuery(queryValues); - } catch (e) { - console.log('Invalid kuery syntax', e); // eslint-disable-line no-console - - toastNotifications.addDanger( - this.props.intl.formatMessage({ - id: 'xpack.ml.explorer.invalidKuerySyntaxErrorMessageFromTable', - defaultMessage: - 'Invalid syntax in query bar. The input must be valid Kibana Query Language (KQL)', - }) - ); - } - }; - - applyInfluencersFilterQuery = payload => { - const { filterQuery: influencersFilterQuery } = payload; - - if ( - influencersFilterQuery.match_all && - Object.keys(influencersFilterQuery.match_all).length === 0 - ) { - explorerService.clearInfluencerFilterSettings(); - } else { - explorerService.setInfluencerFilterSettings(payload); - } - }; - - render() { - const { globalState, intl, jobSelectService$, showCharts } = this.props; - - const { - annotationsData, - anomalyChartRecords, - chartsData, - filterActive, - filterPlaceHolder, - indexPattern, - influencers, - loading, - maskAll, - noInfluencersConfigured, - overallSwimlaneData, + }, + }); + + // Listens to render updates of the swimlanes to update dragSelect + swimlaneRenderDoneListener = () => { + this.dragSelect.clearSelection(); + this.dragSelect.setSelectables(document.getElementsByClassName('sl-cell')); + }; + + resizeRef = createRef(); + resizeChecker = undefined; + resizeHandler = () => { + explorerService.setSwimlaneContainerWidth(getSwimlaneContainerWidth()); + }; + + componentDidMount() { + limit$ + .pipe( + takeUntil(this._unsubscribeAll), + map(d => d.val) + ) + .subscribe(explorerService.setSwimlaneLimit); + + // Required to redraw the time series chart when the container is resized. + this.resizeChecker = new ResizeChecker(this.resizeRef.current); + this.resizeChecker.on('resize', this.resizeHandler); + } + + componentWillUnmount() { + this._unsubscribeAll.next(); + this._unsubscribeAll.complete(); + this.resizeChecker.destroy(); + } + + resetCache() { + this.anomaliesTablePreviousArgs = null; + } + + viewByChangeHandler = e => explorerService.setViewBySwimlaneFieldName(e.target.value); + + isSwimlaneSelectActive = false; + onSwimlaneEnterHandler = () => this.setSwimlaneSelectActive(true); + onSwimlaneLeaveHandler = () => this.setSwimlaneSelectActive(false); + setSwimlaneSelectActive = active => { + if (this.isSwimlaneSelectActive && !active && this.disableDragSelectOnMouseLeave) { + this.dragSelect.stop(); + this.isSwimlaneSelectActive = active; + return; + } + if (!this.isSwimlaneSelectActive && active) { + this.dragSelect.start(); + this.dragSelect.clearSelection(); + this.dragSelect.setSelectables(document.getElementsByClassName('sl-cell')); + this.isSwimlaneSelectActive = active; + } + }; + + // Listener for click events in the swimlane to load corresponding anomaly data. + swimlaneCellClick = selectedCells => { + // If selectedCells is an empty object we clear any existing selection, + // otherwise we save the new selection in AppState and update the Explorer. + if (Object.keys(selectedCells).length === 0) { + this.props.setSelectedCells(); + } else { + this.props.setSelectedCells(selectedCells); + } + }; + // Escape regular parens from fieldName as that portion of the query is not wrapped in double quotes + // and will cause a syntax error when called with getKqlQueryValues + applyFilter = (fieldName, fieldValue, action) => { + const { filterActive, indexPattern, queryString } = this.props.explorerState; + + let newQueryString = ''; + const operator = 'and '; + const sanitizedFieldName = escapeParens(fieldName); + const sanitizedFieldValue = escapeDoubleQuotes(fieldValue); + + if (action === FILTER_ACTION.ADD) { + // Don't re-add if already exists in the query + const queryPattern = getQueryPattern(fieldName, fieldValue); + if (queryString.match(queryPattern) !== null) { + return; + } + newQueryString = `${ + queryString ? `${queryString} ${operator}` : '' + }${sanitizedFieldName}:"${sanitizedFieldValue}"`; + } else if (action === FILTER_ACTION.REMOVE) { + if (filterActive === false) { + return; + } else { + newQueryString = removeFilterFromQueryString( queryString, - selectedCells, - selectedJobs, - swimlaneContainerWidth, - tableData, - tableQueryString, - viewByLoadedForTimeFormatted, - viewBySwimlaneData, - viewBySwimlaneDataLoading, - viewBySwimlaneFieldName, - viewBySwimlaneOptions, - } = this.props.explorerState; - - const { jobIds: selectedJobIds, selectedGroups } = getSelectedJobIds(globalState); - const jobSelectorProps = { - dateFormatTz: getDateFormatTz(), - globalState, - jobSelectService$, - selectedJobIds, - selectedGroups, - }; - - const noJobsFound = selectedJobs === null || selectedJobs.length === 0; - const hasResults = overallSwimlaneData.points && overallSwimlaneData.points.length > 0; - - if (loading === true) { - return ( - - - - ); - } - - if (noJobsFound) { - return ( - - - - ); - } - - if (noJobsFound && hasResults === false) { - return ( - - - - ); - } - - const mainColumnWidthClassName = - noInfluencersConfigured === true ? 'col-xs-12' : 'col-xs-10'; - const mainColumnClasses = `column ${mainColumnWidthClassName}`; - - const showOverallSwimlane = - overallSwimlaneData !== null && - overallSwimlaneData.laneLabels && - overallSwimlaneData.laneLabels.length > 0; - const showViewBySwimlane = - viewBySwimlaneData !== null && - viewBySwimlaneData.laneLabels && - viewBySwimlaneData.laneLabels.length > 0; - - return ( - -
- {/* Make sure ChartTooltip is inside this plain wrapping div so positioning can be infered correctly. */} - - - {noInfluencersConfigured === false && influencers !== undefined && ( -
- -
- )} - - {noInfluencersConfigured && ( -
-
- )} - - {noInfluencersConfigured === false && ( -
- - - - -
- )} + sanitizedFieldName, + sanitizedFieldValue + ); + } + } -
- - - + try { + const queryValues = getKqlQueryValues(`${newQueryString}`, indexPattern); + this.applyInfluencersFilterQuery(queryValues); + } catch (e) { + console.log('Invalid kuery syntax', e); // eslint-disable-line no-console + + toastNotifications.addDanger( + i18n.translate('xpack.ml.explorer.invalidKuerySyntaxErrorMessageFromTable', { + defaultMessage: + 'Invalid syntax in query bar. The input must be valid Kibana Query Language (KQL)', + }) + ); + } + }; + + applyInfluencersFilterQuery = payload => { + const { filterQuery: influencersFilterQuery } = payload; + + if ( + influencersFilterQuery.match_all && + Object.keys(influencersFilterQuery.match_all).length === 0 + ) { + explorerService.clearInfluencerFilterSettings(); + } else { + explorerService.setInfluencerFilterSettings(payload); + } + }; + + render() { + const { showCharts } = this.props; + + const { + annotationsData, + chartsData, + filterActive, + filterPlaceHolder, + indexPattern, + influencers, + loading, + maskAll, + noInfluencersConfigured, + overallSwimlaneData, + queryString, + selectedCells, + selectedJobs, + severity, + swimlaneContainerWidth, + tableData, + tableQueryString, + viewByLoadedForTimeFormatted, + viewBySwimlaneData, + viewBySwimlaneDataLoading, + viewBySwimlaneFieldName, + viewBySwimlaneOptions, + } = this.props.explorerState; + + const jobSelectorProps = { + dateFormatTz: getDateFormatTz(), + }; + + const noJobsFound = selectedJobs === null || selectedJobs.length === 0; + const hasResults = overallSwimlaneData.points && overallSwimlaneData.points.length > 0; + + if (loading === true) { + return ( + + + + ); + } -
- {showOverallSwimlane && ( - - )} -
+ if (noJobsFound) { + return ( + + + + ); + } - {viewBySwimlaneOptions.length > 0 && ( - <> - - - - - - - - - - - - - -
- {viewByLoadedForTimeFormatted && ( - - )} - {viewByLoadedForTimeFormatted === undefined && ( - - )} - {filterActive === true && - viewBySwimlaneFieldName === VIEW_BY_JOB_LABEL && ( - - )} -
-
-
-
- - {showViewBySwimlane && ( - <> - -
- -
- - )} - - {viewBySwimlaneDataLoading && } - - {!showViewBySwimlane && - !viewBySwimlaneDataLoading && - viewBySwimlaneFieldName !== null && ( - - )} - - )} + if (noJobsFound && hasResults === false) { + return ( + + + + ); + } - {annotationsData.length > 0 && ( - <> - - - - - - - - )} + const mainColumnWidthClassName = noInfluencersConfigured === true ? 'col-xs-12' : 'col-xs-10'; + const mainColumnClasses = `column ${mainColumnWidthClassName}`; + + const showOverallSwimlane = + overallSwimlaneData !== null && + overallSwimlaneData.laneLabels && + overallSwimlaneData.laneLabels.length > 0; + const showViewBySwimlane = + viewBySwimlaneData !== null && + viewBySwimlaneData.laneLabels && + viewBySwimlaneData.laneLabels.length > 0; + + const bounds = timefilter.getActiveBounds(); + + return ( + +
+ {/* Make sure ChartTooltip is inside this plain wrapping div so positioning can be infered correctly. */} + + + {noInfluencersConfigured === false && influencers !== undefined && ( +
+ +
+ )} + + {noInfluencersConfigured && ( +
+
+ )} + + {noInfluencersConfigured === false && ( +
+ + + + +
+ )} - - - +
+ + + + +
+ {showOverallSwimlane && ( + + )} +
- - + {viewBySwimlaneOptions.length > 0 && ( + <> + + - + - + - + + + + + +
+ {viewByLoadedForTimeFormatted && ( + + )} + {viewByLoadedForTimeFormatted === undefined && ( + + )} + {filterActive === true && viewBySwimlaneFieldName === VIEW_BY_JOB_LABEL && ( + + )} +
- {anomalyChartRecords.length > 0 && selectedCells !== null && ( - - - - - - )}
- + {showViewBySwimlane && ( + <> + +
+ +
+ + )} + + {viewBySwimlaneDataLoading && } -
- {showCharts && } -
+ {!showViewBySwimlane && + !viewBySwimlaneDataLoading && + viewBySwimlaneFieldName !== null && ( + + )} + + )} - 0 && ( + <> + + + + -
+ + + + )} + + + + + + + + + + + + + + + + + {chartsData.seriesToPlot.length > 0 && selectedCells !== undefined && ( + + + + + + )} + + + + +
+ {showCharts && }
- - ); - } - } - ) -); + + +
+
+ + ); + } +} diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/__snapshots__/explorer_charts_container_service.test.js.snap b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/__snapshots__/explorer_charts_container_service.test.js.snap index df76b049e9837..1c0124b90ae77 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/__snapshots__/explorer_charts_container_service.test.js.snap +++ b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/__snapshots__/explorer_charts_container_service.test.js.snap @@ -1,15 +1,6 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP exports[`explorerChartsContainerService call anomalyChangeListener with actual series config 1`] = ` -Object { - "chartsPerRow": 1, - "seriesToPlot": Array [], - "timeFieldName": "timestamp", - "tooManyBuckets": false, -} -`; - -exports[`explorerChartsContainerService call anomalyChangeListener with actual series config 2`] = ` Object { "chartsPerRow": 1, "seriesToPlot": Array [ @@ -69,7 +60,7 @@ Object { } `; -exports[`explorerChartsContainerService call anomalyChangeListener with actual series config 3`] = ` +exports[`explorerChartsContainerService call anomalyChangeListener with actual series config 2`] = ` Object { "chartsPerRow": 1, "seriesToPlot": Array [ diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_chart_distribution.js b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_chart_distribution.js index 757fd00192fc8..ce819a8d6dc8c 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_chart_distribution.js +++ b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_chart_distribution.js @@ -32,7 +32,6 @@ import { LoadingIndicator } from '../../components/loading_indicator/loading_ind import { TimeBuckets } from '../../util/time_buckets'; import { mlFieldFormatService } from '../../services/field_format_service'; import { mlChartTooltipService } from '../../components/chart_tooltip/chart_tooltip_service'; -import { severity$ } from '../../components/controls/select_severity/select_severity'; import { CHART_TYPE } from '../explorer_constants'; @@ -51,6 +50,7 @@ export const ExplorerChartDistribution = injectI18n( class ExplorerChartDistribution extends React.Component { static propTypes = { seriesConfig: PropTypes.object, + severity: PropTypes.number, }; componentDidMount() { @@ -66,6 +66,7 @@ export const ExplorerChartDistribution = injectI18n( const element = this.rootNode; const config = this.props.seriesConfig; + const severity = this.props.severity; if (typeof config === 'undefined' || Array.isArray(config.chartData) === false) { // just return so the empty directive renders without an error later on @@ -400,13 +401,12 @@ export const ExplorerChartDistribution = injectI18n( .on('mouseout', () => mlChartTooltipService.hide()); // Update all dots to new positions. - const threshold = severity$.getValue(); dots .attr('cx', d => lineChartXScale(d.date)) .attr('cy', d => lineChartYScale(d[CHART_Y_ATTRIBUTE])) .attr('class', d => { let markerClass = 'metric-value'; - if (_.has(d, 'anomalyScore') && Number(d.anomalyScore) >= threshold.val) { + if (_.has(d, 'anomalyScore') && Number(d.anomalyScore) >= severity) { markerClass += ' anomaly-marker '; markerClass += getSeverityWithLow(d.anomalyScore).id; } diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_chart_single_metric.js b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_chart_single_metric.js index 5319692b00a38..583375c87007e 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_chart_single_metric.js +++ b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_chart_single_metric.js @@ -42,7 +42,6 @@ import { TimeBuckets } from '../../util/time_buckets'; import { mlEscape } from '../../util/string_utils'; import { mlFieldFormatService } from '../../services/field_format_service'; import { mlChartTooltipService } from '../../components/chart_tooltip/chart_tooltip_service'; -import { severity$ } from '../../components/controls/select_severity/select_severity'; import { injectI18n } from '@kbn/i18n/react'; @@ -54,6 +53,7 @@ export const ExplorerChartSingleMetric = injectI18n( static propTypes = { tooManyBuckets: PropTypes.bool, seriesConfig: PropTypes.object, + severity: PropTypes.number, }; componentDidMount() { @@ -69,6 +69,7 @@ export const ExplorerChartSingleMetric = injectI18n( const element = this.rootNode; const config = this.props.seriesConfig; + const severity = this.props.severity; if (typeof config === 'undefined' || Array.isArray(config.chartData) === false) { // just return so the empty directive renders without an error later on @@ -312,13 +313,12 @@ export const ExplorerChartSingleMetric = injectI18n( .on('mouseout', () => mlChartTooltipService.hide()); // Update all dots to new positions. - const threshold = severity$.getValue(); dots .attr('cx', d => lineChartXScale(d.date)) .attr('cy', d => lineChartYScale(d.value)) .attr('class', d => { let markerClass = 'metric-value'; - if (_.has(d, 'anomalyScore') && Number(d.anomalyScore) >= threshold.val) { + if (_.has(d, 'anomalyScore') && Number(d.anomalyScore) >= severity) { markerClass += ` anomaly-marker ${getSeverityWithLow(d.anomalyScore).id}`; } return markerClass; diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container.js b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container.js index 140c5a87056e5..99de38c1e0a84 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container.js +++ b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container.js @@ -52,7 +52,7 @@ function getChartId(series) { } // Wrapper for a single explorer chart -function ExplorerChartContainer({ series, tooManyBuckets, wrapLabel }) { +function ExplorerChartContainer({ series, severity, tooManyBuckets, wrapLabel }) { const { detectorLabel, entityFields } = series; const chartType = getChartType(series); @@ -121,10 +121,20 @@ function ExplorerChartContainer({ series, tooManyBuckets, wrapLabel }) { chartType === CHART_TYPE.POPULATION_DISTRIBUTION ) { return ( - + ); } - return ; + return ( + + ); })()} ); @@ -146,7 +156,7 @@ export class ExplorerChartsContainer extends React.Component { } render() { - const { chartsPerRow, seriesToPlot, tooManyBuckets } = this.props; + const { chartsPerRow, seriesToPlot, severity, tooManyBuckets } = this.props; // doesn't allow a setting of `columns={1}` when chartsPerRow would be 1. // If that's the case we trick it doing that with the following settings: @@ -166,6 +176,7 @@ export class ExplorerChartsContainer extends React.Component { > diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container.test.js b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container.test.js index f0b94cb724c57..4b2d307e72c66 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container.test.js +++ b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container.test.js @@ -4,6 +4,16 @@ * you may not use this file except in compliance with the Elastic License. */ +import React from 'react'; +import { mount, shallow } from 'enzyme'; + +import { I18nProvider } from '@kbn/i18n/react'; + +import { chartLimits } from '../../util/chart_utils'; + +import { getDefaultChartsData } from './explorer_charts_container_service'; +import { ExplorerChartsContainer } from './explorer_charts_container'; + import './explorer_chart_single_metric.test.mocks'; import { chartData } from './__mocks__/mock_chart_data'; import seriesConfig from './__mocks__/mock_series_config_filebeat.json'; @@ -38,17 +48,12 @@ jest.mock( getBasePath: () => { return ''; }, + getInjected: () => true, }), { virtual: true } ); -import { shallowWithIntl, mountWithIntl } from 'test_utils/enzyme_helpers'; -import React from 'react'; - -import { chartLimits } from '../../util/chart_utils'; -import { getDefaultChartsData } from './explorer_charts_container_service'; - -import { ExplorerChartsContainer } from './explorer_charts_container'; +jest.mock('ui/new_platform'); describe('ExplorerChartsContainer', () => { const mockedGetBBox = { x: 0, y: -11.5, width: 12.1875, height: 14.5 }; @@ -58,7 +63,11 @@ describe('ExplorerChartsContainer', () => { afterEach(() => (SVGElement.prototype.getBBox = originalGetBBox)); test('Minimal Initialization', () => { - const wrapper = shallowWithIntl(); + const wrapper = shallow( + + + + ); expect(wrapper.html()).toBe( '
' @@ -78,7 +87,11 @@ describe('ExplorerChartsContainer', () => { chartsPerRow: 1, tooManyBuckets: false, }; - const wrapper = mountWithIntl(); + const wrapper = mount( + + + + ); // We test child components with snapshots separately // so we just do some high level sanity check here. @@ -101,7 +114,11 @@ describe('ExplorerChartsContainer', () => { chartsPerRow: 1, tooManyBuckets: false, }; - const wrapper = mountWithIntl(); + const wrapper = mount( + + + + ); // We test child components with snapshots separately // so we just do some high level sanity check here. diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container_service.d.ts b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container_service.d.ts index ccd52a26f2abc..962072b974867 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container_service.d.ts +++ b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container_service.d.ts @@ -13,6 +13,9 @@ export declare interface ExplorerChartsData { export declare const getDefaultChartsData: () => ExplorerChartsData; -export declare const explorerChartsContainerServiceFactory: ( - callback: (data: ExplorerChartsData) => void -) => (anomalyRecords: any[], earliestMs: number, latestMs: number) => void; +export declare const anomalyDataChange: ( + anomalyRecords: any[], + earliestMs: number, + latestMs: number, + severity?: number +) => void; diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container_service.js b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container_service.js index 4aad4fba85746..e0fb97a81f587 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container_service.js +++ b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container_service.js @@ -23,8 +23,8 @@ import { } from '../../../../common/util/job_utils'; import { mlResultsService } from '../../services/results_service'; import { mlJobService } from '../../services/job_service'; -import { severity$ } from '../../components/controls/select_severity/select_severity'; import { getChartContainerWidth } from '../legacy_utils'; +import { explorerService } from '../explorer_dashboard_service'; import { CHART_TYPE } from '../explorer_constants'; @@ -38,593 +38,581 @@ export function getDefaultChartsData() { }; } -export function explorerChartsContainerServiceFactory(callback) { - const CHART_MAX_POINTS = 500; - const ANOMALIES_MAX_RESULTS = 500; - const MAX_SCHEDULED_EVENTS = 10; // Max number of scheduled events displayed per bucket. - const ML_TIME_FIELD_NAME = 'timestamp'; - const USE_OVERALL_CHART_LIMITS = false; - const MAX_CHARTS_PER_ROW = 4; - - callback(getDefaultChartsData()); +const CHART_MAX_POINTS = 500; +const ANOMALIES_MAX_RESULTS = 500; +const MAX_SCHEDULED_EVENTS = 10; // Max number of scheduled events displayed per bucket. +const ML_TIME_FIELD_NAME = 'timestamp'; +const USE_OVERALL_CHART_LIMITS = false; +const MAX_CHARTS_PER_ROW = 4; + +// callback(getDefaultChartsData()); + +export const anomalyDataChange = function(anomalyRecords, earliestMs, latestMs, severity = 0) { + const data = getDefaultChartsData(); + + const filteredRecords = anomalyRecords.filter(record => { + return Number(record.record_score) >= severity; + }); + const allSeriesRecords = processRecordsForDisplay(filteredRecords); + // Calculate the number of charts per row, depending on the width available, to a max of 4. + const chartsContainerWidth = getChartContainerWidth(); + let chartsPerRow = Math.min( + Math.max(Math.floor(chartsContainerWidth / 550), 1), + MAX_CHARTS_PER_ROW + ); + if (allSeriesRecords.length === 1) { + chartsPerRow = 1; + } - const anomalyDataChange = function(anomalyRecords, earliestMs, latestMs) { - const data = getDefaultChartsData(); + data.chartsPerRow = chartsPerRow; - const threshold = severity$.getValue(); + // Build the data configs of the anomalies to be displayed. + // TODO - implement paging? + // For now just take first 6 (or 8 if 4 charts per row). + const maxSeriesToPlot = Math.max(chartsPerRow * 2, 6); + const recordsToPlot = allSeriesRecords.slice(0, maxSeriesToPlot); + const seriesConfigs = recordsToPlot.map(buildConfig); - const filteredRecords = anomalyRecords.filter(record => { - return Number(record.record_score) >= threshold.val; - }); - const allSeriesRecords = processRecordsForDisplay(filteredRecords); - // Calculate the number of charts per row, depending on the width available, to a max of 4. - const chartsContainerWidth = getChartContainerWidth(); - let chartsPerRow = Math.min( - Math.max(Math.floor(chartsContainerWidth / 550), 1), - MAX_CHARTS_PER_ROW - ); - if (allSeriesRecords.length === 1) { - chartsPerRow = 1; - } + // Calculate the time range of the charts, which is a function of the chart width and max job bucket span. + data.tooManyBuckets = false; + const chartWidth = Math.floor(chartsContainerWidth / chartsPerRow); + const { chartRange, tooManyBuckets } = calculateChartRange( + seriesConfigs, + earliestMs, + latestMs, + chartWidth, + recordsToPlot, + data.timeFieldName + ); + data.tooManyBuckets = tooManyBuckets; - data.chartsPerRow = chartsPerRow; - - // Build the data configs of the anomalies to be displayed. - // TODO - implement paging? - // For now just take first 6 (or 8 if 4 charts per row). - const maxSeriesToPlot = Math.max(chartsPerRow * 2, 6); - const recordsToPlot = allSeriesRecords.slice(0, maxSeriesToPlot); - const seriesConfigs = recordsToPlot.map(buildConfig); - - // Calculate the time range of the charts, which is a function of the chart width and max job bucket span. - data.tooManyBuckets = false; - const chartWidth = Math.floor(chartsContainerWidth / chartsPerRow); - const { chartRange, tooManyBuckets } = calculateChartRange( - seriesConfigs, - earliestMs, - latestMs, - chartWidth, - recordsToPlot, - data.timeFieldName - ); - data.tooManyBuckets = tooManyBuckets; + // initialize the charts with loading indicators + data.seriesToPlot = seriesConfigs.map(config => ({ + ...config, + loading: true, + chartData: null, + })); - // initialize the charts with loading indicators - data.seriesToPlot = seriesConfigs.map(config => ({ - ...config, - loading: true, - chartData: null, - })); + explorerService.setCharts({ ...data }); - callback(data); + if (seriesConfigs.length === 0) { + return; + } - // Query 1 - load the raw metric data. - function getMetricData(config, range) { - const { jobId, detectorIndex, entityFields, interval } = config; + // Query 1 - load the raw metric data. + function getMetricData(config, range) { + const { jobId, detectorIndex, entityFields, interval } = config; - const job = mlJobService.getJob(jobId); + const job = mlJobService.getJob(jobId); - // If source data can be plotted, use that, otherwise model plot will be available. - const useSourceData = isSourceDataChartableForDetector(job, detectorIndex); - if (useSourceData === true) { - const datafeedQuery = _.get(config, 'datafeedConfig.query', null); - return mlResultsService - .getMetricData( - config.datafeedConfig.indices, - config.entityFields, - datafeedQuery, - config.metricFunction, - config.metricFieldName, - config.timeField, - range.min, - range.max, - config.interval - ) - .toPromise(); - } else { - // Extract the partition, by, over fields on which to filter. - const criteriaFields = []; - const detector = job.analysis_config.detectors[detectorIndex]; - if (_.has(detector, 'partition_field_name')) { - const partitionEntity = _.find(entityFields, { - fieldName: detector.partition_field_name, - }); - if (partitionEntity !== undefined) { - criteriaFields.push( - { fieldName: 'partition_field_name', fieldValue: partitionEntity.fieldName }, - { fieldName: 'partition_field_value', fieldValue: partitionEntity.fieldValue } - ); - } + // If source data can be plotted, use that, otherwise model plot will be available. + const useSourceData = isSourceDataChartableForDetector(job, detectorIndex); + if (useSourceData === true) { + const datafeedQuery = _.get(config, 'datafeedConfig.query', null); + return mlResultsService + .getMetricData( + config.datafeedConfig.indices, + config.entityFields, + datafeedQuery, + config.metricFunction, + config.metricFieldName, + config.timeField, + range.min, + range.max, + config.interval + ) + .toPromise(); + } else { + // Extract the partition, by, over fields on which to filter. + const criteriaFields = []; + const detector = job.analysis_config.detectors[detectorIndex]; + if (_.has(detector, 'partition_field_name')) { + const partitionEntity = _.find(entityFields, { + fieldName: detector.partition_field_name, + }); + if (partitionEntity !== undefined) { + criteriaFields.push( + { fieldName: 'partition_field_name', fieldValue: partitionEntity.fieldName }, + { fieldName: 'partition_field_value', fieldValue: partitionEntity.fieldValue } + ); } + } - if (_.has(detector, 'over_field_name')) { - const overEntity = _.find(entityFields, { fieldName: detector.over_field_name }); - if (overEntity !== undefined) { - criteriaFields.push( - { fieldName: 'over_field_name', fieldValue: overEntity.fieldName }, - { fieldName: 'over_field_value', fieldValue: overEntity.fieldValue } - ); - } + if (_.has(detector, 'over_field_name')) { + const overEntity = _.find(entityFields, { fieldName: detector.over_field_name }); + if (overEntity !== undefined) { + criteriaFields.push( + { fieldName: 'over_field_name', fieldValue: overEntity.fieldName }, + { fieldName: 'over_field_value', fieldValue: overEntity.fieldValue } + ); } + } - if (_.has(detector, 'by_field_name')) { - const byEntity = _.find(entityFields, { fieldName: detector.by_field_name }); - if (byEntity !== undefined) { - criteriaFields.push( - { fieldName: 'by_field_name', fieldValue: byEntity.fieldName }, - { fieldName: 'by_field_value', fieldValue: byEntity.fieldValue } - ); - } + if (_.has(detector, 'by_field_name')) { + const byEntity = _.find(entityFields, { fieldName: detector.by_field_name }); + if (byEntity !== undefined) { + criteriaFields.push( + { fieldName: 'by_field_name', fieldValue: byEntity.fieldName }, + { fieldName: 'by_field_value', fieldValue: byEntity.fieldValue } + ); } - - return new Promise((resolve, reject) => { - const obj = { - success: true, - results: {}, - }; - - return mlResultsService - .getModelPlotOutput( - jobId, - detectorIndex, - criteriaFields, - range.min, - range.max, - interval - ) - .toPromise() - .then(resp => { - // Return data in format required by the explorer charts. - const results = resp.results; - Object.keys(results).forEach(time => { - obj.results[time] = results[time].actual; - }); - resolve(obj); - }) - .catch(resp => { - reject(resp); - }); - }); } - } - // Query 2 - load the anomalies. - // Criteria to return the records for this series are the detector_index plus - // the specific combination of 'entity' fields i.e. the partition / by / over fields. - function getRecordsForCriteria(config, range) { - let criteria = []; - criteria.push({ fieldName: 'detector_index', fieldValue: config.detectorIndex }); - criteria = criteria.concat(config.entityFields); - return mlResultsService - .getRecordsForCriteria( - [config.jobId], - criteria, - 0, - range.min, - range.max, - ANOMALIES_MAX_RESULTS - ) - .toPromise(); - } + return new Promise((resolve, reject) => { + const obj = { + success: true, + results: {}, + }; - // Query 3 - load any scheduled events for the job. - function getScheduledEvents(config, range) { - return mlResultsService - .getScheduledEventsByBucket( - [config.jobId], - range.min, - range.max, - config.interval, - 1, - MAX_SCHEDULED_EVENTS - ) - .toPromise(); + return mlResultsService + .getModelPlotOutput(jobId, detectorIndex, criteriaFields, range.min, range.max, interval) + .toPromise() + .then(resp => { + // Return data in format required by the explorer charts. + const results = resp.results; + Object.keys(results).forEach(time => { + obj.results[time] = results[time].actual; + }); + resolve(obj); + }) + .catch(resp => { + reject(resp); + }); + }); } + } - // Query 4 - load context data distribution - function getEventDistribution(config, range) { - const chartType = getChartType(config); - - let splitField; - let filterField = null; - - // Define splitField and filterField based on chartType - if (chartType === CHART_TYPE.EVENT_DISTRIBUTION) { - splitField = config.entityFields.find(f => f.fieldType === 'by'); - filterField = config.entityFields.find(f => f.fieldType === 'partition'); - } else if (chartType === CHART_TYPE.POPULATION_DISTRIBUTION) { - splitField = config.entityFields.find(f => f.fieldType === 'over'); - filterField = config.entityFields.find(f => f.fieldType === 'partition'); - } + // Query 2 - load the anomalies. + // Criteria to return the records for this series are the detector_index plus + // the specific combination of 'entity' fields i.e. the partition / by / over fields. + function getRecordsForCriteria(config, range) { + let criteria = []; + criteria.push({ fieldName: 'detector_index', fieldValue: config.detectorIndex }); + criteria = criteria.concat(config.entityFields); + return mlResultsService + .getRecordsForCriteria( + [config.jobId], + criteria, + 0, + range.min, + range.max, + ANOMALIES_MAX_RESULTS + ) + .toPromise(); + } - const datafeedQuery = _.get(config, 'datafeedConfig.query', null); - return mlResultsService.getEventDistributionData( - config.datafeedConfig.indices, - splitField, - filterField, - datafeedQuery, - config.metricFunction, - config.metricFieldName, - config.timeField, + // Query 3 - load any scheduled events for the job. + function getScheduledEvents(config, range) { + return mlResultsService + .getScheduledEventsByBucket( + [config.jobId], range.min, range.max, - config.interval - ); + config.interval, + 1, + MAX_SCHEDULED_EVENTS + ) + .toPromise(); + } + + // Query 4 - load context data distribution + function getEventDistribution(config, range) { + const chartType = getChartType(config); + + let splitField; + let filterField = null; + + // Define splitField and filterField based on chartType + if (chartType === CHART_TYPE.EVENT_DISTRIBUTION) { + splitField = config.entityFields.find(f => f.fieldType === 'by'); + filterField = config.entityFields.find(f => f.fieldType === 'partition'); + } else if (chartType === CHART_TYPE.POPULATION_DISTRIBUTION) { + splitField = config.entityFields.find(f => f.fieldType === 'over'); + filterField = config.entityFields.find(f => f.fieldType === 'partition'); } - // first load and wait for required data, - // only after that trigger data processing and page render. - // TODO - if query returns no results e.g. source data has been deleted, - // display a message saying 'No data between earliest/latest'. - const seriesPromises = seriesConfigs.map(seriesConfig => - Promise.all([ - getMetricData(seriesConfig, chartRange), - getRecordsForCriteria(seriesConfig, chartRange), - getScheduledEvents(seriesConfig, chartRange), - getEventDistribution(seriesConfig, chartRange), - ]) + const datafeedQuery = _.get(config, 'datafeedConfig.query', null); + return mlResultsService.getEventDistributionData( + config.datafeedConfig.indices, + splitField, + filterField, + datafeedQuery, + config.metricFunction, + config.metricFieldName, + config.timeField, + range.min, + range.max, + config.interval ); + } - function processChartData(response, seriesIndex) { - const metricData = response[0].results; - const records = response[1].records; - const jobId = seriesConfigs[seriesIndex].jobId; - const scheduledEvents = response[2].events[jobId]; - const eventDistribution = response[3]; - const chartType = getChartType(seriesConfigs[seriesIndex]); - - // Sort records in ascending time order matching up with chart data - records.sort((recordA, recordB) => { - return recordA[ML_TIME_FIELD_NAME] - recordB[ML_TIME_FIELD_NAME]; - }); + // first load and wait for required data, + // only after that trigger data processing and page render. + // TODO - if query returns no results e.g. source data has been deleted, + // display a message saying 'No data between earliest/latest'. + const seriesPromises = seriesConfigs.map(seriesConfig => + Promise.all([ + getMetricData(seriesConfig, chartRange), + getRecordsForCriteria(seriesConfig, chartRange), + getScheduledEvents(seriesConfig, chartRange), + getEventDistribution(seriesConfig, chartRange), + ]) + ); + + function processChartData(response, seriesIndex) { + const metricData = response[0].results; + const records = response[1].records; + const jobId = seriesConfigs[seriesIndex].jobId; + const scheduledEvents = response[2].events[jobId]; + const eventDistribution = response[3]; + const chartType = getChartType(seriesConfigs[seriesIndex]); + + // Sort records in ascending time order matching up with chart data + records.sort((recordA, recordB) => { + return recordA[ML_TIME_FIELD_NAME] - recordB[ML_TIME_FIELD_NAME]; + }); - // Return dataset in format used by the chart. - // i.e. array of Objects with keys date (timestamp), value, - // plus anomalyScore for points with anomaly markers. - let chartData = []; - if (metricData !== undefined) { - if (eventDistribution.length > 0 && records.length > 0) { - const filterField = records[0].by_field_value || records[0].over_field_value; - chartData = eventDistribution.filter(d => d.entity !== filterField); - _.map(metricData, (value, time) => { - // The filtering for rare/event_distribution charts needs to be handled - // differently because of how the source data is structured. - // For rare chart values we are only interested wether a value is either `0` or not, - // `0` acts like a flag in the chart whether to display the dot/marker. - // All other charts (single metric, population) are metric based and with - // those a value of `null` acts as the flag to hide a data point. - if ( - (chartType === CHART_TYPE.EVENT_DISTRIBUTION && value > 0) || - (chartType !== CHART_TYPE.EVENT_DISTRIBUTION && value !== null) - ) { - chartData.push({ - date: +time, - value: value, - entity: filterField, - }); - } - }); - } else { - chartData = _.map(metricData, (value, time) => ({ - date: +time, - value: value, - })); - } + // Return dataset in format used by the chart. + // i.e. array of Objects with keys date (timestamp), value, + // plus anomalyScore for points with anomaly markers. + let chartData = []; + if (metricData !== undefined) { + if (eventDistribution.length > 0 && records.length > 0) { + const filterField = records[0].by_field_value || records[0].over_field_value; + chartData = eventDistribution.filter(d => d.entity !== filterField); + _.map(metricData, (value, time) => { + // The filtering for rare/event_distribution charts needs to be handled + // differently because of how the source data is structured. + // For rare chart values we are only interested wether a value is either `0` or not, + // `0` acts like a flag in the chart whether to display the dot/marker. + // All other charts (single metric, population) are metric based and with + // those a value of `null` acts as the flag to hide a data point. + if ( + (chartType === CHART_TYPE.EVENT_DISTRIBUTION && value > 0) || + (chartType !== CHART_TYPE.EVENT_DISTRIBUTION && value !== null) + ) { + chartData.push({ + date: +time, + value: value, + entity: filterField, + }); + } + }); + } else { + chartData = _.map(metricData, (value, time) => ({ + date: +time, + value: value, + })); } + } - // Iterate through the anomaly records, adding anomalyScore properties - // to the chartData entries for anomalous buckets. - const chartDataForPointSearch = getChartDataForPointSearch(chartData, records[0], chartType); - _.each(records, record => { - // Look for a chart point with the same time as the record. - // If none found, insert a point for anomalies due to a gap in the data. - const recordTime = record[ML_TIME_FIELD_NAME]; - let chartPoint = findChartPointForTime(chartDataForPointSearch, recordTime); - if (chartPoint === undefined) { - chartPoint = { date: new Date(recordTime), value: null }; - chartData.push(chartPoint); - } + // Iterate through the anomaly records, adding anomalyScore properties + // to the chartData entries for anomalous buckets. + const chartDataForPointSearch = getChartDataForPointSearch(chartData, records[0], chartType); + _.each(records, record => { + // Look for a chart point with the same time as the record. + // If none found, insert a point for anomalies due to a gap in the data. + const recordTime = record[ML_TIME_FIELD_NAME]; + let chartPoint = findChartPointForTime(chartDataForPointSearch, recordTime); + if (chartPoint === undefined) { + chartPoint = { date: new Date(recordTime), value: null }; + chartData.push(chartPoint); + } - chartPoint.anomalyScore = record.record_score; + chartPoint.anomalyScore = record.record_score; - if (record.actual !== undefined) { - chartPoint.actual = record.actual; - chartPoint.typical = record.typical; - } else { - const causes = _.get(record, 'causes', []); - if (causes.length > 0) { - chartPoint.byFieldName = record.by_field_name; - chartPoint.numberOfCauses = causes.length; - if (causes.length === 1) { - // If only a single cause, copy actual and typical values to the top level. - const cause = _.first(record.causes); - chartPoint.actual = cause.actual; - chartPoint.typical = cause.typical; - } + if (record.actual !== undefined) { + chartPoint.actual = record.actual; + chartPoint.typical = record.typical; + } else { + const causes = _.get(record, 'causes', []); + if (causes.length > 0) { + chartPoint.byFieldName = record.by_field_name; + chartPoint.numberOfCauses = causes.length; + if (causes.length === 1) { + // If only a single cause, copy actual and typical values to the top level. + const cause = _.first(record.causes); + chartPoint.actual = cause.actual; + chartPoint.typical = cause.typical; } } + } + + if (record.multi_bucket_impact !== undefined) { + chartPoint.multiBucketImpact = record.multi_bucket_impact; + } + }); - if (record.multi_bucket_impact !== undefined) { - chartPoint.multiBucketImpact = record.multi_bucket_impact; + // Add a scheduledEvents property to any points in the chart data set + // which correspond to times of scheduled events for the job. + if (scheduledEvents !== undefined) { + _.each(scheduledEvents, (events, time) => { + const chartPoint = findChartPointForTime(chartDataForPointSearch, Number(time)); + if (chartPoint !== undefined) { + // Note if the scheduled event coincides with an absence of the underlying metric data, + // we don't worry about plotting the event. + chartPoint.scheduledEvents = events; } }); + } - // Add a scheduledEvents property to any points in the chart data set - // which correspond to times of scheduled events for the job. - if (scheduledEvents !== undefined) { - _.each(scheduledEvents, (events, time) => { - const chartPoint = findChartPointForTime(chartDataForPointSearch, Number(time)); - if (chartPoint !== undefined) { - // Note if the scheduled event coincides with an absence of the underlying metric data, - // we don't worry about plotting the event. - chartPoint.scheduledEvents = events; - } - }); - } + return chartData; + } - return chartData; + function getChartDataForPointSearch(chartData, record, chartType) { + if ( + chartType === CHART_TYPE.EVENT_DISTRIBUTION || + chartType === CHART_TYPE.POPULATION_DISTRIBUTION + ) { + return chartData.filter(d => { + return d.entity === (record && (record.by_field_value || record.over_field_value)); + }); } - function getChartDataForPointSearch(chartData, record, chartType) { - if ( - chartType === CHART_TYPE.EVENT_DISTRIBUTION || - chartType === CHART_TYPE.POPULATION_DISTRIBUTION - ) { - return chartData.filter(d => { - return d.entity === (record && (record.by_field_value || record.over_field_value)); - }); - } + return chartData; + } - return chartData; - } + function findChartPointForTime(chartData, time) { + return chartData.find(point => point.date === time); + } - function findChartPointForTime(chartData, time) { - return chartData.find(point => point.date === time); + Promise.all(seriesPromises) + .then(response => { + // calculate an overall min/max for all series + const processedData = response.map(processChartData); + const allDataPoints = _.reduce( + processedData, + (datapoints, series) => { + _.each(series, d => datapoints.push(d)); + return datapoints; + }, + [] + ); + const overallChartLimits = chartLimits(allDataPoints); + + data.seriesToPlot = response.map((d, i) => ({ + ...seriesConfigs[i], + loading: false, + chartData: processedData[i], + plotEarliest: chartRange.min, + plotLatest: chartRange.max, + selectedEarliest: earliestMs, + selectedLatest: latestMs, + chartLimits: USE_OVERALL_CHART_LIMITS ? overallChartLimits : chartLimits(processedData[i]), + })); + explorerService.setCharts({ ...data }); + }) + .catch(error => { + console.error(error); + }); +}; + +function processRecordsForDisplay(anomalyRecords) { + // Aggregate the anomaly data by detector, and entity (by/over/partition). + if (anomalyRecords.length === 0) { + return []; + } + + // Aggregate by job, detector, and analysis fields (partition, by, over). + const aggregatedData = {}; + _.each(anomalyRecords, record => { + // Check if we can plot a chart for this record, depending on whether the source data + // is chartable, and if model plot is enabled for the job. + const job = mlJobService.getJob(record.job_id); + let isChartable = isSourceDataChartableForDetector(job, record.detector_index); + if (isChartable === false) { + // Check if model plot is enabled for this job. + // Need to check the entity fields for the record in case the model plot config has a terms list. + const entityFields = getEntityFieldList(record); + isChartable = isModelPlotEnabled(job, record.detector_index, entityFields); } - Promise.all(seriesPromises) - .then(response => { - // calculate an overall min/max for all series - const processedData = response.map(processChartData); - const allDataPoints = _.reduce( - processedData, - (datapoints, series) => { - _.each(series, d => datapoints.push(d)); - return datapoints; - }, - [] - ); - const overallChartLimits = chartLimits(allDataPoints); - - data.seriesToPlot = response.map((d, i) => ({ - ...seriesConfigs[i], - loading: false, - chartData: processedData[i], - plotEarliest: chartRange.min, - plotLatest: chartRange.max, - selectedEarliest: earliestMs, - selectedLatest: latestMs, - chartLimits: USE_OVERALL_CHART_LIMITS - ? overallChartLimits - : chartLimits(processedData[i]), - })); - callback(data); - }) - .catch(error => { - console.error(error); - }); - }; + if (isChartable === false) { + return; + } + const jobId = record.job_id; + if (aggregatedData[jobId] === undefined) { + aggregatedData[jobId] = {}; + } + const detectorsForJob = aggregatedData[jobId]; - function processRecordsForDisplay(anomalyRecords) { - // Aggregate the anomaly data by detector, and entity (by/over/partition). - if (anomalyRecords.length === 0) { - return []; + const detectorIndex = record.detector_index; + if (detectorsForJob[detectorIndex] === undefined) { + detectorsForJob[detectorIndex] = {}; } - // Aggregate by job, detector, and analysis fields (partition, by, over). - const aggregatedData = {}; - _.each(anomalyRecords, record => { - // Check if we can plot a chart for this record, depending on whether the source data - // is chartable, and if model plot is enabled for the job. - const job = mlJobService.getJob(record.job_id); - let isChartable = isSourceDataChartableForDetector(job, record.detector_index); - if (isChartable === false) { - // Check if model plot is enabled for this job. - // Need to check the entity fields for the record in case the model plot config has a terms list. - const entityFields = getEntityFieldList(record); - isChartable = isModelPlotEnabled(job, record.detector_index, entityFields); - } + // TODO - work out how best to display results from detectors with just an over field. + const firstFieldName = + record.partition_field_name || record.by_field_name || record.over_field_name; + const firstFieldValue = + record.partition_field_value || record.by_field_value || record.over_field_value; + if (firstFieldName !== undefined) { + const groupsForDetector = detectorsForJob[detectorIndex]; - if (isChartable === false) { - return; + if (groupsForDetector[firstFieldName] === undefined) { + groupsForDetector[firstFieldName] = {}; } - const jobId = record.job_id; - if (aggregatedData[jobId] === undefined) { - aggregatedData[jobId] = {}; + const valuesForGroup = groupsForDetector[firstFieldName]; + if (valuesForGroup[firstFieldValue] === undefined) { + valuesForGroup[firstFieldValue] = {}; } - const detectorsForJob = aggregatedData[jobId]; - const detectorIndex = record.detector_index; - if (detectorsForJob[detectorIndex] === undefined) { - detectorsForJob[detectorIndex] = {}; - } + const dataForGroupValue = valuesForGroup[firstFieldValue]; - // TODO - work out how best to display results from detectors with just an over field. - const firstFieldName = - record.partition_field_name || record.by_field_name || record.over_field_name; - const firstFieldValue = - record.partition_field_value || record.by_field_value || record.over_field_value; - if (firstFieldName !== undefined) { - const groupsForDetector = detectorsForJob[detectorIndex]; - - if (groupsForDetector[firstFieldName] === undefined) { - groupsForDetector[firstFieldName] = {}; - } - const valuesForGroup = groupsForDetector[firstFieldName]; - if (valuesForGroup[firstFieldValue] === undefined) { - valuesForGroup[firstFieldValue] = {}; - } - - const dataForGroupValue = valuesForGroup[firstFieldValue]; - - let isSecondSplit = false; - if (record.partition_field_name !== undefined) { - const splitFieldName = record.over_field_name || record.by_field_name; - if (splitFieldName !== undefined) { - isSecondSplit = true; - } + let isSecondSplit = false; + if (record.partition_field_name !== undefined) { + const splitFieldName = record.over_field_name || record.by_field_name; + if (splitFieldName !== undefined) { + isSecondSplit = true; } + } - if (isSecondSplit === false) { - if (dataForGroupValue.maxScoreRecord === undefined) { + if (isSecondSplit === false) { + if (dataForGroupValue.maxScoreRecord === undefined) { + dataForGroupValue.maxScore = record.record_score; + dataForGroupValue.maxScoreRecord = record; + } else { + if (record.record_score > dataForGroupValue.maxScore) { dataForGroupValue.maxScore = record.record_score; dataForGroupValue.maxScoreRecord = record; - } else { - if (record.record_score > dataForGroupValue.maxScore) { - dataForGroupValue.maxScore = record.record_score; - dataForGroupValue.maxScoreRecord = record; - } } - } else { - // Aggregate another level for the over or by field. - const secondFieldName = record.over_field_name || record.by_field_name; - const secondFieldValue = record.over_field_value || record.by_field_value; + } + } else { + // Aggregate another level for the over or by field. + const secondFieldName = record.over_field_name || record.by_field_name; + const secondFieldValue = record.over_field_value || record.by_field_value; - if (dataForGroupValue[secondFieldName] === undefined) { - dataForGroupValue[secondFieldName] = {}; - } + if (dataForGroupValue[secondFieldName] === undefined) { + dataForGroupValue[secondFieldName] = {}; + } - const splitsForGroup = dataForGroupValue[secondFieldName]; - if (splitsForGroup[secondFieldValue] === undefined) { - splitsForGroup[secondFieldValue] = {}; - } + const splitsForGroup = dataForGroupValue[secondFieldName]; + if (splitsForGroup[secondFieldValue] === undefined) { + splitsForGroup[secondFieldValue] = {}; + } - const dataForSplitValue = splitsForGroup[secondFieldValue]; - if (dataForSplitValue.maxScoreRecord === undefined) { + const dataForSplitValue = splitsForGroup[secondFieldValue]; + if (dataForSplitValue.maxScoreRecord === undefined) { + dataForSplitValue.maxScore = record.record_score; + dataForSplitValue.maxScoreRecord = record; + } else { + if (record.record_score > dataForSplitValue.maxScore) { dataForSplitValue.maxScore = record.record_score; dataForSplitValue.maxScoreRecord = record; - } else { - if (record.record_score > dataForSplitValue.maxScore) { - dataForSplitValue.maxScore = record.record_score; - dataForSplitValue.maxScoreRecord = record; - } } } + } + } else { + // Detector with no partition or by field. + const dataForDetector = detectorsForJob[detectorIndex]; + if (dataForDetector.maxScoreRecord === undefined) { + dataForDetector.maxScore = record.record_score; + dataForDetector.maxScoreRecord = record; } else { - // Detector with no partition or by field. - const dataForDetector = detectorsForJob[detectorIndex]; - if (dataForDetector.maxScoreRecord === undefined) { + if (record.record_score > dataForDetector.maxScore) { dataForDetector.maxScore = record.record_score; dataForDetector.maxScoreRecord = record; - } else { - if (record.record_score > dataForDetector.maxScore) { - dataForDetector.maxScore = record.record_score; - dataForDetector.maxScoreRecord = record; - } } } - }); - - console.log('explorer charts aggregatedData is:', aggregatedData); - let recordsForSeries = []; - // Convert to an array of the records with the highest record_score per unique series. - _.each(aggregatedData, detectorsForJob => { - _.each(detectorsForJob, groupsForDetector => { - if (groupsForDetector.maxScoreRecord !== undefined) { - // Detector with no partition / by field. - recordsForSeries.push(groupsForDetector.maxScoreRecord); - } else { - _.each(groupsForDetector, valuesForGroup => { - _.each(valuesForGroup, dataForGroupValue => { - if (dataForGroupValue.maxScoreRecord !== undefined) { - recordsForSeries.push(dataForGroupValue.maxScoreRecord); - } else { - // Second level of aggregation for partition and by/over. - _.each(dataForGroupValue, splitsForGroup => { - _.each(splitsForGroup, dataForSplitValue => { - recordsForSeries.push(dataForSplitValue.maxScoreRecord); - }); + } + }); + + console.log('explorer charts aggregatedData is:', aggregatedData); + let recordsForSeries = []; + // Convert to an array of the records with the highest record_score per unique series. + _.each(aggregatedData, detectorsForJob => { + _.each(detectorsForJob, groupsForDetector => { + if (groupsForDetector.maxScoreRecord !== undefined) { + // Detector with no partition / by field. + recordsForSeries.push(groupsForDetector.maxScoreRecord); + } else { + _.each(groupsForDetector, valuesForGroup => { + _.each(valuesForGroup, dataForGroupValue => { + if (dataForGroupValue.maxScoreRecord !== undefined) { + recordsForSeries.push(dataForGroupValue.maxScoreRecord); + } else { + // Second level of aggregation for partition and by/over. + _.each(dataForGroupValue, splitsForGroup => { + _.each(splitsForGroup, dataForSplitValue => { + recordsForSeries.push(dataForSplitValue.maxScoreRecord); }); - } - }); + }); + } }); - } - }); + }); + } }); - recordsForSeries = _.sortBy(recordsForSeries, 'record_score').reverse(); + }); + recordsForSeries = _.sortBy(recordsForSeries, 'record_score').reverse(); - return recordsForSeries; - } + return recordsForSeries; +} - function calculateChartRange( - seriesConfigs, - earliestMs, - latestMs, - chartWidth, - recordsToPlot, - timeFieldName - ) { - let tooManyBuckets = false; - // Calculate the time range for the charts. - // Fit in as many points in the available container width plotted at the job bucket span. - const midpointMs = Math.ceil((earliestMs + latestMs) / 2); - const maxBucketSpanMs = - Math.max.apply(null, _.pluck(seriesConfigs, 'bucketSpanSeconds')) * 1000; - - const pointsToPlotFullSelection = Math.ceil((latestMs - earliestMs) / maxBucketSpanMs); - - // Optimally space points 5px apart. - const optimumPointSpacing = 5; - const optimumNumPoints = chartWidth / optimumPointSpacing; - - // Increase actual number of points if we can't plot the selected range - // at optimal point spacing. - const plotPoints = Math.max(optimumNumPoints, pointsToPlotFullSelection); - const halfPoints = Math.ceil(plotPoints / 2); - let chartRange = { - min: midpointMs - halfPoints * maxBucketSpanMs, - max: midpointMs + halfPoints * maxBucketSpanMs, - }; - - if (plotPoints > CHART_MAX_POINTS) { - tooManyBuckets = true; - // For each series being plotted, display the record with the highest score if possible. - const maxTimeSpan = maxBucketSpanMs * CHART_MAX_POINTS; - let minMs = recordsToPlot[0][timeFieldName]; - let maxMs = recordsToPlot[0][timeFieldName]; - - _.each(recordsToPlot, record => { - const diffMs = maxMs - minMs; - if (diffMs < maxTimeSpan) { - const recordTime = record[timeFieldName]; - if (recordTime < minMs) { - if (maxMs - recordTime <= maxTimeSpan) { - minMs = recordTime; - } - } +function calculateChartRange( + seriesConfigs, + earliestMs, + latestMs, + chartWidth, + recordsToPlot, + timeFieldName +) { + let tooManyBuckets = false; + // Calculate the time range for the charts. + // Fit in as many points in the available container width plotted at the job bucket span. + const midpointMs = Math.ceil((earliestMs + latestMs) / 2); + const maxBucketSpanMs = Math.max.apply(null, _.pluck(seriesConfigs, 'bucketSpanSeconds')) * 1000; + + const pointsToPlotFullSelection = Math.ceil((latestMs - earliestMs) / maxBucketSpanMs); + + // Optimally space points 5px apart. + const optimumPointSpacing = 5; + const optimumNumPoints = chartWidth / optimumPointSpacing; + + // Increase actual number of points if we can't plot the selected range + // at optimal point spacing. + const plotPoints = Math.max(optimumNumPoints, pointsToPlotFullSelection); + const halfPoints = Math.ceil(plotPoints / 2); + let chartRange = { + min: midpointMs - halfPoints * maxBucketSpanMs, + max: midpointMs + halfPoints * maxBucketSpanMs, + }; - if (recordTime > maxMs) { - if (recordTime - minMs <= maxTimeSpan) { - maxMs = recordTime; - } + if (plotPoints > CHART_MAX_POINTS) { + tooManyBuckets = true; + // For each series being plotted, display the record with the highest score if possible. + const maxTimeSpan = maxBucketSpanMs * CHART_MAX_POINTS; + let minMs = recordsToPlot[0][timeFieldName]; + let maxMs = recordsToPlot[0][timeFieldName]; + + _.each(recordsToPlot, record => { + const diffMs = maxMs - minMs; + if (diffMs < maxTimeSpan) { + const recordTime = record[timeFieldName]; + if (recordTime < minMs) { + if (maxMs - recordTime <= maxTimeSpan) { + minMs = recordTime; } } - }); - if (maxMs - minMs < maxTimeSpan) { - // Expand out to cover as much as the requested time span as possible. - minMs = Math.max(earliestMs, minMs - maxTimeSpan); - maxMs = Math.min(latestMs, maxMs + maxTimeSpan); + if (recordTime > maxMs) { + if (recordTime - minMs <= maxTimeSpan) { + maxMs = recordTime; + } + } } + }); - chartRange = { min: minMs, max: maxMs }; + if (maxMs - minMs < maxTimeSpan) { + // Expand out to cover as much as the requested time span as possible. + minMs = Math.max(earliestMs, minMs - maxTimeSpan); + maxMs = Math.min(latestMs, maxMs + maxTimeSpan); } - return { - chartRange, - tooManyBuckets, - }; + chartRange = { min: minMs, max: maxMs }; } - return anomalyDataChange; + return { + chartRange, + tooManyBuckets, + }; } diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container_service.test.js b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container_service.test.js index 483a359f98e5b..fbbf5eb324095 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container_service.test.js +++ b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_charts/explorer_charts_container_service.test.js @@ -102,119 +102,79 @@ jest.mock('ui/chrome', () => ({ }), })); -import { - explorerChartsContainerServiceFactory, - getDefaultChartsData, -} from './explorer_charts_container_service'; +jest.mock('../explorer_dashboard_service', () => ({ + explorerService: { + setCharts: jest.fn(), + }, +})); -describe('explorerChartsContainerService', () => { - test('Initialize factory', done => { - explorerChartsContainerServiceFactory(callback); +import { anomalyDataChange, getDefaultChartsData } from './explorer_charts_container_service'; +import { explorerService } from '../explorer_dashboard_service'; - function callback(data) { - expect(data).toEqual(getDefaultChartsData()); - done(); - } +describe('explorerChartsContainerService', () => { + afterEach(() => { + explorerService.setCharts.mockClear(); }); test('call anomalyChangeListener with empty series config', done => { - // callback will be called multiple times. - // the callbackData array contains the expected data values for each consecutive call. - const callbackData = []; - callbackData.push(getDefaultChartsData()); - callbackData.push({ - ...getDefaultChartsData(), - chartsPerRow: 2, + anomalyDataChange([], 1486656000000, 1486670399999); + + setImmediate(() => { + expect(explorerService.setCharts.mock.calls.length).toBe(1); + expect(explorerService.setCharts.mock.calls[0][0]).toStrictEqual({ + ...getDefaultChartsData(), + chartsPerRow: 2, + }); + done(); }); - - const anomalyDataChangeListener = explorerChartsContainerServiceFactory(callback); - - anomalyDataChangeListener([], 1486656000000, 1486670399999); - - function callback(data) { - if (callbackData.length > 0) { - expect(data).toEqual({ - ...callbackData.shift(), - }); - } - if (callbackData.length === 0) { - done(); - } - } }); test('call anomalyChangeListener with actual series config', done => { - let callbackCount = 0; - const expectedTestCount = 3; - - const anomalyDataChangeListener = explorerChartsContainerServiceFactory(callback); + anomalyDataChange(mockAnomalyChartRecords, 1486656000000, 1486670399999); - anomalyDataChangeListener(mockAnomalyChartRecords, 1486656000000, 1486670399999); - - function callback(data) { - callbackCount++; - expect(data).toMatchSnapshot(); - if (callbackCount === expectedTestCount) { - done(); - } - } + setImmediate(() => { + expect(explorerService.setCharts.mock.calls.length).toBe(2); + expect(explorerService.setCharts.mock.calls[0][0]).toMatchSnapshot(); + expect(explorerService.setCharts.mock.calls[1][0]).toMatchSnapshot(); + done(); + }); }); test('filtering should skip values of null', done => { - let callbackCount = 0; - const expectedTestCount = 3; - - const anomalyDataChangeListener = explorerChartsContainerServiceFactory(callback); - const mockAnomalyChartRecordsClone = _.cloneDeep(mockAnomalyChartRecords).map(d => { d.job_id = 'mock-job-id-distribution'; return d; }); - anomalyDataChangeListener(mockAnomalyChartRecordsClone, 1486656000000, 1486670399999); + anomalyDataChange(mockAnomalyChartRecordsClone, 1486656000000, 1486670399999); - function callback(data) { - callbackCount++; + setImmediate(() => { + expect(explorerService.setCharts.mock.calls.length).toBe(2); + expect(explorerService.setCharts.mock.calls[0][0].seriesToPlot.length).toBe(1); + expect(explorerService.setCharts.mock.calls[1][0].seriesToPlot.length).toBe(1); - if (callbackCount === 1) { - expect(data.seriesToPlot).toHaveLength(0); - } - if (callbackCount === 3) { - expect(data.seriesToPlot).toHaveLength(1); - - // the mock source dataset has a length of 115. one data point has a value of `null`, - // and another one `0`. the received dataset should have a length of 114, - // it should remove the datapoint with `null` and keep the one with `0`. - const chartData = data.seriesToPlot[0].chartData; - expect(chartData).toHaveLength(114); - expect(chartData.filter(d => d.value === 0)).toHaveLength(1); - expect(chartData.filter(d => d.value === null)).toHaveLength(0); - } - if (callbackCount === expectedTestCount) { - done(); - } - } + // the mock source dataset has a length of 115. one data point has a value of `null`, + // and another one `0`. the received dataset should have a length of 114, + // it should remove the datapoint with `null` and keep the one with `0`. + const chartData = explorerService.setCharts.mock.calls[1][0].seriesToPlot[0].chartData; + expect(chartData).toHaveLength(114); + expect(chartData.filter(d => d.value === 0)).toHaveLength(1); + expect(chartData.filter(d => d.value === null)).toHaveLength(0); + done(); + }); }); test('field value with trailing dot should not throw an error', done => { - let callbackCount = 0; - const expectedTestCount = 3; - - const anomalyDataChangeListener = explorerChartsContainerServiceFactory(callback); - const mockAnomalyChartRecordsClone = _.cloneDeep(mockAnomalyChartRecords); mockAnomalyChartRecordsClone[1].partition_field_value = 'AAL.'; expect(() => { - anomalyDataChangeListener(mockAnomalyChartRecordsClone, 1486656000000, 1486670399999); + anomalyDataChange(mockAnomalyChartRecordsClone, 1486656000000, 1486670399999); }).not.toThrow(); - function callback() { - callbackCount++; - - if (callbackCount === expectedTestCount) { - done(); - } - } + setImmediate(() => { + expect(explorerService.setCharts.mock.calls.length).toBe(2); + done(); + }); }); }); diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_constants.ts b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_constants.ts index 66cd98f7ebe29..b084f503272cc 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_constants.ts +++ b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_constants.ts @@ -17,24 +17,15 @@ export const DRAG_SELECT_ACTION = { }; export const EXPLORER_ACTION = { - APP_STATE_SET: 'appStateSet', - APP_STATE_CLEAR_INFLUENCER_FILTER_SETTINGS: 'appStateClearInfluencerFilterSettings', - APP_STATE_CLEAR_SELECTION: 'appStateClearSelection', - APP_STATE_SAVE_SELECTION: 'appStateSaveSelection', - APP_STATE_SAVE_VIEW_BY_SWIMLANE_FIELD_NAME: 'appStateSaveViewBySwimlaneFieldName', - APP_STATE_SAVE_INFLUENCER_FILTER_SETTINGS: 'appStateSaveInfluencerFilterSettings', CLEAR_INFLUENCER_FILTER_SETTINGS: 'clearInfluencerFilterSettings', CLEAR_JOBS: 'clearJobs', - CLEAR_SELECTION: 'clearSelection', - INITIALIZE: 'initialize', JOB_SELECTION_CHANGE: 'jobSelectionChange', - LOAD_JOBS: 'loadJobs', - RESET: 'reset', SET_BOUNDS: 'setBounds', SET_CHARTS: 'setCharts', + SET_EXPLORER_DATA: 'setExplorerData', + SET_FILTER_DATA: 'setFilterData', SET_INFLUENCER_FILTER_SETTINGS: 'setInfluencerFilterSettings', SET_SELECTED_CELLS: 'setSelectedCells', - SET_STATE: 'setState', SET_SWIMLANE_CONTAINER_WIDTH: 'setSwimlaneContainerWidth', SET_SWIMLANE_LIMIT: 'setSwimlaneLimit', SET_VIEW_BY_SWIMLANE_FIELD_NAME: 'setViewBySwimlaneFieldName', diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_dashboard_service.ts b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_dashboard_service.ts index 713857835b3b9..89e1a908b1ecc 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_dashboard_service.ts +++ b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_dashboard_service.ts @@ -9,30 +9,25 @@ * components in the Explorer dashboard. */ -import { isEqual, pick } from 'lodash'; +import { isEqual } from 'lodash'; -import { from, isObservable, BehaviorSubject, Observable, Subject } from 'rxjs'; -import { distinctUntilChanged, flatMap, map, pairwise, scan } from 'rxjs/operators'; +import { from, isObservable, Observable, Subject } from 'rxjs'; +import { distinctUntilChanged, flatMap, map, scan } from 'rxjs/operators'; import { DeepPartial } from '../../../common/types/common'; -import { jobSelectionActionCreator, loadExplorerData } from './actions'; +import { jobSelectionActionCreator } from './actions'; import { ExplorerChartsData } from './explorer_charts/explorer_charts_container_service'; import { EXPLORER_ACTION } from './explorer_constants'; -import { RestoredAppState, SelectedCells, TimeRangeBounds } from './explorer_utils'; -import { - explorerReducer, - getExplorerDefaultState, - ExplorerAppState, - ExplorerState, -} from './reducers'; +import { AppStateSelectedCells, TimeRangeBounds } from './explorer_utils'; +import { explorerReducer, getExplorerDefaultState, ExplorerState } from './reducers'; export const ALLOW_CELL_RANGE_SELECTION = true; export const dragSelect$ = new Subject(); type ExplorerAction = Action | Observable; -const explorerAction$ = new BehaviorSubject({ type: EXPLORER_ACTION.RESET }); +export const explorerAction$ = new Subject(); export type ActionPayload = any; @@ -51,94 +46,79 @@ const explorerFilteredAction$ = explorerAction$.pipe( // applies action and returns state const explorerState$: Observable = explorerFilteredAction$.pipe( - scan(explorerReducer, getExplorerDefaultState()), - pairwise(), - map(([prev, curr]) => { - if ( - curr.selectedJobs !== null && - curr.bounds !== undefined && - !isEqual(getCompareState(prev), getCompareState(curr)) - ) { - explorerAction$.next(loadExplorerData(curr).pipe(map(d => setStateActionCreator(d)))); - } - return curr; - }) + scan(explorerReducer, getExplorerDefaultState()) ); +interface ExplorerAppState { + mlExplorerSwimlane: { + selectedType?: string; + selectedLanes?: string[]; + selectedTimes?: number[]; + showTopFieldValues?: boolean; + viewByFieldName?: string; + }; + mlExplorerFilter: { + influencersFilterQuery?: unknown; + filterActive?: boolean; + filteredFields?: string[]; + queryString?: string; + }; +} + const explorerAppState$: Observable = explorerState$.pipe( - map((state: ExplorerState) => state.appState), + map( + (state: ExplorerState): ExplorerAppState => { + const appState: ExplorerAppState = { + mlExplorerFilter: {}, + mlExplorerSwimlane: {}, + }; + + if (state.selectedCells !== undefined) { + const swimlaneSelectedCells = state.selectedCells; + appState.mlExplorerSwimlane.selectedType = swimlaneSelectedCells.type; + appState.mlExplorerSwimlane.selectedLanes = swimlaneSelectedCells.lanes; + appState.mlExplorerSwimlane.selectedTimes = swimlaneSelectedCells.times; + appState.mlExplorerSwimlane.showTopFieldValues = swimlaneSelectedCells.showTopFieldValues; + } + + if (state.viewBySwimlaneFieldName !== undefined) { + appState.mlExplorerSwimlane.viewByFieldName = state.viewBySwimlaneFieldName; + } + + if (state.filterActive) { + appState.mlExplorerFilter.influencersFilterQuery = state.influencersFilterQuery; + appState.mlExplorerFilter.filterActive = state.filterActive; + appState.mlExplorerFilter.filteredFields = state.filteredFields; + appState.mlExplorerFilter.queryString = state.queryString; + } + + return appState; + } + ), distinctUntilChanged(isEqual) ); -function getCompareState(state: ExplorerState) { - return pick(state, [ - 'bounds', - 'filterActive', - 'filteredFields', - 'influencersFilterQuery', - 'isAndOperator', - 'noInfluencersConfigured', - 'selectedCells', - 'selectedJobs', - 'swimlaneContainerWidth', - 'swimlaneLimit', - 'tableInterval', - 'tableSeverity', - 'viewBySwimlaneFieldName', - ]); -} - -export const setStateActionCreator = (payload: DeepPartial) => ({ - type: EXPLORER_ACTION.SET_STATE, +const setExplorerDataActionCreator = (payload: DeepPartial) => ({ + type: EXPLORER_ACTION.SET_EXPLORER_DATA, + payload, +}); +const setFilterDataActionCreator = (payload: DeepPartial) => ({ + type: EXPLORER_ACTION.SET_FILTER_DATA, payload, }); - -interface AppStateSelection { - type: string; - lanes: string[]; - times: number[]; - showTopFieldValues: boolean; - viewByFieldName: string; -} // Export observable state and action dispatchers as service export const explorerService = { appState$: explorerAppState$, state$: explorerState$, - appStateClearSelection: () => { - explorerAction$.next({ type: EXPLORER_ACTION.APP_STATE_CLEAR_SELECTION }); - }, - appStateSaveSelection: (payload: AppStateSelection) => { - explorerAction$.next({ type: EXPLORER_ACTION.APP_STATE_SAVE_SELECTION, payload }); - }, clearInfluencerFilterSettings: () => { explorerAction$.next({ type: EXPLORER_ACTION.CLEAR_INFLUENCER_FILTER_SETTINGS }); }, clearJobs: () => { explorerAction$.next({ type: EXPLORER_ACTION.CLEAR_JOBS }); }, - clearSelection: () => { - explorerAction$.next({ type: EXPLORER_ACTION.CLEAR_SELECTION }); - }, - updateJobSelection: (selectedJobIds: string[], restoredAppState: RestoredAppState) => { - explorerAction$.next( - jobSelectionActionCreator( - EXPLORER_ACTION.JOB_SELECTION_CHANGE, - selectedJobIds, - restoredAppState - ) - ); - }, - initialize: (selectedJobIds: string[], restoredAppState: RestoredAppState) => { - explorerAction$.next( - jobSelectionActionCreator(EXPLORER_ACTION.INITIALIZE, selectedJobIds, restoredAppState) - ); - }, - reset: () => { - explorerAction$.next({ type: EXPLORER_ACTION.RESET }); - }, - setAppState: (payload: DeepPartial) => { - explorerAction$.next({ type: EXPLORER_ACTION.APP_STATE_SET, payload }); + updateJobSelection: (selectedJobIds: string[]) => { + explorerAction$.next(jobSelectionActionCreator(selectedJobIds)); }, setBounds: (payload: TimeRangeBounds) => { explorerAction$.next({ type: EXPLORER_ACTION.SET_BOUNDS, payload }); @@ -152,14 +132,17 @@ export const explorerService = { payload, }); }, - setSelectedCells: (payload: SelectedCells) => { + setSelectedCells: (payload: AppStateSelectedCells | undefined) => { explorerAction$.next({ type: EXPLORER_ACTION.SET_SELECTED_CELLS, payload, }); }, - setState: (payload: DeepPartial) => { - explorerAction$.next(setStateActionCreator(payload)); + setExplorerData: (payload: DeepPartial) => { + explorerAction$.next(setExplorerDataActionCreator(payload)); + }, + setFilterData: (payload: DeepPartial) => { + explorerAction$.next(setFilterDataActionCreator(payload)); }, setSwimlaneContainerWidth: (payload: number) => { explorerAction$.next({ diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_utils.d.ts b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_utils.d.ts index d7873e6d52d78..0ab75b1db2972 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_utils.d.ts +++ b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_utils.d.ts @@ -11,8 +11,7 @@ import { CombinedJob } from '../jobs/new_job/common/job_creator/configs'; import { TimeBucketsInterval } from '../util/time_buckets'; interface ClearedSelectedAnomaliesState { - anomalyChartRecords: []; - selectedCells: null; + selectedCells: undefined; viewByLoadedForTimeFormatted: null; } @@ -37,7 +36,7 @@ export declare const getDefaultSwimlaneData: () => SwimlaneData; export declare const getInfluencers: (selectedJobs: any[]) => string[]; export declare const getSelectionInfluencers: ( - selectedCells: SelectedCells, + selectedCells: AppStateSelectedCells | undefined, fieldName: string ) => any[]; @@ -47,7 +46,7 @@ interface SelectionTimeRange { } export declare const getSelectionTimeRange: ( - selectedCells: SelectedCells, + selectedCells: AppStateSelectedCells | undefined, interval: number, bounds: TimeRangeBounds ) => SelectionTimeRange; @@ -62,7 +61,7 @@ interface ViewBySwimlaneOptionsArgs { filterActive: boolean; filteredFields: any[]; isAndOperator: boolean; - selectedCells: SelectedCells; + selectedCells: AppStateSelectedCells; selectedJobs: ExplorerJob[]; } @@ -94,7 +93,7 @@ declare interface SwimlaneBounds { } export declare const loadAnnotationsTableData: ( - selectedCells: SelectedCells, + selectedCells: AppStateSelectedCells | undefined, selectedJobs: ExplorerJob[], interval: number, bounds: TimeRangeBounds @@ -109,7 +108,7 @@ export declare interface AnomaliesTableData { } export declare const loadAnomaliesTableData: ( - selectedCells: SelectedCells, + selectedCells: AppStateSelectedCells | undefined, selectedJobs: ExplorerJob[], dateFormatTz: any, interval: number, @@ -125,7 +124,7 @@ export declare const loadDataForCharts: ( earliestMs: number, latestMs: number, influencers: any[], - selectedCells: SelectedCells, + selectedCells: AppStateSelectedCells | undefined, influencersFilterQuery: any ) => Promise; @@ -178,25 +177,17 @@ export declare const loadViewByTopFieldValuesForSelectedTime: ( noInfluencersConfigured: boolean ) => Promise; -declare interface FilterData { +export declare interface FilterData { influencersFilterQuery: any; filterActive: boolean; filteredFields: string[]; queryString: string; } -declare interface SelectedCells { +export declare interface AppStateSelectedCells { type: string; lanes: string[]; times: number[]; showTopFieldValues: boolean; viewByFieldName: string; } - -export declare interface RestoredAppState { - selectedCells?: SelectedCells; - filterData: {} | FilterData; - viewBySwimlaneFieldName: string; -} - -export declare const restoreAppState: (appState: any) => RestoredAppState; diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_utils.js b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_utils.js index b54b691f3aba6..4fb4e7d4df94f 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/explorer_utils.js +++ b/x-pack/legacy/plugins/ml/public/application/explorer/explorer_utils.js @@ -53,8 +53,7 @@ export function createJobs(jobs) { export function getClearedSelectedAnomaliesState() { return { - anomalyChartRecords: [], - selectedCells: null, + selectedCells: undefined, viewByLoadedForTimeFormatted: null, }; } @@ -195,7 +194,7 @@ export function getSelectionTimeRange(selectedCells, interval, bounds) { let earliestMs = bounds.min.valueOf(); let latestMs = bounds.max.valueOf(); - if (selectedCells !== null && selectedCells.times !== undefined) { + if (selectedCells !== undefined && selectedCells.times !== undefined) { // time property of the cell data is an array, with the elements being // the start times of the first and last cell selected. earliestMs = @@ -212,7 +211,7 @@ export function getSelectionTimeRange(selectedCells, interval, bounds) { export function getSelectionInfluencers(selectedCells, fieldName) { if ( - selectedCells !== null && + selectedCells !== undefined && selectedCells.type !== SWIMLANE_TYPE.OVERALL && selectedCells.viewByFieldName !== undefined && selectedCells.viewByFieldName !== VIEW_BY_JOB_LABEL @@ -346,7 +345,7 @@ export function getViewBySwimlaneOptions({ if (selectedJobIds.length > 1) { // If more than one job selected, default to job ID. viewBySwimlaneFieldName = VIEW_BY_JOB_LABEL; - } else if (mlJobService.jobs.length > 0) { + } else if (mlJobService.jobs.length > 0 && selectedJobIds.length > 0) { // For a single job, default to the first partition, over, // by or influencer field of the first selected job. const firstSelectedJob = mlJobService.jobs.find(job => { @@ -525,7 +524,7 @@ export function processViewByResults( export function loadAnnotationsTableData(selectedCells, selectedJobs, interval, bounds) { const jobIds = - selectedCells !== null && selectedCells.viewByFieldName === VIEW_BY_JOB_LABEL + selectedCells !== undefined && selectedCells.viewByFieldName === VIEW_BY_JOB_LABEL ? selectedCells.lanes : selectedJobs.map(d => d.id); const timeRange = getSelectionTimeRange(selectedCells, interval, bounds); @@ -587,7 +586,7 @@ export async function loadAnomaliesTableData( influencersFilterQuery ) { const jobIds = - selectedCells !== null && selectedCells.viewByFieldName === VIEW_BY_JOB_LABEL + selectedCells !== undefined && selectedCells.viewByFieldName === VIEW_BY_JOB_LABEL ? selectedCells.lanes : selectedJobs.map(d => d.id); const influencers = getSelectionInfluencers(selectedCells, fieldName); @@ -677,7 +676,7 @@ export async function loadDataForCharts( // Just skip doing the request when this function // is called without the minimum required data. if ( - selectedCells === null && + selectedCells === undefined && influencers.length === 0 && influencersFilterQuery === undefined ) { @@ -705,7 +704,7 @@ export async function loadDataForCharts( } if ( - (selectedCells !== null && Object.keys(selectedCells).length > 0) || + (selectedCells !== undefined && Object.keys(selectedCells).length > 0) || influencersFilterQuery !== undefined ) { console.log('Explorer anomaly charts data set:', resp.records); @@ -879,36 +878,3 @@ export async function loadTopInfluencers( } }); } - -export function restoreAppState(appState) { - // Select any jobs set in the global state (i.e. passed in the URL). - let selectedCells; - let filterData = {}; - - // keep swimlane selection, restore selectedCells from AppState - if (appState.mlExplorerSwimlane.selectedType !== undefined) { - selectedCells = { - type: appState.mlExplorerSwimlane.selectedType, - lanes: appState.mlExplorerSwimlane.selectedLanes, - times: appState.mlExplorerSwimlane.selectedTimes, - showTopFieldValues: appState.mlExplorerSwimlane.showTopFieldValues, - viewByFieldName: appState.mlExplorerSwimlane.viewByFieldName, - }; - } - - // keep influencers filter selection, restore from AppState - if (appState.mlExplorerFilter.influencersFilterQuery !== undefined) { - filterData = { - influencersFilterQuery: appState.mlExplorerFilter.influencersFilterQuery, - filterActive: appState.mlExplorerFilter.filterActive, - filteredFields: appState.mlExplorerFilter.filteredFields, - queryString: appState.mlExplorerFilter.queryString, - }; - } - - return { - filterData, - selectedCells, - viewBySwimlaneFieldName: appState.mlExplorerSwimlane.viewByFieldName, - }; -} diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/hooks/use_selected_cells.ts b/x-pack/legacy/plugins/ml/public/application/explorer/hooks/use_selected_cells.ts new file mode 100644 index 0000000000000..2b3e1c7bd656f --- /dev/null +++ b/x-pack/legacy/plugins/ml/public/application/explorer/hooks/use_selected_cells.ts @@ -0,0 +1,67 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { useUrlState } from '../../util/url_state'; +import { SWIMLANE_TYPE } from '../../explorer/explorer_constants'; +import { AppStateSelectedCells } from '../../explorer/explorer_utils'; + +export const useSelectedCells = (): [ + AppStateSelectedCells | undefined, + (swimlaneSelectedCells: AppStateSelectedCells) => void +] => { + const [appState, setAppState] = useUrlState('_a'); + + let selectedCells: AppStateSelectedCells | undefined; + + // keep swimlane selection, restore selectedCells from AppState + if ( + appState && + appState.mlExplorerSwimlane && + appState.mlExplorerSwimlane.selectedType !== undefined + ) { + selectedCells = { + type: appState.mlExplorerSwimlane.selectedType, + lanes: appState.mlExplorerSwimlane.selectedLanes, + times: appState.mlExplorerSwimlane.selectedTimes, + showTopFieldValues: appState.mlExplorerSwimlane.showTopFieldValues, + viewByFieldName: appState.mlExplorerSwimlane.viewByFieldName, + }; + } + + const setSelectedCells = (swimlaneSelectedCells: AppStateSelectedCells) => { + const mlExplorerSwimlane = { ...appState.mlExplorerSwimlane }; + if (swimlaneSelectedCells !== undefined) { + swimlaneSelectedCells.showTopFieldValues = false; + + const currentSwimlaneType = selectedCells?.type; + const currentShowTopFieldValues = selectedCells?.showTopFieldValues; + const newSwimlaneType = selectedCells?.type; + + if ( + (currentSwimlaneType === SWIMLANE_TYPE.OVERALL && + newSwimlaneType === SWIMLANE_TYPE.VIEW_BY) || + newSwimlaneType === SWIMLANE_TYPE.OVERALL || + currentShowTopFieldValues === true + ) { + swimlaneSelectedCells.showTopFieldValues = true; + } + + mlExplorerSwimlane.selectedType = swimlaneSelectedCells.type; + mlExplorerSwimlane.selectedLanes = swimlaneSelectedCells.lanes; + mlExplorerSwimlane.selectedTimes = swimlaneSelectedCells.times; + mlExplorerSwimlane.showTopFieldValues = swimlaneSelectedCells.showTopFieldValues; + setAppState('mlExplorerSwimlane', mlExplorerSwimlane); + } else { + delete mlExplorerSwimlane.selectedType; + delete mlExplorerSwimlane.selectedLanes; + delete mlExplorerSwimlane.selectedTimes; + delete mlExplorerSwimlane.showTopFieldValues; + setAppState('mlExplorerSwimlane', mlExplorerSwimlane); + } + }; + + return [selectedCells, setSelectedCells]; +}; diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/reducers/app_state_reducer.ts b/x-pack/legacy/plugins/ml/public/application/explorer/reducers/app_state_reducer.ts deleted file mode 100644 index 66e00a41a3f31..0000000000000 --- a/x-pack/legacy/plugins/ml/public/application/explorer/reducers/app_state_reducer.ts +++ /dev/null @@ -1,89 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -import { cloneDeep } from 'lodash'; - -import { EXPLORER_ACTION } from '../explorer_constants'; -import { Action } from '../explorer_dashboard_service'; - -export interface ExplorerAppState { - mlExplorerSwimlane: { - selectedType?: string; - selectedLanes?: string[]; - selectedTimes?: number[]; - showTopFieldValues?: boolean; - viewByFieldName?: string; - }; - mlExplorerFilter: { - influencersFilterQuery?: unknown; - filterActive?: boolean; - filteredFields?: string[]; - queryString?: string; - }; -} - -export function getExplorerDefaultAppState(): ExplorerAppState { - return { - mlExplorerSwimlane: {}, - mlExplorerFilter: {}, - }; -} - -export const appStateReducer = (state: ExplorerAppState, nextAction: Action) => { - const { type, payload } = nextAction; - - const appState = cloneDeep(state); - - if (appState.mlExplorerSwimlane === undefined) { - appState.mlExplorerSwimlane = {}; - } - if (appState.mlExplorerFilter === undefined) { - appState.mlExplorerFilter = {}; - } - - switch (type) { - case EXPLORER_ACTION.APP_STATE_SET: - return { ...appState, ...payload }; - - case EXPLORER_ACTION.APP_STATE_CLEAR_SELECTION: - delete appState.mlExplorerSwimlane.selectedType; - delete appState.mlExplorerSwimlane.selectedLanes; - delete appState.mlExplorerSwimlane.selectedTimes; - delete appState.mlExplorerSwimlane.showTopFieldValues; - break; - - case EXPLORER_ACTION.APP_STATE_SAVE_SELECTION: - const swimlaneSelectedCells = payload; - appState.mlExplorerSwimlane.selectedType = swimlaneSelectedCells.type; - appState.mlExplorerSwimlane.selectedLanes = swimlaneSelectedCells.lanes; - appState.mlExplorerSwimlane.selectedTimes = swimlaneSelectedCells.times; - appState.mlExplorerSwimlane.showTopFieldValues = swimlaneSelectedCells.showTopFieldValues; - appState.mlExplorerSwimlane.viewByFieldName = swimlaneSelectedCells.viewByFieldName; - break; - - case EXPLORER_ACTION.APP_STATE_SAVE_VIEW_BY_SWIMLANE_FIELD_NAME: - appState.mlExplorerSwimlane.viewByFieldName = payload.viewBySwimlaneFieldName; - break; - - case EXPLORER_ACTION.APP_STATE_SAVE_INFLUENCER_FILTER_SETTINGS: - appState.mlExplorerFilter.influencersFilterQuery = payload.influencersFilterQuery; - appState.mlExplorerFilter.filterActive = payload.filterActive; - appState.mlExplorerFilter.filteredFields = payload.filteredFields; - appState.mlExplorerFilter.queryString = payload.queryString; - break; - - case EXPLORER_ACTION.APP_STATE_CLEAR_INFLUENCER_FILTER_SETTINGS: - delete appState.mlExplorerFilter.influencersFilterQuery; - delete appState.mlExplorerFilter.filterActive; - delete appState.mlExplorerFilter.filteredFields; - delete appState.mlExplorerFilter.queryString; - break; - - default: - } - - return appState; -}; diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/check_selected_cells.ts b/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/check_selected_cells.ts index 28f04bf65634a..daeb9ae54013c 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/check_selected_cells.ts +++ b/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/check_selected_cells.ts @@ -4,11 +4,9 @@ * you may not use this file except in compliance with the Elastic License. */ -import { EXPLORER_ACTION, SWIMLANE_TYPE } from '../../explorer_constants'; +import { SWIMLANE_TYPE } from '../../explorer_constants'; import { getClearedSelectedAnomaliesState } from '../../explorer_utils'; -import { appStateReducer } from '../app_state_reducer'; - import { ExplorerState } from './state'; interface SwimlanePoint { @@ -21,18 +19,26 @@ interface SwimlanePoint { // If filter is active - selectedCell may not be available due to swimlane view by change to filter fieldName // Ok to keep cellSelection in this case export const checkSelectedCells = (state: ExplorerState) => { - const { filterActive, selectedCells, viewBySwimlaneData, viewBySwimlaneDataLoading } = state; - - if (viewBySwimlaneDataLoading) { + const { + filterActive, + loading, + selectedCells, + viewBySwimlaneData, + viewBySwimlaneDataLoading, + } = state; + + if (loading || viewBySwimlaneDataLoading) { return {}; } let clearSelection = false; if ( + selectedCells !== undefined && selectedCells !== null && selectedCells.type === SWIMLANE_TYPE.VIEW_BY && viewBySwimlaneData !== undefined && - viewBySwimlaneData.points !== undefined + viewBySwimlaneData.points !== undefined && + viewBySwimlaneData.points.length > 0 ) { clearSelection = filterActive === false && @@ -49,9 +55,6 @@ export const checkSelectedCells = (state: ExplorerState) => { if (clearSelection === true) { return { - appState: appStateReducer(state.appState, { - type: EXPLORER_ACTION.APP_STATE_CLEAR_SELECTION, - }), ...getClearedSelectedAnomaliesState(), }; } diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/clear_influencer_filter_settings.ts b/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/clear_influencer_filter_settings.ts index 29c077a5cba43..1614da14e355a 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/clear_influencer_filter_settings.ts +++ b/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/clear_influencer_filter_settings.ts @@ -4,24 +4,13 @@ * you may not use this file except in compliance with the Elastic License. */ -import { EXPLORER_ACTION } from '../../explorer_constants'; import { getClearedSelectedAnomaliesState } from '../../explorer_utils'; -import { appStateReducer } from '../app_state_reducer'; - import { ExplorerState } from './state'; export function clearInfluencerFilterSettings(state: ExplorerState): ExplorerState { - const appStateClearInfluencer = appStateReducer(state.appState, { - type: EXPLORER_ACTION.APP_STATE_CLEAR_INFLUENCER_FILTER_SETTINGS, - }); - const appStateClearSelection = appStateReducer(appStateClearInfluencer, { - type: EXPLORER_ACTION.APP_STATE_CLEAR_SELECTION, - }); - return { ...state, - appState: appStateClearSelection, filterActive: false, filteredFields: [], influencersFilterQuery: undefined, diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/initialize.ts b/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/initialize.ts deleted file mode 100644 index 8536c8f3e542e..0000000000000 --- a/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/initialize.ts +++ /dev/null @@ -1,35 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -import { ActionPayload } from '../../explorer_dashboard_service'; -import { getInfluencers } from '../../explorer_utils'; - -import { getIndexPattern } from './get_index_pattern'; -import { ExplorerState } from './state'; - -export const initialize = (state: ExplorerState, payload: ActionPayload): ExplorerState => { - const { selectedCells, selectedJobs, viewBySwimlaneFieldName, filterData } = payload; - let currentSelectedCells = state.selectedCells; - let currentviewBySwimlaneFieldName = state.viewBySwimlaneFieldName; - - if (viewBySwimlaneFieldName !== undefined) { - currentviewBySwimlaneFieldName = viewBySwimlaneFieldName; - } - - if (selectedCells !== undefined && currentSelectedCells === null) { - currentSelectedCells = selectedCells; - } - - return { - ...state, - indexPattern: getIndexPattern(selectedJobs), - noInfluencersConfigured: getInfluencers(selectedJobs).length === 0, - selectedCells: currentSelectedCells, - selectedJobs, - viewBySwimlaneFieldName: currentviewBySwimlaneFieldName, - ...(filterData.influencersFilterQuery !== undefined ? { ...filterData } : {}), - }; -}; diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/job_selection_change.ts b/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/job_selection_change.ts index 9fe8ebbb2c481..a26c0564c6b16 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/job_selection_change.ts +++ b/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/job_selection_change.ts @@ -4,27 +4,16 @@ * you may not use this file except in compliance with the Elastic License. */ -import { EXPLORER_ACTION, VIEW_BY_JOB_LABEL } from '../../explorer_constants'; import { ActionPayload } from '../../explorer_dashboard_service'; -import { - getClearedSelectedAnomaliesState, - getDefaultSwimlaneData, - getInfluencers, -} from '../../explorer_utils'; - -import { appStateReducer } from '../app_state_reducer'; +import { getDefaultSwimlaneData, getInfluencers } from '../../explorer_utils'; import { getIndexPattern } from './get_index_pattern'; -import { getExplorerDefaultState, ExplorerState } from './state'; +import { ExplorerState } from './state'; export const jobSelectionChange = (state: ExplorerState, payload: ActionPayload): ExplorerState => { const { selectedJobs } = payload; const stateUpdate: ExplorerState = { ...state, - appState: appStateReducer(getExplorerDefaultState().appState, { - type: EXPLORER_ACTION.APP_STATE_CLEAR_SELECTION, - }), - ...getClearedSelectedAnomaliesState(), noInfluencersConfigured: getInfluencers(selectedJobs).length === 0, overallSwimlaneData: getDefaultSwimlaneData(), selectedJobs, @@ -32,9 +21,6 @@ export const jobSelectionChange = (state: ExplorerState, payload: ActionPayload) // clear filter if selected jobs have no influencers if (stateUpdate.noInfluencersConfigured === true) { - stateUpdate.appState = appStateReducer(stateUpdate.appState, { - type: EXPLORER_ACTION.APP_STATE_CLEAR_INFLUENCER_FILTER_SETTINGS, - }); const noFilterState = { filterActive: false, filteredFields: [], @@ -51,11 +37,6 @@ export const jobSelectionChange = (state: ExplorerState, payload: ActionPayload) stateUpdate.indexPattern = getIndexPattern(selectedJobs); } - if (selectedJobs.length > 1) { - stateUpdate.viewBySwimlaneFieldName = VIEW_BY_JOB_LABEL; - return stateUpdate; - } - stateUpdate.loading = true; return stateUpdate; }; diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/reducer.ts b/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/reducer.ts index 1919ce949683f..c31b26b7adb7b 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/reducer.ts +++ b/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/reducer.ts @@ -7,7 +7,7 @@ import { formatHumanReadableDateTime } from '../../../util/date_utils'; import { getDefaultChartsData } from '../../explorer_charts/explorer_charts_container_service'; -import { EXPLORER_ACTION, SWIMLANE_TYPE, VIEW_BY_JOB_LABEL } from '../../explorer_constants'; +import { EXPLORER_ACTION, VIEW_BY_JOB_LABEL } from '../../explorer_constants'; import { Action } from '../../explorer_dashboard_service'; import { getClearedSelectedAnomaliesState, @@ -16,13 +16,11 @@ import { getSwimlaneBucketInterval, getViewBySwimlaneOptions, } from '../../explorer_utils'; -import { appStateReducer } from '../app_state_reducer'; import { checkSelectedCells } from './check_selected_cells'; import { clearInfluencerFilterSettings } from './clear_influencer_filter_settings'; -import { initialize } from './initialize'; import { jobSelectionChange } from './job_selection_change'; -import { getExplorerDefaultState, ExplorerState } from './state'; +import { ExplorerState } from './state'; import { setInfluencerFilterSettings } from './set_influencer_filter_settings'; import { setKqlQueryBarPlaceholder } from './set_kql_query_bar_placeholder'; @@ -40,45 +38,15 @@ export const explorerReducer = (state: ExplorerState, nextAction: Action): Explo nextState = { ...state, ...getClearedSelectedAnomaliesState(), - appState: appStateReducer(state.appState, { - type: EXPLORER_ACTION.APP_STATE_CLEAR_SELECTION, - }), loading: false, selectedJobs: [], }; break; - case EXPLORER_ACTION.CLEAR_SELECTION: - nextState = { - ...state, - ...getClearedSelectedAnomaliesState(), - appState: appStateReducer(state.appState, { - type: EXPLORER_ACTION.APP_STATE_CLEAR_SELECTION, - }), - }; - break; - - case EXPLORER_ACTION.INITIALIZE: - nextState = initialize(state, payload); - break; - case EXPLORER_ACTION.JOB_SELECTION_CHANGE: nextState = jobSelectionChange(state, payload); break; - case EXPLORER_ACTION.APP_STATE_SET: - case EXPLORER_ACTION.APP_STATE_CLEAR_SELECTION: - case EXPLORER_ACTION.APP_STATE_SAVE_SELECTION: - case EXPLORER_ACTION.APP_STATE_SAVE_VIEW_BY_SWIMLANE_FIELD_NAME: - case EXPLORER_ACTION.APP_STATE_SAVE_INFLUENCER_FILTER_SETTINGS: - case EXPLORER_ACTION.APP_STATE_CLEAR_INFLUENCER_FILTER_SETTINGS: - nextState = { ...state, appState: appStateReducer(state.appState, nextAction) }; - break; - - case EXPLORER_ACTION.RESET: - nextState = getExplorerDefaultState(); - break; - case EXPLORER_ACTION.SET_BOUNDS: nextState = { ...state, bounds: payload }; break; @@ -102,44 +70,15 @@ export const explorerReducer = (state: ExplorerState, nextAction: Action): Explo case EXPLORER_ACTION.SET_SELECTED_CELLS: const selectedCells = payload; - selectedCells.showTopFieldValues = false; - - const currentSwimlaneType = state.selectedCells?.type; - const currentShowTopFieldValues = state.selectedCells?.showTopFieldValues; - const newSwimlaneType = selectedCells?.type; - - if ( - (currentSwimlaneType === SWIMLANE_TYPE.OVERALL && - newSwimlaneType === SWIMLANE_TYPE.VIEW_BY) || - newSwimlaneType === SWIMLANE_TYPE.OVERALL || - currentShowTopFieldValues === true - ) { - selectedCells.showTopFieldValues = true; - } - nextState = { ...state, - appState: appStateReducer(state.appState, { - type: EXPLORER_ACTION.APP_STATE_SAVE_SELECTION, - payload, - }), selectedCells, }; break; - case EXPLORER_ACTION.SET_STATE: - if (payload.viewBySwimlaneFieldName) { - nextState = { - ...state, - ...payload, - appState: appStateReducer(state.appState, { - type: EXPLORER_ACTION.APP_STATE_SAVE_VIEW_BY_SWIMLANE_FIELD_NAME, - payload: { viewBySwimlaneFieldName: payload.viewBySwimlaneFieldName }, - }), - }; - } else { - nextState = { ...state, ...payload }; - } + case EXPLORER_ACTION.SET_EXPLORER_DATA: + case EXPLORER_ACTION.SET_FILTER_DATA: + nextState = { ...state, ...payload }; break; case EXPLORER_ACTION.SET_SWIMLANE_CONTAINER_WIDTH: @@ -157,10 +96,6 @@ export const explorerReducer = (state: ExplorerState, nextAction: Action): Explo case EXPLORER_ACTION.SET_SWIMLANE_LIMIT: nextState = { ...state, - appState: appStateReducer(state.appState, { - type: EXPLORER_ACTION.APP_STATE_CLEAR_SELECTION, - }), - ...getClearedSelectedAnomaliesState(), swimlaneLimit: payload, }; break; @@ -180,9 +115,6 @@ export const explorerReducer = (state: ExplorerState, nextAction: Action): Explo nextState = { ...state, ...getClearedSelectedAnomaliesState(), - appState: appStateReducer(state.appState, { - type: EXPLORER_ACTION.APP_STATE_CLEAR_SELECTION, - }), maskAll, viewBySwimlaneFieldName, }; @@ -216,7 +148,7 @@ export const explorerReducer = (state: ExplorerState, nextAction: Action): Explo ); // Does a sanity check on the selected `viewBySwimlaneFieldName` - // and return the available `viewBySwimlaneOptions`. + // and returns the available `viewBySwimlaneOptions`. const { viewBySwimlaneFieldName, viewBySwimlaneOptions } = getViewBySwimlaneOptions({ currentViewBySwimlaneFieldName: nextState.viewBySwimlaneFieldName, filterActive: nextState.filterActive, @@ -238,7 +170,7 @@ export const explorerReducer = (state: ExplorerState, nextAction: Action): Explo ...nextState, swimlaneBucketInterval, viewByLoadedForTimeFormatted: - selectedCells !== null && selectedCells.showTopFieldValues === true + selectedCells !== undefined && selectedCells.showTopFieldValues === true ? formatHumanReadableDateTime(timerange.earliestMs) : null, viewBySwimlaneFieldName, diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/set_influencer_filter_settings.ts b/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/set_influencer_filter_settings.ts index 76577ae557fe3..8d083a396582a 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/set_influencer_filter_settings.ts +++ b/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/set_influencer_filter_settings.ts @@ -4,11 +4,9 @@ * you may not use this file except in compliance with the Elastic License. */ -import { EXPLORER_ACTION, VIEW_BY_JOB_LABEL } from '../../explorer_constants'; +import { VIEW_BY_JOB_LABEL } from '../../explorer_constants'; import { ActionPayload } from '../../explorer_dashboard_service'; -import { appStateReducer } from '../app_state_reducer'; - import { ExplorerState } from './state'; export function setInfluencerFilterSettings( @@ -43,21 +41,8 @@ export function setInfluencerFilterSettings( } } - const appState = appStateReducer(state.appState, { - type: EXPLORER_ACTION.APP_STATE_SAVE_INFLUENCER_FILTER_SETTINGS, - payload: { - influencersFilterQuery, - filterActive: true, - filteredFields, - queryString, - tableQueryString, - isAndOperator, - }, - }); - return { ...state, - appState, filterActive: true, filteredFields, influencersFilterQuery, diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/state.ts b/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/state.ts index ce37605c3a926..0a2dbf5bcff35 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/state.ts +++ b/x-pack/legacy/plugins/ml/public/application/explorer/reducers/explorer_reducer/state.ts @@ -15,16 +15,13 @@ import { getDefaultSwimlaneData, AnomaliesTableData, ExplorerJob, + AppStateSelectedCells, SwimlaneData, TimeRangeBounds, } from '../../explorer_utils'; -import { getExplorerDefaultAppState, ExplorerAppState } from '../app_state_reducer'; - export interface ExplorerState { annotationsData: any[]; - anomalyChartRecords: any[]; - appState: ExplorerAppState; bounds: TimeRangeBounds | undefined; chartsData: ExplorerChartsData; fieldFormatsLoading: boolean; @@ -40,15 +37,13 @@ export interface ExplorerState { noInfluencersConfigured: boolean; overallSwimlaneData: SwimlaneData; queryString: string; - selectedCells: any; + selectedCells: AppStateSelectedCells | undefined; selectedJobs: ExplorerJob[] | null; swimlaneBucketInterval: any; swimlaneContainerWidth: number; swimlaneLimit: number; tableData: AnomaliesTableData; - tableInterval: string; tableQueryString: string; - tableSeverity: number; viewByLoadedForTimeFormatted: string | null; viewBySwimlaneData: SwimlaneData; viewBySwimlaneDataLoading: boolean; @@ -63,8 +58,6 @@ function getDefaultIndexPattern() { export function getExplorerDefaultState(): ExplorerState { return { annotationsData: [], - anomalyChartRecords: [], - appState: getExplorerDefaultAppState(), bounds: undefined, chartsData: getDefaultChartsData(), fieldFormatsLoading: false, @@ -80,7 +73,7 @@ export function getExplorerDefaultState(): ExplorerState { noInfluencersConfigured: true, overallSwimlaneData: getDefaultSwimlaneData(), queryString: '', - selectedCells: null, + selectedCells: undefined, selectedJobs: null, swimlaneBucketInterval: undefined, swimlaneContainerWidth: 0, @@ -92,9 +85,7 @@ export function getExplorerDefaultState(): ExplorerState { jobIds: [], showViewSeriesLink: false, }, - tableInterval: 'auto', tableQueryString: '', - tableSeverity: 0, viewByLoadedForTimeFormatted: null, viewBySwimlaneData: getDefaultSwimlaneData(), viewBySwimlaneDataLoading: false, diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/reducers/index.ts b/x-pack/legacy/plugins/ml/public/application/explorer/reducers/index.ts index 98cc07e8f9449..29787365923c8 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/reducers/index.ts +++ b/x-pack/legacy/plugins/ml/public/application/explorer/reducers/index.ts @@ -4,7 +4,6 @@ * you may not use this file except in compliance with the Elastic License. */ -export { appStateReducer, getExplorerDefaultAppState, ExplorerAppState } from './app_state_reducer'; export { explorerReducer, getExplorerDefaultState, diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/select_limit/index.js b/x-pack/legacy/plugins/ml/public/application/explorer/select_limit/index.ts similarity index 79% rename from x-pack/legacy/plugins/ml/public/application/explorer/select_limit/index.js rename to x-pack/legacy/plugins/ml/public/application/explorer/select_limit/index.ts index fa1b24e118180..5b7040e5c3606 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/select_limit/index.js +++ b/x-pack/legacy/plugins/ml/public/application/explorer/select_limit/index.ts @@ -4,4 +4,4 @@ * you may not use this file except in compliance with the Elastic License. */ -import './select_limit_service.js'; +export { useSwimlaneLimit, SelectLimit } from './select_limit'; diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/select_limit/select_limit.js b/x-pack/legacy/plugins/ml/public/application/explorer/select_limit/select_limit.js deleted file mode 100644 index 5971e7dcc82be..0000000000000 --- a/x-pack/legacy/plugins/ml/public/application/explorer/select_limit/select_limit.js +++ /dev/null @@ -1,80 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -/* - * React component for rendering a select element with limit options. - */ -import PropTypes from 'prop-types'; -import React, { Component } from 'react'; -import { BehaviorSubject } from 'rxjs'; - -import { EuiSelect } from '@elastic/eui'; - -import { injectObservablesAsProps } from '../../util/observable_utils'; - -const optionsMap = { - '5': 5, - '10': 10, - '25': 25, - '50': 50, -}; - -const LIMIT_OPTIONS = [ - { val: 5, display: '5' }, - { val: 10, display: '10' }, - { val: 25, display: '25' }, - { val: 50, display: '50' }, -]; - -function optionValueToLimit(value) { - // Get corresponding limit object with required display and val properties from the specified value. - let limit = LIMIT_OPTIONS.find(opt => opt.val === value); - - // Default to 10 if supplied value doesn't map to one of the options. - if (limit === undefined) { - limit = LIMIT_OPTIONS[1]; - } - - return limit; -} - -const EUI_OPTIONS = LIMIT_OPTIONS.map(({ display, val }) => ({ - value: display, - text: val, -})); - -export const limit$ = new BehaviorSubject(LIMIT_OPTIONS[1]); - -class SelectLimitUnwrapped extends Component { - onChange = e => { - const valueDisplay = e.target.value; - const limit = optionValueToLimit(optionsMap[valueDisplay]); - limit$.next(limit); - }; - - render() { - return ( - - ); - } -} - -SelectLimitUnwrapped.propTypes = { - limit: PropTypes.object, -}; - -SelectLimitUnwrapped.defaultProps = { - limit: LIMIT_OPTIONS[1], -}; - -const SelectLimit = injectObservablesAsProps( - { - limit: limit$, - }, - SelectLimitUnwrapped -); - -export { SelectLimit }; diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/select_limit/select_limit.test.js b/x-pack/legacy/plugins/ml/public/application/explorer/select_limit/select_limit.test.tsx similarity index 59% rename from x-pack/legacy/plugins/ml/public/application/explorer/select_limit/select_limit.test.js rename to x-pack/legacy/plugins/ml/public/application/explorer/select_limit/select_limit.test.tsx index 60543cfad2de4..657f1c6c7af2e 100644 --- a/x-pack/legacy/plugins/ml/public/application/explorer/select_limit/select_limit.test.js +++ b/x-pack/legacy/plugins/ml/public/application/explorer/select_limit/select_limit.test.tsx @@ -5,25 +5,27 @@ */ import React from 'react'; +import { act } from 'react-dom/test-utils'; import { shallow } from 'enzyme'; import { SelectLimit } from './select_limit'; +jest.useFakeTimers(); + describe('SelectLimit', () => { test('creates correct initial selected value', () => { const wrapper = shallow(); - const defaultSelectedValue = wrapper.props().limit.display; - expect(defaultSelectedValue).toBe('10'); + expect(wrapper.props().value).toEqual(10); }); test('state for currently selected value is updated correctly on click', () => { const wrapper = shallow(); - const select = wrapper.first().shallow(); + expect(wrapper.props().value).toEqual(10); - const defaultSelectedValue = wrapper.props().limit.display; - expect(defaultSelectedValue).toBe('10'); + act(() => { + wrapper.simulate('change', { target: { value: 25 } }); + }); + wrapper.update(); - select.simulate('change', { target: { value: '25' } }); - const updatedSelectedValue = wrapper.props().limit.display; - expect(updatedSelectedValue).toBe('25'); + expect(wrapper.props().value).toEqual(10); }); }); diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/select_limit/select_limit.tsx b/x-pack/legacy/plugins/ml/public/application/explorer/select_limit/select_limit.tsx new file mode 100644 index 0000000000000..383d07eb7a9f6 --- /dev/null +++ b/x-pack/legacy/plugins/ml/public/application/explorer/select_limit/select_limit.tsx @@ -0,0 +1,40 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +/* + * React component for rendering a select element with limit options. + */ +import React from 'react'; +import useObservable from 'react-use/lib/useObservable'; +import { Subject } from 'rxjs'; + +import { EuiSelect } from '@elastic/eui'; + +const limitOptions = [5, 10, 25, 50]; + +const euiOptions = limitOptions.map(limit => ({ + value: limit, + text: `${limit}`, +})); + +export const limit$ = new Subject(); +export const defaultLimit = limitOptions[1]; + +export const useSwimlaneLimit = (): [number, (newLimit: number) => void] => { + const limit = useObservable(limit$, defaultLimit); + + return [limit, (newLimit: number) => limit$.next(newLimit)]; +}; + +export const SelectLimit = () => { + const [limit, setLimit] = useSwimlaneLimit(); + + function onChange(e: React.ChangeEvent) { + setLimit(parseInt(e.target.value, 10)); + } + + return ; +}; diff --git a/x-pack/legacy/plugins/ml/public/application/explorer/select_limit/select_limit_service.js b/x-pack/legacy/plugins/ml/public/application/explorer/select_limit/select_limit_service.js deleted file mode 100644 index dc9d90d3c677e..0000000000000 --- a/x-pack/legacy/plugins/ml/public/application/explorer/select_limit/select_limit_service.js +++ /dev/null @@ -1,19 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -/* - * AngularJS service for storing limit values in AppState. - */ - -import { uiModules } from 'ui/modules'; -const module = uiModules.get('apps/ml'); - -import { subscribeAppStateToObservable } from '../../util/app_state_utils'; -import { limit$ } from './select_limit'; - -module.service('mlSelectLimitService', function(AppState, $rootScope) { - subscribeAppStateToObservable(AppState, 'mlSelectLimit', limit$, () => $rootScope.$applyAsync()); -}); diff --git a/x-pack/legacy/plugins/ml/public/application/routing/routes/explorer.tsx b/x-pack/legacy/plugins/ml/public/application/routing/routes/explorer.tsx index 1b6b91026d6a5..6aaad5294369b 100644 --- a/x-pack/legacy/plugins/ml/public/application/routing/routes/explorer.tsx +++ b/x-pack/legacy/plugins/ml/public/application/routing/routes/explorer.tsx @@ -4,27 +4,33 @@ * you may not use this file except in compliance with the Elastic License. */ -import React, { FC, useEffect } from 'react'; +import moment from 'moment'; +import React, { FC, useEffect, useState } from 'react'; +import useObservable from 'react-use/lib/useObservable'; + import { i18n } from '@kbn/i18n'; -import { decode } from 'rison-node'; -import { Subscription } from 'rxjs'; -// @ts-ignore -import queryString from 'query-string'; import { timefilter } from 'ui/timefilter'; + +import { MlJobWithTimeRange } from '../../../../common/types/jobs'; + import { MlRoute, PageLoader, PageProps } from '../router'; +import { useRefresh } from '../use_refresh'; import { useResolver } from '../use_resolver'; import { basicResolvers } from '../resolvers'; import { Explorer } from '../../explorer'; +import { useSelectedCells } from '../../explorer/hooks/use_selected_cells'; import { mlJobService } from '../../services/job_service'; -import { getExplorerDefaultAppState, ExplorerAppState } from '../../explorer/reducers'; +import { ml } from '../../services/ml_api_service'; +import { useExplorerData } from '../../explorer/actions'; import { explorerService } from '../../explorer/explorer_dashboard_service'; -import { jobSelectServiceFactory } from '../../components/job_selector/job_select_service_utils'; -import { subscribeAppStateToObservable } from '../../util/app_state_utils'; - -import { interval$ } from '../../components/controls/select_interval'; -import { severity$ } from '../../components/controls/select_severity'; -import { showCharts$ } from '../../components/controls/checkbox_showcharts'; +import { getDateFormatTz } from '../../explorer/explorer_utils'; +import { useSwimlaneLimit } from '../../explorer/select_limit'; +import { useJobSelection } from '../../components/job_selector/use_job_selection'; +import { useShowCharts } from '../../components/controls/checkbox_showcharts'; +import { useTableInterval } from '../../components/controls/select_interval'; +import { useTableSeverity } from '../../components/controls/select_severity'; +import { useUrlState } from '../../util/url_state'; import { ANOMALY_DETECTION_BREADCRUMB, ML_BREADCRUMB } from '../breadcrumbs'; const breadcrumbs = [ @@ -44,111 +50,140 @@ export const explorerRoute: MlRoute = { breadcrumbs, }; -const PageWrapper: FC = ({ location, config, deps }) => { - const { index } = queryString.parse(location.search); - const { context } = useResolver(index, undefined, config, { +const PageWrapper: FC = ({ config, deps }) => { + const { context, results } = useResolver(undefined, undefined, config, { ...basicResolvers(deps), jobs: mlJobService.loadJobsWrapper, + jobsWithTimeRange: () => ml.jobs.jobsWithTimerange(getDateFormatTz()), }); - const { _a, _g } = queryString.parse(location.search); - let appState: any = {}; - let globalState: any = {}; - try { - appState = decode(_a); - globalState = decode(_g); - } catch (error) { - // eslint-disable-next-line no-console - console.error('Could not parse global or app state'); - } - - if (appState.mlExplorerSwimlane === undefined) { - appState.mlExplorerSwimlane = {}; - } - - if (appState.mlExplorerFilter === undefined) { - appState.mlExplorerFilter = {}; - } - - appState.fetch = () => {}; - appState.on = () => {}; - appState.off = () => {}; - appState.save = () => {}; - globalState.fetch = () => {}; - globalState.on = () => {}; - globalState.off = () => {}; - globalState.save = () => {}; return ( - + ); }; -class AppState { - fetch() {} - on() {} - off() {} - save() {} +interface ExplorerUrlStateManagerProps { + jobsWithTimeRange: MlJobWithTimeRange[]; } -const ExplorerWrapper: FC<{ globalState: any; appState: any }> = ({ globalState, appState }) => { - const subscriptions = new Subscription(); - - const { jobSelectService$, unsubscribeFromGlobalState } = jobSelectServiceFactory(globalState); - appState = getExplorerDefaultAppState(); - const { mlExplorerFilter, mlExplorerSwimlane } = appState; - window.setTimeout(() => { - // Pass the current URL AppState on to anomaly explorer's reactive state. - // After this hand-off, the appState stored in explorerState$ is the single - // source of truth. - explorerService.setAppState({ mlExplorerSwimlane, mlExplorerFilter }); - - // Now that appState in explorerState$ is the single source of truth, - // subscribe to it and update the actual URL appState on changes. - subscriptions.add( - explorerService.appState$.subscribe((appStateIn: ExplorerAppState) => { - // appState.fetch(); - appState.mlExplorerFilter = appStateIn.mlExplorerFilter; - appState.mlExplorerSwimlane = appStateIn.mlExplorerSwimlane; - // appState.save(); - }) - ); - }); +const ExplorerUrlStateManager: FC = ({ jobsWithTimeRange }) => { + const [appState, setAppState] = useUrlState('_a'); + const [globalState] = useUrlState('_g'); + const [lastRefresh, setLastRefresh] = useState(0); - subscriptions.add(subscribeAppStateToObservable(AppState, 'mlShowCharts', showCharts$, () => {})); - subscriptions.add( - subscribeAppStateToObservable(AppState, 'mlSelectInterval', interval$, () => {}) - ); - subscriptions.add( - subscribeAppStateToObservable(AppState, 'mlSelectSeverity', severity$, () => {}) - ); + const { jobIds } = useJobSelection(jobsWithTimeRange, getDateFormatTz()); - if (globalState.time) { - timefilter.setTime({ - from: globalState.time.from, - to: globalState.time.to, - }); - } + const refresh = useRefresh(); + useEffect(() => { + if (refresh !== undefined) { + setLastRefresh(refresh?.lastRefresh); + const activeBounds = timefilter.getActiveBounds(); + if (activeBounds !== undefined) { + explorerService.setBounds(activeBounds); + } + } + }, [refresh?.lastRefresh]); useEffect(() => { - return () => { - subscriptions.unsubscribe(); - unsubscribeFromGlobalState(); - }; - }); + timefilter.enableTimeRangeSelector(); + timefilter.enableAutoRefreshSelector(); + + const viewByFieldName = appState?.mlExplorerSwimlane?.viewByFieldName; + if (viewByFieldName !== undefined) { + explorerService.setViewBySwimlaneFieldName(viewByFieldName); + } + + const filterData = appState?.mlExplorerFilter; + if (filterData !== undefined) { + explorerService.setFilterData(filterData); + } + }, []); + + useEffect(() => { + if (globalState?.time !== undefined) { + timefilter.setTime({ + from: globalState.time.from, + to: globalState.time.to, + }); + explorerService.setBounds({ + min: moment(globalState.time.from), + max: moment(globalState.time.to), + }); + } + }, [globalState?.time?.from, globalState?.time?.to]); + + useEffect(() => { + if (jobIds.length > 0) { + explorerService.updateJobSelection(jobIds); + } else { + explorerService.clearJobs(); + } + }, [JSON.stringify(jobIds)]); + + const [explorerData, loadExplorerData] = useExplorerData(); + useEffect(() => { + if (explorerData !== undefined && Object.keys(explorerData).length > 0) { + explorerService.setExplorerData(explorerData); + } + }, [explorerData]); + + const explorerAppState = useObservable(explorerService.appState$); + useEffect(() => { + if ( + explorerAppState !== undefined && + explorerAppState.mlExplorerSwimlane.viewByFieldName !== undefined + ) { + setAppState(explorerAppState); + } + }, [explorerAppState]); + + const explorerState = useObservable(explorerService.state$); + + const [showCharts] = useShowCharts(); + const [tableInterval] = useTableInterval(); + const [tableSeverity] = useTableSeverity(); + const [swimlaneLimit] = useSwimlaneLimit(); + useEffect(() => { + explorerService.setSwimlaneLimit(swimlaneLimit); + }, [swimlaneLimit]); + + const [selectedCells, setSelectedCells] = useSelectedCells(); + useEffect(() => { + explorerService.setSelectedCells(selectedCells); + }, [JSON.stringify(selectedCells)]); + + const loadExplorerDataConfig = + (explorerState !== undefined && { + bounds: explorerState.bounds, + lastRefresh, + influencersFilterQuery: explorerState.influencersFilterQuery, + noInfluencersConfigured: explorerState.noInfluencersConfigured, + selectedCells, + selectedJobs: explorerState.selectedJobs, + swimlaneBucketInterval: explorerState.swimlaneBucketInterval, + swimlaneLimit: explorerState.swimlaneLimit, + tableInterval: tableInterval.val, + tableSeverity: tableSeverity.val, + viewBySwimlaneFieldName: explorerState.viewBySwimlaneFieldName, + }) || + undefined; + useEffect(() => { + loadExplorerData(loadExplorerDataConfig); + }, [JSON.stringify(loadExplorerDataConfig)]); + + if (explorerState === undefined || refresh === undefined || showCharts === undefined) { + return null; + } return (
diff --git a/x-pack/legacy/plugins/ml/public/application/routing/routes/timeseriesexplorer.tsx b/x-pack/legacy/plugins/ml/public/application/routing/routes/timeseriesexplorer.tsx index a40bbfa214b28..cbf54a70ea74f 100644 --- a/x-pack/legacy/plugins/ml/public/application/routing/routes/timeseriesexplorer.tsx +++ b/x-pack/legacy/plugins/ml/public/application/routing/routes/timeseriesexplorer.tsx @@ -4,24 +4,37 @@ * you may not use this file except in compliance with the Elastic License. */ -import React, { FC, useEffect } from 'react'; -import { i18n } from '@kbn/i18n'; -import { decode } from 'rison-node'; +import { isEqual } from 'lodash'; +import React, { FC, useCallback, useEffect, useState } from 'react'; +import { usePrevious } from 'react-use'; import moment from 'moment'; -import { Subscription } from 'rxjs'; - // @ts-ignore import queryString from 'query-string'; + +import { i18n } from '@kbn/i18n'; + import { timefilter } from 'ui/timefilter'; -import { MlRoute, PageLoader, PageProps } from '../router'; -import { useResolver } from '../use_resolver'; -import { basicResolvers } from '../resolvers'; + +import { MlJobWithTimeRange } from '../../../../common/types/jobs'; + import { TimeSeriesExplorer } from '../../timeseriesexplorer'; +import { getDateFormatTz, TimeRangeBounds } from '../../explorer/explorer_utils'; +import { ml } from '../../services/ml_api_service'; import { mlJobService } from '../../services/job_service'; +import { mlForecastService } from '../../services/forecast_service'; import { APP_STATE_ACTION } from '../../timeseriesexplorer/timeseriesexplorer_constants'; -import { subscribeAppStateToObservable } from '../../util/app_state_utils'; -import { interval$ } from '../../components/controls/select_interval'; -import { severity$ } from '../../components/controls/select_severity'; +import { + createTimeSeriesJobData, + getAutoZoomDuration, +} from '../../timeseriesexplorer/timeseriesexplorer_utils'; +import { useUrlState } from '../../util/url_state'; +import { useTableInterval } from '../../components/controls/select_interval'; +import { useTableSeverity } from '../../components/controls/select_severity'; + +import { MlRoute, PageLoader, PageProps } from '../router'; +import { useRefresh } from '../use_refresh'; +import { useResolver } from '../use_resolver'; +import { basicResolvers } from '../resolvers'; import { ANOMALY_DETECTION_BREADCRUMB, ML_BREADCRUMB } from '../breadcrumbs'; export const timeSeriesExplorerRoute: MlRoute = { @@ -39,105 +52,207 @@ export const timeSeriesExplorerRoute: MlRoute = { ], }; -const PageWrapper: FC = ({ location, config, deps }) => { - const { context } = useResolver('', undefined, config, { +const PageWrapper: FC = ({ config, deps }) => { + const { context, results } = useResolver('', undefined, config, { ...basicResolvers(deps), jobs: mlJobService.loadJobsWrapper, + jobsWithTimeRange: () => ml.jobs.jobsWithTimerange(getDateFormatTz()), }); - const { _a, _g } = queryString.parse(location.search); - let appState: any = {}; - let globalState: any = {}; - try { - appState = decode(_a); - globalState = decode(_g); - } catch (error) { - // eslint-disable-next-line no-console - console.error('Could not parse global or app state'); - } - if (appState.mlTimeSeriesExplorer === undefined) { - appState.mlTimeSeriesExplorer = {}; - } - globalState.fetch = () => {}; - globalState.on = () => {}; - globalState.off = () => {}; - globalState.save = () => {}; return ( - + ); }; -class AppState { - fetch() {} - on() {} - off() {} - save() {} +interface TimeSeriesExplorerUrlStateManager { + config: any; + jobsWithTimeRange: MlJobWithTimeRange[]; } -const TimeSeriesExplorerWrapper: FC<{ globalState: any; appState: any; config: any }> = ({ - globalState, - appState, +const TimeSeriesExplorerUrlStateManager: FC = ({ config, + jobsWithTimeRange, }) => { - if (globalState.time) { - timefilter.setTime({ - from: globalState.time.from, - to: globalState.time.to, - }); - } + const [appState, setAppState] = useUrlState('_a'); + const [globalState, setGlobalState] = useUrlState('_g'); + const [lastRefresh, setLastRefresh] = useState(0); - const subscriptions = new Subscription(); - subscriptions.add( - subscribeAppStateToObservable(AppState, 'mlSelectInterval', interval$, () => {}) - ); - subscriptions.add( - subscribeAppStateToObservable(AppState, 'mlSelectSeverity', severity$, () => {}) - ); + const refresh = useRefresh(); + useEffect(() => { + if (refresh !== undefined) { + setLastRefresh(refresh?.lastRefresh); - const appStateHandler = (action: string, payload: any) => { - switch (action) { - case APP_STATE_ACTION.CLEAR: - delete appState.mlTimeSeriesExplorer.detectorIndex; - delete appState.mlTimeSeriesExplorer.entities; - delete appState.mlTimeSeriesExplorer.forecastId; - break; - - case APP_STATE_ACTION.GET_DETECTOR_INDEX: - return appState.mlTimeSeriesExplorer.detectorIndex; - case APP_STATE_ACTION.SET_DETECTOR_INDEX: - appState.mlTimeSeriesExplorer.detectorIndex = payload; - break; - - case APP_STATE_ACTION.GET_ENTITIES: - return appState.mlTimeSeriesExplorer.entities; - case APP_STATE_ACTION.SET_ENTITIES: - appState.mlTimeSeriesExplorer.entities = payload; - break; - - case APP_STATE_ACTION.GET_FORECAST_ID: - return appState.mlTimeSeriesExplorer.forecastId; - case APP_STATE_ACTION.SET_FORECAST_ID: - appState.mlTimeSeriesExplorer.forecastId = payload; - break; - - case APP_STATE_ACTION.GET_ZOOM: - return appState.mlTimeSeriesExplorer.zoom; - case APP_STATE_ACTION.SET_ZOOM: - appState.mlTimeSeriesExplorer.zoom = payload; - break; - case APP_STATE_ACTION.UNSET_ZOOM: - delete appState.mlTimeSeriesExplorer.zoom; - break; + if (refresh.timeRange !== undefined) { + const { start, end } = refresh.timeRange; + setGlobalState('time', { + from: start, + to: end, + }); + } } - }; + }, [refresh?.lastRefresh]); useEffect(() => { - return () => { - subscriptions.unsubscribe(); + timefilter.enableTimeRangeSelector(); + timefilter.enableAutoRefreshSelector(); + }, []); + + useEffect(() => { + if (globalState?.time !== undefined) { + timefilter.setTime({ + from: globalState.time.from, + to: globalState.time.to, + }); + } + }, [globalState?.time?.from, globalState?.time?.to]); + + let bounds: TimeRangeBounds | undefined; + if (globalState?.time !== undefined) { + bounds = { + min: moment(globalState.time.from), + max: moment(globalState.time.to), }; - }); + } + + const selectedJobIds = globalState?.ml?.jobIds; + // Sort selectedJobIds so we can be sure comparison works when stringifying. + if (Array.isArray(selectedJobIds)) { + selectedJobIds.sort(); + } + + // When changing jobs we'll clear appState (detectorIndex, entities, forecastId). + // To retore settings from the URL on initial load we also need to check against + // `previousSelectedJobIds` to avoid wiping appState. + const previousSelectedJobIds = usePrevious(selectedJobIds); + const isJobChange = !isEqual(previousSelectedJobIds, selectedJobIds); + + // Use a side effect to clear appState when changing jobs. + useEffect(() => { + if (selectedJobIds !== undefined && previousSelectedJobIds !== undefined) { + setLastRefresh(Date.now()); + appStateHandler(APP_STATE_ACTION.CLEAR); + } + }, [JSON.stringify(selectedJobIds)]); + + // Next we get globalState and appState information to pass it on as props later. + // If a job change is going on, we fall back to defaults (as if appState was already cleard), + // otherwise the page could break. + const selectedDetectorIndex = isJobChange + ? 0 + : +appState?.mlTimeSeriesExplorer?.detectorIndex || 0; + const selectedEntities = isJobChange ? undefined : appState?.mlTimeSeriesExplorer?.entities; + const selectedForecastId = isJobChange ? undefined : appState?.mlTimeSeriesExplorer?.forecastId; + const zoom = isJobChange ? undefined : appState?.mlTimeSeriesExplorer?.zoom; + + const selectedJob = selectedJobIds && mlJobService.getJob(selectedJobIds[0]); + + let autoZoomDuration: number | undefined; + if (selectedJobIds !== undefined && selectedJobIds.length === 1 && selectedJob !== undefined) { + autoZoomDuration = getAutoZoomDuration( + createTimeSeriesJobData(mlJobService.jobs), + mlJobService.getJob(selectedJobIds[0]) + ); + } + + const appStateHandler = useCallback( + (action: string, payload?: any) => { + const mlTimeSeriesExplorer = + appState?.mlTimeSeriesExplorer !== undefined ? { ...appState.mlTimeSeriesExplorer } : {}; + + switch (action) { + case APP_STATE_ACTION.CLEAR: + delete mlTimeSeriesExplorer.detectorIndex; + delete mlTimeSeriesExplorer.entities; + delete mlTimeSeriesExplorer.forecastId; + delete mlTimeSeriesExplorer.zoom; + break; + + case APP_STATE_ACTION.SET_DETECTOR_INDEX: + mlTimeSeriesExplorer.detectorIndex = payload; + break; + + case APP_STATE_ACTION.SET_ENTITIES: + mlTimeSeriesExplorer.entities = payload; + break; + + case APP_STATE_ACTION.SET_FORECAST_ID: + mlTimeSeriesExplorer.forecastId = payload; + break; + + case APP_STATE_ACTION.SET_ZOOM: + mlTimeSeriesExplorer.zoom = payload; + break; + + case APP_STATE_ACTION.UNSET_ZOOM: + delete mlTimeSeriesExplorer.zoom; + break; + } + + setAppState('mlTimeSeriesExplorer', mlTimeSeriesExplorer); + }, + [JSON.stringify([appState, globalState])] + ); + + const boundsMinMs = bounds?.min?.valueOf(); + const boundsMaxMs = bounds?.max?.valueOf(); + useEffect(() => { + if ( + autoZoomDuration !== undefined && + boundsMinMs !== undefined && + boundsMaxMs !== undefined && + selectedJob !== undefined && + selectedForecastId !== undefined + ) { + mlForecastService + .getForecastDateRange(selectedJob, selectedForecastId) + .then(resp => { + if (autoZoomDuration === undefined) { + return; + } + + const earliest = moment(resp.earliest || boundsMinMs); + const latest = moment(resp.latest || boundsMaxMs); + + // Set the zoom to centre on the start of the forecast range, depending + // on the time range of the forecast and data. + // const earliestDataDate = first(contextChartData).date; + const zoomLatestMs = Math.min( + earliest.valueOf() + autoZoomDuration / 2, + latest.valueOf() + ); + const zoomEarliestMs = zoomLatestMs - autoZoomDuration; + const zoomState = { + from: moment(zoomEarliestMs).toISOString(), + to: moment(zoomLatestMs).toISOString(), + }; + appStateHandler(APP_STATE_ACTION.SET_ZOOM, zoomState); + + if (earliest.isBefore(moment(boundsMinMs)) || latest.isAfter(moment(boundsMaxMs))) { + const earliestMs = Math.min(earliest.valueOf(), boundsMinMs); + const latestMs = Math.max(latest.valueOf(), boundsMaxMs); + setGlobalState('time', { + from: moment(earliestMs).toISOString(), + to: moment(latestMs).toISOString(), + }); + } + }) + .catch(resp => { + // eslint-disable-next-line no-console + console.error( + 'Time series explorer - error loading time range of forecast from elasticsearch:', + resp + ); + }); + } + }, [selectedForecastId]); + + const [tableInterval] = useTableInterval(); + const [tableSeverity] = useTableSeverity(); const tzConfig = config.get('dateFormat:tz'); const dateFormatTz = tzConfig !== 'Browser' ? tzConfig : moment.tz.guess(); @@ -146,9 +261,20 @@ const TimeSeriesExplorerWrapper: FC<{ globalState: any; appState: any; config: a ); diff --git a/x-pack/legacy/plugins/ml/public/application/routing/use_refresh.ts b/x-pack/legacy/plugins/ml/public/application/routing/use_refresh.ts new file mode 100644 index 0000000000000..f9f3bb66f14f3 --- /dev/null +++ b/x-pack/legacy/plugins/ml/public/application/routing/use_refresh.ts @@ -0,0 +1,30 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { useObservable } from 'react-use'; +import { merge, Observable } from 'rxjs'; +import { map } from 'rxjs/operators'; + +import { annotationsRefresh$ } from '../services/annotations_service'; +import { + mlTimefilterRefresh$, + mlTimefilterTimeChange$, +} from '../services/timefilter_refresh_service'; + +export interface Refresh { + lastRefresh: number; + timeRange?: { start: string; end: string }; +} + +const refresh$: Observable = merge( + mlTimefilterRefresh$, + mlTimefilterTimeChange$, + annotationsRefresh$.pipe(map(d => ({ lastRefresh: d }))) +); + +export const useRefresh = () => { + return useObservable(refresh$); +}; diff --git a/x-pack/legacy/plugins/ml/public/application/services/annotations_service.test.tsx b/x-pack/legacy/plugins/ml/public/application/services/annotations_service.test.tsx index d74c3802c2ed2..2ba54d243ed1b 100644 --- a/x-pack/legacy/plugins/ml/public/application/services/annotations_service.test.tsx +++ b/x-pack/legacy/plugins/ml/public/application/services/annotations_service.test.tsx @@ -7,7 +7,7 @@ import mockAnnotations from '../components/annotations/annotations_table/__mocks__/mock_annotations.json'; import { Annotation } from '../../../common/types/annotations'; -import { annotation$, annotationsRefresh$ } from './annotations_service'; +import { annotation$, annotationsRefresh$, annotationsRefreshed } from './annotations_service'; describe('annotations_service', () => { test('annotation$', () => { @@ -34,7 +34,7 @@ describe('annotations_service', () => { expect(subscriber.mock.calls).toHaveLength(1); - annotationsRefresh$.next(true); + annotationsRefreshed(); expect(subscriber.mock.calls).toHaveLength(2); }); diff --git a/x-pack/legacy/plugins/ml/public/application/services/annotations_service.tsx b/x-pack/legacy/plugins/ml/public/application/services/annotations_service.tsx index 6953232f0cc6c..6493770156cb8 100644 --- a/x-pack/legacy/plugins/ml/public/application/services/annotations_service.tsx +++ b/x-pack/legacy/plugins/ml/public/application/services/annotations_service.tsx @@ -48,8 +48,8 @@ export type AnnotationState = Annotation | null; - To add it to a given components state, just use `annotation$.subscribe(annotation => this.setState({ annotation }));` in `componentDidMount()`. - 2. injectObservablesAsProps() from public/utils/observable_utils.tsx, as the name implies, offers - a way to wrap observables into another component which passes on updated values as props. + 2. useObservable() from 'react-use', offers a way to wrap observables + into another component which passes on updated values as props. - To subscribe to updates this way, wrap your component like: @@ -62,10 +62,13 @@ export type AnnotationState = Annotation | null; return {annotation.annotation}; } - export const MyObservableComponent = injectObservablesAsProps( - { annotation: annotaton$ }, - MyOriginalComponent - ); + export const MyObservableComponent = (props) => { + const annotationProp = useObservable(annotation$); + if (annotationProp === undefined) { + return null; + } + return ; + }; */ export const annotation$ = new BehaviorSubject(null); @@ -74,4 +77,5 @@ export const annotation$ = new BehaviorSubject(null); Instead of passing around callbacks or deeply nested props, it can be imported for both angularjs controllers/directives and React components. */ -export const annotationsRefresh$ = new BehaviorSubject(false); +export const annotationsRefresh$ = new BehaviorSubject(Date.now()); +export const annotationsRefreshed = () => annotationsRefresh$.next(Date.now()); diff --git a/x-pack/legacy/plugins/ml/public/application/services/forecast_service.d.ts b/x-pack/legacy/plugins/ml/public/application/services/forecast_service.d.ts index 19f77d97a5708..8de903a422f34 100644 --- a/x-pack/legacy/plugins/ml/public/application/services/forecast_service.d.ts +++ b/x-pack/legacy/plugins/ml/public/application/services/forecast_service.d.ts @@ -12,6 +12,11 @@ export interface ForecastData { results: any; } +export interface ForecastDateRange { + earliest: number; + latest: number; +} + export const mlForecastService: { getForecastData: ( job: Job, @@ -23,4 +28,6 @@ export const mlForecastService: { interval: string, aggType: any ) => Observable; + + getForecastDateRange: (job: Job, forecastId: string) => Promise; }; diff --git a/x-pack/legacy/plugins/ml/public/application/services/ml_api_service/index.d.ts b/x-pack/legacy/plugins/ml/public/application/services/ml_api_service/index.d.ts index 2ad2a148f05d1..bca32e9528f64 100644 --- a/x-pack/legacy/plugins/ml/public/application/services/ml_api_service/index.d.ts +++ b/x-pack/legacy/plugins/ml/public/application/services/ml_api_service/index.d.ts @@ -6,11 +6,12 @@ import { Observable } from 'rxjs'; import { Annotation } from '../../../../common/types/annotations'; +import { Dictionary } from '../../../../common/types/common'; import { AggFieldNamePair } from '../../../../common/types/fields'; import { Category } from '../../../../common/types/categories'; import { ExistingJobsAndGroups } from '../job_service'; import { PrivilegesResponse } from '../../../../common/types/privileges'; -import { MlSummaryJobs } from '../../../../common/types/jobs'; +import { MlJobWithTimeRange, MlSummaryJobs } from '../../../../common/types/jobs'; import { MlServerDefaults, MlServerLimits } from '../ml_server_info'; import { ES_AGGREGATION } from '../../../../common/constants/aggregation_types'; import { DataFrameAnalyticsStats } from '../../data_frame_analytics/pages/analytics_management/components/analytics_list/common'; @@ -135,6 +136,9 @@ declare interface Ml { jobs: { jobsSummary(jobIds: string[]): Promise; + jobsWithTimerange( + dateFormatTz: string + ): Promise<{ jobs: MlJobWithTimeRange[]; jobsMap: Dictionary }>; jobs(jobIds: string[]): Promise; groups(): Promise; updateGroups(updatedJobs: string[]): Promise; diff --git a/x-pack/legacy/plugins/ml/public/application/services/timefilter_refresh_service.tsx b/x-pack/legacy/plugins/ml/public/application/services/timefilter_refresh_service.tsx index 2085c2a5dc77f..86c07a3577f7b 100644 --- a/x-pack/legacy/plugins/ml/public/application/services/timefilter_refresh_service.tsx +++ b/x-pack/legacy/plugins/ml/public/application/services/timefilter_refresh_service.tsx @@ -6,4 +6,7 @@ import { Subject } from 'rxjs'; -export const mlTimefilterRefresh$ = new Subject(); +import { Refresh } from '../routing/use_refresh'; + +export const mlTimefilterRefresh$ = new Subject>(); +export const mlTimefilterTimeChange$ = new Subject>(); diff --git a/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/__tests__/timeseriesexplorer_directive.js b/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/__tests__/timeseriesexplorer_directive.js deleted file mode 100644 index 32b4fa3df3cf0..0000000000000 --- a/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/__tests__/timeseriesexplorer_directive.js +++ /dev/null @@ -1,40 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -import ngMock from 'ng_mock'; -import expect from '@kbn/expect'; - -describe('ML - Time Series Explorer Directive', () => { - let $scope; - let $compile; - let $element; - - beforeEach(ngMock.module('kibana')); - beforeEach(() => { - ngMock.inject(function($injector) { - $compile = $injector.get('$compile'); - const $rootScope = $injector.get('$rootScope'); - $scope = $rootScope.$new(); - }); - }); - - afterEach(() => { - $scope.$destroy(); - }); - - it('Initialize Time Series Explorer Directive', done => { - ngMock.inject(function() { - expect(() => { - $element = $compile('')($scope); - }).to.not.throwError(); - - // directive has scope: false - const scope = $element.isolateScope(); - expect(scope).to.eql(undefined); - done(); - }); - }); -}); diff --git a/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/components/entity_control/entity_control.tsx b/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/components/entity_control/entity_control.tsx index bc6896a1a66ba..df5412e609a9c 100644 --- a/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/components/entity_control/entity_control.tsx +++ b/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/components/entity_control/entity_control.tsx @@ -22,21 +22,13 @@ export interface Entity { fieldValues: any; } -function getEntityControlOptions(entity: Entity): EuiComboBoxOptionProps[] { - if (!Array.isArray(entity.fieldValues)) { - return []; - } - - return entity.fieldValues.map(value => { - return { label: value }; - }); -} - interface EntityControlProps { entity: Entity; entityFieldValueChanged: (entity: Entity, fieldValue: any) => void; + isLoading: boolean; onSearchChange: (entity: Entity, queryTerm: string) => void; forceSelection: boolean; + options: EuiComboBoxOptionProps[]; } interface EntityControlState { @@ -55,17 +47,11 @@ export class EntityControl extends Component 0) || @@ -79,11 +65,13 @@ export class EntityControl extends Component { - this.props.loadForForecastId(forecastId); + this.props.setForecastId(forecastId); this.closeModal(); }; @@ -279,7 +279,7 @@ export const ForecastingModal = injectI18n( this.setState({ jobClosingState: PROGRESS_STATES.DONE, }); - this.props.loadForForecastId(forecastId); + this.props.setForecastId(forecastId); this.closeAfterRunningForecast(); }) .catch(response => { @@ -297,10 +297,10 @@ export const ForecastingModal = injectI18n( this.setState({ jobClosingState: PROGRESS_STATES.ERROR, }); - this.props.loadForForecastId(forecastId); + this.props.setForecastId(forecastId); }); } else { - this.props.loadForForecastId(forecastId); + this.props.setForecastId(forecastId); this.closeAfterRunningForecast(); } } else { @@ -327,7 +327,7 @@ export const ForecastingModal = injectI18n( ); // Try and load any results which may have been created. - this.props.loadForForecastId(forecastId); + this.props.setForecastId(forecastId); this.setState({ forecastProgress: PROGRESS_STATES.ERROR }); clearInterval(this.forecastChecker); } diff --git a/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/components/timeseries_chart/timeseries_chart.js b/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/components/timeseries_chart/timeseries_chart.js index 4d10d73bcc048..d8e9e4379395a 100644 --- a/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/components/timeseries_chart/timeseries_chart.js +++ b/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/components/timeseries_chart/timeseries_chart.js @@ -11,7 +11,7 @@ import PropTypes from 'prop-types'; import React from 'react'; - +import useObservable from 'react-use/lib/useObservable'; import _ from 'lodash'; import d3 from 'd3'; import moment from 'moment'; @@ -23,7 +23,6 @@ import { getMultiBucketImpactLabel, } from '../../../../../common/util/anomaly_utils'; import { annotation$ } from '../../../services/annotations_service'; -import { injectObservablesAsProps } from '../../../util/observable_utils'; import { formatValue } from '../../../formatters/format_value'; import { LINE_CHART_ANOMALY_RADIUS, @@ -97,16 +96,16 @@ const TimeseriesChartIntl = injectI18n( static propTypes = { annotation: PropTypes.object, autoZoomDuration: PropTypes.number, + bounds: PropTypes.object, contextAggregationInterval: PropTypes.object, contextChartData: PropTypes.array, contextForecastData: PropTypes.array, contextChartSelected: PropTypes.func.isRequired, - detectorIndex: PropTypes.string, + detectorIndex: PropTypes.number, focusAggregationInterval: PropTypes.object, focusAnnotationData: PropTypes.array, focusChartData: PropTypes.array, focusForecastData: PropTypes.array, - skipRefresh: PropTypes.bool.isRequired, modelPlotEnabled: PropTypes.bool.isRequired, renderFocusChartOnly: PropTypes.bool.isRequired, selectedJob: PropTypes.object, @@ -114,7 +113,6 @@ const TimeseriesChartIntl = injectI18n( showModelBounds: PropTypes.bool.isRequired, svgWidth: PropTypes.number.isRequired, swimlaneData: PropTypes.array, - timefilter: PropTypes.object.isRequired, zoomFrom: PropTypes.object, zoomTo: PropTypes.object, zoomFromFocusLoaded: PropTypes.object, @@ -234,10 +232,6 @@ const TimeseriesChartIntl = injectI18n( } componentDidUpdate() { - if (this.props.skipRefresh) { - return; - } - if (this.props.renderFocusChartOnly === false) { this.renderChart(); this.drawContextChartSelection(); @@ -887,13 +881,12 @@ const TimeseriesChartIntl = injectI18n( } createZoomInfoElements(zoomGroup, fcsWidth) { - const { autoZoomDuration, modelPlotEnabled, timefilter, intl } = this.props; + const { autoZoomDuration, bounds, modelPlotEnabled, intl } = this.props; const setZoomInterval = this.setZoomInterval.bind(this); // Create zoom duration links applicable for the current time span. // Don't add links for any durations which would give a brush extent less than 10px. - const bounds = timefilter.getActiveBounds(); const boundsSecs = bounds.max.unix() - bounds.min.unix(); const minSecs = (10 / this.vizWidth) * boundsSecs; @@ -968,7 +961,7 @@ const TimeseriesChartIntl = injectI18n( } drawContextElements(cxtGroup, cxtWidth, cxtChartHeight, swlHeight) { - const { contextChartData, contextForecastData, modelPlotEnabled, timefilter } = this.props; + const { bounds, contextChartData, contextForecastData, modelPlotEnabled } = this.props; const data = contextChartData; @@ -1034,7 +1027,6 @@ const TimeseriesChartIntl = injectI18n( .attr('y2', cxtChartHeight + swlHeight); // Add x axis. - const bounds = timefilter.getActiveBounds(); const timeBuckets = new TimeBuckets(); timeBuckets.setInterval('auto'); timeBuckets.setBounds(bounds); @@ -1362,13 +1354,12 @@ const TimeseriesChartIntl = injectI18n( }; calculateContextXAxisDomain = () => { - const { contextAggregationInterval, swimlaneData, timefilter } = this.props; + const { bounds, contextAggregationInterval, swimlaneData } = this.props; // Calculates the x axis domain for the context elements. // Elasticsearch aggregation returns points at start of bucket, // so set the x-axis min to the start of the first aggregation interval, // and the x-axis max to the end of the last aggregation interval. // Context chart and swimlane use the same aggregation interval. - const bounds = timefilter.getActiveBounds(); let earliest = bounds.min.valueOf(); if (swimlaneData !== undefined && swimlaneData.length > 0) { @@ -1406,9 +1397,8 @@ const TimeseriesChartIntl = injectI18n( }; setZoomInterval(ms) { - const { timefilter, zoomTo } = this.props; + const { bounds, zoomTo } = this.props; - const bounds = timefilter.getActiveBounds(); const minBoundsMs = bounds.min.valueOf(); const maxBoundsMs = bounds.max.valueOf(); @@ -1726,7 +1716,10 @@ const TimeseriesChartIntl = injectI18n( } ); -export const TimeseriesChart = injectObservablesAsProps( - { annotation: annotation$ }, - TimeseriesChartIntl -); +export const TimeseriesChart = props => { + const annotationProp = useObservable(annotation$); + if (annotationProp === undefined) { + return null; + } + return ; +}; diff --git a/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/components/timeseries_chart/timeseries_chart.test.js b/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/components/timeseries_chart/timeseries_chart.test.js index fb52d191013f7..cc77ad9f1a985 100644 --- a/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/components/timeseries_chart/timeseries_chart.test.js +++ b/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/components/timeseries_chart/timeseries_chart.test.js @@ -46,7 +46,6 @@ function getTimeseriesChartPropsMock() { showModelBounds: true, svgWidth: 1600, timefilter: {}, - skipRefresh: false, }; } diff --git a/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer.d.ts b/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer.d.ts index ac4bc6186e5b4..3edbbc1af2323 100644 --- a/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer.d.ts +++ b/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer.d.ts @@ -10,6 +10,12 @@ import { FC } from 'react'; declare const TimeSeriesExplorer: FC<{ appStateHandler: (action: string, payload: any) => void; dateFormatTz: string; - globalState: any; + selectedJobIds: string[]; + selectedDetectorIndex: number; + selectedEntities: any[]; + selectedForecastId: string; + setGlobalState: (arg: any) => void; + tableInterval: string; + tableSeverity: number; timefilter: Timefilter; }>; diff --git a/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer.js b/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer.js index 0ab10c4fe69cd..807a368fc9b34 100644 --- a/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer.js +++ b/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer.js @@ -8,7 +8,7 @@ * React component for rendering Single Metric Viewer. */ -import { debounce, difference, each, find, first, get, has, isEqual, without } from 'lodash'; +import { debounce, difference, each, find, get, has, isEqual, without } from 'lodash'; import moment from 'moment-timezone'; import { Subject, Subscription, forkJoin } from 'rxjs'; import { map, debounceTime, switchMap, tap, withLatestFrom } from 'rxjs/operators'; @@ -36,42 +36,34 @@ import { toastNotifications } from 'ui/notify'; import { ResizeChecker } from '../../../../../../../src/plugins/kibana_utils/public'; import { ANOMALIES_TABLE_DEFAULT_QUERY_SIZE } from '../../../common/constants/search'; -import { parseInterval } from '../../../common/util/parse_interval'; import { isModelPlotEnabled, isSourceDataChartableForDetector, - isTimeSeriesViewJob, isTimeSeriesViewDetector, mlFunctionToESAggregation, } from '../../../common/util/job_utils'; -import { ChartTooltip } from '../components/chart_tooltip'; -import { - jobSelectServiceFactory, - setGlobalState, - getSelectedJobIds, -} from '../components/job_selector/job_select_service_utils'; import { AnnotationFlyout } from '../components/annotations/annotation_flyout'; import { AnnotationsTable } from '../components/annotations/annotations_table'; import { AnomaliesTable } from '../components/anomalies_table/anomalies_table'; +import { ChartTooltip } from '../components/chart_tooltip'; import { EntityControl } from './components/entity_control'; import { ForecastingModal } from './components/forecasting_modal/forecasting_modal'; import { JobSelector } from '../components/job_selector'; +import { getTimeRangeFromSelection } from '../components/job_selector/job_select_service_utils'; import { LoadingIndicator } from '../components/loading_indicator/loading_indicator'; import { NavigationMenu } from '../components/navigation_menu'; -import { severity$, SelectSeverity } from '../components/controls/select_severity/select_severity'; -import { interval$, SelectInterval } from '../components/controls/select_interval/select_interval'; +import { SelectInterval } from '../components/controls/select_interval/select_interval'; +import { SelectSeverity } from '../components/controls/select_severity/select_severity'; import { TimeseriesChart } from './components/timeseries_chart/timeseries_chart'; import { TimeseriesexplorerNoJobsFound } from './components/timeseriesexplorer_no_jobs_found'; import { TimeseriesexplorerNoChartData } from './components/timeseriesexplorer_no_chart_data'; -import { annotationsRefresh$ } from '../services/annotations_service'; import { ml } from '../services/ml_api_service'; import { mlFieldFormatService } from '../services/field_format_service'; import { mlForecastService } from '../services/forecast_service'; import { mlJobService } from '../services/job_service'; import { mlResultsService } from '../services/results_service'; -import { mlTimefilterRefresh$ } from '../services/timefilter_refresh_service'; import { getBoundsRoundedToInterval } from '../util/time_buckets'; @@ -86,7 +78,6 @@ import { calculateDefaultFocusRange, calculateInitialFocusRange, createTimeSeriesJobData, - getAutoZoomDuration, processForecastResults, processMetricPlotResults, processRecordScoreResults, @@ -102,33 +93,57 @@ const allValuesLabel = i18n.translate('xpack.ml.timeSeriesExplorer.allPartitionV defaultMessage: 'all', }); +function getEntityControlOptions(fieldValues) { + if (!Array.isArray(fieldValues)) { + return []; + } + + return fieldValues.map(value => { + return { label: value }; + }); +} + +function getViewableDetectors(selectedJob) { + const jobDetectors = selectedJob.analysis_config.detectors; + const viewableDetectors = []; + each(jobDetectors, (dtr, index) => { + if (isTimeSeriesViewDetector(selectedJob, index)) { + viewableDetectors.push({ + index, + detector_description: dtr.detector_description, + }); + } + }); + return viewableDetectors; +} + function getTimeseriesexplorerDefaultState() { return { chartDetails: undefined, + contextAggregationInterval: undefined, contextChartData: undefined, contextForecastData: undefined, // Not chartable if e.g. model plot with terms for a varp detector dataNotChartable: false, - detectorId: undefined, - detectors: [], - entities: [], + entitiesLoading: false, + entityValues: {}, focusAnnotationData: [], focusChartData: undefined, focusForecastData: undefined, fullRefresh: true, hasResults: false, - jobs: [], // Counter to keep track of what data sets have been loaded. loadCounter: 0, loading: false, modelPlotEnabled: false, - selectedJob: undefined, // Toggles display of annotations in the focus chart showAnnotations: mlAnnotationsEnabled, showAnnotationsCheckbox: mlAnnotationsEnabled, // Toggles display of forecast data in the focus chart showForecast: true, showForecastCheckbox: false, + // Toggles display of model bounds in the focus chart + showModelBounds: true, showModelBoundsCheckbox: false, svgWidth: 0, tableData: undefined, @@ -136,9 +151,6 @@ function getTimeseriesexplorerDefaultState() { zoomTo: undefined, zoomFromFocusLoaded: undefined, zoomToFocusLoaded: undefined, - - // Toggles display of model bounds in the focus chart - showModelBounds: true, }; } @@ -174,26 +186,23 @@ const containerPadding = 24; export class TimeSeriesExplorer extends React.Component { static propTypes = { appStateHandler: PropTypes.func.isRequired, + autoZoomDuration: PropTypes.number, + bounds: PropTypes.object, dateFormatTz: PropTypes.string.isRequired, - globalState: PropTypes.object.isRequired, - timefilter: PropTypes.object.isRequired, + jobsWithTimeRange: PropTypes.array.isRequired, + lastRefresh: PropTypes.number.isRequired, + selectedJobIds: PropTypes.arrayOf(PropTypes.string), + selectedDetectorIndex: PropTypes.number, + selectedEntities: PropTypes.object, + selectedForecastId: PropTypes.string, + tableInterval: PropTypes.string, + tableSeverity: PropTypes.number, }; state = getTimeseriesexplorerDefaultState(); subscriptions = new Subscription(); - _criteriaFields = null; - - constructor(props) { - super(props); - const { jobSelectService$, unsubscribeFromGlobalState } = jobSelectServiceFactory( - props.globalState - ); - this.jobSelectService$ = jobSelectService$; - this.unsubscribeFromGlobalState = unsubscribeFromGlobalState; - } - resizeRef = createRef(); resizeChecker = undefined; resizeHandler = () => { @@ -209,13 +218,10 @@ export class TimeSeriesExplorer extends React.Component { contextChart$ = new Subject(); detectorIndexChangeHandler = e => { + const { appStateHandler } = this.props; const id = e.target.value; if (id !== undefined) { - this.setState({ detectorId: id }, () => { - this.updateControlsForDetector(() => - this.loadEntityValues(() => this.saveSeriesPropertiesAndRefresh()) - ); - }); + appStateHandler(APP_STATE_ACTION.SET_DETECTOR_INDEX, +id); } }; @@ -245,7 +251,7 @@ export class TimeSeriesExplorer extends React.Component { previousShowModelBounds = undefined; tableFilter = (field, value, operator) => { - const { entities } = this.state; + const entities = this.getControlsForDetector(); const entity = entities.find(({ fieldName }) => fieldName === field); if (entity === undefined) { @@ -272,35 +278,14 @@ export class TimeSeriesExplorer extends React.Component { }; appStateHandler(APP_STATE_ACTION.SET_ENTITIES, resultEntities); - - this.updateControlsForDetector(() => { - this.refresh(); - }); }; contextChartSelectedInitCallDone = false; - /** - * Gets default range from component state. - */ - getDefaultRangeFromState() { - const { - autoZoomDuration, - contextAggregationInterval, - contextChartData, - contextForecastData, - } = this.state; - - return calculateDefaultFocusRange( - autoZoomDuration, - contextAggregationInterval, - contextChartData, - contextForecastData - ); - } - getFocusAggregationInterval(selection) { - const { jobs, selectedJob } = this.state; + const { selectedJobIds } = this.props; + const jobs = createTimeSeriesJobData(mlJobService.jobs); + const selectedJob = mlJobService.getJob(selectedJobIds[0]); // Calculate the aggregation interval for the focus chart. const bounds = { min: moment(selection.from), max: moment(selection.to) }; @@ -312,13 +297,13 @@ export class TimeSeriesExplorer extends React.Component { * Gets focus data for the current component state/ */ getFocusData(selection) { - const { detectorId, entities, modelPlotEnabled, selectedJob } = this.state; - - const { appStateHandler } = this.props; + const { selectedJobIds, selectedForecastId, selectedDetectorIndex } = this.props; + const { modelPlotEnabled } = this.state; + const selectedJob = mlJobService.getJob(selectedJobIds[0]); + const entityControls = this.getControlsForDetector(); // Calculate the aggregation interval for the focus chart. const bounds = { min: moment(selection.from), max: moment(selection.to) }; - const focusAggregationInterval = this.getFocusAggregationInterval(selection); // Ensure the search bounds align to the bucketing interval so that the first and last buckets are complete. @@ -327,12 +312,12 @@ export class TimeSeriesExplorer extends React.Component { const searchBounds = getBoundsRoundedToInterval(bounds, focusAggregationInterval, false); return getFocusData( - this._criteriaFields, - +detectorId, + this.getCriteriaFields(selectedDetectorIndex, entityControls), + selectedDetectorIndex, focusAggregationInterval, - appStateHandler(APP_STATE_ACTION.GET_FORECAST_ID), + selectedForecastId, modelPlotEnabled, - entities.filter(entity => entity.fieldValue.length > 0), + entityControls.filter(entity => entity.fieldValue.length > 0), searchBounds, selectedJob, TIME_FIELD_NAME @@ -345,10 +330,10 @@ export class TimeSeriesExplorer extends React.Component { entityFieldValueChanged = (entity, fieldValue) => { const { appStateHandler } = this.props; - const { entities } = this.state; + const entityControls = this.getControlsForDetector(); const resultEntities = { - ...entities.reduce((appStateEntities, appStateEntity) => { + ...entityControls.reduce((appStateEntities, appStateEntity) => { appStateEntities[appStateEntity.fieldName] = appStateEntity.fieldValue; return appStateEntities; }, {}), @@ -356,29 +341,33 @@ export class TimeSeriesExplorer extends React.Component { }; appStateHandler(APP_STATE_ACTION.SET_ENTITIES, resultEntities); - - this.updateControlsForDetector(() => { - this.refresh(); - }); }; entityFieldSearchChanged = debounce((entity, queryTerm) => { - this.loadEntityValues({ + const entityControls = this.getControlsForDetector(); + this.loadEntityValues(entityControls, { [entity.fieldType]: queryTerm, }); }, 500); loadAnomaliesTableData = (earliestMs, latestMs) => { - const { dateFormatTz } = this.props; - const { selectedJob } = this.state; + const { + dateFormatTz, + selectedDetectorIndex, + selectedJobIds, + tableInterval, + tableSeverity, + } = this.props; + const selectedJob = mlJobService.getJob(selectedJobIds[0]); + const entityControls = this.getControlsForDetector(); return ml.results .getAnomaliesTableData( [selectedJob.job_id], - this._criteriaFields, + this.getCriteriaFields(selectedDetectorIndex, entityControls), [], - interval$.getValue().val, - severity$.getValue().val, + tableInterval, + tableSeverity, earliestMs, latestMs, dateFormatTz, @@ -427,16 +416,18 @@ export class TimeSeriesExplorer extends React.Component { /** * Loads available entity values. + * @param {Array} entities - Entity controls configuration * @param {Object} searchTerm - Search term for partition, e.g. { partition_field: 'partition' } - * @param callback - Callback to execute after component state update. */ - loadEntityValues = async (searchTerm = {}, callback = () => {}) => { - const { timefilter } = this.props; - const { detectorId, entities, selectedJob } = this.state; + loadEntityValues = async (entities, searchTerm = {}) => { + this.setState({ entitiesLoading: true }); + + const { bounds, selectedJobIds, selectedDetectorIndex } = this.props; + const selectedJob = mlJobService.getJob(selectedJobIds[0]); - // Populate the entity input datalists with aggregated values. No need to pass through finish(). - const bounds = timefilter.getActiveBounds(); - const detectorIndex = +detectorId; + // Populate the entity input datalists with the values from the top records by score + // for the selected detector across the full time range. No need to pass through finish(). + const detectorIndex = selectedDetectorIndex; const { partition_field: partitionField, @@ -457,98 +448,46 @@ export class TimeSeriesExplorer extends React.Component { ) .toPromise(); - this.setState( - { - entities: entities.map(entity => { - const newEntity = { ...entity }; - if (partitionField?.name === entity.fieldName) { - newEntity.fieldValues = partitionField.values; - } - if (overField?.name === entity.fieldName) { - newEntity.fieldValues = overField.values; - } - if (byField?.name === entity.fieldName) { - newEntity.fieldValues = byField.values; - } - return newEntity; - }), - }, - callback - ); - }; - - loadForForecastId = forecastId => { - const { appStateHandler, timefilter } = this.props; - const { autoZoomDuration, contextChartData, selectedJob } = this.state; - - mlForecastService - .getForecastDateRange(selectedJob, forecastId) - .then(resp => { - const bounds = timefilter.getActiveBounds(); - const earliest = moment(resp.earliest || timefilter.getTime().from); - const latest = moment(resp.latest || timefilter.getTime().to); - - // Store forecast ID in the appState. - appStateHandler(APP_STATE_ACTION.SET_FORECAST_ID, forecastId); - - // Set the zoom to centre on the start of the forecast range, depending - // on the time range of the forecast and data. - const earliestDataDate = first(contextChartData).date; - const zoomLatestMs = Math.min(earliest + autoZoomDuration / 2, latest.valueOf()); - const zoomEarliestMs = Math.max( - zoomLatestMs - autoZoomDuration, - earliestDataDate.getTime() - ); + const entityValues = {}; + entities.forEach(entity => { + let fieldValues; - const zoomState = { - from: moment(zoomEarliestMs).toISOString(), - to: moment(zoomLatestMs).toISOString(), - }; - appStateHandler(APP_STATE_ACTION.SET_ZOOM, zoomState); - - // Ensure the forecast data will be shown if hidden previously. - this.setState({ showForecast: true }); + if (partitionField?.name === entity.fieldName) { + fieldValues = partitionField.values; + } + if (overField?.name === entity.fieldName) { + fieldValues = overField.values; + } + if (byField?.name === entity.fieldName) { + fieldValues = byField.values; + } + entityValues[entity.fieldName] = fieldValues; + }); - if (earliest.isBefore(bounds.min) || latest.isAfter(bounds.max)) { - const earliestMs = Math.min(earliest.valueOf(), bounds.min.valueOf()); - const latestMs = Math.max(latest.valueOf(), bounds.max.valueOf()); + this.setState({ entitiesLoading: false, entityValues }); + }; - timefilter.setTime({ - from: moment(earliestMs).toISOString(), - to: moment(latestMs).toISOString(), - }); - } else { - // Refresh to show the requested forecast data. - this.refresh(); - } - }) - .catch(resp => { - console.log( - 'Time series explorer - error loading time range of forecast from elasticsearch:', - resp - ); - }); + setForecastId = forecastId => { + this.props.appStateHandler(APP_STATE_ACTION.SET_FORECAST_ID, forecastId); }; - refresh = (fullRefresh = true) => { - // Skip the refresh if: - // a) The global state's `skipRefresh` was set to true by the job selector to avoid race conditions - // when loading the Single Metric Viewer after a job/group and time range update. - // b) A 'soft' refresh without a full page reload is already happening. - if ( - get(this.props.globalState, 'ml.skipRefresh') || - (this.state.loading && fullRefresh === false) - ) { + loadSingleMetricData = (fullRefresh = true) => { + const { + autoZoomDuration, + bounds, + selectedDetectorIndex, + selectedForecastId, + selectedJobIds, + zoom, + } = this.props; + + if (selectedJobIds === undefined) { return; } - const { appStateHandler, timefilter } = this.props; - const { - detectorId: currentDetectorId, - entities: currentEntities, - loadCounter: currentLoadCounter, - selectedJob: currentSelectedJob, - } = this.state; + const { loadCounter: currentLoadCounter } = this.state; + + const currentSelectedJob = mlJobService.getJob(selectedJobIds[0]); if (currentSelectedJob === undefined) { return; @@ -558,6 +497,7 @@ export class TimeSeriesExplorer extends React.Component { // Only when `fullRefresh` is true we'll reset all data // and show the loading spinner within the page. + const entityControls = this.getControlsForDetector(); this.setState( { fullRefresh, @@ -572,8 +512,8 @@ export class TimeSeriesExplorer extends React.Component { focusForecastData: undefined, modelPlotEnabled: isModelPlotEnabled( currentSelectedJob, - +currentDetectorId, - currentEntities + selectedDetectorIndex, + entityControls ), hasResults: false, dataNotChartable: false, @@ -581,15 +521,11 @@ export class TimeSeriesExplorer extends React.Component { : {}), }, () => { - const { - detectorId, - entities, - loadCounter, - jobs, - modelPlotEnabled, - selectedJob, - } = this.state; - const detectorIndex = +detectorId; + const { loadCounter, modelPlotEnabled } = this.state; + + const jobs = createTimeSeriesJobData(mlJobService.jobs); + const selectedJob = mlJobService.getJob(selectedJobIds[0]); + const detectorIndex = selectedDetectorIndex; let awaitingCount = 3; @@ -609,19 +545,16 @@ export class TimeSeriesExplorer extends React.Component { // Set zoomFrom/zoomTo attributes in scope which will result in the metric chart automatically // selecting the specified range in the context chart, and so loading that date range in the focus chart. if (stateUpdate.contextChartData.length) { - // Calculate the 'auto' zoom duration which shows data at bucket span granularity. - stateUpdate.autoZoomDuration = getAutoZoomDuration(jobs, selectedJob); - // Check for a zoom parameter in the appState (URL). let focusRange = calculateInitialFocusRange( - appStateHandler(APP_STATE_ACTION.GET_ZOOM), + zoom, stateUpdate.contextAggregationInterval, - timefilter + bounds ); if (focusRange === undefined) { focusRange = calculateDefaultFocusRange( - stateUpdate.autoZoomDuration, + autoZoomDuration, stateUpdate.contextAggregationInterval, stateUpdate.contextChartData, stateUpdate.contextForecastData @@ -636,7 +569,7 @@ export class TimeSeriesExplorer extends React.Component { } }; - const nonBlankEntities = currentEntities.filter(entity => { + const nonBlankEntities = entityControls.filter(entity => { return entity.fieldValue.length > 0; }); @@ -654,8 +587,6 @@ export class TimeSeriesExplorer extends React.Component { return; } - const bounds = timefilter.getActiveBounds(); - // Calculate the aggregation interval for the context chart. // Context chart swimlane will display bucket anomaly score at the same interval. stateUpdate.contextAggregationInterval = calculateAggregationInterval( @@ -706,7 +637,7 @@ export class TimeSeriesExplorer extends React.Component { mlResultsService .getRecordMaxScoreByTime( selectedJob.job_id, - this._criteriaFields, + this.getCriteriaFields(detectorIndex, entityControls), searchBounds.min.valueOf(), searchBounds.max.valueOf(), stateUpdate.contextAggregationInterval.expression @@ -728,7 +659,7 @@ export class TimeSeriesExplorer extends React.Component { .getChartDetails( selectedJob, detectorIndex, - entities, + entityControls, searchBounds.min.valueOf(), searchBounds.max.valueOf() ) @@ -744,8 +675,7 @@ export class TimeSeriesExplorer extends React.Component { }); // Plus query for forecast data if there is a forecastId stored in the appState. - const forecastId = appStateHandler(APP_STATE_ACTION.GET_FORECAST_ID); - if (forecastId !== undefined) { + if (selectedForecastId !== undefined) { awaitingCount++; let aggType = undefined; const detector = selectedJob.analysis_config.detectors[detectorIndex]; @@ -757,7 +687,7 @@ export class TimeSeriesExplorer extends React.Component { .getForecastData( selectedJob, detectorIndex, - forecastId, + selectedForecastId, nonBlankEntities, searchBounds.min.valueOf(), searchBounds.max.valueOf(), @@ -771,13 +701,11 @@ export class TimeSeriesExplorer extends React.Component { }) .catch(resp => { console.log( - `Time series explorer - error loading data for forecast ID ${forecastId}`, + `Time series explorer - error loading data for forecast ID ${selectedForecastId}`, resp ); }); } - - this.loadEntityValues(); } ); }; @@ -786,15 +714,21 @@ export class TimeSeriesExplorer extends React.Component { * Updates local state of detector related controls from the global state. * @param callback to invoke after a state update. */ - updateControlsForDetector = (callback = () => {}) => { - const { appStateHandler } = this.props; - const { detectorId, selectedJob } = this.state; + getControlsForDetector = () => { + const { selectedDetectorIndex, selectedEntities, selectedJobIds } = this.props; + const selectedJob = mlJobService.getJob(selectedJobIds[0]); + + const entities = []; + + if (selectedJob === undefined) { + return entities; + } + // Update the entity dropdown control(s) according to the partitioning fields for the selected detector. - const detectorIndex = +detectorId; + const detectorIndex = selectedDetectorIndex; const detector = selectedJob.analysis_config.detectors[detectorIndex]; - const entities = []; - const entitiesState = appStateHandler(APP_STATE_ACTION.GET_ENTITIES); + const entitiesState = selectedEntities; const partitionFieldName = get(detector, 'partition_field_name'); const overFieldName = get(detector, 'over_field_name'); const byFieldName = get(detector, 'by_field_name'); @@ -825,9 +759,7 @@ export class TimeSeriesExplorer extends React.Component { entities.push({ fieldType: 'by_field', fieldName: byFieldName, fieldValue: byFieldValue }); } - this.updateCriteriaFields(detectorIndex, entities); - - this.setState({ entities }, callback); + return entities; }; /** @@ -835,10 +767,10 @@ export class TimeSeriesExplorer extends React.Component { * @param detectorIndex * @param entities */ - updateCriteriaFields(detectorIndex, entities) { + getCriteriaFields(detectorIndex, entities) { // Only filter on the entity if the field has a value. const nonBlankEntities = entities.filter(entity => entity.fieldValue.length > 0); - this._criteriaFields = [ + return [ { fieldName: 'detector_index', fieldValue: detectorIndex, @@ -847,47 +779,21 @@ export class TimeSeriesExplorer extends React.Component { ]; } - loadForJobId(jobId, jobs) { - const { appStateHandler } = this.props; - - // Validation that the ID is for a time series job must already have been performed. - // Check if the job was created since the page was first loaded. - let jobPickerSelectedJob = find(jobs, { id: jobId }); - if (jobPickerSelectedJob === undefined) { - const newJobs = []; - each(mlJobService.jobs, job => { - if (isTimeSeriesViewJob(job) === true) { - const bucketSpan = parseInterval(job.analysis_config.bucket_span); - newJobs.push({ - id: job.job_id, - selected: false, - bucketSpanSeconds: bucketSpan.asSeconds(), - }); - } - }); - this.setState({ jobs: newJobs }); - jobPickerSelectedJob = find(newJobs, { id: jobId }); - } + loadForJobId(jobId) { + const { appStateHandler, selectedDetectorIndex } = this.props; const selectedJob = mlJobService.getJob(jobId); - // Read the detector index and entities out of the AppState. - const jobDetectors = selectedJob.analysis_config.detectors; - const viewableDetectors = []; - each(jobDetectors, (dtr, index) => { - if (isTimeSeriesViewDetector(selectedJob, index)) { - viewableDetectors.push({ - index: '' + index, - detector_description: dtr.detector_description, - }); - } - }); - const detectors = viewableDetectors; + if (selectedJob === undefined) { + return; + } + + const detectors = getViewableDetectors(selectedJob); // Check the supplied index is valid. - const appStateDtrIdx = appStateHandler(APP_STATE_ACTION.GET_DETECTOR_INDEX); - let detectorIndex = appStateDtrIdx !== undefined ? appStateDtrIdx : +viewableDetectors[0].index; - if (find(viewableDetectors, { index: '' + detectorIndex }) === undefined) { + const appStateDtrIdx = selectedDetectorIndex; + let detectorIndex = appStateDtrIdx !== undefined ? appStateDtrIdx : detectors[0].index; + if (find(detectors, { index: detectorIndex }) === undefined) { const warningText = i18n.translate( 'xpack.ml.timeSeriesExplorer.requestedDetectorIndexNotValidWarningMessage', { @@ -899,179 +805,22 @@ export class TimeSeriesExplorer extends React.Component { } ); toastNotifications.addWarning(warningText); - detectorIndex = +viewableDetectors[0].index; - appStateHandler(APP_STATE_ACTION.SET_DETECTOR_INDEX, detectorIndex); + detectorIndex = detectors[0].index; } - // Store the detector index as a string so it can be used as ng-model in a select control. - const detectorId = '' + detectorIndex; + const detectorId = detectorIndex; - this.setState({ detectorId, detectors, selectedJob }, () => { - this.updateControlsForDetector(() => { - // Populate the map of jobs / detectors / field formatters for the selected IDs and refresh. - mlFieldFormatService - .populateFormats([jobId]) - .catch(err => { - console.log('Error populating field formats:', err); - }) - // Load the data - if the FieldFormats failed to populate - // the default formatting will be used for metric values. - .then(() => { - this.refresh(); - }); - }); + if (detectorId !== selectedDetectorIndex) { + appStateHandler(APP_STATE_ACTION.SET_DETECTOR_INDEX, detectorId); + } + + // Populate the map of jobs / detectors / field formatters for the selected IDs and refresh. + mlFieldFormatService.populateFormats([jobId]).catch(err => { + console.log('Error populating field formats:', err); }); } - saveSeriesPropertiesAndRefresh = () => { - const { appStateHandler } = this.props; - const { detectorId, entities } = this.state; - - appStateHandler(APP_STATE_ACTION.SET_DETECTOR_INDEX, +detectorId); - appStateHandler( - APP_STATE_ACTION.SET_ENTITIES, - entities.reduce((appStateEntities, entity) => { - appStateEntities[entity.fieldName] = entity.fieldValue; - return appStateEntities; - }, {}) - ); - - this.refresh(); - }; - componentDidMount() { - const { appStateHandler, globalState, timefilter } = this.props; - - this.setState({ jobs: [] }); - - // Get the job info needed by the visualization, then do the first load. - if (mlJobService.jobs.length > 0) { - const jobs = createTimeSeriesJobData(mlJobService.jobs); - this.setState({ jobs }); - } else { - this.setState({ loading: false }); - } - - // Reload the anomalies table if the Interval or Threshold controls are changed. - const tableControlsListener = () => { - const { zoomFrom, zoomTo } = this.state; - if (zoomFrom !== undefined && zoomTo !== undefined) { - this.loadAnomaliesTableData(zoomFrom.getTime(), zoomTo.getTime()).subscribe(res => - this.setState(res) - ); - } - }; - - this.subscriptions.add(annotationsRefresh$.subscribe(this.refresh)); - this.subscriptions.add(interval$.subscribe(tableControlsListener)); - this.subscriptions.add(severity$.subscribe(tableControlsListener)); - this.subscriptions.add( - mlTimefilterRefresh$.subscribe(() => { - this.refresh(true); - }) - ); - - // Listen for changes to job selection. - this.subscriptions.add( - this.jobSelectService$.subscribe(({ selection: selectedJobIds }) => { - const jobs = createTimeSeriesJobData(mlJobService.jobs); - - this.contextChartSelectedInitCallDone = false; - this.setState({ fullRefresh: false, loading: true, showForecastCheckbox: false }); - - const timeSeriesJobIds = jobs.map(j => j.id); - - // Check if any of the jobs set in the URL are not time series jobs - // (e.g. if switching to this view straight from the Anomaly Explorer). - const invalidIds = difference(selectedJobIds, timeSeriesJobIds); - selectedJobIds = without(selectedJobIds, ...invalidIds); - if (invalidIds.length > 0) { - let warningText = i18n.translate( - 'xpack.ml.timeSeriesExplorer.canNotViewRequestedJobsWarningMessage', - { - defaultMessage: `You can't view requested {invalidIdsCount, plural, one {job} other {jobs}} {invalidIds} in this dashboard`, - values: { - invalidIdsCount: invalidIds.length, - invalidIds, - }, - } - ); - if (selectedJobIds.length === 0 && timeSeriesJobIds.length > 0) { - warningText += i18n.translate('xpack.ml.timeSeriesExplorer.autoSelectingFirstJobText', { - defaultMessage: ', auto selecting first job', - }); - } - toastNotifications.addWarning(warningText); - } - - if (selectedJobIds.length > 1) { - // if more than one job or a group has been loaded from the URL - if (selectedJobIds.length > 1) { - // if more than one job, select the first job from the selection. - toastNotifications.addWarning( - i18n.translate('xpack.ml.timeSeriesExplorer.youCanViewOneJobAtTimeWarningMessage', { - defaultMessage: 'You can only view one job at a time in this dashboard', - }) - ); - - setGlobalState(globalState, { selectedIds: [selectedJobIds[0]] }); - this.jobSelectService$.next({ selection: [selectedJobIds[0]], resetSelection: true }); - } else { - // if a group has been loaded - if (selectedJobIds.length > 0) { - // if the group contains valid jobs, select the first - toastNotifications.addWarning( - i18n.translate('xpack.ml.timeSeriesExplorer.youCanViewOneJobAtTimeWarningMessage', { - defaultMessage: 'You can only view one job at a time in this dashboard', - }) - ); - - setGlobalState(globalState, { selectedIds: [selectedJobIds[0]] }); - this.jobSelectService$.next({ selection: [selectedJobIds[0]], resetSelection: true }); - } else if (jobs.length > 0) { - // if there are no valid jobs in the group but there are valid jobs - // in the list of all jobs, select the first - setGlobalState(globalState, { selectedIds: [jobs[0].id] }); - this.jobSelectService$.next({ selection: [jobs[0].id], resetSelection: true }); - } else { - // if there are no valid jobs left. - this.setState({ loading: false }); - } - } - } else if (invalidIds.length > 0 && selectedJobIds.length > 0) { - // if some ids have been filtered out because they were invalid. - // refresh the URL with the first valid id - setGlobalState(globalState, { selectedIds: [selectedJobIds[0]] }); - this.jobSelectService$.next({ selection: [selectedJobIds[0]], resetSelection: true }); - } else if (selectedJobIds.length > 0) { - // normal behavior. a job ID has been loaded from the URL - if ( - this.state.selectedJob !== undefined && - selectedJobIds[0] !== this.state.selectedJob.job_id - ) { - // Clear the detectorIndex, entities and forecast info. - appStateHandler(APP_STATE_ACTION.CLEAR); - } - this.loadForJobId(selectedJobIds[0], jobs); - } else { - if (selectedJobIds.length === 0 && jobs.length > 0) { - // no jobs were loaded from the URL, so add the first job - // from the full jobs list. - setGlobalState(globalState, { selectedIds: [jobs[0].id] }); - this.jobSelectService$.next({ selection: [jobs[0].id], resetSelection: true }); - } else { - // Jobs exist, but no time series jobs. - this.setState({ loading: false }); - } - } - }) - ); - - timefilter.enableTimeRangeSelector(); - timefilter.enableAutoRefreshSelector(); - - this.subscriptions.add(timefilter.getTimeUpdate$().subscribe(() => this.refresh(false))); - // Required to redraw the time series chart when the container is resized. this.resizeChecker = new ResizeChecker(this.resizeRef.current); this.resizeChecker.on('resize', () => { @@ -1106,23 +855,6 @@ export class TimeSeriesExplorer extends React.Component { return; } - const defaultRange = this.getDefaultRangeFromState(); - - if ( - (selection.from.getTime() !== defaultRange[0].getTime() || - selection.to.getTime() !== defaultRange[1].getTime()) && - isNaN(Date.parse(selection.from)) === false && - isNaN(Date.parse(selection.to)) === false - ) { - const zoomState = { - from: selection.from.toISOString(), - to: selection.to.toISOString(), - }; - appStateHandler(APP_STATE_ACTION.SET_ZOOM, zoomState); - } else { - appStateHandler(APP_STATE_ACTION.UNSET_ZOOM); - } - if ( (this.contextChartSelectedInitCallDone === false && focusChartData === undefined) || zoomFromFocusLoaded.getTime() !== selection.from.getTime() || @@ -1137,7 +869,9 @@ export class TimeSeriesExplorer extends React.Component { } }), switchMap(selection => { - const { jobs, selectedJob } = this.state; + const { selectedJobIds } = this.props; + const jobs = createTimeSeriesJobData(mlJobService.jobs); + const selectedJob = mlJobService.getJob(selectedJobIds[0]); // Calculate the aggregation interval for the focus chart. const bounds = { min: moment(selection.from), max: moment(selection.to) }; @@ -1180,39 +914,267 @@ export class TimeSeriesExplorer extends React.Component { ...refreshFocusData, ...tableData, }); + const zoomState = { + from: selection.from.toISOString(), + to: selection.to.toISOString(), + }; + this.props.appStateHandler(APP_STATE_ACTION.SET_ZOOM, zoomState); }) ); + + this.componentDidUpdate(); + } + + /** + * returns true/false if setGlobalState has been triggered + * or returns the job id which should be loaded. + */ + checkJobSelection() { + const { jobsWithTimeRange, selectedJobIds, setGlobalState } = this.props; + + const jobs = createTimeSeriesJobData(mlJobService.jobs); + const timeSeriesJobIds = jobs.map(j => j.id); + + // Check if any of the jobs set in the URL are not time series jobs + // (e.g. if switching to this view straight from the Anomaly Explorer). + const invalidIds = difference(selectedJobIds, timeSeriesJobIds); + const validSelectedJobIds = without(selectedJobIds, ...invalidIds); + if (invalidIds.length > 0) { + let warningText = i18n.translate( + 'xpack.ml.timeSeriesExplorer.canNotViewRequestedJobsWarningMessage', + { + defaultMessage: `You can't view requested {invalidIdsCount, plural, one {job} other {jobs}} {invalidIds} in this dashboard`, + values: { + invalidIdsCount: invalidIds.length, + invalidIds, + }, + } + ); + if (validSelectedJobIds.length === 0 && timeSeriesJobIds.length > 0) { + warningText += i18n.translate('xpack.ml.timeSeriesExplorer.autoSelectingFirstJobText', { + defaultMessage: ', auto selecting first job', + }); + } + toastNotifications.addWarning(warningText); + } + + if (validSelectedJobIds.length > 1) { + // if more than one job or a group has been loaded from the URL + if (validSelectedJobIds.length > 1) { + // if more than one job, select the first job from the selection. + toastNotifications.addWarning( + i18n.translate('xpack.ml.timeSeriesExplorer.youCanViewOneJobAtTimeWarningMessage', { + defaultMessage: 'You can only view one job at a time in this dashboard', + }) + ); + setGlobalState('ml', { jobIds: [validSelectedJobIds[0]] }); + return true; + } else { + // if a group has been loaded + if (selectedJobIds.length > 0) { + // if the group contains valid jobs, select the first + toastNotifications.addWarning( + i18n.translate('xpack.ml.timeSeriesExplorer.youCanViewOneJobAtTimeWarningMessage', { + defaultMessage: 'You can only view one job at a time in this dashboard', + }) + ); + setGlobalState('ml', { jobIds: [validSelectedJobIds[0]] }); + return true; + } else if (jobs.length > 0) { + // if there are no valid jobs in the group but there are valid jobs + // in the list of all jobs, select the first + const jobIds = [jobs[0].id]; + const time = getTimeRangeFromSelection(jobsWithTimeRange, jobIds); + setGlobalState({ + ...{ ml: { jobIds } }, + ...(time !== undefined ? { time } : {}), + }); + return true; + } else { + // if there are no valid jobs left. + return false; + } + } + } else if (invalidIds.length > 0 && validSelectedJobIds.length > 0) { + // if some ids have been filtered out because they were invalid. + // refresh the URL with the first valid id + setGlobalState('ml', { jobIds: [validSelectedJobIds[0]] }); + return true; + } else if (validSelectedJobIds.length > 0) { + // normal behavior. a job ID has been loaded from the URL + // Clear the detectorIndex, entities and forecast info. + return validSelectedJobIds[0]; + } else { + if (validSelectedJobIds.length === 0 && jobs.length > 0) { + // no jobs were loaded from the URL, so add the first job + // from the full jobs list. + const jobIds = [jobs[0].id]; + const time = getTimeRangeFromSelection(jobsWithTimeRange, jobIds); + setGlobalState({ + ...{ ml: { jobIds } }, + ...(time !== undefined ? { time } : {}), + }); + return true; + } else { + // Jobs exist, but no time series jobs. + return false; + } + } + } + + componentDidUpdate(previousProps) { + if ( + previousProps === undefined || + !isEqual(previousProps.selectedJobIds, this.props.selectedJobIds) + ) { + const update = this.checkJobSelection(); + // - true means a setGlobalState got triggered and + // we'll just wait for the next React render. + // - false means there are either no jobs or no time based jobs present. + // - if we get back a string it means we got back a job id we can load. + if (update === true) { + return; + } else if (update === false) { + this.setState({ loading: false }); + return; + } else if (typeof update === 'string') { + this.contextChartSelectedInitCallDone = false; + this.setState({ fullRefresh: false, loading: true }, () => { + this.loadForJobId(update); + }); + } + } + + if ( + this.props.bounds !== undefined && + this.props.selectedJobIds !== undefined && + (previousProps === undefined || + !isEqual(previousProps.selectedJobIds, this.props.selectedJobIds) || + previousProps.selectedDetectorIndex !== this.props.selectedDetectorIndex || + !isEqual(previousProps.selectedEntities, this.props.selectedEntities)) + ) { + const entityControls = this.getControlsForDetector(); + this.loadEntityValues(entityControls); + } + + if ( + previousProps === undefined || + previousProps.selectedForecastId !== this.props.selectedForecastId + ) { + if (this.props.selectedForecastId !== undefined) { + // Ensure the forecast data will be shown if hidden previously. + this.setState({ showForecast: true }); + } + } + + if ( + previousProps === undefined || + !isEqual(previousProps.bounds, this.props.bounds) || + !isEqual(previousProps.lastRefresh, this.props.lastRefresh) || + !isEqual(previousProps.selectedDetectorIndex, this.props.selectedDetectorIndex) || + !isEqual(previousProps.selectedEntities, this.props.selectedEntities) || + !isEqual(previousProps.selectedForecastId, this.props.selectedForecastId) || + !isEqual(previousProps.selectedJobIds, this.props.selectedJobIds) || + !isEqual(previousProps.zoom, this.props.zoom) + ) { + const fullRefresh = + previousProps === undefined || + !isEqual(previousProps.bounds, this.props.bounds) || + !isEqual(previousProps.lastRefresh, this.props.lastRefresh) || + !isEqual(previousProps.selectedDetectorIndex, this.props.selectedDetectorIndex) || + !isEqual(previousProps.selectedEntities, this.props.selectedEntities) || + !isEqual(previousProps.selectedForecastId, this.props.selectedForecastId) || + !isEqual(previousProps.selectedJobIds, this.props.selectedJobIds); + this.loadSingleMetricData(fullRefresh); + } + + if (previousProps === undefined) { + return; + } + + // Reload the anomalies table if the Interval or Threshold controls are changed. + const tableControlsListener = () => { + const { zoomFrom, zoomTo } = this.state; + if (zoomFrom !== undefined && zoomTo !== undefined) { + this.loadAnomaliesTableData(zoomFrom.getTime(), zoomTo.getTime()).subscribe(res => + this.setState(res) + ); + } + }; + + if ( + previousProps.tableInterval !== this.props.tableInterval || + previousProps.tableSeverity !== this.props.tableSeverity + ) { + tableControlsListener(); + } + + if ( + this.props.autoZoomDuration === undefined || + this.props.selectedForecastId !== undefined || + this.state.contextAggregationInterval === undefined || + this.state.contextChartData === undefined || + this.state.contextChartData.length === 0 + ) { + return; + } + + const defaultRange = calculateDefaultFocusRange( + this.props.autoZoomDuration, + this.state.contextAggregationInterval, + this.state.contextChartData, + this.state.contextForecastData + ); + + const selection = { + from: this.state.zoomFrom, + to: this.state.zoomTo, + }; + + if ( + (selection.from.getTime() !== defaultRange[0].getTime() || + selection.to.getTime() !== defaultRange[1].getTime()) && + isNaN(Date.parse(selection.from)) === false && + isNaN(Date.parse(selection.to)) === false + ) { + const zoomState = { + from: selection.from.toISOString(), + to: selection.to.toISOString(), + }; + this.props.appStateHandler(APP_STATE_ACTION.SET_ZOOM, zoomState); + } } componentWillUnmount() { this.subscriptions.unsubscribe(); this.resizeChecker.destroy(); - this.unsubscribeFromGlobalState(); } render() { - const { dateFormatTz, globalState, timefilter } = this.props; - const { autoZoomDuration, + bounds, + dateFormatTz, + lastRefresh, + selectedDetectorIndex, + selectedJobIds, + } = this.props; + + const { chartDetails, contextAggregationInterval, contextChartData, contextForecastData, dataNotChartable, - detectors, - detectorId, - entities, + entityValues, focusAggregationInterval, focusAnnotationData, focusChartData, focusForecastData, fullRefresh, hasResults, - jobs, loading, modelPlotEnabled, - selectedJob, showAnnotations, showAnnotationsCheckbox, showForecast, @@ -1228,11 +1190,6 @@ export class TimeSeriesExplorer extends React.Component { zoomToFocusLoaded, } = this.state; - const fieldNamesWithEmptyValues = entities - .filter(({ fieldValue }) => !fieldValue) - .map(({ fieldName }) => fieldName); - const arePartitioningFieldsProvided = fieldNamesWithEmptyValues.length === 0; - const chartProps = { modelPlotEnabled, contextChartData, @@ -1244,7 +1201,6 @@ export class TimeSeriesExplorer extends React.Component { focusChartData, focusForecastData, focusAggregationInterval, - skipRefresh: loading || !!get(this.props.globalState, 'ml.skipRefresh'), svgWidth, zoomFrom, zoomTo, @@ -1253,17 +1209,14 @@ export class TimeSeriesExplorer extends React.Component { autoZoomDuration, }; - const { jobIds: selectedJobIds, selectedGroups } = getSelectedJobIds(globalState); const jobSelectorProps = { dateFormatTz, - globalState, - jobSelectService$: this.jobSelectService$, - selectedJobIds, - selectedGroups, singleSelection: true, timeseriesOnly: true, }; + const jobs = createTimeSeriesJobData(mlJobService.jobs); + if (jobs.length === 0) { return ( @@ -1272,7 +1225,27 @@ export class TimeSeriesExplorer extends React.Component { ); } - const detectorSelectOptions = detectors.map(d => ({ + if ( + selectedJobIds === undefined || + selectedJobIds.length > 1 || + selectedDetectorIndex === undefined || + mlJobService.getJob(selectedJobIds[0]) === undefined + ) { + return ( + + ); + } + + const selectedJob = mlJobService.getJob(selectedJobIds[0]); + const entityControls = this.getControlsForDetector(); + + const fieldNamesWithEmptyValues = entityControls + .filter(({ fieldValue }) => !fieldValue) + .map(({ fieldName }) => fieldName); + + const arePartitioningFieldsProvided = fieldNamesWithEmptyValues.length === 0; + + const detectorSelectOptions = getViewableDetectors(selectedJob).map(d => ({ value: d.index, text: d.detector_description, })); @@ -1285,12 +1258,14 @@ export class TimeSeriesExplorer extends React.Component { isEqual(this.previousChartProps.focusAnnotationData, chartProps.focusAnnotationData) && this.previousShowAnnotations === showAnnotations && this.previousShowForecast === showForecast && - this.previousShowModelBounds === showModelBounds + this.previousShowModelBounds === showModelBounds && + this.previousLastRefresh === lastRefresh ) { renderFocusChartOnly = false; } this.previousChartProps = chartProps; + this.previousLastRefresh = lastRefresh; this.previousShowAnnotations = showAnnotations; this.previousShowForecast = showForecast; this.previousShowModelBounds = showModelBounds; @@ -1337,12 +1312,12 @@ export class TimeSeriesExplorer extends React.Component { > - {entities.map(entity => { + {entityControls.map(entity => { const entityKey = `${entity.fieldName}`; const forceSelection = !hasEmptyFieldValues && !entity.fieldValue; hasEmptyFieldValues = !hasEmptyFieldValues && forceSelection; @@ -1350,9 +1325,11 @@ export class TimeSeriesExplorer extends React.Component { ); })} @@ -1361,9 +1338,9 @@ export class TimeSeriesExplorer extends React.Component { @@ -1386,7 +1363,7 @@ export class TimeSeriesExplorer extends React.Component { hasResults === false && ( )} @@ -1488,13 +1465,13 @@ export class TimeSeriesExplorer extends React.Component {
{showAnnotations && focusAnnotationData.length > 0 && ( @@ -1547,8 +1524,8 @@ export class TimeSeriesExplorer extends React.Component { )} - {arePartitioningFieldsProvided && jobs.length > 0 && ( - + {arePartitioningFieldsProvided && jobs.length > 0 && hasResults === true && ( + )}
); diff --git a/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer_constants.ts b/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer_constants.ts index 29a5facf64c0f..a801a1c5ce6f5 100644 --- a/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer_constants.ts +++ b/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer_constants.ts @@ -10,13 +10,9 @@ export const APP_STATE_ACTION = { CLEAR: 'CLEAR', - GET_DETECTOR_INDEX: 'GET_DETECTOR_INDEX', SET_DETECTOR_INDEX: 'SET_DETECTOR_INDEX', - GET_ENTITIES: 'GET_ENTITIES', SET_ENTITIES: 'SET_ENTITIES', - GET_FORECAST_ID: 'GET_FORECAST_ID', SET_FORECAST_ID: 'SET_FORECAST_ID', - GET_ZOOM: 'GET_ZOOM', SET_ZOOM: 'SET_ZOOM', UNSET_ZOOM: 'UNSET_ZOOM', }; diff --git a/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer_utils/timeseriesexplorer_utils.d.ts b/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer_utils/timeseriesexplorer_utils.d.ts index 1528ac887ad76..1b7a740d90dde 100644 --- a/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer_utils/timeseriesexplorer_utils.d.ts +++ b/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer_utils/timeseriesexplorer_utils.d.ts @@ -46,7 +46,7 @@ export function calculateDefaultFocusRange( export function calculateInitialFocusRange( zoomState: any, contextAggregationInterval: any, - timefilter: any + bounds: any ): any; export function getAutoZoomDuration(jobs: any, selectedJob: any): any; diff --git a/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer_utils/timeseriesexplorer_utils.js b/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer_utils/timeseriesexplorer_utils.js index 8e8b31ede86a8..b4706e6f609dc 100644 --- a/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer_utils/timeseriesexplorer_utils.js +++ b/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer_utils/timeseriesexplorer_utils.js @@ -340,14 +340,13 @@ export function calculateDefaultFocusRange( return [new Date(rangeEarliestMs), new Date(rangeLatestMs)]; } -export function calculateInitialFocusRange(zoomState, contextAggregationInterval, timefilter) { +export function calculateInitialFocusRange(zoomState, contextAggregationInterval, bounds) { if (zoomState !== undefined) { // Check that the zoom times are valid. // zoomFrom must be at or after context chart search bounds earliest, // zoomTo must be at or before context chart search bounds latest. const zoomFrom = moment(zoomState.from, 'YYYY-MM-DDTHH:mm:ss.SSSZ', true); const zoomTo = moment(zoomState.to, 'YYYY-MM-DDTHH:mm:ss.SSSZ', true); - const bounds = timefilter.getActiveBounds(); const searchBounds = getBoundsRoundedToInterval(bounds, contextAggregationInterval, true); const earliest = searchBounds.min; const latest = searchBounds.max; diff --git a/x-pack/legacy/plugins/ml/public/application/util/__snapshots__/observable_utils.test.tsx.snap b/x-pack/legacy/plugins/ml/public/application/util/__snapshots__/observable_utils.test.tsx.snap deleted file mode 100644 index b93a4702b7c3d..0000000000000 --- a/x-pack/legacy/plugins/ml/public/application/util/__snapshots__/observable_utils.test.tsx.snap +++ /dev/null @@ -1,13 +0,0 @@ -// Jest Snapshot v1, https://goo.gl/fbAQLP - -exports[`observable_utils injectObservablesAsProps() 1`] = ` - -`; - -exports[`observable_utils injectObservablesAsProps() 2`] = ` - -`; diff --git a/x-pack/legacy/plugins/ml/public/application/util/__tests__/app_state_utils.js b/x-pack/legacy/plugins/ml/public/application/util/__tests__/app_state_utils.js deleted file mode 100644 index 2ab428f979f53..0000000000000 --- a/x-pack/legacy/plugins/ml/public/application/util/__tests__/app_state_utils.js +++ /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; - * you may not use this file except in compliance with the Elastic License. - */ - -import expect from '@kbn/expect'; -import ngMock from 'ng_mock'; - -import { BehaviorSubject } from 'rxjs'; - -import { initializeAppState, subscribeAppStateToObservable } from '../app_state_utils'; - -describe('ML - initializeAppState', () => { - let AppState; - - beforeEach( - ngMock.module('kibana', stateManagementConfigProvider => { - stateManagementConfigProvider.enable(); - }) - ); - - beforeEach( - ngMock.inject($injector => { - AppState = $injector.get('AppState'); - }) - ); - - it('Throws an error when called without arguments.', () => { - expect(() => initializeAppState()).to.throwError(); - }); - - it('Initializes an appstate, gets a test value.', () => { - const appState = initializeAppState(AppState, 'mlTest', { value: 10 }); - expect(appState.mlTest.value).to.be(10); - }); -}); - -describe('ML - subscribeAppStateToObservable', () => { - let AppState; - let $rootScope; - - beforeEach( - ngMock.module('kibana', stateManagementConfigProvider => { - stateManagementConfigProvider.enable(); - }) - ); - - beforeEach( - ngMock.inject($injector => { - AppState = $injector.get('AppState'); - $rootScope = $injector.get('$rootScope'); - }) - ); - - it('Initializes a custom state store, sets and gets a test value using events.', done => { - const o$ = new BehaviorSubject({ value: 10 }); - - subscribeAppStateToObservable(AppState, 'mlTest', o$, () => $rootScope.$applyAsync()); - - o$.subscribe(payload => { - const appState = new AppState(); - appState.fetch(); - - expect(payload.value).to.be(10); - expect(appState.mlTest.value).to.be(10); - - done(); - }); - }); -}); diff --git a/x-pack/legacy/plugins/ml/public/application/util/app_state_utils.d.ts b/x-pack/legacy/plugins/ml/public/application/util/app_state_utils.d.ts deleted file mode 100644 index 454ea55210dcc..0000000000000 --- a/x-pack/legacy/plugins/ml/public/application/util/app_state_utils.d.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; - * you may not use this file except in compliance with the Elastic License. - */ - -import { Observable } from 'rxjs'; - -export const initializeAppState: (AppState: any, stateName: any, defaultState: any) => any; - -export const subscribeAppStateToObservable: ( - AppState: any, - appStateName: string, - o$: Observable, - callback: (payload: any) => void -) => any; diff --git a/x-pack/legacy/plugins/ml/public/application/util/app_state_utils.js b/x-pack/legacy/plugins/ml/public/application/util/app_state_utils.js deleted file mode 100644 index 2875a6fa3ce19..0000000000000 --- a/x-pack/legacy/plugins/ml/public/application/util/app_state_utils.js +++ /dev/null @@ -1,70 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -import { cloneDeep, isEqual } from 'lodash'; - -import { distinctUntilChanged } from 'rxjs/operators'; - -function hasEqualKeys(a, b) { - return isEqual(Object.keys(a).sort(), Object.keys(b).sort()); -} - -export function initializeAppState(AppState, stateName, defaultState) { - const appState = new AppState(); - appState.fetch(); - - // Store the state to the AppState so that it's - // restored on page refresh. - if (appState[stateName] === undefined) { - appState[stateName] = cloneDeep(defaultState); - appState.save(); - } - - // if defaultState isn't defined or if defaultState matches the current value - // stored in the URL in appState then return appState as is. - if (defaultState === undefined || appState[stateName] === defaultState) { - return appState; - } - - // If defaultState is defined, check if the keys of the defaultState - // match the one from appState, if not, fall back to the defaultState. - // If we didn't do this, the structure of an out-of-date appState - // might break some follow up code. Note that this will not catch any - // deeper nested inconsistencies. this does two checks: - // - if defaultState is an object, check if current appState has the same keys. - // - if it's not an object, check if defaultState and current appState are of the same type. - if ( - (typeof defaultState === 'object' && !hasEqualKeys(defaultState, appState[stateName])) || - typeof defaultState !== typeof appState[stateName] - ) { - appState[stateName] = cloneDeep(defaultState); - appState.save(); - } - - return appState; -} - -// Some components like the show-chart-checkbox or severity/interval-dropdowns -// emit their state change to an observable. This utility function can be used -// to persist these state changes to AppState and save the state to the url. -// distinctUntilChanged() makes sure the callback is only triggered upon changes -// of the state and filters consecutive triggers of the same value. -export function subscribeAppStateToObservable(AppState, appStateName, o$, callback) { - const appState = initializeAppState(AppState, appStateName, o$.getValue()); - - o$.next(appState[appStateName]); - - const subscription = o$.pipe(distinctUntilChanged()).subscribe(payload => { - appState.fetch(); - appState[appStateName] = payload; - appState.save(); - if (typeof callback === 'function') { - callback(payload); - } - }); - - return subscription; -} diff --git a/x-pack/legacy/plugins/ml/public/application/util/observable_utils.test.tsx b/x-pack/legacy/plugins/ml/public/application/util/observable_utils.test.tsx deleted file mode 100644 index c95824fc5dc4d..0000000000000 --- a/x-pack/legacy/plugins/ml/public/application/util/observable_utils.test.tsx +++ /dev/null @@ -1,43 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -import { shallow } from 'enzyme'; -import React, { ComponentType } from 'react'; -import { BehaviorSubject } from 'rxjs'; - -import { injectObservablesAsProps } from './observable_utils'; - -interface Props { - testProp: string; -} - -describe('observable_utils', () => { - test('injectObservablesAsProps()', () => { - // an observable that allows us to trigger updating some text. - const observable$ = new BehaviorSubject('initial text'); - - // a simple stateless component that just renders some text - const TestComponent: React.FC = ({ testProp }) => { - return {testProp}; - }; - - // injectObservablesAsProps wraps the observable in a new component - const ObservableComponent = injectObservablesAsProps( - { testProp: observable$ }, - (TestComponent as any) as ComponentType - ); - - const wrapper = shallow(); - - // the component should render with "initial text" - expect(wrapper).toMatchSnapshot(); - - observable$.next('updated text'); - - // the component should render with "updated text" - expect(wrapper).toMatchSnapshot(); - }); -}); diff --git a/x-pack/legacy/plugins/ml/public/application/util/observable_utils.tsx b/x-pack/legacy/plugins/ml/public/application/util/observable_utils.tsx deleted file mode 100644 index 4b8027260ab9a..0000000000000 --- a/x-pack/legacy/plugins/ml/public/application/util/observable_utils.tsx +++ /dev/null @@ -1,67 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -import { isEqual } from 'lodash'; -import React, { Component, ComponentType } from 'react'; -import { BehaviorSubject, Subscription } from 'rxjs'; -import { distinctUntilChanged } from 'rxjs/operators'; -import { Dictionary } from '../../../common/types/common'; - -// Sets up a ObservableComponent which subscribes to given observable updates and -// and passes them on as prop values to the given WrappedComponent. -// This give us the benefit of abstracting away the need to set up subscribers and callbacks, -// and the passed down props can be used in pure/functional components without -// the need for their own state management. -export function injectObservablesAsProps( - observables: Dictionary>, - WrappedComponent: ComponentType -): ComponentType { - const observableKeys = Object.keys(observables); - - class ObservableComponent extends Component { - public state = observableKeys.reduce((reducedState: Dictionary, key: string) => { - reducedState[key] = observables[key].value; - return reducedState; - }, {}); - - public subscriptions = {} as Dictionary; - - public componentDidMount() { - observableKeys.forEach(k => { - this.subscriptions[k] = observables[k] - .pipe(distinctUntilChanged(isEqual)) - .subscribe(v => this.setState({ [k]: v })); - }); - } - - public componentWillUnmount() { - Object.keys(this.subscriptions).forEach((key: string) => - this.subscriptions[key].unsubscribe() - ); - } - - public render() { - // All injected observables are expected to provide initial state. - // If an observable has undefined as its current value, rendering - // the wrapped component will be skipped. - if ( - Object.keys(this.state) - .map(k => this.state[k]) - .some(v => v === undefined) - ) { - return null; - } - - return ( - - {this.props.children} - - ); - } - } - - return ObservableComponent as ComponentType; -} diff --git a/x-pack/legacy/plugins/ml/public/application/util/url_state.ts b/x-pack/legacy/plugins/ml/public/application/util/url_state.ts new file mode 100644 index 0000000000000..4402155815a5b --- /dev/null +++ b/x-pack/legacy/plugins/ml/public/application/util/url_state.ts @@ -0,0 +1,91 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { useCallback } from 'react'; +import { isEqual } from 'lodash'; +// @ts-ignore +import queryString from 'query-string'; +import { decode, encode } from 'rison-node'; +import { useHistory, useLocation } from 'react-router-dom'; + +import { Dictionary } from '../../../common/types/common'; + +import { getNestedProperty } from './object_utils'; + +export type SetUrlState = (attribute: string | Dictionary, value?: any) => void; +export type UrlState = [Dictionary, SetUrlState]; + +function getUrlState(search: string) { + const urlState: Dictionary = {}; + const parsedQueryString = queryString.parse(search); + + try { + Object.keys(parsedQueryString).forEach(a => { + urlState[a] = decode(parsedQueryString[a]) as Dictionary; + }); + } catch (error) { + // eslint-disable-next-line no-console + console.error('Could not read url state', error); + } + + return urlState; +} + +// Compared to the original appState/globalState, +// this no longer makes use of fetch/save methods. +// - Reading from `location.search` is the successor of `fetch`. +// - `history.push()` is the successor of `save`. +// - The exposed state and set call make use of the above and make sure that +// different urlStates(e.g. `_a` / `_g`) don't overwrite each other. +export const useUrlState = (accessor: string): UrlState => { + const history = useHistory(); + const { search } = useLocation(); + + const setUrlState = useCallback( + (attribute: string | Dictionary, value?: any) => { + const urlState = getUrlState(search); + const parsedQueryString = queryString.parse(search); + + if (!Object.prototype.hasOwnProperty.call(urlState, accessor)) { + urlState[accessor] = {}; + } + + if (typeof attribute === 'string') { + if (isEqual(getNestedProperty(urlState, `${accessor}.${attribute}`), value)) { + return; + } + + urlState[accessor][attribute] = value; + } else { + const attributes = attribute; + Object.keys(attributes).forEach(a => { + urlState[accessor][a] = attributes[a]; + }); + } + + try { + const oldLocationSearch = queryString.stringify(parsedQueryString, { encode: false }); + + Object.keys(urlState).forEach(a => { + parsedQueryString[a] = encode(urlState[a]); + }); + const newLocationSearch = queryString.stringify(parsedQueryString, { encode: false }); + + if (oldLocationSearch !== newLocationSearch) { + history.push({ + search: queryString.stringify(parsedQueryString), + }); + } + } catch (error) { + // eslint-disable-next-line no-console + console.error('Could not save url state', error); + } + }, + [search] + ); + + return [getUrlState(search)[accessor], setUrlState]; +}; diff --git a/x-pack/package.json b/x-pack/package.json index 1e20157831ba5..3f826030ac16b 100644 --- a/x-pack/package.json +++ b/x-pack/package.json @@ -42,6 +42,7 @@ "@storybook/react": "^5.2.6", "@storybook/theming": "^5.2.6", "@testing-library/react": "^9.3.2", + "@testing-library/react-hooks": "^3.2.1", "@testing-library/jest-dom": "4.2.0", "@types/angular": "^1.6.56", "@types/archiver": "^3.0.0", @@ -309,6 +310,7 @@ "react-shortcuts": "^2.0.0", "react-sticky": "^6.0.3", "react-syntax-highlighter": "^5.7.0", + "react-use": "^13.13.0", "react-vis": "^1.8.1", "react-visibility-sensor": "^5.1.1", "recompose": "^0.26.0", From e54a7175dacff31fd2fbf8522029af7fffa6f931 Mon Sep 17 00:00:00 2001 From: Gidi Meir Morris Date: Mon, 13 Jan 2020 17:15:08 +0000 Subject: [PATCH 032/139] pass previousStartedAt as Date into Alert executor (#54576) Corrects how we pass previousStartedAt into Alert executor --- .../server/task_runner/task_runner.test.ts | 16 +++++++++------- .../alerting/server/task_runner/task_runner.ts | 2 +- 2 files changed, 10 insertions(+), 8 deletions(-) diff --git a/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.test.ts b/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.test.ts index 87fa33a9cea58..e4d8c78d12265 100644 --- a/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.test.ts +++ b/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.test.ts @@ -38,9 +38,7 @@ describe('Task Runner', () => { scheduledAt: new Date(), startedAt: new Date(), retryAt: new Date(Date.now() + 5 * 60 * 1000), - state: { - startedAt: new Date(Date.now() - 5 * 60 * 1000), - }, + state: {}, taskType: 'alerting:test', params: { alertId: '1', @@ -110,7 +108,13 @@ describe('Task Runner', () => { test('successfully executes the task', async () => { const taskRunner = new TaskRunner( alertType, - mockedTaskInstance, + { + ...mockedTaskInstance, + state: { + ...mockedTaskInstance.state, + previousStartedAt: new Date(Date.now() - 5 * 60 * 1000).toISOString(), + }, + }, taskRunnerFactoryInitializerParams ); savedObjectsClient.get.mockResolvedValueOnce(mockedAlertTypeSavedObject); @@ -141,6 +145,7 @@ describe('Task Runner', () => { } `); expect(call.startedAt).toMatchInlineSnapshot(`1970-01-01T00:00:00.000Z`); + expect(call.previousStartedAt).toMatchInlineSnapshot(`1969-12-31T23:55:00.000Z`); expect(call.state).toMatchInlineSnapshot(`Object {}`); expect(call.name).toBe('alert-name'); expect(call.tags).toEqual(['alert-', '-tags']); @@ -261,7 +266,6 @@ describe('Task Runner', () => { "runAt": 1970-01-01T00:00:10.000Z, "state": Object { "previousStartedAt": 1970-01-01T00:00:00.000Z, - "startedAt": 1969-12-31T23:55:00.000Z, }, } `); @@ -293,7 +297,6 @@ describe('Task Runner', () => { "runAt": 1970-01-01T00:00:10.000Z, "state": Object { "previousStartedAt": 1970-01-01T00:00:00.000Z, - "startedAt": 1969-12-31T23:55:00.000Z, }, } `); @@ -400,7 +403,6 @@ describe('Task Runner', () => { "runAt": 1970-01-01T00:00:10.000Z, "state": Object { "previousStartedAt": 1970-01-01T00:00:00.000Z, - "startedAt": 1969-12-31T23:55:00.000Z, }, } `); diff --git a/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.ts b/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.ts index 42c332e82e034..2589313acc76b 100644 --- a/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.ts +++ b/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.ts @@ -152,7 +152,7 @@ export class TaskRunner { params, state: alertTypeState, startedAt: this.taskInstance.startedAt!, - previousStartedAt, + previousStartedAt: previousStartedAt && new Date(previousStartedAt), spaceId, namespace, name, From 71dfdea7ae757010547db95cbca935511edbdbfa Mon Sep 17 00:00:00 2001 From: Poff Poffenberger Date: Mon, 13 Jan 2020 17:16:12 +0000 Subject: [PATCH 033/139] [Canvas] Fix expression updating bug (#54297) * Fix expression updating bug * Add functional test for expression editor * Add page object helper to open expression editor Co-authored-by: Elastic Machine --- .../public/components/expression/index.js | 11 +++ .../public/components/toolbar/toolbar.tsx | 3 +- .../test/functional/apps/canvas/expression.ts | 70 +++++++++++++++++++ x-pack/test/functional/apps/canvas/index.js | 1 + .../functional/page_objects/canvas_page.ts | 4 ++ 5 files changed, 88 insertions(+), 1 deletion(-) create mode 100644 x-pack/test/functional/apps/canvas/expression.ts diff --git a/x-pack/legacy/plugins/canvas/public/components/expression/index.js b/x-pack/legacy/plugins/canvas/public/components/expression/index.js index 806ef388bc4f6..d6eefca4e1461 100644 --- a/x-pack/legacy/plugins/canvas/public/components/expression/index.js +++ b/x-pack/legacy/plugins/canvas/public/components/expression/index.js @@ -55,6 +55,17 @@ const mergeProps = (stateProps, dispatchProps, ownProps) => { }; const expressionLifecycle = lifecycle({ + componentDidUpdate({ expression }) { + if ( + this.props.expression !== expression && + this.props.expression !== this.props.formState.expression + ) { + this.props.setFormState({ + expression: this.props.expression, + dirty: false, + }); + } + }, componentDidMount() { const { functionDefinitionsPromise, setFunctionDefinitions } = this.props; functionDefinitionsPromise.then(defs => setFunctionDefinitions(defs)); diff --git a/x-pack/legacy/plugins/canvas/public/components/toolbar/toolbar.tsx b/x-pack/legacy/plugins/canvas/public/components/toolbar/toolbar.tsx index da3475eceb18d..089f021ccdc32 100644 --- a/x-pack/legacy/plugins/canvas/public/components/toolbar/toolbar.tsx +++ b/x-pack/legacy/plugins/canvas/public/components/toolbar/toolbar.tsx @@ -97,7 +97,7 @@ export const Toolbar = (props: Props) => { const trays = { pageManager: , - expression: !elementIsSelected ? null : , + expression: !elementIsSelected ? null : , }; return ( @@ -141,6 +141,7 @@ export const Toolbar = (props: Props) => { color="text" iconType="editorCodeBlock" onClick={() => showHideTray(TrayType.expression)} + data-test-subj="canvasExpressionEditorButton" > {strings.getEditorButtonLabel()} diff --git a/x-pack/test/functional/apps/canvas/expression.ts b/x-pack/test/functional/apps/canvas/expression.ts new file mode 100644 index 0000000000000..fc6b80468b9f2 --- /dev/null +++ b/x-pack/test/functional/apps/canvas/expression.ts @@ -0,0 +1,70 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import expect from '@kbn/expect'; + +import { FtrProviderContext } from '../../ftr_provider_context'; + +export default function canvasExpressionTest({ getService, getPageObjects }: FtrProviderContext) { + const esArchiver = getService('esArchiver'); + const testSubjects = getService('testSubjects'); + // const browser = getService('browser'); + const retry = getService('retry'); + const PageObjects = getPageObjects(['canvas', 'common']); + const find = getService('find'); + + describe('expression editor', function() { + // there is an issue with FF not properly clicking on workpad elements + this.tags('skipFirefox'); + + before(async () => { + // init data + await esArchiver.loadIfNeeded('logstash_functional'); + await esArchiver.load('canvas/default'); + + // load test workpad + await PageObjects.common.navigateToApp('canvas', { + hash: '/workpad/workpad-1705f884-6224-47de-ba49-ca224fe6ec31/page/1', + }); + }); + + it('updates when element is changed via side bar', async () => { + // wait for all our elements to load up + await retry.try(async () => { + const elements = await testSubjects.findAll( + 'canvasWorkpadPage > canvasWorkpadPageElementContent' + ); + expect(elements).to.have.length(4); + }); + + // find the first workpad element (a markdown element) and click it to select it + await testSubjects.click('canvasWorkpadPage > canvasWorkpadPageElementContent', 20000); + + // open the expression editor + await PageObjects.canvas.openExpressionEditor(); + + // select markdown content and clear it + const mdBox = await find.byCssSelector('.canvasSidebar__panel .canvasTextArea__code'); + const oldMd = await mdBox.getVisibleText(); + await mdBox.clearValueWithKeyboard(); + + // type the new text + const newMd = `${oldMd} and this is a test`; + await mdBox.type(newMd); + await find.clickByCssSelector('.canvasArg--controls .euiButton'); + + // make sure the open expression editor also has the changes + const editor = await find.byCssSelector('.monaco-editor .view-lines'); + const editorText = await editor.getVisibleText(); + expect(editorText).to.contain('Orange: Timelion, Server function and this is a test'); + + // reset the markdown + await mdBox.clearValueWithKeyboard(); + await mdBox.type(oldMd); + await find.clickByCssSelector('.canvasArg--controls .euiButton'); + }); + }); +} diff --git a/x-pack/test/functional/apps/canvas/index.js b/x-pack/test/functional/apps/canvas/index.js index bc33161cc4e97..fa4e362b6bc59 100644 --- a/x-pack/test/functional/apps/canvas/index.js +++ b/x-pack/test/functional/apps/canvas/index.js @@ -8,6 +8,7 @@ export default function canvasApp({ loadTestFile }) { describe('Canvas app', function canvasAppTestSuite() { this.tags('ciGroup2'); // CI requires tags ヽ(゜Q。)ノ? loadTestFile(require.resolve('./smoke_test')); + loadTestFile(require.resolve('./expression')); loadTestFile(require.resolve('./feature_controls/canvas_security')); loadTestFile(require.resolve('./feature_controls/canvas_spaces')); }); diff --git a/x-pack/test/functional/page_objects/canvas_page.ts b/x-pack/test/functional/page_objects/canvas_page.ts index a4b4f500b8832..fa117dbea393d 100644 --- a/x-pack/test/functional/page_objects/canvas_page.ts +++ b/x-pack/test/functional/page_objects/canvas_page.ts @@ -23,6 +23,10 @@ export function CanvasPageProvider({ getService }: FtrProviderContext) { await browser.pressKeys(browser.keys.ESCAPE); }, + async openExpressionEditor() { + await testSubjects.click('canvasExpressionEditorButton'); + }, + async waitForWorkpadElements() { await testSubjects.findAll('canvasWorkpadPage > canvasWorkpadPageElementContent'); }, From e8b2b28aef1b1591ec850b090996da25d91818e5 Mon Sep 17 00:00:00 2001 From: Gidi Meir Morris Date: Mon, 13 Jan 2020 17:16:25 +0000 Subject: [PATCH 034/139] [alerting] gracefully handle error in initialization of Alert TaskRunner (#54335) Prevents an edge cases where Alerts can end up in a zombie state. 1. Decrypting attributes throws an error 2. Fetching an Api Key throws an error 3. Getting Services with user permissions throws an error --- .../alerting/server/lib/result_type.ts | 8 ++ .../server/task_runner/task_runner.test.ts | 93 +++++++++++++++++++ .../server/task_runner/task_runner.ts | 75 ++++++++++++--- 3 files changed, 162 insertions(+), 14 deletions(-) diff --git a/x-pack/legacy/plugins/alerting/server/lib/result_type.ts b/x-pack/legacy/plugins/alerting/server/lib/result_type.ts index 644ae51292249..52843f6362303 100644 --- a/x-pack/legacy/plugins/alerting/server/lib/result_type.ts +++ b/x-pack/legacy/plugins/alerting/server/lib/result_type.ts @@ -15,6 +15,10 @@ export interface Err { } export type Result = Ok | Err; +export type Resultable = { + [P in keyof T]: Result; +}; + export function asOk(value: T): Ok { return { tag: 'ok', @@ -52,3 +56,7 @@ export function map( ): Resolution { return isOk(result) ? onOk(result.value) : onErr(result.error); } + +export function resolveErr(result: Result, onErr: (error: E) => T): T { + return isOk(result) ? result.value : onErr(result.error); +} diff --git a/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.test.ts b/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.test.ts index e4d8c78d12265..dc220067bd35a 100644 --- a/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.test.ts +++ b/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.test.ts @@ -407,4 +407,97 @@ describe('Task Runner', () => { } `); }); + + test('recovers gracefully when the Alert Task Runner throws an exception when fetching the encrypted attributes', async () => { + encryptedSavedObjectsPlugin.getDecryptedAsInternalUser.mockImplementation(() => { + throw new Error('OMG'); + }); + + const taskRunner = new TaskRunner( + alertType, + mockedTaskInstance, + taskRunnerFactoryInitializerParams + ); + + savedObjectsClient.get.mockResolvedValueOnce(mockedAlertTypeSavedObject); + + const runnerResult = await taskRunner.run(); + + expect(runnerResult).toMatchInlineSnapshot(` + Object { + "runAt": 1970-01-01T00:05:00.000Z, + "state": Object { + "previousStartedAt": 1970-01-01T00:00:00.000Z, + "startedAt": 1969-12-31T23:55:00.000Z, + }, + } + `); + }); + + test('recovers gracefully when the Alert Task Runner throws an exception when getting internal Services', async () => { + taskRunnerFactoryInitializerParams.getServices.mockImplementation(() => { + throw new Error('OMG'); + }); + + const taskRunner = new TaskRunner( + alertType, + mockedTaskInstance, + taskRunnerFactoryInitializerParams + ); + + savedObjectsClient.get.mockResolvedValueOnce(mockedAlertTypeSavedObject); + encryptedSavedObjectsPlugin.getDecryptedAsInternalUser.mockResolvedValueOnce({ + id: '1', + type: 'alert', + attributes: { + apiKey: Buffer.from('123:abc').toString('base64'), + }, + references: [], + }); + + const runnerResult = await taskRunner.run(); + + expect(runnerResult).toMatchInlineSnapshot(` + Object { + "runAt": 1970-01-01T00:05:00.000Z, + "state": Object { + "previousStartedAt": 1970-01-01T00:00:00.000Z, + "startedAt": 1969-12-31T23:55:00.000Z, + }, + } + `); + }); + + test('recovers gracefully when the Alert Task Runner throws an exception when fetching attributes', async () => { + savedObjectsClient.get.mockImplementation(() => { + throw new Error('OMG'); + }); + + const taskRunner = new TaskRunner( + alertType, + mockedTaskInstance, + taskRunnerFactoryInitializerParams + ); + + encryptedSavedObjectsPlugin.getDecryptedAsInternalUser.mockResolvedValueOnce({ + id: '1', + type: 'alert', + attributes: { + apiKey: Buffer.from('123:abc').toString('base64'), + }, + references: [], + }); + + const runnerResult = await taskRunner.run(); + + expect(runnerResult).toMatchInlineSnapshot(` + Object { + "runAt": 1970-01-01T00:05:00.000Z, + "state": Object { + "previousStartedAt": 1970-01-01T00:00:00.000Z, + "startedAt": 1969-12-31T23:55:00.000Z, + }, + } + `); + }); }); diff --git a/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.ts b/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.ts index 2589313acc76b..c6f1a02da8dcd 100644 --- a/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.ts +++ b/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.ts @@ -14,10 +14,17 @@ import { AlertInstance, createAlertInstanceFactory } from '../alert_instance'; import { getNextRunAt } from './get_next_run_at'; import { validateAlertTypeParams } from '../lib'; import { AlertType, RawAlert, IntervalSchedule, Services, State, AlertInfoParams } from '../types'; -import { promiseResult, map } from '../lib/result_type'; +import { promiseResult, map, Resultable, asOk, asErr, resolveErr } from '../lib/result_type'; type AlertInstances = Record; +const FALLBACK_RETRY_INTERVAL: IntervalSchedule = { interval: '5m' }; + +interface AlertTaskRunResult { + state: State; + runAt: Date; +} + export class TaskRunner { private context: TaskRunnerContext; private logger: Logger; @@ -190,7 +197,7 @@ export class TaskRunner { }; } - async validateAndRunAlert( + async validateAndExecuteAlert( services: Services, apiKey: string | null, attributes: RawAlert, @@ -217,11 +224,9 @@ export class TaskRunner { ); } - async run() { + async loadAlertAttributesAndRun(): Promise> { const { params: { alertId, spaceId }, - startedAt: previousStartedAt, - state: originalState, } = this.taskInstance; const apiKey = await this.getApiKeyForAlertPermissions(alertId, spaceId); @@ -233,11 +238,34 @@ export class TaskRunner { alertId ); + return { + state: await promiseResult( + this.validateAndExecuteAlert(services, apiKey, attributes, references) + ), + runAt: asOk( + getNextRunAt( + new Date(this.taskInstance.startedAt!), + // we do not currently have a good way of returning the type + // from SavedObjectsClient, and as we currenrtly require a schedule + // and we only support `interval`, we can cast this safely + attributes.schedule as IntervalSchedule + ) + ), + }; + } + + async run(): Promise { + const { + params: { alertId }, + startedAt: previousStartedAt, + state: originalState, + } = this.taskInstance; + + const { state, runAt } = await errorAsAlertTaskRunResult(this.loadAlertAttributesAndRun()); + return { state: map( - await promiseResult( - this.validateAndRunAlert(services, apiKey, attributes, references) - ), + state, (stateUpdates: State) => { return { ...stateUpdates, @@ -252,13 +280,32 @@ export class TaskRunner { }; } ), - runAt: getNextRunAt( - new Date(this.taskInstance.startedAt!), - // we do not currently have a good way of returning the type - // from SavedObjectsClient, and as we currenrtly require a schedule - // and we only support `interval`, we can cast this safely - attributes.schedule as IntervalSchedule + runAt: resolveErr(runAt, () => + getNextRunAt( + new Date(), + // if we fail at this point we wish to recover but don't have access to the Alert's + // attributes, so we'll use a default interval to prevent the underlying task from + // falling into a failed state + FALLBACK_RETRY_INTERVAL + ) ), }; } } + +/** + * If an error is thrown, wrap it in an AlertTaskRunResult + * so that we can treat each field independantly + */ +async function errorAsAlertTaskRunResult( + future: Promise> +): Promise> { + try { + return await future; + } catch (e) { + return { + state: asErr(e), + runAt: asErr(e), + }; + } +} From 48b0b06acc43524ae71c6fb11e6b742d16d08577 Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Mon, 13 Jan 2020 12:27:28 -0500 Subject: [PATCH 035/139] start removing duplication --- .../maps/public/layers/styles/color_utils.js | 17 ++ .../components/color/color_map_select.js | 187 ++++++++++++++++++ .../components/color/color_palette_select.js | 130 ------------ .../components/color/color_ramp_select.js | 121 ------------ .../components/color/dynamic_color_form.js | 10 +- 5 files changed, 210 insertions(+), 255 deletions(-) create mode 100644 x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js delete mode 100644 x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_palette_select.js delete mode 100644 x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_ramp_select.js diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.js b/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.js index 1f4250d3331d8..857f7c2c67869 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.js @@ -130,3 +130,20 @@ export function getColorPalette(paletteId) { const palette = COLOR_PALETTES.find(palette => palette.id === paletteId); return palette ? palette.colors : null; } + +export const COLOR_PALETTES_INPUTS = COLOR_PALETTES.map(palette => { + const paletteDisplay = palette.colors.map(color => { + const style = { + backgroundColor: color, + width: '10%', + position: 'relative', + height: '100%', + display: 'inline-block', + }; + return
 
; + }); + return { + value: palette.id, + inputDisplay:
{paletteDisplay}
, + }; +}); diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js new file mode 100644 index 0000000000000..d714d84ba78ae --- /dev/null +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js @@ -0,0 +1,187 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React, { Component, Fragment } from 'react'; + +import { EuiSuperSelect, EuiSpacer } from '@elastic/eui'; +import { COLOR_GRADIENTS, COLOR_PALETTES_INPUTS } from '../../../color_utils'; +import { FormattedMessage } from '@kbn/i18n/react'; +import { ColorStopsOrdinal } from './color_stops_ordinal'; +import { COLOR_MAP_TYPE } from '../../../../../../common/constants'; +import { ColorStopsCategorical } from './color_stops_categorical'; + +const CUSTOM_COLOR_MAP = 'CUSTOM_COLOR_MAP'; + +export class ColorMapSelect extends Component { + state = {}; + + static getDerivedStateFromProps(nextProps, prevState) { + let newState = null; + if (nextProps.customColorRamp !== prevState.prevPropsCustomColorRamp) { + newState = { + ...{ + prevPropsCustomColorRamp: nextProps.customColorRamp, // reset tracker to latest value + customColorRamp: nextProps.customColorRamp, // reset customColorRamp to latest value + }, + }; + } + + if (nextProps.customColorPalette !== prevState.prevPropsCustomColorPalette) { + if (!newState) { + newState = {}; + } + newState = { + ...newState, + ...{ + prevPropsCustomColorPalette: nextProps.customColorPalette, // reset tracker to latest value + customColorPalette: nextProps.customColorPalette, // reset customColorRamp to latest value + }, + }; + } + + return newState; + } + + _onColorMapSelect = selectedValue => { + const useCustomColorMap = selectedValue === CUSTOM_COLOR_MAP; + const newProps = {}; + if (this.props.colorMapType === COLOR_MAP_TYPE.ORDINAL) { + newProps.useCustomColorRamp = useCustomColorMap; + } else if (this.props.colorMapType === COLOR_MAP_TYPE.CATEGORICAL) { + newProps.useCustomColorPalette = useCustomColorMap; + } + newProps.color = useCustomColorMap ? null : selectedValue; + + this.props.onChange({ + ...newProps, + type: this.props.colorMapType, + }); + }; + + _onCustomColorMapChange = ({ colorStops, isInvalid }) => { + // Manage invalid custom color ramp in local state + if (isInvalid) { + const newState = {}; + if (this.props.colorMapType === COLOR_MAP_TYPE.ORDINAL) { + newState.customColorRamp = colorStops; + } else if (this.props.colorMapType === COLOR_MAP_TYPE.CATEGORICAL) { + newState.customColorPalette = colorStops; + } + this.setState(newState); + return; + } + + const newProps = {}; + if (this.props.colorMapType === COLOR_MAP_TYPE.ORDINAL) { + newProps.useCustomColorRamp = true; + newProps.customColorRamp = colorStops; + } else if (this.props.colorMapType === COLOR_MAP_TYPE.CATEGORICAL) { + newProps.useCustomColorPalette = true; + newProps.customColorPalette = colorStops; + } + newProps.type = this.props.colorMapType; + this.props.onChange(newProps); + }; + + render() { + const { color, useCustomColorRamp, useCustomColorPalette } = this.props; + + let colorStopsInput; + if (this.props.colorMapType === COLOR_MAP_TYPE.ORDINAL) { + if (useCustomColorRamp) { + colorStopsInput = ( + + + + + ); + } + } else if (this.props.colorMapType === COLOR_MAP_TYPE.CATEGORICAL) { + if (useCustomColorPalette) { + colorStopsInput = ( + + + + + ); + } + } + + let colorMapOptions; + let valueOfSelected; + if (this.props.colorMapType === COLOR_MAP_TYPE.ORDINAL) { + colorMapOptions = [ + { + value: CUSTOM_COLOR_MAP, + inputDisplay: ( + + ), + }, + ...COLOR_GRADIENTS, + ]; + if (useCustomColorRamp) { + valueOfSelected = CUSTOM_COLOR_MAP; + } else { + if (colorMapOptions.find(option => option.value === color)) { + valueOfSelected = color; + } else { + valueOfSelected = COLOR_GRADIENTS[0].value; + this._onColorMapSelect(valueOfSelected); + } + } + } else if (this.props.colorMapType === COLOR_MAP_TYPE.CATEGORICAL) { + const customOption = { + value: CUSTOM_COLOR_MAP, + inputDisplay: ( + + ), + }; + + colorMapOptions = [customOption, ...COLOR_PALETTES_INPUTS]; + if (useCustomColorPalette) { + valueOfSelected = CUSTOM_COLOR_MAP; + } else { + if (colorMapOptions.find(option => option.value === color)) { + valueOfSelected = color; + } else { + valueOfSelected = COLOR_PALETTES_INPUTS[0].value; + this._onColorMapSelect(valueOfSelected); + } + } + } + + return ( + + + {colorStopsInput} + + ); + } +} + +// ColorRampSelect.propTypes = { +// color: PropTypes.string, +// onChange: PropTypes.func.isRequired, +// useCustomColorRamp: PropTypes.bool, +// customColorRamp: PropTypes.array, +// }; diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_palette_select.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_palette_select.js deleted file mode 100644 index 32b23409a3865..0000000000000 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_palette_select.js +++ /dev/null @@ -1,130 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -import React, { Component, Fragment } from 'react'; -import PropTypes from 'prop-types'; - -import { EuiSuperSelect, EuiSpacer } from '@elastic/eui'; -import { FormattedMessage } from '@kbn/i18n/react'; -import { ColorStopsCategorical } from './color_stops_categorical'; -import { COLOR_PALETTES } from '../../../color_utils'; -import { COLOR_MAP_TYPE } from '../../../../../../common/constants'; - -const CUSTOM_COLOR_PALETTE = 'CUSTOM_COLOR_PALETTE'; -const CUSTOM_OPTION = { - value: CUSTOM_COLOR_PALETTE, - inputDisplay: ( - - ), -}; - -const colorPaletteInputs = COLOR_PALETTES.map(palette => { - const paletteDisplay = palette.colors.map(color => { - const style = { - backgroundColor: color, - width: '10%', - position: 'relative', - height: '100%', - display: 'inline-block', - }; - return
 
; - }); - return { - value: palette.id, - inputDisplay:
{paletteDisplay}
, - }; -}); - -export class ColorPaletteSelect extends Component { - state = {}; - - static getDerivedStateFromProps(nextProps, prevState) { - if (nextProps.customColorPalette !== prevState.prevPropsCustomColorPalette) { - return { - prevPropsCustomColorPalette: nextProps.customColorPalette, // reset tracker to latest value - customColorPalette: nextProps.customColorPalette, // reset customColorPalette to latest value - }; - } - - return null; - } - - _onColorPaletteSelect = selectedValue => { - const useCustomColorPalette = selectedValue === CUSTOM_COLOR_PALETTE; - this.props.onChange({ - type: COLOR_MAP_TYPE.CATEGORICAL, - color: useCustomColorPalette ? null : selectedValue, - useCustomColorPalette, - }); - }; - - _onCustomColorPaletteChange = ({ colorStops }) => { - this.props.onChange({ - type: COLOR_MAP_TYPE.CATEGORICAL, - customColorPalette: colorStops, - useCustomColorPalette: true, - }); - }; - - render() { - const { - color, - onChange, // eslint-disable-line no-unused-vars - useCustomColorPalette, - customColorPalette, // eslint-disable-line no-unused-vars - ...rest - } = this.props; - - let colorStopsInput; - if (useCustomColorPalette) { - colorStopsInput = ( - - - - - ); - } - - const colorPaletteOptions = [CUSTOM_OPTION, ...colorPaletteInputs]; - let valueOfSelected; - if (useCustomColorPalette) { - valueOfSelected = CUSTOM_COLOR_PALETTE; - } else { - if (colorPaletteOptions.find(option => option.value === color)) { - valueOfSelected = color; - } else { - valueOfSelected = colorPaletteInputs[0].value; - this._onColorPaletteSelect(valueOfSelected); - } - } - - return ( - - - {colorStopsInput} - - ); - } -} - -ColorPaletteSelect.propTypes = { - color: PropTypes.string, - onChange: PropTypes.func.isRequired, - useCustomColorPalette: PropTypes.bool, - customColorPalette: PropTypes.array, -}; diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_ramp_select.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_ramp_select.js deleted file mode 100644 index 29f954b56f061..0000000000000 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_ramp_select.js +++ /dev/null @@ -1,121 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -import React, { Component, Fragment } from 'react'; -import PropTypes from 'prop-types'; - -import { EuiSuperSelect, EuiSpacer } from '@elastic/eui'; -import { COLOR_GRADIENTS } from '../../../color_utils'; -import { FormattedMessage } from '@kbn/i18n/react'; -import { ColorStopsOrdinal } from './color_stops_ordinal'; -import { COLOR_MAP_TYPE } from '../../../../../../common/constants'; - -const CUSTOM_COLOR_RAMP = 'CUSTOM_COLOR_RAMP'; - -export class ColorRampSelect extends Component { - state = {}; - - static getDerivedStateFromProps(nextProps, prevState) { - if (nextProps.customColorRamp !== prevState.prevPropsCustomColorRamp) { - return { - prevPropsCustomColorRamp: nextProps.customColorRamp, // reset tracker to latest value - customColorRamp: nextProps.customColorRamp, // reset customColorRamp to latest value - }; - } - - return null; - } - - _onColorRampSelect = selectedValue => { - const useCustomColorRamp = selectedValue === CUSTOM_COLOR_RAMP; - this.props.onChange({ - color: useCustomColorRamp ? null : selectedValue, - useCustomColorRamp, - type: COLOR_MAP_TYPE.ORDINAL, - }); - }; - - _onCustomColorRampChange = ({ colorStops, isInvalid }) => { - // Manage invalid custom color ramp in local state - if (isInvalid) { - this.setState({ customColorRamp: colorStops }); - return; - } - - this.props.onChange({ - customColorRamp: colorStops, - type: COLOR_MAP_TYPE.ORDINAL, - useCustomColorRamp: true, - }); - }; - - render() { - const { - color, - onChange, // eslint-disable-line no-unused-vars - useCustomColorRamp, - customColorRamp, // eslint-disable-line no-unused-vars - ...rest - } = this.props; - - let colorStopsInput; - if (useCustomColorRamp) { - colorStopsInput = ( - - - - - ); - } - - const colorRampOptions = [ - { - value: CUSTOM_COLOR_RAMP, - inputDisplay: ( - - ), - }, - ...COLOR_GRADIENTS, - ]; - let valueOfSelected; - if (useCustomColorRamp) { - valueOfSelected = CUSTOM_COLOR_RAMP; - } else { - if (colorRampOptions.find(option => option.value === color)) { - valueOfSelected = color; - } else { - valueOfSelected = COLOR_GRADIENTS[0].value; - this._onColorRampSelect(valueOfSelected); - } - } - - return ( - - - {colorStopsInput} - - ); - } -} - -ColorRampSelect.propTypes = { - color: PropTypes.string, - onChange: PropTypes.func.isRequired, - useCustomColorRamp: PropTypes.bool, - customColorRamp: PropTypes.array, -}; diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js index 208adfa36bddb..170b97ff0e5ba 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js @@ -7,8 +7,7 @@ import _ from 'lodash'; import React, { Fragment } from 'react'; import { FieldSelect } from '../field_select'; -import { ColorRampSelect } from './color_ramp_select'; -import { ColorPaletteSelect } from './color_palette_select'; +import { ColorMapSelect } from './color_map_select'; import { EuiFlexGroup, EuiFlexItem, EuiSpacer } from '@elastic/eui'; import { CATEGORICAL_DATA_TYPES, COLOR_MAP_TYPE } from '../../../../../../common/constants'; import { OrdinalFieldMetaOptionsPopover } from '../ordinal_field_meta_options_popover'; @@ -84,10 +83,12 @@ export class DynamicColorForm extends React.Component { }; onDynamicStyleChange(styleProperty.getStyleName(), newOptions); }; + if (this.state.colorMapType === COLOR_MAP_TYPE.ORDINAL) { colorSelect = ( - onColorChange(options)} + colorMapType={COLOR_MAP_TYPE.ORDINAL} color={styleOptions.color} customColorRamp={styleOptions.customColorRamp} useCustomColorRamp={_.get(styleOptions, 'useCustomColorRamp', false)} @@ -96,8 +97,9 @@ export class DynamicColorForm extends React.Component { ); } else if (this.state.colorMapType === COLOR_MAP_TYPE.CATEGORICAL) { colorSelect = ( - onColorChange(options)} + colorMapType={COLOR_MAP_TYPE.CATEGORICAL} color={styleOptions.color} customColorPalette={styleOptions.customColorPalette} useCustomColorPalette={_.get(styleOptions, 'useCustomColorPalette', false)} From 7543b0c7b2ddb074cc75b0f0f0c9dc5f400609ce Mon Sep 17 00:00:00 2001 From: Maja Grubic Date: Mon, 13 Jan 2020 17:38:47 +0000 Subject: [PATCH 036/139] [Lens][Dashboard] Adding Lens to Dashboard (#53110) * First version of adding Lens to dashboard * Fix failing unit test * Replacing explicit Lens query param with a more generic one * Fixing failing unit test * Adding a unit test for redirect * Do not show Save New if adding from Dashboard * Adding functional test * Adding functional test * Fixing type issues * Renaming query params * Fixing failing unit test * Removing unused constants * Fixing erroneous imports * Fixing erroneous import * Fixing import * Fix failing typecheck * Removing timefilter from Dashboard URL * Fixing type error * Replacing time parsing with rison * Replacing URL regex parsing with legacy URLs * Fixing failing test Co-authored-by: Elastic Machine --- .../dashboard/__tests__/url_helper.test.ts | 117 ++++++++++++++++++ .../kibana/public/dashboard/legacy_imports.ts | 1 + .../np_ready/dashboard_app_controller.tsx | 14 +-- .../dashboard/np_ready/dashboard_constants.ts | 3 +- .../public/dashboard/np_ready/url_helper.ts | 102 +++++++++++++++ .../visualize/np_ready/editor/editor.js | 8 +- .../np_ready/wizard/new_vis_modal.test.tsx | 4 +- .../np_ready/wizard/new_vis_modal.tsx | 7 +- .../functional/page_objects/visualize_page.ts | 4 + .../lens/public/app_plugin/app.test.tsx | 25 ++++ .../plugins/lens/public/app_plugin/app.tsx | 18 ++- .../plugins/lens/public/app_plugin/plugin.tsx | 76 ++++++++++-- .../dashboard_mode/dashboard_empty_screen.js | 68 ++++++++++ .../functional/apps/dashboard_mode/index.js | 1 + 14 files changed, 420 insertions(+), 28 deletions(-) create mode 100644 src/legacy/core_plugins/kibana/public/dashboard/__tests__/url_helper.test.ts create mode 100644 src/legacy/core_plugins/kibana/public/dashboard/np_ready/url_helper.ts create mode 100644 x-pack/test/functional/apps/dashboard_mode/dashboard_empty_screen.js diff --git a/src/legacy/core_plugins/kibana/public/dashboard/__tests__/url_helper.test.ts b/src/legacy/core_plugins/kibana/public/dashboard/__tests__/url_helper.test.ts new file mode 100644 index 0000000000000..16773c02f5a7b --- /dev/null +++ b/src/legacy/core_plugins/kibana/public/dashboard/__tests__/url_helper.test.ts @@ -0,0 +1,117 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +jest.mock('../', () => ({ + DashboardConstants: { + ADD_EMBEDDABLE_ID: 'addEmbeddableId', + ADD_EMBEDDABLE_TYPE: 'addEmbeddableType', + }, +})); + +jest.mock('../legacy_imports', () => { + return { + absoluteToParsedUrl: jest.fn(() => { + return { + basePath: '/pep', + appId: 'kibana', + appPath: '/dashboard?addEmbeddableType=lens&addEmbeddableId=123eb456cd&x=1&y=2&z=3', + hostname: 'localhost', + port: 5601, + protocol: 'http:', + addQueryParameter: () => {}, + getAbsoluteUrl: () => { + return 'http://localhost:5601/pep/app/kibana#/dashboard?addEmbeddableType=lens&addEmbeddableId=123eb456cd&x=1&y=2&z=3'; + }, + }; + }), + }; +}); + +import { + addEmbeddableToDashboardUrl, + getLensUrlFromDashboardAbsoluteUrl, + getUrlVars, +} from '../np_ready/url_helper'; + +describe('Dashboard URL Helper', () => { + beforeEach(() => { + jest.resetModules(); + }); + + it('addEmbeddableToDashboardUrl', () => { + const id = '123eb456cd'; + const type = 'lens'; + const urlVars = { + x: '1', + y: '2', + z: '3', + }; + const basePath = '/pep'; + const url = + "http://localhost:5601/pep/app/kibana#/dashboard?_g=(refreshInterval:(pause:!t,value:0),time:(from:now-15m,to:now))&_a=(description:'',filters:!()"; + expect(addEmbeddableToDashboardUrl(url, basePath, id, urlVars, type)).toEqual( + `http://localhost:5601/pep/app/kibana#/dashboard?addEmbeddableType=${type}&addEmbeddableId=${id}&x=1&y=2&z=3` + ); + }); + + it('getUrlVars', () => { + let url = + "http://localhost:5601/app/kibana#/dashboard?_g=(refreshInterval:(pause:!t,value:0),time:(from:now-15m,to:now))&_a=(description:'',filters:!()"; + expect(getUrlVars(url)).toEqual({ + _g: '(refreshInterval:(pause:!t,value:0),time:(from:now-15m,to:now))', + _a: "(description:'',filters:!()", + }); + url = 'http://mybusiness.mydomain.com/app/kibana#/dashboard?x=y&y=z'; + expect(getUrlVars(url)).toEqual({ + x: 'y', + y: 'z', + }); + url = 'http://notDashboardUrl'; + expect(getUrlVars(url)).toEqual({}); + url = 'http://localhost:5601/app/kibana#/dashboard/777182'; + expect(getUrlVars(url)).toEqual({}); + }); + + it('getLensUrlFromDashboardAbsoluteUrl', () => { + const id = '1244'; + const basePath = '/wev'; + let url = + "http://localhost:5601/wev/app/kibana#/dashboard?_g=(refreshInterval:(pause:!t,value:0),time:(from:now-15m,to:now))&_a=(description:'',filters:!()"; + expect(getLensUrlFromDashboardAbsoluteUrl(url, basePath, id)).toEqual( + 'http://localhost:5601/wev/app/kibana#/lens/edit/1244' + ); + + url = + "http://localhost:5601/wev/app/kibana#/dashboard/625357282?_a=(description:'',filters:!()&_g=(refreshInterval:(pause:!t,value:0),time:(from:now-15m,to:now))"; + expect(getLensUrlFromDashboardAbsoluteUrl(url, basePath, id)).toEqual( + 'http://localhost:5601/wev/app/kibana#/lens/edit/1244' + ); + + url = 'http://myserver.mydomain.com:5601/wev/app/kibana#/dashboard/777182'; + expect(getLensUrlFromDashboardAbsoluteUrl(url, basePath, id)).toEqual( + 'http://myserver.mydomain.com:5601/wev/app/kibana#/lens/edit/1244' + ); + + url = + "http://localhost:5601/app/kibana#/dashboard?_g=(refreshInterval:(pause:!t,value:0),time:(from:now-15m,to:now))&_a=(description:'',filters:!()"; + expect(getLensUrlFromDashboardAbsoluteUrl(url, '', id)).toEqual( + 'http://localhost:5601/app/kibana#/lens/edit/1244' + ); + }); +}); diff --git a/src/legacy/core_plugins/kibana/public/dashboard/legacy_imports.ts b/src/legacy/core_plugins/kibana/public/dashboard/legacy_imports.ts index ec0913e5fb3e7..ba01919431080 100644 --- a/src/legacy/core_plugins/kibana/public/dashboard/legacy_imports.ts +++ b/src/legacy/core_plugins/kibana/public/dashboard/legacy_imports.ts @@ -67,3 +67,4 @@ export { IInjector } from 'ui/chrome'; export { SavedObjectLoader } from 'ui/saved_objects'; export { VISUALIZE_EMBEDDABLE_TYPE } from '../visualize_embeddable'; export { registerTimefilterWithGlobalStateFactory } from 'ui/timefilter/setup_router'; +export { absoluteToParsedUrl } from 'ui/url/absolute_to_parsed_url'; diff --git a/src/legacy/core_plugins/kibana/public/dashboard/np_ready/dashboard_app_controller.tsx b/src/legacy/core_plugins/kibana/public/dashboard/np_ready/dashboard_app_controller.tsx index 2523d1e60a741..2706b588a2ec4 100644 --- a/src/legacy/core_plugins/kibana/public/dashboard/np_ready/dashboard_app_controller.tsx +++ b/src/legacy/core_plugins/kibana/public/dashboard/np_ready/dashboard_app_controller.tsx @@ -37,7 +37,6 @@ import { KbnUrl, SavedObjectSaveOpts, unhashUrl, - VISUALIZE_EMBEDDABLE_TYPE, } from '../legacy_imports'; import { FilterStateManager } from '../../../../data/public'; import { @@ -334,13 +333,12 @@ export class DashboardAppController { // This code needs to be replaced with a better mechanism for adding new embeddables of // any type from the add panel. Likely this will happen via creating a visualization "inline", // without navigating away from the UX. - if ($routeParams[DashboardConstants.NEW_VISUALIZATION_ID_PARAM]) { - container.addSavedObjectEmbeddable( - VISUALIZE_EMBEDDABLE_TYPE, - $routeParams[DashboardConstants.NEW_VISUALIZATION_ID_PARAM] - ); - kbnUrl.removeParam(DashboardConstants.ADD_VISUALIZATION_TO_DASHBOARD_MODE_PARAM); - kbnUrl.removeParam(DashboardConstants.NEW_VISUALIZATION_ID_PARAM); + if ($routeParams[DashboardConstants.ADD_EMBEDDABLE_TYPE]) { + const type = $routeParams[DashboardConstants.ADD_EMBEDDABLE_TYPE]; + const id = $routeParams[DashboardConstants.ADD_EMBEDDABLE_ID]; + container.addSavedObjectEmbeddable(type, id); + kbnUrl.removeParam(DashboardConstants.ADD_EMBEDDABLE_TYPE); + kbnUrl.removeParam(DashboardConstants.ADD_EMBEDDABLE_ID); } } diff --git a/src/legacy/core_plugins/kibana/public/dashboard/np_ready/dashboard_constants.ts b/src/legacy/core_plugins/kibana/public/dashboard/np_ready/dashboard_constants.ts index b76b3f309874a..fe42e07912799 100644 --- a/src/legacy/core_plugins/kibana/public/dashboard/np_ready/dashboard_constants.ts +++ b/src/legacy/core_plugins/kibana/public/dashboard/np_ready/dashboard_constants.ts @@ -19,9 +19,10 @@ export const DashboardConstants = { ADD_VISUALIZATION_TO_DASHBOARD_MODE_PARAM: 'addToDashboard', - NEW_VISUALIZATION_ID_PARAM: 'addVisualization', LANDING_PAGE_PATH: '/dashboards', CREATE_NEW_DASHBOARD_URL: '/dashboard', + ADD_EMBEDDABLE_ID: 'addEmbeddableId', + ADD_EMBEDDABLE_TYPE: 'addEmbeddableType', }; export function createDashboardEditUrl(id: string) { diff --git a/src/legacy/core_plugins/kibana/public/dashboard/np_ready/url_helper.ts b/src/legacy/core_plugins/kibana/public/dashboard/np_ready/url_helper.ts new file mode 100644 index 0000000000000..ee9e3c4ef4781 --- /dev/null +++ b/src/legacy/core_plugins/kibana/public/dashboard/np_ready/url_helper.ts @@ -0,0 +1,102 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ +import { parse } from 'url'; +import { absoluteToParsedUrl } from '../legacy_imports'; +import { DashboardConstants } from './dashboard_constants'; +/** + * Return query params from URL + * @param url given url + */ +export function getUrlVars(url: string): Record { + const vars: Record = {}; + // @ts-ignore + url.replace(/[?&]+([^=&]+)=([^&]*)/gi, function(_, key, value) { + // @ts-ignore + vars[key] = value; + }); + return vars; +} + +/** * + * Returns dashboard URL with added embeddableType and embeddableId query params + * eg. + * input: url: http://localhost:5601/lib/app/kibana#/dashboard?_g=(refreshInterval:(pause:!t,value:0),time:(from:now-15m,to:now)), embeddableId: 12345, embeddableType: 'lens' + * output: http://localhost:5601/lib/app/kibana#dashboard?addEmbeddableType=lens&addEmbeddableId=12345&_g=(refreshInterval:(pause:!t,value:0),time:(from:now-15m,to:now)) + * @param url dasbhoard absolute url + * @param embeddableId id of the saved visualization + * @param basePath current base path + * @param urlVars url query params (optional) + * @param embeddableType 'lens' or 'visualization' (optional, default is 'lens') + */ +export function addEmbeddableToDashboardUrl( + url: string | undefined, + basePath: string, + embeddableId: string, + urlVars?: Record, + embeddableType?: string +): string | null { + if (!url) { + return null; + } + const dashboardUrl = getUrlWithoutQueryParams(url); + const dashboardParsedUrl = absoluteToParsedUrl(dashboardUrl, basePath); + if (urlVars) { + const keys = Object.keys(urlVars).sort(); + keys.forEach(key => { + dashboardParsedUrl.addQueryParameter(key, urlVars[key]); + }); + } + dashboardParsedUrl.addQueryParameter( + DashboardConstants.ADD_EMBEDDABLE_TYPE, + embeddableType || 'lens' + ); + dashboardParsedUrl.addQueryParameter(DashboardConstants.ADD_EMBEDDABLE_ID, embeddableId); + return dashboardParsedUrl.getAbsoluteUrl(); +} + +/** + * Return Lens URL from dashboard absolute URL + * @param dashboardAbsoluteUrl + * @param basePath current base path + * @param id Lens id + */ +export function getLensUrlFromDashboardAbsoluteUrl( + dashboardAbsoluteUrl: string | undefined | null, + basePath: string | null | undefined, + id: string +): string | null { + if (!dashboardAbsoluteUrl || basePath === null || basePath === undefined) { + return null; + } + const { host, protocol } = parse(dashboardAbsoluteUrl); + return `${protocol}//${host}${basePath}/app/kibana#/lens/edit/${id}`; +} + +/** + * Returns the portion of the URL without query params + * eg. + * input: http://localhost:5601/lib/app/kibana#/dashboard?param1=x¶m2=y¶m3=z + * output:http://localhost:5601/lib/app/kibana#/dashboard + * input: http://localhost:5601/lib/app/kibana#/dashboard/39292992?param1=x¶m2=y¶m3=z + * output: http://localhost:5601/lib/app/kibana#/dashboard/39292992 + * @param url url to parse + */ +function getUrlWithoutQueryParams(url: string): string { + return url.split('?')[0]; +} diff --git a/src/legacy/core_plugins/kibana/public/visualize/np_ready/editor/editor.js b/src/legacy/core_plugins/kibana/public/visualize/np_ready/editor/editor.js index ed9bec9db4112..64653730473cd 100644 --- a/src/legacy/core_plugins/kibana/public/visualize/np_ready/editor/editor.js +++ b/src/legacy/core_plugins/kibana/public/visualize/np_ready/editor/editor.js @@ -35,8 +35,8 @@ import { unhashUrl } from '../../../../../../../plugins/kibana_utils/public'; import { initVisEditorDirective } from './visualization_editor'; import { initVisualizationDirective } from './visualization'; - import { + VISUALIZE_EMBEDDABLE_TYPE, subscribeWithScope, absoluteToParsedUrl, KibanaParsedUrl, @@ -588,7 +588,11 @@ function VisualizeAppController( getBasePath() ); dashboardParsedUrl.addQueryParameter( - DashboardConstants.NEW_VISUALIZATION_ID_PARAM, + DashboardConstants.ADD_EMBEDDABLE_TYPE, + VISUALIZE_EMBEDDABLE_TYPE + ); + dashboardParsedUrl.addQueryParameter( + DashboardConstants.ADD_EMBEDDABLE_ID, savedVis.id ); kbnUrl.change(dashboardParsedUrl.appPath); diff --git a/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/new_vis_modal.test.tsx b/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/new_vis_modal.test.tsx index 2005133e6d03e..0ef1b711eafc8 100644 --- a/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/new_vis_modal.test.tsx +++ b/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/new_vis_modal.test.tsx @@ -144,7 +144,7 @@ describe('NewVisModal', () => { expect(window.location.assign).toBeCalledWith('#/visualize/create?type=vis&foo=true&bar=42'); }); - it('closes if visualization with aliasUrl and addToDashboard in editorParams', () => { + it('closes and redirects properly if visualization with aliasUrl and addToDashboard in editorParams', () => { const onClose = jest.fn(); window.location.assign = jest.fn(); const wrapper = mountWithIntl( @@ -160,7 +160,7 @@ describe('NewVisModal', () => { ); const visButton = wrapper.find('button[data-test-subj="visType-visWithAliasUrl"]'); visButton.simulate('click'); - expect(window.location.assign).toBeCalledWith('testbasepath/aliasUrl'); + expect(window.location.assign).toBeCalledWith('testbasepath/aliasUrl?addToDashboard'); expect(onClose).toHaveBeenCalled(); }); }); diff --git a/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/new_vis_modal.tsx b/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/new_vis_modal.tsx index 9e8f46407f591..082fc3bc36b6b 100644 --- a/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/new_vis_modal.tsx +++ b/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/new_vis_modal.tsx @@ -143,15 +143,18 @@ class NewVisModal extends React.Component (await globalNav.getLastBreadcrumb()) === vizName ); } + + public async clickLensWidget() { + await this.clickVisType('lens'); + } } return new VisualizePage(); diff --git a/x-pack/legacy/plugins/lens/public/app_plugin/app.test.tsx b/x-pack/legacy/plugins/lens/public/app_plugin/app.test.tsx index 1cdae05833b98..794128832461b 100644 --- a/x-pack/legacy/plugins/lens/public/app_plugin/app.test.tsx +++ b/x-pack/legacy/plugins/lens/public/app_plugin/app.test.tsx @@ -80,6 +80,7 @@ describe('Lens App', () => { docId?: string; docStorage: SavedObjectStore; redirectTo: (id?: string) => void; + addToDashboardMode?: boolean; }> { return ({ editorFrame: createMockFrame(), @@ -126,6 +127,7 @@ describe('Lens App', () => { docId?: string; docStorage: SavedObjectStore; redirectTo: (id?: string) => void; + addToDashboardMode?: boolean; }>; } @@ -306,6 +308,7 @@ describe('Lens App', () => { docId?: string; docStorage: SavedObjectStore; redirectTo: (id?: string) => void; + addToDashboardMode?: boolean; }>; beforeEach(() => { @@ -344,14 +347,19 @@ describe('Lens App', () => { async function save({ initialDocId, + addToDashboardMode, ...saveProps }: SaveProps & { initialDocId?: string; + addToDashboardMode?: boolean; }) { const args = { ...defaultArgs, docId: initialDocId, }; + if (addToDashboardMode) { + args.addToDashboardMode = addToDashboardMode; + } args.editorFrame = frame; (args.docStorage.load as jest.Mock).mockResolvedValue({ id: '1234', @@ -543,6 +551,23 @@ describe('Lens App', () => { expect(getButton(instance).disableButton).toEqual(false); }); + + it('saves new doc and redirects to dashboard', async () => { + const { args } = await save({ + initialDocId: undefined, + addToDashboardMode: true, + newCopyOnSave: false, + newTitle: 'hello there', + }); + + expect(args.docStorage.save).toHaveBeenCalledWith({ + expression: 'kibana 3', + id: undefined, + title: 'hello there', + }); + + expect(args.redirectTo).toHaveBeenCalledWith('aaa'); + }); }); }); diff --git a/x-pack/legacy/plugins/lens/public/app_plugin/app.tsx b/x-pack/legacy/plugins/lens/public/app_plugin/app.tsx index cb57f2c884e38..f33cd41f46a11 100644 --- a/x-pack/legacy/plugins/lens/public/app_plugin/app.tsx +++ b/x-pack/legacy/plugins/lens/public/app_plugin/app.tsx @@ -13,6 +13,7 @@ import { SavedObjectSaveModal } from 'ui/saved_objects/components/saved_object_s import { AppMountContext, NotificationsStart } from 'src/core/public'; import { IStorageWrapper } from 'src/plugins/kibana_utils/public'; import { npStart } from 'ui/new_platform'; +import { FormattedMessage } from '@kbn/i18n/react'; import { KibanaContextProvider } from '../../../../../../src/plugins/kibana_react/public'; import { Document, SavedObjectStore } from '../persistence'; import { EditorFrameInstance } from '../types'; @@ -50,6 +51,7 @@ export function App({ docId, docStorage, redirectTo, + addToDashboardMode, }: { editorFrame: EditorFrameInstance; data: DataPublicPluginStart; @@ -58,6 +60,7 @@ export function App({ docId?: string; docStorage: SavedObjectStore; redirectTo: (id?: string) => void; + addToDashboardMode?: boolean; }) { const language = storage.get('kibana.userQueryLanguage') || core.uiSettings.get('search:queryLanguage'); @@ -166,6 +169,13 @@ export function App({ const { TopNavMenu } = npStart.plugins.navigation.ui; + const confirmButton = addToDashboardMode ? ( + + ) : null; + return ( { + .catch(e => { + // eslint-disable-next-line no-console + console.dir(e); trackUiEvent('save_failed'); core.notifications.toasts.addDanger( i18n.translate('xpack.lens.app.docSavingError', { @@ -337,10 +348,11 @@ export function App({ }} onClose={() => setState(s => ({ ...s, isSaveModalVisible: false }))} title={lastKnownDoc.title || ''} - showCopyOnSave={true} + showCopyOnSave={!addToDashboardMode} objectType={i18n.translate('xpack.lens.app.saveModalType', { defaultMessage: 'Lens visualization', })} + confirmButtonLabel={confirmButton} /> )} diff --git a/x-pack/legacy/plugins/lens/public/app_plugin/plugin.tsx b/x-pack/legacy/plugins/lens/public/app_plugin/plugin.tsx index b1eac8e287bd8..7465de2dba7f1 100644 --- a/x-pack/legacy/plugins/lens/public/app_plugin/plugin.tsx +++ b/x-pack/legacy/plugins/lens/public/app_plugin/plugin.tsx @@ -14,11 +14,13 @@ import 'uiExports/visResponseHandlers'; import 'uiExports/savedObjectTypes'; import React from 'react'; -import { I18nProvider, FormattedMessage } from '@kbn/i18n/react'; -import { HashRouter, Switch, Route, RouteComponentProps } from 'react-router-dom'; +import { FormattedMessage, I18nProvider } from '@kbn/i18n/react'; +import { HashRouter, Route, RouteComponentProps, Switch } from 'react-router-dom'; import { render, unmountComponentAtNode } from 'react-dom'; import { CoreSetup, CoreStart, SavedObjectsClientContract } from 'src/core/public'; import { DataPublicPluginStart } from 'src/plugins/data/public'; +import rison, { RisonObject, RisonValue } from 'rison-node'; +import { isObject } from 'lodash'; import { DataStart } from '../../../../../../src/legacy/core_plugins/data/public'; import { Storage } from '../../../../../../src/plugins/kibana_utils/public'; import { editorFrameSetup, editorFrameStart, editorFrameStop } from '../editor_frame_plugin'; @@ -41,6 +43,11 @@ import { import { NOT_INTERNATIONALIZED_PRODUCT_NAME } from '../../common'; import { KibanaLegacySetup } from '../../../../../../src/plugins/kibana_legacy/public'; import { EditorFrameStart } from '../types'; +import { + addEmbeddableToDashboardUrl, + getUrlVars, + getLensUrlFromDashboardAbsoluteUrl, +} from '../../../../../../src/legacy/core_plugins/kibana/public/dashboard/np_ready/url_helper'; export interface LensPluginSetupDependencies { kibana_legacy: KibanaLegacySetup; @@ -51,6 +58,9 @@ export interface LensPluginStartDependencies { dataShim: DataStart; } +export const isRisonObject = (value: RisonValue): value is RisonObject => { + return isObject(value); +}; export class AppPlugin { private startDependencies: { data: DataPublicPluginStart; @@ -84,7 +94,6 @@ export class AppPlugin { } const { data, savedObjectsClient, editorFrame } = this.startDependencies; addHelpMenuToAppChrome(context.core.chrome); - const instance = editorFrame.createInstance({}); setReportManager( @@ -93,9 +102,60 @@ export class AppPlugin { http: core.http, }) ); + const updateUrlTime = (urlVars: Record): void => { + const decoded: RisonObject = rison.decode(urlVars._g) as RisonObject; + if (!decoded) { + return; + } + // @ts-ignore + decoded.time = data.query.timefilter.timefilter.getTime(); + urlVars._g = rison.encode((decoded as unknown) as RisonObject); + }; + const redirectTo = ( + routeProps: RouteComponentProps<{ id?: string }>, + addToDashboardMode: boolean, + id?: string + ) => { + if (!id) { + routeProps.history.push('/lens'); + } else if (!addToDashboardMode) { + routeProps.history.push(`/lens/edit/${id}`); + } else if (addToDashboardMode && id) { + routeProps.history.push(`/lens/edit/${id}`); + const url = context.core.chrome.navLinks.get('kibana:dashboard'); + if (!url) { + throw new Error('Cannot get last dashboard url'); + } + const lastDashboardAbsoluteUrl = url.url; + const basePath = context.core.http.basePath.get(); + const lensUrl = getLensUrlFromDashboardAbsoluteUrl( + lastDashboardAbsoluteUrl, + basePath, + id + ); + if (!lastDashboardAbsoluteUrl || !lensUrl) { + throw new Error('Cannot get last dashboard url'); + } + window.history.pushState({}, '', lensUrl); + const urlVars = getUrlVars(lastDashboardAbsoluteUrl); + updateUrlTime(urlVars); // we need to pass in timerange in query params directly + const dashboardParsedUrl = addEmbeddableToDashboardUrl( + lastDashboardAbsoluteUrl, + basePath, + id, + urlVars + ); + if (!dashboardParsedUrl) { + throw new Error('Problem parsing dashboard url'); + } + window.history.pushState({}, '', dashboardParsedUrl); + } + }; const renderEditor = (routeProps: RouteComponentProps<{ id?: string }>) => { trackUiEvent('loaded'); + const addToDashboardMode = + !!routeProps.location.search && routeProps.location.search.includes('addToDashboard'); return ( { - if (!id) { - routeProps.history.push('/lens'); - } else { - routeProps.history.push(`/lens/edit/${id}`); - } - }} + redirectTo={id => redirectTo(routeProps, addToDashboardMode, id)} + addToDashboardMode={addToDashboardMode} /> ); }; @@ -119,6 +174,7 @@ export class AppPlugin { trackUiEvent('loaded_404'); return ; } + render( diff --git a/x-pack/test/functional/apps/dashboard_mode/dashboard_empty_screen.js b/x-pack/test/functional/apps/dashboard_mode/dashboard_empty_screen.js new file mode 100644 index 0000000000000..c90a0ae6d19fc --- /dev/null +++ b/x-pack/test/functional/apps/dashboard_mode/dashboard_empty_screen.js @@ -0,0 +1,68 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export default function({ getPageObjects, getService }) { + const log = getService('log'); + const testSubjects = getService('testSubjects'); + const esArchiver = getService('esArchiver'); + const dashboardVisualizations = getService('dashboardVisualizations'); + const PageObjects = getPageObjects(['common', 'dashboard', 'visualize', 'lens']); + + describe('empty dashboard', function() { + before(async () => { + await esArchiver.loadIfNeeded('logstash_functional'); + await esArchiver.loadIfNeeded('lens/basic'); + await PageObjects.common.navigateToApp('dashboard'); + await PageObjects.dashboard.preserveCrossAppState(); + await PageObjects.dashboard.clickNewDashboard(); + }); + + after(async () => { + await PageObjects.dashboard.gotoDashboardLandingPage(); + }); + + async function createAndAddLens(title) { + log.debug(`createAndAddLens(${title})`); + const inViewMode = await PageObjects.dashboard.getIsInViewMode(); + if (inViewMode) { + await PageObjects.dashboard.switchToEditMode(); + } + await PageObjects.visualize.clickLensWidget(); + await PageObjects.lens.goToTimeRange(); + await PageObjects.lens.configureDimension({ + dimension: + '[data-test-subj="lnsXY_xDimensionPanel"] [data-test-subj="indexPattern-configure-dimension"]', + operation: 'date_histogram', + field: '@timestamp', + }); + + await PageObjects.lens.configureDimension({ + dimension: + '[data-test-subj="lnsXY_yDimensionPanel"] [data-test-subj="indexPattern-configure-dimension"]', + operation: 'avg', + field: 'bytes', + }); + + await PageObjects.lens.configureDimension({ + dimension: + '[data-test-subj="lnsXY_splitDimensionPanel"] [data-test-subj="indexPattern-configure-dimension"]', + operation: 'terms', + field: 'ip', + }); + await PageObjects.lens.save(title); + } + + it('adds Lens visualization to empty dashboard', async () => { + const title = 'Dashboard Test Lens'; + await testSubjects.exists('addVisualizationButton'); + await testSubjects.click('addVisualizationButton'); + await dashboardVisualizations.ensureNewVisualizationDialogIsShowing(); + await createAndAddLens(title); + await PageObjects.dashboard.waitForRenderComplete(); + await testSubjects.exists(`embeddablePanelHeading-${title}`); + }); + }); +} diff --git a/x-pack/test/functional/apps/dashboard_mode/index.js b/x-pack/test/functional/apps/dashboard_mode/index.js index 2a98634ba40d5..09b9717ea9f02 100644 --- a/x-pack/test/functional/apps/dashboard_mode/index.js +++ b/x-pack/test/functional/apps/dashboard_mode/index.js @@ -9,5 +9,6 @@ export default function({ loadTestFile }) { this.tags('ciGroup7'); loadTestFile(require.resolve('./dashboard_view_mode')); + loadTestFile(require.resolve('./dashboard_empty_screen')); }); } From 668c16ceafabe4b5b98a0dd416d4e9ac6d8fd724 Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Mon, 13 Jan 2020 12:44:02 -0500 Subject: [PATCH 037/139] more removal --- .../components/color/color_map_select.js | 70 +++++-------------- .../components/color/dynamic_color_form.js | 18 +++++ 2 files changed, 36 insertions(+), 52 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js index d714d84ba78ae..d0ffb32415590 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js @@ -7,8 +7,6 @@ import React, { Component, Fragment } from 'react'; import { EuiSuperSelect, EuiSpacer } from '@elastic/eui'; -import { COLOR_GRADIENTS, COLOR_PALETTES_INPUTS } from '../../../color_utils'; -import { FormattedMessage } from '@kbn/i18n/react'; import { ColorStopsOrdinal } from './color_stops_ordinal'; import { COLOR_MAP_TYPE } from '../../../../../../common/constants'; import { ColorStopsCategorical } from './color_stops_categorical'; @@ -116,52 +114,27 @@ export class ColorMapSelect extends Component { } } - let colorMapOptions; let valueOfSelected; - if (this.props.colorMapType === COLOR_MAP_TYPE.ORDINAL) { - colorMapOptions = [ - { - value: CUSTOM_COLOR_MAP, - inputDisplay: ( - - ), - }, - ...COLOR_GRADIENTS, - ]; - if (useCustomColorRamp) { - valueOfSelected = CUSTOM_COLOR_MAP; - } else { - if (colorMapOptions.find(option => option.value === color)) { - valueOfSelected = color; - } else { - valueOfSelected = COLOR_GRADIENTS[0].value; - this._onColorMapSelect(valueOfSelected); - } - } - } else if (this.props.colorMapType === COLOR_MAP_TYPE.CATEGORICAL) { - const customOption = { + const colorMapOptions = [ + { value: CUSTOM_COLOR_MAP, - inputDisplay: ( - - ), - }; - - colorMapOptions = [customOption, ...COLOR_PALETTES_INPUTS]; - if (useCustomColorPalette) { - valueOfSelected = CUSTOM_COLOR_MAP; + inputDisplay: this.props.customOptionLabel, + }, + ...this.props.colorMapOptions, + ]; + + const useCustom = + this.props.colorMapType === COLOR_MAP_TYPE.ORDINAL + ? useCustomColorRamp + : useCustomColorPalette; + if (useCustom) { + valueOfSelected = CUSTOM_COLOR_MAP; + } else { + if (colorMapOptions.find(option => option.value === color)) { + valueOfSelected = color; } else { - if (colorMapOptions.find(option => option.value === color)) { - valueOfSelected = color; - } else { - valueOfSelected = COLOR_PALETTES_INPUTS[0].value; - this._onColorMapSelect(valueOfSelected); - } + valueOfSelected = this.props.colorMapOptions[0].value; + this._onColorMapSelect(valueOfSelected); } } @@ -178,10 +151,3 @@ export class ColorMapSelect extends Component { ); } } - -// ColorRampSelect.propTypes = { -// color: PropTypes.string, -// onChange: PropTypes.func.isRequired, -// useCustomColorRamp: PropTypes.bool, -// customColorRamp: PropTypes.array, -// }; diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js index 170b97ff0e5ba..1a5507479aaff 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js @@ -11,6 +11,8 @@ import { ColorMapSelect } from './color_map_select'; import { EuiFlexGroup, EuiFlexItem, EuiSpacer } from '@elastic/eui'; import { CATEGORICAL_DATA_TYPES, COLOR_MAP_TYPE } from '../../../../../../common/constants'; import { OrdinalFieldMetaOptionsPopover } from '../ordinal_field_meta_options_popover'; +import { FormattedMessage } from '@kbn/i18n/react'; +import { COLOR_GRADIENTS, COLOR_PALETTES_INPUTS } from '../../../color_utils'; export class DynamicColorForm extends React.Component { state = { @@ -85,8 +87,16 @@ export class DynamicColorForm extends React.Component { }; if (this.state.colorMapType === COLOR_MAP_TYPE.ORDINAL) { + const customOptionLabel = ( + + ); colorSelect = ( onColorChange(options)} colorMapType={COLOR_MAP_TYPE.ORDINAL} color={styleOptions.color} @@ -96,8 +106,16 @@ export class DynamicColorForm extends React.Component { /> ); } else if (this.state.colorMapType === COLOR_MAP_TYPE.CATEGORICAL) { + const customOptionLabel = ( + + ); colorSelect = ( onColorChange(options)} colorMapType={COLOR_MAP_TYPE.CATEGORICAL} color={styleOptions.color} From 70aa7b3c5cb20c93b5be671d37dff12261117d3a Mon Sep 17 00:00:00 2001 From: Catherine Liu Date: Mon, 13 Jan 2020 10:50:00 -0700 Subject: [PATCH 038/139] Migrates ES Fields Route to NP (#54398) * Migrated es fields route to NP and added tests * Removed extraneous import * Removed check for index query * Fixed broken test --- .../routes/es_fields/get_es_field_types.js | 33 ---- .../canvas/server/routes/es_fields/index.ts | 40 ----- .../plugins/canvas/server/routes/index.ts | 2 - .../server/routes/es_fields/es_fields.test.ts | 164 ++++++++++++++++++ .../server/routes/es_fields/es_fields.ts | 58 +++++++ .../canvas/server/routes/es_fields/index.ts | 12 ++ x-pack/plugins/canvas/server/routes/index.ts | 2 + 7 files changed, 236 insertions(+), 75 deletions(-) delete mode 100644 x-pack/legacy/plugins/canvas/server/routes/es_fields/get_es_field_types.js delete mode 100644 x-pack/legacy/plugins/canvas/server/routes/es_fields/index.ts create mode 100644 x-pack/plugins/canvas/server/routes/es_fields/es_fields.test.ts create mode 100644 x-pack/plugins/canvas/server/routes/es_fields/es_fields.ts create mode 100644 x-pack/plugins/canvas/server/routes/es_fields/index.ts diff --git a/x-pack/legacy/plugins/canvas/server/routes/es_fields/get_es_field_types.js b/x-pack/legacy/plugins/canvas/server/routes/es_fields/get_es_field_types.js deleted file mode 100644 index 36f7399ecd031..0000000000000 --- a/x-pack/legacy/plugins/canvas/server/routes/es_fields/get_es_field_types.js +++ /dev/null @@ -1,33 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -import { mapValues, keys } from 'lodash'; -import { normalizeType } from '../../lib/normalize_type'; - -export function getESFieldTypes(index, fields, elasticsearchClient) { - const config = { - index: index, - fields: fields || '*', - }; - - if (fields && fields.length === 0) { - return Promise.resolve({}); - } - - return elasticsearchClient('fieldCaps', config).then(resp => { - return mapValues(resp.fields, types => { - if (keys(types).length > 1) { - return 'conflict'; - } - - try { - return normalizeType(keys(types)[0]); - } catch (e) { - return 'unsupported'; - } - }); - }); -} diff --git a/x-pack/legacy/plugins/canvas/server/routes/es_fields/index.ts b/x-pack/legacy/plugins/canvas/server/routes/es_fields/index.ts deleted file mode 100644 index 6c1dd723299c6..0000000000000 --- a/x-pack/legacy/plugins/canvas/server/routes/es_fields/index.ts +++ /dev/null @@ -1,40 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -import { partial } from 'lodash'; -import { API_ROUTE } from '../../../common/lib/constants'; -import { CoreSetup } from '../../shim'; -// @ts-ignore untyped local -import { getESFieldTypes } from './get_es_field_types'; - -// TODO: Error handling, note: esErrors - -interface ESFieldsRequest { - query: { - index: string; - fields: string[]; - }; -} - -export function esFields( - route: CoreSetup['http']['route'], - elasticsearch: CoreSetup['elasticsearch'] -) { - const { callWithRequest } = elasticsearch.getCluster('data'); - - route({ - method: 'GET', - path: `${API_ROUTE}/es_fields`, - handler(request: ESFieldsRequest, h: any) { - const { index, fields } = request.query; - if (!index) { - return h.response({ error: '"index" query is required' }).code(400); - } - - return getESFieldTypes(index, fields, partial(callWithRequest, request)); - }, - }); -} diff --git a/x-pack/legacy/plugins/canvas/server/routes/index.ts b/x-pack/legacy/plugins/canvas/server/routes/index.ts index 2f6b706fc7edb..6898a3c459e3d 100644 --- a/x-pack/legacy/plugins/canvas/server/routes/index.ts +++ b/x-pack/legacy/plugins/canvas/server/routes/index.ts @@ -4,11 +4,9 @@ * you may not use this file except in compliance with the Elastic License. */ -import { esFields } from './es_fields'; import { shareableWorkpads } from './shareables'; import { CoreSetup } from '../shim'; export function routes(setup: CoreSetup): void { - esFields(setup.http.route, setup.elasticsearch); shareableWorkpads(setup.http.route); } diff --git a/x-pack/plugins/canvas/server/routes/es_fields/es_fields.test.ts b/x-pack/plugins/canvas/server/routes/es_fields/es_fields.test.ts new file mode 100644 index 0000000000000..c96856d09256b --- /dev/null +++ b/x-pack/plugins/canvas/server/routes/es_fields/es_fields.test.ts @@ -0,0 +1,164 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { initializeESFieldsRoute } from './es_fields'; +import { + IRouter, + kibanaResponseFactory, + RequestHandlerContext, + RequestHandler, +} from 'src/core/server'; +import { + httpServiceMock, + httpServerMock, + loggingServiceMock, + elasticsearchServiceMock, +} from 'src/core/server/mocks'; + +const mockRouteContext = ({ + core: { + elasticsearch: { dataClient: elasticsearchServiceMock.createScopedClusterClient() }, + }, +} as unknown) as RequestHandlerContext; + +const path = `api/canvas/workpad/find`; + +describe('Retrieve ES Fields', () => { + let routeHandler: RequestHandler; + + beforeEach(() => { + const httpService = httpServiceMock.createSetupContract(); + const router = httpService.createRouter('') as jest.Mocked; + initializeESFieldsRoute({ + router, + logger: loggingServiceMock.create().get(), + }); + + routeHandler = router.get.mock.calls[0][1]; + }); + + it(`returns 200 with fields from existing index/index pattern`, async () => { + const index = 'test'; + const mockResults = { + indices: ['test'], + fields: { + '@timestamp': { + date: { + type: 'date', + searchable: true, + aggregatable: true, + }, + }, + name: { + text: { + type: 'text', + searchable: true, + aggregatable: false, + }, + }, + products: { + object: { + type: 'object', + searchable: false, + aggregatable: false, + }, + }, + }, + }; + const request = httpServerMock.createKibanaRequest({ + method: 'get', + path, + query: { + index, + }, + }); + + const callAsCurrentUserMock = mockRouteContext.core.elasticsearch.dataClient + .callAsCurrentUser as jest.Mock; + + callAsCurrentUserMock.mockResolvedValueOnce(mockResults); + + const response = await routeHandler(mockRouteContext, request, kibanaResponseFactory); + + expect(response.status).toBe(200); + expect(response.payload).toMatchInlineSnapshot(` + Object { + "@timestamp": "date", + "name": "string", + "products": "unsupported", + } + `); + }); + + it(`returns 200 with empty object when index/index pattern has no fields`, async () => { + const index = 'test'; + const mockResults = { indices: [index], fields: {} }; + const request = httpServerMock.createKibanaRequest({ + method: 'get', + path, + query: { + index, + }, + }); + + const callAsCurrentUserMock = mockRouteContext.core.elasticsearch.dataClient + .callAsCurrentUser as jest.Mock; + + callAsCurrentUserMock.mockResolvedValueOnce(mockResults); + + const response = await routeHandler(mockRouteContext, request, kibanaResponseFactory); + + expect(response.status).toBe(200); + expect(response.payload).toMatchInlineSnapshot('Object {}'); + }); + + it(`returns 200 with empty object when index/index pattern does not have specified field(s)`, async () => { + const index = 'test'; + + const mockResults = { + indices: [index], + fields: {}, + }; + + const request = httpServerMock.createKibanaRequest({ + method: 'get', + path, + query: { + index, + fields: ['foo', 'bar'], + }, + }); + + const callAsCurrentUserMock = mockRouteContext.core.elasticsearch.dataClient + .callAsCurrentUser as jest.Mock; + + callAsCurrentUserMock.mockResolvedValueOnce(mockResults); + + const response = await routeHandler(mockRouteContext, request, kibanaResponseFactory); + + expect(response.status).toBe(200); + expect(response.payload).toMatchInlineSnapshot(`Object {}`); + }); + + it(`returns 500 when index does not exist`, async () => { + const request = httpServerMock.createKibanaRequest({ + method: 'get', + path, + query: { + index: 'foo', + }, + }); + + const callAsCurrentUserMock = mockRouteContext.core.elasticsearch.dataClient + .callAsCurrentUser as jest.Mock; + + callAsCurrentUserMock.mockRejectedValueOnce(new Error('Index not found')); + + const response = await routeHandler(mockRouteContext, request, kibanaResponseFactory); + + expect(response.status).toBe(500); + }); +}); diff --git a/x-pack/plugins/canvas/server/routes/es_fields/es_fields.ts b/x-pack/plugins/canvas/server/routes/es_fields/es_fields.ts new file mode 100644 index 0000000000000..b82f84b931d73 --- /dev/null +++ b/x-pack/plugins/canvas/server/routes/es_fields/es_fields.ts @@ -0,0 +1,58 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { mapValues, keys } from 'lodash'; +import { schema } from '@kbn/config-schema'; +import { API_ROUTE } from '../../../../../legacy/plugins/canvas/common/lib'; +import { catchErrorHandler } from '../catch_error_handler'; +// @ts-ignore unconverted lib +import { normalizeType } from '../../../../../legacy/plugins/canvas/server/lib/normalize_type'; +import { RouteInitializerDeps } from '..'; + +const ESFieldsRequestSchema = schema.object({ + index: schema.string(), + fields: schema.maybe(schema.arrayOf(schema.string())), +}); + +export function initializeESFieldsRoute(deps: RouteInitializerDeps) { + const { router } = deps; + + router.get( + { + path: `${API_ROUTE}/es_fields`, + validate: { + query: ESFieldsRequestSchema, + }, + }, + catchErrorHandler(async (context, request, response) => { + const { callAsCurrentUser } = context.core.elasticsearch.dataClient; + const { index, fields } = request.query; + + const config = { + index, + fields: fields || '*', + }; + + const esFields = await callAsCurrentUser('fieldCaps', config).then(resp => { + return mapValues(resp.fields, types => { + if (keys(types).length > 1) { + return 'conflict'; + } + + try { + return normalizeType(keys(types)[0]); + } catch (e) { + return 'unsupported'; + } + }); + }); + + return response.ok({ + body: esFields, + }); + }) + ); +} diff --git a/x-pack/plugins/canvas/server/routes/es_fields/index.ts b/x-pack/plugins/canvas/server/routes/es_fields/index.ts new file mode 100644 index 0000000000000..fa44f09747d6c --- /dev/null +++ b/x-pack/plugins/canvas/server/routes/es_fields/index.ts @@ -0,0 +1,12 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { initializeESFieldsRoute } from './es_fields'; +import { RouteInitializerDeps } from '..'; + +export function initESFieldsRoutes(deps: RouteInitializerDeps) { + initializeESFieldsRoute(deps); +} diff --git a/x-pack/plugins/canvas/server/routes/index.ts b/x-pack/plugins/canvas/server/routes/index.ts index 8b2d77d634760..e9afab5680332 100644 --- a/x-pack/plugins/canvas/server/routes/index.ts +++ b/x-pack/plugins/canvas/server/routes/index.ts @@ -7,6 +7,7 @@ import { IRouter, Logger } from 'src/core/server'; import { initWorkpadRoutes } from './workpad'; import { initCustomElementsRoutes } from './custom_elements'; +import { initESFieldsRoutes } from './es_fields'; export interface RouteInitializerDeps { router: IRouter; @@ -16,4 +17,5 @@ export interface RouteInitializerDeps { export function initRoutes(deps: RouteInitializerDeps) { initWorkpadRoutes(deps); initCustomElementsRoutes(deps); + initESFieldsRoutes(deps); } From 79ee978fc46279095f85e0e5709a31e685c8d6f6 Mon Sep 17 00:00:00 2001 From: Jimmy Kuang Date: Mon, 13 Jan 2020 09:58:20 -0800 Subject: [PATCH 039/139] [SR] Support capitalized date formats in snapshot names (#53751) Snapshot names that contain date math may require capital letters, e.g. "". This change fixes a bug which complained that capital letters are not allowed in snapshot names, by scoping this validation to only the name part of this pattern, ignoring the date math part. --- .../policy_form/steps/step_logistics.tsx | 2 +- .../app/services/validation/validate_policy.ts | 18 ++++++++++++++++++ .../models/action/webhook_action.js | 1 + 3 files changed, 20 insertions(+), 1 deletion(-) diff --git a/x-pack/legacy/plugins/snapshot_restore/public/app/components/policy_form/steps/step_logistics.tsx b/x-pack/legacy/plugins/snapshot_restore/public/app/components/policy_form/steps/step_logistics.tsx index 2206d6de341c8..111b46d596e56 100644 --- a/x-pack/legacy/plugins/snapshot_restore/public/app/components/policy_form/steps/step_logistics.tsx +++ b/x-pack/legacy/plugins/snapshot_restore/public/app/components/policy_form/steps/step_logistics.tsx @@ -347,7 +347,7 @@ export const PolicyStepLogistics: React.FunctionComponent = ({ onChange={e => { updatePolicy( { - snapshotName: e.target.value.toLowerCase(), + snapshotName: e.target.value, }, { managedRepository, diff --git a/x-pack/legacy/plugins/snapshot_restore/public/app/services/validation/validate_policy.ts b/x-pack/legacy/plugins/snapshot_restore/public/app/services/validation/validate_policy.ts index 7d44979e697a7..0720994ca7669 100644 --- a/x-pack/legacy/plugins/snapshot_restore/public/app/services/validation/validate_policy.ts +++ b/x-pack/legacy/plugins/snapshot_restore/public/app/services/validation/validate_policy.ts @@ -15,6 +15,16 @@ const isStringEmpty = (str: string | null): boolean => { return str ? !Boolean(str.trim()) : true; }; +// strExcludeDate is the concat results of the SnapshotName ...{...}>... without the date +// This way we can check only the SnapshotName portion for lowercasing +// For example: would give strExcludeDate = + +const isSnapshotNameNotLowerCase = (str: string): boolean => { + const strExcludeDate = + str.substring(0, str.search('{')) + str.substring(str.search('}>') + 1, str.length); + return strExcludeDate !== strExcludeDate.toLowerCase() ? true : false; +}; + export const validatePolicy = ( policy: SlmPolicyPayload, validationHelperData: { @@ -61,6 +71,14 @@ export const validatePolicy = ( ); } + if (isSnapshotNameNotLowerCase(snapshotName)) { + validation.errors.snapshotName.push( + i18n.translate('xpack.snapshotRestore.policyValidation.snapshotNameLowerCaseErrorMessage', { + defaultMessage: 'Snapshot name needs to be lowercase.', + }) + ); + } + if (isStringEmpty(schedule)) { validation.errors.schedule.push( i18n.translate('xpack.snapshotRestore.policyValidation.scheduleRequiredErrorMessage', { diff --git a/x-pack/legacy/plugins/watcher/public/np_ready/application/models/action/webhook_action.js b/x-pack/legacy/plugins/watcher/public/np_ready/application/models/action/webhook_action.js index 6f496dd9ee138..3225653acbb3d 100644 --- a/x-pack/legacy/plugins/watcher/public/np_ready/application/models/action/webhook_action.js +++ b/x-pack/legacy/plugins/watcher/public/np_ready/application/models/action/webhook_action.js @@ -25,6 +25,7 @@ export class WebhookAction extends BaseAction { this.username = get(props, 'username'); this.password = get(props, 'password'); this.contentType = get(props, 'contentType'); + this.fullPath = `${this.host}:${this.port}${this.path ? '/' + this.path : ''}`; } From ddea3dddb6f5087b287d8d203b8c6836f5c9b23b Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Mon, 13 Jan 2020 13:11:26 -0500 Subject: [PATCH 040/139] read out correct default --- .../vector/properties/dynamic_color_property.js | 17 +++++++++++++---- 1 file changed, 13 insertions(+), 4 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js index b813f168d3967..8bfe83aaa1c67 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js @@ -196,13 +196,22 @@ export class DynamicColorProperty extends DynamicStyleProperty { if (!paletteStops.length) { return null; } + const mbStops = []; - for (let i = 0; i < paletteStops.length - 1; i++) { + let defaultColor = null; + for (let i = 0; i < paletteStops.length; i++) { const stop = paletteStops[i]; - mbStops.push(stop.stop); - mbStops.push(stop.color); + if (stop.isDefault) { + defaultColor = stop.color; + } else { + mbStops.push(stop.stop); + mbStops.push(stop.color); + } + } + if (!defaultColor) { + return null; } - mbStops.push(paletteStops[paletteStops.length - 2].color); //last color is default color + mbStops.push(defaultColor); //last color is default color return ['match', ['get', this._options.field.name], ...mbStops]; } From f7ba36279e468bd8c738bc7d947453a5a3c39e93 Mon Sep 17 00:00:00 2001 From: gchaps <33642766+gchaps@users.noreply.github.com> Date: Mon, 13 Jan 2020 10:19:20 -0800 Subject: [PATCH 041/139] [DOCS] Removes dashboard search batching setting (#54594) * [DOCS] Removes dashboard search batching setting * [DOCS] Keeps content for search setting and adds deprecation notice * [DOCS] Fixes version notice in deprecation notice --- docs/management/advanced-options.asciidoc | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/docs/management/advanced-options.asciidoc b/docs/management/advanced-options.asciidoc index 977a65f62202d..757c6f10f2a99 100644 --- a/docs/management/advanced-options.asciidoc +++ b/docs/management/advanced-options.asciidoc @@ -187,7 +187,8 @@ Refresh the page to apply the changes. === Search settings [horizontal] -`courier:batchSearches`:: When disabled, dashboard panels will load individually, and search requests will terminate when +`courier:batchSearches`:: **Deprecated in 7.6. Starting in 8.0, this setting will be optimized internally.** +When disabled, dashboard panels will load individually, and search requests will terminate when users navigate away or update the query. When enabled, dashboard panels will load together when all of the data is loaded, and searches will not terminate. `courier:customRequestPreference`:: {ref}/search-request-body.html#request-body-search-preference[Request preference] From ec69443ca27d4196bd5111e2d099b848fe37f94f Mon Sep 17 00:00:00 2001 From: Jonathan Budzenski Date: Mon, 13 Jan 2020 12:37:39 -0600 Subject: [PATCH 042/139] [docs] load balancing kibana (#52659) * [docs] multiple kibanas * fix * capital title * Update docs/setup/production.asciidoc Co-Authored-By: gchaps <33642766+gchaps@users.noreply.github.com> * Update docs/setup/production.asciidoc Co-Authored-By: gchaps <33642766+gchaps@users.noreply.github.com> * Update docs/setup/production.asciidoc Co-Authored-By: gchaps <33642766+gchaps@users.noreply.github.com> * title and actions * fix reference * fix merge * case fix * plural Co-authored-by: gchaps <33642766+gchaps@users.noreply.github.com> --- docs/setup/production.asciidoc | 40 ++++++++++++++++++++++++++++++---- 1 file changed, 36 insertions(+), 4 deletions(-) diff --git a/docs/setup/production.asciidoc b/docs/setup/production.asciidoc index fed4ba4886bf9..eef2b11e53d85 100644 --- a/docs/setup/production.asciidoc +++ b/docs/setup/production.asciidoc @@ -4,7 +4,8 @@ * <> * <> * <> -* <> +* <> +* <> * <> * <> @@ -18,7 +19,7 @@ While Kibana isn't terribly resource intensive, we still recommend running Kiban separate from your Elasticsearch data or master nodes. To distribute Kibana traffic across the nodes in your Elasticsearch cluster, you can run Kibana and an Elasticsearch client node on the same machine. For more information, see -<>. +<>. [float] [[configuring-kibana-shield]] @@ -63,7 +64,7 @@ csp.strict: true See <>. [float] -[[load-balancing]] +[[load-balancing-es]] === Load Balancing Across Multiple Elasticsearch Nodes If you have multiple nodes in your Elasticsearch cluster, the easiest way to distribute Kibana requests across the nodes is to run an Elasticsearch _Coordinating only_ node on the same machine as Kibana. @@ -110,9 +111,40 @@ transport.tcp.port: 9300 - 9400 elasticsearch.hosts: ["http://localhost:9200"] -------- +[float] +[[load-balancing-kibana]] +=== Load balancing across multiple Kibana instances +To serve multiple Kibana installations behind a load balancer, you must change the configuration. See {kibana-ref}/settings.html[Configuring Kibana] for details on each setting. + +Settings unique across each Kibana instance: +-------- +server.uuid +server.name +-------- + +Settings unique across each host (for example, running multiple installations on the same virtual machine): +-------- +logging.dest +path.data +pid.file +server.port +-------- + +Settings that must be the same: +-------- +xpack.security.encryptionKey //decrypting session cookies +xpack.reporting.encryptionKey //decrypting reports stored in Elasticsearch +-------- + +Separate configuration files can be used from the command line by using the `-c` flag: +-------- +bin/kibana -c config/instance1.yml +bin/kibana -c config/instance2.yml +-------- + [float] [[high-availability]] -=== High Availability Across Multiple Elasticsearch Nodes +=== High availability across multiple Elasticsearch nodes Kibana can be configured to connect to multiple Elasticsearch nodes in the same cluster. In situations where a node becomes unavailable, Kibana will transparently connect to an available node and continue operating. Requests to available hosts will be routed in a round robin fashion. From c501b16b43089b670c05f90661a61c28a9bc65dd Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Mon, 13 Jan 2020 13:37:44 -0500 Subject: [PATCH 043/139] feedback --- .../layers/styles/vector/components/color/color_stops.js | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops.js index 9f1ea340aa17f..9b0f9695bfdfb 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops.js @@ -21,8 +21,7 @@ export const ColorStops = ({ function getStopInput(stop, index) { const onStopChange = e => { const newColorStops = _.cloneDeep(colorStops); - const newValue = sanitizeStopInput(e.target.value); - newColorStops[index].stop = newValue; + newColorStops[index].stop = sanitizeStopInput(e.target.value); const invalid = isStopsInvalid(newColorStops); onChange({ colorStops: newColorStops, From 8ce3293cab6fca10a2e670c80512afc766db50c5 Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Mon, 13 Jan 2020 13:47:20 -0500 Subject: [PATCH 044/139] update snapshots --- .../dynamic_color_property.test.js.snap | 339 ------------------ 1 file changed, 339 deletions(-) delete mode 100644 x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/__snapshots__/dynamic_color_property.test.js.snap diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/__snapshots__/dynamic_color_property.test.js.snap b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/__snapshots__/dynamic_color_property.test.js.snap deleted file mode 100644 index a037748f32258..0000000000000 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/__snapshots__/dynamic_color_property.test.js.snap +++ /dev/null @@ -1,339 +0,0 @@ -// Jest Snapshot v1, https://goo.gl/fbAQLP - -exports[`Should render categorical legend with breaks from custom 1`] = ` -
- - - - - - - - Default - - - - - - - - - - - - - US_STOP_format - - - - - - - - - - - - CN_STOP_format - - - - - - - - - - - - - - - foobar_label - - - - - - -
-`; - -exports[`Should render categorical legend with breaks from default 1`] = ` -
- - - - - - - - Default - - - - - - - - - - - - - US_format - - - - - - - - - - - - CN_format - - - - - - - - - - - - - - - foobar_label - - - - - - -
-`; - -exports[`Should render ordinal legend 1`] = ` - - } - maxLabel="100_format" - minLabel="0_format" - propertyLabel="Border color" -/> -`; - -exports[`Should render ordinal legend with breaks 1`] = ` -
- - - - - - - 0_format - - - - - - - - - - - - 10_format - - - - - - - - - - - - - - - foobar_label - - - - - - -
-`; From a1fa814fa90cf944fa5b34987134baf6d32e68f8 Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Mon, 13 Jan 2020 13:52:13 -0500 Subject: [PATCH 045/139] update snapshots --- .../dynamic_color_property.test.js.snap | 229 ++++++++++++++++++ 1 file changed, 229 insertions(+) create mode 100644 x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/__snapshots__/dynamic_color_property.test.js.snap diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/__snapshots__/dynamic_color_property.test.js.snap b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/__snapshots__/dynamic_color_property.test.js.snap new file mode 100644 index 0000000000000..ab337e0dbfe7a --- /dev/null +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/__snapshots__/dynamic_color_property.test.js.snap @@ -0,0 +1,229 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`Should render categorical legend with breaks from custom 1`] = `""`; + +exports[`Should render categorical legend with breaks from default 1`] = ` +
+ + + + + + + US_format + + + + + + + + + + + + CN_format + + + + + + + + + + + + + Other + + + + + + + + + + + + + + + + foobar_label + + + + + + +
+`; + +exports[`Should render ordinal legend 1`] = ` + + } + maxLabel="100_format" + minLabel="0_format" + propertyLabel="Border color" +/> +`; + +exports[`Should render ordinal legend with breaks 1`] = ` +
+ + + + + + + 0_format + + + + + + + + + + + + 10_format + + + + + + + + + + + + + + + foobar_label + + + + + + +
+`; From ea9a7b8a16abbee97ddf39f91e4cf3c3b7253b42 Mon Sep 17 00:00:00 2001 From: Gidi Meir Morris Date: Mon, 13 Jan 2020 19:09:57 +0000 Subject: [PATCH 046/139] migrate TaskManager Plugin to the Kibana Platform (#53869) Migrates the existing TaskManager plugin from Legacy to Kibana Platform. We retain the Legacy API to prevent a breaking change, but under the hood, the legacy plugin is now using the Kibana Platform plugin. Another reason we retain the Legacy plugin to support several features that the Platform team has yet to migrate to Kibana Platform (mapping, SO schema and migrations). --- src/core/server/mocks.ts | 1 + .../server/action_type_registry.test.ts | 4 +- .../actions/server/action_type_registry.ts | 4 +- .../actions/server/actions_client.test.ts | 4 +- .../server/builtin_action_types/index.test.ts | 4 +- .../server/create_execute_function.test.ts | 4 +- .../actions/server/create_execute_function.ts | 2 +- x-pack/legacy/plugins/actions/server/init.ts | 5 +- .../server/lib/task_runner_factory.test.ts | 2 +- .../actions/server/lib/task_runner_factory.ts | 2 +- .../legacy/plugins/actions/server/plugin.ts | 4 +- x-pack/legacy/plugins/actions/server/shim.ts | 31 +- .../server/alert_type_registry.test.ts | 5 +- .../alerting/server/alert_type_registry.ts | 3 +- .../alerting/server/alerts_client.test.ts | 6 +- .../plugins/alerting/server/alerts_client.ts | 2 +- .../server/alerts_client_factory.test.ts | 4 +- .../alerting/server/alerts_client_factory.ts | 3 +- .../legacy/plugins/alerting/server/plugin.ts | 4 +- x-pack/legacy/plugins/alerting/server/shim.ts | 23 +- .../server/task_runner/task_runner.test.ts | 2 +- .../server/task_runner/task_runner.ts | 2 +- .../task_runner/task_runner_factory.test.ts | 2 +- .../server/task_runner/task_runner_factory.ts | 2 +- x-pack/legacy/plugins/lens/index.ts | 7 + x-pack/legacy/plugins/lens/server/plugin.tsx | 35 +- .../plugins/lens/server/usage/collectors.ts | 39 +-- .../legacy/plugins/lens/server/usage/task.ts | 36 +-- .../plugins/maps/server/test_utils/index.js | 21 -- x-pack/legacy/plugins/oss_telemetry/index.ts | 20 +- .../server/lib/collectors/index.ts | 4 +- .../get_usage_collector.test.ts | 53 +-- .../visualizations/get_usage_collector.ts | 8 +- .../register_usage_collector.ts | 4 +- .../oss_telemetry/server/lib/tasks/index.ts | 11 +- .../tasks/visualizations/task_runner.test.ts | 2 +- .../lib/tasks/visualizations/task_runner.ts | 2 +- .../plugins/oss_telemetry/server/plugin.ts | 23 +- .../plugins/oss_telemetry/test_utils/index.ts | 48 ++- .../plugins/task_manager/server/index.ts | 105 +++--- .../plugins/task_manager/server/legacy.ts | 57 ++++ .../task_manager/server/plugin.test.ts | 73 ----- .../plugins/task_manager/server/plugin.ts | 82 ----- .../task_manager/server/task_manager.mock.ts | 43 ++- x-pack/plugins/task_manager/kibana.json | 8 + .../plugins/task_manager/server/README.md | 305 +++++++++++------- .../task_manager/server/config.test.ts | 33 ++ x-pack/plugins/task_manager/server/config.ts | 44 +++ .../server/create_task_manager.test.ts | 58 ++++ .../server/create_task_manager.ts | 46 +++ x-pack/plugins/task_manager/server/index.ts | 29 ++ .../lib/correct_deprecated_fields.test.ts | 0 .../server/lib/correct_deprecated_fields.ts | 0 .../task_manager/server/lib/fill_pool.test.ts | 0 .../task_manager/server/lib/fill_pool.ts | 0 .../server/lib/get_template_version.test.ts | 0 .../server/lib/get_template_version.ts | 0 .../server/lib/identify_es_error.test.ts | 0 .../server/lib/identify_es_error.ts | 0 .../task_manager/server/lib/intervals.test.ts | 0 .../task_manager/server/lib/intervals.ts | 0 .../server/lib/middleware.test.ts | 0 .../task_manager/server/lib/middleware.ts | 0 .../server/lib/pull_from_set.test.ts | 0 .../task_manager/server/lib/pull_from_set.ts | 0 .../task_manager/server/lib/result_type.ts | 0 .../lib/sanitize_task_definitions.test.ts | 0 .../server/lib/sanitize_task_definitions.ts | 0 x-pack/plugins/task_manager/server/plugin.ts | 83 +++++ .../mark_available_tasks_as_claimed.test.ts | 0 .../mark_available_tasks_as_claimed.ts | 0 .../server/queries/query_clauses.ts | 0 .../plugins/task_manager/server/task.ts | 0 .../task_manager/server/task_events.ts | 0 .../task_manager/server/task_manager.mock.ts | 32 ++ .../task_manager/server/task_manager.test.ts | 53 +-- .../task_manager/server/task_manager.ts | 28 +- .../task_manager/server/task_poller.test.ts | 0 .../task_manager/server/task_poller.ts | 0 .../task_manager/server/task_pool.test.ts | 0 .../plugins/task_manager/server/task_pool.ts | 0 .../task_manager/server/task_runner.test.ts | 2 +- .../task_manager/server/task_runner.ts | 0 .../task_manager/server/task_store.test.ts | 8 +- .../plugins/task_manager/server/task_store.ts | 8 +- .../task_manager/server/test_utils/index.ts | 0 .../plugins/task_manager/server/types.ts | 0 .../fixtures/plugins/task_manager/index.ts | 4 +- .../plugins/task_manager/index.js | 8 +- .../plugins/task_manager/init_routes.js | 43 ++- .../task_manager/task_manager_integration.js | 19 ++ .../plugins/task_manager_performance/index.js | 5 +- .../task_manager_performance/init_routes.js | 5 +- x-pack/test/typings/hapi.d.ts | 2 - x-pack/typings/hapi.d.ts | 4 +- 95 files changed, 1006 insertions(+), 619 deletions(-) create mode 100644 x-pack/legacy/plugins/task_manager/server/legacy.ts delete mode 100644 x-pack/legacy/plugins/task_manager/server/plugin.test.ts delete mode 100644 x-pack/legacy/plugins/task_manager/server/plugin.ts create mode 100644 x-pack/plugins/task_manager/kibana.json rename x-pack/{legacy => }/plugins/task_manager/server/README.md (68%) create mode 100644 x-pack/plugins/task_manager/server/config.test.ts create mode 100644 x-pack/plugins/task_manager/server/config.ts create mode 100644 x-pack/plugins/task_manager/server/create_task_manager.test.ts create mode 100644 x-pack/plugins/task_manager/server/create_task_manager.ts create mode 100644 x-pack/plugins/task_manager/server/index.ts rename x-pack/{legacy => }/plugins/task_manager/server/lib/correct_deprecated_fields.test.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/lib/correct_deprecated_fields.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/lib/fill_pool.test.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/lib/fill_pool.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/lib/get_template_version.test.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/lib/get_template_version.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/lib/identify_es_error.test.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/lib/identify_es_error.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/lib/intervals.test.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/lib/intervals.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/lib/middleware.test.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/lib/middleware.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/lib/pull_from_set.test.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/lib/pull_from_set.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/lib/result_type.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/lib/sanitize_task_definitions.test.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/lib/sanitize_task_definitions.ts (100%) create mode 100644 x-pack/plugins/task_manager/server/plugin.ts rename x-pack/{legacy => }/plugins/task_manager/server/queries/mark_available_tasks_as_claimed.test.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/queries/mark_available_tasks_as_claimed.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/queries/query_clauses.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/task.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/task_events.ts (100%) create mode 100644 x-pack/plugins/task_manager/server/task_manager.mock.ts rename x-pack/{legacy => }/plugins/task_manager/server/task_manager.test.ts (94%) rename x-pack/{legacy => }/plugins/task_manager/server/task_manager.ts (95%) rename x-pack/{legacy => }/plugins/task_manager/server/task_poller.test.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/task_poller.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/task_pool.test.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/task_pool.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/task_runner.test.ts (99%) rename x-pack/{legacy => }/plugins/task_manager/server/task_runner.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/task_store.test.ts (99%) rename x-pack/{legacy => }/plugins/task_manager/server/task_store.ts (98%) rename x-pack/{legacy => }/plugins/task_manager/server/test_utils/index.ts (100%) rename x-pack/{legacy => }/plugins/task_manager/server/types.ts (100%) diff --git a/src/core/server/mocks.ts b/src/core/server/mocks.ts index 073d380d3aa67..c7082d46313ae 100644 --- a/src/core/server/mocks.ts +++ b/src/core/server/mocks.ts @@ -37,6 +37,7 @@ export { elasticsearchServiceMock } from './elasticsearch/elasticsearch_service. export { httpServiceMock } from './http/http_service.mock'; export { loggingServiceMock } from './logging/logging_service.mock'; export { savedObjectsClientMock } from './saved_objects/service/saved_objects_client.mock'; +export { savedObjectsRepositoryMock } from './saved_objects/service/lib/repository.mock'; export { uiSettingsServiceMock } from './ui_settings/ui_settings_service.mock'; import { uuidServiceMock } from './uuid/uuid_service.mock'; diff --git a/x-pack/legacy/plugins/actions/server/action_type_registry.test.ts b/x-pack/legacy/plugins/actions/server/action_type_registry.test.ts index 2f15ae1c0a2b3..63f1b545179c7 100644 --- a/x-pack/legacy/plugins/actions/server/action_type_registry.test.ts +++ b/x-pack/legacy/plugins/actions/server/action_type_registry.test.ts @@ -4,13 +4,13 @@ * you may not use this file except in compliance with the Elastic License. */ -import { taskManagerMock } from '../../task_manager/server/task_manager.mock'; +import { taskManagerMock } from '../../../../plugins/task_manager/server/task_manager.mock'; import { ActionTypeRegistry } from './action_type_registry'; import { ExecutorType } from './types'; import { ActionExecutor, ExecutorError, TaskRunnerFactory } from './lib'; import { configUtilsMock } from './actions_config.mock'; -const mockTaskManager = taskManagerMock.create(); +const mockTaskManager = taskManagerMock.setup(); const actionTypeRegistryParams = { taskManager: mockTaskManager, taskRunnerFactory: new TaskRunnerFactory(new ActionExecutor()), diff --git a/x-pack/legacy/plugins/actions/server/action_type_registry.ts b/x-pack/legacy/plugins/actions/server/action_type_registry.ts index f66d1947c2b8b..351c1add7b451 100644 --- a/x-pack/legacy/plugins/actions/server/action_type_registry.ts +++ b/x-pack/legacy/plugins/actions/server/action_type_registry.ts @@ -6,11 +6,11 @@ import Boom from 'boom'; import { i18n } from '@kbn/i18n'; -import { TaskManagerSetupContract } from './shim'; -import { RunContext } from '../../task_manager/server'; +import { RunContext, TaskManagerSetupContract } from '../../../../plugins/task_manager/server'; import { ExecutorError, TaskRunnerFactory } from './lib'; import { ActionType } from './types'; import { ActionsConfigurationUtilities } from './actions_config'; + interface ConstructorOptions { taskManager: TaskManagerSetupContract; taskRunnerFactory: TaskRunnerFactory; diff --git a/x-pack/legacy/plugins/actions/server/actions_client.test.ts b/x-pack/legacy/plugins/actions/server/actions_client.test.ts index 9e75248c56cae..dfbd2db4b6842 100644 --- a/x-pack/legacy/plugins/actions/server/actions_client.test.ts +++ b/x-pack/legacy/plugins/actions/server/actions_client.test.ts @@ -10,7 +10,7 @@ import { ActionTypeRegistry } from './action_type_registry'; import { ActionsClient } from './actions_client'; import { ExecutorType } from './types'; import { ActionExecutor, TaskRunnerFactory } from './lib'; -import { taskManagerMock } from '../../task_manager/server/task_manager.mock'; +import { taskManagerMock } from '../../../../plugins/task_manager/server/task_manager.mock'; import { configUtilsMock } from './actions_config.mock'; import { getActionsConfigurationUtilities } from './actions_config'; @@ -23,7 +23,7 @@ const defaultKibanaIndex = '.kibana'; const savedObjectsClient = savedObjectsClientMock.create(); const scopedClusterClient = elasticsearchServiceMock.createScopedClusterClient(); -const mockTaskManager = taskManagerMock.create(); +const mockTaskManager = taskManagerMock.setup(); const actionTypeRegistryParams = { taskManager: mockTaskManager, diff --git a/x-pack/legacy/plugins/actions/server/builtin_action_types/index.test.ts b/x-pack/legacy/plugins/actions/server/builtin_action_types/index.test.ts index 3a0c9f415cc2b..5fcf39c2e8fdd 100644 --- a/x-pack/legacy/plugins/actions/server/builtin_action_types/index.test.ts +++ b/x-pack/legacy/plugins/actions/server/builtin_action_types/index.test.ts @@ -6,7 +6,7 @@ import { ActionExecutor, TaskRunnerFactory } from '../lib'; import { ActionTypeRegistry } from '../action_type_registry'; -import { taskManagerMock } from '../../../task_manager/server/task_manager.mock'; +import { taskManagerMock } from '../../../../../plugins/task_manager/server/task_manager.mock'; import { registerBuiltInActionTypes } from './index'; import { Logger } from '../../../../../../src/core/server'; import { loggingServiceMock } from '../../../../../../src/core/server/mocks'; @@ -20,7 +20,7 @@ export function createActionTypeRegistry(): { } { const logger = loggingServiceMock.create().get() as jest.Mocked; const actionTypeRegistry = new ActionTypeRegistry({ - taskManager: taskManagerMock.create(), + taskManager: taskManagerMock.setup(), taskRunnerFactory: new TaskRunnerFactory(new ActionExecutor()), actionsConfigUtils: configUtilsMock, }); diff --git a/x-pack/legacy/plugins/actions/server/create_execute_function.test.ts b/x-pack/legacy/plugins/actions/server/create_execute_function.test.ts index 6de446ee2da76..7dbcfce5ee335 100644 --- a/x-pack/legacy/plugins/actions/server/create_execute_function.test.ts +++ b/x-pack/legacy/plugins/actions/server/create_execute_function.test.ts @@ -4,11 +4,11 @@ * you may not use this file except in compliance with the Elastic License. */ -import { taskManagerMock } from '../../task_manager/server/task_manager.mock'; +import { taskManagerMock } from '../../../../plugins/task_manager/server/task_manager.mock'; import { createExecuteFunction } from './create_execute_function'; import { savedObjectsClientMock } from '../../../../../src/core/server/mocks'; -const mockTaskManager = taskManagerMock.create(); +const mockTaskManager = taskManagerMock.start(); const savedObjectsClient = savedObjectsClientMock.create(); const getBasePath = jest.fn(); diff --git a/x-pack/legacy/plugins/actions/server/create_execute_function.ts b/x-pack/legacy/plugins/actions/server/create_execute_function.ts index 8ff12b8c3fa4b..ddd8b1df2327b 100644 --- a/x-pack/legacy/plugins/actions/server/create_execute_function.ts +++ b/x-pack/legacy/plugins/actions/server/create_execute_function.ts @@ -5,7 +5,7 @@ */ import { SavedObjectsClientContract } from 'src/core/server'; -import { TaskManagerStartContract } from './shim'; +import { TaskManagerStartContract } from '../../../../plugins/task_manager/server'; import { GetBasePathFunction } from './types'; interface CreateExecuteFunctionOptions { diff --git a/x-pack/legacy/plugins/actions/server/init.ts b/x-pack/legacy/plugins/actions/server/init.ts index 5eab3418467bc..6f221b08c4bc5 100644 --- a/x-pack/legacy/plugins/actions/server/init.ts +++ b/x-pack/legacy/plugins/actions/server/init.ts @@ -4,11 +4,12 @@ * you may not use this file except in compliance with the Elastic License. */ +import { Legacy } from 'kibana'; import { Plugin } from './plugin'; -import { shim, Server } from './shim'; +import { shim } from './shim'; import { ActionsPlugin } from './types'; -export async function init(server: Server) { +export async function init(server: Legacy.Server) { const { initializerContext, coreSetup, coreStart, pluginsSetup, pluginsStart } = shim(server); const plugin = new Plugin(initializerContext); diff --git a/x-pack/legacy/plugins/actions/server/lib/task_runner_factory.test.ts b/x-pack/legacy/plugins/actions/server/lib/task_runner_factory.test.ts index 5b60696c42d52..ad2b74da0d7d4 100644 --- a/x-pack/legacy/plugins/actions/server/lib/task_runner_factory.test.ts +++ b/x-pack/legacy/plugins/actions/server/lib/task_runner_factory.test.ts @@ -7,7 +7,7 @@ import sinon from 'sinon'; import { ExecutorError } from './executor_error'; import { ActionExecutor } from './action_executor'; -import { ConcreteTaskInstance, TaskStatus } from '../../../task_manager/server'; +import { ConcreteTaskInstance, TaskStatus } from '../../../../../plugins/task_manager/server'; import { TaskRunnerFactory } from './task_runner_factory'; import { actionTypeRegistryMock } from '../action_type_registry.mock'; import { actionExecutorMock } from './action_executor.mock'; diff --git a/x-pack/legacy/plugins/actions/server/lib/task_runner_factory.ts b/x-pack/legacy/plugins/actions/server/lib/task_runner_factory.ts index ca6a726f40e14..2dc3d1161399e 100644 --- a/x-pack/legacy/plugins/actions/server/lib/task_runner_factory.ts +++ b/x-pack/legacy/plugins/actions/server/lib/task_runner_factory.ts @@ -6,7 +6,7 @@ import { ActionExecutorContract } from './action_executor'; import { ExecutorError } from './executor_error'; -import { RunContext } from '../../../task_manager/server'; +import { RunContext } from '../../../../../plugins/task_manager/server'; import { PluginStartContract as EncryptedSavedObjectsStartContract } from '../../../../../plugins/encrypted_saved_objects/server'; import { ActionTaskParams, GetBasePathFunction, SpaceIdToNamespaceFunction } from '../types'; diff --git a/x-pack/legacy/plugins/actions/server/plugin.ts b/x-pack/legacy/plugins/actions/server/plugin.ts index 48f99ba5135b7..ffc4a9cf90e54 100644 --- a/x-pack/legacy/plugins/actions/server/plugin.ts +++ b/x-pack/legacy/plugins/actions/server/plugin.ts @@ -93,7 +93,7 @@ export class Plugin { const actionsConfigUtils = getActionsConfigurationUtilities(config as ActionsConfigType); const actionTypeRegistry = new ActionTypeRegistry({ taskRunnerFactory, - taskManager: plugins.task_manager, + taskManager: plugins.taskManager, actionsConfigUtils, }); this.taskRunnerFactory = taskRunnerFactory; @@ -164,7 +164,7 @@ export class Plugin { }); const executeFn = createExecuteFunction({ - taskManager: plugins.task_manager, + taskManager: plugins.taskManager, getScopedSavedObjectsClient: core.savedObjects.getScopedSavedObjectsClient, getBasePath, }); diff --git a/x-pack/legacy/plugins/actions/server/shim.ts b/x-pack/legacy/plugins/actions/server/shim.ts index f8aa9b8d7a25c..8077dc67c92c4 100644 --- a/x-pack/legacy/plugins/actions/server/shim.ts +++ b/x-pack/legacy/plugins/actions/server/shim.ts @@ -8,7 +8,11 @@ import Hapi from 'hapi'; import { Legacy } from 'kibana'; import * as Rx from 'rxjs'; import { ActionsConfigType } from './types'; -import { TaskManager } from '../../task_manager/server'; +import { + TaskManagerStartContract, + TaskManagerSetupContract, +} from '../../../../plugins/task_manager/server'; +import { getTaskManagerSetup, getTaskManagerStart } from '../../task_manager/server'; import { XPackMainPlugin } from '../../xpack_main/server/xpack_main'; import KbnServer from '../../../../../src/legacy/server/kbn_server'; import { LegacySpacesPlugin as SpacesPluginStartContract } from '../../spaces'; @@ -24,16 +28,6 @@ import { } from '../../../../../src/core/server'; import { LicensingPluginSetup } from '../../../../plugins/licensing/server'; -// Extend PluginProperties to indicate which plugins are guaranteed to exist -// due to being marked as dependencies -interface Plugins extends Hapi.PluginProperties { - task_manager: TaskManager; -} - -export interface Server extends Legacy.Server { - plugins: Plugins; -} - export interface KibanaConfig { index: string; } @@ -41,14 +35,9 @@ export interface KibanaConfig { /** * Shim what we're thinking setup and start contracts will look like */ -export type TaskManagerStartContract = Pick; export type XPackMainPluginSetupContract = Pick; export type SecurityPluginSetupContract = Pick; export type SecurityPluginStartContract = Pick; -export type TaskManagerSetupContract = Pick< - TaskManager, - 'addMiddleware' | 'registerTaskDefinitions' ->; /** * New platform interfaces @@ -74,7 +63,7 @@ export interface ActionsCoreStart { } export interface ActionsPluginsSetup { security?: SecurityPluginSetupContract; - task_manager: TaskManagerSetupContract; + taskManager: TaskManagerSetupContract; xpack_main: XPackMainPluginSetupContract; encryptedSavedObjects: EncryptedSavedObjectsSetupContract; licensing: LicensingPluginSetup; @@ -83,7 +72,7 @@ export interface ActionsPluginsStart { security?: SecurityPluginStartContract; spaces: () => SpacesPluginStartContract | undefined; encryptedSavedObjects: EncryptedSavedObjectsStartContract; - task_manager: TaskManagerStartContract; + taskManager: TaskManagerStartContract; } /** @@ -92,7 +81,7 @@ export interface ActionsPluginsStart { * @param server Hapi server instance */ export function shim( - server: Server + server: Legacy.Server ): { initializerContext: ActionsPluginInitializerContext; coreSetup: ActionsCoreSetup; @@ -132,7 +121,7 @@ export function shim( const pluginsSetup: ActionsPluginsSetup = { security: newPlatform.setup.plugins.security as SecurityPluginSetupContract | undefined, - task_manager: server.plugins.task_manager, + taskManager: getTaskManagerSetup(server)!, xpack_main: server.plugins.xpack_main, encryptedSavedObjects: newPlatform.setup.plugins .encryptedSavedObjects as EncryptedSavedObjectsSetupContract, @@ -146,7 +135,7 @@ export function shim( spaces: () => server.plugins.spaces, encryptedSavedObjects: newPlatform.start.plugins .encryptedSavedObjects as EncryptedSavedObjectsStartContract, - task_manager: server.plugins.task_manager, + taskManager: getTaskManagerStart(server)!, }; return { diff --git a/x-pack/legacy/plugins/alerting/server/alert_type_registry.test.ts b/x-pack/legacy/plugins/alerting/server/alert_type_registry.test.ts index 8e96ad8dae31c..e1a05d6460e25 100644 --- a/x-pack/legacy/plugins/alerting/server/alert_type_registry.test.ts +++ b/x-pack/legacy/plugins/alerting/server/alert_type_registry.test.ts @@ -6,10 +6,9 @@ import { TaskRunnerFactory } from './task_runner'; import { AlertTypeRegistry } from './alert_type_registry'; -import { taskManagerMock } from '../../task_manager/server/task_manager.mock'; - -const taskManager = taskManagerMock.create(); +import { taskManagerMock } from '../../../../plugins/task_manager/server/task_manager.mock'; +const taskManager = taskManagerMock.setup(); const alertTypeRegistryParams = { taskManager, taskRunnerFactory: new TaskRunnerFactory(), diff --git a/x-pack/legacy/plugins/alerting/server/alert_type_registry.ts b/x-pack/legacy/plugins/alerting/server/alert_type_registry.ts index 2003e810a05b5..1e9007202c452 100644 --- a/x-pack/legacy/plugins/alerting/server/alert_type_registry.ts +++ b/x-pack/legacy/plugins/alerting/server/alert_type_registry.ts @@ -6,9 +6,8 @@ import Boom from 'boom'; import { i18n } from '@kbn/i18n'; +import { RunContext, TaskManagerSetupContract } from '../../../../plugins/task_manager/server'; import { TaskRunnerFactory } from './task_runner'; -import { RunContext } from '../../task_manager'; -import { TaskManagerSetupContract } from './shim'; import { AlertType } from './types'; interface ConstructorOptions { diff --git a/x-pack/legacy/plugins/alerting/server/alerts_client.test.ts b/x-pack/legacy/plugins/alerting/server/alerts_client.test.ts index 32293d9755a2a..2af66059d9fed 100644 --- a/x-pack/legacy/plugins/alerting/server/alerts_client.test.ts +++ b/x-pack/legacy/plugins/alerting/server/alerts_client.test.ts @@ -7,14 +7,14 @@ import uuid from 'uuid'; import { schema } from '@kbn/config-schema'; import { AlertsClient } from './alerts_client'; import { savedObjectsClientMock, loggingServiceMock } from '../../../../../src/core/server/mocks'; -import { taskManagerMock } from '../../task_manager/server/task_manager.mock'; +import { taskManagerMock } from '../../../../plugins/task_manager/server/task_manager.mock'; import { alertTypeRegistryMock } from './alert_type_registry.mock'; -import { TaskStatus } from '../../task_manager/server'; +import { TaskStatus } from '../../../../plugins/task_manager/server'; import { IntervalSchedule } from './types'; import { resolvable } from './test_utils'; import { encryptedSavedObjectsMock } from '../../../../plugins/encrypted_saved_objects/server/mocks'; -const taskManager = taskManagerMock.create(); +const taskManager = taskManagerMock.start(); const alertTypeRegistry = alertTypeRegistryMock.create(); const savedObjectsClient = savedObjectsClientMock.create(); const encryptedSavedObjects = encryptedSavedObjectsMock.createStart(); diff --git a/x-pack/legacy/plugins/alerting/server/alerts_client.ts b/x-pack/legacy/plugins/alerting/server/alerts_client.ts index 33a6b716e9b8a..fe96a233b8663 100644 --- a/x-pack/legacy/plugins/alerting/server/alerts_client.ts +++ b/x-pack/legacy/plugins/alerting/server/alerts_client.ts @@ -22,7 +22,6 @@ import { AlertType, IntervalSchedule, } from './types'; -import { TaskManagerStartContract } from './shim'; import { validateAlertTypeParams } from './lib'; import { InvalidateAPIKeyParams, @@ -30,6 +29,7 @@ import { InvalidateAPIKeyResult as SecurityPluginInvalidateAPIKeyResult, } from '../../../../plugins/security/server'; import { PluginStartContract as EncryptedSavedObjectsStartContract } from '../../../../plugins/encrypted_saved_objects/server'; +import { TaskManagerStartContract } from '../../../../plugins/task_manager/server'; type NormalizedAlertAction = Omit; export type CreateAPIKeyResult = diff --git a/x-pack/legacy/plugins/alerting/server/alerts_client_factory.test.ts b/x-pack/legacy/plugins/alerting/server/alerts_client_factory.test.ts index 519001d07e089..754e02a3f1e5e 100644 --- a/x-pack/legacy/plugins/alerting/server/alerts_client_factory.test.ts +++ b/x-pack/legacy/plugins/alerting/server/alerts_client_factory.test.ts @@ -7,7 +7,7 @@ import { Request } from 'hapi'; import { AlertsClientFactory, ConstructorOpts } from './alerts_client_factory'; import { alertTypeRegistryMock } from './alert_type_registry.mock'; -import { taskManagerMock } from '../../task_manager/server/task_manager.mock'; +import { taskManagerMock } from '../../../../plugins/task_manager/server/task_manager.mock'; import { KibanaRequest } from '../../../../../src/core/server'; import { loggingServiceMock } from '../../../../../src/core/server/mocks'; import { encryptedSavedObjectsMock } from '../../../../plugins/encrypted_saved_objects/server/mocks'; @@ -23,7 +23,7 @@ const securityPluginSetup = { }; const alertsClientFactoryParams: jest.Mocked = { logger: loggingServiceMock.create().get(), - taskManager: taskManagerMock.create(), + taskManager: taskManagerMock.start(), alertTypeRegistry: alertTypeRegistryMock.create(), getSpaceId: jest.fn(), spaceIdToNamespace: jest.fn(), diff --git a/x-pack/legacy/plugins/alerting/server/alerts_client_factory.ts b/x-pack/legacy/plugins/alerting/server/alerts_client_factory.ts index 94a396fbaa806..eab1cc3ce627b 100644 --- a/x-pack/legacy/plugins/alerting/server/alerts_client_factory.ts +++ b/x-pack/legacy/plugins/alerting/server/alerts_client_factory.ts @@ -8,10 +8,11 @@ import Hapi from 'hapi'; import uuid from 'uuid'; import { AlertsClient } from './alerts_client'; import { AlertTypeRegistry, SpaceIdToNamespaceFunction } from './types'; -import { SecurityPluginStartContract, TaskManagerStartContract } from './shim'; +import { SecurityPluginStartContract } from './shim'; import { KibanaRequest, Logger } from '../../../../../src/core/server'; import { InvalidateAPIKeyParams } from '../../../../plugins/security/server'; import { PluginStartContract as EncryptedSavedObjectsStartContract } from '../../../../plugins/encrypted_saved_objects/server'; +import { TaskManagerStartContract } from '../../../../plugins/task_manager/server'; export interface ConstructorOpts { logger: Logger; diff --git a/x-pack/legacy/plugins/alerting/server/plugin.ts b/x-pack/legacy/plugins/alerting/server/plugin.ts index fb16f579d4c70..357db9e3df97e 100644 --- a/x-pack/legacy/plugins/alerting/server/plugin.ts +++ b/x-pack/legacy/plugins/alerting/server/plugin.ts @@ -79,7 +79,7 @@ export class Plugin { }); const alertTypeRegistry = new AlertTypeRegistry({ - taskManager: plugins.task_manager, + taskManager: plugins.taskManager, taskRunnerFactory: this.taskRunnerFactory, }); this.alertTypeRegistry = alertTypeRegistry; @@ -116,7 +116,7 @@ export class Plugin { const alertsClientFactory = new AlertsClientFactory({ alertTypeRegistry: this.alertTypeRegistry!, logger: this.logger, - taskManager: plugins.task_manager, + taskManager: plugins.taskManager, securityPluginSetup: plugins.security, encryptedSavedObjectsPlugin: plugins.encryptedSavedObjects, spaceIdToNamespace, diff --git a/x-pack/legacy/plugins/alerting/server/shim.ts b/x-pack/legacy/plugins/alerting/server/shim.ts index ae29048d83dd9..ccc10f929e123 100644 --- a/x-pack/legacy/plugins/alerting/server/shim.ts +++ b/x-pack/legacy/plugins/alerting/server/shim.ts @@ -7,7 +7,11 @@ import Hapi from 'hapi'; import { Legacy } from 'kibana'; import { LegacySpacesPlugin as SpacesPluginStartContract } from '../../spaces'; -import { TaskManager } from '../../task_manager/server'; +import { + TaskManagerStartContract, + TaskManagerSetupContract, +} from '../../../../plugins/task_manager/server'; +import { getTaskManagerSetup, getTaskManagerStart } from '../../task_manager/server'; import { XPackMainPlugin } from '../../xpack_main/server/xpack_main'; import KbnServer from '../../../../../src/legacy/server/kbn_server'; import { @@ -31,7 +35,6 @@ import { LicensingPluginSetup } from '../../../../plugins/licensing/server'; // due to being marked as dependencies interface Plugins extends Hapi.PluginProperties { actions: ActionsPlugin; - task_manager: TaskManager; } export interface Server extends Legacy.Server { @@ -41,17 +44,9 @@ export interface Server extends Legacy.Server { /** * Shim what we're thinking setup and start contracts will look like */ -export type TaskManagerStartContract = Pick< - TaskManager, - 'schedule' | 'fetch' | 'remove' | 'runNow' ->; export type SecurityPluginSetupContract = Pick; export type SecurityPluginStartContract = Pick; export type XPackMainPluginSetupContract = Pick; -export type TaskManagerSetupContract = Pick< - TaskManager, - 'addMiddleware' | 'registerTaskDefinitions' ->; /** * New platform interfaces @@ -73,7 +68,7 @@ export interface AlertingCoreStart { } export interface AlertingPluginsSetup { security?: SecurityPluginSetupContract; - task_manager: TaskManagerSetupContract; + taskManager: TaskManagerSetupContract; actions: ActionsPluginSetupContract; xpack_main: XPackMainPluginSetupContract; encryptedSavedObjects: EncryptedSavedObjectsSetupContract; @@ -84,7 +79,7 @@ export interface AlertingPluginsStart { security?: SecurityPluginStartContract; spaces: () => SpacesPluginStartContract | undefined; encryptedSavedObjects: EncryptedSavedObjectsStartContract; - task_manager: TaskManagerStartContract; + taskManager: TaskManagerStartContract; } /** @@ -121,7 +116,7 @@ export function shim( const pluginsSetup: AlertingPluginsSetup = { security: newPlatform.setup.plugins.security as SecurityPluginSetupContract | undefined, - task_manager: server.plugins.task_manager, + taskManager: getTaskManagerSetup(server)!, actions: server.plugins.actions.setup, xpack_main: server.plugins.xpack_main, encryptedSavedObjects: newPlatform.setup.plugins @@ -137,7 +132,7 @@ export function shim( spaces: () => server.plugins.spaces, encryptedSavedObjects: newPlatform.start.plugins .encryptedSavedObjects as EncryptedSavedObjectsStartContract, - task_manager: server.plugins.task_manager, + taskManager: getTaskManagerStart(server)!, }; return { diff --git a/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.test.ts b/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.test.ts index dc220067bd35a..45ee13e2370d2 100644 --- a/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.test.ts +++ b/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.test.ts @@ -7,7 +7,7 @@ import sinon from 'sinon'; import { schema } from '@kbn/config-schema'; import { AlertExecutorOptions } from '../types'; -import { ConcreteTaskInstance, TaskStatus } from '../../../task_manager'; +import { ConcreteTaskInstance, TaskStatus } from '../../../../../plugins/task_manager/server'; import { TaskRunnerContext } from './task_runner_factory'; import { TaskRunner } from './task_runner'; import { encryptedSavedObjectsMock } from '../../../../../plugins/encrypted_saved_objects/server/mocks'; diff --git a/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.ts b/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.ts index c6f1a02da8dcd..0f643e3d3121c 100644 --- a/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.ts +++ b/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.ts @@ -8,7 +8,7 @@ import { pick, mapValues, omit } from 'lodash'; import { Logger } from '../../../../../../src/core/server'; import { SavedObject } from '../../../../../../src/core/server'; import { TaskRunnerContext } from './task_runner_factory'; -import { ConcreteTaskInstance } from '../../../task_manager'; +import { ConcreteTaskInstance } from '../../../../../plugins/task_manager/server'; import { createExecutionHandler } from './create_execution_handler'; import { AlertInstance, createAlertInstanceFactory } from '../alert_instance'; import { getNextRunAt } from './get_next_run_at'; diff --git a/x-pack/legacy/plugins/alerting/server/task_runner/task_runner_factory.test.ts b/x-pack/legacy/plugins/alerting/server/task_runner/task_runner_factory.test.ts index 2ea1256352bec..543b9e7d32e12 100644 --- a/x-pack/legacy/plugins/alerting/server/task_runner/task_runner_factory.test.ts +++ b/x-pack/legacy/plugins/alerting/server/task_runner/task_runner_factory.test.ts @@ -5,7 +5,7 @@ */ import sinon from 'sinon'; -import { ConcreteTaskInstance, TaskStatus } from '../../../task_manager'; +import { ConcreteTaskInstance, TaskStatus } from '../../../../../plugins/task_manager/server'; import { TaskRunnerContext, TaskRunnerFactory } from './task_runner_factory'; import { encryptedSavedObjectsMock } from '../../../../../plugins/encrypted_saved_objects/server/mocks'; import { diff --git a/x-pack/legacy/plugins/alerting/server/task_runner/task_runner_factory.ts b/x-pack/legacy/plugins/alerting/server/task_runner/task_runner_factory.ts index 7186e1e729bda..7178fa4f01282 100644 --- a/x-pack/legacy/plugins/alerting/server/task_runner/task_runner_factory.ts +++ b/x-pack/legacy/plugins/alerting/server/task_runner/task_runner_factory.ts @@ -4,7 +4,7 @@ * you may not use this file except in compliance with the Elastic License. */ import { Logger } from '../../../../../../src/core/server'; -import { RunContext } from '../../../task_manager'; +import { RunContext } from '../../../../../plugins/task_manager/server'; import { PluginStartContract as EncryptedSavedObjectsStartContract } from '../../../../../plugins/encrypted_saved_objects/server'; import { PluginStartContract as ActionsPluginStartContract } from '../../../actions'; import { diff --git a/x-pack/legacy/plugins/lens/index.ts b/x-pack/legacy/plugins/lens/index.ts index c4a684381b17c..a4eb24d4a4de4 100644 --- a/x-pack/legacy/plugins/lens/index.ts +++ b/x-pack/legacy/plugins/lens/index.ts @@ -11,6 +11,7 @@ import KbnServer, { Server } from 'src/legacy/server/kbn_server'; import mappings from './mappings.json'; import { PLUGIN_ID, getEditPath, NOT_INTERNATIONALIZED_PRODUCT_NAME } from './common'; import { lensServerPlugin } from './server'; +import { getTaskManagerSetup, getTaskManagerStart } from '../task_manager/server'; export const lens: LegacyPluginInitializer = kibana => { return new kibana.Plugin({ @@ -64,6 +65,12 @@ export const lens: LegacyPluginInitializer = kibana => { savedObjects: server.savedObjects, config: server.config(), server, + taskManager: getTaskManagerSetup(server)!, + }); + + plugin.start(kbnServer.newPlatform.start.core, { + server, + taskManager: getTaskManagerStart(server)!, }); server.events.on('stop', () => { diff --git a/x-pack/legacy/plugins/lens/server/plugin.tsx b/x-pack/legacy/plugins/lens/server/plugin.tsx index 0223b90c37046..f80d52248b484 100644 --- a/x-pack/legacy/plugins/lens/server/plugin.tsx +++ b/x-pack/legacy/plugins/lens/server/plugin.tsx @@ -5,28 +5,51 @@ */ import { Server, KibanaConfig } from 'src/legacy/server/kbn_server'; -import { Plugin, CoreSetup, SavedObjectsLegacyService } from 'src/core/server'; +import { Plugin, CoreSetup, CoreStart, SavedObjectsLegacyService } from 'src/core/server'; import { UsageCollectionSetup } from 'src/plugins/usage_collection/server'; +import { Subject } from 'rxjs'; +import { first } from 'rxjs/operators'; +import { + TaskManagerSetupContract, + TaskManagerStartContract, +} from '../../../../plugins/task_manager/server'; import { setupRoutes } from './routes'; -import { registerLensUsageCollector, initializeLensTelemetry } from './usage'; +import { + registerLensUsageCollector, + initializeLensTelemetry, + scheduleLensTelemetry, +} from './usage'; export interface PluginSetupContract { savedObjects: SavedObjectsLegacyService; usageCollection: UsageCollectionSetup; config: KibanaConfig; server: Server; + taskManager: TaskManagerSetupContract; } +export interface PluginStartContract { + server: Server; + taskManager: TaskManagerStartContract; +} + +const taskManagerStartContract$ = new Subject(); + export class LensServer implements Plugin<{}, {}, {}, {}> { setup(core: CoreSetup, plugins: PluginSetupContract) { setupRoutes(core, plugins); - registerLensUsageCollector(plugins.usageCollection, plugins.server); - initializeLensTelemetry(core, plugins.server); - + registerLensUsageCollector( + plugins.usageCollection, + taskManagerStartContract$.pipe(first()).toPromise() + ); + initializeLensTelemetry(plugins.server, plugins.taskManager); return {}; } - start() { + start(core: CoreStart, plugins: PluginStartContract) { + scheduleLensTelemetry(plugins.server, plugins.taskManager); + taskManagerStartContract$.next(plugins.taskManager); + taskManagerStartContract$.complete(); return {}; } diff --git a/x-pack/legacy/plugins/lens/server/usage/collectors.ts b/x-pack/legacy/plugins/lens/server/usage/collectors.ts index 274b72c33e59a..666b3718d5125 100644 --- a/x-pack/legacy/plugins/lens/server/usage/collectors.ts +++ b/x-pack/legacy/plugins/lens/server/usage/collectors.ts @@ -6,32 +6,25 @@ import moment from 'moment'; import { get } from 'lodash'; -import { Server } from 'src/legacy/server/kbn_server'; import { UsageCollectionSetup } from 'src/plugins/usage_collection/server'; +import { TaskManagerStartContract } from '../../../../../plugins/task_manager/server'; import { LensUsage, LensTelemetryState } from './types'; -export function registerLensUsageCollector(usageCollection: UsageCollectionSetup, server: Server) { +export function registerLensUsageCollector( + usageCollection: UsageCollectionSetup, + taskManager: Promise +) { let isCollectorReady = false; - async function determineIfTaskManagerIsReady() { - let isReady = false; - try { - isReady = await isTaskManagerReady(server); - } catch (err) {} // eslint-disable-line - - if (isReady) { - isCollectorReady = true; - } else { - setTimeout(determineIfTaskManagerIsReady, 500); - } - } - determineIfTaskManagerIsReady(); - + taskManager.then(() => { + // mark lensUsageCollector as ready to collect when the TaskManager is ready + isCollectorReady = true; + }); const lensUsageCollector = usageCollection.makeUsageCollector({ type: 'lens', fetch: async (): Promise => { try { - const docs = await getLatestTaskState(server); + const docs = await getLatestTaskState(await taskManager); // get the accumulated state from the recurring task const state: LensTelemetryState = get(docs, '[0].state'); @@ -73,17 +66,7 @@ function addEvents(prevEvents: Record, newEvents: Record Promise; -export function initializeLensTelemetry(core: CoreSetup, server: Server) { - registerLensTelemetryTask(core, server); - scheduleTasks(server); -} - -function registerLensTelemetryTask(core: CoreSetup, server: Server) { - const taskManager = server.plugins.task_manager; - +export function initializeLensTelemetry(server: Server, taskManager?: TaskManagerSetupContract) { if (!taskManager) { server.log(['debug', 'telemetry'], `Task manager is not available`); - return; + } else { + registerLensTelemetryTask(server, taskManager); } +} +export function scheduleLensTelemetry(server: Server, taskManager?: TaskManagerStartContract) { + if (taskManager) { + scheduleTasks(server, taskManager); + } +} + +function registerLensTelemetryTask(server: Server, taskManager: TaskManagerSetupContract) { taskManager.registerTaskDefinitions({ [TELEMETRY_TASK_TYPE]: { title: 'Lens telemetry fetch task', @@ -62,17 +68,11 @@ function registerLensTelemetryTask(core: CoreSetup, server: Server) { }); } -function scheduleTasks(server: Server) { - const taskManager = server.plugins.task_manager; +function scheduleTasks(server: Server, taskManager: TaskManagerStartContract) { const { kbnServer } = (server.plugins.xpack_main as XPackMainPlugin & { status: { plugin: { kbnServer: KbnServer } }; }).status.plugin; - if (!taskManager) { - server.log(['debug', 'telemetry'], `Task manager is not available`); - return; - } - kbnServer.afterPluginsInit(() => { // The code block below can't await directly within "afterPluginsInit" // callback due to circular dependency The server isn't "ready" until diff --git a/x-pack/legacy/plugins/maps/server/test_utils/index.js b/x-pack/legacy/plugins/maps/server/test_utils/index.js index 944d65a21aae2..f208917e20924 100644 --- a/x-pack/legacy/plugins/maps/server/test_utils/index.js +++ b/x-pack/legacy/plugins/maps/server/test_utils/index.js @@ -25,24 +25,3 @@ export const getMockCallWithInternal = (hits = defaultMockSavedObjects) => { export const getMockTaskFetch = (docs = defaultMockTaskDocs) => { return () => Promise.resolve({ docs }); }; - -export const getMockKbnServer = ( - mockCallWithInternal = getMockCallWithInternal(), - mockTaskFetch = getMockTaskFetch() -) => ({ - plugins: { - elasticsearch: { - getCluster: () => ({ - callWithInternalUser: mockCallWithInternal, - }), - }, - xpack_main: {}, - task_manager: { - registerTaskDefinitions: () => undefined, - schedule: () => Promise.resolve(), - fetch: mockTaskFetch, - }, - }, - config: () => ({ get: () => '' }), - log: () => undefined, -}); diff --git a/x-pack/legacy/plugins/oss_telemetry/index.ts b/x-pack/legacy/plugins/oss_telemetry/index.ts index 8b16c7cf13cad..fce861c7d3f46 100644 --- a/x-pack/legacy/plugins/oss_telemetry/index.ts +++ b/x-pack/legacy/plugins/oss_telemetry/index.ts @@ -4,10 +4,12 @@ * you may not use this file except in compliance with the Elastic License. */ -import { Logger, PluginInitializerContext } from 'kibana/server'; +import { Logger, PluginInitializerContext, CoreStart } from 'kibana/server'; +import { Legacy } from 'kibana'; import { PLUGIN_ID } from './constants'; import { OssTelemetryPlugin } from './server/plugin'; import { LegacyPluginInitializer } from '../../../../src/legacy/plugin_discovery/types'; +import { getTaskManagerSetup, getTaskManagerStart } from '../task_manager/server'; export const ossTelemetry: LegacyPluginInitializer = kibana => { return new kibana.Plugin({ @@ -15,7 +17,7 @@ export const ossTelemetry: LegacyPluginInitializer = kibana => { require: ['elasticsearch', 'xpack_main'], configPrefix: 'xpack.oss_telemetry', - init(server) { + init(server: Legacy.Server) { const plugin = new OssTelemetryPlugin({ logger: { get: () => @@ -27,14 +29,24 @@ export const ossTelemetry: LegacyPluginInitializer = kibana => { } as Logger), }, } as PluginInitializerContext); - plugin.setup(server.newPlatform.setup.core, { + + const deps = { usageCollection: server.newPlatform.setup.plugins.usageCollection, - taskManager: server.plugins.task_manager, __LEGACY: { config: server.config(), xpackMainStatus: ((server.plugins.xpack_main as unknown) as { status: any }).status .plugin, }, + }; + + plugin.setup(server.newPlatform.setup.core, { + ...deps, + taskManager: getTaskManagerSetup(server), + }); + + plugin.start((server.newPlatform.setup.core as unknown) as CoreStart, { + ...deps, + taskManager: getTaskManagerStart(server), }); }, }); diff --git a/x-pack/legacy/plugins/oss_telemetry/server/lib/collectors/index.ts b/x-pack/legacy/plugins/oss_telemetry/server/lib/collectors/index.ts index 3b47099fdc462..9d547c1b22099 100644 --- a/x-pack/legacy/plugins/oss_telemetry/server/lib/collectors/index.ts +++ b/x-pack/legacy/plugins/oss_telemetry/server/lib/collectors/index.ts @@ -5,8 +5,8 @@ */ import { registerVisualizationsCollector } from './visualizations/register_usage_collector'; -import { OssTelemetrySetupDependencies } from '../../plugin'; +import { OssTelemetryStartDependencies } from '../../plugin'; -export function registerCollectors(deps: OssTelemetrySetupDependencies) { +export function registerCollectors(deps: OssTelemetryStartDependencies) { registerVisualizationsCollector(deps.usageCollection, deps.taskManager); } diff --git a/x-pack/legacy/plugins/oss_telemetry/server/lib/collectors/visualizations/get_usage_collector.test.ts b/x-pack/legacy/plugins/oss_telemetry/server/lib/collectors/visualizations/get_usage_collector.test.ts index ec35266646650..ce106d1a64fd6 100644 --- a/x-pack/legacy/plugins/oss_telemetry/server/lib/collectors/visualizations/get_usage_collector.test.ts +++ b/x-pack/legacy/plugins/oss_telemetry/server/lib/collectors/visualizations/get_usage_collector.test.ts @@ -4,29 +4,37 @@ * you may not use this file except in compliance with the Elastic License. */ -import { getMockTaskFetch, getMockTaskManager } from '../../../../test_utils'; +import { + getMockTaskFetch, + getMockThrowingTaskFetch, + getMockTaskInstance, +} from '../../../../test_utils'; +import { taskManagerMock } from '../../../../../../../plugins/task_manager/server/task_manager.mock'; import { getUsageCollector } from './get_usage_collector'; describe('getVisualizationsCollector#fetch', () => { test('can return empty stats', async () => { - const { type, fetch } = getUsageCollector(getMockTaskManager()); + const { type, fetch } = getUsageCollector(taskManagerMock.start(getMockTaskFetch())); expect(type).toBe('visualization_types'); const fetchResult = await fetch(); expect(fetchResult).toEqual({}); }); test('provides known stats', async () => { - const mockTaskFetch = getMockTaskFetch([ - { - state: { - runs: 1, - stats: { comic_books: { total: 16, max: 12, min: 2, avg: 6 } }, - }, - taskType: 'test', - params: {}, - }, - ]); - const { type, fetch } = getUsageCollector(getMockTaskManager(mockTaskFetch)); + const { type, fetch } = getUsageCollector( + taskManagerMock.start( + getMockTaskFetch([ + getMockTaskInstance({ + state: { + runs: 1, + stats: { comic_books: { total: 16, max: 12, min: 2, avg: 6 } }, + }, + taskType: 'test', + params: {}, + }), + ]) + ) + ); expect(type).toBe('visualization_types'); const fetchResult = await fetch(); expect(fetchResult).toEqual({ comic_books: { avg: 6, max: 12, min: 2, total: 16 } }); @@ -34,20 +42,21 @@ describe('getVisualizationsCollector#fetch', () => { describe('Error handling', () => { test('Silently handles Task Manager NotInitialized', async () => { - const mockTaskFetch = jest.fn(() => { - throw new Error('NotInitialized taskManager is still waiting for plugins to load'); - }); - const { fetch } = getUsageCollector(getMockTaskManager(mockTaskFetch)); + const { fetch } = getUsageCollector( + taskManagerMock.start( + getMockThrowingTaskFetch( + new Error('NotInitialized taskManager is still waiting for plugins to load') + ) + ) + ); const result = await fetch(); expect(result).toBe(undefined); }); // In real life, the CollectorSet calls fetch and handles errors test('defers the errors', async () => { - const mockTaskFetch = jest.fn(() => { - throw new Error('BOOM'); - }); - - const { fetch } = getUsageCollector(getMockTaskManager(mockTaskFetch)); + const { fetch } = getUsageCollector( + taskManagerMock.start(getMockThrowingTaskFetch(new Error('BOOM'))) + ); await expect(fetch()).rejects.toThrowErrorMatchingInlineSnapshot(`"BOOM"`); }); }); diff --git a/x-pack/legacy/plugins/oss_telemetry/server/lib/collectors/visualizations/get_usage_collector.ts b/x-pack/legacy/plugins/oss_telemetry/server/lib/collectors/visualizations/get_usage_collector.ts index 11dbddc00f830..bc0d10860a667 100644 --- a/x-pack/legacy/plugins/oss_telemetry/server/lib/collectors/visualizations/get_usage_collector.ts +++ b/x-pack/legacy/plugins/oss_telemetry/server/lib/collectors/visualizations/get_usage_collector.ts @@ -5,15 +5,15 @@ */ import { get } from 'lodash'; -import { PluginSetupContract as TaskManagerPluginSetupContract } from '../../../../../task_manager/server/plugin'; import { PLUGIN_ID, VIS_TELEMETRY_TASK, VIS_USAGE_TYPE } from '../../../../constants'; +import { TaskManagerStartContract } from '../../../../../../../plugins/task_manager/server'; -async function isTaskManagerReady(taskManager: TaskManagerPluginSetupContract | undefined) { +async function isTaskManagerReady(taskManager?: TaskManagerStartContract) { const result = await fetch(taskManager); return result !== null; } -async function fetch(taskManager: TaskManagerPluginSetupContract | undefined) { +async function fetch(taskManager?: TaskManagerStartContract) { if (!taskManager) { return null; } @@ -38,7 +38,7 @@ async function fetch(taskManager: TaskManagerPluginSetupContract | undefined) { return docs; } -export function getUsageCollector(taskManager: TaskManagerPluginSetupContract | undefined) { +export function getUsageCollector(taskManager?: TaskManagerStartContract) { let isCollectorReady = false; async function determineIfTaskManagerIsReady() { let isReady = false; diff --git a/x-pack/legacy/plugins/oss_telemetry/server/lib/collectors/visualizations/register_usage_collector.ts b/x-pack/legacy/plugins/oss_telemetry/server/lib/collectors/visualizations/register_usage_collector.ts index 46b86091c9db1..657f1c725f4e0 100644 --- a/x-pack/legacy/plugins/oss_telemetry/server/lib/collectors/visualizations/register_usage_collector.ts +++ b/x-pack/legacy/plugins/oss_telemetry/server/lib/collectors/visualizations/register_usage_collector.ts @@ -5,12 +5,12 @@ */ import { UsageCollectionSetup } from 'src/plugins/usage_collection/server'; -import { PluginSetupContract as TaskManagerPluginSetupContract } from '../../../../../task_manager/server/plugin'; +import { TaskManagerStartContract } from '../../../../../../../plugins/task_manager/server'; import { getUsageCollector } from './get_usage_collector'; export function registerVisualizationsCollector( collectorSet: UsageCollectionSetup, - taskManager: TaskManagerPluginSetupContract | undefined + taskManager?: TaskManagerStartContract ): void { const collector = collectorSet.makeUsageCollector(getUsageCollector(taskManager)); collectorSet.registerCollector(collector); diff --git a/x-pack/legacy/plugins/oss_telemetry/server/lib/tasks/index.ts b/x-pack/legacy/plugins/oss_telemetry/server/lib/tasks/index.ts index c9714306d73c5..cf7295f67a231 100644 --- a/x-pack/legacy/plugins/oss_telemetry/server/lib/tasks/index.ts +++ b/x-pack/legacy/plugins/oss_telemetry/server/lib/tasks/index.ts @@ -5,12 +5,15 @@ */ import { CoreSetup, Logger } from 'kibana/server'; -import { PluginSetupContract as TaskManagerPluginSetupContract } from '../../../../task_manager/server/plugin'; import { PLUGIN_ID, VIS_TELEMETRY_TASK } from '../../../constants'; import { visualizationsTaskRunner } from './visualizations/task_runner'; import KbnServer from '../../../../../../../src/legacy/server/kbn_server'; import { LegacyConfig } from '../../plugin'; -import { TaskInstance } from '../../../../task_manager/server'; +import { + TaskInstance, + TaskManagerStartContract, + TaskManagerSetupContract, +} from '../../../../../../plugins/task_manager/server'; export function registerTasks({ taskManager, @@ -18,7 +21,7 @@ export function registerTasks({ elasticsearch, config, }: { - taskManager?: TaskManagerPluginSetupContract; + taskManager?: TaskManagerSetupContract; logger: Logger; elasticsearch: CoreSetup['elasticsearch']; config: LegacyConfig; @@ -46,7 +49,7 @@ export function scheduleTasks({ xpackMainStatus, logger, }: { - taskManager?: TaskManagerPluginSetupContract; + taskManager?: TaskManagerStartContract; xpackMainStatus: { kbnServer: KbnServer }; logger: Logger; }) { diff --git a/x-pack/legacy/plugins/oss_telemetry/server/lib/tasks/visualizations/task_runner.test.ts b/x-pack/legacy/plugins/oss_telemetry/server/lib/tasks/visualizations/task_runner.test.ts index af3eed2496f5d..ef03e857de8ef 100644 --- a/x-pack/legacy/plugins/oss_telemetry/server/lib/tasks/visualizations/task_runner.test.ts +++ b/x-pack/legacy/plugins/oss_telemetry/server/lib/tasks/visualizations/task_runner.test.ts @@ -12,7 +12,7 @@ import { getMockTaskInstance, } from '../../../../test_utils'; import { visualizationsTaskRunner } from './task_runner'; -import { TaskInstance } from '../../../../../task_manager/server'; +import { TaskInstance } from '../../../../../../../plugins/task_manager/server'; describe('visualizationsTaskRunner', () => { let mockTaskInstance: TaskInstance; diff --git a/x-pack/legacy/plugins/oss_telemetry/server/lib/tasks/visualizations/task_runner.ts b/x-pack/legacy/plugins/oss_telemetry/server/lib/tasks/visualizations/task_runner.ts index 8fb2da5627ee8..0b7b301df12bf 100644 --- a/x-pack/legacy/plugins/oss_telemetry/server/lib/tasks/visualizations/task_runner.ts +++ b/x-pack/legacy/plugins/oss_telemetry/server/lib/tasks/visualizations/task_runner.ts @@ -8,7 +8,7 @@ import _, { countBy, groupBy, mapValues } from 'lodash'; import { APICaller, CoreSetup } from 'kibana/server'; import { getNextMidnight } from '../../get_next_midnight'; import { VisState } from '../../../../../../../../src/legacy/core_plugins/visualizations/public'; -import { TaskInstance } from '../../../../../task_manager/server'; +import { TaskInstance } from '../../../../../../../plugins/task_manager/server'; import { ESSearchHit } from '../../../../../apm/typings/elasticsearch'; import { LegacyConfig } from '../../../plugin'; diff --git a/x-pack/legacy/plugins/oss_telemetry/server/plugin.ts b/x-pack/legacy/plugins/oss_telemetry/server/plugin.ts index 209c73eb0eb62..0aac319cf5818 100644 --- a/x-pack/legacy/plugins/oss_telemetry/server/plugin.ts +++ b/x-pack/legacy/plugins/oss_telemetry/server/plugin.ts @@ -4,8 +4,11 @@ * you may not use this file except in compliance with the Elastic License. */ -import { CoreSetup, Logger, Plugin, PluginInitializerContext } from 'kibana/server'; -import { PluginSetupContract as TaskManagerPluginSetupContract } from '../../task_manager/server/plugin'; +import { CoreSetup, CoreStart, Logger, Plugin, PluginInitializerContext } from 'kibana/server'; +import { + TaskManagerSetupContract, + TaskManagerStartContract, +} from '../../../../plugins/task_manager/server'; import { registerCollectors } from './lib/collectors'; import { registerTasks, scheduleTasks } from './lib/tasks'; import KbnServer from '../../../../../src/legacy/server/kbn_server'; @@ -15,13 +18,18 @@ export interface LegacyConfig { get: (key: string) => string | number | boolean; } -export interface OssTelemetrySetupDependencies { +interface OssTelemetryDependencies { usageCollection: UsageCollectionSetup; __LEGACY: { config: LegacyConfig; xpackMainStatus: { kbnServer: KbnServer }; }; - taskManager?: TaskManagerPluginSetupContract; +} +export interface OssTelemetrySetupDependencies extends OssTelemetryDependencies { + taskManager?: TaskManagerSetupContract; +} +export interface OssTelemetryStartDependencies extends OssTelemetryDependencies { + taskManager?: TaskManagerStartContract; } export class OssTelemetryPlugin implements Plugin { @@ -32,19 +40,20 @@ export class OssTelemetryPlugin implements Plugin { } public setup(core: CoreSetup, deps: OssTelemetrySetupDependencies) { - registerCollectors(deps); registerTasks({ taskManager: deps.taskManager, logger: this.logger, elasticsearch: core.elasticsearch, config: deps.__LEGACY.config, }); + } + + public start(core: CoreStart, deps: OssTelemetryStartDependencies) { + registerCollectors(deps); scheduleTasks({ taskManager: deps.taskManager, xpackMainStatus: deps.__LEGACY.xpackMainStatus, logger: this.logger, }); } - - public start() {} } diff --git a/x-pack/legacy/plugins/oss_telemetry/test_utils/index.ts b/x-pack/legacy/plugins/oss_telemetry/test_utils/index.ts index c6046eb648bf4..0695fda3c2c94 100644 --- a/x-pack/legacy/plugins/oss_telemetry/test_utils/index.ts +++ b/x-pack/legacy/plugins/oss_telemetry/test_utils/index.ts @@ -6,13 +6,28 @@ import { APICaller, CoreSetup } from 'kibana/server'; -import { TaskInstance } from '../../task_manager/server'; -import { PluginSetupContract as TaskManagerPluginSetupContract } from '../../task_manager/server/plugin'; +import { + ConcreteTaskInstance, + TaskStatus, + TaskManagerStartContract, + // eslint-disable-next-line @kbn/eslint/no-restricted-paths +} from '../../../../plugins/task_manager/server'; -export const getMockTaskInstance = (): TaskInstance => ({ +export const getMockTaskInstance = ( + overrides: Partial = {} +): ConcreteTaskInstance => ({ state: { runs: 0, stats: {} }, taskType: 'test', params: {}, + id: '', + scheduledAt: new Date(), + attempts: 1, + status: TaskStatus.Idle, + runAt: new Date(), + startedAt: null, + retryAt: null, + ownerId: null, + ...overrides, }); const defaultMockSavedObjects = [ @@ -38,8 +53,24 @@ export const getMockCallWithInternal = (hits: unknown[] = defaultMockSavedObject }) as unknown) as APICaller; }; -export const getMockTaskFetch = (docs: TaskInstance[] = defaultMockTaskDocs) => { - return () => Promise.resolve({ docs }); +export const getMockTaskFetch = ( + docs: ConcreteTaskInstance[] = defaultMockTaskDocs +): Partial> => { + return { + fetch: jest.fn(fetchOpts => { + return Promise.resolve({ docs, searchAfter: [] }); + }), + } as Partial>; +}; + +export const getMockThrowingTaskFetch = ( + throws: Error +): Partial> => { + return { + fetch: jest.fn(fetchOpts => { + throw throws; + }), + } as Partial>; }; export const getMockConfig = () => { @@ -48,13 +79,6 @@ export const getMockConfig = () => { }; }; -export const getMockTaskManager = (fetch: any = getMockTaskFetch()) => - (({ - registerTaskDefinitions: () => undefined, - ensureScheduled: () => Promise.resolve(), - fetch, - } as unknown) as TaskManagerPluginSetupContract); - export const getCluster = () => ({ callWithInternalUser: getMockCallWithInternal(), }); diff --git a/x-pack/legacy/plugins/task_manager/server/index.ts b/x-pack/legacy/plugins/task_manager/server/index.ts index 67b85af324f3d..56135bb27326b 100644 --- a/x-pack/legacy/plugins/task_manager/server/index.ts +++ b/x-pack/legacy/plugins/task_manager/server/index.ts @@ -6,19 +6,26 @@ import { Root } from 'joi'; import { Legacy } from 'kibana'; -import { Plugin, PluginSetupContract } from './plugin'; -import { SavedObjectsSerializer, SavedObjectsSchema } from '../../../../../src/core/server'; import mappings from './mappings.json'; import { migrations } from './migrations'; -export { PluginSetupContract as TaskManager }; -export { - TaskInstance, - ConcreteTaskInstance, - TaskRunCreatorFunction, - TaskStatus, - RunContext, -} from './task'; +import { createLegacyApi, getTaskManagerSetup } from './legacy'; +export { LegacyTaskManagerApi, getTaskManagerSetup, getTaskManagerStart } from './legacy'; + +// Once all plugins are migrated to NP, this can be removed +// eslint-disable-next-line @kbn/eslint/no-restricted-paths +import { TaskManager } from '../../../../plugins/task_manager/server/task_manager'; + +const savedObjectSchemas = { + task: { + hidden: true, + isNamespaceAgnostic: true, + convertToAliasScript: `ctx._id = ctx._source.type + ':' + ctx._id`, + indexPattern(config: any) { + return config.get('xpack.task_manager.index'); + }, + }, +}; export function taskManager(kibana: any) { return new kibana.Plugin({ @@ -28,73 +35,41 @@ export function taskManager(kibana: any) { config(Joi: Root) { return Joi.object({ enabled: Joi.boolean().default(true), - max_attempts: Joi.number() - .description( - 'The maximum number of times a task will be attempted before being abandoned as failed' - ) - .min(1) - .default(3), - poll_interval: Joi.number() - .description('How often, in milliseconds, the task manager will look for more work.') - .min(100) - .default(3000), - request_capacity: Joi.number() - .description('How many requests can Task Manager buffer before it rejects new requests.') - .min(1) - // a nice round contrived number, feel free to change as we learn how it behaves - .default(1000), index: Joi.string() .description('The name of the index used to store task information.') .default('.kibana_task_manager') .invalid(['.tasks']), - max_workers: Joi.number() - .description( - 'The maximum number of tasks that this Kibana instance will run simultaneously.' - ) - .min(1) // disable the task manager rather than trying to specify it with 0 workers - .default(10), }).default(); }, init(server: Legacy.Server) { - const plugin = new Plugin({ - logger: { - get: () => ({ - info: (message: string) => server.log(['info', 'task_manager'], message), - debug: (message: string) => server.log(['debug', 'task_manager'], message), - warn: (message: string) => server.log(['warn', 'task_manager'], message), - error: (message: string) => server.log(['error', 'task_manager'], message), - }), - }, - }); - const schema = new SavedObjectsSchema(this.kbnServer.uiExports.savedObjectSchemas); - const serializer = new SavedObjectsSerializer(schema); - const setupContract = plugin.setup( - {}, - { - serializer, - config: server.config(), - elasticsearch: server.plugins.elasticsearch, - savedObjects: server.savedObjects, - } + /* + * We must expose the New Platform Task Manager Plugin via the legacy Api + * as removing it now would be a breaking change - we'll remove this in v8.0.0 + */ + server.expose( + createLegacyApi( + getTaskManagerSetup(server)! + .registerLegacyAPI({ + savedObjectSchemas, + }) + .then((taskManagerPlugin: TaskManager) => { + // we can't tell the Kibana Platform Task Manager plugin to + // to wait to `start` as that happens before legacy plugins + // instead we will start the internal Task Manager plugin when + // all legacy plugins have finished initializing + // Once all plugins are migrated to NP, this can be removed + this.kbnServer.afterPluginsInit(() => { + taskManagerPlugin.start(); + }); + return taskManagerPlugin; + }) + ) ); - this.kbnServer.afterPluginsInit(() => { - plugin.start(); - }); - server.expose(setupContract); }, uiExports: { mappings, migrations, - savedObjectSchemas: { - task: { - hidden: true, - isNamespaceAgnostic: true, - convertToAliasScript: `ctx._id = ctx._source.type + ':' + ctx._id`, - indexPattern(config: any) { - return config.get('xpack.task_manager.index'); - }, - }, - }, + savedObjectSchemas, }, }); } diff --git a/x-pack/legacy/plugins/task_manager/server/legacy.ts b/x-pack/legacy/plugins/task_manager/server/legacy.ts new file mode 100644 index 0000000000000..772309d67c334 --- /dev/null +++ b/x-pack/legacy/plugins/task_manager/server/legacy.ts @@ -0,0 +1,57 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { Server } from 'src/legacy/server/kbn_server'; +import { + TaskManagerSetupContract, + TaskManagerStartContract, +} from '../../../../plugins/task_manager/server'; + +import { Middleware } from '../../../../plugins/task_manager/server/lib/middleware.js'; +import { + TaskDictionary, + TaskInstanceWithDeprecatedFields, + TaskInstanceWithId, + TaskDefinition, +} from '../../../../plugins/task_manager/server/task.js'; +import { FetchOpts } from '../../../../plugins/task_manager/server/task_store.js'; + +// Once all plugins are migrated to NP and we can remove Legacy TaskManager in version 8.0.0, +// this can be removed +// eslint-disable-next-line @kbn/eslint/no-restricted-paths +import { TaskManager } from '../../../../plugins/task_manager/server/task_manager'; + +export type LegacyTaskManagerApi = Pick< + TaskManagerSetupContract, + 'addMiddleware' | 'registerTaskDefinitions' +> & + TaskManagerStartContract; + +export function getTaskManagerSetup(server: Server): TaskManagerSetupContract | undefined { + return server?.newPlatform?.setup?.plugins?.taskManager as TaskManagerSetupContract; +} + +export function getTaskManagerStart(server: Server): TaskManagerStartContract | undefined { + return server?.newPlatform?.start?.plugins?.taskManager as TaskManagerStartContract; +} + +export function createLegacyApi(legacyTaskManager: Promise): LegacyTaskManagerApi { + return { + addMiddleware: (middleware: Middleware) => { + legacyTaskManager.then((tm: TaskManager) => tm.addMiddleware(middleware)); + }, + registerTaskDefinitions: (taskDefinitions: TaskDictionary) => { + legacyTaskManager.then((tm: TaskManager) => tm.registerTaskDefinitions(taskDefinitions)); + }, + fetch: (opts: FetchOpts) => legacyTaskManager.then((tm: TaskManager) => tm.fetch(opts)), + remove: (id: string) => legacyTaskManager.then((tm: TaskManager) => tm.remove(id)), + schedule: (taskInstance: TaskInstanceWithDeprecatedFields, options?: any) => + legacyTaskManager.then((tm: TaskManager) => tm.schedule(taskInstance, options)), + runNow: (taskId: string) => legacyTaskManager.then((tm: TaskManager) => tm.runNow(taskId)), + ensureScheduled: (taskInstance: TaskInstanceWithId, options?: any) => + legacyTaskManager.then((tm: TaskManager) => tm.ensureScheduled(taskInstance, options)), + }; +} diff --git a/x-pack/legacy/plugins/task_manager/server/plugin.test.ts b/x-pack/legacy/plugins/task_manager/server/plugin.test.ts deleted file mode 100644 index f7c5b35da50c2..0000000000000 --- a/x-pack/legacy/plugins/task_manager/server/plugin.test.ts +++ /dev/null @@ -1,73 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -import { Plugin, LegacyDeps } from './plugin'; -import { mockLogger } from './test_utils'; -import { TaskManager } from './task_manager'; - -jest.mock('./task_manager'); - -describe('Task Manager Plugin', () => { - let plugin: Plugin; - const mockCoreSetup = {}; - const mockLegacyDeps: LegacyDeps = { - config: { - get: jest.fn(), - }, - serializer: {}, - elasticsearch: { - getCluster: jest.fn(), - }, - savedObjects: { - getSavedObjectsRepository: jest.fn(), - }, - }; - - beforeEach(() => { - jest.resetAllMocks(); - mockLegacyDeps.elasticsearch.getCluster.mockReturnValue({ callWithInternalUser: jest.fn() }); - plugin = new Plugin({ - logger: { - get: mockLogger, - }, - }); - }); - - describe('setup()', () => { - test('exposes proper contract', async () => { - const setupResult = plugin.setup(mockCoreSetup, mockLegacyDeps); - expect(setupResult).toMatchInlineSnapshot(` - Object { - "addMiddleware": [Function], - "ensureScheduled": [Function], - "fetch": [Function], - "registerTaskDefinitions": [Function], - "remove": [Function], - "runNow": [Function], - "schedule": [Function], - } - `); - }); - }); - - describe('start()', () => { - test('properly starts up the task manager', async () => { - plugin.setup(mockCoreSetup, mockLegacyDeps); - plugin.start(); - const taskManager = (TaskManager as any).mock.instances[0]; - expect(taskManager.start).toHaveBeenCalled(); - }); - }); - - describe('stop()', () => { - test('properly stops up the task manager', async () => { - plugin.setup(mockCoreSetup, mockLegacyDeps); - plugin.stop(); - const taskManager = (TaskManager as any).mock.instances[0]; - expect(taskManager.stop).toHaveBeenCalled(); - }); - }); -}); diff --git a/x-pack/legacy/plugins/task_manager/server/plugin.ts b/x-pack/legacy/plugins/task_manager/server/plugin.ts deleted file mode 100644 index 08382d1d825b6..0000000000000 --- a/x-pack/legacy/plugins/task_manager/server/plugin.ts +++ /dev/null @@ -1,82 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -import { Logger } from './types'; -import { TaskManager } from './task_manager'; - -export interface PluginSetupContract { - fetch: TaskManager['fetch']; - remove: TaskManager['remove']; - schedule: TaskManager['schedule']; - runNow: TaskManager['runNow']; - ensureScheduled: TaskManager['ensureScheduled']; - addMiddleware: TaskManager['addMiddleware']; - registerTaskDefinitions: TaskManager['registerTaskDefinitions']; -} - -export interface LegacyDeps { - config: any; - serializer: any; - elasticsearch: any; - savedObjects: any; -} - -interface PluginInitializerContext { - logger: { - get: () => Logger; - }; -} - -export class Plugin { - private logger: Logger; - private taskManager?: TaskManager; - - constructor(initializerContext: PluginInitializerContext) { - this.logger = initializerContext.logger.get(); - } - - // TODO: Make asynchronous like new platform - public setup( - core: {}, - { config, serializer, elasticsearch, savedObjects }: LegacyDeps - ): PluginSetupContract { - const { callWithInternalUser } = elasticsearch.getCluster('admin'); - const savedObjectsRepository = savedObjects.getSavedObjectsRepository(callWithInternalUser, [ - 'task', - ]); - - const taskManager = new TaskManager({ - config, - savedObjectsRepository, - serializer, - callWithInternalUser, - logger: this.logger, - }); - this.taskManager = taskManager; - - return { - fetch: (...args) => taskManager.fetch(...args), - remove: (...args) => taskManager.remove(...args), - schedule: (...args) => taskManager.schedule(...args), - runNow: (...args) => taskManager.runNow(...args), - ensureScheduled: (...args) => taskManager.ensureScheduled(...args), - addMiddleware: (...args) => taskManager.addMiddleware(...args), - registerTaskDefinitions: (...args) => taskManager.registerTaskDefinitions(...args), - }; - } - - public start() { - if (this.taskManager) { - this.taskManager.start(); - } - } - - public stop() { - if (this.taskManager) { - this.taskManager.stop(); - } - } -} diff --git a/x-pack/legacy/plugins/task_manager/server/task_manager.mock.ts b/x-pack/legacy/plugins/task_manager/server/task_manager.mock.ts index 4837e75fd3160..a4b80d902d098 100644 --- a/x-pack/legacy/plugins/task_manager/server/task_manager.mock.ts +++ b/x-pack/legacy/plugins/task_manager/server/task_manager.mock.ts @@ -4,23 +4,32 @@ * you may not use this file except in compliance with the Elastic License. */ -import { TaskManager } from './types'; - -const createTaskManagerMock = () => { - const mocked: jest.Mocked = { - registerTaskDefinitions: jest.fn(), - addMiddleware: jest.fn(), - ensureScheduled: jest.fn(), - schedule: jest.fn(), - fetch: jest.fn(), - runNow: jest.fn(), - remove: jest.fn(), - start: jest.fn(), - stop: jest.fn(), - }; - return mocked; -}; +import { + TaskManagerSetupContract, + TaskManagerStartContract, +} from '../../../../plugins/task_manager/server'; +import { Subject } from 'rxjs'; export const taskManagerMock = { - create: createTaskManagerMock, + setup(overrides: Partial> = {}) { + const mocked: jest.Mocked = { + registerTaskDefinitions: jest.fn(), + addMiddleware: jest.fn(), + config$: new Subject(), + registerLegacyAPI: jest.fn(), + ...overrides, + }; + return mocked; + }, + start(overrides: Partial> = {}) { + const mocked: jest.Mocked = { + ensureScheduled: jest.fn(), + schedule: jest.fn(), + fetch: jest.fn(), + runNow: jest.fn(), + remove: jest.fn(), + ...overrides, + }; + return mocked; + }, }; diff --git a/x-pack/plugins/task_manager/kibana.json b/x-pack/plugins/task_manager/kibana.json new file mode 100644 index 0000000000000..ad2d5d00ae0be --- /dev/null +++ b/x-pack/plugins/task_manager/kibana.json @@ -0,0 +1,8 @@ +{ + "id": "taskManager", + "server": true, + "version": "8.0.0", + "kibanaVersion": "kibana", + "configPath": ["xpack", "task_manager"], + "ui": false +} diff --git a/x-pack/legacy/plugins/task_manager/server/README.md b/x-pack/plugins/task_manager/server/README.md similarity index 68% rename from x-pack/legacy/plugins/task_manager/server/README.md rename to x-pack/plugins/task_manager/server/README.md index 3afcb758260c0..a067358dc8841 100644 --- a/x-pack/legacy/plugins/task_manager/server/README.md +++ b/x-pack/plugins/task_manager/server/README.md @@ -55,51 +55,61 @@ Plugins define tasks by calling the `registerTaskDefinitions` method on the `ser A sample task can be found in the [x-pack/test/plugin_api_integration/plugins/task_manager](../../test/plugin_api_integration/plugins/task_manager/index.js) folder. ```js -const taskManager = server.plugins.task_manager; -taskManager.registerTaskDefinitions({ - // clusterMonitoring is the task type, and must be unique across the entire system - clusterMonitoring: { - // Human friendly name, used to represent this task in logs, UI, etc - title: 'Human friendly name', - - // Optional, human-friendly, more detailed description - description: 'Amazing!!', - - // Optional, how long, in minutes or seconds, the system should wait before - // a running instance of this task is considered to be timed out. - // This defaults to 5 minutes. - timeout: '5m', - - // Optional, how many attempts before marking task as failed. - // This defaults to what is configured at the task manager level. - maxAttempts: 5, - - // The clusterMonitoring task occupies 2 workers, so if the system has 10 worker slots, - // 5 clusterMonitoring tasks could run concurrently per Kibana instance. This value is - // overridden by the `override_num_workers` config value, if specified. - numWorkers: 2, - - // The createTaskRunner function / method returns an object that is responsible for - // performing the work of the task. context: { taskInstance }, is documented below. - createTaskRunner(context) { - return { - // Perform the work of the task. The return value should fit the TaskResult interface, documented - // below. Invalid return values will result in a logged warning. - async run() { - // Do some work - // Conditionally send some alerts - // Return some result or other... +export class Plugin { + constructor() { + } + + public setup(core: CoreSetup, plugins: { taskManager }) { + taskManager.registerTaskDefinitions({ + // clusterMonitoring is the task type, and must be unique across the entire system + clusterMonitoring: { + // Human friendly name, used to represent this task in logs, UI, etc + title: 'Human friendly name', + + // Optional, human-friendly, more detailed description + description: 'Amazing!!', + + // Optional, how long, in minutes or seconds, the system should wait before + // a running instance of this task is considered to be timed out. + // This defaults to 5 minutes. + timeout: '5m', + + // Optional, how many attempts before marking task as failed. + // This defaults to what is configured at the task manager level. + maxAttempts: 5, + + // The clusterMonitoring task occupies 2 workers, so if the system has 10 worker slots, + // 5 clusterMonitoring tasks could run concurrently per Kibana instance. This value is + // overridden by the `override_num_workers` config value, if specified. + numWorkers: 2, + + // The createTaskRunner function / method returns an object that is responsible for + // performing the work of the task. context: { taskInstance }, is documented below. + createTaskRunner(context) { + return { + // Perform the work of the task. The return value should fit the TaskResult interface, documented + // below. Invalid return values will result in a logged warning. + async run() { + // Do some work + // Conditionally send some alerts + // Return some result or other... + }, + + // Optional, will be called if a running instance of this task times out, allowing the task + // to attempt to clean itself up. + async cancel() { + // Do whatever is required to cancel this task, such as killing any spawned processes + }, + }; }, + }, + }); + } - // Optional, will be called if a running instance of this task times out, allowing the task - // to attempt to clean itself up. - async cancel() { - // Do whatever is required to cancel this task, such as killing any spawned processes - }, - }; - }, - }, -}); + public start(core: CoreStart, plugins: { taskManager }) { + + } +} ``` When Kibana attempts to claim and run a task instance, it looks its definition up, and executes its createTaskRunner's method, passing it a run context which looks like this: @@ -222,67 +232,129 @@ The data stored for a task instance looks something like this: The task manager mixin exposes a taskManager object on the Kibana server which plugins can use to manage scheduled tasks. Each method takes an optional `scope` argument and ensures that only tasks with the specified scope(s) will be affected. -### schedule -Using `schedule` you can instruct TaskManger to schedule an instance of a TaskType at some point in the future. +### Overview +Interaction with the TaskManager Plugin is done via the Kibana Platform Plugin system. +When developing your Plugin, you're asked to define a `setup` method and a `start` method. +These methods are handed Kibana's Plugin APIs for these two stages, which means you'll have access to the following apis in these two stages: + +#### Setup +The _Setup_ Plugin api includes methods which configure Task Manager to support your Plugin's requirements, such as defining custom Middleware and Task Definitions. +```js +{ + addMiddleware: (middleware: Middleware) => { + // ... + }, + registerTaskDefinitions: (taskDefinitions: TaskDictionary) => { + // ... + }, +} +``` + +#### Start +The _Start_ Plugin api allow you to use Task Manager to facilitate your Plugin's behaviour, such as scheduling tasks. ```js -const taskManager = server.plugins.task_manager; -// Schedules a task. All properties are as documented in the previous -// storage section, except that here, params is an object, not a JSON -// string. -const task = await taskManager.schedule({ - taskType, - runAt, - schedule, - params, - scope: ['my-fanci-app'], -}); - -// Removes the specified task -await manager.remove(task.id); - -// Fetches tasks, supports pagination, via the search-after API: -// https://www.elastic.co/guide/en/elasticsearch/reference/current/search-request-search-after.html -// If scope is not specified, all tasks are returned, otherwise only tasks -// with the given scope are returned. -const results = await manager.find({ scope: 'my-fanci-app', searchAfter: ['ids'] }); - -// results look something like this: { - searchAfter: ['233322'], - // Tasks is an array of task instances - tasks: [{ - id: '3242342', - taskType: 'reporting', - // etc - }] + fetch: (opts: FetchOpts) => { + // ... + }, + remove: (id: string) => { + // ... + }, + schedule: (taskInstance: TaskInstanceWithDeprecatedFields, options?: any) => { + // ... + }, + runNow: (taskId: string) => { + // ... + }, + ensureScheduled: (taskInstance: TaskInstanceWithId, options?: any) => { + // ... + }, } ``` -### ensureScheduling +### Detailed APIs + +#### schedule +Using `schedule` you can instruct TaskManger to schedule an instance of a TaskType at some point in the future. + + +```js +export class Plugin { + constructor() { + } + + public setup(core: CoreSetup, plugins: { taskManager }) { + } + + public start(core: CoreStart, plugins: { taskManager }) { + // Schedules a task. All properties are as documented in the previous + // storage section, except that here, params is an object, not a JSON + // string. + const task = await taskManager.schedule({ + taskType, + runAt, + schedule, + params, + scope: ['my-fanci-app'], + }); + + // Removes the specified task + await taskManager.remove(task.id); + + // Fetches tasks, supports pagination, via the search-after API: + // https://www.elastic.co/guide/en/elasticsearch/reference/current/search-request-search-after.html + // If scope is not specified, all tasks are returned, otherwise only tasks + // with the given scope are returned. + const results = await taskManager.find({ scope: 'my-fanci-app', searchAfter: ['ids'] }); + } +} +``` +*results* then look something like this: + +```json + { + "searchAfter": ["233322"], + // Tasks is an array of task instances + "tasks": [{ + "id": "3242342", + "taskType": "reporting", + // etc + }] + } +``` + +#### ensureScheduling When using the `schedule` api to schedule a Task you can provide a hard coded `id` on the Task. This tells TaskManager to use this `id` to identify the Task Instance rather than generate an `id` on its own. The danger is that in such a situation, a Task with that same `id` might already have been scheduled at some earlier point, and this would result in an error. In some cases, this is the expected behavior, but often you only care about ensuring the task has been _scheduled_ and don't need it to be scheduled a fresh. To achieve this you should use the `ensureScheduling` api which has the exact same behavior as `schedule`, except it allows the scheduling of a Task with an `id` that's already in assigned to another Task and it will assume that the existing Task is the one you wished to `schedule`, treating this as a successful operation. -### runNow +#### runNow Using `runNow` you can instruct TaskManger to run an existing task on-demand, without waiting for its scheduled time to be reached. ```js -const taskManager = server.plugins.task_manager; - -try { - const taskRunResult = await taskManager.runNow('91760f10-ba42-de9799'); - // If no error is thrown, the task has completed successfully. -} catch(err: Error) { - // If running the task has failed, we throw an error with an appropriate message. - // For example, if the requested task doesnt exist: `Error: failed to run task "91760f10-ba42-de9799" as it does not exist` - // Or if, for example, the task is already running: `Error: failed to run task "91760f10-ba42-de9799" as it is currently running` +export class Plugin { + constructor() { + } + + public setup(core: CoreSetup, plugins: { taskManager }) { + } + + public start(core: CoreStart, plugins: { taskManager }) { + try { + const taskRunResult = await taskManager.runNow('91760f10-ba42-de9799'); + // If no error is thrown, the task has completed successfully. + } catch(err: Error) { + // If running the task has failed, we throw an error with an appropriate message. + // For example, if the requested task doesnt exist: `Error: failed to run task "91760f10-ba42-de9799" as it does not exist` + // Or if, for example, the task is already running: `Error: failed to run task "91760f10-ba42-de9799" as it is currently running` + } + } } ``` - -### more options +#### more options More custom access to the tasks can be done directly via Elasticsearch, though that won't be officially supported, as we can change the document structure at any time. @@ -291,35 +363,44 @@ More custom access to the tasks can be done directly via Elasticsearch, though t The task manager exposes a middleware layer that allows modifying tasks before they are scheduled / persisted to the task manager index, and modifying tasks / the run context before a task is run. For example: - ```js -// In your plugin's init -server.plugins.task_manager.addMiddleware({ - async beforeSave({ taskInstance, ...opts }) { - console.log(`About to save a task of type ${taskInstance.taskType}`); - - return { - ...opts, - taskInstance: { - ...taskInstance, - params: { - ...taskInstance.params, - example: 'Added to params!', - }, +export class Plugin { + constructor() { + } + + public setup(core: CoreSetup, plugins: { taskManager }) { + taskManager.addMiddleware({ + async beforeSave({ taskInstance, ...opts }) { + console.log(`About to save a task of type ${taskInstance.taskType}`); + + return { + ...opts, + taskInstance: { + ...taskInstance, + params: { + ...taskInstance.params, + example: 'Added to params!', + }, + }, + }; }, - }; - }, - async beforeRun({ taskInstance, ...opts }) { - console.log(`About to run ${taskInstance.taskType} ${taskInstance.id}`); - const { example, ...taskWithoutExampleProp } = taskInstance; + async beforeRun({ taskInstance, ...opts }) { + console.log(`About to run ${taskInstance.taskType} ${taskInstance.id}`); + const { example, ...taskWithoutExampleProp } = taskInstance; - return { - ...opts, - taskInstance: taskWithoutExampleProp, - }; - }, -}); + return { + ...opts, + taskInstance: taskWithoutExampleProp, + }; + }, + }); + } + + public start(core: CoreStart, plugins: { taskManager }) { + + } +} ``` ## Task Poller: polling for work diff --git a/x-pack/plugins/task_manager/server/config.test.ts b/x-pack/plugins/task_manager/server/config.test.ts new file mode 100644 index 0000000000000..f7962f7011f34 --- /dev/null +++ b/x-pack/plugins/task_manager/server/config.test.ts @@ -0,0 +1,33 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import { configSchema } from './config'; + +describe('config validation', () => { + test('task manager defaults', () => { + const config: Record = {}; + expect(configSchema.validate(config)).toMatchInlineSnapshot(` + Object { + "enabled": true, + "index": ".kibana_task_manager", + "max_attempts": 3, + "max_workers": 10, + "poll_interval": 3000, + "request_capacity": 1000, + } + `); + }); + + test('the ElastiSearch Tasks index cannot be used for task manager', () => { + const config: Record = { + index: '.tasks', + }; + expect(() => { + configSchema.validate(config); + }).toThrowErrorMatchingInlineSnapshot( + `"[index]: \\".tasks\\" is an invalid Kibana Task Manager index, as it is already in use by the ElasticSearch Tasks Manager"` + ); + }); +}); diff --git a/x-pack/plugins/task_manager/server/config.ts b/x-pack/plugins/task_manager/server/config.ts new file mode 100644 index 0000000000000..06e6ad3e62282 --- /dev/null +++ b/x-pack/plugins/task_manager/server/config.ts @@ -0,0 +1,44 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { schema, TypeOf } from '@kbn/config-schema'; + +export const configSchema = schema.object({ + enabled: schema.boolean({ defaultValue: true }), + /* The maximum number of times a task will be attempted before being abandoned as failed */ + max_attempts: schema.number({ + defaultValue: 3, + min: 1, + }), + /* How often, in milliseconds, the task manager will look for more work. */ + poll_interval: schema.number({ + defaultValue: 3000, + min: 100, + }), + /* How many requests can Task Manager buffer before it rejects new requests. */ + request_capacity: schema.number({ + // a nice round contrived number, feel free to change as we learn how it behaves + defaultValue: 1000, + min: 1, + }), + /* The name of the index used to store task information. */ + index: schema.string({ + defaultValue: '.kibana_task_manager', + validate: val => { + if (val.toLowerCase() === '.tasks') { + return `"${val}" is an invalid Kibana Task Manager index, as it is already in use by the ElasticSearch Tasks Manager`; + } + }, + }), + /* The maximum number of tasks that this Kibana instance will run simultaneously. */ + max_workers: schema.number({ + defaultValue: 10, + // disable the task manager rather than trying to specify it with 0 workers + min: 1, + }), +}); + +export type TaskManagerConfig = TypeOf; diff --git a/x-pack/plugins/task_manager/server/create_task_manager.test.ts b/x-pack/plugins/task_manager/server/create_task_manager.test.ts new file mode 100644 index 0000000000000..f4deeb1ea02ed --- /dev/null +++ b/x-pack/plugins/task_manager/server/create_task_manager.test.ts @@ -0,0 +1,58 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { createTaskManager, LegacyDeps } from './create_task_manager'; +import { mockLogger } from './test_utils'; +import { CoreSetup, UuidServiceSetup } from 'kibana/server'; +import { savedObjectsRepositoryMock } from '../../../../src/core/server/mocks'; + +jest.mock('./task_manager'); + +describe('createTaskManager', () => { + const uuid: UuidServiceSetup = { + getInstanceUuid() { + return 'some-uuid'; + }, + }; + const mockCoreSetup = { + uuid, + } as CoreSetup; + + const getMockLegacyDeps = (): LegacyDeps => ({ + config: {}, + savedObjectSchemas: {}, + elasticsearch: { + callAsInternalUser: jest.fn(), + }, + savedObjectsRepository: savedObjectsRepositoryMock.create(), + logger: mockLogger(), + }); + + beforeEach(() => { + jest.resetAllMocks(); + }); + + test('exposes the underlying TaskManager', async () => { + const mockLegacyDeps = getMockLegacyDeps(); + const setupResult = createTaskManager(mockCoreSetup, mockLegacyDeps); + expect(setupResult).toMatchInlineSnapshot(` + TaskManager { + "addMiddleware": [MockFunction], + "assertUninitialized": [MockFunction], + "attemptToRun": [MockFunction], + "ensureScheduled": [MockFunction], + "fetch": [MockFunction], + "registerTaskDefinitions": [MockFunction], + "remove": [MockFunction], + "runNow": [MockFunction], + "schedule": [MockFunction], + "start": [MockFunction], + "stop": [MockFunction], + "waitUntilStarted": [MockFunction], + } + `); + }); +}); diff --git a/x-pack/plugins/task_manager/server/create_task_manager.ts b/x-pack/plugins/task_manager/server/create_task_manager.ts new file mode 100644 index 0000000000000..5c66b8ba5bd58 --- /dev/null +++ b/x-pack/plugins/task_manager/server/create_task_manager.ts @@ -0,0 +1,46 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { + IClusterClient, + SavedObjectsSerializer, + SavedObjectsSchema, + CoreSetup, + ISavedObjectsRepository, +} from '../../../../src/core/server'; +import { TaskManager } from './task_manager'; +import { Logger } from './types'; + +export interface LegacyDeps { + config: any; + savedObjectSchemas: any; + elasticsearch: Pick; + savedObjectsRepository: ISavedObjectsRepository; + logger: Logger; +} + +export function createTaskManager( + core: CoreSetup, + { + logger, + config, + savedObjectSchemas, + elasticsearch: { callAsInternalUser }, + savedObjectsRepository, + }: LegacyDeps +) { + // as we use this Schema solely to interact with Tasks, we + // can initialise it with solely the Tasks schema + const serializer = new SavedObjectsSerializer(new SavedObjectsSchema(savedObjectSchemas)); + return new TaskManager({ + taskManagerId: core.uuid.getInstanceUuid(), + config, + savedObjectsRepository, + serializer, + callAsInternalUser, + logger, + }); +} diff --git a/x-pack/plugins/task_manager/server/index.ts b/x-pack/plugins/task_manager/server/index.ts new file mode 100644 index 0000000000000..7eba218e16fed --- /dev/null +++ b/x-pack/plugins/task_manager/server/index.ts @@ -0,0 +1,29 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { PluginInitializerContext } from 'src/core/server'; +import { TaskManagerPlugin } from './plugin'; +import { configSchema } from './config'; + +export const plugin = (initContext: PluginInitializerContext) => new TaskManagerPlugin(initContext); + +export { + TaskInstance, + ConcreteTaskInstance, + TaskRunCreatorFunction, + TaskStatus, + RunContext, +} from './task'; + +export { + TaskManagerPlugin as TaskManager, + TaskManagerSetupContract, + TaskManagerStartContract, +} from './plugin'; + +export const config = { + schema: configSchema, +}; diff --git a/x-pack/legacy/plugins/task_manager/server/lib/correct_deprecated_fields.test.ts b/x-pack/plugins/task_manager/server/lib/correct_deprecated_fields.test.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/lib/correct_deprecated_fields.test.ts rename to x-pack/plugins/task_manager/server/lib/correct_deprecated_fields.test.ts diff --git a/x-pack/legacy/plugins/task_manager/server/lib/correct_deprecated_fields.ts b/x-pack/plugins/task_manager/server/lib/correct_deprecated_fields.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/lib/correct_deprecated_fields.ts rename to x-pack/plugins/task_manager/server/lib/correct_deprecated_fields.ts diff --git a/x-pack/legacy/plugins/task_manager/server/lib/fill_pool.test.ts b/x-pack/plugins/task_manager/server/lib/fill_pool.test.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/lib/fill_pool.test.ts rename to x-pack/plugins/task_manager/server/lib/fill_pool.test.ts diff --git a/x-pack/legacy/plugins/task_manager/server/lib/fill_pool.ts b/x-pack/plugins/task_manager/server/lib/fill_pool.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/lib/fill_pool.ts rename to x-pack/plugins/task_manager/server/lib/fill_pool.ts diff --git a/x-pack/legacy/plugins/task_manager/server/lib/get_template_version.test.ts b/x-pack/plugins/task_manager/server/lib/get_template_version.test.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/lib/get_template_version.test.ts rename to x-pack/plugins/task_manager/server/lib/get_template_version.test.ts diff --git a/x-pack/legacy/plugins/task_manager/server/lib/get_template_version.ts b/x-pack/plugins/task_manager/server/lib/get_template_version.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/lib/get_template_version.ts rename to x-pack/plugins/task_manager/server/lib/get_template_version.ts diff --git a/x-pack/legacy/plugins/task_manager/server/lib/identify_es_error.test.ts b/x-pack/plugins/task_manager/server/lib/identify_es_error.test.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/lib/identify_es_error.test.ts rename to x-pack/plugins/task_manager/server/lib/identify_es_error.test.ts diff --git a/x-pack/legacy/plugins/task_manager/server/lib/identify_es_error.ts b/x-pack/plugins/task_manager/server/lib/identify_es_error.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/lib/identify_es_error.ts rename to x-pack/plugins/task_manager/server/lib/identify_es_error.ts diff --git a/x-pack/legacy/plugins/task_manager/server/lib/intervals.test.ts b/x-pack/plugins/task_manager/server/lib/intervals.test.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/lib/intervals.test.ts rename to x-pack/plugins/task_manager/server/lib/intervals.test.ts diff --git a/x-pack/legacy/plugins/task_manager/server/lib/intervals.ts b/x-pack/plugins/task_manager/server/lib/intervals.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/lib/intervals.ts rename to x-pack/plugins/task_manager/server/lib/intervals.ts diff --git a/x-pack/legacy/plugins/task_manager/server/lib/middleware.test.ts b/x-pack/plugins/task_manager/server/lib/middleware.test.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/lib/middleware.test.ts rename to x-pack/plugins/task_manager/server/lib/middleware.test.ts diff --git a/x-pack/legacy/plugins/task_manager/server/lib/middleware.ts b/x-pack/plugins/task_manager/server/lib/middleware.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/lib/middleware.ts rename to x-pack/plugins/task_manager/server/lib/middleware.ts diff --git a/x-pack/legacy/plugins/task_manager/server/lib/pull_from_set.test.ts b/x-pack/plugins/task_manager/server/lib/pull_from_set.test.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/lib/pull_from_set.test.ts rename to x-pack/plugins/task_manager/server/lib/pull_from_set.test.ts diff --git a/x-pack/legacy/plugins/task_manager/server/lib/pull_from_set.ts b/x-pack/plugins/task_manager/server/lib/pull_from_set.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/lib/pull_from_set.ts rename to x-pack/plugins/task_manager/server/lib/pull_from_set.ts diff --git a/x-pack/legacy/plugins/task_manager/server/lib/result_type.ts b/x-pack/plugins/task_manager/server/lib/result_type.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/lib/result_type.ts rename to x-pack/plugins/task_manager/server/lib/result_type.ts diff --git a/x-pack/legacy/plugins/task_manager/server/lib/sanitize_task_definitions.test.ts b/x-pack/plugins/task_manager/server/lib/sanitize_task_definitions.test.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/lib/sanitize_task_definitions.test.ts rename to x-pack/plugins/task_manager/server/lib/sanitize_task_definitions.test.ts diff --git a/x-pack/legacy/plugins/task_manager/server/lib/sanitize_task_definitions.ts b/x-pack/plugins/task_manager/server/lib/sanitize_task_definitions.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/lib/sanitize_task_definitions.ts rename to x-pack/plugins/task_manager/server/lib/sanitize_task_definitions.ts diff --git a/x-pack/plugins/task_manager/server/plugin.ts b/x-pack/plugins/task_manager/server/plugin.ts new file mode 100644 index 0000000000000..9bdd1ce6d8748 --- /dev/null +++ b/x-pack/plugins/task_manager/server/plugin.ts @@ -0,0 +1,83 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import { PluginInitializerContext, Plugin, CoreSetup } from 'src/core/server'; +import { Observable, Subject } from 'rxjs'; +import { first } from 'rxjs/operators'; +import { once } from 'lodash'; +import { TaskDictionary, TaskDefinition } from './task'; +import { TaskManager } from './task_manager'; +import { createTaskManager, LegacyDeps } from './create_task_manager'; +import { TaskManagerConfig } from './config'; +import { Middleware } from './lib/middleware'; + +export type PluginLegacyDependencies = Pick; +export type TaskManagerSetupContract = { + config$: Observable; + registerLegacyAPI: (legacyDependencies: PluginLegacyDependencies) => Promise; +} & Pick; + +export type TaskManagerStartContract = Pick< + TaskManager, + 'fetch' | 'remove' | 'schedule' | 'runNow' | 'ensureScheduled' +>; + +export class TaskManagerPlugin + implements Plugin { + legacyTaskManager$: Subject = new Subject(); + taskManager: Promise = this.legacyTaskManager$.pipe(first()).toPromise(); + currentConfig: TaskManagerConfig; + + constructor(private readonly initContext: PluginInitializerContext) { + this.initContext = initContext; + this.currentConfig = {} as TaskManagerConfig; + } + + public setup(core: CoreSetup, plugins: any): TaskManagerSetupContract { + const logger = this.initContext.logger.get('taskManager'); + const config$ = this.initContext.config.create(); + const savedObjectsRepository = core.savedObjects.createInternalRepository(['task']); + const elasticsearch = core.elasticsearch.adminClient; + return { + config$, + registerLegacyAPI: once((__LEGACY: PluginLegacyDependencies) => { + config$.subscribe(async config => { + this.legacyTaskManager$.next( + createTaskManager(core, { + logger, + config, + elasticsearch, + savedObjectsRepository, + ...__LEGACY, + }) + ); + this.legacyTaskManager$.complete(); + }); + return this.taskManager; + }), + addMiddleware: (middleware: Middleware) => { + this.taskManager.then(tm => tm.addMiddleware(middleware)); + }, + registerTaskDefinitions: (taskDefinition: TaskDictionary) => { + this.taskManager.then(tm => tm.registerTaskDefinitions(taskDefinition)); + }, + }; + } + + public start(): TaskManagerStartContract { + return { + fetch: (...args) => this.taskManager.then(tm => tm.fetch(...args)), + remove: (...args) => this.taskManager.then(tm => tm.remove(...args)), + schedule: (...args) => this.taskManager.then(tm => tm.schedule(...args)), + runNow: (...args) => this.taskManager.then(tm => tm.runNow(...args)), + ensureScheduled: (...args) => this.taskManager.then(tm => tm.ensureScheduled(...args)), + }; + } + public stop() { + this.taskManager.then(tm => { + tm.stop(); + }); + } +} diff --git a/x-pack/legacy/plugins/task_manager/server/queries/mark_available_tasks_as_claimed.test.ts b/x-pack/plugins/task_manager/server/queries/mark_available_tasks_as_claimed.test.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/queries/mark_available_tasks_as_claimed.test.ts rename to x-pack/plugins/task_manager/server/queries/mark_available_tasks_as_claimed.test.ts diff --git a/x-pack/legacy/plugins/task_manager/server/queries/mark_available_tasks_as_claimed.ts b/x-pack/plugins/task_manager/server/queries/mark_available_tasks_as_claimed.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/queries/mark_available_tasks_as_claimed.ts rename to x-pack/plugins/task_manager/server/queries/mark_available_tasks_as_claimed.ts diff --git a/x-pack/legacy/plugins/task_manager/server/queries/query_clauses.ts b/x-pack/plugins/task_manager/server/queries/query_clauses.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/queries/query_clauses.ts rename to x-pack/plugins/task_manager/server/queries/query_clauses.ts diff --git a/x-pack/legacy/plugins/task_manager/server/task.ts b/x-pack/plugins/task_manager/server/task.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/task.ts rename to x-pack/plugins/task_manager/server/task.ts diff --git a/x-pack/legacy/plugins/task_manager/server/task_events.ts b/x-pack/plugins/task_manager/server/task_events.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/task_events.ts rename to x-pack/plugins/task_manager/server/task_events.ts diff --git a/x-pack/plugins/task_manager/server/task_manager.mock.ts b/x-pack/plugins/task_manager/server/task_manager.mock.ts new file mode 100644 index 0000000000000..9750dd14100d9 --- /dev/null +++ b/x-pack/plugins/task_manager/server/task_manager.mock.ts @@ -0,0 +1,32 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { TaskManagerSetupContract, TaskManagerStartContract } from './plugin'; +import { Subject } from 'rxjs'; + +export const taskManagerMock = { + setup(overrides: Partial> = {}) { + const mocked: jest.Mocked = { + registerTaskDefinitions: jest.fn(), + addMiddleware: jest.fn(), + config$: new Subject(), + registerLegacyAPI: jest.fn(), + ...overrides, + }; + return mocked; + }, + start(overrides: Partial> = {}) { + const mocked: jest.Mocked = { + ensureScheduled: jest.fn(), + schedule: jest.fn(), + fetch: jest.fn(), + runNow: jest.fn(), + remove: jest.fn(), + ...overrides, + }; + return mocked; + }, +}; diff --git a/x-pack/legacy/plugins/task_manager/server/task_manager.test.ts b/x-pack/plugins/task_manager/server/task_manager.test.ts similarity index 94% rename from x-pack/legacy/plugins/task_manager/server/task_manager.test.ts rename to x-pack/plugins/task_manager/server/task_manager.test.ts index 51c3e5b81d764..a65723b2e8de7 100644 --- a/x-pack/legacy/plugins/task_manager/server/task_manager.test.ts +++ b/x-pack/plugins/task_manager/server/task_manager.test.ts @@ -20,39 +20,33 @@ import { awaitTaskRunResult, TaskLifecycleEvent, } from './task_manager'; -import { savedObjectsClientMock } from '../../../../../src/core/server/mocks'; -import { SavedObjectsSerializer, SavedObjectsSchema } from '../../../../../src/core/server'; +import { savedObjectsRepositoryMock } from '../../../../src/core/server/mocks'; +import { SavedObjectsSerializer, SavedObjectsSchema } from '../../../../src/core/server'; import { mockLogger } from './test_utils'; import { asErr, asOk } from './lib/result_type'; import { ConcreteTaskInstance, TaskLifecycleResult, TaskStatus } from './task'; -const savedObjectsClient = savedObjectsClientMock.create(); +const savedObjectsClient = savedObjectsRepositoryMock.create(); const serializer = new SavedObjectsSerializer(new SavedObjectsSchema()); describe('TaskManager', () => { let clock: sinon.SinonFakeTimers; - const defaultConfig = { - xpack: { - task_manager: { - max_workers: 10, - index: 'foo', - max_attempts: 9, - poll_interval: 6000000, - }, - }, - server: { - uuid: 'some-uuid', - }, - }; + const config = { - get: (path: string) => _.get(defaultConfig, path), + enabled: true, + max_workers: 10, + index: 'foo', + max_attempts: 9, + poll_interval: 6000000, + request_capacity: 1000, }; const taskManagerOpts = { config, savedObjectsRepository: savedObjectsClient, serializer, - callWithInternalUser: jest.fn(), + callAsInternalUser: jest.fn(), logger: mockLogger(), + taskManagerId: 'some-uuid', }; beforeEach(() => { @@ -63,21 +57,9 @@ describe('TaskManager', () => { test('throws if no valid UUID is available', async () => { expect(() => { - const configWithoutServerUUID = { - xpack: { - task_manager: { - max_workers: 10, - index: 'foo', - max_attempts: 9, - poll_interval: 6000000, - }, - }, - }; new TaskManager({ ...taskManagerOpts, - config: { - get: (path: string) => _.get(configWithoutServerUUID, path), - }, + taskManagerId: '', }); }).toThrowErrorMatchingInlineSnapshot( `"TaskManager is unable to start as Kibana has no valid UUID assigned to it."` @@ -234,7 +216,7 @@ describe('TaskManager', () => { test('allows and queues fetching tasks before starting', async () => { const client = new TaskManager(taskManagerOpts); - taskManagerOpts.callWithInternalUser.mockResolvedValue({ + taskManagerOpts.callAsInternalUser.mockResolvedValue({ hits: { total: { value: 0, @@ -245,13 +227,13 @@ describe('TaskManager', () => { const promise = client.fetch({}); client.start(); await promise; - expect(taskManagerOpts.callWithInternalUser).toHaveBeenCalled(); + expect(taskManagerOpts.callAsInternalUser).toHaveBeenCalled(); }); test('allows fetching tasks after starting', async () => { const client = new TaskManager(taskManagerOpts); client.start(); - taskManagerOpts.callWithInternalUser.mockResolvedValue({ + taskManagerOpts.callAsInternalUser.mockResolvedValue({ hits: { total: { value: 0, @@ -260,7 +242,7 @@ describe('TaskManager', () => { }, }); await client.fetch({}); - expect(taskManagerOpts.callWithInternalUser).toHaveBeenCalled(); + expect(taskManagerOpts.callAsInternalUser).toHaveBeenCalled(); }); test('allows middleware registration before starting', () => { @@ -282,7 +264,6 @@ describe('TaskManager', () => { }; client.start(); - expect(() => client.addMiddleware(middleware)).toThrow( /Cannot add middleware after the task manager is initialized/i ); diff --git a/x-pack/legacy/plugins/task_manager/server/task_manager.ts b/x-pack/plugins/task_manager/server/task_manager.ts similarity index 95% rename from x-pack/legacy/plugins/task_manager/server/task_manager.ts rename to x-pack/plugins/task_manager/server/task_manager.ts index 6c9191ffe3d0e..c0baed3708a0a 100644 --- a/x-pack/legacy/plugins/task_manager/server/task_manager.ts +++ b/x-pack/plugins/task_manager/server/task_manager.ts @@ -10,8 +10,13 @@ import { performance } from 'perf_hooks'; import { pipe } from 'fp-ts/lib/pipeable'; import { Option, none, some, map as mapOptional } from 'fp-ts/lib/Option'; -import { SavedObjectsClientContract, SavedObjectsSerializer } from '../../../../../src/core/server'; +import { + SavedObjectsSerializer, + IScopedClusterClient, + ISavedObjectsRepository, +} from '../../../../src/core/server'; import { Result, asErr, either, map, mapErr, promiseResult } from './lib/result_type'; +import { TaskManagerConfig } from './config'; import { Logger } from './types'; import { @@ -56,10 +61,11 @@ const VERSION_CONFLICT_STATUS = 409; export interface TaskManagerOpts { logger: Logger; - config: any; - callWithInternalUser: any; - savedObjectsRepository: SavedObjectsClientContract; + config: TaskManagerConfig; + callAsInternalUser: IScopedClusterClient['callAsInternalUser']; + savedObjectsRepository: ISavedObjectsRepository; serializer: SavedObjectsSerializer; + taskManagerId: string; } interface RunNowResult { @@ -110,7 +116,7 @@ export class TaskManager { constructor(opts: TaskManagerOpts) { this.logger = opts.logger; - const taskManagerId = opts.config.get('server.uuid'); + const { taskManagerId } = opts; if (!taskManagerId) { this.logger.error( `TaskManager is unable to start as there the Kibana UUID is invalid (value of the "server.uuid" configuration is ${taskManagerId})` @@ -123,9 +129,9 @@ export class TaskManager { this.store = new TaskStore({ serializer: opts.serializer, savedObjectsRepository: opts.savedObjectsRepository, - callCluster: opts.callWithInternalUser, - index: opts.config.get('xpack.task_manager.index'), - maxAttempts: opts.config.get('xpack.task_manager.max_attempts'), + callCluster: opts.callAsInternalUser, + index: opts.config.index, + maxAttempts: opts.config.max_attempts, definitions: this.definitions, taskManagerId: `kibana:${taskManagerId}`, }); @@ -134,12 +140,12 @@ export class TaskManager { this.pool = new TaskPool({ logger: this.logger, - maxWorkers: opts.config.get('xpack.task_manager.max_workers'), + maxWorkers: opts.config.max_workers, }); this.poller$ = createTaskPoller({ - pollInterval: opts.config.get('xpack.task_manager.poll_interval'), - bufferCapacity: opts.config.get('xpack.task_manager.request_capacity'), + pollInterval: opts.config.poll_interval, + bufferCapacity: opts.config.request_capacity, getCapacity: () => this.pool.availableWorkers, pollRequests$: this.claimRequests$, work: this.pollForWork, diff --git a/x-pack/legacy/plugins/task_manager/server/task_poller.test.ts b/x-pack/plugins/task_manager/server/task_poller.test.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/task_poller.test.ts rename to x-pack/plugins/task_manager/server/task_poller.test.ts diff --git a/x-pack/legacy/plugins/task_manager/server/task_poller.ts b/x-pack/plugins/task_manager/server/task_poller.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/task_poller.ts rename to x-pack/plugins/task_manager/server/task_poller.ts diff --git a/x-pack/legacy/plugins/task_manager/server/task_pool.test.ts b/x-pack/plugins/task_manager/server/task_pool.test.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/task_pool.test.ts rename to x-pack/plugins/task_manager/server/task_pool.test.ts diff --git a/x-pack/legacy/plugins/task_manager/server/task_pool.ts b/x-pack/plugins/task_manager/server/task_pool.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/task_pool.ts rename to x-pack/plugins/task_manager/server/task_pool.ts diff --git a/x-pack/legacy/plugins/task_manager/server/task_runner.test.ts b/x-pack/plugins/task_manager/server/task_runner.test.ts similarity index 99% rename from x-pack/legacy/plugins/task_manager/server/task_runner.test.ts rename to x-pack/plugins/task_manager/server/task_runner.test.ts index 3f7877aa4c20f..3f0132105347e 100644 --- a/x-pack/legacy/plugins/task_manager/server/task_runner.test.ts +++ b/x-pack/plugins/task_manager/server/task_runner.test.ts @@ -12,7 +12,7 @@ import { TaskEvent, asTaskRunEvent, asTaskMarkRunningEvent } from './task_events import { ConcreteTaskInstance, TaskStatus } from './task'; import { TaskManagerRunner } from './task_runner'; import { mockLogger } from './test_utils'; -import { SavedObjectsErrorHelpers } from '../../../../../src/core/server'; +import { SavedObjectsErrorHelpers } from '../../../../src/core/server'; let fakeTimer: sinon.SinonFakeTimers; diff --git a/x-pack/legacy/plugins/task_manager/server/task_runner.ts b/x-pack/plugins/task_manager/server/task_runner.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/task_runner.ts rename to x-pack/plugins/task_manager/server/task_runner.ts diff --git a/x-pack/legacy/plugins/task_manager/server/task_store.test.ts b/x-pack/plugins/task_manager/server/task_store.test.ts similarity index 99% rename from x-pack/legacy/plugins/task_manager/server/task_store.test.ts rename to x-pack/plugins/task_manager/server/task_store.test.ts index c7a0a1a020721..f47cc41c2d045 100644 --- a/x-pack/legacy/plugins/task_manager/server/task_store.test.ts +++ b/x-pack/plugins/task_manager/server/task_store.test.ts @@ -17,13 +17,13 @@ import { TaskLifecycleResult, } from './task'; import { FetchOpts, StoreOpts, OwnershipClaimingOpts, TaskStore } from './task_store'; -import { savedObjectsClientMock } from '../../../../../src/core/server/mocks'; +import { savedObjectsRepositoryMock } from '../../../../src/core/server/mocks'; import { SavedObjectsSerializer, SavedObjectsSchema, SavedObjectAttributes, -} from '../../../../../src/core/server'; -import { SavedObjectsErrorHelpers } from '../../../../../src/core/server/saved_objects/service/lib/errors'; +} from '../../../../src/core/server'; +import { SavedObjectsErrorHelpers } from '../../../../src/core/server/saved_objects/service/lib/errors'; import { asTaskClaimEvent, TaskEvent } from './task_events'; import { asOk, asErr } from './lib/result_type'; @@ -45,7 +45,7 @@ const taskDefinitions: TaskDictionary = { }, }; -const savedObjectsClient = savedObjectsClientMock.create(); +const savedObjectsClient = savedObjectsRepositoryMock.create(); const serializer = new SavedObjectsSerializer(new SavedObjectsSchema()); beforeEach(() => jest.resetAllMocks()); diff --git a/x-pack/legacy/plugins/task_manager/server/task_store.ts b/x-pack/plugins/task_manager/server/task_store.ts similarity index 98% rename from x-pack/legacy/plugins/task_manager/server/task_store.ts rename to x-pack/plugins/task_manager/server/task_store.ts index e8fc0ccb90936..f4695b152237a 100644 --- a/x-pack/legacy/plugins/task_manager/server/task_store.ts +++ b/x-pack/plugins/task_manager/server/task_store.ts @@ -11,12 +11,12 @@ import { Subject, Observable } from 'rxjs'; import { omit, difference } from 'lodash'; import { - SavedObjectsClientContract, SavedObject, SavedObjectAttributes, SavedObjectsSerializer, SavedObjectsRawDoc, -} from '../../../../../src/core/server'; + ISavedObjectsRepository, +} from '../../../../src/core/server'; import { asOk, asErr } from './lib/result_type'; @@ -60,7 +60,7 @@ export interface StoreOpts { taskManagerId: string; maxAttempts: number; definitions: TaskDictionary; - savedObjectsRepository: SavedObjectsClientContract; + savedObjectsRepository: ISavedObjectsRepository; serializer: SavedObjectsSerializer; } @@ -123,7 +123,7 @@ export class TaskStore { private callCluster: ElasticJs; private definitions: TaskDictionary; - private savedObjectsRepository: SavedObjectsClientContract; + private savedObjectsRepository: ISavedObjectsRepository; private serializer: SavedObjectsSerializer; private events$: Subject; diff --git a/x-pack/legacy/plugins/task_manager/server/test_utils/index.ts b/x-pack/plugins/task_manager/server/test_utils/index.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/test_utils/index.ts rename to x-pack/plugins/task_manager/server/test_utils/index.ts diff --git a/x-pack/legacy/plugins/task_manager/server/types.ts b/x-pack/plugins/task_manager/server/types.ts similarity index 100% rename from x-pack/legacy/plugins/task_manager/server/types.ts rename to x-pack/plugins/task_manager/server/types.ts diff --git a/x-pack/test/alerting_api_integration/common/fixtures/plugins/task_manager/index.ts b/x-pack/test/alerting_api_integration/common/fixtures/plugins/task_manager/index.ts index 3bfad59b71166..29708f86b0a9b 100644 --- a/x-pack/test/alerting_api_integration/common/fixtures/plugins/task_manager/index.ts +++ b/x-pack/test/alerting_api_integration/common/fixtures/plugins/task_manager/index.ts @@ -4,6 +4,8 @@ * you may not use this file except in compliance with the Elastic License. */ +import { TaskManagerStartContract } from '../../../../../../plugins/task_manager/server'; + const taskManagerQuery = (...filters: any[]) => ({ bool: { filter: { @@ -38,7 +40,7 @@ export default function(kibana: any) { }, init(server: any) { - const taskManager = server.plugins.task_manager; + const taskManager = server.newPlatform.start.plugins.taskManager as TaskManagerStartContract; server.route({ path: '/api/alerting_tasks/{taskId}', diff --git a/x-pack/test/plugin_api_integration/plugins/task_manager/index.js b/x-pack/test/plugin_api_integration/plugins/task_manager/index.js index b0e46543b4e76..50fb9571c2687 100644 --- a/x-pack/test/plugin_api_integration/plugins/task_manager/index.js +++ b/x-pack/test/plugin_api_integration/plugins/task_manager/index.js @@ -28,7 +28,11 @@ export default function TaskTestingAPI(kibana) { }, init(server) { - const taskManager = server.plugins.task_manager; + const taskManager = { + ...server.newPlatform.setup.plugins.taskManager, + ...server.newPlatform.start.plugins.taskManager, + }; + const legacyTaskManager = server.plugins.task_manager; const defaultSampleTaskConfig = { timeout: '1m', @@ -128,7 +132,7 @@ export default function TaskTestingAPI(kibana) { }, }); - initRoutes(server, taskTestingEvents); + initRoutes(server, taskManager, legacyTaskManager, taskTestingEvents); }, }); } diff --git a/x-pack/test/plugin_api_integration/plugins/task_manager/init_routes.js b/x-pack/test/plugin_api_integration/plugins/task_manager/init_routes.js index 3330d08dfd0d2..c0dcd99525915 100644 --- a/x-pack/test/plugin_api_integration/plugins/task_manager/init_routes.js +++ b/x-pack/test/plugin_api_integration/plugins/task_manager/init_routes.js @@ -23,9 +23,7 @@ const taskManagerQuery = { }, }; -export function initRoutes(server, taskTestingEvents) { - const taskManager = server.plugins.task_manager; - +export function initRoutes(server, taskManager, legacyTaskManager, taskTestingEvents) { server.route({ path: '/api/sample_tasks/schedule', method: 'POST', @@ -62,6 +60,45 @@ export function initRoutes(server, taskTestingEvents) { }, }); + /* + Schedule using legacy Api + */ + server.route({ + path: '/api/sample_tasks/schedule_legacy', + method: 'POST', + config: { + validate: { + payload: Joi.object({ + task: Joi.object({ + taskType: Joi.string().required(), + schedule: Joi.object({ + interval: Joi.string(), + }).optional(), + interval: Joi.string().optional(), + params: Joi.object().required(), + state: Joi.object().optional(), + id: Joi.string().optional(), + }), + }), + }, + }, + async handler(request) { + try { + const { task: taskFields } = request.payload; + const task = { + ...taskFields, + scope: [scope], + }; + + const taskResult = await legacyTaskManager.schedule(task, { request }); + + return taskResult; + } catch (err) { + return err; + } + }, + }); + server.route({ path: '/api/sample_tasks/run_now', method: 'POST', diff --git a/x-pack/test/plugin_api_integration/test_suites/task_manager/task_manager_integration.js b/x-pack/test/plugin_api_integration/test_suites/task_manager/task_manager_integration.js index ff06bee83d51d..0b1c1cbb5af29 100644 --- a/x-pack/test/plugin_api_integration/test_suites/task_manager/task_manager_integration.js +++ b/x-pack/test/plugin_api_integration/test_suites/task_manager/task_manager_integration.js @@ -74,6 +74,15 @@ export default function({ getService }) { .then(response => response.body); } + function scheduleTaskUsingLegacyApi(task) { + return supertest + .post('/api/sample_tasks/schedule_legacy') + .set('kbn-xsrf', 'xxx') + .send({ task }) + .expect(200) + .then(response => response.body); + } + function runTaskNow(task) { return supertest .post('/api/sample_tasks/run_now') @@ -494,5 +503,15 @@ export default function({ getService }) { expect(getTaskById(tasks, longRunningTask.id).state.count).to.eql(1); }); }); + + it('should retain the legacy api until v8.0.0', async () => { + const result = await scheduleTaskUsingLegacyApi({ + id: 'task-with-legacy-api', + taskType: 'sampleTask', + params: {}, + }); + + expect(result.id).to.be('task-with-legacy-api'); + }); }); } diff --git a/x-pack/test/plugin_api_perf/plugins/task_manager_performance/index.js b/x-pack/test/plugin_api_perf/plugins/task_manager_performance/index.js index c3cd582fd59c4..87e3b3b66a201 100644 --- a/x-pack/test/plugin_api_perf/plugins/task_manager_performance/index.js +++ b/x-pack/test/plugin_api_perf/plugins/task_manager_performance/index.js @@ -23,7 +23,10 @@ export default function TaskManagerPerformanceAPI(kibana) { }, init(server) { - const taskManager = server.plugins.task_manager; + const taskManager = { + ...server.newPlatform.setup.plugins.taskManager, + ...server.newPlatform.start.plugins.taskManager, + }; const performanceState = resetPerfState({}); let lastFlush = new Date(); diff --git a/x-pack/test/plugin_api_perf/plugins/task_manager_performance/init_routes.js b/x-pack/test/plugin_api_perf/plugins/task_manager_performance/init_routes.js index ca6d8707f5c58..6cd706a6ebecd 100644 --- a/x-pack/test/plugin_api_perf/plugins/task_manager_performance/init_routes.js +++ b/x-pack/test/plugin_api_perf/plugins/task_manager_performance/init_routes.js @@ -9,7 +9,10 @@ import { range, chunk } from 'lodash'; const scope = 'perf-testing'; export function initRoutes(server, performanceState) { - const taskManager = server.plugins.task_manager; + const taskManager = { + ...server.newPlatform.setup.plugins.taskManager, + ...server.newPlatform.start.plugins.taskManager, + }; server.route({ path: '/api/perf_tasks', diff --git a/x-pack/test/typings/hapi.d.ts b/x-pack/test/typings/hapi.d.ts index 0400c1b7d8f23..fc5ce09e5e618 100644 --- a/x-pack/test/typings/hapi.d.ts +++ b/x-pack/test/typings/hapi.d.ts @@ -9,7 +9,6 @@ import 'hapi'; import { XPackMainPlugin } from '../../legacy/plugins/xpack_main/server/xpack_main'; import { SecurityPlugin } from '../../legacy/plugins/security'; import { ActionsPlugin, ActionsClient } from '../../legacy/plugins/actions'; -import { TaskManager } from '../../legacy/plugins/task_manager/server'; import { AlertingPlugin, AlertsClient } from '../../legacy/plugins/alerting'; declare module 'hapi' { @@ -22,6 +21,5 @@ declare module 'hapi' { security?: SecurityPlugin; actions?: ActionsPlugin; alerting?: AlertingPlugin; - task_manager?: TaskManager; } } diff --git a/x-pack/typings/hapi.d.ts b/x-pack/typings/hapi.d.ts index cfc1a641550fc..a739d5f884f6e 100644 --- a/x-pack/typings/hapi.d.ts +++ b/x-pack/typings/hapi.d.ts @@ -9,8 +9,8 @@ import 'hapi'; import { XPackMainPlugin } from '../legacy/plugins/xpack_main/server/xpack_main'; import { SecurityPlugin } from '../legacy/plugins/security'; import { ActionsPlugin, ActionsClient } from '../legacy/plugins/actions'; -import { TaskManager } from '../legacy/plugins/task_manager/server'; import { AlertingPlugin, AlertsClient } from '../legacy/plugins/alerting'; +import { LegacyTaskManagerApi } from '../legacy/plugins/task_manager/server'; declare module 'hapi' { interface Request { @@ -22,6 +22,6 @@ declare module 'hapi' { security?: SecurityPlugin; actions?: ActionsPlugin; alerting?: AlertingPlugin; - task_manager?: TaskManager; + task_manager?: LegacyTaskManagerApi; } } From 5ef4aa10e7af43041abf89aa22baf8108e656a7b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Felix=20St=C3=BCrmer?= Date: Mon, 13 Jan 2020 20:15:15 +0100 Subject: [PATCH 047/139] [Logs UI] Add categories table to the categorization tab (#53004) This renders the log entry categories after the ML jobs have been set up previously. closes #42776 closes #42065 --- .../http_api/log_analysis/results/index.ts | 2 + .../results/log_entry_categories.ts | 109 ++++++ .../results/log_entry_category_datasets.ts | 63 +++ .../infra/common/http_api/shared/index.ts | 1 + .../infra/common/http_api/shared/timing.ts | 13 + .../infra/common/log_analysis/index.ts | 3 + .../infra/common/log_analysis/log_analysis.ts | 8 - .../log_analysis/log_analysis_results.ts | 46 +++ .../log_entry_categories_analysis.ts | 17 + .../log_analysis/log_entry_rate_analysis.ts | 15 + .../infra/common/performance_tracing.ts | 33 ++ .../plugins/infra/common/runtime_types.ts | 15 +- .../plugins/infra/public/apps/start_app.tsx | 1 + .../logging/log_analysis_job_status/index.ts | 1 + .../log_analysis_job_problem_indicator.tsx | 15 +- .../recreate_job_button.tsx | 18 + .../recreate_job_callout.tsx | 12 +- .../first_use_callout.tsx | 27 ++ .../logging/log_analysis_results/index.ts | 1 + .../api/ml_get_jobs_summary_api.ts | 1 + .../log_analysis_module_status.tsx | 6 +- .../log_entry_categories/module_descriptor.ts | 17 +- .../log_entry_categories/page_content.tsx | 4 +- .../page_results_content.tsx | 240 ++++++++++++ .../anomaly_severity_indicator.tsx | 31 ++ .../top_categories/category_expression.tsx | 65 ++++ .../sections/top_categories/datasets_list.tsx | 20 + .../top_categories/datasets_selector.tsx | 60 +++ .../sections/top_categories/index.ts | 7 + .../log_entry_count_sparkline.tsx | 50 +++ .../single_metric_comparison.tsx | 57 +++ .../single_metric_sparkline.tsx | 65 ++++ .../top_categories/top_categories_section.tsx | 82 ++++ .../top_categories/top_categories_table.tsx | 106 +++++ .../get_log_entry_category_datasets.ts | 46 +++ .../get_top_log_entry_categories.ts | 67 ++++ .../use_log_entry_categories_results.ts | 116 ++++++ ...log_entry_categories_results_url_state.tsx | 64 +++ .../pages/logs/log_entry_rate/first_use.tsx | 30 -- .../logs/log_entry_rate/module_descriptor.ts | 23 +- .../log_entry_rate/page_results_content.tsx | 12 +- .../sections/anomalies/chart.tsx | 13 +- .../sections/anomalies/index.tsx | 13 +- .../sections/anomalies/table.tsx | 12 +- .../sections/helpers/data_formatters.tsx | 38 +- .../infra/public/utils/use_tracked_promise.ts | 4 +- .../plugins/infra/server/infra_server.ts | 4 + .../infra/server/lib/compose/kibana.ts | 8 +- .../plugins/infra/server/lib/infra_types.ts | 5 +- .../infra/server/lib/log_analysis/errors.ts | 2 +- .../infra/server/lib/log_analysis/index.ts | 3 +- .../log_entry_categories_analysis.ts | 363 ++++++++++++++++++ ...analysis.ts => log_entry_rate_analysis.ts} | 10 +- .../server/lib/log_analysis/queries/common.ts | 37 ++ .../server/lib/log_analysis/queries/index.ts | 1 + .../queries/log_entry_categories.ts | 53 +++ .../queries/log_entry_category_histograms.ts | 125 ++++++ .../queries/log_entry_data_sets.ts | 93 +++++ .../log_analysis/queries/log_entry_rate.ts | 9 +- .../queries/top_log_entry_categories.ts | 160 ++++++++ .../infra/server/new_platform_plugin.ts | 8 +- .../routes/log_analysis/results/index.ts | 2 + .../results/log_entry_categories.ts | 93 +++++ .../results/log_entry_category_datasets.ts | 82 ++++ .../log_analysis/results/log_entry_rate.ts | 12 +- .../utils/elasticsearch_runtime_types.ts | 18 + .../translations/translations/ja-JP.json | 2 - .../translations/translations/zh-CN.json | 2 - 68 files changed, 2581 insertions(+), 160 deletions(-) create mode 100644 x-pack/legacy/plugins/infra/common/http_api/log_analysis/results/log_entry_categories.ts create mode 100644 x-pack/legacy/plugins/infra/common/http_api/log_analysis/results/log_entry_category_datasets.ts create mode 100644 x-pack/legacy/plugins/infra/common/http_api/shared/timing.ts create mode 100644 x-pack/legacy/plugins/infra/common/log_analysis/log_analysis_results.ts create mode 100644 x-pack/legacy/plugins/infra/common/log_analysis/log_entry_categories_analysis.ts create mode 100644 x-pack/legacy/plugins/infra/common/log_analysis/log_entry_rate_analysis.ts create mode 100644 x-pack/legacy/plugins/infra/common/performance_tracing.ts create mode 100644 x-pack/legacy/plugins/infra/public/components/logging/log_analysis_job_status/recreate_job_button.tsx create mode 100644 x-pack/legacy/plugins/infra/public/components/logging/log_analysis_results/first_use_callout.tsx create mode 100644 x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/page_results_content.tsx create mode 100644 x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/anomaly_severity_indicator.tsx create mode 100644 x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/category_expression.tsx create mode 100644 x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/datasets_list.tsx create mode 100644 x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/datasets_selector.tsx create mode 100644 x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/index.ts create mode 100644 x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/log_entry_count_sparkline.tsx create mode 100644 x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/single_metric_comparison.tsx create mode 100644 x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/single_metric_sparkline.tsx create mode 100644 x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/top_categories_section.tsx create mode 100644 x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/top_categories_table.tsx create mode 100644 x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/service_calls/get_log_entry_category_datasets.ts create mode 100644 x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/service_calls/get_top_log_entry_categories.ts create mode 100644 x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/use_log_entry_categories_results.ts create mode 100644 x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/use_log_entry_categories_results_url_state.tsx delete mode 100644 x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/first_use.tsx create mode 100644 x-pack/legacy/plugins/infra/server/lib/log_analysis/log_entry_categories_analysis.ts rename x-pack/legacy/plugins/infra/server/lib/log_analysis/{log_analysis.ts => log_entry_rate_analysis.ts} (95%) create mode 100644 x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/common.ts create mode 100644 x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/log_entry_categories.ts create mode 100644 x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/log_entry_category_histograms.ts create mode 100644 x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/log_entry_data_sets.ts create mode 100644 x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/top_log_entry_categories.ts create mode 100644 x-pack/legacy/plugins/infra/server/routes/log_analysis/results/log_entry_categories.ts create mode 100644 x-pack/legacy/plugins/infra/server/routes/log_analysis/results/log_entry_category_datasets.ts create mode 100644 x-pack/legacy/plugins/infra/server/utils/elasticsearch_runtime_types.ts diff --git a/x-pack/legacy/plugins/infra/common/http_api/log_analysis/results/index.ts b/x-pack/legacy/plugins/infra/common/http_api/log_analysis/results/index.ts index 1749421277719..d9ca9a96ffe51 100644 --- a/x-pack/legacy/plugins/infra/common/http_api/log_analysis/results/index.ts +++ b/x-pack/legacy/plugins/infra/common/http_api/log_analysis/results/index.ts @@ -4,4 +4,6 @@ * you may not use this file except in compliance with the Elastic License. */ +export * from './log_entry_categories'; +export * from './log_entry_category_datasets'; export * from './log_entry_rate'; diff --git a/x-pack/legacy/plugins/infra/common/http_api/log_analysis/results/log_entry_categories.ts b/x-pack/legacy/plugins/infra/common/http_api/log_analysis/results/log_entry_categories.ts new file mode 100644 index 0000000000000..66823c25237ac --- /dev/null +++ b/x-pack/legacy/plugins/infra/common/http_api/log_analysis/results/log_entry_categories.ts @@ -0,0 +1,109 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import * as rt from 'io-ts'; + +import { + badRequestErrorRT, + forbiddenErrorRT, + timeRangeRT, + routeTimingMetadataRT, +} from '../../shared'; + +export const LOG_ANALYSIS_GET_LOG_ENTRY_CATEGORIES_PATH = + '/api/infra/log_analysis/results/log_entry_categories'; + +/** + * request + */ + +const logEntryCategoriesHistogramParametersRT = rt.type({ + id: rt.string, + timeRange: timeRangeRT, + bucketCount: rt.number, +}); + +export type LogEntryCategoriesHistogramParameters = rt.TypeOf< + typeof logEntryCategoriesHistogramParametersRT +>; + +export const getLogEntryCategoriesRequestPayloadRT = rt.type({ + data: rt.intersection([ + rt.type({ + // the number of categories to fetch + categoryCount: rt.number, + // the id of the source configuration + sourceId: rt.string, + // the time range to fetch the categories from + timeRange: timeRangeRT, + // a list of histograms to create + histograms: rt.array(logEntryCategoriesHistogramParametersRT), + }), + rt.partial({ + // the datasets to filter for (optional, unfiltered if not present) + datasets: rt.array(rt.string), + }), + ]), +}); + +export type GetLogEntryCategoriesRequestPayload = rt.TypeOf< + typeof getLogEntryCategoriesRequestPayloadRT +>; + +/** + * response + */ + +export const logEntryCategoryHistogramBucketRT = rt.type({ + startTime: rt.number, + bucketDuration: rt.number, + logEntryCount: rt.number, +}); + +export type LogEntryCategoryHistogramBucket = rt.TypeOf; + +export const logEntryCategoryHistogramRT = rt.type({ + histogramId: rt.string, + buckets: rt.array(logEntryCategoryHistogramBucketRT), +}); + +export type LogEntryCategoryHistogram = rt.TypeOf; + +export const logEntryCategoryRT = rt.type({ + categoryId: rt.number, + datasets: rt.array(rt.string), + histograms: rt.array(logEntryCategoryHistogramRT), + logEntryCount: rt.number, + maximumAnomalyScore: rt.number, + regularExpression: rt.string, +}); + +export type LogEntryCategory = rt.TypeOf; + +export const getLogEntryCategoriesSuccessReponsePayloadRT = rt.intersection([ + rt.type({ + data: rt.type({ + categories: rt.array(logEntryCategoryRT), + }), + }), + rt.partial({ + timing: routeTimingMetadataRT, + }), +]); + +export type GetLogEntryCategoriesSuccessResponsePayload = rt.TypeOf< + typeof getLogEntryCategoriesSuccessReponsePayloadRT +>; + +export const getLogEntryCategoriesResponsePayloadRT = rt.union([ + getLogEntryCategoriesSuccessReponsePayloadRT, + badRequestErrorRT, + forbiddenErrorRT, +]); + +export type GetLogEntryCategoriesReponsePayload = rt.TypeOf< + typeof getLogEntryCategoriesResponsePayloadRT +>; diff --git a/x-pack/legacy/plugins/infra/common/http_api/log_analysis/results/log_entry_category_datasets.ts b/x-pack/legacy/plugins/infra/common/http_api/log_analysis/results/log_entry_category_datasets.ts new file mode 100644 index 0000000000000..934d1052fa29f --- /dev/null +++ b/x-pack/legacy/plugins/infra/common/http_api/log_analysis/results/log_entry_category_datasets.ts @@ -0,0 +1,63 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import * as rt from 'io-ts'; + +import { + badRequestErrorRT, + forbiddenErrorRT, + timeRangeRT, + routeTimingMetadataRT, +} from '../../shared'; + +export const LOG_ANALYSIS_GET_LOG_ENTRY_CATEGORY_DATASETS_PATH = + '/api/infra/log_analysis/results/log_entry_category_datasets'; + +/** + * request + */ + +export const getLogEntryCategoryDatasetsRequestPayloadRT = rt.type({ + data: rt.type({ + // the id of the source configuration + sourceId: rt.string, + // the time range to fetch the category datasets from + timeRange: timeRangeRT, + }), +}); + +export type GetLogEntryCategoryDatasetsRequestPayload = rt.TypeOf< + typeof getLogEntryCategoryDatasetsRequestPayloadRT +>; + +/** + * response + */ + +export const getLogEntryCategoryDatasetsSuccessReponsePayloadRT = rt.intersection([ + rt.type({ + data: rt.type({ + datasets: rt.array(rt.string), + }), + }), + rt.partial({ + timing: routeTimingMetadataRT, + }), +]); + +export type GetLogEntryCategoryDatasetsSuccessResponsePayload = rt.TypeOf< + typeof getLogEntryCategoryDatasetsSuccessReponsePayloadRT +>; + +export const getLogEntryCategoryDatasetsResponsePayloadRT = rt.union([ + getLogEntryCategoryDatasetsSuccessReponsePayloadRT, + badRequestErrorRT, + forbiddenErrorRT, +]); + +export type GetLogEntryCategoryDatasetsReponsePayload = rt.TypeOf< + typeof getLogEntryCategoryDatasetsResponsePayloadRT +>; diff --git a/x-pack/legacy/plugins/infra/common/http_api/shared/index.ts b/x-pack/legacy/plugins/infra/common/http_api/shared/index.ts index 1047ca2f2a01a..caeb1914cb8a2 100644 --- a/x-pack/legacy/plugins/infra/common/http_api/shared/index.ts +++ b/x-pack/legacy/plugins/infra/common/http_api/shared/index.ts @@ -7,3 +7,4 @@ export * from './errors'; export * from './metric_statistics'; export * from './time_range'; +export * from './timing'; diff --git a/x-pack/legacy/plugins/infra/common/http_api/shared/timing.ts b/x-pack/legacy/plugins/infra/common/http_api/shared/timing.ts new file mode 100644 index 0000000000000..a208921c03d6f --- /dev/null +++ b/x-pack/legacy/plugins/infra/common/http_api/shared/timing.ts @@ -0,0 +1,13 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import * as rt from 'io-ts'; + +import { tracingSpanRT } from '../../performance_tracing'; + +export const routeTimingMetadataRT = rt.type({ + spans: rt.array(tracingSpanRT), +}); diff --git a/x-pack/legacy/plugins/infra/common/log_analysis/index.ts b/x-pack/legacy/plugins/infra/common/log_analysis/index.ts index 79913f829191d..22137e63ab7e7 100644 --- a/x-pack/legacy/plugins/infra/common/log_analysis/index.ts +++ b/x-pack/legacy/plugins/infra/common/log_analysis/index.ts @@ -5,4 +5,7 @@ */ export * from './log_analysis'; +export * from './log_analysis_results'; +export * from './log_entry_rate_analysis'; +export * from './log_entry_categories_analysis'; export * from './job_parameters'; diff --git a/x-pack/legacy/plugins/infra/common/log_analysis/log_analysis.ts b/x-pack/legacy/plugins/infra/common/log_analysis/log_analysis.ts index 4a6f20d549799..9b2f1a55eb8c1 100644 --- a/x-pack/legacy/plugins/infra/common/log_analysis/log_analysis.ts +++ b/x-pack/legacy/plugins/infra/common/log_analysis/log_analysis.ts @@ -4,14 +4,6 @@ * you may not use this file except in compliance with the Elastic License. */ -import * as rt from 'io-ts'; - -export const jobTypeRT = rt.keyof({ - 'log-entry-rate': null, -}); - -export type JobType = rt.TypeOf; - // combines and abstracts job and datafeed status export type JobStatus = | 'unknown' diff --git a/x-pack/legacy/plugins/infra/common/log_analysis/log_analysis_results.ts b/x-pack/legacy/plugins/infra/common/log_analysis/log_analysis_results.ts new file mode 100644 index 0000000000000..1dcd4a10fc4e3 --- /dev/null +++ b/x-pack/legacy/plugins/infra/common/log_analysis/log_analysis_results.ts @@ -0,0 +1,46 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export const ML_SEVERITY_SCORES = { + warning: 3, + minor: 25, + major: 50, + critical: 75, +}; + +export type MLSeverityScoreCategories = keyof typeof ML_SEVERITY_SCORES; + +export const ML_SEVERITY_COLORS = { + critical: 'rgb(228, 72, 72)', + major: 'rgb(229, 113, 0)', + minor: 'rgb(255, 221, 0)', + warning: 'rgb(125, 180, 226)', +}; + +export const getSeverityCategoryForScore = ( + score: number +): MLSeverityScoreCategories | undefined => { + if (score >= ML_SEVERITY_SCORES.critical) { + return 'critical'; + } else if (score >= ML_SEVERITY_SCORES.major) { + return 'major'; + } else if (score >= ML_SEVERITY_SCORES.minor) { + return 'minor'; + } else if (score >= ML_SEVERITY_SCORES.warning) { + return 'warning'; + } else { + // Category is too low to include + return undefined; + } +}; + +export const formatAnomalyScore = (score: number) => { + return Math.round(score); +}; + +export const getFriendlyNameForPartitionId = (partitionId: string) => { + return partitionId !== '' ? partitionId : 'unknown'; +}; diff --git a/x-pack/legacy/plugins/infra/common/log_analysis/log_entry_categories_analysis.ts b/x-pack/legacy/plugins/infra/common/log_analysis/log_entry_categories_analysis.ts new file mode 100644 index 0000000000000..0957126ee52e3 --- /dev/null +++ b/x-pack/legacy/plugins/infra/common/log_analysis/log_entry_categories_analysis.ts @@ -0,0 +1,17 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import * as rt from 'io-ts'; + +export const logEntryCategoriesJobTypeRT = rt.keyof({ + 'log-entry-categories-count': null, +}); + +export type LogEntryCategoriesJobType = rt.TypeOf; + +export const logEntryCategoriesJobTypes: LogEntryCategoriesJobType[] = [ + 'log-entry-categories-count', +]; diff --git a/x-pack/legacy/plugins/infra/common/log_analysis/log_entry_rate_analysis.ts b/x-pack/legacy/plugins/infra/common/log_analysis/log_entry_rate_analysis.ts new file mode 100644 index 0000000000000..7fd668dc4ebce --- /dev/null +++ b/x-pack/legacy/plugins/infra/common/log_analysis/log_entry_rate_analysis.ts @@ -0,0 +1,15 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import * as rt from 'io-ts'; + +export const logEntryRateJobTypeRT = rt.keyof({ + 'log-entry-rate': null, +}); + +export type LogEntryRateJobType = rt.TypeOf; + +export const logEntryRateJobTypes: LogEntryRateJobType[] = ['log-entry-rate']; diff --git a/x-pack/legacy/plugins/infra/common/performance_tracing.ts b/x-pack/legacy/plugins/infra/common/performance_tracing.ts new file mode 100644 index 0000000000000..3e96f3c19d06d --- /dev/null +++ b/x-pack/legacy/plugins/infra/common/performance_tracing.ts @@ -0,0 +1,33 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import * as rt from 'io-ts'; +import uuid from 'uuid'; + +export const tracingSpanRT = rt.type({ + duration: rt.number, + id: rt.string, + name: rt.string, + start: rt.number, +}); + +export type TracingSpan = rt.TypeOf; + +export type ActiveTrace = (endTime?: number) => TracingSpan; + +export const startTracingSpan = (name: string): ActiveTrace => { + const initialState: TracingSpan = { + duration: Number.POSITIVE_INFINITY, + id: uuid.v4(), + name, + start: Date.now(), + }; + + return (endTime: number = Date.now()) => ({ + ...initialState, + duration: endTime - initialState.start, + }); +}; diff --git a/x-pack/legacy/plugins/infra/common/runtime_types.ts b/x-pack/legacy/plugins/infra/common/runtime_types.ts index 297743f9b3456..d5b858df38def 100644 --- a/x-pack/legacy/plugins/infra/common/runtime_types.ts +++ b/x-pack/legacy/plugins/infra/common/runtime_types.ts @@ -4,11 +4,22 @@ * you may not use this file except in compliance with the Elastic License. */ -import { Errors } from 'io-ts'; +import { fold } from 'fp-ts/lib/Either'; +import { identity } from 'fp-ts/lib/function'; +import { pipe } from 'fp-ts/lib/pipeable'; +import { Errors, Type } from 'io-ts'; import { failure } from 'io-ts/lib/PathReporter'; +type ErrorFactory = (message: string) => Error; + export const createPlainError = (message: string) => new Error(message); -export const throwErrors = (createError: (message: string) => Error) => (errors: Errors) => { +export const throwErrors = (createError: ErrorFactory) => (errors: Errors) => { throw createError(failure(errors).join('\n')); }; + +export const decodeOrThrow = ( + runtimeType: Type, + createError: ErrorFactory = createPlainError +) => (inputValue: I) => + pipe(runtimeType.decode(inputValue), fold(throwErrors(createError), identity)); diff --git a/x-pack/legacy/plugins/infra/public/apps/start_app.tsx b/x-pack/legacy/plugins/infra/public/apps/start_app.tsx index 8ccb051724ede..dbdc827478a45 100644 --- a/x-pack/legacy/plugins/infra/public/apps/start_app.tsx +++ b/x-pack/legacy/plugins/infra/public/apps/start_app.tsx @@ -27,6 +27,7 @@ import { KibanaContextProvider, } from '../../../../../../src/plugins/kibana_react/public'; import { ROOT_ELEMENT_ID } from '../app'; + // NP_TODO: Type plugins export async function startApp(libs: InfraFrontendLibs, core: CoreStart, plugins: any) { const history = createHashHistory(); diff --git a/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_job_status/index.ts b/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_job_status/index.ts index 06229a26afd19..e954cf21229ee 100644 --- a/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_job_status/index.ts +++ b/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_job_status/index.ts @@ -5,3 +5,4 @@ */ export * from './log_analysis_job_problem_indicator'; +export * from './recreate_job_button'; diff --git a/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_job_status/log_analysis_job_problem_indicator.tsx b/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_job_status/log_analysis_job_problem_indicator.tsx index 018c5f5e0570d..8a16d819e12c2 100644 --- a/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_job_status/log_analysis_job_problem_indicator.tsx +++ b/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_job_status/log_analysis_job_problem_indicator.tsx @@ -17,13 +17,22 @@ export const LogAnalysisJobProblemIndicator: React.FC<{ onRecreateMlJobForReconfiguration: () => void; onRecreateMlJobForUpdate: () => void; }> = ({ jobStatus, setupStatus, onRecreateMlJobForReconfiguration, onRecreateMlJobForUpdate }) => { - if (jobStatus === 'stopped') { + if (isStopped(jobStatus)) { return ; - } else if (setupStatus === 'skippedButUpdatable') { + } else if (isUpdatable(setupStatus)) { return ; - } else if (setupStatus === 'skippedButReconfigurable') { + } else if (isReconfigurable(setupStatus)) { return ; } return null; // no problem to indicate }; + +const isStopped = (jobStatus: JobStatus) => jobStatus === 'stopped'; + +const isUpdatable = (setupStatus: SetupStatus) => setupStatus === 'skippedButUpdatable'; + +const isReconfigurable = (setupStatus: SetupStatus) => setupStatus === 'skippedButReconfigurable'; + +export const jobHasProblem = (jobStatus: JobStatus, setupStatus: SetupStatus) => + isStopped(jobStatus) || isUpdatable(setupStatus) || isReconfigurable(setupStatus); diff --git a/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_job_status/recreate_job_button.tsx b/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_job_status/recreate_job_button.tsx new file mode 100644 index 0000000000000..74e8d197ef455 --- /dev/null +++ b/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_job_status/recreate_job_button.tsx @@ -0,0 +1,18 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { EuiButton, PropsOf } from '@elastic/eui'; +import { FormattedMessage } from '@kbn/i18n/react'; +import React from 'react'; + +export const RecreateJobButton: React.FunctionComponent> = props => ( + + + +); diff --git a/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_job_status/recreate_job_callout.tsx b/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_job_status/recreate_job_callout.tsx index b95054bbd6a9b..5b872d4ee5147 100644 --- a/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_job_status/recreate_job_callout.tsx +++ b/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_job_status/recreate_job_callout.tsx @@ -5,8 +5,9 @@ */ import React from 'react'; -import { EuiCallOut, EuiButton } from '@elastic/eui'; -import { FormattedMessage } from '@kbn/i18n/react'; +import { EuiCallOut } from '@elastic/eui'; + +import { RecreateJobButton } from './recreate_job_button'; export const RecreateJobCallout: React.FC<{ onRecreateMlJob: () => void; @@ -14,11 +15,6 @@ export const RecreateJobCallout: React.FC<{ }> = ({ children, onRecreateMlJob, title }) => (

{children}

- - - +
); diff --git a/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_results/first_use_callout.tsx b/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_results/first_use_callout.tsx new file mode 100644 index 0000000000000..7fcdcc89a633a --- /dev/null +++ b/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_results/first_use_callout.tsx @@ -0,0 +1,27 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { EuiCallOut } from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; +import React from 'react'; + +export const FirstUseCallout = () => { + return ( + +

+ {i18n.translate('xpack.infra.logs.analysis.onboardingSuccessContent', { + defaultMessage: + 'Please allow a few minutes for our machine learning robots to begin collecting data.', + })} +

+
+ ); +}; diff --git a/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_results/index.ts b/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_results/index.ts index 8a4ceb70252a3..a3139124e6c9f 100644 --- a/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_results/index.ts +++ b/x-pack/legacy/plugins/infra/public/components/logging/log_analysis_results/index.ts @@ -5,3 +5,4 @@ */ export * from './analyze_in_ml_button'; +export * from './first_use_callout'; diff --git a/x-pack/legacy/plugins/infra/public/containers/logs/log_analysis/api/ml_get_jobs_summary_api.ts b/x-pack/legacy/plugins/infra/public/containers/logs/log_analysis/api/ml_get_jobs_summary_api.ts index 41c155e185c3a..a067285026e33 100644 --- a/x-pack/legacy/plugins/infra/public/containers/logs/log_analysis/api/ml_get_jobs_summary_api.ts +++ b/x-pack/legacy/plugins/infra/public/containers/logs/log_analysis/api/ml_get_jobs_summary_api.ts @@ -41,6 +41,7 @@ export type FetchJobStatusRequestPayload = rt.TypeOf ( jobSummaries .filter(jobSummary => jobSummary.id === jobId) .every( - jobSummary => - jobSummary.fullJob && - jobSummary.fullJob.custom_settings && - jobSummary.fullJob.custom_settings.job_revision && - jobSummary.fullJob.custom_settings.job_revision >= currentRevision + jobSummary => (jobSummary?.fullJob?.custom_settings?.job_revision ?? 0) >= currentRevision ); const isJobConfigurationConsistent = ( diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/module_descriptor.ts b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/module_descriptor.ts index 5910dc54dfc90..be7547f2e74cb 100644 --- a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/module_descriptor.ts +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/module_descriptor.ts @@ -8,6 +8,8 @@ import { bucketSpan, categoriesMessageField, getJobId, + LogEntryCategoriesJobType, + logEntryCategoriesJobTypes, partitionField, } from '../../../../common/log_analysis'; @@ -21,22 +23,19 @@ import { callGetMlModuleAPI } from '../../../containers/logs/log_analysis/api/ml import { callSetupMlModuleAPI } from '../../../containers/logs/log_analysis/api/ml_setup_module_api'; import { callValidateIndicesAPI } from '../../../containers/logs/log_analysis/api/validate_indices'; -const jobTypes = ['log-entry-categories-count']; const moduleId = 'logs_ui_categories'; -type JobType = typeof jobTypes[0]; - const getJobIds = (spaceId: string, sourceId: string) => - jobTypes.reduce( + logEntryCategoriesJobTypes.reduce( (accumulatedJobIds, jobType) => ({ ...accumulatedJobIds, [jobType]: getJobId(spaceId, sourceId, jobType), }), - {} as Record + {} as Record ); const getJobSummary = async (spaceId: string, sourceId: string) => { - const response = await callJobsSummaryAPI(spaceId, sourceId, jobTypes); + const response = await callJobsSummaryAPI(spaceId, sourceId, logEntryCategoriesJobTypes); const jobIds = Object.values(getJobIds(spaceId, sourceId)); return response.filter(jobSummary => jobIds.includes(jobSummary.id)); @@ -83,7 +82,7 @@ const setUpModule = async ( }; const cleanUpModule = async (spaceId: string, sourceId: string) => { - return await cleanUpJobsAndDatafeeds(spaceId, sourceId, jobTypes); + return await cleanUpJobsAndDatafeeds(spaceId, sourceId, logEntryCategoriesJobTypes); }; const validateSetupIndices = async ({ indices, timestampField }: ModuleSourceConfiguration) => { @@ -103,9 +102,9 @@ const validateSetupIndices = async ({ indices, timestampField }: ModuleSourceCon ]); }; -export const logEntryCategoriesModule: ModuleDescriptor = { +export const logEntryCategoriesModule: ModuleDescriptor = { moduleId, - jobTypes, + jobTypes: logEntryCategoriesJobTypes, bucketSpan, getJobIds, getJobSummary, diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/page_content.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/page_content.tsx index 9a50acf622ee1..cc59d73055796 100644 --- a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/page_content.tsx +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/page_content.tsx @@ -14,6 +14,7 @@ import { MlUnavailablePrompt, } from '../../../components/logging/log_analysis_setup'; import { LogAnalysisCapabilities } from '../../../containers/logs/log_analysis'; +import { LogEntryCategoriesResultsContent } from './page_results_content'; import { LogEntryCategoriesSetupContent } from './page_setup_content'; import { useLogEntryCategoriesModuleContext } from './use_log_entry_categories_module'; @@ -44,8 +45,7 @@ export const LogEntryCategoriesPageContent = () => { } else if (setupStatus === 'unknown') { return ; } else if (isSetupStatusWithResults(setupStatus)) { - return null; - // return ; + return ; } else { return ; } diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/page_results_content.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/page_results_content.tsx new file mode 100644 index 0000000000000..ffffba0691749 --- /dev/null +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/page_results_content.tsx @@ -0,0 +1,240 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import datemath from '@elastic/datemath'; +import { EuiFlexGroup, EuiFlexItem, EuiPage, EuiPanel, EuiSuperDatePicker } from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; +import moment from 'moment'; +import React, { useCallback, useEffect, useMemo, useState } from 'react'; + +import { useKibana } from '../../../../../../../../src/plugins/kibana_react/public'; +import euiStyled from '../../../../../../common/eui_styled_components'; +import { TimeRange } from '../../../../common/http_api/shared/time_range'; +import { + LogAnalysisJobProblemIndicator, + jobHasProblem, +} from '../../../components/logging/log_analysis_job_status'; +import { FirstUseCallout } from '../../../components/logging/log_analysis_results'; +import { useInterval } from '../../../hooks/use_interval'; +import { useTrackPageview } from '../../../hooks/use_track_metric'; +import { TopCategoriesSection } from './sections/top_categories'; +import { useLogEntryCategoriesModuleContext } from './use_log_entry_categories_module'; +import { useLogEntryCategoriesResults } from './use_log_entry_categories_results'; +import { + StringTimeRange, + useLogEntryCategoriesResultsUrlState, +} from './use_log_entry_categories_results_url_state'; + +const JOB_STATUS_POLLING_INTERVAL = 30000; + +export const LogEntryCategoriesResultsContent: React.FunctionComponent = () => { + useTrackPageview({ app: 'infra_logs', path: 'log_entry_categories_results' }); + useTrackPageview({ app: 'infra_logs', path: 'log_entry_categories_results', delay: 15000 }); + + const { + fetchJobStatus, + jobStatus, + setupStatus, + viewSetupForReconfiguration, + viewSetupForUpdate, + jobIds, + sourceConfiguration: { sourceId }, + } = useLogEntryCategoriesModuleContext(); + + const { + timeRange: selectedTimeRange, + setTimeRange: setSelectedTimeRange, + autoRefresh, + setAutoRefresh, + } = useLogEntryCategoriesResultsUrlState(); + + const [categoryQueryTimeRange, setCategoryQueryTimeRange] = useState<{ + lastChangedTime: number; + timeRange: TimeRange; + }>(() => ({ + lastChangedTime: Date.now(), + timeRange: stringToNumericTimeRange(selectedTimeRange), + })); + + const [categoryQueryDatasets, setCategoryQueryDatasets] = useState([]); + + const { services } = useKibana<{}>(); + + const showLoadDataErrorNotification = useCallback( + (error: Error) => { + // eslint-disable-next-line no-unused-expressions + services.notifications?.toasts.addError(error, { + title: loadDataErrorTitle, + }); + }, + [services.notifications] + ); + + const { + getLogEntryCategoryDatasets, + getTopLogEntryCategories, + isLoadingLogEntryCategoryDatasets, + isLoadingTopLogEntryCategories, + logEntryCategoryDatasets, + topLogEntryCategories, + } = useLogEntryCategoriesResults({ + categoriesCount: 25, + endTime: categoryQueryTimeRange.timeRange.endTime, + filteredDatasets: categoryQueryDatasets, + onGetTopLogEntryCategoriesError: showLoadDataErrorNotification, + sourceId, + startTime: categoryQueryTimeRange.timeRange.startTime, + }); + + const handleQueryTimeRangeChange = useCallback( + ({ start: startTime, end: endTime }: { start: string; end: string }) => { + setCategoryQueryTimeRange(previousQueryParameters => ({ + ...previousQueryParameters, + timeRange: stringToNumericTimeRange({ startTime, endTime }), + lastChangedTime: Date.now(), + })); + }, + [setCategoryQueryTimeRange] + ); + + const handleSelectedTimeRangeChange = useCallback( + (selectedTime: { start: string; end: string; isInvalid: boolean }) => { + if (selectedTime.isInvalid) { + return; + } + setSelectedTimeRange({ + startTime: selectedTime.start, + endTime: selectedTime.end, + }); + handleQueryTimeRangeChange(selectedTime); + }, + [setSelectedTimeRange, handleQueryTimeRangeChange] + ); + + const handleAutoRefreshChange = useCallback( + ({ isPaused, refreshInterval: interval }: { isPaused: boolean; refreshInterval: number }) => { + setAutoRefresh({ + isPaused, + interval, + }); + }, + [setAutoRefresh] + ); + + const isFirstUse = useMemo(() => setupStatus === 'hiddenAfterSuccess', [setupStatus]); + + const hasResults = useMemo(() => topLogEntryCategories.length > 0, [ + topLogEntryCategories.length, + ]); + + useEffect(() => { + getTopLogEntryCategories(); + }, [getTopLogEntryCategories, categoryQueryDatasets, categoryQueryTimeRange.lastChangedTime]); + + useEffect(() => { + getLogEntryCategoryDatasets(); + }, [getLogEntryCategoryDatasets, categoryQueryTimeRange.lastChangedTime]); + + useInterval(() => { + fetchJobStatus(); + }, JOB_STATUS_POLLING_INTERVAL); + + useInterval( + () => { + handleQueryTimeRangeChange({ + start: selectedTimeRange.startTime, + end: selectedTimeRange.endTime, + }); + }, + autoRefresh.isPaused ? null : autoRefresh.interval + ); + + return ( + + + + + + + + + + + + + {jobHasProblem(jobStatus['log-entry-categories-count'], setupStatus) ? ( + + + + ) : null} + {isFirstUse && !hasResults ? ( + + + + ) : null} + + + + + + + + ); +}; + +const stringToNumericTimeRange = (timeRange: StringTimeRange): TimeRange => ({ + startTime: moment( + datemath.parse(timeRange.startTime, { + momentInstance: moment, + }) + ).valueOf(), + endTime: moment( + datemath.parse(timeRange.endTime, { + momentInstance: moment, + roundUp: true, + }) + ).valueOf(), +}); + +// This is needed due to the flex-basis: 100% !important; rule that +// kicks in on small screens via media queries breaking when using direction="column" +export const ResultsContentPage = euiStyled(EuiPage)` + flex: 1 0 0%; + flex-direction: column; + + .euiFlexGroup--responsive > .euiFlexItem { + flex-basis: auto !important; + } +`; + +const loadDataErrorTitle = i18n.translate( + 'xpack.infra.logs.logEntryCategories.loadDataErrorTitle', + { + defaultMessage: 'Failed to load category data', + } +); diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/anomaly_severity_indicator.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/anomaly_severity_indicator.tsx new file mode 100644 index 0000000000000..e50231316fb5a --- /dev/null +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/anomaly_severity_indicator.tsx @@ -0,0 +1,31 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { EuiHealth } from '@elastic/eui'; +import React, { useMemo } from 'react'; +import { + formatAnomalyScore, + getSeverityCategoryForScore, + ML_SEVERITY_COLORS, +} from '../../../../../../common/log_analysis'; + +export const AnomalySeverityIndicator: React.FunctionComponent<{ + anomalyScore: number; +}> = ({ anomalyScore }) => { + const severityColor = useMemo(() => getColorForAnomalyScore(anomalyScore), [anomalyScore]); + + return {formatAnomalyScore(anomalyScore)}; +}; + +const getColorForAnomalyScore = (anomalyScore: number) => { + const severityCategory = getSeverityCategoryForScore(anomalyScore); + + if (severityCategory != null && severityCategory in ML_SEVERITY_COLORS) { + return ML_SEVERITY_COLORS[severityCategory]; + } else { + return 'subdued'; + } +}; diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/category_expression.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/category_expression.tsx new file mode 100644 index 0000000000000..5c8b18528cae6 --- /dev/null +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/category_expression.tsx @@ -0,0 +1,65 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { i18n } from '@kbn/i18n'; +import React, { memo } from 'react'; + +import euiStyled from '../../../../../../../../common/eui_styled_components'; + +export const RegularExpressionRepresentation: React.FunctionComponent<{ + maximumSegmentCount?: number; + regularExpression: string; +}> = memo(({ maximumSegmentCount = 30, regularExpression }) => { + const segments = regularExpression.split(collapsedRegularExpressionCharacters); + + return ( + + {segments + .slice(0, maximumSegmentCount) + .map((segment, segmentIndex) => [ + segmentIndex > 0 ? ( + + ) : null, + + {segment.replace(escapedRegularExpressionCharacters, '$1')} + , + ])} + {segments.length > maximumSegmentCount ? ( + + … + + ) : null} + + ); +}); + +const CategoryPattern = euiStyled.span` + font-family: ${props => props.theme.eui.euiCodeFontFamily}; + word-break: break-all; +`; + +const CategoryPatternWildcard = euiStyled.span` + color: ${props => props.theme.eui.euiColorMediumShade}; +`; + +const CategoryPatternSegment = euiStyled.span` + font-weight: bold; +`; + +const collapsedRegularExpressionCharacters = /\.[+*]\??/g; + +const escapedRegularExpressionCharacters = /\\([\\^$*+?.()\[\]])/g; diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/datasets_list.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/datasets_list.tsx new file mode 100644 index 0000000000000..c30612f54be00 --- /dev/null +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/datasets_list.tsx @@ -0,0 +1,20 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React from 'react'; + +import { getFriendlyNameForPartitionId } from '../../../../../../common/log_analysis'; + +export const DatasetsList: React.FunctionComponent<{ + datasets: string[]; +}> = ({ datasets }) => ( +
    + {datasets.sort().map(dataset => { + const datasetLabel = getFriendlyNameForPartitionId(dataset); + return
  • {datasetLabel}
  • ; + })} +
+); diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/datasets_selector.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/datasets_selector.tsx new file mode 100644 index 0000000000000..9c22caa4b3465 --- /dev/null +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/datasets_selector.tsx @@ -0,0 +1,60 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { EuiComboBox, EuiComboBoxOptionProps } from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; +import React, { useCallback, useMemo } from 'react'; + +import { getFriendlyNameForPartitionId } from '../../../../../../common/log_analysis'; + +type DatasetOptionProps = EuiComboBoxOptionProps; + +export const DatasetsSelector: React.FunctionComponent<{ + availableDatasets: string[]; + isLoading?: boolean; + onChangeDatasetSelection: (datasets: string[]) => void; + selectedDatasets: string[]; +}> = ({ availableDatasets, isLoading = false, onChangeDatasetSelection, selectedDatasets }) => { + const options = useMemo( + () => + availableDatasets.map(dataset => ({ + value: dataset, + label: getFriendlyNameForPartitionId(dataset), + })), + [availableDatasets] + ); + + const selectedOptions = useMemo( + () => options.filter(({ value }) => value != null && selectedDatasets.includes(value)), + [options, selectedDatasets] + ); + + const handleChange = useCallback( + (newSelectedOptions: DatasetOptionProps[]) => + onChangeDatasetSelection(newSelectedOptions.map(({ value }) => value).filter(isDefined)), + [onChangeDatasetSelection] + ); + + return ( + + ); +}; + +const datasetFilterPlaceholder = i18n.translate( + 'xpack.infra.logs.logEntryCategories.datasetFilterPlaceholder', + { + defaultMessage: 'Filter by datasets', + } +); + +const isDefined = (value: Value): value is NonNullable => value != null; diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/index.ts b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/index.ts new file mode 100644 index 0000000000000..e699bbf956f94 --- /dev/null +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/index.ts @@ -0,0 +1,7 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export * from './top_categories_section'; diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/log_entry_count_sparkline.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/log_entry_count_sparkline.tsx new file mode 100644 index 0000000000000..7a29ea9aa0ebc --- /dev/null +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/log_entry_count_sparkline.tsx @@ -0,0 +1,50 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React, { useMemo } from 'react'; + +import { LogEntryCategoryHistogram } from '../../../../../../common/http_api/log_analysis'; +import { TimeRange } from '../../../../../../common/http_api/shared'; +import { SingleMetricComparison } from './single_metric_comparison'; +import { SingleMetricSparkline } from './single_metric_sparkline'; + +export const LogEntryCountSparkline: React.FunctionComponent<{ + currentCount: number; + histograms: LogEntryCategoryHistogram[]; + timeRange: TimeRange; +}> = ({ currentCount, histograms, timeRange }) => { + const metric = useMemo( + () => + histograms + .find(histogram => histogram.histogramId === 'history') + ?.buckets?.map(({ startTime: timestamp, logEntryCount: value }) => ({ + timestamp, + value, + })) ?? [], + [histograms] + ); + const referenceCount = useMemo( + () => + histograms.find(histogram => histogram.histogramId === 'reference')?.buckets?.[0] + ?.logEntryCount ?? 0, + [histograms] + ); + + const overallTimeRange = useMemo( + () => ({ + endTime: timeRange.endTime, + startTime: timeRange.startTime - (timeRange.endTime - timeRange.startTime), + }), + [timeRange.endTime, timeRange.startTime] + ); + + return ( + <> + + + + ); +}; diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/single_metric_comparison.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/single_metric_comparison.tsx new file mode 100644 index 0000000000000..1352afb60a505 --- /dev/null +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/single_metric_comparison.tsx @@ -0,0 +1,57 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { EuiIcon, EuiTextColor } from '@elastic/eui'; +import numeral from '@elastic/numeral'; +import { i18n } from '@kbn/i18n'; +import React from 'react'; + +import euiStyled from '../../../../../../../../common/eui_styled_components'; + +export const SingleMetricComparison: React.FunctionComponent<{ + currentValue: number; + previousValue: number; +}> = ({ currentValue, previousValue }) => { + const changeFactor = currentValue / previousValue - 1; + + if (changeFactor < 0) { + return ( + + + {formatPercentage(changeFactor)} + + ); + } else if (changeFactor > 0 && Number.isFinite(changeFactor)) { + return ( + + + {formatPercentage(changeFactor)} + + ); + } else if (changeFactor > 0 && !Number.isFinite(changeFactor)) { + return ( + + + {newCategoryTrendLabel} + + ); + } + + return null; +}; + +const formatPercentage = (value: number) => numeral(value).format('+0,0 %'); + +const newCategoryTrendLabel = i18n.translate( + 'xpack.infra.logs.logEntryCategories.newCategoryTrendLabel', + { + defaultMessage: 'new', + } +); + +const NoWrapSpan = euiStyled.span` + white-space: nowrap; +`; diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/single_metric_sparkline.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/single_metric_sparkline.tsx new file mode 100644 index 0000000000000..5fb8e3380f23f --- /dev/null +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/single_metric_sparkline.tsx @@ -0,0 +1,65 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React, { useMemo } from 'react'; +import { Chart, Settings, AreaSeries } from '@elastic/charts'; +import { + EUI_CHARTS_THEME_LIGHT, + EUI_SPARKLINE_THEME_PARTIAL, + EUI_CHARTS_THEME_DARK, +} from '@elastic/eui/dist/eui_charts_theme'; + +import { useKibanaUiSetting } from '../../../../../utils/use_kibana_ui_setting'; +import { TimeRange } from '../../../../../../common/http_api/shared'; + +interface TimeSeriesPoint { + timestamp: number; + value: number; +} + +const timestampAccessor = 'timestamp'; +const valueAccessor = ['value']; +const sparklineSize = { + height: 20, + width: 100, +}; + +export const SingleMetricSparkline: React.FunctionComponent<{ + metric: TimeSeriesPoint[]; + timeRange: TimeRange; +}> = ({ metric, timeRange }) => { + const [isDarkMode] = useKibanaUiSetting('theme:darkMode'); + + const theme = useMemo( + () => [ + // localThemeOverride, + EUI_SPARKLINE_THEME_PARTIAL, + isDarkMode ? EUI_CHARTS_THEME_DARK.theme : EUI_CHARTS_THEME_LIGHT.theme, + ], + [isDarkMode] + ); + + const xDomain = useMemo( + () => ({ + max: timeRange.endTime, + min: timeRange.startTime, + }), + [timeRange] + ); + + return ( + + + + + ); +}; diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/top_categories_section.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/top_categories_section.tsx new file mode 100644 index 0000000000000..0281615a59c78 --- /dev/null +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/top_categories_section.tsx @@ -0,0 +1,82 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { EuiFlexGroup, EuiFlexItem, EuiLoadingSpinner, EuiSpacer, EuiTitle } from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; +import React from 'react'; + +import { LogEntryCategory } from '../../../../../../common/http_api/log_analysis'; +import { TimeRange } from '../../../../../../common/http_api/shared'; +import { LoadingOverlayWrapper } from '../../../../../components/loading_overlay_wrapper'; +import { RecreateJobButton } from '../../../../../components/logging/log_analysis_job_status'; +import { AnalyzeInMlButton } from '../../../../../components/logging/log_analysis_results'; +import { DatasetsSelector } from './datasets_selector'; +import { TopCategoriesTable } from './top_categories_table'; + +export const TopCategoriesSection: React.FunctionComponent<{ + availableDatasets: string[]; + isLoadingDatasets?: boolean; + isLoadingTopCategories?: boolean; + jobId: string; + onChangeDatasetSelection: (datasets: string[]) => void; + onRequestRecreateMlJob: () => void; + selectedDatasets: string[]; + timeRange: TimeRange; + topCategories: LogEntryCategory[]; +}> = ({ + availableDatasets, + isLoadingDatasets = false, + isLoadingTopCategories = false, + jobId, + onChangeDatasetSelection, + onRequestRecreateMlJob, + selectedDatasets, + timeRange, + topCategories, +}) => { + return ( + <> + + + +

{title}

+
+
+ + + + + + +
+ + + + } + > + + + + ); +}; + +const title = i18n.translate('xpack.infra.logs.logEntryCategories.topCategoriesSectionTitle', { + defaultMessage: 'Log message categories', +}); + +const loadingAriaLabel = i18n.translate( + 'xpack.infra.logs.logEntryCategories.topCategoriesSectionLoadingAriaLabel', + { defaultMessage: 'Loading message categories' } +); + +const LoadingOverlayContent = () => ; diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/top_categories_table.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/top_categories_table.tsx new file mode 100644 index 0000000000000..3d20aef03ff15 --- /dev/null +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/top_categories_table.tsx @@ -0,0 +1,106 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { EuiBasicTable, EuiBasicTableColumn } from '@elastic/eui'; +import numeral from '@elastic/numeral'; +import { i18n } from '@kbn/i18n'; +import React, { useMemo } from 'react'; + +import euiStyled from '../../../../../../../../common/eui_styled_components'; +import { + LogEntryCategory, + LogEntryCategoryHistogram, +} from '../../../../../../common/http_api/log_analysis'; +import { TimeRange } from '../../../../../../common/http_api/shared'; +import { AnomalySeverityIndicator } from './anomaly_severity_indicator'; +import { RegularExpressionRepresentation } from './category_expression'; +import { DatasetsList } from './datasets_list'; +import { LogEntryCountSparkline } from './log_entry_count_sparkline'; + +export const TopCategoriesTable = euiStyled( + ({ + className, + timeRange, + topCategories, + }: { + className?: string; + timeRange: TimeRange; + topCategories: LogEntryCategory[]; + }) => { + const columns = useMemo(() => createColumns(timeRange), [timeRange]); + + return ( + + ); + } +)` + &.euiTableRow--topAligned .euiTableRowCell { + vertical-align: top; + } +`; + +const createColumns = (timeRange: TimeRange): Array> => [ + { + align: 'right', + field: 'logEntryCount', + name: i18n.translate('xpack.infra.logs.logEntryCategories.countColumnTitle', { + defaultMessage: 'Message count', + }), + render: (logEntryCount: number) => { + return numeral(logEntryCount).format('0,0'); + }, + width: '120px', + }, + { + field: 'histograms', + name: i18n.translate('xpack.infra.logs.logEntryCategories.trendColumnTitle', { + defaultMessage: 'Trend', + }), + render: (histograms: LogEntryCategoryHistogram[], item) => { + return ( + + ); + }, + width: '220px', + }, + { + field: 'regularExpression', + name: i18n.translate('xpack.infra.logs.logEntryCategories.categoryColumnTitle', { + defaultMessage: 'Category', + }), + truncateText: true, + render: (regularExpression: string) => ( + + ), + }, + { + field: 'datasets', + name: i18n.translate('xpack.infra.logs.logEntryCategories.datasetColumnTitle', { + defaultMessage: 'Datasets', + }), + render: (datasets: string[]) => , + width: '200px', + }, + { + align: 'right', + field: 'maximumAnomalyScore', + name: i18n.translate('xpack.infra.logs.logEntryCategories.maximumAnomalyScoreColumnTitle', { + defaultMessage: 'Maximum anomaly score', + }), + render: (maximumAnomalyScore: number) => ( + + ), + width: '160px', + }, +]; diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/service_calls/get_log_entry_category_datasets.ts b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/service_calls/get_log_entry_category_datasets.ts new file mode 100644 index 0000000000000..942ded4230e97 --- /dev/null +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/service_calls/get_log_entry_category_datasets.ts @@ -0,0 +1,46 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { fold } from 'fp-ts/lib/Either'; +import { pipe } from 'fp-ts/lib/pipeable'; +import { identity } from 'fp-ts/lib/function'; +import { npStart } from 'ui/new_platform'; + +import { + getLogEntryCategoryDatasetsRequestPayloadRT, + getLogEntryCategoryDatasetsSuccessReponsePayloadRT, + LOG_ANALYSIS_GET_LOG_ENTRY_CATEGORY_DATASETS_PATH, +} from '../../../../../common/http_api/log_analysis'; +import { createPlainError, throwErrors } from '../../../../../common/runtime_types'; + +export const callGetLogEntryCategoryDatasetsAPI = async ( + sourceId: string, + startTime: number, + endTime: number +) => { + const response = await npStart.core.http.fetch( + LOG_ANALYSIS_GET_LOG_ENTRY_CATEGORY_DATASETS_PATH, + { + method: 'POST', + body: JSON.stringify( + getLogEntryCategoryDatasetsRequestPayloadRT.encode({ + data: { + sourceId, + timeRange: { + startTime, + endTime, + }, + }, + }) + ), + } + ); + + return pipe( + getLogEntryCategoryDatasetsSuccessReponsePayloadRT.decode(response), + fold(throwErrors(createPlainError), identity) + ); +}; diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/service_calls/get_top_log_entry_categories.ts b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/service_calls/get_top_log_entry_categories.ts new file mode 100644 index 0000000000000..35d6f1ec4f893 --- /dev/null +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/service_calls/get_top_log_entry_categories.ts @@ -0,0 +1,67 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { fold } from 'fp-ts/lib/Either'; +import { pipe } from 'fp-ts/lib/pipeable'; +import { identity } from 'fp-ts/lib/function'; +import { npStart } from 'ui/new_platform'; + +import { + getLogEntryCategoriesRequestPayloadRT, + getLogEntryCategoriesSuccessReponsePayloadRT, + LOG_ANALYSIS_GET_LOG_ENTRY_CATEGORIES_PATH, +} from '../../../../../common/http_api/log_analysis'; +import { createPlainError, throwErrors } from '../../../../../common/runtime_types'; + +export const callGetTopLogEntryCategoriesAPI = async ( + sourceId: string, + startTime: number, + endTime: number, + categoryCount: number, + datasets?: string[] +) => { + const intervalDuration = endTime - startTime; + + const response = await npStart.core.http.fetch(LOG_ANALYSIS_GET_LOG_ENTRY_CATEGORIES_PATH, { + method: 'POST', + body: JSON.stringify( + getLogEntryCategoriesRequestPayloadRT.encode({ + data: { + sourceId, + timeRange: { + startTime, + endTime, + }, + categoryCount, + datasets, + histograms: [ + { + id: 'history', + timeRange: { + startTime: startTime - intervalDuration, + endTime, + }, + bucketCount: 10, + }, + { + id: 'reference', + timeRange: { + startTime: startTime - intervalDuration, + endTime: startTime, + }, + bucketCount: 1, + }, + ], + }, + }) + ), + }); + + return pipe( + getLogEntryCategoriesSuccessReponsePayloadRT.decode(response), + fold(throwErrors(createPlainError), identity) + ); +}; diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/use_log_entry_categories_results.ts b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/use_log_entry_categories_results.ts new file mode 100644 index 0000000000000..2282582dc2bd6 --- /dev/null +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/use_log_entry_categories_results.ts @@ -0,0 +1,116 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { useMemo, useState } from 'react'; + +import { + GetLogEntryCategoriesSuccessResponsePayload, + GetLogEntryCategoryDatasetsSuccessResponsePayload, +} from '../../../../common/http_api/log_analysis'; +import { useTrackedPromise, CanceledPromiseError } from '../../../utils/use_tracked_promise'; +import { callGetTopLogEntryCategoriesAPI } from './service_calls/get_top_log_entry_categories'; +import { callGetLogEntryCategoryDatasetsAPI } from './service_calls/get_log_entry_category_datasets'; + +type TopLogEntryCategories = GetLogEntryCategoriesSuccessResponsePayload['data']['categories']; +type LogEntryCategoryDatasets = GetLogEntryCategoryDatasetsSuccessResponsePayload['data']['datasets']; + +export const useLogEntryCategoriesResults = ({ + categoriesCount, + filteredDatasets: filteredDatasets, + endTime, + onGetLogEntryCategoryDatasetsError, + onGetTopLogEntryCategoriesError, + sourceId, + startTime, +}: { + categoriesCount: number; + filteredDatasets: string[]; + endTime: number; + onGetLogEntryCategoryDatasetsError?: (error: Error) => void; + onGetTopLogEntryCategoriesError?: (error: Error) => void; + sourceId: string; + startTime: number; +}) => { + const [topLogEntryCategories, setTopLogEntryCategories] = useState([]); + const [logEntryCategoryDatasets, setLogEntryCategoryDatasets] = useState< + LogEntryCategoryDatasets + >([]); + + const [getTopLogEntryCategoriesRequest, getTopLogEntryCategories] = useTrackedPromise( + { + cancelPreviousOn: 'creation', + createPromise: async () => { + return await callGetTopLogEntryCategoriesAPI( + sourceId, + startTime, + endTime, + categoriesCount, + filteredDatasets + ); + }, + onResolve: ({ data: { categories } }) => { + setTopLogEntryCategories(categories); + }, + onReject: error => { + if ( + error instanceof Error && + !(error instanceof CanceledPromiseError) && + onGetTopLogEntryCategoriesError + ) { + onGetTopLogEntryCategoriesError(error); + } + }, + }, + [categoriesCount, endTime, filteredDatasets, sourceId, startTime] + ); + + const [getLogEntryCategoryDatasetsRequest, getLogEntryCategoryDatasets] = useTrackedPromise( + { + cancelPreviousOn: 'creation', + createPromise: async () => { + return await callGetLogEntryCategoryDatasetsAPI(sourceId, startTime, endTime); + }, + onResolve: ({ data: { datasets } }) => { + setLogEntryCategoryDatasets(datasets); + }, + onReject: error => { + if ( + error instanceof Error && + !(error instanceof CanceledPromiseError) && + onGetLogEntryCategoryDatasetsError + ) { + onGetLogEntryCategoryDatasetsError(error); + } + }, + }, + [categoriesCount, endTime, sourceId, startTime] + ); + + const isLoadingTopLogEntryCategories = useMemo( + () => getTopLogEntryCategoriesRequest.state === 'pending', + [getTopLogEntryCategoriesRequest.state] + ); + + const isLoadingLogEntryCategoryDatasets = useMemo( + () => getLogEntryCategoryDatasetsRequest.state === 'pending', + [getLogEntryCategoryDatasetsRequest.state] + ); + + const isLoading = useMemo( + () => isLoadingTopLogEntryCategories || isLoadingLogEntryCategoryDatasets, + [isLoadingLogEntryCategoryDatasets, isLoadingTopLogEntryCategories] + ); + + return { + getLogEntryCategoryDatasets, + getTopLogEntryCategories, + isLoading, + isLoadingLogEntryCategoryDatasets, + isLoadingTopLogEntryCategories, + logEntryCategoryDatasets, + topLogEntryCategories, + }; +}; diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/use_log_entry_categories_results_url_state.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/use_log_entry_categories_results_url_state.tsx new file mode 100644 index 0000000000000..bf30f96e4b741 --- /dev/null +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/use_log_entry_categories_results_url_state.tsx @@ -0,0 +1,64 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { fold } from 'fp-ts/lib/Either'; +import { constant, identity } from 'fp-ts/lib/function'; +import { pipe } from 'fp-ts/lib/pipeable'; +import * as rt from 'io-ts'; + +import { useUrlState } from '../../../utils/use_url_state'; + +const autoRefreshRT = rt.union([ + rt.type({ + interval: rt.number, + isPaused: rt.boolean, + }), + rt.undefined, +]); + +export const stringTimeRangeRT = rt.type({ + startTime: rt.string, + endTime: rt.string, +}); +export type StringTimeRange = rt.TypeOf; + +const urlTimeRangeRT = rt.union([stringTimeRangeRT, rt.undefined]); + +const TIME_RANGE_URL_STATE_KEY = 'timeRange'; +const AUTOREFRESH_URL_STATE_KEY = 'autoRefresh'; + +export const useLogEntryCategoriesResultsUrlState = () => { + const [timeRange, setTimeRange] = useUrlState({ + defaultState: { + startTime: 'now-2w', + endTime: 'now', + }, + decodeUrlState: (value: unknown) => + pipe(urlTimeRangeRT.decode(value), fold(constant(undefined), identity)), + encodeUrlState: urlTimeRangeRT.encode, + urlStateKey: TIME_RANGE_URL_STATE_KEY, + writeDefaultState: true, + }); + + const [autoRefresh, setAutoRefresh] = useUrlState({ + defaultState: { + isPaused: false, + interval: 60000, + }, + decodeUrlState: (value: unknown) => + pipe(autoRefreshRT.decode(value), fold(constant(undefined), identity)), + encodeUrlState: autoRefreshRT.encode, + urlStateKey: AUTOREFRESH_URL_STATE_KEY, + writeDefaultState: true, + }); + + return { + timeRange, + setTimeRange, + autoRefresh, + setAutoRefresh, + }; +}; diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/first_use.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/first_use.tsx deleted file mode 100644 index 1ab9356a69e2a..0000000000000 --- a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/first_use.tsx +++ /dev/null @@ -1,30 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -import React from 'react'; -import { i18n } from '@kbn/i18n'; -import { EuiCallOut, EuiSpacer } from '@elastic/eui'; - -export const FirstUseCallout = () => { - return ( - <> - -

- {i18n.translate('xpack.infra.logs.logsAnalysisResults.onboardingSuccessContent', { - defaultMessage: - 'Please allow a few minutes for our machine learning robots to begin collecting data.', - })} -

-
- - - ); -}; diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/module_descriptor.ts b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/module_descriptor.ts index 52be313264335..52ba3101dbc38 100644 --- a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/module_descriptor.ts +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/module_descriptor.ts @@ -4,7 +4,13 @@ * you may not use this file except in compliance with the Elastic License. */ -import { bucketSpan, getJobId, partitionField } from '../../../../common/log_analysis'; +import { + bucketSpan, + getJobId, + LogEntryRateJobType, + logEntryRateJobTypes, + partitionField, +} from '../../../../common/log_analysis'; import { ModuleDescriptor, @@ -16,22 +22,19 @@ import { callGetMlModuleAPI } from '../../../containers/logs/log_analysis/api/ml import { callSetupMlModuleAPI } from '../../../containers/logs/log_analysis/api/ml_setup_module_api'; import { callValidateIndicesAPI } from '../../../containers/logs/log_analysis/api/validate_indices'; -const jobTypes = ['log-entry-rate']; const moduleId = 'logs_ui_analysis'; -type JobType = typeof jobTypes[0]; - const getJobIds = (spaceId: string, sourceId: string) => - jobTypes.reduce( + logEntryRateJobTypes.reduce( (accumulatedJobIds, jobType) => ({ ...accumulatedJobIds, [jobType]: getJobId(spaceId, sourceId, jobType), }), - {} as Record + {} as Record ); const getJobSummary = async (spaceId: string, sourceId: string) => { - const response = await callJobsSummaryAPI(spaceId, sourceId, jobTypes); + const response = await callJobsSummaryAPI(spaceId, sourceId, logEntryRateJobTypes); const jobIds = Object.values(getJobIds(spaceId, sourceId)); return response.filter(jobSummary => jobIds.includes(jobSummary.id)); @@ -78,7 +81,7 @@ const setUpModule = async ( }; const cleanUpModule = async (spaceId: string, sourceId: string) => { - return await cleanUpJobsAndDatafeeds(spaceId, sourceId, jobTypes); + return await cleanUpJobsAndDatafeeds(spaceId, sourceId, logEntryRateJobTypes); }; const validateSetupIndices = async ({ indices, timestampField }: ModuleSourceConfiguration) => { @@ -94,9 +97,9 @@ const validateSetupIndices = async ({ indices, timestampField }: ModuleSourceCon ]); }; -export const logEntryRateModule: ModuleDescriptor = { +export const logEntryRateModule: ModuleDescriptor = { moduleId, - jobTypes, + jobTypes: logEntryRateJobTypes, bucketSpan, getJobIds, getJobSummary, diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/page_results_content.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/page_results_content.tsx index b6ab8acdea5b2..693444c02ce5f 100644 --- a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/page_results_content.tsx +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/page_results_content.tsx @@ -11,6 +11,7 @@ import { EuiFlexItem, EuiPage, EuiPanel, + EuiSpacer, EuiSuperDatePicker, EuiText, } from '@elastic/eui'; @@ -26,7 +27,6 @@ import { LoadingOverlayWrapper } from '../../../components/loading_overlay_wrapp import { useInterval } from '../../../hooks/use_interval'; import { useTrackPageview } from '../../../hooks/use_track_metric'; import { useKibanaUiSetting } from '../../../utils/use_kibana_ui_setting'; -import { FirstUseCallout } from './first_use'; import { AnomaliesResults } from './sections/anomalies'; import { LogRateResults } from './sections/log_rate'; import { useLogEntryRateModuleContext } from './use_log_entry_rate_module'; @@ -35,6 +35,7 @@ import { StringTimeRange, useLogAnalysisResultsUrlState, } from './use_log_entry_rate_results_url_state'; +import { FirstUseCallout } from '../../../components/logging/log_analysis_results'; const JOB_STATUS_POLLING_INTERVAL = 30000; @@ -196,7 +197,12 @@ export const LogEntryRateResultsContent: React.FunctionComponent = () => { - {isFirstUse && !hasResults ? : null} + {isFirstUse && !hasResults ? ( + <> + + + + ) : null} { // This is needed due to the flex-basis: 100% !important; rule that // kicks in on small screens via media queries breaking when using direction="column" export const ResultsContentPage = euiStyled(EuiPage)` + flex: 1 0 0%; + .euiFlexGroup--responsive > .euiFlexItem { flex-basis: auto !important; } diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/sections/anomalies/chart.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/sections/anomalies/chart.tsx index a75e6c50ab03f..1a3a7d9e2b572 100644 --- a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/sections/anomalies/chart.tsx +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/sections/anomalies/chart.tsx @@ -22,8 +22,11 @@ import moment from 'moment'; import React, { useCallback, useMemo } from 'react'; import { TimeRange } from '../../../../../../common/http_api/shared/time_range'; +import { + MLSeverityScoreCategories, + ML_SEVERITY_COLORS, +} from '../../../../../../common/log_analysis'; import { useKibanaUiSetting } from '../../../../../utils/use_kibana_ui_setting'; -import { MLSeverityScoreCategories } from '../helpers/data_formatters'; export const AnomaliesChart: React.FunctionComponent<{ chartId: string; @@ -109,19 +112,19 @@ interface SeverityConfig { const severityConfigs: Record = { warning: { id: `anomalies-warning`, - style: { fill: 'rgb(125, 180, 226)', opacity: 0.7 }, + style: { fill: ML_SEVERITY_COLORS.warning, opacity: 0.7 }, }, minor: { id: `anomalies-minor`, - style: { fill: 'rgb(255, 221, 0)', opacity: 0.7 }, + style: { fill: ML_SEVERITY_COLORS.minor, opacity: 0.7 }, }, major: { id: `anomalies-major`, - style: { fill: 'rgb(229, 113, 0)', opacity: 0.7 }, + style: { fill: ML_SEVERITY_COLORS.major, opacity: 0.7 }, }, critical: { id: `anomalies-critical`, - style: { fill: 'rgb(228, 72, 72)', opacity: 0.7 }, + style: { fill: ML_SEVERITY_COLORS.critical, opacity: 0.7 }, }, }; diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/sections/anomalies/index.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/sections/anomalies/index.tsx index e5e719c2d69f6..4aff907cfad66 100644 --- a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/sections/anomalies/index.tsx +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/sections/anomalies/index.tsx @@ -12,7 +12,6 @@ import { EuiStat, EuiTitle, EuiLoadingSpinner, - EuiButton, } from '@elastic/eui'; import numeral from '@elastic/numeral'; import { i18n } from '@kbn/i18n'; @@ -21,16 +20,18 @@ import React, { useMemo } from 'react'; import euiStyled from '../../../../../../../../common/eui_styled_components'; import { LogEntryRateResults } from '../../use_log_entry_rate_results'; import { TimeRange } from '../../../../../../common/http_api/shared/time_range'; -import { JobStatus, SetupStatus } from '../../../../../../common/log_analysis'; +import { formatAnomalyScore, JobStatus, SetupStatus } from '../../../../../../common/log_analysis'; import { - formatAnomalyScore, getAnnotationsForAll, getLogEntryRateCombinedSeries, getTopAnomalyScoreAcrossAllPartitions, } from '../helpers/data_formatters'; import { AnomaliesChart } from './chart'; import { AnomaliesTable } from './table'; -import { LogAnalysisJobProblemIndicator } from '../../../../../components/logging/log_analysis_job_status'; +import { + LogAnalysisJobProblemIndicator, + RecreateJobButton, +} from '../../../../../components/logging/log_analysis_job_status'; import { AnalyzeInMlButton } from '../../../../../components/logging/log_analysis_results'; import { LoadingOverlayWrapper } from '../../../../../components/loading_overlay_wrapper'; @@ -99,9 +100,7 @@ export const AnomaliesResults: React.FunctionComponent<{ - - Recreate jobs - + diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/sections/anomalies/table.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/sections/anomalies/table.tsx index 45893315c7361..3e86b45fadfdd 100644 --- a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/sections/anomalies/table.tsx +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/sections/anomalies/table.tsx @@ -4,15 +4,19 @@ * you may not use this file except in compliance with the Elastic License. */ -import React, { useMemo, useState, useCallback } from 'react'; import { EuiBasicTable, EuiButtonIcon } from '@elastic/eui'; -import { i18n } from '@kbn/i18n'; import { RIGHT_ALIGNMENT } from '@elastic/eui/lib/services'; +import { i18n } from '@kbn/i18n'; +import React, { useCallback, useMemo, useState } from 'react'; + +import euiStyled from '../../../../../../../../common/eui_styled_components'; import { TimeRange } from '../../../../../../common/http_api/shared/time_range'; +import { + formatAnomalyScore, + getFriendlyNameForPartitionId, +} from '../../../../../../common/log_analysis'; import { LogEntryRateResults } from '../../use_log_entry_rate_results'; import { AnomaliesTableExpandedRow } from './expanded_row'; -import { formatAnomalyScore, getFriendlyNameForPartitionId } from '../helpers/data_formatters'; -import euiStyled from '../../../../../../../../common/eui_styled_components'; interface TableItem { id: string; diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/sections/helpers/data_formatters.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/sections/helpers/data_formatters.tsx index f9b85fc4e20c2..e8e4c18e7420c 100644 --- a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/sections/helpers/data_formatters.tsx +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/sections/helpers/data_formatters.tsx @@ -7,17 +7,14 @@ import { RectAnnotationDatum } from '@elastic/charts'; import { i18n } from '@kbn/i18n'; +import { + formatAnomalyScore, + getFriendlyNameForPartitionId, + getSeverityCategoryForScore, + MLSeverityScoreCategories, +} from '../../../../../../common/log_analysis'; import { LogEntryRateResults } from '../../use_log_entry_rate_results'; -const ML_SEVERITY_SCORES = { - warning: 3, - minor: 25, - major: 50, - critical: 75, -}; - -export type MLSeverityScoreCategories = keyof typeof ML_SEVERITY_SCORES; - export const getLogEntryRatePartitionedSeries = (results: LogEntryRateResults) => { return results.histogramBuckets.reduce>( (buckets, bucket) => { @@ -182,26 +179,3 @@ export const getTopAnomalyScoreAcrossAllPartitions = (results: LogEntryRateResul ); return Math.max(...allTopScores); }; - -const getSeverityCategoryForScore = (score: number): MLSeverityScoreCategories | undefined => { - if (score >= ML_SEVERITY_SCORES.critical) { - return 'critical'; - } else if (score >= ML_SEVERITY_SCORES.major) { - return 'major'; - } else if (score >= ML_SEVERITY_SCORES.minor) { - return 'minor'; - } else if (score >= ML_SEVERITY_SCORES.warning) { - return 'warning'; - } else { - // Category is too low to include - return undefined; - } -}; - -export const formatAnomalyScore = (score: number) => { - return Math.round(score); -}; - -export const getFriendlyNameForPartitionId = (partitionId: string) => { - return partitionId !== '' ? partitionId : 'unknown'; -}; diff --git a/x-pack/legacy/plugins/infra/public/utils/use_tracked_promise.ts b/x-pack/legacy/plugins/infra/public/utils/use_tracked_promise.ts index c23bab7026aaa..e9a966b97e4dd 100644 --- a/x-pack/legacy/plugins/infra/public/utils/use_tracked_promise.ts +++ b/x-pack/legacy/plugins/infra/public/utils/use_tracked_promise.ts @@ -248,7 +248,7 @@ interface CancelablePromise { promise: Promise; } -class CanceledPromiseError extends Error { +export class CanceledPromiseError extends Error { public isCanceled = true; constructor(message?: string) { @@ -257,6 +257,6 @@ class CanceledPromiseError extends Error { } } -class SilentCanceledPromiseError extends CanceledPromiseError {} +export class SilentCanceledPromiseError extends CanceledPromiseError {} const noOp = () => undefined; diff --git a/x-pack/legacy/plugins/infra/server/infra_server.ts b/x-pack/legacy/plugins/infra/server/infra_server.ts index f99589e1b52bd..4f290cb05f056 100644 --- a/x-pack/legacy/plugins/infra/server/infra_server.ts +++ b/x-pack/legacy/plugins/infra/server/infra_server.ts @@ -12,6 +12,8 @@ import { createSourceStatusResolvers } from './graphql/source_status'; import { createSourcesResolvers } from './graphql/sources'; import { InfraBackendLibs } from './lib/infra_types'; import { + initGetLogEntryCategoriesRoute, + initGetLogEntryCategoryDatasetsRoute, initGetLogEntryRateRoute, initValidateLogAnalysisIndicesRoute, } from './routes/log_analysis'; @@ -41,6 +43,8 @@ export const initInfraServer = (libs: InfraBackendLibs) => { libs.framework.registerGraphQLEndpoint('/graphql', schema); initIpToHostName(libs); + initGetLogEntryCategoriesRoute(libs); + initGetLogEntryCategoryDatasetsRoute(libs); initGetLogEntryRateRoute(libs); initSnapshotRoute(libs); initNodeDetailsRoute(libs); diff --git a/x-pack/legacy/plugins/infra/server/lib/compose/kibana.ts b/x-pack/legacy/plugins/infra/server/lib/compose/kibana.ts index 305841aa52d36..d8a39a6b9c16f 100644 --- a/x-pack/legacy/plugins/infra/server/lib/compose/kibana.ts +++ b/x-pack/legacy/plugins/infra/server/lib/compose/kibana.ts @@ -12,7 +12,7 @@ import { InfraFieldsDomain } from '../domains/fields_domain'; import { InfraLogEntriesDomain } from '../domains/log_entries_domain'; import { InfraMetricsDomain } from '../domains/metrics_domain'; import { InfraBackendLibs, InfraDomainLibs } from '../infra_types'; -import { InfraLogAnalysis } from '../log_analysis'; +import { LogEntryCategoriesAnalysis, LogEntryRateAnalysis } from '../log_analysis'; import { InfraSnapshot } from '../snapshot'; import { InfraSourceStatus } from '../source_status'; import { InfraSources } from '../sources'; @@ -29,7 +29,8 @@ export function compose(core: CoreSetup, config: InfraConfig, plugins: InfraServ sources, }); const snapshot = new InfraSnapshot({ sources, framework }); - const logAnalysis = new InfraLogAnalysis({ framework }); + const logEntryCategoriesAnalysis = new LogEntryCategoriesAnalysis({ framework }); + const logEntryRateAnalysis = new LogEntryRateAnalysis({ framework }); // TODO: separate these out individually and do away with "domains" as a temporary group const domainLibs: InfraDomainLibs = { @@ -45,7 +46,8 @@ export function compose(core: CoreSetup, config: InfraConfig, plugins: InfraServ const libs: InfraBackendLibs = { configuration: config, // NP_TODO: Do we ever use this anywhere? framework, - logAnalysis, + logEntryCategoriesAnalysis, + logEntryRateAnalysis, snapshot, sources, sourceStatus, diff --git a/x-pack/legacy/plugins/infra/server/lib/infra_types.ts b/x-pack/legacy/plugins/infra/server/lib/infra_types.ts index 46d32885600df..d52416b39596b 100644 --- a/x-pack/legacy/plugins/infra/server/lib/infra_types.ts +++ b/x-pack/legacy/plugins/infra/server/lib/infra_types.ts @@ -8,7 +8,7 @@ import { InfraSourceConfiguration } from '../../public/graphql/types'; import { InfraFieldsDomain } from './domains/fields_domain'; import { InfraLogEntriesDomain } from './domains/log_entries_domain'; import { InfraMetricsDomain } from './domains/metrics_domain'; -import { InfraLogAnalysis } from './log_analysis/log_analysis'; +import { LogEntryCategoriesAnalysis, LogEntryRateAnalysis } from './log_analysis'; import { InfraSnapshot } from './snapshot'; import { InfraSources } from './sources'; import { InfraSourceStatus } from './source_status'; @@ -31,7 +31,8 @@ export interface InfraDomainLibs { export interface InfraBackendLibs extends InfraDomainLibs { configuration: InfraConfig; framework: KibanaFramework; - logAnalysis: InfraLogAnalysis; + logEntryCategoriesAnalysis: LogEntryCategoriesAnalysis; + logEntryRateAnalysis: LogEntryRateAnalysis; snapshot: InfraSnapshot; sources: InfraSources; sourceStatus: InfraSourceStatus; diff --git a/x-pack/legacy/plugins/infra/server/lib/log_analysis/errors.ts b/x-pack/legacy/plugins/infra/server/lib/log_analysis/errors.ts index dc5c87c61fdce..d1c8316ad061b 100644 --- a/x-pack/legacy/plugins/infra/server/lib/log_analysis/errors.ts +++ b/x-pack/legacy/plugins/infra/server/lib/log_analysis/errors.ts @@ -4,7 +4,7 @@ * you may not use this file except in compliance with the Elastic License. */ -export class NoLogRateResultsIndexError extends Error { +export class NoLogAnalysisResultsIndexError extends Error { constructor(message?: string) { super(message); Object.setPrototypeOf(this, new.target.prototype); diff --git a/x-pack/legacy/plugins/infra/server/lib/log_analysis/index.ts b/x-pack/legacy/plugins/infra/server/lib/log_analysis/index.ts index 0b58c71c1db7b..44c2bafce4194 100644 --- a/x-pack/legacy/plugins/infra/server/lib/log_analysis/index.ts +++ b/x-pack/legacy/plugins/infra/server/lib/log_analysis/index.ts @@ -5,4 +5,5 @@ */ export * from './errors'; -export * from './log_analysis'; +export * from './log_entry_categories_analysis'; +export * from './log_entry_rate_analysis'; diff --git a/x-pack/legacy/plugins/infra/server/lib/log_analysis/log_entry_categories_analysis.ts b/x-pack/legacy/plugins/infra/server/lib/log_analysis/log_entry_categories_analysis.ts new file mode 100644 index 0000000000000..f2b6c468df69f --- /dev/null +++ b/x-pack/legacy/plugins/infra/server/lib/log_analysis/log_entry_categories_analysis.ts @@ -0,0 +1,363 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { KibanaRequest, RequestHandlerContext } from '../../../../../../../src/core/server'; +import { getJobId, logEntryCategoriesJobTypes } from '../../../common/log_analysis'; +import { startTracingSpan, TracingSpan } from '../../../common/performance_tracing'; +import { decodeOrThrow } from '../../../common/runtime_types'; +import { KibanaFramework } from '../adapters/framework/kibana_framework_adapter'; +import { NoLogAnalysisResultsIndexError } from './errors'; +import { + createLogEntryCategoriesQuery, + logEntryCategoriesResponseRT, + LogEntryCategoryHit, +} from './queries/log_entry_categories'; +import { + createLogEntryCategoryHistogramsQuery, + logEntryCategoryHistogramsResponseRT, +} from './queries/log_entry_category_histograms'; +import { + CompositeDatasetKey, + createLogEntryDatasetsQuery, + LogEntryDatasetBucket, + logEntryDatasetsResponseRT, +} from './queries/log_entry_data_sets'; +import { + createTopLogEntryCategoriesQuery, + topLogEntryCategoriesResponseRT, +} from './queries/top_log_entry_categories'; + +const COMPOSITE_AGGREGATION_BATCH_SIZE = 1000; + +export class LogEntryCategoriesAnalysis { + constructor( + private readonly libs: { + framework: KibanaFramework; + } + ) {} + + public async getTopLogEntryCategories( + requestContext: RequestHandlerContext, + request: KibanaRequest, + sourceId: string, + startTime: number, + endTime: number, + categoryCount: number, + datasets: string[], + histograms: HistogramParameters[] + ) { + const finalizeTopLogEntryCategoriesSpan = startTracingSpan('get top categories'); + + const logEntryCategoriesCountJobId = getJobId( + this.libs.framework.getSpaceId(request), + sourceId, + logEntryCategoriesJobTypes[0] + ); + + const { + topLogEntryCategories, + timing: { spans: fetchTopLogEntryCategoriesAggSpans }, + } = await this.fetchTopLogEntryCategories( + requestContext, + logEntryCategoriesCountJobId, + startTime, + endTime, + categoryCount, + datasets + ); + + const categoryIds = topLogEntryCategories.map(({ categoryId }) => categoryId); + + const { + logEntryCategoriesById, + timing: { spans: fetchTopLogEntryCategoryPatternsSpans }, + } = await this.fetchLogEntryCategories( + requestContext, + logEntryCategoriesCountJobId, + categoryIds + ); + + const { + categoryHistogramsById, + timing: { spans: fetchTopLogEntryCategoryHistogramsSpans }, + } = await this.fetchTopLogEntryCategoryHistograms( + requestContext, + logEntryCategoriesCountJobId, + categoryIds, + histograms + ); + + const topLogEntryCategoriesSpan = finalizeTopLogEntryCategoriesSpan(); + + return { + data: topLogEntryCategories.map(topCategory => ({ + ...topCategory, + regularExpression: logEntryCategoriesById[topCategory.categoryId]?._source.regex ?? '', + histograms: categoryHistogramsById[topCategory.categoryId] ?? [], + })), + timing: { + spans: [ + topLogEntryCategoriesSpan, + ...fetchTopLogEntryCategoriesAggSpans, + ...fetchTopLogEntryCategoryPatternsSpans, + ...fetchTopLogEntryCategoryHistogramsSpans, + ], + }, + }; + } + + public async getLogEntryCategoryDatasets( + requestContext: RequestHandlerContext, + request: KibanaRequest, + sourceId: string, + startTime: number, + endTime: number + ) { + const finalizeLogEntryDatasetsSpan = startTracingSpan('get data sets'); + + const logEntryCategoriesCountJobId = getJobId( + this.libs.framework.getSpaceId(request), + sourceId, + logEntryCategoriesJobTypes[0] + ); + + let logEntryDatasetBuckets: LogEntryDatasetBucket[] = []; + let afterLatestBatchKey: CompositeDatasetKey | undefined; + let esSearchSpans: TracingSpan[] = []; + + while (true) { + const finalizeEsSearchSpan = startTracingSpan('fetch category dataset batch from ES'); + + const logEntryDatasetsResponse = decodeOrThrow(logEntryDatasetsResponseRT)( + await this.libs.framework.callWithRequest( + requestContext, + 'search', + createLogEntryDatasetsQuery( + logEntryCategoriesCountJobId, + startTime, + endTime, + COMPOSITE_AGGREGATION_BATCH_SIZE, + afterLatestBatchKey + ) + ) + ); + + if (logEntryDatasetsResponse._shards.total === 0) { + throw new NoLogAnalysisResultsIndexError( + `Failed to find ml result index for job ${logEntryCategoriesCountJobId}.` + ); + } + + const { + after_key: afterKey, + buckets: latestBatchBuckets, + } = logEntryDatasetsResponse.aggregations.dataset_buckets; + + logEntryDatasetBuckets = [...logEntryDatasetBuckets, ...latestBatchBuckets]; + afterLatestBatchKey = afterKey; + esSearchSpans = [...esSearchSpans, finalizeEsSearchSpan()]; + + if (latestBatchBuckets.length < COMPOSITE_AGGREGATION_BATCH_SIZE) { + break; + } + } + + const logEntryDatasetsSpan = finalizeLogEntryDatasetsSpan(); + + return { + data: logEntryDatasetBuckets.map(logEntryDatasetBucket => logEntryDatasetBucket.key.dataset), + timing: { + spans: [logEntryDatasetsSpan, ...esSearchSpans], + }, + }; + } + + private async fetchTopLogEntryCategories( + requestContext: RequestHandlerContext, + logEntryCategoriesCountJobId: string, + startTime: number, + endTime: number, + categoryCount: number, + datasets: string[] + ) { + const finalizeEsSearchSpan = startTracingSpan('Fetch top categories from ES'); + + const topLogEntryCategoriesResponse = decodeOrThrow(topLogEntryCategoriesResponseRT)( + await this.libs.framework.callWithRequest( + requestContext, + 'search', + createTopLogEntryCategoriesQuery( + logEntryCategoriesCountJobId, + startTime, + endTime, + categoryCount, + datasets + ) + ) + ); + + const esSearchSpan = finalizeEsSearchSpan(); + + if (topLogEntryCategoriesResponse._shards.total === 0) { + throw new NoLogAnalysisResultsIndexError( + `Failed to find ml result index for job ${logEntryCategoriesCountJobId}.` + ); + } + + const topLogEntryCategories = topLogEntryCategoriesResponse.aggregations.terms_category_id.buckets.map( + topCategoryBucket => ({ + categoryId: parseCategoryId(topCategoryBucket.key), + logEntryCount: topCategoryBucket.filter_model_plot.sum_actual.value ?? 0, + datasets: topCategoryBucket.filter_model_plot.terms_dataset.buckets.map( + datasetBucket => datasetBucket.key + ), + maximumAnomalyScore: topCategoryBucket.filter_record.maximum_record_score.value ?? 0, + }) + ); + + return { + topLogEntryCategories, + timing: { + spans: [esSearchSpan], + }, + }; + } + + private async fetchLogEntryCategories( + requestContext: RequestHandlerContext, + logEntryCategoriesCountJobId: string, + categoryIds: number[] + ) { + if (categoryIds.length === 0) { + return { + logEntryCategoriesById: {}, + timing: { spans: [] }, + }; + } + + const finalizeEsSearchSpan = startTracingSpan('Fetch category patterns from ES'); + + const logEntryCategoriesResponse = decodeOrThrow(logEntryCategoriesResponseRT)( + await this.libs.framework.callWithRequest( + requestContext, + 'search', + createLogEntryCategoriesQuery(logEntryCategoriesCountJobId, categoryIds) + ) + ); + + const esSearchSpan = finalizeEsSearchSpan(); + + const logEntryCategoriesById = logEntryCategoriesResponse.hits.hits.reduce< + Record + >( + (accumulatedCategoriesById, categoryHit) => ({ + ...accumulatedCategoriesById, + [categoryHit._source.category_id]: categoryHit, + }), + {} + ); + + return { + logEntryCategoriesById, + timing: { + spans: [esSearchSpan], + }, + }; + } + + private async fetchTopLogEntryCategoryHistograms( + requestContext: RequestHandlerContext, + logEntryCategoriesCountJobId: string, + categoryIds: number[], + histograms: HistogramParameters[] + ) { + if (categoryIds.length === 0 || histograms.length === 0) { + return { + categoryHistogramsById: {}, + timing: { spans: [] }, + }; + } + + const finalizeEsSearchSpan = startTracingSpan('Fetch category histograms from ES'); + + const categoryHistogramsReponses = await Promise.all( + histograms.map(({ bucketCount, endTime, id: histogramId, startTime }) => + this.libs.framework + .callWithRequest( + requestContext, + 'search', + createLogEntryCategoryHistogramsQuery( + logEntryCategoriesCountJobId, + categoryIds, + startTime, + endTime, + bucketCount + ) + ) + .then(decodeOrThrow(logEntryCategoryHistogramsResponseRT)) + .then(response => ({ + histogramId, + histogramBuckets: response.aggregations.filters_categories.buckets, + })) + ) + ); + + const esSearchSpan = finalizeEsSearchSpan(); + + const categoryHistogramsById = Object.values(categoryHistogramsReponses).reduce< + Record< + number, + Array<{ + histogramId: string; + buckets: Array<{ + bucketDuration: number; + logEntryCount: number; + startTime: number; + }>; + }> + > + >( + (outerAccumulatedHistograms, { histogramId, histogramBuckets }) => + Object.entries(histogramBuckets).reduce( + (innerAccumulatedHistograms, [categoryBucketKey, categoryBucket]) => { + const categoryId = parseCategoryId(categoryBucketKey); + return { + ...innerAccumulatedHistograms, + [categoryId]: [ + ...(innerAccumulatedHistograms[categoryId] ?? []), + { + histogramId, + buckets: categoryBucket.histogram_timestamp.buckets.map(bucket => ({ + bucketDuration: categoryBucket.histogram_timestamp.meta.bucketDuration, + logEntryCount: bucket.sum_actual.value, + startTime: bucket.key, + })), + }, + ], + }; + }, + outerAccumulatedHistograms + ), + {} + ); + + return { + categoryHistogramsById, + timing: { + spans: [esSearchSpan], + }, + }; + } +} + +const parseCategoryId = (rawCategoryId: string) => parseInt(rawCategoryId, 10); + +interface HistogramParameters { + id: string; + startTime: number; + endTime: number; + bucketCount: number; +} diff --git a/x-pack/legacy/plugins/infra/server/lib/log_analysis/log_analysis.ts b/x-pack/legacy/plugins/infra/server/lib/log_analysis/log_entry_rate_analysis.ts similarity index 95% rename from x-pack/legacy/plugins/infra/server/lib/log_analysis/log_analysis.ts rename to x-pack/legacy/plugins/infra/server/lib/log_analysis/log_entry_rate_analysis.ts index fac49a7980f26..515856fa6be8a 100644 --- a/x-pack/legacy/plugins/infra/server/lib/log_analysis/log_analysis.ts +++ b/x-pack/legacy/plugins/infra/server/lib/log_analysis/log_entry_rate_analysis.ts @@ -10,7 +10,7 @@ import { identity } from 'fp-ts/lib/function'; import { getJobId } from '../../../common/log_analysis'; import { throwErrors, createPlainError } from '../../../common/runtime_types'; import { KibanaFramework } from '../adapters/framework/kibana_framework_adapter'; -import { NoLogRateResultsIndexError } from './errors'; +import { NoLogAnalysisResultsIndexError } from './errors'; import { logRateModelPlotResponseRT, createLogEntryRateQuery, @@ -21,7 +21,7 @@ import { RequestHandlerContext, KibanaRequest } from '../../../../../../../src/c const COMPOSITE_AGGREGATION_BATCH_SIZE = 1000; -export class InfraLogAnalysis { +export class LogEntryRateAnalysis { constructor( private readonly libs: { framework: KibanaFramework; @@ -36,11 +36,11 @@ export class InfraLogAnalysis { public async getLogEntryRateBuckets( requestContext: RequestHandlerContext, + request: KibanaRequest, sourceId: string, startTime: number, endTime: number, - bucketDuration: number, - request: KibanaRequest + bucketDuration: number ) { const logRateJobId = this.getJobIds(request, sourceId).logEntryRate; let mlModelPlotBuckets: LogRateModelPlotBucket[] = []; @@ -61,7 +61,7 @@ export class InfraLogAnalysis { ); if (mlModelPlotResponse._shards.total === 0) { - throw new NoLogRateResultsIndexError( + throw new NoLogAnalysisResultsIndexError( `Failed to find ml result index for job ${logRateJobId}.` ); } diff --git a/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/common.ts b/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/common.ts new file mode 100644 index 0000000000000..92ef4fb4e35c9 --- /dev/null +++ b/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/common.ts @@ -0,0 +1,37 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +const ML_ANOMALY_INDEX_PREFIX = '.ml-anomalies-'; + +export const getMlResultIndex = (jobId: string) => `${ML_ANOMALY_INDEX_PREFIX}${jobId}`; + +export const defaultRequestParameters = { + allowNoIndices: true, + ignoreUnavailable: true, + trackScores: false, + trackTotalHits: false, +}; + +export const createTimeRangeFilters = (startTime: number, endTime: number) => [ + { + range: { + timestamp: { + gte: startTime, + lte: endTime, + }, + }, + }, +]; + +export const createResultTypeFilters = (resultType: 'model_plot' | 'record') => [ + { + term: { + result_type: { + value: resultType, + }, + }, + }, +]; diff --git a/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/index.ts b/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/index.ts index 1749421277719..8c470acbf02fb 100644 --- a/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/index.ts +++ b/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/index.ts @@ -5,3 +5,4 @@ */ export * from './log_entry_rate'; +export * from './top_log_entry_categories'; diff --git a/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/log_entry_categories.ts b/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/log_entry_categories.ts new file mode 100644 index 0000000000000..63b3632f03784 --- /dev/null +++ b/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/log_entry_categories.ts @@ -0,0 +1,53 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import * as rt from 'io-ts'; + +import { commonSearchSuccessResponseFieldsRT } from '../../../utils/elasticsearch_runtime_types'; +import { defaultRequestParameters, getMlResultIndex } from './common'; + +export const createLogEntryCategoriesQuery = ( + logEntryCategoriesJobId: string, + categoryIds: number[] +) => ({ + ...defaultRequestParameters, + body: { + query: { + bool: { + filter: [ + { + terms: { + category_id: categoryIds, + }, + }, + ], + }, + }, + _source: ['category_id', 'regex'], + }, + index: getMlResultIndex(logEntryCategoriesJobId), + size: categoryIds.length, +}); + +export const logEntryCategoryHitRT = rt.type({ + _source: rt.type({ + category_id: rt.number, + regex: rt.string, + }), +}); + +export type LogEntryCategoryHit = rt.TypeOf; + +export const logEntryCategoriesResponseRT = rt.intersection([ + commonSearchSuccessResponseFieldsRT, + rt.type({ + hits: rt.type({ + hits: rt.array(logEntryCategoryHitRT), + }), + }), +]); + +export type logEntryCategoriesResponse = rt.TypeOf; diff --git a/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/log_entry_category_histograms.ts b/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/log_entry_category_histograms.ts new file mode 100644 index 0000000000000..67087f3b4775b --- /dev/null +++ b/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/log_entry_category_histograms.ts @@ -0,0 +1,125 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import * as rt from 'io-ts'; + +import { commonSearchSuccessResponseFieldsRT } from '../../../utils/elasticsearch_runtime_types'; +import { + createResultTypeFilters, + createTimeRangeFilters, + defaultRequestParameters, + getMlResultIndex, +} from './common'; + +export const createLogEntryCategoryHistogramsQuery = ( + logEntryCategoriesJobId: string, + categoryIds: number[], + startTime: number, + endTime: number, + bucketCount: number +) => ({ + ...defaultRequestParameters, + body: { + query: { + bool: { + filter: [ + ...createTimeRangeFilters(startTime, endTime), + ...createResultTypeFilters('model_plot'), + ...createCategoryFilters(categoryIds), + ], + }, + }, + aggs: { + filters_categories: { + filters: createCategoryFiltersAggregation(categoryIds), + aggs: { + histogram_timestamp: createHistogramAggregation(startTime, endTime, bucketCount), + }, + }, + }, + }, + index: getMlResultIndex(logEntryCategoriesJobId), + size: 0, +}); + +const createCategoryFilters = (categoryIds: number[]) => [ + { + terms: { + by_field_value: categoryIds, + }, + }, +]; + +const createCategoryFiltersAggregation = (categoryIds: number[]) => ({ + filters: categoryIds.reduce>( + (categoryFilters, categoryId) => ({ + ...categoryFilters, + [`${categoryId}`]: { + term: { + by_field_value: categoryId, + }, + }, + }), + {} + ), +}); + +const createHistogramAggregation = (startTime: number, endTime: number, bucketCount: number) => { + const bucketDuration = Math.round((endTime - startTime) / bucketCount); + + return { + histogram: { + field: 'timestamp', + interval: bucketDuration, + offset: startTime, + }, + meta: { + bucketDuration, + }, + aggs: { + sum_actual: { + sum: { + field: 'actual', + }, + }, + }, + }; +}; + +export const logEntryCategoryFilterBucketRT = rt.type({ + doc_count: rt.number, + histogram_timestamp: rt.type({ + meta: rt.type({ + bucketDuration: rt.number, + }), + buckets: rt.array( + rt.type({ + key: rt.number, + doc_count: rt.number, + sum_actual: rt.type({ + value: rt.number, + }), + }) + ), + }), +}); + +export type LogEntryCategoryFilterBucket = rt.TypeOf; + +export const logEntryCategoryHistogramsResponseRT = rt.intersection([ + commonSearchSuccessResponseFieldsRT, + rt.type({ + aggregations: rt.type({ + filters_categories: rt.type({ + buckets: rt.record(rt.string, logEntryCategoryFilterBucketRT), + }), + }), + }), +]); + +export type LogEntryCategorHistogramsResponse = rt.TypeOf< + typeof logEntryCategoryHistogramsResponseRT +>; diff --git a/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/log_entry_data_sets.ts b/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/log_entry_data_sets.ts new file mode 100644 index 0000000000000..b41a21a21b6a6 --- /dev/null +++ b/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/log_entry_data_sets.ts @@ -0,0 +1,93 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import * as rt from 'io-ts'; + +import { commonSearchSuccessResponseFieldsRT } from '../../../utils/elasticsearch_runtime_types'; +import { defaultRequestParameters, getMlResultIndex } from './common'; + +export const createLogEntryDatasetsQuery = ( + logEntryAnalysisJobId: string, + startTime: number, + endTime: number, + size: number, + afterKey?: CompositeDatasetKey +) => ({ + ...defaultRequestParameters, + body: { + query: { + bool: { + filter: [ + { + range: { + timestamp: { + gte: startTime, + lt: endTime, + }, + }, + }, + { + term: { + result_type: { + value: 'model_plot', + }, + }, + }, + ], + }, + }, + aggs: { + dataset_buckets: { + composite: { + after: afterKey, + size, + sources: [ + { + dataset: { + terms: { + field: 'partition_field_value', + order: 'asc', + }, + }, + }, + ], + }, + }, + }, + }, + index: getMlResultIndex(logEntryAnalysisJobId), + size: 0, +}); + +const compositeDatasetKeyRT = rt.type({ + dataset: rt.string, +}); + +export type CompositeDatasetKey = rt.TypeOf; + +const logEntryDatasetBucketRT = rt.type({ + key: compositeDatasetKeyRT, +}); + +export type LogEntryDatasetBucket = rt.TypeOf; + +export const logEntryDatasetsResponseRT = rt.intersection([ + commonSearchSuccessResponseFieldsRT, + rt.type({ + aggregations: rt.type({ + dataset_buckets: rt.intersection([ + rt.type({ + buckets: rt.array(logEntryDatasetBucketRT), + }), + rt.partial({ + after_key: compositeDatasetKeyRT, + }), + ]), + }), + }), +]); + +export type LogEntryDatasetsResponse = rt.TypeOf; diff --git a/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/log_entry_rate.ts b/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/log_entry_rate.ts index 2dd0880cbf8cb..def7caf578b94 100644 --- a/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/log_entry_rate.ts +++ b/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/log_entry_rate.ts @@ -6,7 +6,7 @@ import * as rt from 'io-ts'; -const ML_ANOMALY_INDEX_PREFIX = '.ml-anomalies-'; +import { defaultRequestParameters, getMlResultIndex } from './common'; export const createLogEntryRateQuery = ( logRateJobId: string, @@ -16,7 +16,7 @@ export const createLogEntryRateQuery = ( size: number, afterKey?: CompositeTimestampPartitionKey ) => ({ - allowNoIndices: true, + ...defaultRequestParameters, body: { query: { bool: { @@ -118,11 +118,8 @@ export const createLogEntryRateQuery = ( }, }, }, - ignoreUnavailable: true, - index: `${ML_ANOMALY_INDEX_PREFIX}${logRateJobId}`, + index: getMlResultIndex(logRateJobId), size: 0, - trackScores: false, - trackTotalHits: false, }); const logRateMlRecordRT = rt.type({ diff --git a/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/top_log_entry_categories.ts b/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/top_log_entry_categories.ts new file mode 100644 index 0000000000000..22b0ef748f5f8 --- /dev/null +++ b/x-pack/legacy/plugins/infra/server/lib/log_analysis/queries/top_log_entry_categories.ts @@ -0,0 +1,160 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import * as rt from 'io-ts'; + +import { commonSearchSuccessResponseFieldsRT } from '../../../utils/elasticsearch_runtime_types'; +import { + createResultTypeFilters, + createTimeRangeFilters, + defaultRequestParameters, + getMlResultIndex, +} from './common'; + +export const createTopLogEntryCategoriesQuery = ( + logEntryCategoriesJobId: string, + startTime: number, + endTime: number, + size: number, + datasets: string[], + sortDirection: 'asc' | 'desc' = 'desc' +) => ({ + ...defaultRequestParameters, + body: { + query: { + bool: { + filter: [ + ...createTimeRangeFilters(startTime, endTime), + ...createDatasetsFilters(datasets), + { + bool: { + should: [ + { + bool: { + filter: [ + ...createResultTypeFilters('model_plot'), + { + range: { + actual: { + gt: 0, + }, + }, + }, + ], + }, + }, + { + bool: { + filter: createResultTypeFilters('record'), + }, + }, + ], + minimum_should_match: 1, + }, + }, + ], + }, + }, + aggs: { + terms_category_id: { + terms: { + field: 'by_field_value', + size, + order: { + 'filter_model_plot>sum_actual': sortDirection, + }, + }, + aggs: { + filter_model_plot: { + filter: { + term: { + result_type: 'model_plot', + }, + }, + aggs: { + sum_actual: { + sum: { + field: 'actual', + }, + }, + terms_dataset: { + terms: { + field: 'partition_field_value', + size: 1000, + }, + }, + }, + }, + filter_record: { + filter: { + term: { + result_type: 'record', + }, + }, + aggs: { + maximum_record_score: { + max: { + field: 'record_score', + }, + }, + }, + }, + }, + }, + }, + }, + index: getMlResultIndex(logEntryCategoriesJobId), + size: 0, +}); + +const createDatasetsFilters = (datasets: string[]) => + datasets.length > 0 + ? [ + { + terms: { + partition_field_value: datasets, + }, + }, + ] + : []; + +const metricAggregationRT = rt.type({ + value: rt.union([rt.number, rt.null]), +}); + +export const logEntryCategoryBucketRT = rt.type({ + key: rt.string, + doc_count: rt.number, + filter_record: rt.type({ + maximum_record_score: metricAggregationRT, + }), + filter_model_plot: rt.type({ + sum_actual: metricAggregationRT, + terms_dataset: rt.type({ + buckets: rt.array( + rt.type({ + key: rt.string, + doc_count: rt.number, + }) + ), + }), + }), +}); + +export type LogEntryCategoryBucket = rt.TypeOf; + +export const topLogEntryCategoriesResponseRT = rt.intersection([ + commonSearchSuccessResponseFieldsRT, + rt.type({ + aggregations: rt.type({ + terms_category_id: rt.type({ + buckets: rt.array(logEntryCategoryBucketRT), + }), + }), + }), +]); + +export type TopLogEntryCategoriesResponse = rt.TypeOf; diff --git a/x-pack/legacy/plugins/infra/server/new_platform_plugin.ts b/x-pack/legacy/plugins/infra/server/new_platform_plugin.ts index 147729a1d0b3e..d3c6f7a5f70a1 100644 --- a/x-pack/legacy/plugins/infra/server/new_platform_plugin.ts +++ b/x-pack/legacy/plugins/infra/server/new_platform_plugin.ts @@ -17,7 +17,7 @@ import { InfraElasticsearchSourceStatusAdapter } from './lib/adapters/source_sta import { InfraFieldsDomain } from './lib/domains/fields_domain'; import { InfraLogEntriesDomain } from './lib/domains/log_entries_domain'; import { InfraMetricsDomain } from './lib/domains/metrics_domain'; -import { InfraLogAnalysis } from './lib/log_analysis'; +import { LogEntryCategoriesAnalysis, LogEntryRateAnalysis } from './lib/log_analysis'; import { InfraSnapshot } from './lib/snapshot'; import { InfraSourceStatus } from './lib/source_status'; import { InfraSources } from './lib/sources'; @@ -87,7 +87,8 @@ export class InfraServerPlugin { } ); const snapshot = new InfraSnapshot({ sources, framework }); - const logAnalysis = new InfraLogAnalysis({ framework }); + const logEntryCategoriesAnalysis = new LogEntryCategoriesAnalysis({ framework }); + const logEntryRateAnalysis = new LogEntryRateAnalysis({ framework }); // TODO: separate these out individually and do away with "domains" as a temporary group const domainLibs: InfraDomainLibs = { @@ -103,7 +104,8 @@ export class InfraServerPlugin { this.libs = { configuration: this.config, framework, - logAnalysis, + logEntryCategoriesAnalysis, + logEntryRateAnalysis, snapshot, sources, sourceStatus, diff --git a/x-pack/legacy/plugins/infra/server/routes/log_analysis/results/index.ts b/x-pack/legacy/plugins/infra/server/routes/log_analysis/results/index.ts index 1749421277719..d9ca9a96ffe51 100644 --- a/x-pack/legacy/plugins/infra/server/routes/log_analysis/results/index.ts +++ b/x-pack/legacy/plugins/infra/server/routes/log_analysis/results/index.ts @@ -4,4 +4,6 @@ * you may not use this file except in compliance with the Elastic License. */ +export * from './log_entry_categories'; +export * from './log_entry_category_datasets'; export * from './log_entry_rate'; diff --git a/x-pack/legacy/plugins/infra/server/routes/log_analysis/results/log_entry_categories.ts b/x-pack/legacy/plugins/infra/server/routes/log_analysis/results/log_entry_categories.ts new file mode 100644 index 0000000000000..7eb7de57b2f92 --- /dev/null +++ b/x-pack/legacy/plugins/infra/server/routes/log_analysis/results/log_entry_categories.ts @@ -0,0 +1,93 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import Boom from 'boom'; + +import { pipe } from 'fp-ts/lib/pipeable'; +import { fold } from 'fp-ts/lib/Either'; +import { identity } from 'fp-ts/lib/function'; +import { schema } from '@kbn/config-schema'; +import { InfraBackendLibs } from '../../../lib/infra_types'; +import { + LOG_ANALYSIS_GET_LOG_ENTRY_CATEGORIES_PATH, + getLogEntryCategoriesRequestPayloadRT, + getLogEntryCategoriesSuccessReponsePayloadRT, +} from '../../../../common/http_api/log_analysis'; +import { throwErrors } from '../../../../common/runtime_types'; +import { NoLogAnalysisResultsIndexError } from '../../../lib/log_analysis'; + +const anyObject = schema.object({}, { allowUnknowns: true }); + +export const initGetLogEntryCategoriesRoute = ({ + framework, + logEntryCategoriesAnalysis, +}: InfraBackendLibs) => { + framework.registerRoute( + { + method: 'post', + path: LOG_ANALYSIS_GET_LOG_ENTRY_CATEGORIES_PATH, + validate: { + // short-circuit forced @kbn/config-schema validation so we can do io-ts validation + body: anyObject, + }, + }, + async (requestContext, request, response) => { + const { + data: { + categoryCount, + histograms, + sourceId, + timeRange: { startTime, endTime }, + datasets, + }, + } = pipe( + getLogEntryCategoriesRequestPayloadRT.decode(request.body), + fold(throwErrors(Boom.badRequest), identity) + ); + + try { + const { + data: topLogEntryCategories, + timing, + } = await logEntryCategoriesAnalysis.getTopLogEntryCategories( + requestContext, + request, + sourceId, + startTime, + endTime, + categoryCount, + datasets ?? [], + histograms.map(histogram => ({ + bucketCount: histogram.bucketCount, + endTime: histogram.timeRange.endTime, + id: histogram.id, + startTime: histogram.timeRange.startTime, + })) + ); + + return response.ok({ + body: getLogEntryCategoriesSuccessReponsePayloadRT.encode({ + data: { + categories: topLogEntryCategories, + }, + timing, + }), + }); + } catch (e) { + const { statusCode = 500, message = 'Unknown error occurred' } = e; + + if (e instanceof NoLogAnalysisResultsIndexError) { + return response.notFound({ body: { message } }); + } + + return response.customError({ + statusCode, + body: { message }, + }); + } + } + ); +}; diff --git a/x-pack/legacy/plugins/infra/server/routes/log_analysis/results/log_entry_category_datasets.ts b/x-pack/legacy/plugins/infra/server/routes/log_analysis/results/log_entry_category_datasets.ts new file mode 100644 index 0000000000000..8132633028277 --- /dev/null +++ b/x-pack/legacy/plugins/infra/server/routes/log_analysis/results/log_entry_category_datasets.ts @@ -0,0 +1,82 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { schema } from '@kbn/config-schema'; +import Boom from 'boom'; +import { fold } from 'fp-ts/lib/Either'; +import { identity } from 'fp-ts/lib/function'; +import { pipe } from 'fp-ts/lib/pipeable'; + +import { + getLogEntryCategoryDatasetsRequestPayloadRT, + getLogEntryCategoryDatasetsSuccessReponsePayloadRT, + LOG_ANALYSIS_GET_LOG_ENTRY_CATEGORY_DATASETS_PATH, +} from '../../../../common/http_api/log_analysis'; +import { throwErrors } from '../../../../common/runtime_types'; +import { InfraBackendLibs } from '../../../lib/infra_types'; +import { NoLogAnalysisResultsIndexError } from '../../../lib/log_analysis'; + +const anyObject = schema.object({}, { allowUnknowns: true }); + +export const initGetLogEntryCategoryDatasetsRoute = ({ + framework, + logEntryCategoriesAnalysis, +}: InfraBackendLibs) => { + framework.registerRoute( + { + method: 'post', + path: LOG_ANALYSIS_GET_LOG_ENTRY_CATEGORY_DATASETS_PATH, + validate: { + // short-circuit forced @kbn/config-schema validation so we can do io-ts validation + body: anyObject, + }, + }, + async (requestContext, request, response) => { + const { + data: { + sourceId, + timeRange: { startTime, endTime }, + }, + } = pipe( + getLogEntryCategoryDatasetsRequestPayloadRT.decode(request.body), + fold(throwErrors(Boom.badRequest), identity) + ); + + try { + const { + data: logEntryCategoryDatasets, + timing, + } = await logEntryCategoriesAnalysis.getLogEntryCategoryDatasets( + requestContext, + request, + sourceId, + startTime, + endTime + ); + + return response.ok({ + body: getLogEntryCategoryDatasetsSuccessReponsePayloadRT.encode({ + data: { + datasets: logEntryCategoryDatasets, + }, + timing, + }), + }); + } catch (e) { + const { statusCode = 500, message = 'Unknown error occurred' } = e; + + if (e instanceof NoLogAnalysisResultsIndexError) { + return response.notFound({ body: { message } }); + } + + return response.customError({ + statusCode, + body: { message }, + }); + } + } + ); +}; diff --git a/x-pack/legacy/plugins/infra/server/routes/log_analysis/results/log_entry_rate.ts b/x-pack/legacy/plugins/infra/server/routes/log_analysis/results/log_entry_rate.ts index 9778311bd8e58..6551316fd0c64 100644 --- a/x-pack/legacy/plugins/infra/server/routes/log_analysis/results/log_entry_rate.ts +++ b/x-pack/legacy/plugins/infra/server/routes/log_analysis/results/log_entry_rate.ts @@ -18,11 +18,11 @@ import { GetLogEntryRateSuccessResponsePayload, } from '../../../../common/http_api/log_analysis'; import { throwErrors } from '../../../../common/runtime_types'; -import { NoLogRateResultsIndexError } from '../../../lib/log_analysis'; +import { NoLogAnalysisResultsIndexError } from '../../../lib/log_analysis'; const anyObject = schema.object({}, { allowUnknowns: true }); -export const initGetLogEntryRateRoute = ({ framework, logAnalysis }: InfraBackendLibs) => { +export const initGetLogEntryRateRoute = ({ framework, logEntryRateAnalysis }: InfraBackendLibs) => { framework.registerRoute( { method: 'post', @@ -39,13 +39,13 @@ export const initGetLogEntryRateRoute = ({ framework, logAnalysis }: InfraBacken fold(throwErrors(Boom.badRequest), identity) ); - const logEntryRateBuckets = await logAnalysis.getLogEntryRateBuckets( + const logEntryRateBuckets = await logEntryRateAnalysis.getLogEntryRateBuckets( requestContext, + request, payload.data.sourceId, payload.data.timeRange.startTime, payload.data.timeRange.endTime, - payload.data.bucketDuration, - request + payload.data.bucketDuration ); return response.ok({ @@ -59,7 +59,7 @@ export const initGetLogEntryRateRoute = ({ framework, logAnalysis }: InfraBacken }); } catch (e) { const { statusCode = 500, message = 'Unknown error occurred' } = e; - if (e instanceof NoLogRateResultsIndexError) { + if (e instanceof NoLogAnalysisResultsIndexError) { return response.notFound({ body: { message } }); } return response.customError({ diff --git a/x-pack/legacy/plugins/infra/server/utils/elasticsearch_runtime_types.ts b/x-pack/legacy/plugins/infra/server/utils/elasticsearch_runtime_types.ts new file mode 100644 index 0000000000000..a48c65d648b25 --- /dev/null +++ b/x-pack/legacy/plugins/infra/server/utils/elasticsearch_runtime_types.ts @@ -0,0 +1,18 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import * as rt from 'io-ts'; + +export const commonSearchSuccessResponseFieldsRT = rt.type({ + _shards: rt.type({ + total: rt.number, + successful: rt.number, + skipped: rt.number, + failed: rt.number, + }), + timed_out: rt.boolean, + took: rt.number, +}); diff --git a/x-pack/plugins/translations/translations/ja-JP.json b/x-pack/plugins/translations/translations/ja-JP.json index 3b0c188318309..7d1c68cfdd976 100644 --- a/x-pack/plugins/translations/translations/ja-JP.json +++ b/x-pack/plugins/translations/translations/ja-JP.json @@ -6075,8 +6075,6 @@ "xpack.infra.logs.highlights.goToPreviousHighlightButtonLabel": "前のハイライトにスキップ", "xpack.infra.logs.index.settingsTabTitle": "設定", "xpack.infra.logs.index.streamTabTitle": "ストリーム", - "xpack.infra.logs.logsAnalysisResults.onboardingSuccessContent": "機械学習ロボットがデータの収集を開始するまでしばらくお待ちください。", - "xpack.infra.logs.logsAnalysisResults.onboardingSuccessTitle": "成功!", "xpack.infra.logs.streamPage.documentTitle": "{previousTitle} | ストリーム", "xpack.infra.logsPage.toolbar.kqlSearchFieldAriaLabel": "ログエントリーを検索", "xpack.infra.metricDetailPage.awsMetricsLayout.cpuUtilSection.percentSeriesLabel": "パーセント", diff --git a/x-pack/plugins/translations/translations/zh-CN.json b/x-pack/plugins/translations/translations/zh-CN.json index 3cc476937d4e7..413b9c65616cc 100644 --- a/x-pack/plugins/translations/translations/zh-CN.json +++ b/x-pack/plugins/translations/translations/zh-CN.json @@ -6077,8 +6077,6 @@ "xpack.infra.logs.highlights.goToPreviousHighlightButtonLabel": "跳转到上一高亮条目", "xpack.infra.logs.index.settingsTabTitle": "设置", "xpack.infra.logs.index.streamTabTitle": "流式传输", - "xpack.infra.logs.logsAnalysisResults.onboardingSuccessContent": "请注意,我们的 Machine Learning 机器人若干分钟后才会开始收集数据。", - "xpack.infra.logs.logsAnalysisResults.onboardingSuccessTitle": "成功!", "xpack.infra.logs.streamPage.documentTitle": "{previousTitle} | 流式传输", "xpack.infra.logsPage.toolbar.kqlSearchFieldAriaLabel": "搜索日志条目", "xpack.infra.metricDetailPage.awsMetricsLayout.cpuUtilSection.percentSeriesLabel": "百分比", From 70cedb08f9c88817cc8442cb64611be742bcf16b Mon Sep 17 00:00:00 2001 From: Brian Seeders Date: Mon, 13 Jan 2020 14:29:08 -0500 Subject: [PATCH 048/139] Update alerting task_runner test snapshots (#54627) --- .../plugins/alerting/server/task_runner/task_runner.test.ts | 3 --- 1 file changed, 3 deletions(-) diff --git a/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.test.ts b/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.test.ts index 45ee13e2370d2..394c13e1bd24f 100644 --- a/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.test.ts +++ b/x-pack/legacy/plugins/alerting/server/task_runner/task_runner.test.ts @@ -428,7 +428,6 @@ describe('Task Runner', () => { "runAt": 1970-01-01T00:05:00.000Z, "state": Object { "previousStartedAt": 1970-01-01T00:00:00.000Z, - "startedAt": 1969-12-31T23:55:00.000Z, }, } `); @@ -462,7 +461,6 @@ describe('Task Runner', () => { "runAt": 1970-01-01T00:05:00.000Z, "state": Object { "previousStartedAt": 1970-01-01T00:00:00.000Z, - "startedAt": 1969-12-31T23:55:00.000Z, }, } `); @@ -495,7 +493,6 @@ describe('Task Runner', () => { "runAt": 1970-01-01T00:05:00.000Z, "state": Object { "previousStartedAt": 1970-01-01T00:00:00.000Z, - "startedAt": 1969-12-31T23:55:00.000Z, }, } `); From 6f3ff99968a2c4c43a3992a0a2fc495e7d960c78 Mon Sep 17 00:00:00 2001 From: Shahzad Date: Mon, 13 Jan 2020 20:30:11 +0100 Subject: [PATCH 049/139] [Uptime] Monitor SSL Certificate Color version for warning (#54040) * update monitor list columns * update columns * update snaps * enhance ui * update SSL Cert to badge warning * fix i18n errors * removed unnecessary margin * update snaps * update ssl * update snaps * added test for warning state * added test for warning state * update test name * update test name Co-authored-by: Elastic Machine --- .../monitor_ssl_certificate.test.tsx.snap | 21 ----- .../monitor_ssl_certificate.test.tsx | 38 ---------- .../monitor_ssl_certificate.test.tsx.snap | 30 ++++++++ .../__test__/monitor_ssl_certificate.test.tsx | 76 +++++++++++++++++++ .../monitor_ssl_certificate.tsx | 38 ++++++---- .../translations/translations/ja-JP.json | 2 - .../translations/translations/zh-CN.json | 2 - 7 files changed, 128 insertions(+), 79 deletions(-) delete mode 100644 x-pack/legacy/plugins/uptime/public/components/functional/__tests__/__snapshots__/monitor_ssl_certificate.test.tsx.snap delete mode 100644 x-pack/legacy/plugins/uptime/public/components/functional/__tests__/monitor_ssl_certificate.test.tsx create mode 100644 x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/__test__/__snapshots__/monitor_ssl_certificate.test.tsx.snap create mode 100644 x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/__test__/monitor_ssl_certificate.test.tsx diff --git a/x-pack/legacy/plugins/uptime/public/components/functional/__tests__/__snapshots__/monitor_ssl_certificate.test.tsx.snap b/x-pack/legacy/plugins/uptime/public/components/functional/__tests__/__snapshots__/monitor_ssl_certificate.test.tsx.snap deleted file mode 100644 index d731a168225b7..0000000000000 --- a/x-pack/legacy/plugins/uptime/public/components/functional/__tests__/__snapshots__/monitor_ssl_certificate.test.tsx.snap +++ /dev/null @@ -1,21 +0,0 @@ -// Jest Snapshot v1, https://goo.gl/fbAQLP - -exports[`MonitorStatusBar component renders 1`] = ` -Array [ -
, -
-
- SSL certificate expires in 2 months -
-
, -] -`; - -exports[`MonitorStatusBar component renders null if invalid date 1`] = `null`; diff --git a/x-pack/legacy/plugins/uptime/public/components/functional/__tests__/monitor_ssl_certificate.test.tsx b/x-pack/legacy/plugins/uptime/public/components/functional/__tests__/monitor_ssl_certificate.test.tsx deleted file mode 100644 index 03eb252aa8c09..0000000000000 --- a/x-pack/legacy/plugins/uptime/public/components/functional/__tests__/monitor_ssl_certificate.test.tsx +++ /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; - * you may not use this file except in compliance with the Elastic License. - */ - -import React from 'react'; -import moment from 'moment'; -import { renderWithIntl } from 'test_utils/enzyme_helpers'; -import { PingTls } from '../../../../common/graphql/types'; -import { MonitorSSLCertificate } from '../monitor_status_details/monitor_status_bar'; - -describe('MonitorStatusBar component', () => { - let monitorTls: PingTls; - - beforeEach(() => { - const dateInTwoMonths = moment() - .add(2, 'month') - .toString(); - - monitorTls = { - certificate_not_valid_after: dateInTwoMonths, - }; - }); - - it('renders', () => { - const component = renderWithIntl(); - expect(component).toMatchSnapshot(); - }); - - it('renders null if invalid date', () => { - monitorTls = { - certificate_not_valid_after: 'i am so invalid date', - }; - const component = renderWithIntl(); - expect(component).toMatchSnapshot(); - }); -}); diff --git a/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/__test__/__snapshots__/monitor_ssl_certificate.test.tsx.snap b/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/__test__/__snapshots__/monitor_ssl_certificate.test.tsx.snap new file mode 100644 index 0000000000000..0cb0a7ec248df --- /dev/null +++ b/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/__test__/__snapshots__/monitor_ssl_certificate.test.tsx.snap @@ -0,0 +1,30 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`MonitorStatusBar component renders 1`] = ` +Array [ +
, +
+ SSL certificate expires + + + + in 2 months + + + +
, +] +`; + +exports[`MonitorStatusBar component renders null if invalid date 1`] = `null`; diff --git a/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/__test__/monitor_ssl_certificate.test.tsx b/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/__test__/monitor_ssl_certificate.test.tsx new file mode 100644 index 0000000000000..2eae14301fd4d --- /dev/null +++ b/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/__test__/monitor_ssl_certificate.test.tsx @@ -0,0 +1,76 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React from 'react'; +import moment from 'moment'; +import { mountWithIntl } from 'test_utils/enzyme_helpers'; +import { EuiBadge } from '@elastic/eui'; +import { renderWithIntl } from 'test_utils/enzyme_helpers'; +import { PingTls } from '../../../../../common/graphql/types'; +import { MonitorSSLCertificate } from '../monitor_status_bar'; + +describe('MonitorStatusBar component', () => { + let monitorTls: PingTls; + + beforeEach(() => { + const dateInTwoMonths = moment() + .add(2, 'month') + .toString(); + + monitorTls = { + certificate_not_valid_after: dateInTwoMonths, + }; + }); + + it('renders', () => { + const component = renderWithIntl(); + expect(component).toMatchSnapshot(); + }); + + it('renders null if invalid date', () => { + monitorTls = { + certificate_not_valid_after: 'i am so invalid date', + }; + const component = renderWithIntl(); + expect(component).toMatchSnapshot(); + }); + + it('renders expiration date with a warning state if ssl expiry date is less than 30 days', () => { + const dateIn15Days = moment() + .add(15, 'day') + .toString(); + monitorTls = { + certificate_not_valid_after: dateIn15Days, + }; + const component = mountWithIntl(); + + const badgeComponent = component.find(EuiBadge); + expect(badgeComponent.props().color).toBe('warning'); + + const badgeComponentText = component.find('.euiBadge__text'); + expect(badgeComponentText.text()).toBe(moment(dateIn15Days).fromNow()); + + expect(badgeComponent.find('span.euiBadge--warning')).toBeTruthy(); + }); + + it('does not render the expiration date with a warning state if expiry date is greater than a month', () => { + const dateIn40Days = moment() + .add(40, 'day') + .toString(); + monitorTls = { + certificate_not_valid_after: dateIn40Days, + }; + const component = mountWithIntl(); + + const badgeComponent = component.find(EuiBadge); + expect(badgeComponent.props().color).toBe('default'); + + const badgeComponentText = component.find('.euiBadge__text'); + expect(badgeComponentText.text()).toBe(moment(dateIn40Days).fromNow()); + + expect(badgeComponent.find('span.euiBadge--warning')).toHaveLength(0); + }); +}); diff --git a/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/monitor_status_bar/monitor_ssl_certificate.tsx b/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/monitor_status_bar/monitor_ssl_certificate.tsx index 5e916c40e712d..c57348c4ab4cd 100644 --- a/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/monitor_status_bar/monitor_ssl_certificate.tsx +++ b/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/monitor_status_bar/monitor_ssl_certificate.tsx @@ -5,9 +5,8 @@ */ import React from 'react'; -import { get } from 'lodash'; import moment from 'moment'; -import { EuiSpacer, EuiText } from '@elastic/eui'; +import { EuiSpacer, EuiText, EuiBadge } from '@elastic/eui'; import { FormattedMessage } from '@kbn/i18n/react'; import { i18n } from '@kbn/i18n'; @@ -21,30 +20,37 @@ interface Props { } export const MonitorSSLCertificate = ({ tls }: Props) => { - const certificateValidity: string | undefined = get( - tls, - 'certificate_not_valid_after', - undefined - ); + const certValidityDate = new Date(tls?.certificate_not_valid_after ?? ''); - const validExpiryDate = certificateValidity && !isNaN(new Date(certificateValidity).valueOf()); + const isValidDate = !isNaN(certValidityDate.valueOf()); - return validExpiryDate && certificateValidity ? ( + const dateIn30Days = moment().add('30', 'days'); + + const isExpiringInMonth = isValidDate && dateIn30Days > moment(certValidityDate); + + return isValidDate ? ( <> + {moment(certValidityDate).fromNow()} + + ), }} /> diff --git a/x-pack/plugins/translations/translations/ja-JP.json b/x-pack/plugins/translations/translations/ja-JP.json index 7d1c68cfdd976..5661020ba6fa6 100644 --- a/x-pack/plugins/translations/translations/ja-JP.json +++ b/x-pack/plugins/translations/translations/ja-JP.json @@ -11823,8 +11823,6 @@ "xpack.uptime.kueryBar.searchPlaceholder": "モニター ID、名前、プロトコルタイプなどを検索…", "xpack.uptime.monitorList.noItemForSelectedFiltersMessage": "選択されたフィルター条件でモニターが見つかりませんでした", "xpack.uptime.monitorList.table.description": "列にステータス、名前、URL、IP、ダウンタイム履歴、統合が入力されたモニターステータス表です。この表は現在 {length} 項目を表示しています。", - "xpack.uptime.monitorStatusBar.sslCertificateExpiry.ariaLabel": "SSL 証明書の有効期限:", - "xpack.uptime.monitorStatusBar.sslCertificateExpiry.content": "SSL 証明書の有効期限: {certificateValidity}", "xpack.uptime.notFountPage.homeLinkText": "ホームへ戻る", "xpack.uptime.overviewPageLink.disabled.ariaLabel": "無効になったページ付けボタンです。モニターリストがこれ以上ナビゲーションできないことを示しています。", "xpack.uptime.overviewPageLink.next.ariaLabel": "次の結果ページ", diff --git a/x-pack/plugins/translations/translations/zh-CN.json b/x-pack/plugins/translations/translations/zh-CN.json index 413b9c65616cc..1bcfab4240aed 100644 --- a/x-pack/plugins/translations/translations/zh-CN.json +++ b/x-pack/plugins/translations/translations/zh-CN.json @@ -11912,8 +11912,6 @@ "xpack.uptime.kueryBar.searchPlaceholder": "搜索监测 ID、名称和协议类型......", "xpack.uptime.monitorList.noItemForSelectedFiltersMessage": "未找到匹配选定筛选条件的监测", "xpack.uptime.monitorList.table.description": "具有“状态”、“名称”、“URL”、“IP”、“中断历史记录”和“集成”列的“监测状态”表。该表当前显示 {length} 个项目。", - "xpack.uptime.monitorStatusBar.sslCertificateExpiry.ariaLabel": "SSL 证书过期", - "xpack.uptime.monitorStatusBar.sslCertificateExpiry.content": "SSL 证书于 {certificateValidity} 过期", "xpack.uptime.notFountPage.homeLinkText": "返回主页", "xpack.uptime.overviewPageLink.disabled.ariaLabel": "禁用的分页按钮表示在监测列表中无法进行进一步导航。", "xpack.uptime.overviewPageLink.next.ariaLabel": "下页结果", From e90ca93687057675b8fc836d77995b7e00635e22 Mon Sep 17 00:00:00 2001 From: Shahzad Date: Mon, 13 Jan 2020 20:31:28 +0100 Subject: [PATCH 050/139] [Uptime] Most recent checks info on details page (#54340) * update API * update query * hide layer control and added loc tags * update test * remove unused comment * update API * remove capitalization * style fix * update types * added location status number on details page * useref instead of createRef * update interface * update import * removed redundant file * fix header for empty data * refactor for most recent check * remove redundant code * remone unused translation * update status bar * update styling * update snaps * added API tests * fix types * fixing integration tests and a typo * remove unused translations * update tests * fixed PR feedback * update feedback * update messaging * update snap * added timestamp in front of tags * update snaps * improve readability * PR feedbacka and snaps * PR feedbacka and snaps * update txt * snaps * fix timestamp issue in tests Co-authored-by: Elastic Machine --- .../common/runtime_types/monitor/locations.ts | 1 + .../location_status_tags.test.tsx.snap | 577 ++++++++++++++++++ .../__tests__/location_status_tags.test.tsx | 101 +++ .../functional/location_map/index.tsx | 1 + .../location_map/location_status_tags.tsx | 108 +++- .../__test__/status_by_location.test.tsx | 7 + .../elasticsearch_monitors_adapter.ts | 3 +- 7 files changed, 768 insertions(+), 30 deletions(-) create mode 100644 x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/__snapshots__/location_status_tags.test.tsx.snap create mode 100644 x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/location_status_tags.test.tsx diff --git a/x-pack/legacy/plugins/uptime/common/runtime_types/monitor/locations.ts b/x-pack/legacy/plugins/uptime/common/runtime_types/monitor/locations.ts index a40453b3671b7..ea3cfe677ca99 100644 --- a/x-pack/legacy/plugins/uptime/common/runtime_types/monitor/locations.ts +++ b/x-pack/legacy/plugins/uptime/common/runtime_types/monitor/locations.ts @@ -10,6 +10,7 @@ import { CheckGeoType, SummaryType } from '../common'; export const MonitorLocationType = t.partial({ summary: SummaryType, geo: CheckGeoType, + timestamp: t.string, }); // Typescript type for type checking diff --git a/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/__snapshots__/location_status_tags.test.tsx.snap b/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/__snapshots__/location_status_tags.test.tsx.snap new file mode 100644 index 0000000000000..6228183e7c2b2 --- /dev/null +++ b/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/__snapshots__/location_status_tags.test.tsx.snap @@ -0,0 +1,577 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`StatusByLocation component renders when all locations are down 1`] = ` +.c3 { + display: inline-block; + margin-left: 4px; +} + +.c2 { + font-weight: 600; +} + +.c1 { + margin-bottom: 5px; +} + +.c0 { + padding: 10px; + max-height: 229px; + overflow: hidden; +} + +
+ +
+ + + +
+
+ Islamabad +
+
+
+
+
+ +
+
+ 3d ago +
+
+
+
+
+ + + +
+
+ Berlin +
+
+
+
+
+ +
+
+ 3d ago +
+
+
+
+
+ +
+`; + +exports[`StatusByLocation component renders when all locations are up 1`] = ` +.c3 { + display: inline-block; + margin-left: 4px; +} + +.c2 { + font-weight: 600; +} + +.c1 { + margin-bottom: 5px; +} + +.c0 { + padding: 10px; + max-height: 229px; + overflow: hidden; +} + +
+ + +
+ + + +
+
+ Islamabad +
+
+
+
+
+ +
+
+ 3d ago +
+
+
+
+
+ + + +
+
+ Berlin +
+
+
+
+
+ +
+
+ 3d ago +
+
+
+
+
+
+`; + +exports[`StatusByLocation component renders when there are many location 1`] = ` +Array [ + .c3 { + display: inline-block; + margin-left: 4px; +} + +.c2 { + font-weight: 600; +} + +.c1 { + margin-bottom: 5px; +} + +.c0 { + padding: 10px; + max-height: 229px; + overflow: hidden; +} + +
+ +
+ + + +
+
+ Islamabad +
+
+
+
+
+ +
+
+ 3d ago +
+
+
+
+
+ + + +
+
+ Berlin +
+
+
+
+
+ +
+
+ 3d ago +
+
+
+
+
+ + + +
+
+ st-paul +
+
+
+
+
+ +
+
+ 3d ago +
+
+
+
+
+ + + +
+
+ Tokya +
+
+
+
+
+ +
+
+ 3d ago +
+
+
+
+
+ + + +
+
+ New York +
+
+
+
+
+ +
+
+ 3d ago +
+
+
+
+
+ + + +
+
+ Toronto +
+
+
+
+
+ +
+
+ 3d ago +
+
+
+
+
+ + + +
+
+ Sydney +
+
+
+
+
+ +
+
+ 3d ago +
+
+
+
+
+ + + +
+
+ Paris +
+
+
+
+
+ +
+
+ 3d ago +
+
+
+
+
+ +
, + .c0 { + padding-left: 18px; +} + +
+
+
+

+ 1 Others ... +

+
+
+
, +] +`; diff --git a/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/location_status_tags.test.tsx b/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/location_status_tags.test.tsx new file mode 100644 index 0000000000000..21e5881654533 --- /dev/null +++ b/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/location_status_tags.test.tsx @@ -0,0 +1,101 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React from 'react'; +import moment from 'moment'; +import { renderWithIntl } from 'test_utils/enzyme_helpers'; +import { MonitorLocation } from '../../../../../common/runtime_types/monitor'; +import { LocationStatusTags } from '../'; + +describe('StatusByLocation component', () => { + let monitorLocations: MonitorLocation[]; + + const start = moment('2020-01-10T12:22:32.567Z'); + beforeAll(() => { + moment.prototype.fromNow = jest.fn((date: string) => start.from(date)); + }); + + it('renders when there are many location', () => { + monitorLocations = [ + { + summary: { up: 0, down: 1 }, + geo: { name: 'Islamabad', location: { lat: '52.487448', lon: ' 13.394798' } }, + timestamp: '2020-01-09T12:22:32.567Z', + }, + { + summary: { up: 0, down: 1 }, + geo: { name: 'Berlin', location: { lat: '52.487448', lon: ' 13.394798' } }, + timestamp: '2020-01-09T12:22:28.825Z', + }, + { + summary: { up: 0, down: 1 }, + geo: { name: 'st-paul', location: { lat: '52.487448', lon: ' 13.394798' } }, + timestamp: '2020-01-09T12:22:31.586Z', + }, + { + summary: { up: 0, down: 1 }, + geo: { name: 'Tokya', location: { lat: '52.487448', lon: ' 13.394798' } }, + timestamp: '2020-01-09T12:22:25.771Z', + }, + { + summary: { up: 0, down: 1 }, + geo: { name: 'New York', location: { lat: '52.487448', lon: ' 13.394798' } }, + timestamp: '2020-01-09T12:22:27.485Z', + }, + { + summary: { up: 0, down: 1 }, + geo: { name: 'Toronto', location: { lat: '52.487448', lon: ' 13.394798' } }, + timestamp: '2020-01-09T12:22:28.815Z', + }, + { + summary: { up: 0, down: 1 }, + geo: { name: 'Sydney', location: { lat: '52.487448', lon: ' 13.394798' } }, + timestamp: '2020-01-09T12:22:32.132Z', + }, + { + summary: { up: 0, down: 1 }, + geo: { name: 'Paris', location: { lat: '52.487448', lon: ' 13.394798' } }, + timestamp: '2020-01-09T12:22:32.973Z', + }, + ]; + const component = renderWithIntl(); + expect(component).toMatchSnapshot(); + }); + + it('renders when all locations are up', () => { + monitorLocations = [ + { + summary: { up: 4, down: 0 }, + geo: { name: 'Islamabad', location: { lat: '52.487448', lon: ' 13.394798' } }, + timestamp: '2020-01-09T12:22:32.567Z', + }, + { + summary: { up: 4, down: 0 }, + geo: { name: 'Berlin', location: { lat: '52.487448', lon: ' 13.394798' } }, + timestamp: '2020-01-08T12:22:28.825Z', + }, + ]; + const component = renderWithIntl(); + expect(component).toMatchSnapshot(); + }); + + it('renders when all locations are down', () => { + monitorLocations = [ + { + summary: { up: 0, down: 2 }, + geo: { name: 'Islamabad', location: { lat: '52.487448', lon: ' 13.394798' } }, + timestamp: '2020-01-06T12:22:32.567Z', + }, + { + summary: { up: 0, down: 2 }, + geo: { name: 'Berlin', location: { lat: '52.487448', lon: ' 13.394798' } }, + timestamp: '2020-01-09T12:22:28.825Z', + }, + ]; + const component = renderWithIntl(); + expect(component).toMatchSnapshot(); + }); +}); diff --git a/x-pack/legacy/plugins/uptime/public/components/functional/location_map/index.tsx b/x-pack/legacy/plugins/uptime/public/components/functional/location_map/index.tsx index 1f4b88b971c4c..140d33bbeef66 100644 --- a/x-pack/legacy/plugins/uptime/public/components/functional/location_map/index.tsx +++ b/x-pack/legacy/plugins/uptime/public/components/functional/location_map/index.tsx @@ -5,3 +5,4 @@ */ export * from './location_map'; +export * from './location_status_tags'; diff --git a/x-pack/legacy/plugins/uptime/public/components/functional/location_map/location_status_tags.tsx b/x-pack/legacy/plugins/uptime/public/components/functional/location_map/location_status_tags.tsx index a10d8e02e6863..6563c03ad7c34 100644 --- a/x-pack/legacy/plugins/uptime/public/components/functional/location_map/location_status_tags.tsx +++ b/x-pack/legacy/plugins/uptime/public/components/functional/location_map/location_status_tags.tsx @@ -7,9 +7,16 @@ import React, { useContext } from 'react'; import styled from 'styled-components'; import { EuiBadge, EuiText } from '@elastic/eui'; +import moment from 'moment'; +import { FormattedMessage } from '@kbn/i18n/react'; import { UptimeSettingsContext } from '../../../contexts'; import { MonitorLocation } from '../../../../common/runtime_types'; +const TimeStampSpan = styled.span` + display: inline-block; + margin-left: 4px; +`; + const TextStyle = styled.div` font-weight: 600; `; @@ -20,54 +27,97 @@ const BadgeItem = styled.div` const TagContainer = styled.div` padding: 10px; - max-height: 200px; + max-height: 229px; overflow: hidden; `; +const OtherLocationsDiv = styled.div` + padding-left: 18px; +`; + interface Props { locations: MonitorLocation[]; } +interface StatusTag { + label: string; + timestamp: number; +} + export const LocationStatusTags = ({ locations }: Props) => { const { colors: { gray, danger }, } = useContext(UptimeSettingsContext); - const upLocs: string[] = []; - const downLocs: string[] = []; + const upLocations: StatusTag[] = []; + const downLocations: StatusTag[] = []; locations.forEach((item: any) => { if (item.summary.down === 0) { - upLocs.push(item.geo.name); + upLocations.push({ label: item.geo.name, timestamp: new Date(item.timestamp).valueOf() }); } else { - downLocs.push(item.geo.name); + downLocations.push({ label: item.geo.name, timestamp: new Date(item.timestamp).valueOf() }); } }); + // Sort by recent timestamp + upLocations.sort((a, b) => { + return a.timestamp < b.timestamp ? 1 : b.timestamp < a.timestamp ? -1 : 0; + }); + + moment.locale('en', { + relativeTime: { + future: 'in %s', + past: '%s ago', + s: '%ds', + ss: '%ss', + m: '%dm', + mm: '%dm', + h: '%dh', + hh: '%dh', + d: '%dd', + dd: '%dd', + M: '%d Mon', + MM: '%d Mon', + y: '%d Yr', + yy: '%d Yr', + }, + }); + + const tagLabel = (item: StatusTag, ind: number, color: string) => ( + + + + {item.label} + + + + {moment(item.timestamp).fromNow()} + + + ); + return ( - - - {downLocs.map((item, ind) => ( - - - - {item} - - - - ))} - - - {upLocs.map((item, ind) => ( - - - - {item} - - - - ))} - - + <> + + {downLocations.map((item, ind) => tagLabel(item, ind, danger))} + {upLocations.map((item, ind) => tagLabel(item, ind, gray))} + + {locations.length > 7 && ( + + +

+ +

+
+
+ )} + ); }; diff --git a/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/__test__/status_by_location.test.tsx b/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/__test__/status_by_location.test.tsx index 4e515a52b8de6..38864103564ca 100644 --- a/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/__test__/status_by_location.test.tsx +++ b/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/__test__/status_by_location.test.tsx @@ -17,6 +17,7 @@ describe('StatusByLocation component', () => { { summary: { up: 4, down: 0 }, geo: { name: 'Berlin', location: { lat: '52.487448', lon: ' 13.394798' } }, + timestamp: '2020-01-09T12:22:32.567Z', }, { summary: { up: 4, down: 0 }, @@ -32,6 +33,7 @@ describe('StatusByLocation component', () => { { summary: { up: 4, down: 0 }, geo: { name: 'Berlin', location: { lat: '52.487448', lon: ' 13.394798' } }, + timestamp: '2020-01-09T12:22:32.567Z', }, ]; const component = renderWithIntl(); @@ -43,6 +45,7 @@ describe('StatusByLocation component', () => { { summary: { up: 0, down: 4 }, geo: { name: 'Berlin', location: { lat: '52.487448', lon: ' 13.394798' } }, + timestamp: '2020-01-09T12:22:32.567Z', }, ]; const component = renderWithIntl(); @@ -54,10 +57,12 @@ describe('StatusByLocation component', () => { { summary: { up: 0, down: 4 }, geo: { name: 'Berlin', location: { lat: '52.487448', lon: ' 13.394798' } }, + timestamp: '2020-01-09T12:22:32.567Z', }, { summary: { up: 0, down: 4 }, geo: { name: 'st-paul', location: { lat: '52.487448', lon: ' 13.394798' } }, + timestamp: '2020-01-09T12:22:32.567Z', }, ]; const component = renderWithIntl(); @@ -69,10 +74,12 @@ describe('StatusByLocation component', () => { { summary: { up: 0, down: 4 }, geo: { name: 'Berlin', location: { lat: '52.487448', lon: ' 13.394798' } }, + timestamp: '2020-01-09T12:22:32.567Z', }, { summary: { up: 4, down: 0 }, geo: { name: 'st-paul', location: { lat: '52.487448', lon: ' 13.394798' } }, + timestamp: '2020-01-09T12:22:32.567Z', }, ]; const component = renderWithIntl(); diff --git a/x-pack/legacy/plugins/uptime/server/lib/adapters/monitors/elasticsearch_monitors_adapter.ts b/x-pack/legacy/plugins/uptime/server/lib/adapters/monitors/elasticsearch_monitors_adapter.ts index 37a9e032cd442..b237fd8771f58 100644 --- a/x-pack/legacy/plugins/uptime/server/lib/adapters/monitors/elasticsearch_monitors_adapter.ts +++ b/x-pack/legacy/plugins/uptime/server/lib/adapters/monitors/elasticsearch_monitors_adapter.ts @@ -334,7 +334,7 @@ export const elasticsearchMonitorsAdapter: UMMonitorsAdapter = { order: 'desc', }, }, - _source: ['monitor', 'summary', 'observer'], + _source: ['monitor', 'summary', 'observer', '@timestamp'], }, }, }, @@ -365,6 +365,7 @@ export const elasticsearchMonitorsAdapter: UMMonitorsAdapter = { const location: MonitorLocation = { summary: mostRecentLocation?.summary, geo: getGeo(mostRecentLocation?.observer?.geo), + timestamp: mostRecentLocation['@timestamp'], }; monLocs.push(location); } From 62e7edbe26d68eb0c132c8eaa58c39e01d19a6c4 Mon Sep 17 00:00:00 2001 From: robbruce Date: Mon, 13 Jan 2020 19:50:33 +0000 Subject: [PATCH 051/139] Fixes #45896 (#50229) Co-authored-by: Elastic Machine --- .../plugins/canvas/server/lib/query_es_sql.js | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/x-pack/legacy/plugins/canvas/server/lib/query_es_sql.js b/x-pack/legacy/plugins/canvas/server/lib/query_es_sql.js index 15d3dc52ee311..f7907e2cffb26 100644 --- a/x-pack/legacy/plugins/canvas/server/lib/query_es_sql.js +++ b/x-pack/legacy/plugins/canvas/server/lib/query_es_sql.js @@ -30,6 +30,19 @@ export const queryEsSQL = (elasticsearchClient, { count, query, filter, timezone }); const columnNames = map(columns, 'name'); const rows = res.rows.map(row => zipObject(columnNames, row)); + + if (!!res.cursor) { + elasticsearchClient('transport.request', { + path: '/_sql/close', + method: 'POST', + body: { + cursor: res.cursor, + }, + }).catch(e => { + throw new Error(`Unexpected error from Elasticsearch: ${e.message}`); + }); + } + return { type: 'datatable', columns, From 2178ee38c0a3daf4acac62b5f37db4f1147070b5 Mon Sep 17 00:00:00 2001 From: Matthew Kime Date: Mon, 13 Jan 2020 13:58:59 -0600 Subject: [PATCH 052/139] uiSettings - use validation field for image field maxSize (#54522) * uiSettings - use validation field for image field maxSize --- .../server/kibana-plugin-server.basepath.get.md | 2 +- .../server/kibana-plugin-server.basepath.md | 4 ++-- .../server/kibana-plugin-server.basepath.set.md | 2 +- .../kibana-plugin-server.uisettingsparams.md | 1 + ...plugin-server.uisettingsparams.validation.md | 11 +++++++++++ src/core/server/server.api.md | 5 +++++ src/core/server/ui_settings/types.ts | 17 +++++++++++++++++ .../sections/settings/components/field/field.js | 2 +- .../settings/components/field/field.test.js | 3 +-- .../sections/settings/lib/to_editable_config.js | 13 +++++++------ x-pack/legacy/plugins/reporting/index.ts | 2 +- 11 files changed, 48 insertions(+), 14 deletions(-) create mode 100644 docs/development/core/server/kibana-plugin-server.uisettingsparams.validation.md diff --git a/docs/development/core/server/kibana-plugin-server.basepath.get.md b/docs/development/core/server/kibana-plugin-server.basepath.get.md index 6ef7022f10e62..a20bc1a4e3174 100644 --- a/docs/development/core/server/kibana-plugin-server.basepath.get.md +++ b/docs/development/core/server/kibana-plugin-server.basepath.get.md @@ -9,5 +9,5 @@ returns `basePath` value, specific for an incoming request. Signature: ```typescript -get: (request: KibanaRequest | LegacyRequest) => string; +get: (request: LegacyRequest | KibanaRequest) => string; ``` diff --git a/docs/development/core/server/kibana-plugin-server.basepath.md b/docs/development/core/server/kibana-plugin-server.basepath.md index 50a30f7c43fe6..63aeb7f711d97 100644 --- a/docs/development/core/server/kibana-plugin-server.basepath.md +++ b/docs/development/core/server/kibana-plugin-server.basepath.md @@ -20,9 +20,9 @@ The constructor for this class is marked as internal. Third-party code should no | Property | Modifiers | Type | Description | | --- | --- | --- | --- | -| [get](./kibana-plugin-server.basepath.get.md) | | (request: KibanaRequest<unknown, unknown, unknown, any> | LegacyRequest) => string | returns basePath value, specific for an incoming request. | +| [get](./kibana-plugin-server.basepath.get.md) | | (request: LegacyRequest | KibanaRequest<unknown, unknown, unknown, any>) => string | returns basePath value, specific for an incoming request. | | [prepend](./kibana-plugin-server.basepath.prepend.md) | | (path: string) => string | Prepends path with the basePath. | | [remove](./kibana-plugin-server.basepath.remove.md) | | (path: string) => string | Removes the prepended basePath from the path. | | [serverBasePath](./kibana-plugin-server.basepath.serverbasepath.md) | | string | returns the server's basePathSee [BasePath.get](./kibana-plugin-server.basepath.get.md) for getting the basePath value for a specific request | -| [set](./kibana-plugin-server.basepath.set.md) | | (request: KibanaRequest<unknown, unknown, unknown, any> | LegacyRequest, requestSpecificBasePath: string) => void | sets basePath value, specific for an incoming request. | +| [set](./kibana-plugin-server.basepath.set.md) | | (request: LegacyRequest | KibanaRequest<unknown, unknown, unknown, any>, requestSpecificBasePath: string) => void | sets basePath value, specific for an incoming request. | diff --git a/docs/development/core/server/kibana-plugin-server.basepath.set.md b/docs/development/core/server/kibana-plugin-server.basepath.set.md index 56a7f644d34cc..ac08baa0bb99e 100644 --- a/docs/development/core/server/kibana-plugin-server.basepath.set.md +++ b/docs/development/core/server/kibana-plugin-server.basepath.set.md @@ -9,5 +9,5 @@ sets `basePath` value, specific for an incoming request. Signature: ```typescript -set: (request: KibanaRequest | LegacyRequest, requestSpecificBasePath: string) => void; +set: (request: LegacyRequest | KibanaRequest, requestSpecificBasePath: string) => void; ``` diff --git a/docs/development/core/server/kibana-plugin-server.uisettingsparams.md b/docs/development/core/server/kibana-plugin-server.uisettingsparams.md index a38499e8f37dd..89eb5b10b9de5 100644 --- a/docs/development/core/server/kibana-plugin-server.uisettingsparams.md +++ b/docs/development/core/server/kibana-plugin-server.uisettingsparams.md @@ -24,5 +24,6 @@ export interface UiSettingsParams | [readonly](./kibana-plugin-server.uisettingsparams.readonly.md) | boolean | a flag indicating that value cannot be changed | | [requiresPageReload](./kibana-plugin-server.uisettingsparams.requirespagereload.md) | boolean | a flag indicating whether new value applying requires page reloading | | [type](./kibana-plugin-server.uisettingsparams.type.md) | UiSettingsType | defines a type of UI element [UiSettingsType](./kibana-plugin-server.uisettingstype.md) | +| [validation](./kibana-plugin-server.uisettingsparams.validation.md) | ImageValidation | StringValidation | | | [value](./kibana-plugin-server.uisettingsparams.value.md) | SavedObjectAttribute | default value to fall back to if a user doesn't provide any | diff --git a/docs/development/core/server/kibana-plugin-server.uisettingsparams.validation.md b/docs/development/core/server/kibana-plugin-server.uisettingsparams.validation.md new file mode 100644 index 0000000000000..f097f36e999ba --- /dev/null +++ b/docs/development/core/server/kibana-plugin-server.uisettingsparams.validation.md @@ -0,0 +1,11 @@ + + +[Home](./index.md) > [kibana-plugin-server](./kibana-plugin-server.md) > [UiSettingsParams](./kibana-plugin-server.uisettingsparams.md) > [validation](./kibana-plugin-server.uisettingsparams.validation.md) + +## UiSettingsParams.validation property + +Signature: + +```typescript +validation?: ImageValidation | StringValidation; +``` diff --git a/src/core/server/server.api.md b/src/core/server/server.api.md index bf7dc14c73265..65477e93e225e 100644 --- a/src/core/server/server.api.md +++ b/src/core/server/server.api.md @@ -1935,6 +1935,11 @@ export interface UiSettingsParams { readonly?: boolean; requiresPageReload?: boolean; type?: UiSettingsType; + // Warning: (ae-forgotten-export) The symbol "ImageValidation" needs to be exported by the entry point index.d.ts + // Warning: (ae-forgotten-export) The symbol "StringValidation" needs to be exported by the entry point index.d.ts + // + // (undocumented) + validation?: ImageValidation | StringValidation; value?: SavedObjectAttribute; } diff --git a/src/core/server/ui_settings/types.ts b/src/core/server/ui_settings/types.ts index 5e3f0a4fbb6bd..2ab6114e7df88 100644 --- a/src/core/server/ui_settings/types.ts +++ b/src/core/server/ui_settings/types.ts @@ -102,6 +102,23 @@ export interface UiSettingsParams { readonly?: boolean; /** defines a type of UI element {@link UiSettingsType} */ type?: UiSettingsType; + /* + * Allows defining a custom validation applicable to value change on the client. + * @deprecated + */ + validation?: ImageValidation | StringValidation; +} + +export interface StringValidation { + regexString: string; + message: string; +} + +export interface ImageValidation { + maxSize: { + length: number; + description: string; + }; } /** @internal */ diff --git a/src/legacy/core_plugins/kibana/public/management/sections/settings/components/field/field.js b/src/legacy/core_plugins/kibana/public/management/sections/settings/components/field/field.js index 939dc8c20e465..65d212c23a28c 100644 --- a/src/legacy/core_plugins/kibana/public/management/sections/settings/components/field/field.js +++ b/src/legacy/core_plugins/kibana/public/management/sections/settings/components/field/field.js @@ -224,7 +224,7 @@ export class Field extends PureComponent { } const file = files[0]; - const { maxSize } = this.props.setting.options; + const { maxSize } = this.props.setting.validation; try { const base64Image = await this.getImageAsBase64(file); const isInvalid = !!(maxSize && maxSize.length && base64Image.length > maxSize.length); diff --git a/src/legacy/core_plugins/kibana/public/management/sections/settings/components/field/field.test.js b/src/legacy/core_plugins/kibana/public/management/sections/settings/components/field/field.test.js index 74bb0e25ff52e..07ce6f84d2bb6 100644 --- a/src/legacy/core_plugins/kibana/public/management/sections/settings/components/field/field.test.js +++ b/src/legacy/core_plugins/kibana/public/management/sections/settings/components/field/field.test.js @@ -72,10 +72,9 @@ const settings = { defVal: null, isCustom: false, isOverridden: false, - options: { + validation: { maxSize: { length: 1000, - displayName: '1 kB', description: 'Description for 1 kB', }, }, diff --git a/src/legacy/core_plugins/kibana/public/management/sections/settings/lib/to_editable_config.js b/src/legacy/core_plugins/kibana/public/management/sections/settings/lib/to_editable_config.js index 791f9e400b407..bb561cbe04212 100644 --- a/src/legacy/core_plugins/kibana/public/management/sections/settings/lib/to_editable_config.js +++ b/src/legacy/core_plugins/kibana/public/management/sections/settings/lib/to_editable_config.js @@ -43,12 +43,13 @@ export function toEditableConfig({ def, name, value, isCustom, isOverridden }) { defVal: def.value, type: getValType(def, value), description: def.description, - validation: def.validation - ? { - regex: new RegExp(def.validation.regexString), - message: def.validation.message, - } - : undefined, + validation: + def.validation && def.validation.regexString + ? { + regex: new RegExp(def.validation.regexString), + message: def.validation.message, + } + : def.validation, options: def.options, optionLabels: def.optionLabels, requiresPageReload: !!def.requiresPageReload, diff --git a/x-pack/legacy/plugins/reporting/index.ts b/x-pack/legacy/plugins/reporting/index.ts index faa27bfb2d6ea..ef0ab37738362 100644 --- a/x-pack/legacy/plugins/reporting/index.ts +++ b/x-pack/legacy/plugins/reporting/index.ts @@ -59,7 +59,7 @@ export const reporting = (kibana: any) => { defaultMessage: `Custom image to use in the PDF's footer`, }), type: 'image', - options: { + validation: { maxSize: { length: kbToBase64Length(200), description: '200 kB', From 054bbbbc46e3e2cb0908297e315fc3d4d22d8cd7 Mon Sep 17 00:00:00 2001 From: Frank Hassanabad Date: Mon, 13 Jan 2020 13:36:51 -0700 Subject: [PATCH 053/139] [SIEM][Detection Engine] Increases the number or rules you can view on a single page (#54628) * Increased the number or rules you can view on a single page * messed up one line --- .../siem/public/pages/detection_engine/rules/all/index.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/index.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/index.tsx index e900058b6c53c..d928cc0949851 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/index.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/index.tsx @@ -217,7 +217,7 @@ export const AllRules = React.memo<{ pageIndex: pagination.page - 1, pageSize: pagination.perPage, totalItemCount: pagination.total, - pageSizeOptions: [5, 10, 20], + pageSizeOptions: [5, 10, 20, 50, 100, 200, 300], }} sorting={{ sort: { field: 'activate', direction: filterOptions.sortOrder } }} selection={hasNoPermissions ? undefined : euiBasicTableSelectionProps} From 24b3ecbae0ac30a98b27eb67c3703df26345de9a Mon Sep 17 00:00:00 2001 From: Corey Robertson Date: Mon, 13 Jan 2020 15:40:05 -0500 Subject: [PATCH 054/139] [Canvas] Enable Embeddable maps (#53971) * Enables Embeddable maps in Canvas. Updates expressions as maps are interacted with * Fix type check errors * Update imports. Remove filters from initial embed expressions * Adds hide layer functionality to canvas map embeds * Fix typecheck error * Fix Type check Co-authored-by: Elastic Machine --- .../expression_types/embeddable.ts | 4 +- .../expression_types/embeddable_types.ts | 2 +- .../functions/common/index.ts | 4 + .../functions/common/map_center.ts | 50 +++++++++++++ .../functions/common/saved_map.test.ts | 12 +-- .../functions/common/saved_map.ts | 68 +++++++++++++++-- .../functions/common/time_range.ts | 44 +++++++++++ .../renderers/{ => embeddable}/embeddable.tsx | 36 +++++---- .../embeddable_input_to_expression.test.ts | 75 +++++++++++++++++++ .../embeddable_input_to_expression.ts | 50 +++++++++++++ .../canvas_plugin_src/renderers/index.js | 2 +- .../canvas/i18n/functions/dict/map_center.ts | 27 +++++++ .../canvas/i18n/functions/dict/saved_map.ts | 16 +++- .../canvas/i18n/functions/dict/time_range.ts | 24 ++++++ .../canvas/i18n/functions/function_help.ts | 4 + .../element_content/element_content.js | 11 ++- .../element_wrapper/lib/handlers.js | 12 +++ .../components/embeddable_flyout/index.tsx | 7 +- .../workpad_interactive_page/index.js | 28 +++++++ .../canvas/public/state/actions/embeddable.ts | 36 +++++++++ .../canvas/public/state/reducers/elements.js | 2 +- .../public/state/reducers/embeddable.ts | 67 +++++++++++++++++ .../public/state/reducers/embeddables.test.ts | 41 ++++++++++ .../canvas/public/state/reducers/index.js | 3 +- .../lib/build_embeddable_filters.test.ts | 4 +- .../server/lib/build_embeddable_filters.ts | 6 +- .../components/rendered_element.tsx | 2 + .../legacy/plugins/canvas/types/functions.ts | 13 ++++ .../legacy/plugins/canvas/types/renderers.ts | 4 + .../public/customize_time_range_modal.tsx | 2 +- 30 files changed, 608 insertions(+), 48 deletions(-) create mode 100644 x-pack/legacy/plugins/canvas/canvas_plugin_src/functions/common/map_center.ts create mode 100644 x-pack/legacy/plugins/canvas/canvas_plugin_src/functions/common/time_range.ts rename x-pack/legacy/plugins/canvas/canvas_plugin_src/renderers/{ => embeddable}/embeddable.tsx (74%) create mode 100644 x-pack/legacy/plugins/canvas/canvas_plugin_src/renderers/embeddable/embeddable_input_to_expression.test.ts create mode 100644 x-pack/legacy/plugins/canvas/canvas_plugin_src/renderers/embeddable/embeddable_input_to_expression.ts create mode 100644 x-pack/legacy/plugins/canvas/i18n/functions/dict/map_center.ts create mode 100644 x-pack/legacy/plugins/canvas/i18n/functions/dict/time_range.ts create mode 100644 x-pack/legacy/plugins/canvas/public/state/actions/embeddable.ts create mode 100644 x-pack/legacy/plugins/canvas/public/state/reducers/embeddable.ts create mode 100644 x-pack/legacy/plugins/canvas/public/state/reducers/embeddables.test.ts diff --git a/x-pack/legacy/plugins/canvas/canvas_plugin_src/expression_types/embeddable.ts b/x-pack/legacy/plugins/canvas/canvas_plugin_src/expression_types/embeddable.ts index 063e69d1d2141..e728ea25f5504 100644 --- a/x-pack/legacy/plugins/canvas/canvas_plugin_src/expression_types/embeddable.ts +++ b/x-pack/legacy/plugins/canvas/canvas_plugin_src/expression_types/embeddable.ts @@ -5,11 +5,11 @@ */ import { ExpressionType } from 'src/plugins/expressions/public'; -import { EmbeddableInput } from 'src/legacy/core_plugins/embeddable_api/public/np_ready/public'; +import { EmbeddableInput } from '../../../../../../src/plugins/embeddable/public'; import { EmbeddableTypes } from './embeddable_types'; export const EmbeddableExpressionType = 'embeddable'; -export { EmbeddableTypes }; +export { EmbeddableTypes, EmbeddableInput }; export interface EmbeddableExpression { type: typeof EmbeddableExpressionType; diff --git a/x-pack/legacy/plugins/canvas/canvas_plugin_src/expression_types/embeddable_types.ts b/x-pack/legacy/plugins/canvas/canvas_plugin_src/expression_types/embeddable_types.ts index 3669bd3e08201..8f5ad859d28ba 100644 --- a/x-pack/legacy/plugins/canvas/canvas_plugin_src/expression_types/embeddable_types.ts +++ b/x-pack/legacy/plugins/canvas/canvas_plugin_src/expression_types/embeddable_types.ts @@ -9,7 +9,7 @@ import { MAP_SAVED_OBJECT_TYPE } from '../../../maps/common/constants'; import { VISUALIZE_EMBEDDABLE_TYPE } from '../../../../../../src/legacy/core_plugins/kibana/public/visualize_embeddable/constants'; import { SEARCH_EMBEDDABLE_TYPE } from '../../../../../../src/legacy/core_plugins/kibana/public/discover/np_ready/embeddable/constants'; -export const EmbeddableTypes = { +export const EmbeddableTypes: { map: string; search: string; visualization: string } = { map: MAP_SAVED_OBJECT_TYPE, search: SEARCH_EMBEDDABLE_TYPE, visualization: VISUALIZE_EMBEDDABLE_TYPE, diff --git a/x-pack/legacy/plugins/canvas/canvas_plugin_src/functions/common/index.ts b/x-pack/legacy/plugins/canvas/canvas_plugin_src/functions/common/index.ts index 097aef69d4b4c..48b50930d563e 100644 --- a/x-pack/legacy/plugins/canvas/canvas_plugin_src/functions/common/index.ts +++ b/x-pack/legacy/plugins/canvas/canvas_plugin_src/functions/common/index.ts @@ -32,6 +32,7 @@ import { image } from './image'; import { joinRows } from './join_rows'; import { lt } from './lt'; import { lte } from './lte'; +import { mapCenter } from './map_center'; import { mapColumn } from './mapColumn'; import { math } from './math'; import { metric } from './metric'; @@ -57,6 +58,7 @@ import { staticColumn } from './staticColumn'; import { string } from './string'; import { table } from './table'; import { tail } from './tail'; +import { timerange } from './time_range'; import { timefilter } from './timefilter'; import { timefilterControl } from './timefilterControl'; import { switchFn } from './switch'; @@ -91,6 +93,7 @@ export const functions = [ lt, lte, joinRows, + mapCenter, mapColumn, math, metric, @@ -118,6 +121,7 @@ export const functions = [ tail, timefilter, timefilterControl, + timerange, switchFn, caseFn, ]; diff --git a/x-pack/legacy/plugins/canvas/canvas_plugin_src/functions/common/map_center.ts b/x-pack/legacy/plugins/canvas/canvas_plugin_src/functions/common/map_center.ts new file mode 100644 index 0000000000000..21f9e9fe3148d --- /dev/null +++ b/x-pack/legacy/plugins/canvas/canvas_plugin_src/functions/common/map_center.ts @@ -0,0 +1,50 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { ExpressionFunction } from 'src/plugins/expressions/common'; +import { getFunctionHelp } from '../../../i18n/functions'; +import { MapCenter } from '../../../types'; + +interface Args { + lat: number; + lon: number; + zoom: number; +} + +export function mapCenter(): ExpressionFunction<'mapCenter', null, Args, MapCenter> { + const { help, args: argHelp } = getFunctionHelp().mapCenter; + return { + name: 'mapCenter', + help, + type: 'mapCenter', + context: { + types: ['null'], + }, + args: { + lat: { + types: ['number'], + required: true, + help: argHelp.lat, + }, + lon: { + types: ['number'], + required: true, + help: argHelp.lon, + }, + zoom: { + types: ['number'], + required: true, + help: argHelp.zoom, + }, + }, + fn: (context, args) => { + return { + type: 'mapCenter', + ...args, + }; + }, + }; +} diff --git a/x-pack/legacy/plugins/canvas/canvas_plugin_src/functions/common/saved_map.test.ts b/x-pack/legacy/plugins/canvas/canvas_plugin_src/functions/common/saved_map.test.ts index 25f035bbb6d8c..5b95886faa13d 100644 --- a/x-pack/legacy/plugins/canvas/canvas_plugin_src/functions/common/saved_map.test.ts +++ b/x-pack/legacy/plugins/canvas/canvas_plugin_src/functions/common/saved_map.test.ts @@ -5,7 +5,7 @@ */ jest.mock('ui/new_platform'); import { savedMap } from './saved_map'; -import { buildEmbeddableFilters } from '../../../server/lib/build_embeddable_filters'; +import { getQueryFilters } from '../../../server/lib/build_embeddable_filters'; const filterContext = { and: [ @@ -24,20 +24,22 @@ describe('savedMap', () => { const fn = savedMap().fn; const args = { id: 'some-id', + center: null, + title: null, + timerange: null, + hideLayer: [], }; it('accepts null context', () => { const expression = fn(null, args, {}); expect(expression.input.filters).toEqual([]); - expect(expression.input.timeRange).toBeUndefined(); }); it('accepts filter context', () => { const expression = fn(filterContext, args, {}); - const embeddableFilters = buildEmbeddableFilters(filterContext.and); + const embeddableFilters = getQueryFilters(filterContext.and); - expect(expression.input.filters).toEqual(embeddableFilters.filters); - expect(expression.input.timeRange).toEqual(embeddableFilters.timeRange); + expect(expression.input.filters).toEqual(embeddableFilters); }); }); diff --git a/x-pack/legacy/plugins/canvas/canvas_plugin_src/functions/common/saved_map.ts b/x-pack/legacy/plugins/canvas/canvas_plugin_src/functions/common/saved_map.ts index 460cb9c34efff..b6d88c06ed06d 100644 --- a/x-pack/legacy/plugins/canvas/canvas_plugin_src/functions/common/saved_map.ts +++ b/x-pack/legacy/plugins/canvas/canvas_plugin_src/functions/common/saved_map.ts @@ -7,8 +7,8 @@ import { ExpressionFunction } from 'src/plugins/expressions/common/types'; import { TimeRange } from 'src/plugins/data/public'; import { EmbeddableInput } from 'src/legacy/core_plugins/embeddable_api/public/np_ready/public'; -import { buildEmbeddableFilters } from '../../../server/lib/build_embeddable_filters'; -import { Filter } from '../../../types'; +import { getQueryFilters } from '../../../server/lib/build_embeddable_filters'; +import { Filter, MapCenter, TimeRange as TimeRangeArg } from '../../../types'; import { EmbeddableTypes, EmbeddableExpressionType, @@ -19,19 +19,36 @@ import { esFilters } from '../../../../../../../src/plugins/data/public'; interface Arguments { id: string; + center: MapCenter | null; + hideLayer: string[]; + title: string | null; + timerange: TimeRangeArg | null; } // Map embeddable is missing proper typings, so type is just to document what we // are expecting to pass to the embeddable -interface SavedMapInput extends EmbeddableInput { +export type SavedMapInput = EmbeddableInput & { id: string; + isLayerTOCOpen: boolean; timeRange?: TimeRange; refreshConfig: { isPaused: boolean; interval: number; }; + hideFilterActions: true; filters: esFilters.Filter[]; -} + mapCenter?: { + lat: number; + lon: number; + zoom: number; + }; + hiddenLayers?: string[]; +}; + +const defaultTimeRange = { + from: 'now-15m', + to: 'now', +}; type Return = EmbeddableExpression; @@ -46,21 +63,56 @@ export function savedMap(): ExpressionFunction<'savedMap', Filter | null, Argume required: false, help: argHelp.id, }, + center: { + types: ['mapCenter'], + help: argHelp.center, + required: false, + }, + hideLayer: { + types: ['string'], + help: argHelp.hideLayer, + required: false, + multi: true, + }, + timerange: { + types: ['timerange'], + help: argHelp.timerange, + required: false, + }, + title: { + types: ['string'], + help: argHelp.title, + required: false, + }, }, type: EmbeddableExpressionType, - fn: (context, { id }) => { + fn: (context, args) => { const filters = context ? context.and : []; + const center = args.center + ? { + lat: args.center.lat, + lon: args.center.lon, + zoom: args.center.zoom, + } + : undefined; + return { type: EmbeddableExpressionType, input: { - id, - ...buildEmbeddableFilters(filters), - + id: args.id, + filters: getQueryFilters(filters), + timeRange: args.timerange || defaultTimeRange, refreshConfig: { isPaused: false, interval: 0, }, + + mapCenter: center, + hideFilterActions: true, + title: args.title ? args.title : undefined, + isLayerTOCOpen: false, + hiddenLayers: args.hideLayer || [], }, embeddableType: EmbeddableTypes.map, }; diff --git a/x-pack/legacy/plugins/canvas/canvas_plugin_src/functions/common/time_range.ts b/x-pack/legacy/plugins/canvas/canvas_plugin_src/functions/common/time_range.ts new file mode 100644 index 0000000000000..716026279ccea --- /dev/null +++ b/x-pack/legacy/plugins/canvas/canvas_plugin_src/functions/common/time_range.ts @@ -0,0 +1,44 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { ExpressionFunction } from 'src/plugins/expressions/common'; +import { getFunctionHelp } from '../../../i18n/functions'; +import { TimeRange } from '../../../types'; + +interface Args { + from: string; + to: string; +} + +export function timerange(): ExpressionFunction<'timerange', null, Args, TimeRange> { + const { help, args: argHelp } = getFunctionHelp().timerange; + return { + name: 'timerange', + help, + type: 'timerange', + context: { + types: ['null'], + }, + args: { + from: { + types: ['string'], + required: true, + help: argHelp.from, + }, + to: { + types: ['string'], + required: true, + help: argHelp.to, + }, + }, + fn: (context, args) => { + return { + type: 'timerange', + ...args, + }; + }, + }; +} diff --git a/x-pack/legacy/plugins/canvas/canvas_plugin_src/renderers/embeddable.tsx b/x-pack/legacy/plugins/canvas/canvas_plugin_src/renderers/embeddable/embeddable.tsx similarity index 74% rename from x-pack/legacy/plugins/canvas/canvas_plugin_src/renderers/embeddable.tsx rename to x-pack/legacy/plugins/canvas/canvas_plugin_src/renderers/embeddable/embeddable.tsx index 5c7ef1a8c1799..8642ebd901bb4 100644 --- a/x-pack/legacy/plugins/canvas/canvas_plugin_src/renderers/embeddable.tsx +++ b/x-pack/legacy/plugins/canvas/canvas_plugin_src/renderers/embeddable/embeddable.tsx @@ -10,32 +10,27 @@ import { I18nContext } from 'ui/i18n'; import { npStart } from 'ui/new_platform'; import { IEmbeddable, + EmbeddableFactory, EmbeddablePanel, EmbeddableFactoryNotFoundError, - EmbeddableInput, -} from '../../../../../../src/legacy/core_plugins/embeddable_api/public/np_ready/public'; -import { start } from '../../../../../../src/legacy/core_plugins/embeddable_api/public/np_ready/public/legacy'; -import { EmbeddableExpression } from '../expression_types/embeddable'; -import { RendererStrings } from '../../i18n'; +} from '../../../../../../../src/plugins/embeddable/public'; +import { start } from '../../../../../../../src/legacy/core_plugins/embeddable_api/public/np_ready/public/legacy'; +import { EmbeddableExpression } from '../../expression_types/embeddable'; +import { RendererStrings } from '../../../i18n'; import { SavedObjectFinderProps, SavedObjectFinderUi, -} from '../../../../../../src/plugins/kibana_react/public'; +} from '../../../../../../../src/plugins/kibana_react/public'; const { embeddable: strings } = RendererStrings; +import { embeddableInputToExpression } from './embeddable_input_to_expression'; +import { EmbeddableInput } from '../../expression_types'; +import { RendererHandlers } from '../../../types'; const embeddablesRegistry: { [key: string]: IEmbeddable; } = {}; -interface Handlers { - setFilter: (text: string) => void; - getFilter: () => string | null; - done: () => void; - onResize: (fn: () => void) => void; - onDestroy: (fn: () => void) => void; -} - const renderEmbeddable = (embeddableObject: IEmbeddable, domNode: HTMLElement) => { const SavedObjectFinder = (props: SavedObjectFinderProps) => ( ({ render: async ( domNode: HTMLElement, { input, embeddableType }: EmbeddableExpression, - handlers: Handlers + handlers: RendererHandlers ) => { if (!embeddablesRegistry[input.id]) { const factory = Array.from(start.getEmbeddableFactories()).find( embeddableFactory => embeddableFactory.type === embeddableType - ); + ) as EmbeddableFactory; if (!factory) { handlers.done(); @@ -86,8 +81,13 @@ const embeddable = () => ({ } const embeddableObject = await factory.createFromSavedObject(input.id, input); + embeddablesRegistry[input.id] = embeddableObject; + ReactDOM.unmountComponentAtNode(domNode); + const subscription = embeddableObject.getInput$().subscribe(function(updatedInput) { + handlers.onEmbeddableInputChange(embeddableInputToExpression(updatedInput, embeddableType)); + }); ReactDOM.render(renderEmbeddable(embeddableObject, domNode), domNode, () => handlers.done()); handlers.onResize(() => { @@ -97,7 +97,11 @@ const embeddable = () => ({ }); handlers.onDestroy(() => { + subscription.unsubscribe(); + handlers.onEmbeddableDestroyed(); + delete embeddablesRegistry[input.id]; + return ReactDOM.unmountComponentAtNode(domNode); }); } else { diff --git a/x-pack/legacy/plugins/canvas/canvas_plugin_src/renderers/embeddable/embeddable_input_to_expression.test.ts b/x-pack/legacy/plugins/canvas/canvas_plugin_src/renderers/embeddable/embeddable_input_to_expression.test.ts new file mode 100644 index 0000000000000..93d747537c34c --- /dev/null +++ b/x-pack/legacy/plugins/canvas/canvas_plugin_src/renderers/embeddable/embeddable_input_to_expression.test.ts @@ -0,0 +1,75 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { embeddableInputToExpression } from './embeddable_input_to_expression'; +import { SavedMapInput } from '../../functions/common/saved_map'; +import { EmbeddableTypes } from '../../expression_types'; +import { fromExpression, Ast } from '@kbn/interpreter/common'; + +const baseSavedMapInput = { + id: 'embeddableId', + filters: [], + isLayerTOCOpen: false, + refreshConfig: { + isPaused: true, + interval: 0, + }, + hideFilterActions: true as true, +}; + +describe('input to expression', () => { + describe('Map Embeddable', () => { + it('converts to a savedMap expression', () => { + const input: SavedMapInput = { + ...baseSavedMapInput, + }; + + const expression = embeddableInputToExpression(input, EmbeddableTypes.map); + const ast = fromExpression(expression); + + expect(ast.type).toBe('expression'); + expect(ast.chain[0].function).toBe('savedMap'); + + expect(ast.chain[0].arguments.id).toStrictEqual([input.id]); + + expect(ast.chain[0].arguments).not.toHaveProperty('title'); + expect(ast.chain[0].arguments).not.toHaveProperty('center'); + expect(ast.chain[0].arguments).not.toHaveProperty('timerange'); + }); + + it('includes optional input values', () => { + const input: SavedMapInput = { + ...baseSavedMapInput, + mapCenter: { + lat: 1, + lon: 2, + zoom: 3, + }, + title: 'title', + timeRange: { + from: 'now-1h', + to: 'now', + }, + }; + + const expression = embeddableInputToExpression(input, EmbeddableTypes.map); + const ast = fromExpression(expression); + + const centerExpression = ast.chain[0].arguments.center[0] as Ast; + + expect(centerExpression.chain[0].function).toBe('mapCenter'); + expect(centerExpression.chain[0].arguments.lat[0]).toEqual(input.mapCenter?.lat); + expect(centerExpression.chain[0].arguments.lon[0]).toEqual(input.mapCenter?.lon); + expect(centerExpression.chain[0].arguments.zoom[0]).toEqual(input.mapCenter?.zoom); + + const timerangeExpression = ast.chain[0].arguments.timerange[0] as Ast; + + expect(timerangeExpression.chain[0].function).toBe('timerange'); + expect(timerangeExpression.chain[0].arguments.from[0]).toEqual(input.timeRange?.from); + expect(timerangeExpression.chain[0].arguments.to[0]).toEqual(input.timeRange?.to); + }); + }); +}); diff --git a/x-pack/legacy/plugins/canvas/canvas_plugin_src/renderers/embeddable/embeddable_input_to_expression.ts b/x-pack/legacy/plugins/canvas/canvas_plugin_src/renderers/embeddable/embeddable_input_to_expression.ts new file mode 100644 index 0000000000000..a3cb53acebed2 --- /dev/null +++ b/x-pack/legacy/plugins/canvas/canvas_plugin_src/renderers/embeddable/embeddable_input_to_expression.ts @@ -0,0 +1,50 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { EmbeddableTypes, EmbeddableInput } from '../../expression_types'; +import { SavedMapInput } from '../../functions/common/saved_map'; + +/* + Take the input from an embeddable and the type of embeddable and convert it into an expression +*/ +export function embeddableInputToExpression( + input: EmbeddableInput, + embeddableType: string +): string { + const expressionParts: string[] = []; + + if (embeddableType === EmbeddableTypes.map) { + const mapInput = input as SavedMapInput; + + expressionParts.push('savedMap'); + + expressionParts.push(`id="${input.id}"`); + + if (input.title) { + expressionParts.push(`title="${input.title}"`); + } + + if (mapInput.mapCenter) { + expressionParts.push( + `center={mapCenter lat=${mapInput.mapCenter.lat} lon=${mapInput.mapCenter.lon} zoom=${mapInput.mapCenter.zoom}}` + ); + } + + if (mapInput.timeRange) { + expressionParts.push( + `timerange={timerange from="${mapInput.timeRange.from}" to="${mapInput.timeRange.to}"}` + ); + } + + if (mapInput.hiddenLayers && mapInput.hiddenLayers.length) { + for (const layerId of mapInput.hiddenLayers) { + expressionParts.push(`hideLayer="${layerId}"`); + } + } + } + + return expressionParts.join(' '); +} diff --git a/x-pack/legacy/plugins/canvas/canvas_plugin_src/renderers/index.js b/x-pack/legacy/plugins/canvas/canvas_plugin_src/renderers/index.js index 50fa6943fc74a..48364be06e539 100644 --- a/x-pack/legacy/plugins/canvas/canvas_plugin_src/renderers/index.js +++ b/x-pack/legacy/plugins/canvas/canvas_plugin_src/renderers/index.js @@ -7,7 +7,7 @@ import { advancedFilter } from './advanced_filter'; import { debug } from './debug'; import { dropdownFilter } from './dropdown_filter'; -import { embeddable } from './embeddable'; +import { embeddable } from './embeddable/embeddable'; import { error } from './error'; import { image } from './image'; import { markdown } from './markdown'; diff --git a/x-pack/legacy/plugins/canvas/i18n/functions/dict/map_center.ts b/x-pack/legacy/plugins/canvas/i18n/functions/dict/map_center.ts new file mode 100644 index 0000000000000..3022ad07089d2 --- /dev/null +++ b/x-pack/legacy/plugins/canvas/i18n/functions/dict/map_center.ts @@ -0,0 +1,27 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { i18n } from '@kbn/i18n'; +import { mapCenter } from '../../../canvas_plugin_src/functions/common/map_center'; +import { FunctionHelp } from '../'; +import { FunctionFactory } from '../../../types'; + +export const help: FunctionHelp> = { + help: i18n.translate('xpack.canvas.functions.mapCenterHelpText', { + defaultMessage: `Returns an object with the center coordinates and zoom level of the map`, + }), + args: { + lat: i18n.translate('xpack.canvas.functions.mapCenter.args.latHelpText', { + defaultMessage: `Latitude for the center of the map`, + }), + lon: i18n.translate('xpack.canvas.functions.savedMap.args.lonHelpText', { + defaultMessage: `Longitude for the center of the map`, + }), + zoom: i18n.translate('xpack.canvas.functions.savedMap.args.zoomHelpText', { + defaultMessage: `The zoom level of the map`, + }), + }, +}; diff --git a/x-pack/legacy/plugins/canvas/i18n/functions/dict/saved_map.ts b/x-pack/legacy/plugins/canvas/i18n/functions/dict/saved_map.ts index d01b77e1cfd51..53bcd481f185f 100644 --- a/x-pack/legacy/plugins/canvas/i18n/functions/dict/saved_map.ts +++ b/x-pack/legacy/plugins/canvas/i18n/functions/dict/saved_map.ts @@ -14,6 +14,20 @@ export const help: FunctionHelp> = { defaultMessage: `Returns an embeddable for a saved map object`, }), args: { - id: 'The id of the saved map object', + id: i18n.translate('xpack.canvas.functions.savedMap.args.idHelpText', { + defaultMessage: `The ID of the Saved Map Object`, + }), + center: i18n.translate('xpack.canvas.functions.savedMap.args.centerHelpText', { + defaultMessage: `The center and zoom level the map should have`, + }), + hideLayer: i18n.translate('xpack.canvas.functions.savedMap.args.hideLayer', { + defaultMessage: `The IDs of map layers that should be hidden`, + }), + timerange: i18n.translate('xpack.canvas.functions.savedMap.args.timerangeHelpText', { + defaultMessage: `The timerange of data that should be included`, + }), + title: i18n.translate('xpack.canvas.functions.savedMap.args.titleHelpText', { + defaultMessage: `The title for the map`, + }), }, }; diff --git a/x-pack/legacy/plugins/canvas/i18n/functions/dict/time_range.ts b/x-pack/legacy/plugins/canvas/i18n/functions/dict/time_range.ts new file mode 100644 index 0000000000000..476a9978800df --- /dev/null +++ b/x-pack/legacy/plugins/canvas/i18n/functions/dict/time_range.ts @@ -0,0 +1,24 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { i18n } from '@kbn/i18n'; +import { timerange } from '../../../canvas_plugin_src/functions/common/time_range'; +import { FunctionHelp } from '../function_help'; +import { FunctionFactory } from '../../../types'; + +export const help: FunctionHelp> = { + help: i18n.translate('xpack.canvas.functions.timerangeHelpText', { + defaultMessage: `An object that represents a span of time`, + }), + args: { + from: i18n.translate('xpack.canvas.functions.timerange.args.fromHelpText', { + defaultMessage: `The start of the time range`, + }), + to: i18n.translate('xpack.canvas.functions.timerange.args.toHelpText', { + defaultMessage: `The end of the time range`, + }), + }, +}; diff --git a/x-pack/legacy/plugins/canvas/i18n/functions/function_help.ts b/x-pack/legacy/plugins/canvas/i18n/functions/function_help.ts index f6b3c451c6fbb..94d7e6f43326f 100644 --- a/x-pack/legacy/plugins/canvas/i18n/functions/function_help.ts +++ b/x-pack/legacy/plugins/canvas/i18n/functions/function_help.ts @@ -44,6 +44,7 @@ import { help as joinRows } from './dict/join_rows'; import { help as location } from './dict/location'; import { help as lt } from './dict/lt'; import { help as lte } from './dict/lte'; +import { help as mapCenter } from './dict/map_center'; import { help as mapColumn } from './dict/map_column'; import { help as markdown } from './dict/markdown'; import { help as math } from './dict/math'; @@ -75,6 +76,7 @@ import { help as tail } from './dict/tail'; import { help as timefilter } from './dict/timefilter'; import { help as timefilterControl } from './dict/timefilter_control'; import { help as timelion } from './dict/timelion'; +import { help as timerange } from './dict/time_range'; import { help as to } from './dict/to'; import { help as urlparam } from './dict/urlparam'; @@ -196,6 +198,7 @@ export const getFunctionHelp = (): FunctionHelpDict => ({ location, lt, lte, + mapCenter, mapColumn, markdown, math, @@ -227,6 +230,7 @@ export const getFunctionHelp = (): FunctionHelpDict => ({ timefilter, timefilterControl, timelion, + timerange, to, urlparam, }); diff --git a/x-pack/legacy/plugins/canvas/public/components/element_content/element_content.js b/x-pack/legacy/plugins/canvas/public/components/element_content/element_content.js index 89c0b5b21c581..1926fb4aaa5eb 100644 --- a/x-pack/legacy/plugins/canvas/public/components/element_content/element_content.js +++ b/x-pack/legacy/plugins/canvas/public/components/element_content/element_content.js @@ -47,7 +47,14 @@ export const ElementContent = compose( pure, ...branches )(({ renderable, renderFunction, size, handlers }) => { - const { getFilter, setFilter, done, onComplete } = handlers; + const { + getFilter, + setFilter, + done, + onComplete, + onEmbeddableInputChange, + onEmbeddableDestroyed, + } = handlers; return Style.it( renderable.css, @@ -69,7 +76,7 @@ export const ElementContent = compose( config={renderable.value} css={renderable.css} // This is an actual CSS stylesheet string, it will be scoped by RenderElement size={size} // Size is only passed for the purpose of triggering the resize event, it isn't really used otherwise - handlers={{ getFilter, setFilter, done }} + handlers={{ getFilter, setFilter, done, onEmbeddableInputChange, onEmbeddableDestroyed }} />
diff --git a/x-pack/legacy/plugins/canvas/public/components/element_wrapper/lib/handlers.js b/x-pack/legacy/plugins/canvas/public/components/element_wrapper/lib/handlers.js index ce6791f2f88b6..e93cea597901f 100644 --- a/x-pack/legacy/plugins/canvas/public/components/element_wrapper/lib/handlers.js +++ b/x-pack/legacy/plugins/canvas/public/components/element_wrapper/lib/handlers.js @@ -6,6 +6,10 @@ import { isEqual } from 'lodash'; import { setFilter } from '../../../state/actions/elements'; +import { + updateEmbeddableExpression, + fetchEmbeddableRenderable, +} from '../../../state/actions/embeddable'; export const createHandlers = dispatch => { let isComplete = false; @@ -32,6 +36,14 @@ export const createHandlers = dispatch => { completeFn = fn; }, + onEmbeddableInputChange(embeddableExpression) { + dispatch(updateEmbeddableExpression({ elementId: element.id, embeddableExpression })); + }, + + onEmbeddableDestroyed() { + dispatch(fetchEmbeddableRenderable(element.id)); + }, + done() { // don't emit if the element is already done if (isComplete) { diff --git a/x-pack/legacy/plugins/canvas/public/components/embeddable_flyout/index.tsx b/x-pack/legacy/plugins/canvas/public/components/embeddable_flyout/index.tsx index c54c56e1561ca..565ca5fa5bbd6 100644 --- a/x-pack/legacy/plugins/canvas/public/components/embeddable_flyout/index.tsx +++ b/x-pack/legacy/plugins/canvas/public/components/embeddable_flyout/index.tsx @@ -19,14 +19,15 @@ import { withKibana } from '../../../../../../../src/plugins/kibana_react/public const allowedEmbeddables = { [EmbeddableTypes.map]: (id: string) => { - return `filters | savedMap id="${id}" | render`; + return `savedMap id="${id}" | render`; }, - [EmbeddableTypes.visualization]: (id: string) => { + // FIX: Only currently allow Map embeddables + /* [EmbeddableTypes.visualization]: (id: string) => { return `filters | savedVisualization id="${id}" | render`; }, [EmbeddableTypes.search]: (id: string) => { return `filters | savedSearch id="${id}" | render`; - }, + },*/ }; interface StateProps { diff --git a/x-pack/legacy/plugins/canvas/public/components/workpad_page/workpad_interactive_page/index.js b/x-pack/legacy/plugins/canvas/public/components/workpad_page/workpad_interactive_page/index.js index 4ee3a65172a2e..b775524acf639 100644 --- a/x-pack/legacy/plugins/canvas/public/components/workpad_page/workpad_interactive_page/index.js +++ b/x-pack/legacy/plugins/canvas/public/components/workpad_page/workpad_interactive_page/index.js @@ -73,6 +73,32 @@ function closest(s) { return null; } +// If you interact with an embeddable panel, only the header should be draggable +// This function will determine if an element is an embeddable body or not +const isEmbeddableBody = element => { + const hasClosest = typeof element.closest === 'function'; + + if (hasClosest) { + return element.closest('.embeddable') && !element.closest('.embPanel__header'); + } else { + return closest.call(element, '.embeddable') && !closest.call(element, '.embPanel__header'); + } +}; + +// Some elements in an embeddable may be portaled out of the embeddable container. +// We do not want clicks on those to trigger drags, etc, in the workpad. This function +// will check to make sure the clicked item is actually in the container +const isInWorkpad = element => { + const hasClosest = typeof element.closest === 'function'; + const workpadContainerSelector = '.canvasWorkpadContainer'; + + if (hasClosest) { + return !!element.closest(workpadContainerSelector); + } else { + return !!closest.call(element, workpadContainerSelector); + } +}; + const componentLayoutState = ({ aeroStore, setAeroStore, @@ -209,6 +235,8 @@ export const InteractivePage = compose( withProps((...props) => ({ ...props, canDragElement: element => { + return !isEmbeddableBody(element) && isInWorkpad(element); + const hasClosest = typeof element.closest === 'function'; if (hasClosest) { diff --git a/x-pack/legacy/plugins/canvas/public/state/actions/embeddable.ts b/x-pack/legacy/plugins/canvas/public/state/actions/embeddable.ts new file mode 100644 index 0000000000000..3604d7e3c2141 --- /dev/null +++ b/x-pack/legacy/plugins/canvas/public/state/actions/embeddable.ts @@ -0,0 +1,36 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { Dispatch } from 'redux'; +import { createAction } from 'redux-actions'; +// @ts-ignore Untyped +import { createThunk } from 'redux-thunks'; +// @ts-ignore Untyped Local +import { fetchRenderable } from './elements'; +import { State } from '../../../types'; + +export const UpdateEmbeddableExpressionActionType = 'updateEmbeddableExpression'; +export interface UpdateEmbeddableExpressionPayload { + embeddableExpression: string; + elementId: string; +} +export const updateEmbeddableExpression = createAction( + UpdateEmbeddableExpressionActionType +); + +export const fetchEmbeddableRenderable = createThunk( + 'fetchEmbeddableRenderable', + ({ dispatch, getState }: { dispatch: Dispatch; getState: () => State }, elementId: string) => { + const pageWithElement = getState().persistent.workpad.pages.find(page => { + return page.elements.find(element => element.id === elementId) !== undefined; + }); + + if (pageWithElement) { + const element = pageWithElement.elements.find(el => el.id === elementId); + dispatch(fetchRenderable(element)); + } + } +); diff --git a/x-pack/legacy/plugins/canvas/public/state/reducers/elements.js b/x-pack/legacy/plugins/canvas/public/state/reducers/elements.js index 10a5bdb5998ea..c7e8a5c2ff2d8 100644 --- a/x-pack/legacy/plugins/canvas/public/state/reducers/elements.js +++ b/x-pack/legacy/plugins/canvas/public/state/reducers/elements.js @@ -28,7 +28,7 @@ function getNodeIndexById(page, nodeId, location) { return page[location].findIndex(node => node.id === nodeId); } -function assignNodeProperties(workpadState, pageId, nodeId, props) { +export function assignNodeProperties(workpadState, pageId, nodeId, props) { const pageIndex = getPageIndexById(workpadState, pageId); const location = getLocationFromIds(workpadState, pageId, nodeId); const nodesPath = `pages.${pageIndex}.${location}`; diff --git a/x-pack/legacy/plugins/canvas/public/state/reducers/embeddable.ts b/x-pack/legacy/plugins/canvas/public/state/reducers/embeddable.ts new file mode 100644 index 0000000000000..9969c38cfa767 --- /dev/null +++ b/x-pack/legacy/plugins/canvas/public/state/reducers/embeddable.ts @@ -0,0 +1,67 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { fromExpression, toExpression } from '@kbn/interpreter/common'; +import { handleActions } from 'redux-actions'; +import { State } from '../../../types'; + +import { + UpdateEmbeddableExpressionActionType, + UpdateEmbeddableExpressionPayload, +} from '../actions/embeddable'; + +// @ts-ignore untyped local +import { assignNodeProperties } from './elements'; + +export const embeddableReducer = handleActions< + State['persistent']['workpad'], + UpdateEmbeddableExpressionPayload +>( + { + [UpdateEmbeddableExpressionActionType]: (workpadState, { payload }) => { + if (!payload) { + return workpadState; + } + + const { elementId, embeddableExpression } = payload; + + // Find the element + const pageWithElement = workpadState.pages.find(page => { + return page.elements.find(element => element.id === elementId) !== undefined; + }); + + if (!pageWithElement) { + return workpadState; + } + + const element = pageWithElement.elements.find(elem => elem.id === elementId); + + if (!element) { + return workpadState; + } + + const existingAst = fromExpression(element.expression); + const newAst = fromExpression(embeddableExpression); + const searchForFunction = newAst.chain[0].function; + + // Find the first matching function in the existing ASt + const existingAstFunction = existingAst.chain.find(f => f.function === searchForFunction); + + if (!existingAstFunction) { + return workpadState; + } + + existingAstFunction.arguments = newAst.chain[0].arguments; + + const updatedExpression = toExpression(existingAst); + + return assignNodeProperties(workpadState, pageWithElement.id, elementId, { + expression: updatedExpression, + }); + }, + }, + {} as State['persistent']['workpad'] +); diff --git a/x-pack/legacy/plugins/canvas/public/state/reducers/embeddables.test.ts b/x-pack/legacy/plugins/canvas/public/state/reducers/embeddables.test.ts new file mode 100644 index 0000000000000..5b1192630897a --- /dev/null +++ b/x-pack/legacy/plugins/canvas/public/state/reducers/embeddables.test.ts @@ -0,0 +1,41 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +jest.mock('ui/new_platform'); +import { State } from '../../../types'; +import { updateEmbeddableExpression } from '../actions/embeddable'; +import { embeddableReducer } from './embeddable'; + +const elementId = 'element-1111'; +const embeddableId = '1234'; +const mockWorkpadState = { + pages: [ + { + elements: [ + { + id: elementId, + expression: `function1 | function2 id="${embeddableId}" change="start value" remove="remove"`, + }, + ], + }, + ], +} as State['persistent']['workpad']; + +describe('embeddables reducer', () => { + it('updates the functions expression', () => { + const updatedValue = 'updated value'; + + const action = updateEmbeddableExpression({ + elementId, + embeddableExpression: `function2 id="${embeddableId}" change="${updatedValue}" add="add"`, + }); + + const newState = embeddableReducer(mockWorkpadState, action); + + expect(newState.pages[0].elements[0].expression.replace(/\s/g, '')).toBe( + `function1 | ${action.payload!.embeddableExpression}`.replace(/\s/g, '') + ); + }); +}); diff --git a/x-pack/legacy/plugins/canvas/public/state/reducers/index.js b/x-pack/legacy/plugins/canvas/public/state/reducers/index.js index b60a0a3b32656..cec6f9dceef6d 100644 --- a/x-pack/legacy/plugins/canvas/public/state/reducers/index.js +++ b/x-pack/legacy/plugins/canvas/public/state/reducers/index.js @@ -16,6 +16,7 @@ import { pagesReducer } from './pages'; import { elementsReducer } from './elements'; import { assetsReducer } from './assets'; import { historyReducer } from './history'; +import { embeddableReducer } from './embeddable'; export function getRootReducer(initialState) { return combineReducers({ @@ -25,7 +26,7 @@ export function getRootReducer(initialState) { persistent: reduceReducers( historyReducer, combineReducers({ - workpad: reduceReducers(workpadReducer, pagesReducer, elementsReducer), + workpad: reduceReducers(workpadReducer, pagesReducer, elementsReducer, embeddableReducer), schemaVersion: (state = get(initialState, 'persistent.schemaVersion')) => state, }) ), diff --git a/x-pack/legacy/plugins/canvas/server/lib/build_embeddable_filters.test.ts b/x-pack/legacy/plugins/canvas/server/lib/build_embeddable_filters.test.ts index d1632fc3eef28..b422a9451293f 100644 --- a/x-pack/legacy/plugins/canvas/server/lib/build_embeddable_filters.test.ts +++ b/x-pack/legacy/plugins/canvas/server/lib/build_embeddable_filters.test.ts @@ -23,10 +23,10 @@ const timeFilter: Filter = { }; describe('buildEmbeddableFilters', () => { - it('converts non time Canvas Filters to ES Filters ', () => { + it('converts all Canvas Filters to ES Filters ', () => { const filters = buildEmbeddableFilters([timeFilter, columnFilter, columnFilter]); - expect(filters.filters).toHaveLength(2); + expect(filters.filters).toHaveLength(3); }); it('converts time filter to time range', () => { diff --git a/x-pack/legacy/plugins/canvas/server/lib/build_embeddable_filters.ts b/x-pack/legacy/plugins/canvas/server/lib/build_embeddable_filters.ts index 52fcc9813a93d..1a78a1e057016 100644 --- a/x-pack/legacy/plugins/canvas/server/lib/build_embeddable_filters.ts +++ b/x-pack/legacy/plugins/canvas/server/lib/build_embeddable_filters.ts @@ -35,10 +35,8 @@ function getTimeRangeFromFilters(filters: Filter[]): TimeRange | undefined { : undefined; } -function getQueryFilters(filters: Filter[]): esFilters.Filter[] { - return buildBoolArray(filters.filter(filter => filter.type !== 'time')).map( - esFilters.buildQueryFilter - ); +export function getQueryFilters(filters: Filter[]): esFilters.Filter[] { + return buildBoolArray(filters).map(esFilters.buildQueryFilter); } export function buildEmbeddableFilters(filters: Filter[]): EmbeddableFilterInput { diff --git a/x-pack/legacy/plugins/canvas/shareable_runtime/components/rendered_element.tsx b/x-pack/legacy/plugins/canvas/shareable_runtime/components/rendered_element.tsx index 03b3e0df8a0cf..317a3417841b8 100644 --- a/x-pack/legacy/plugins/canvas/shareable_runtime/components/rendered_element.tsx +++ b/x-pack/legacy/plugins/canvas/shareable_runtime/components/rendered_element.tsx @@ -69,6 +69,8 @@ export class RenderedElementComponent extends PureComponent { onResize: () => {}, setFilter: () => {}, getFilter: () => '', + onEmbeddableInputChange: () => {}, + onEmbeddableDestroyed: () => {}, }); } catch (e) { // eslint-disable-next-line no-console diff --git a/x-pack/legacy/plugins/canvas/types/functions.ts b/x-pack/legacy/plugins/canvas/types/functions.ts index 6510c018f1ed4..773c9c3020a85 100644 --- a/x-pack/legacy/plugins/canvas/types/functions.ts +++ b/x-pack/legacy/plugins/canvas/types/functions.ts @@ -192,3 +192,16 @@ export interface AxisConfig { */ export const isAxisConfig = (axisConfig: any): axisConfig is AxisConfig => !!axisConfig && axisConfig.type === 'axisConfig'; + +export interface MapCenter { + type: 'mapCenter'; + lat: number; + lon: number; + zoom: number; +} + +export interface TimeRange { + type: 'timerange'; + from: string; + to: string; +} diff --git a/x-pack/legacy/plugins/canvas/types/renderers.ts b/x-pack/legacy/plugins/canvas/types/renderers.ts index 282a1c820e346..af1710e69c257 100644 --- a/x-pack/legacy/plugins/canvas/types/renderers.ts +++ b/x-pack/legacy/plugins/canvas/types/renderers.ts @@ -17,6 +17,10 @@ export interface RendererHandlers { getFilter: () => string; /** Sets the value of the filter property on the element object persisted on the workpad */ setFilter: (filter: string) => void; + /** Handler to invoke when the input to a function has changed internally */ + onEmbeddableInputChange: (expression: string) => void; + /** Handler to invoke when a rendered embeddable is destroyed */ + onEmbeddableDestroyed: () => void; } export interface RendererSpec { diff --git a/x-pack/plugins/advanced_ui_actions/public/customize_time_range_modal.tsx b/x-pack/plugins/advanced_ui_actions/public/customize_time_range_modal.tsx index 90393f9f4ff6f..9880a2b811f8b 100644 --- a/x-pack/plugins/advanced_ui_actions/public/customize_time_range_modal.tsx +++ b/x-pack/plugins/advanced_ui_actions/public/customize_time_range_modal.tsx @@ -137,7 +137,7 @@ export class CustomizeTimeRangeModal extends Component {i18n.translate( From 51d96e52ec09acac9ed580bef84af6bfe3c4eed9 Mon Sep 17 00:00:00 2001 From: Brian Seeders Date: Mon, 13 Jan 2020 15:54:58 -0500 Subject: [PATCH 055/139] Skip flaky test --- .../security_and_spaces/tests/alerting/alerts.ts | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/x-pack/test/alerting_api_integration/security_and_spaces/tests/alerting/alerts.ts b/x-pack/test/alerting_api_integration/security_and_spaces/tests/alerting/alerts.ts index 551498e22d5c8..d20450f8ec47e 100644 --- a/x-pack/test/alerting_api_integration/security_and_spaces/tests/alerting/alerts.ts +++ b/x-pack/test/alerting_api_integration/security_and_spaces/tests/alerting/alerts.ts @@ -761,7 +761,8 @@ export default function alertTests({ getService }: FtrProviderContext) { } }); - it(`should unmute all instances when unmuting an alert`, async () => { + // Flaky: https://github.com/elastic/kibana/issues/54125 + it.skip(`should unmute all instances when unmuting an alert`, async () => { const testStart = new Date(); const reference = alertUtils.generateReference(); const response = await alertUtils.createAlwaysFiringAction({ From e9319360e21ed6d85e00b2f99c2764e9e228a0f2 Mon Sep 17 00:00:00 2001 From: patrykkopycinski Date: Mon, 13 Jan 2020 21:59:45 +0100 Subject: [PATCH 056/139] [SIEM] Detection Engine Create Rule Design Review #1 (#54442) --- .../detection_engine/rules/all/columns.tsx | 19 +- .../rules/components/add_item_form/index.tsx | 23 +- .../assets/list_tree_icon.svg | 1 + .../components/description_step/helpers.tsx | 147 +++++++----- .../components/description_step/index.tsx | 48 ++-- .../rules/components/mitre/index.tsx | 16 +- .../components/optional_field_label/index.tsx | 16 ++ .../rules/components/query_bar/index.tsx | 2 +- .../components/schedule_item_form/index.tsx | 42 +++- .../rules/components/severity_badge/index.tsx | 32 +++ .../rules/components/step_about_rule/data.tsx | 17 +- .../components/step_about_rule/index.tsx | 150 ++++++------ .../components/step_about_rule/schema.tsx | 14 +- .../components/step_content_wrapper/index.tsx | 18 ++ .../components/step_define_rule/index.tsx | 227 ++++++++++-------- .../components/step_schedule_rule/index.tsx | 186 +++++++------- .../components/step_schedule_rule/schema.tsx | 6 +- .../detection_engine/rules/create/index.tsx | 47 ++-- .../detection_engine/rules/details/index.tsx | 2 +- .../pages/detection_engine/rules/types.ts | 1 + 20 files changed, 588 insertions(+), 426 deletions(-) create mode 100644 x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/description_step/assets/list_tree_icon.svg create mode 100644 x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/optional_field_label/index.tsx create mode 100644 x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/severity_badge/index.tsx create mode 100644 x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_content_wrapper/index.tsx diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/columns.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/columns.tsx index 95b9c9324894f..636cbb8ecb064 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/columns.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/columns.tsx @@ -8,7 +8,6 @@ import { EuiBadge, - EuiHealth, EuiIconTip, EuiLink, EuiTextColor, @@ -17,7 +16,6 @@ import { } from '@elastic/eui'; import * as H from 'history'; import React from 'react'; -import euiLightVars from '@elastic/eui/dist/eui_theme_light.json'; import { getEmptyTagValue } from '../../../../components/empty_value'; import { deleteRulesAction, @@ -32,6 +30,7 @@ import { TableData } from '../types'; import * as i18n from '../translations'; import { PreferenceFormattedDate } from '../../../../components/formatted_date'; import { RuleSwitch } from '../components/rule_switch'; +import { SeverityBadge } from '../components/severity_badge'; const getActions = (dispatch: React.Dispatch, history: H.History) => [ { @@ -92,21 +91,7 @@ export const getColumns = ( { field: 'severity', name: i18n.COLUMN_SEVERITY, - render: (value: TableData['severity']) => ( - - {value} - - ), + render: (value: TableData['severity']) => , truncateText: true, }, { diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/add_item_form/index.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/add_item_form/index.tsx index b3cc81b5cdfcf..0c75da7d8a632 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/add_item_form/index.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/add_item_form/index.tsx @@ -37,6 +37,25 @@ const MyEuiFormRow = styled(EuiFormRow)` } `; +export const MyAddItemButton = styled(EuiButtonEmpty)` + margin-top: 4px; + + &.euiButtonEmpty--xSmall { + font-size: 12px; + } + + .euiIcon { + width: 12px; + height: 12px; + } +`; + +MyAddItemButton.defaultProps = { + flush: 'left', + iconType: 'plusInCircle', + size: 'xs', +}; + export const AddItem = ({ addText, dataTestSubj, @@ -160,9 +179,9 @@ export const AddItem = ({ ); })} - + {addText} - + ); diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/description_step/assets/list_tree_icon.svg b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/description_step/assets/list_tree_icon.svg new file mode 100644 index 0000000000000..527d8d445bc03 --- /dev/null +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/description_step/assets/list_tree_icon.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/description_step/helpers.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/description_step/helpers.tsx index 09d0c1131ea10..e8b6919165c8b 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/description_step/helpers.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/description_step/helpers.tsx @@ -9,12 +9,10 @@ import { EuiLoadingSpinner, EuiFlexGroup, EuiFlexItem, - EuiHealth, EuiLink, - EuiText, - EuiListGroup, + EuiButtonEmpty, + EuiSpacer, } from '@elastic/eui'; -import euiLightVars from '@elastic/eui/dist/eui_theme_light.json'; import { isEmpty } from 'lodash/fp'; import React from 'react'; @@ -27,6 +25,11 @@ import { tacticsOptions, techniquesOptions } from '../../../mitre/mitre_tactics_ import { FilterLabel } from './filter_label'; import * as i18n from './translations'; import { BuildQueryBarDescription, BuildThreatsDescription, ListItems } from './types'; +import { SeverityBadge } from '../severity_badge'; +import ListTreeIcon from './assets/list_tree_icon.svg'; + +const isNotEmptyArray = (values: string[]) => + !isEmpty(values) && values.filter(val => !isEmpty(val)).length > 0; const EuiBadgeWrap = styled(EuiBadge)` .euiBadge__text { @@ -97,10 +100,17 @@ const ThreatsEuiFlexGroup = styled(EuiFlexGroup)` } `; -const MyEuiListGroup = styled(EuiListGroup)` - padding: 0px; - .euiListGroupItem__button { - padding: 0px; +const TechniqueLinkItem = styled(EuiButtonEmpty)` + .euiIcon { + width: 8px; + height: 8px; + } +`; + +const ReferenceLinkItem = styled(EuiButtonEmpty)` + .euiIcon { + width: 12px; + height: 12px; } `; @@ -118,28 +128,31 @@ export const buildThreatsDescription = ({ const tactic = tacticsOptions.find(t => t.name === threat.tactic.name); return ( - -
- - {tactic != null ? tactic.text : ''} - -
- { - const myTechnique = techniquesOptions.find(t => t.name === technique.name); - return { - label: myTechnique != null ? myTechnique.label : '', - href: technique.reference, - target: '_blank', - }; - })} - /> -
+ + {tactic != null ? tactic.text : ''} + + + {threat.techniques.map(technique => { + const myTechnique = techniquesOptions.find(t => t.name === technique.name); + return ( + + + {myTechnique != null ? myTechnique.label : ''} + + + ); + })} +
); })} + ), }, @@ -148,12 +161,34 @@ export const buildThreatsDescription = ({ return []; }; +export const buildUnorderedListArrayDescription = ( + label: string, + field: string, + values: string[] +): ListItems[] => { + if (isNotEmptyArray(values)) { + return [ + { + title: label, + description: ( +
    + {values.map((val: string) => + isEmpty(val) ? null :
  • {val}
  • + )} +
+ ), + }, + ]; + } + return []; +}; + export const buildStringArrayDescription = ( label: string, field: string, values: string[] ): ListItems[] => { - if (!isEmpty(values) && values.filter(val => !isEmpty(val)).length > 0) { + if (isNotEmptyArray(values)) { return [ { title: label, @@ -174,46 +209,34 @@ export const buildStringArrayDescription = ( return []; }; -export const buildSeverityDescription = (label: string, value: string): ListItems[] => { - return [ - { - title: label, - description: ( - - {value} - - ), - }, - ]; -}; +export const buildSeverityDescription = (label: string, value: string): ListItems[] => [ + { + title: label, + description: , + }, +]; export const buildUrlsDescription = (label: string, values: string[]): ListItems[] => { - if (!isEmpty(values) && values.filter(val => !isEmpty(val)).length > 0) { + if (isNotEmptyArray(values)) { return [ { title: label, description: ( - ({ - label: val, - href: val, - iconType: 'link', - size: 'xs', - target: '_blank', - }))} - /> + + {values.map((val: string) => ( + + + {val} + + + ))} + ), }, ]; diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/description_step/index.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/description_step/index.tsx index af4f93c0fdbcd..8cf1601e2c4b6 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/description_step/index.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/description_step/index.tsx @@ -4,10 +4,9 @@ * you may not use this file except in compliance with the Elastic License. */ -import { EuiDescriptionList, EuiFlexGroup, EuiFlexItem, EuiTextArea } from '@elastic/eui'; +import { EuiDescriptionList, EuiFlexGroup, EuiFlexItem } from '@elastic/eui'; import { isEmpty, chunk, get, pick } from 'lodash/fp'; import React, { memo, useState } from 'react'; -import styled from 'styled-components'; import { IIndexPattern, @@ -26,6 +25,7 @@ import { buildSeverityDescription, buildStringArrayDescription, buildThreatsDescription, + buildUnorderedListArrayDescription, buildUrlsDescription, } from './helpers'; @@ -36,15 +36,6 @@ interface StepRuleDescriptionProps { schema: FormSchema; } -const EuiFlexItemWidth = styled(EuiFlexItem)<{ direction: string }>` - ${props => (props.direction === 'row' ? 'width : 50%;' : 'width: 100%;')}; -`; - -const MyEuiTextArea = styled(EuiTextArea)` - max-width: 100%; - height: 80px; -`; - const StepRuleDescriptionComponent: React.FC = ({ data, direction = 'row', @@ -62,13 +53,24 @@ const StepRuleDescriptionComponent: React.FC = ({ ], [] ); + + if (direction === 'row') { + return ( + + {chunk(Math.ceil(listItems.length / 2), listItems).map((chunkListItems, index) => ( + + + + ))} + + ); + } + return ( - - {chunk(Math.ceil(listItems.length / 2), listItems).map((chunkListItems, index) => ( - - - - ))} + + + + ); }; @@ -123,18 +125,28 @@ const getDescriptionItem = ( return [ { title: label, - description: , + description: get(field, value), }, ]; } else if (field === 'references') { const urls: string[] = get(field, value); return buildUrlsDescription(label, urls); + } else if (field === 'falsePositives') { + const values: string[] = get(field, value); + return buildUnorderedListArrayDescription(label, field, values); } else if (Array.isArray(get(field, value))) { const values: string[] = get(field, value); return buildStringArrayDescription(label, field, values); } else if (field === 'severity') { const val: string = get(field, value); return buildSeverityDescription(label, val); + } else if (field === 'riskScore') { + return [ + { + title: label, + description: get(field, value), + }, + ]; } else if (field === 'timeline') { const timeline = get(field, value) as FieldValueTimeline; return [ diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/mitre/index.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/mitre/index.tsx index 2c19e99e90114..f9a22c37cfdf0 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/mitre/index.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/mitre/index.tsx @@ -5,7 +5,6 @@ */ import { - EuiButtonEmpty, EuiButtonIcon, EuiFormRow, EuiSuperSelect, @@ -24,6 +23,7 @@ import * as Rulei18n from '../../translations'; import { FieldHook, getFieldValidityAndErrorMessage } from '../shared_imports'; import { threatsDefault } from '../step_about_rule/default_value'; import { IMitreEnterpriseAttack } from '../../types'; +import { MyAddItemButton } from '../add_item_form'; import { isMitreAttackInvalid } from './helpers'; import * as i18n from './translations'; @@ -134,13 +134,19 @@ export const AddMitreThreat = ({ dataTestSubj, field, idAria, isDisabled }: AddI const getSelectTechniques = (item: IMitreEnterpriseAttack, index: number, disabled: boolean) => { const invalid = isMitreAttackInvalid(item.tactic.name, item.techniques); + const options = techniquesOptions.filter(t => t.tactics.includes(kebabCase(item.tactic.name))); + const selectedOptions = item.techniques.map(technic => ({ + ...technic, + label: `${technic.name} (${technic.id})`, // API doesn't allow for label field + })); + return ( t.tactics.includes(kebabCase(item.tactic.name)))} - selectedOptions={item.techniques} + options={options} + selectedOptions={selectedOptions} onChange={updateTechniques.bind(null, index)} isDisabled={disabled || item.tactic.name === 'none'} fullWidth={true} @@ -202,9 +208,9 @@ export const AddMitreThreat = ({ dataTestSubj, field, idAria, isDisabled }: AddI {values.length - 1 !== index && }
))} - + {i18n.ADD_MITRE_ATTACK} - + ); }; diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/optional_field_label/index.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/optional_field_label/index.tsx new file mode 100644 index 0000000000000..0dab87b0a3b74 --- /dev/null +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/optional_field_label/index.tsx @@ -0,0 +1,16 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { EuiText } from '@elastic/eui'; +import React from 'react'; + +import * as RuleI18n from '../../translations'; + +export const OptionalFieldLabel = ( + + {RuleI18n.OPTIONAL_FIELD} + +); diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/query_bar/index.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/query_bar/index.tsx index 3e39beb6e61b7..46a7a13ec03f1 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/query_bar/index.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/query_bar/index.tsx @@ -51,7 +51,7 @@ interface QueryBarDefineRuleProps { const StyledEuiFormRow = styled(EuiFormRow)` .kbnTypeahead__items { - max-height: 14vh !important; + max-height: 45vh !important; } .globalQueryBar { padding: 4px 0px 0px 0px; diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/schedule_item_form/index.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/schedule_item_form/index.tsx index 8097c27cddfe8..fa4bea319f859 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/schedule_item_form/index.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/schedule_item_form/index.tsx @@ -4,7 +4,14 @@ * you may not use this file except in compliance with the Elastic License. */ -import { EuiFlexGroup, EuiFlexItem, EuiFieldNumber, EuiFormRow, EuiSelect } from '@elastic/eui'; +import { + EuiFlexGroup, + EuiFlexItem, + EuiFieldNumber, + EuiFormRow, + EuiSelect, + EuiFormControlLayout, +} from '@elastic/eui'; import { isEmpty } from 'lodash/fp'; import React, { useCallback, useEffect, useMemo, useState } from 'react'; import styled from 'styled-components'; @@ -26,10 +33,28 @@ const timeTypeOptions = [ { value: 'h', text: I18n.HOURS }, ]; +// move optional label to the end of input +const StyledLabelAppend = styled(EuiFlexItem)` + &.euiFlexItem.euiFlexItem--flexGrowZero { + margin-left: 31px; + } +`; + const StyledEuiFormRow = styled(EuiFormRow)` + max-width: none; + .euiFormControlLayout { max-width: 200px !important; } + + .euiFormControlLayout__childrenWrapper > *:first-child { + box-shadow: none; + height: 38px; + } + + .euiFormControlLayout:not(:first-child) { + border-left: 1px solid ${({ theme }) => theme.eui.euiColorLightShade}; + } `; const MyEuiSelect = styled(EuiSelect)` @@ -89,9 +114,9 @@ export const ScheduleItem = ({ dataTestSubj, field, idAria, isDisabled }: Schedu {field.label} - + {field.labelAppend} - + ), [field.label, field.labelAppend] @@ -107,7 +132,7 @@ export const ScheduleItem = ({ dataTestSubj, field, idAria, isDisabled }: Schedu data-test-subj={dataTestSubj} describedByIds={idAria ? [idAria] : undefined} > - } - fullWidth - min={0} - onChange={onChangeTimeVal} - value={timeVal} - {...rest} - /> + > + + ); }; diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/severity_badge/index.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/severity_badge/index.tsx new file mode 100644 index 0000000000000..09c02dfca56f9 --- /dev/null +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/severity_badge/index.tsx @@ -0,0 +1,32 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { upperFirst } from 'lodash/fp'; +import React from 'react'; +import { EuiHealth } from '@elastic/eui'; +import euiLightVars from '@elastic/eui/dist/eui_theme_light.json'; + +interface Props { + value: string; +} + +const SeverityBadgeComponent: React.FC = ({ value }) => ( + + {upperFirst(value)} + +); + +export const SeverityBadge = React.memo(SeverityBadgeComponent); diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_about_rule/data.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_about_rule/data.tsx index 9fb64189ebd1a..269d2d4509508 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_about_rule/data.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_about_rule/data.tsx @@ -4,6 +4,7 @@ * you may not use this file except in compliance with the Elastic License. */ +import styled from 'styled-components'; import { EuiHealth } from '@elastic/eui'; import euiLightVars from '@elastic/eui/dist/eui_theme_light.json'; import React from 'react'; @@ -16,22 +17,30 @@ interface SeverityOptionItem { inputDisplay: React.ReactElement; } +const StyledEuiHealth = styled(EuiHealth)` + line-height: inherit; +`; + export const severityOptions: SeverityOptionItem[] = [ { value: 'low', - inputDisplay: {I18n.LOW}, + inputDisplay: {I18n.LOW}, }, { value: 'medium', - inputDisplay: {I18n.MEDIUM} , + inputDisplay: ( + {I18n.MEDIUM} + ), }, { value: 'high', - inputDisplay: {I18n.HIGH} , + inputDisplay: {I18n.HIGH}, }, { value: 'critical', - inputDisplay: {I18n.CRITICAL} , + inputDisplay: ( + {I18n.CRITICAL} + ), }, ]; diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_about_rule/index.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_about_rule/index.tsx index 8956776dcd3b2..0e03a11776fb7 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_about_rule/index.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_about_rule/index.tsx @@ -6,7 +6,7 @@ import { EuiButton, EuiHorizontalRule, EuiFlexGroup, EuiFlexItem } from '@elastic/eui'; import { isEqual, get } from 'lodash/fp'; -import React, { memo, useCallback, useEffect, useState } from 'react'; +import React, { FC, memo, useCallback, useEffect, useState } from 'react'; import styled from 'styled-components'; import { RuleStepProps, RuleStep, AboutStepRule } from '../../types'; @@ -22,6 +22,7 @@ import { isUrlInvalid } from './helpers'; import { schema } from './schema'; import * as I18n from './translations'; import { PickTimeline } from '../pick_timeline'; +import { StepContentWrapper } from '../step_content_wrapper'; const CommonUseField = getUseField({ component: Field }); @@ -33,64 +34,67 @@ const TagContainer = styled.div` margin-top: 16px; `; -export const StepAboutRule = memo( - ({ - defaultValues, - descriptionDirection = 'row', - isReadOnlyView, - isUpdateView = false, - isLoading, - setForm, - setStepData, - }) => { - const [myStepData, setMyStepData] = useState(stepAboutDefaultValue); +const StepAboutRuleComponent: FC = ({ + addPadding = false, + defaultValues, + descriptionDirection = 'row', + isReadOnlyView, + isUpdateView = false, + isLoading, + setForm, + setStepData, +}) => { + const [myStepData, setMyStepData] = useState(stepAboutDefaultValue); - const { form } = useForm({ - defaultValue: myStepData, - options: { stripEmptyFields: false }, - schema, - }); + const { form } = useForm({ + defaultValue: myStepData, + options: { stripEmptyFields: false }, + schema, + }); - const onSubmit = useCallback(async () => { - if (setStepData) { - setStepData(RuleStep.aboutRule, null, false); - const { isValid, data } = await form.submit(); - if (isValid) { - setStepData(RuleStep.aboutRule, data, isValid); - setMyStepData({ ...data, isNew: false } as AboutStepRule); - } + const onSubmit = useCallback(async () => { + if (setStepData) { + setStepData(RuleStep.aboutRule, null, false); + const { isValid, data } = await form.submit(); + if (isValid) { + setStepData(RuleStep.aboutRule, data, isValid); + setMyStepData({ ...data, isNew: false } as AboutStepRule); } - }, [form]); + } + }, [form]); - useEffect(() => { - const { isNew, ...initDefaultValue } = myStepData; - if (defaultValues != null && !isEqual(initDefaultValue, defaultValues)) { - const myDefaultValues = { - ...defaultValues, - isNew: false, - }; - setMyStepData(myDefaultValues); - if (!isReadOnlyView) { - Object.keys(schema).forEach(key => { - const val = get(key, myDefaultValues); - if (val != null) { - form.setFieldValue(key, val); - } - }); - } + useEffect(() => { + const { isNew, ...initDefaultValue } = myStepData; + if (defaultValues != null && !isEqual(initDefaultValue, defaultValues)) { + const myDefaultValues = { + ...defaultValues, + isNew: false, + }; + setMyStepData(myDefaultValues); + if (!isReadOnlyView) { + Object.keys(schema).forEach(key => { + const val = get(key, myDefaultValues); + if (val != null) { + form.setFieldValue(key, val); + } + }); } - }, [defaultValues]); + } + }, [defaultValues]); - useEffect(() => { - if (setForm != null) { - setForm(RuleStep.aboutRule, form); - } - }, [form]); + useEffect(() => { + if (setForm != null) { + setForm(RuleStep.aboutRule, form); + } + }, [form]); - return isReadOnlyView && myStepData != null ? ( + return isReadOnlyView && myStepData != null ? ( + - ) : ( - <> + + ) : ( + <> +
( }} - {!isUpdateView && ( - <> - - - - - {RuleI18n.CONTINUE} - - - - - )} - - ); - } -); +
+ {!isUpdateView && ( + <> + + + + + {RuleI18n.CONTINUE} + + + + + )} + + ); +}; + +export const StepAboutRule = memo(StepAboutRuleComponent); diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_about_rule/schema.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_about_rule/schema.tsx index 008a1b48610d6..3de0e7605f3d9 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_about_rule/schema.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_about_rule/schema.tsx @@ -4,11 +4,8 @@ * you may not use this file except in compliance with the Elastic License. */ -import { EuiText } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; -import React from 'react'; -import * as RuleI18n from '../../translations'; import { IMitreEnterpriseAttack } from '../../types'; import { FIELD_TYPES, @@ -18,6 +15,7 @@ import { ERROR_CODE, } from '../shared_imports'; import { isMitreAttackInvalid } from '../mitre/helpers'; +import { OptionalFieldLabel } from '../optional_field_label'; import { isUrlInvalid } from './helpers'; import * as I18n from './translations'; @@ -108,7 +106,7 @@ export const schema: FormSchema = { defaultMessage: 'Reference URLs', } ), - labelAppend: {RuleI18n.OPTIONAL_FIELD}, + labelAppend: OptionalFieldLabel, validations: [ { validator: ( @@ -136,10 +134,10 @@ export const schema: FormSchema = { label: i18n.translate( 'xpack.siem.detectionEngine.createRule.stepAboutRule.fieldFalsePositiveLabel', { - defaultMessage: 'False positives examples', + defaultMessage: 'False positive examples', } ), - labelAppend: {RuleI18n.OPTIONAL_FIELD}, + labelAppend: OptionalFieldLabel, }, threats: { label: i18n.translate( @@ -148,7 +146,7 @@ export const schema: FormSchema = { defaultMessage: 'MITRE ATT&CK\\u2122', } ), - labelAppend: {RuleI18n.OPTIONAL_FIELD}, + labelAppend: OptionalFieldLabel, validations: [ { validator: ( @@ -184,6 +182,6 @@ export const schema: FormSchema = { 'Type one or more custom identifying tags for this rule. Press enter after each tag to begin a new one.', } ), - labelAppend: {RuleI18n.OPTIONAL_FIELD}, + labelAppend: OptionalFieldLabel, }, }; diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_content_wrapper/index.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_content_wrapper/index.tsx new file mode 100644 index 0000000000000..b04a321dab05b --- /dev/null +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_content_wrapper/index.tsx @@ -0,0 +1,18 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React from 'react'; +import styled from 'styled-components'; + +const StyledDiv = styled.div<{ addPadding: boolean }>` + padding-left: ${({ addPadding }) => addPadding && '53px'}; /* to align with the step title */ +`; + +StyledDiv.defaultProps = { + addPadding: false, +}; + +export const StepContentWrapper = React.memo(StyledDiv); diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_define_rule/index.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_define_rule/index.tsx index ecd2ce442238f..6bdef4a69af1e 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_define_rule/index.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_define_rule/index.tsx @@ -12,7 +12,8 @@ import { EuiButton, } from '@elastic/eui'; import { isEmpty, isEqual, get } from 'lodash/fp'; -import React, { memo, useCallback, useState, useEffect } from 'react'; +import React, { FC, memo, useCallback, useState, useEffect } from 'react'; +import styled from 'styled-components'; import { IIndexPattern } from '../../../../../../../../../../src/plugins/data/public'; import { useFetchIndexPatterns } from '../../../../../containers/detection_engine/rules'; @@ -22,6 +23,7 @@ import * as RuleI18n from '../../translations'; import { DefineStepRule, RuleStep, RuleStepProps } from '../../types'; import { StepRuleDescription } from '../description_step'; import { QueryBarDefineRule } from '../query_bar'; +import { StepContentWrapper } from '../step_content_wrapper'; import { Field, Form, FormDataProvider, getUseField, UseField, useForm } from '../shared_imports'; import { schema } from './schema'; import * as i18n from './translations'; @@ -42,6 +44,20 @@ const stepDefineDefaultValue = { }, }; +const MyLabelButton = styled(EuiButtonEmpty)` + height: 18px; + font-size: 12px; + + .euiIcon { + width: 14px; + height: 14px; + } +`; + +MyLabelButton.defaultProps = { + flush: 'right', +}; + const getStepDefaultValue = ( indicesConfig: string[], defaultValues: DefineStepRule | null @@ -59,106 +75,104 @@ const getStepDefaultValue = ( } }; -export const StepDefineRule = memo( - ({ - defaultValues, - descriptionDirection = 'row', - isReadOnlyView, - isLoading, - isUpdateView = false, - resizeParentContainer, - setForm, - setStepData, - }) => { - const [openTimelineSearch, setOpenTimelineSearch] = useState(false); - const [localUseIndicesConfig, setLocalUseIndicesConfig] = useState(false); - const [indicesConfig] = useUiSetting$(DEFAULT_INDEX_KEY); - const [mylocalIndicesConfig, setMyLocalIndicesConfig] = useState( - defaultValues != null ? defaultValues.index : indicesConfig ?? [] - ); - const [ - { - browserFields, - indexPatterns: indexPatternQueryBar, - isLoading: indexPatternLoadingQueryBar, - }, - ] = useFetchIndexPatterns(mylocalIndicesConfig); - const [myStepData, setMyStepData] = useState( - getStepDefaultValue(indicesConfig, null) - ); - - const { form } = useForm({ - defaultValue: myStepData, - options: { stripEmptyFields: false }, - schema, - }); - - const onSubmit = useCallback(async () => { - if (setStepData) { - setStepData(RuleStep.defineRule, null, false); - const { isValid, data } = await form.submit(); - if (isValid && setStepData) { - setStepData(RuleStep.defineRule, data, isValid); - setMyStepData({ ...data, isNew: false } as DefineStepRule); - } +const StepDefineRuleComponent: FC = ({ + addPadding = false, + defaultValues, + descriptionDirection = 'row', + isReadOnlyView, + isLoading, + isUpdateView = false, + setForm, + setStepData, +}) => { + const [openTimelineSearch, setOpenTimelineSearch] = useState(false); + const [localUseIndicesConfig, setLocalUseIndicesConfig] = useState(false); + const [indicesConfig] = useUiSetting$(DEFAULT_INDEX_KEY); + const [mylocalIndicesConfig, setMyLocalIndicesConfig] = useState( + defaultValues != null ? defaultValues.index : indicesConfig ?? [] + ); + const [ + { browserFields, indexPatterns: indexPatternQueryBar, isLoading: indexPatternLoadingQueryBar }, + ] = useFetchIndexPatterns(mylocalIndicesConfig); + const [myStepData, setMyStepData] = useState( + getStepDefaultValue(indicesConfig, null) + ); + + const { form } = useForm({ + defaultValue: myStepData, + options: { stripEmptyFields: false }, + schema, + }); + + const onSubmit = useCallback(async () => { + if (setStepData) { + setStepData(RuleStep.defineRule, null, false); + const { isValid, data } = await form.submit(); + if (isValid && setStepData) { + setStepData(RuleStep.defineRule, data, isValid); + setMyStepData({ ...data, isNew: false } as DefineStepRule); } - }, [form]); - - useEffect(() => { - if (indicesConfig != null && defaultValues != null) { - const myDefaultValues = getStepDefaultValue(indicesConfig, defaultValues); - if (!isEqual(myDefaultValues, myStepData)) { - setMyStepData(myDefaultValues); - setLocalUseIndicesConfig(isEqual(myDefaultValues.index, indicesConfig)); - if (!isReadOnlyView) { - Object.keys(schema).forEach(key => { - const val = get(key, myDefaultValues); - if (val != null) { - form.setFieldValue(key, val); - } - }); - } + } + }, [form]); + + useEffect(() => { + if (indicesConfig != null && defaultValues != null) { + const myDefaultValues = getStepDefaultValue(indicesConfig, defaultValues); + if (!isEqual(myDefaultValues, myStepData)) { + setMyStepData(myDefaultValues); + setLocalUseIndicesConfig(isEqual(myDefaultValues.index, indicesConfig)); + if (!isReadOnlyView) { + Object.keys(schema).forEach(key => { + const val = get(key, myDefaultValues); + if (val != null) { + form.setFieldValue(key, val); + } + }); } } - }, [defaultValues, indicesConfig]); + } + }, [defaultValues, indicesConfig]); - useEffect(() => { - if (setForm != null) { - setForm(RuleStep.defineRule, form); - } - }, [form]); + useEffect(() => { + if (setForm != null) { + setForm(RuleStep.defineRule, form); + } + }, [form]); - const handleResetIndices = useCallback(() => { - const indexField = form.getFields().index; - indexField.setValue(indicesConfig); - }, [form, indicesConfig]); + const handleResetIndices = useCallback(() => { + const indexField = form.getFields().index; + indexField.setValue(indicesConfig); + }, [form, indicesConfig]); - const handleOpenTimelineSearch = useCallback(() => { - setOpenTimelineSearch(true); - }, []); + const handleOpenTimelineSearch = useCallback(() => { + setOpenTimelineSearch(true); + }, []); - const handleCloseTimelineSearch = useCallback(() => { - setOpenTimelineSearch(false); - }, []); + const handleCloseTimelineSearch = useCallback(() => { + setOpenTimelineSearch(false); + }, []); - return isReadOnlyView && myStepData != null ? ( + return isReadOnlyView && myStepData != null ? ( + - ) : ( - <> + + ) : ( + <> +
- {i18n.RESET_DEFAULT_INDEX} - + + {i18n.RESET_DEFAULT_INDEX} + ) : null, }} componentProps={{ @@ -176,9 +190,9 @@ export const StepDefineRule = memo( config={{ ...schema.queryBar, labelAppend: ( - - {i18n.IMPORT_TIMELINE_QUERY} - + + {i18n.IMPORT_TIMELINE_QUERY} + ), }} component={QueryBarDefineRule} @@ -192,7 +206,6 @@ export const StepDefineRule = memo( dataTestSubj: 'detectionEngineStepDefineRuleQueryBar', openTimelineSearch, onCloseTimelineSearch: handleCloseTimelineSearch, - resizeParentContainer, }} /> @@ -212,24 +225,26 @@ export const StepDefineRule = memo( }} - {!isUpdateView && ( - <> - - - - - {RuleI18n.CONTINUE} - - - - - )} - - ); - } -); +
+ {!isUpdateView && ( + <> + + + + + {RuleI18n.CONTINUE} + + + + + )} + + ); +}; + +export const StepDefineRule = memo(StepDefineRuleComponent); diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_schedule_rule/index.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_schedule_rule/index.tsx index 35b8ca6650bf6..b99201abe8777 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_schedule_rule/index.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_schedule_rule/index.tsx @@ -6,12 +6,13 @@ import { EuiHorizontalRule, EuiFlexGroup, EuiFlexItem, EuiButton } from '@elastic/eui'; import { isEqual, get } from 'lodash/fp'; -import React, { memo, useCallback, useEffect, useState } from 'react'; +import React, { FC, memo, useCallback, useEffect, useState } from 'react'; import { RuleStep, RuleStepProps, ScheduleStepRule } from '../../types'; import { StepRuleDescription } from '../description_step'; import { ScheduleItem } from '../schedule_item_form'; import { Form, UseField, useForm } from '../shared_imports'; +import { StepContentWrapper } from '../step_content_wrapper'; import { schema } from './schema'; import * as I18n from './translations'; @@ -26,67 +27,70 @@ const stepScheduleDefaultValue = { from: '0m', }; -export const StepScheduleRule = memo( - ({ - defaultValues, - descriptionDirection = 'row', - isReadOnlyView, - isLoading, - isUpdateView = false, - setStepData, - setForm, - }) => { - const [myStepData, setMyStepData] = useState(stepScheduleDefaultValue); +const StepScheduleRuleComponent: FC = ({ + addPadding = false, + defaultValues, + descriptionDirection = 'row', + isReadOnlyView, + isLoading, + isUpdateView = false, + setStepData, + setForm, +}) => { + const [myStepData, setMyStepData] = useState(stepScheduleDefaultValue); - const { form } = useForm({ - defaultValue: myStepData, - options: { stripEmptyFields: false }, - schema, - }); + const { form } = useForm({ + defaultValue: myStepData, + options: { stripEmptyFields: false }, + schema, + }); - const onSubmit = useCallback( - async (enabled: boolean) => { - if (setStepData) { - setStepData(RuleStep.scheduleRule, null, false); - const { isValid: newIsValid, data } = await form.submit(); - if (newIsValid) { - setStepData(RuleStep.scheduleRule, { ...data, enabled }, newIsValid); - setMyStepData({ ...data, isNew: false } as ScheduleStepRule); - } - } - }, - [form] - ); - - useEffect(() => { - const { isNew, ...initDefaultValue } = myStepData; - if (defaultValues != null && !isEqual(initDefaultValue, defaultValues)) { - const myDefaultValues = { - ...defaultValues, - isNew: false, - }; - setMyStepData(myDefaultValues); - if (!isReadOnlyView) { - Object.keys(schema).forEach(key => { - const val = get(key, myDefaultValues); - if (val != null) { - form.setFieldValue(key, val); - } - }); + const onSubmit = useCallback( + async (enabled: boolean) => { + if (setStepData) { + setStepData(RuleStep.scheduleRule, null, false); + const { isValid: newIsValid, data } = await form.submit(); + if (newIsValid) { + setStepData(RuleStep.scheduleRule, { ...data, enabled }, newIsValid); + setMyStepData({ ...data, isNew: false } as ScheduleStepRule); } } - }, [defaultValues]); + }, + [form] + ); - useEffect(() => { - if (setForm != null) { - setForm(RuleStep.scheduleRule, form); + useEffect(() => { + const { isNew, ...initDefaultValue } = myStepData; + if (defaultValues != null && !isEqual(initDefaultValue, defaultValues)) { + const myDefaultValues = { + ...defaultValues, + isNew: false, + }; + setMyStepData(myDefaultValues); + if (!isReadOnlyView) { + Object.keys(schema).forEach(key => { + const val = get(key, myDefaultValues); + if (val != null) { + form.setFieldValue(key, val); + } + }); } - }, [form]); + } + }, [defaultValues]); - return isReadOnlyView && myStepData != null ? ( + useEffect(() => { + if (setForm != null) { + setForm(RuleStep.scheduleRule, form); + } + }, [form]); + + return isReadOnlyView && myStepData != null ? ( + - ) : ( - <> + + ) : ( + <> +
( }} /> +
+ + {!isUpdateView && ( + <> + + + + + {I18n.COMPLETE_WITHOUT_ACTIVATING} + + + + + {I18n.COMPLETE_WITH_ACTIVATING} + + + + + )} + + ); +}; - {!isUpdateView && ( - <> - - - - - {I18n.COMPLETE_WITHOUT_ACTIVATING} - - - - - {I18n.COMPLETE_WITH_ACTIVATING} - - - - - )} - - ); - } -); +export const StepScheduleRule = memo(StepScheduleRuleComponent); diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_schedule_rule/schema.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_schedule_rule/schema.tsx index 31e56265dec42..4da17b88b9ad0 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_schedule_rule/schema.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/step_schedule_rule/schema.tsx @@ -4,11 +4,9 @@ * you may not use this file except in compliance with the Elastic License. */ -import { EuiText } from '@elastic/eui'; -import React from 'react'; import { i18n } from '@kbn/i18n'; -import * as RuleI18n from '../../translations'; +import { OptionalFieldLabel } from '../optional_field_label'; import { FormSchema } from '../shared_imports'; export const schema: FormSchema = { @@ -33,7 +31,7 @@ export const schema: FormSchema = { defaultMessage: 'Additional look-back', } ), - labelAppend: {RuleI18n.OPTIONAL_FIELD}, + labelAppend: OptionalFieldLabel, helpText: i18n.translate( 'xpack.siem.detectionEngine.createRule.stepScheduleRule.fieldAdditionalLookBackHelpText', { diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/create/index.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/create/index.tsx index 9a0f41bbd8c51..e5656f5b081fb 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/create/index.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/create/index.tsx @@ -27,26 +27,17 @@ import * as i18n from './translations'; const stepsRuleOrder = [RuleStep.defineRule, RuleStep.aboutRule, RuleStep.scheduleRule]; -const ResizeEuiPanel = styled(EuiPanel)<{ - height?: number; +const MyEuiPanel = styled(EuiPanel)<{ + zIndex?: number; }>` + position: relative; + z-index: ${props => props.zIndex}; /* ugly fix to allow searchBar to overflow the EuiPanel */ + .euiAccordion__iconWrapper { display: none; } .euiAccordion__childWrapper { - height: ${props => (props.height !== -1 ? `${props.height}px !important` : 'auto')}; - } - .euiAccordion__button { - cursor: default !important; - &:hover { - text-decoration: none !important; - } - } -`; - -const MyEuiPanel = styled(EuiPanel)` - .euiAccordion__iconWrapper { - display: none; + overflow: visible; } .euiAccordion__button { cursor: default !important; @@ -64,7 +55,6 @@ export const CreateRuleComponent = React.memo(() => { canUserCRUD, hasManageApiKey, } = useUserInfo(); - const [heightAccordion, setHeightAccordion] = useState(-1); const [openAccordionId, setOpenAccordionId] = useState(RuleStep.defineRule); const defineRuleRef = useRef(null); const aboutRuleRef = useRef(null); @@ -239,7 +229,7 @@ export const CreateRuleComponent = React.memo(() => { isLoading={isLoading || loading} title={i18n.PAGE_TITLE} /> - + { ) } > - + setHeightAccordion(height)} + descriptionDirection="row" /> - - - + + + { ) } > - + { /> - - + + { ) } > - + ( {aboutRuleData != null && ( void; isReadOnlyView: boolean; From b65710d33d1ddd3121ea2a31ab6798b4d4ca0dce Mon Sep 17 00:00:00 2001 From: Oliver Gupte Date: Mon, 13 Jan 2020 13:25:14 -0800 Subject: [PATCH 057/139] Service Map Data API at Runtime (#54027) * [APM] Runtime service maps * Make nodes interactive * Don't use smaller range query on initial request * Address feedback from Ron * Get all services separately * Get single service as well * Query both transactions/spans for initial request * Optimize 'top' query for service maps * Use agent.name from scripted metric * adds basic loading overlay * filter out service map node self reference edges from being rendered * Make service map initial load time range configurable with `xpack.apm.serviceMapInitialTimeRange` default to last 1 hour in milliseconds * ensure destination.address is not missing in the composite agg when fetching sample trace ids * wip: added incremental data fetch & progress bar * implement progressive loading design while blocking service map interaction during loading * adds filter that destination.address exists before fetching sample trace ids * reduce pairs of connections to 1 bi-directional connection with arrows on both ends of the edge * Optimize query; add update button * Allow user interaction after 5s, auto update in that time, otherwise show toast for user to update the map with button * Correctly reduce nodes/connections * - remove non-interactive state while loading - use cytoscape element definition types * - readability improvements to the ServiceMap component - only show the update map button toast after last request loads * addresses feedback for changes to the Cytoscape component * Add span.type/span.subtype do external nodes * PR feedback Co-authored-by: Dario Gieselaar --- .../elasticsearch_fieldnames.test.ts.snap | 6 + .../apm/common/elasticsearch_fieldnames.ts | 2 + .../legacy/plugins/apm/common/service_map.ts | 23 ++ x-pack/legacy/plugins/apm/index.ts | 3 +- .../components/app/ServiceMap/Cytoscape.tsx | 1 + .../app/ServiceMap/LoadingOverlay.tsx | 66 +++++ .../app/ServiceMap/cytoscapeOptions.ts | 23 +- .../app/ServiceMap/get_cytoscape_elements.ts | 158 ++++++++++ .../components/app/ServiceMap/index.tsx | 181 +++++++++-- .../apm/server/lib/helpers/es_client.ts | 49 ++- .../server/lib/service_map/get_service_map.ts | 129 ++++++++ .../get_service_map_from_trace_ids.ts | 280 ++++++++++++++++++ .../lib/service_map/get_trace_sample_ids.ts | 177 +++++++++++ .../apm/server/routes/create_apm_api.ts | 8 +- .../plugins/apm/server/routes/service_map.ts | 34 +++ .../plugins/apm/server/routes/services.ts | 15 - .../apm/typings/elasticsearch/aggregations.ts | 47 +++ .../apm/typings/elasticsearch/index.ts | 1 + x-pack/plugins/apm/server/index.ts | 2 + 19 files changed, 1142 insertions(+), 63 deletions(-) create mode 100644 x-pack/legacy/plugins/apm/common/service_map.ts create mode 100644 x-pack/legacy/plugins/apm/public/components/app/ServiceMap/LoadingOverlay.tsx create mode 100644 x-pack/legacy/plugins/apm/public/components/app/ServiceMap/get_cytoscape_elements.ts create mode 100644 x-pack/legacy/plugins/apm/server/lib/service_map/get_service_map.ts create mode 100644 x-pack/legacy/plugins/apm/server/lib/service_map/get_service_map_from_trace_ids.ts create mode 100644 x-pack/legacy/plugins/apm/server/lib/service_map/get_trace_sample_ids.ts create mode 100644 x-pack/legacy/plugins/apm/server/routes/service_map.ts diff --git a/x-pack/legacy/plugins/apm/common/__snapshots__/elasticsearch_fieldnames.test.ts.snap b/x-pack/legacy/plugins/apm/common/__snapshots__/elasticsearch_fieldnames.test.ts.snap index e345ca3552e5a..8f87b3473b2e4 100644 --- a/x-pack/legacy/plugins/apm/common/__snapshots__/elasticsearch_fieldnames.test.ts.snap +++ b/x-pack/legacy/plugins/apm/common/__snapshots__/elasticsearch_fieldnames.test.ts.snap @@ -4,6 +4,8 @@ exports[`Error CLIENT_GEO_COUNTRY_ISO_CODE 1`] = `undefined`; exports[`Error CONTAINER_ID 1`] = `undefined`; +exports[`Error DESTINATION_ADDRESS 1`] = `undefined`; + exports[`Error ERROR_CULPRIT 1`] = `"handleOopsie"`; exports[`Error ERROR_EXC_HANDLED 1`] = `undefined`; @@ -112,6 +114,8 @@ exports[`Span CLIENT_GEO_COUNTRY_ISO_CODE 1`] = `undefined`; exports[`Span CONTAINER_ID 1`] = `undefined`; +exports[`Span DESTINATION_ADDRESS 1`] = `undefined`; + exports[`Span ERROR_CULPRIT 1`] = `undefined`; exports[`Span ERROR_EXC_HANDLED 1`] = `undefined`; @@ -220,6 +224,8 @@ exports[`Transaction CLIENT_GEO_COUNTRY_ISO_CODE 1`] = `undefined`; exports[`Transaction CONTAINER_ID 1`] = `"container1234567890abcdef"`; +exports[`Transaction DESTINATION_ADDRESS 1`] = `undefined`; + exports[`Transaction ERROR_CULPRIT 1`] = `undefined`; exports[`Transaction ERROR_EXC_HANDLED 1`] = `undefined`; diff --git a/x-pack/legacy/plugins/apm/common/elasticsearch_fieldnames.ts b/x-pack/legacy/plugins/apm/common/elasticsearch_fieldnames.ts index 0d7ff3114e73f..ce2db4964a412 100644 --- a/x-pack/legacy/plugins/apm/common/elasticsearch_fieldnames.ts +++ b/x-pack/legacy/plugins/apm/common/elasticsearch_fieldnames.ts @@ -14,6 +14,8 @@ export const HTTP_REQUEST_METHOD = 'http.request.method'; export const USER_ID = 'user.id'; export const USER_AGENT_NAME = 'user_agent.name'; +export const DESTINATION_ADDRESS = 'destination.address'; + export const OBSERVER_VERSION_MAJOR = 'observer.version_major'; export const OBSERVER_LISTENING = 'observer.listening'; export const PROCESSOR_EVENT = 'processor.event'; diff --git a/x-pack/legacy/plugins/apm/common/service_map.ts b/x-pack/legacy/plugins/apm/common/service_map.ts new file mode 100644 index 0000000000000..fbaa489c45039 --- /dev/null +++ b/x-pack/legacy/plugins/apm/common/service_map.ts @@ -0,0 +1,23 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export interface ServiceConnectionNode { + 'service.name': string; + 'service.environment': string | null; + 'agent.name': string; +} +export interface ExternalConnectionNode { + 'destination.address': string; + 'span.type': string; + 'span.subtype': string; +} + +export type ConnectionNode = ServiceConnectionNode | ExternalConnectionNode; + +export interface Connection { + source: ConnectionNode; + destination: ConnectionNode; +} diff --git a/x-pack/legacy/plugins/apm/index.ts b/x-pack/legacy/plugins/apm/index.ts index cf2cbd2507215..0934cb0019f44 100644 --- a/x-pack/legacy/plugins/apm/index.ts +++ b/x-pack/legacy/plugins/apm/index.ts @@ -71,7 +71,8 @@ export const apm: LegacyPluginInitializer = kibana => { autocreateApmIndexPattern: Joi.boolean().default(true), // service map - serviceMapEnabled: Joi.boolean().default(false) + serviceMapEnabled: Joi.boolean().default(false), + serviceMapInitialTimeRange: Joi.number().default(60 * 1000 * 60) // last 1 hour }).default(); }, diff --git a/x-pack/legacy/plugins/apm/public/components/app/ServiceMap/Cytoscape.tsx b/x-pack/legacy/plugins/apm/public/components/app/ServiceMap/Cytoscape.tsx index 238158c5bf224..bc020815cc9cb 100644 --- a/x-pack/legacy/plugins/apm/public/components/app/ServiceMap/Cytoscape.tsx +++ b/x-pack/legacy/plugins/apm/public/components/app/ServiceMap/Cytoscape.tsx @@ -73,6 +73,7 @@ export function Cytoscape({ cy.on('data', event => { // Add the "primary" class to the node if its id matches the serviceName. if (cy.nodes().length > 0 && serviceName) { + cy.nodes().removeClass('primary'); cy.getElementById(serviceName).addClass('primary'); } diff --git a/x-pack/legacy/plugins/apm/public/components/app/ServiceMap/LoadingOverlay.tsx b/x-pack/legacy/plugins/apm/public/components/app/ServiceMap/LoadingOverlay.tsx new file mode 100644 index 0000000000000..efafdbcecd41c --- /dev/null +++ b/x-pack/legacy/plugins/apm/public/components/app/ServiceMap/LoadingOverlay.tsx @@ -0,0 +1,66 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import theme from '@elastic/eui/dist/eui_theme_light.json'; +import React from 'react'; +import { EuiProgress, EuiText, EuiSpacer } from '@elastic/eui'; +import styled from 'styled-components'; +import { i18n } from '@kbn/i18n'; + +const Container = styled.div` + position: relative; +`; + +const Overlay = styled.div` + position: absolute; + top: 0; + z-index: 1; + display: flex; + flex-direction: column; + align-items: center; + width: 100%; + padding: ${theme.gutterTypes.gutterMedium}; +`; + +const ProgressBarContainer = styled.div` + width: 50%; + max-width: 600px; +`; + +interface Props { + children: React.ReactNode; + isLoading: boolean; + percentageLoaded: number; +} + +export const LoadingOverlay = ({ + children, + isLoading, + percentageLoaded +}: Props) => ( + + {isLoading && ( + + + + + + + {i18n.translate('xpack.apm.loadingServiceMap', { + defaultMessage: + 'Loading service map... This might take a short while.' + })} + + + )} + {children} + +); diff --git a/x-pack/legacy/plugins/apm/public/components/app/ServiceMap/cytoscapeOptions.ts b/x-pack/legacy/plugins/apm/public/components/app/ServiceMap/cytoscapeOptions.ts index 03ae9d0c287e5..d4e792ccf761b 100644 --- a/x-pack/legacy/plugins/apm/public/components/app/ServiceMap/cytoscapeOptions.ts +++ b/x-pack/legacy/plugins/apm/public/components/app/ServiceMap/cytoscapeOptions.ts @@ -8,17 +8,13 @@ import theme from '@elastic/eui/dist/eui_theme_light.json'; import { icons, defaultIcon } from './icons'; const layout = { - animate: true, - animationEasing: theme.euiAnimSlightBounce as cytoscape.Css.TransitionTimingFunction, - animationDuration: parseInt(theme.euiAnimSpeedFast, 10), name: 'dagre', nodeDimensionsIncludeLabels: true, - rankDir: 'LR', - spacingFactor: 2 + rankDir: 'LR' }; function isDatabaseOrExternal(agentName: string) { - return agentName === 'database' || agentName === 'external'; + return !agentName; } const style: cytoscape.Stylesheet[] = [ @@ -47,7 +43,7 @@ const style: cytoscape.Stylesheet[] = [ 'font-family': 'Inter UI, Segoe UI, Helvetica, Arial, sans-serif', 'font-size': theme.euiFontSizeXS, height: theme.avatarSizing.l.size, - label: 'data(id)', + label: 'data(label)', 'min-zoomed-font-size': theme.euiSizeL, 'overlay-opacity': 0, shape: (el: cytoscape.NodeSingular) => @@ -76,7 +72,18 @@ const style: cytoscape.Stylesheet[] = [ // // @ts-ignore 'target-distance-from-node': theme.paddingSizes.xs, - width: 2 + width: 1, + 'source-arrow-shape': 'none' + } + }, + { + selector: 'edge[bidirectional]', + style: { + 'source-arrow-shape': 'triangle', + 'target-arrow-shape': 'triangle', + // @ts-ignore + 'source-distance-from-node': theme.paddingSizes.xs, + 'target-distance-from-node': theme.paddingSizes.xs } } ]; diff --git a/x-pack/legacy/plugins/apm/public/components/app/ServiceMap/get_cytoscape_elements.ts b/x-pack/legacy/plugins/apm/public/components/app/ServiceMap/get_cytoscape_elements.ts new file mode 100644 index 0000000000000..c9caa27af41c5 --- /dev/null +++ b/x-pack/legacy/plugins/apm/public/components/app/ServiceMap/get_cytoscape_elements.ts @@ -0,0 +1,158 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import { ValuesType } from 'utility-types'; +import { sortBy, isEqual } from 'lodash'; +import { Connection, ConnectionNode } from '../../../../common/service_map'; +import { ServiceMapAPIResponse } from '../../../../server/lib/service_map/get_service_map'; +import { getAPMHref } from '../../shared/Links/apm/APMLink'; + +function getConnectionNodeId(node: ConnectionNode): string { + if ('destination.address' in node) { + // use a prefix to distinguish exernal destination ids from services + return `>${node['destination.address']}`; + } + return node['service.name']; +} + +function getConnectionId(connection: Connection) { + return `${getConnectionNodeId(connection.source)}~${getConnectionNodeId( + connection.destination + )}`; +} +export function getCytoscapeElements( + responses: ServiceMapAPIResponse[], + search: string +) { + const discoveredServices = responses.flatMap( + response => response.discoveredServices + ); + + const serviceNodes = responses + .flatMap(response => response.services) + .map(service => ({ + ...service, + id: service['service.name'] + })); + + // maps destination.address to service.name if possible + function getConnectionNode(node: ConnectionNode) { + let mappedNode: ConnectionNode | undefined; + + if ('destination.address' in node) { + mappedNode = discoveredServices.find(map => isEqual(map.from, node))?.to; + } + + if (!mappedNode) { + mappedNode = node; + } + + return { + ...mappedNode, + id: getConnectionNodeId(mappedNode) + }; + } + + // build connections with mapped nodes + const connections = responses + .flatMap(response => response.connections) + .map(connection => { + const source = getConnectionNode(connection.source); + const destination = getConnectionNode(connection.destination); + + return { + source, + destination, + id: getConnectionId({ source, destination }) + }; + }) + .filter(connection => connection.source.id !== connection.destination.id); + + const nodes = connections + .flatMap(connection => [connection.source, connection.destination]) + .concat(serviceNodes); + + type ConnectionWithId = ValuesType; + type ConnectionNodeWithId = ValuesType; + + const connectionsById = connections.reduce((connectionMap, connection) => { + return { + ...connectionMap, + [connection.id]: connection + }; + }, {} as Record); + + const nodesById = nodes.reduce((nodeMap, node) => { + return { + ...nodeMap, + [node.id]: node + }; + }, {} as Record); + + const cyNodes = (Object.values(nodesById) as ConnectionNodeWithId[]).map( + node => { + let data = {}; + + if ('service.name' in node) { + data = { + href: getAPMHref( + `/services/${node['service.name']}/service-map`, + search + ), + agentName: node['agent.name'] || node['agent.name'] + }; + } + + return { + group: 'nodes' as const, + data: { + id: node.id, + label: + 'service.name' in node + ? node['service.name'] + : node['destination.address'], + ...data + } + }; + } + ); + + // instead of adding connections in two directions, + // we add a `bidirectional` flag to use in styling + const dedupedConnections = (sortBy( + Object.values(connectionsById), + // make sure that order is stable + 'id' + ) as ConnectionWithId[]).reduce< + Array + >((prev, connection) => { + const reversedConnection = prev.find( + c => + c.destination.id === connection.source.id && + c.source.id === connection.destination.id + ); + + if (reversedConnection) { + reversedConnection.bidirectional = true; + return prev; + } + + return prev.concat(connection); + }, []); + + const cyEdges = dedupedConnections.map(connection => { + return { + group: 'edges' as const, + data: { + id: connection.id, + source: connection.source.id, + target: connection.destination.id, + bidirectional: connection.bidirectional ? true : undefined + } + }; + }, []); + + return [...cyNodes, ...cyEdges]; +} diff --git a/x-pack/legacy/plugins/apm/public/components/app/ServiceMap/index.tsx b/x-pack/legacy/plugins/apm/public/components/app/ServiceMap/index.tsx index cc09975a344b5..d3cc2b14e2c68 100644 --- a/x-pack/legacy/plugins/apm/public/components/app/ServiceMap/index.tsx +++ b/x-pack/legacy/plugins/apm/public/components/app/ServiceMap/index.tsx @@ -5,13 +5,30 @@ */ import theme from '@elastic/eui/dist/eui_theme_light.json'; -import React from 'react'; -import { useFetcher } from '../../../hooks/useFetcher'; +import React, { + useMemo, + useEffect, + useState, + useRef, + useCallback +} from 'react'; +import { find, isEqual } from 'lodash'; +import { i18n } from '@kbn/i18n'; +import { EuiButton } from '@elastic/eui'; +import { ElementDefinition } from 'cytoscape'; +import { toMountPoint } from '../../../../../../../../src/plugins/kibana_react/public'; +import { ServiceMapAPIResponse } from '../../../../server/lib/service_map/get_service_map'; import { useLicense } from '../../../hooks/useLicense'; import { useUrlParams } from '../../../hooks/useUrlParams'; import { Controls } from './Controls'; import { Cytoscape } from './Cytoscape'; import { PlatinumLicensePrompt } from './PlatinumLicensePrompt'; +import { useCallApmApi } from '../../../hooks/useCallApmApi'; +import { useDeepObjectIdentity } from '../../../hooks/useDeepObjectIdentity'; +import { useLocation } from '../../../hooks/useLocation'; +import { LoadingOverlay } from './LoadingOverlay'; +import { useApmPluginContext } from '../../../hooks/useApmPluginContext'; +import { getCytoscapeElements } from './get_cytoscape_elements'; interface ServiceMapProps { serviceName?: string; @@ -37,37 +54,159 @@ ${theme.euiColorLightShade}`, margin: `-${theme.gutterTypes.gutterLarge}` }; +const MAX_REQUESTS = 5; + export function ServiceMap({ serviceName }: ServiceMapProps) { - const { - urlParams: { start, end } - } = useUrlParams(); + const callApmApi = useCallApmApi(); + const license = useLicense(); + const { search } = useLocation(); + const { urlParams, uiFilters } = useUrlParams(); + const { notifications } = useApmPluginContext().core; + const params = useDeepObjectIdentity({ + start: urlParams.start, + end: urlParams.end, + environment: urlParams.environment, + serviceName, + uiFilters: { + ...uiFilters, + environment: undefined + } + }); + + const renderedElements = useRef([]); + const openToast = useRef(null); + + const [responses, setResponses] = useState([]); + const [isLoading, setIsLoading] = useState(true); + const [percentageLoaded, setPercentageLoaded] = useState(0); + const [, _setUnusedState] = useState(false); + + const elements = useMemo(() => getCytoscapeElements(responses, search), [ + responses, + search + ]); + + const forceUpdate = useCallback(() => _setUnusedState(value => !value), []); + + const getNext = useCallback( + async (input: { reset?: boolean; after?: string | undefined }) => { + const { start, end, uiFilters: strippedUiFilters, ...query } = params; + + if (input.reset) { + renderedElements.current = []; + setResponses([]); + } - const { data } = useFetcher( - callApmApi => { if (start && end) { - return callApmApi({ - pathname: '/api/apm/service-map', - params: { query: { start, end } } - }); + setIsLoading(true); + try { + const data = await callApmApi({ + pathname: '/api/apm/service-map', + params: { + query: { + ...query, + start, + end, + uiFilters: JSON.stringify(strippedUiFilters), + after: input.after + } + } + }); + setResponses(resp => resp.concat(data)); + setIsLoading(false); + + const shouldGetNext = + responses.length + 1 < MAX_REQUESTS && data.after; + + if (shouldGetNext) { + setPercentageLoaded(value => value + 30); // increase loading bar 30% + await getNext({ after: data.after }); + } + } catch (error) { + setIsLoading(false); + notifications.toasts.addError(error, { + title: i18n.translate('xpack.apm.errorServiceMapData', { + defaultMessage: `Error loading service connections` + }) + }); + } } }, - [start, end] + [callApmApi, params, responses.length, notifications.toasts] ); - const elements = Array.isArray(data) ? data : []; - const license = useLicense(); + useEffect(() => { + const loadServiceMaps = async () => { + setPercentageLoaded(5); + await getNext({ reset: true }); + setPercentageLoaded(100); + }; + + loadServiceMaps(); + + // eslint-disable-next-line react-hooks/exhaustive-deps + }, [params]); + + useEffect(() => { + if (renderedElements.current.length === 0) { + renderedElements.current = elements; + return; + } + + const newElements = elements.filter(element => { + return !find(renderedElements.current, el => isEqual(el, element)); + }); + + const updateMap = () => { + renderedElements.current = elements; + if (openToast.current) { + notifications.toasts.remove(openToast.current); + } + forceUpdate(); + }; + + if (newElements.length > 0 && percentageLoaded === 100) { + openToast.current = notifications.toasts.add({ + title: i18n.translate('xpack.apm.newServiceMapData', { + defaultMessage: `Newly discovered connections are available.` + }), + onClose: () => { + openToast.current = null; + }, + toastLifeTimeMs: 24 * 60 * 60 * 1000, + text: toMountPoint( + + {i18n.translate('xpack.apm.updateServiceMap', { + defaultMessage: 'Update map' + })} + + ) + }).id; + } + + return () => { + if (openToast.current) { + notifications.toasts.remove(openToast.current); + } + }; + + // eslint-disable-next-line react-hooks/exhaustive-deps + }, [elements, percentageLoaded]); + const isValidPlatinumLicense = license?.isActive && (license?.type === 'platinum' || license?.type === 'trial'); return isValidPlatinumLicense ? ( - - - + + + + + ) : ( ); diff --git a/x-pack/legacy/plugins/apm/server/lib/helpers/es_client.ts b/x-pack/legacy/plugins/apm/server/lib/helpers/es_client.ts index aeeb39733b5db..737eeac95516e 100644 --- a/x-pack/legacy/plugins/apm/server/lib/helpers/es_client.ts +++ b/x-pack/legacy/plugins/apm/server/lib/helpers/es_client.ts @@ -11,7 +11,7 @@ import { IndicesDeleteParams, IndicesCreateParams } from 'elasticsearch'; -import { merge } from 'lodash'; +import { merge, uniqueId } from 'lodash'; import { cloneDeep, isString } from 'lodash'; import { KibanaRequest } from 'src/core/server'; import { OBSERVER_VERSION_MAJOR } from '../../../common/elasticsearch_fieldnames'; @@ -127,6 +127,23 @@ export function getESClient( ? callAsInternalUser : callAsCurrentUser; + const debug = context.params.query._debug; + + function withTime( + fn: (log: typeof console.log) => Promise + ): Promise { + const log = console.log.bind(console, uniqueId()); + if (!debug) { + return fn(log); + } + const time = process.hrtime(); + return fn(log).then(data => { + const now = process.hrtime(time); + log(`took: ${Math.round(now[0] * 1000 + now[1] / 1e6)}ms`); + return data; + }); + } + return { search: async < TDocument = unknown, @@ -141,27 +158,29 @@ export function getESClient( apmOptions ); - if (context.params.query._debug) { - console.log(`--DEBUG ES QUERY--`); - console.log( - `${request.url.pathname} ${JSON.stringify(context.params.query)}` - ); - console.log(`GET ${nextParams.index}/_search`); - console.log(JSON.stringify(nextParams.body, null, 2)); - } + return withTime(log => { + if (context.params.query._debug) { + log(`--DEBUG ES QUERY--`); + log( + `${request.url.pathname} ${JSON.stringify(context.params.query)}` + ); + log(`GET ${nextParams.index}/_search`); + log(JSON.stringify(nextParams.body, null, 2)); + } - return (callMethod('search', nextParams) as unknown) as Promise< - ESSearchResponse - >; + return (callMethod('search', nextParams) as unknown) as Promise< + ESSearchResponse + >; + }); }, index: (params: APMIndexDocumentParams) => { - return callMethod('index', params); + return withTime(() => callMethod('index', params)); }, delete: (params: IndicesDeleteParams) => { - return callMethod('delete', params); + return withTime(() => callMethod('delete', params)); }, indicesCreate: (params: IndicesCreateParams) => { - return callMethod('indices.create', params); + return withTime(() => callMethod('indices.create', params)); } }; } diff --git a/x-pack/legacy/plugins/apm/server/lib/service_map/get_service_map.ts b/x-pack/legacy/plugins/apm/server/lib/service_map/get_service_map.ts new file mode 100644 index 0000000000000..04e2a43a4b8f1 --- /dev/null +++ b/x-pack/legacy/plugins/apm/server/lib/service_map/get_service_map.ts @@ -0,0 +1,129 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { PromiseReturnType } from '../../../typings/common'; +import { + Setup, + SetupTimeRange, + SetupUIFilters +} from '../helpers/setup_request'; +import { getServiceMapFromTraceIds } from './get_service_map_from_trace_ids'; +import { getTraceSampleIds } from './get_trace_sample_ids'; +import { getServicesProjection } from '../../../common/projections/services'; +import { mergeProjection } from '../../../common/projections/util/merge_projection'; +import { + SERVICE_AGENT_NAME, + SERVICE_NAME +} from '../../../common/elasticsearch_fieldnames'; + +export interface IEnvOptions { + setup: Setup & SetupTimeRange & SetupUIFilters; + serviceName?: string; + environment?: string; + after?: string; +} + +async function getConnectionData({ + setup, + serviceName, + environment, + after +}: IEnvOptions) { + const { traceIds, after: nextAfter } = await getTraceSampleIds({ + setup, + serviceName, + environment, + after + }); + + const serviceMapData = traceIds.length + ? await getServiceMapFromTraceIds({ + setup, + serviceName, + environment, + traceIds + }) + : { connections: [], discoveredServices: [] }; + + return { + after: nextAfter, + ...serviceMapData + }; +} + +async function getServicesData(options: IEnvOptions) { + // only return services on the first request for the global service map + if (options.after) { + return []; + } + + const { setup } = options; + + const projection = getServicesProjection({ setup }); + + const { filter } = projection.body.query.bool; + + const params = mergeProjection(projection, { + body: { + size: 0, + query: { + bool: { + ...projection.body.query.bool, + filter: options.serviceName + ? filter.concat({ + term: { + [SERVICE_NAME]: options.serviceName + } + }) + : filter + } + }, + aggs: { + services: { + terms: { + field: projection.body.aggs.services.terms.field, + size: 500 + }, + aggs: { + agent_name: { + terms: { + field: SERVICE_AGENT_NAME + } + } + } + } + } + } + }); + + const { client } = setup; + + const response = await client.search(params); + + return ( + response.aggregations?.services.buckets.map(bucket => { + return { + 'service.name': bucket.key as string, + 'agent.name': + (bucket.agent_name.buckets[0]?.key as string | undefined) || '', + 'service.environment': options.environment || null + }; + }) || [] + ); +} + +export type ServiceMapAPIResponse = PromiseReturnType; +export async function getServiceMap(options: IEnvOptions) { + const [connectionData, servicesData] = await Promise.all([ + getConnectionData(options), + getServicesData(options) + ]); + + return { + ...connectionData, + services: servicesData + }; +} diff --git a/x-pack/legacy/plugins/apm/server/lib/service_map/get_service_map_from_trace_ids.ts b/x-pack/legacy/plugins/apm/server/lib/service_map/get_service_map_from_trace_ids.ts new file mode 100644 index 0000000000000..ea9af12ac7f9a --- /dev/null +++ b/x-pack/legacy/plugins/apm/server/lib/service_map/get_service_map_from_trace_ids.ts @@ -0,0 +1,280 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import { uniq, find } from 'lodash'; +import { Setup } from '../helpers/setup_request'; +import { + TRACE_ID, + PROCESSOR_EVENT +} from '../../../common/elasticsearch_fieldnames'; +import { + Connection, + ServiceConnectionNode, + ConnectionNode, + ExternalConnectionNode +} from '../../../common/service_map'; + +export async function getServiceMapFromTraceIds({ + setup, + traceIds, + serviceName, + environment +}: { + setup: Setup; + traceIds: string[]; + serviceName?: string; + environment?: string; +}) { + const { indices, client } = setup; + + const serviceMapParams = { + index: [ + indices['apm_oss.spanIndices'], + indices['apm_oss.transactionIndices'] + ], + body: { + size: 0, + query: { + bool: { + filter: [ + { + terms: { + [PROCESSOR_EVENT]: ['span', 'transaction'] + } + }, + { + terms: { + [TRACE_ID]: traceIds + } + } + ] + } + }, + aggs: { + service_map: { + scripted_metric: { + init_script: { + lang: 'painless', + source: `state.eventsById = new HashMap(); + + String[] fieldsToCopy = new String[] { + 'parent.id', + 'service.name', + 'service.environment', + 'destination.address', + 'trace.id', + 'processor.event', + 'span.type', + 'span.subtype', + 'agent.name' + }; + state.fieldsToCopy = fieldsToCopy;` + }, + map_script: { + lang: 'painless', + source: `def id; + if (!doc['span.id'].empty) { + id = doc['span.id'].value; + } else { + id = doc['transaction.id'].value; + } + + def copy = new HashMap(); + copy.id = id; + + for(key in state.fieldsToCopy) { + if (!doc[key].empty) { + copy[key] = doc[key].value; + } + } + + state.eventsById[id] = copy` + }, + combine_script: { + lang: 'painless', + source: `return state.eventsById;` + }, + reduce_script: { + lang: 'painless', + source: ` + def getDestination ( def event ) { + def destination = new HashMap(); + destination['destination.address'] = event['destination.address']; + destination['span.type'] = event['span.type']; + destination['span.subtype'] = event['span.subtype']; + return destination; + } + + def processAndReturnEvent(def context, def eventId) { + if (context.processedEvents[eventId] != null) { + return context.processedEvents[eventId]; + } + + def event = context.eventsById[eventId]; + + if (event == null) { + return null; + } + + def service = new HashMap(); + service['service.name'] = event['service.name']; + service['service.environment'] = event['service.environment']; + service['agent.name'] = event['agent.name']; + + def basePath = new ArrayList(); + + def parentId = event['parent.id']; + def parent; + + if (parentId != null && parentId != event['id']) { + parent = processAndReturnEvent(context, parentId); + if (parent != null) { + /* copy the path from the parent */ + basePath.addAll(parent.path); + /* flag parent path for removal, as it has children */ + context.locationsToRemove.add(parent.path); + + /* if the parent has 'destination.address' set, and the service is different, + we've discovered a service */ + + if (parent['destination.address'] != null + && parent['destination.address'] != "" + && (parent['span.type'] == 'external' + || parent['span.type'] == 'messaging') + && (parent['service.name'] != event['service.name'] + || parent['service.environment'] != event['service.environment'] + ) + ) { + def parentDestination = getDestination(parent); + context.externalToServiceMap.put(parentDestination, service); + } + } + } + + def lastLocation = basePath.size() > 0 ? basePath[basePath.size() - 1] : null; + + def currentLocation = service; + + /* only add the current location to the path if it's different from the last one*/ + if (lastLocation == null || !lastLocation.equals(currentLocation)) { + basePath.add(currentLocation); + } + + /* if there is an outgoing span, create a new path */ + if (event['span.type'] == 'external' || event['span.type'] == 'messaging') { + def outgoingLocation = getDestination(event); + def outgoingPath = new ArrayList(basePath); + outgoingPath.add(outgoingLocation); + context.paths.add(outgoingPath); + } + + event.path = basePath; + + context.processedEvents[eventId] = event; + return event; + } + + def context = new HashMap(); + + context.processedEvents = new HashMap(); + context.eventsById = new HashMap(); + + context.paths = new HashSet(); + context.externalToServiceMap = new HashMap(); + context.locationsToRemove = new HashSet(); + + for (state in states) { + context.eventsById.putAll(state); + } + + for (entry in context.eventsById.entrySet()) { + processAndReturnEvent(context, entry.getKey()); + } + + def paths = new HashSet(); + + for(foundPath in context.paths) { + if (!context.locationsToRemove.contains(foundPath)) { + paths.add(foundPath); + } + } + + def response = new HashMap(); + response.paths = paths; + + def discoveredServices = new HashSet(); + + for(entry in context.externalToServiceMap.entrySet()) { + def map = new HashMap(); + map.from = entry.getKey(); + map.to = entry.getValue(); + discoveredServices.add(map); + } + response.discoveredServices = discoveredServices; + + return response;` + } + } + } + } + } + }; + + const serviceMapResponse = await client.search(serviceMapParams); + + const scriptResponse = serviceMapResponse.aggregations?.service_map.value as { + paths: ConnectionNode[][]; + discoveredServices: Array<{ + from: ExternalConnectionNode; + to: ServiceConnectionNode; + }>; + }; + + let paths = scriptResponse.paths; + + if (serviceName || environment) { + paths = paths.filter(path => { + return path.some(node => { + let matches = true; + if (serviceName) { + matches = + matches && + 'service.name' in node && + node['service.name'] === serviceName; + } + if (environment) { + matches = + matches && + 'service.environment' in node && + node['service.environment'] === environment; + } + return matches; + }); + }); + } + + const connections = uniq( + paths.flatMap(path => { + return path.reduce((conns, location, index) => { + const prev = path[index - 1]; + if (prev) { + return conns.concat({ + source: prev, + destination: location + }); + } + return conns; + }, [] as Connection[]); + }, [] as Connection[]), + (value, index, array) => { + return find(array, value); + } + ); + + return { + connections, + discoveredServices: scriptResponse.discoveredServices + }; +} diff --git a/x-pack/legacy/plugins/apm/server/lib/service_map/get_trace_sample_ids.ts b/x-pack/legacy/plugins/apm/server/lib/service_map/get_trace_sample_ids.ts new file mode 100644 index 0000000000000..acf113b426608 --- /dev/null +++ b/x-pack/legacy/plugins/apm/server/lib/service_map/get_trace_sample_ids.ts @@ -0,0 +1,177 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import { uniq, take, sortBy } from 'lodash'; +import { + Setup, + SetupUIFilters, + SetupTimeRange +} from '../helpers/setup_request'; +import { rangeFilter } from '../helpers/range_filter'; +import { ESFilter } from '../../../typings/elasticsearch'; +import { + PROCESSOR_EVENT, + SERVICE_NAME, + SERVICE_ENVIRONMENT, + SPAN_TYPE, + SPAN_SUBTYPE, + DESTINATION_ADDRESS, + TRACE_ID +} from '../../../common/elasticsearch_fieldnames'; + +const MAX_TRACES_TO_INSPECT = 1000; + +export async function getTraceSampleIds({ + after, + serviceName, + environment, + setup +}: { + after?: string; + serviceName?: string; + environment?: string; + setup: Setup & SetupTimeRange & SetupUIFilters; +}) { + const isTop = !after; + + const { start, end, client, indices, config } = setup; + + const rangeEnd = end; + const rangeStart = isTop + ? rangeEnd - config['xpack.apm.serviceMapInitialTimeRange'] + : start; + + const rangeQuery = { range: rangeFilter(rangeStart, rangeEnd) }; + + const query = { + bool: { + filter: [ + { + term: { + [PROCESSOR_EVENT]: 'span' + } + }, + { + exists: { + field: DESTINATION_ADDRESS + } + }, + rangeQuery + ] as ESFilter[] + } + } as { bool: { filter: ESFilter[]; must_not?: ESFilter[] | ESFilter } }; + + if (serviceName) { + query.bool.filter.push({ term: { [SERVICE_NAME]: serviceName } }); + } + + if (environment) { + query.bool.filter.push({ term: { [SERVICE_ENVIRONMENT]: environment } }); + } + + const afterObj = + after && after !== 'top' + ? { after: JSON.parse(Buffer.from(after, 'base64').toString()) } + : {}; + + const params = { + index: [indices['apm_oss.spanIndices']], + body: { + size: 0, + query, + aggs: { + connections: { + composite: { + size: 1000, + ...afterObj, + sources: [ + { [SERVICE_NAME]: { terms: { field: SERVICE_NAME } } }, + { + [SERVICE_ENVIRONMENT]: { + terms: { field: SERVICE_ENVIRONMENT, missing_bucket: true } + } + }, + { + [SPAN_TYPE]: { + terms: { field: SPAN_TYPE, missing_bucket: true } + } + }, + { + [SPAN_SUBTYPE]: { + terms: { field: SPAN_SUBTYPE, missing_bucket: true } + } + }, + { + [DESTINATION_ADDRESS]: { + terms: { field: DESTINATION_ADDRESS } + } + } + ] + }, + aggs: { + sample: { + sampler: { + shard_size: 30 + }, + aggs: { + trace_ids: { + terms: { + field: TRACE_ID, + execution_hint: 'map' as const, + // remove bias towards large traces by sorting on trace.id + // which will be random-esque + order: { + _key: 'desc' as const + } + } + } + } + } + } + } + } + } + }; + + const tracesSampleResponse = await client.search< + { trace: { id: string } }, + typeof params + >(params); + + let nextAfter: string | undefined; + + const receivedAfterKey = + tracesSampleResponse.aggregations?.connections.after_key; + + if (!after) { + nextAfter = 'top'; + } else if (receivedAfterKey) { + nextAfter = Buffer.from(JSON.stringify(receivedAfterKey)).toString( + 'base64' + ); + } + + // make sure at least one trace per composite/connection bucket + // is queried + const traceIdsWithPriority = + tracesSampleResponse.aggregations?.connections.buckets.flatMap(bucket => + bucket.sample.trace_ids.buckets.map((sampleDocBucket, index) => ({ + traceId: sampleDocBucket.key as string, + priority: index + })) + ) || []; + + const traceIds = take( + uniq( + sortBy(traceIdsWithPriority, 'priority').map(({ traceId }) => traceId) + ), + MAX_TRACES_TO_INSPECT + ); + + return { + after: nextAfter, + traceIds + }; +} diff --git a/x-pack/legacy/plugins/apm/server/routes/create_apm_api.ts b/x-pack/legacy/plugins/apm/server/routes/create_apm_api.ts index e98842151da84..a9a8241da39d1 100644 --- a/x-pack/legacy/plugins/apm/server/routes/create_apm_api.ts +++ b/x-pack/legacy/plugins/apm/server/routes/create_apm_api.ts @@ -58,7 +58,7 @@ import { uiFiltersEnvironmentsRoute } from './ui_filters'; import { createApi } from './create_api'; -import { serviceMapRoute } from './services'; +import { serviceMapRoute } from './service_map'; const createApmApi = () => { const api = createApi() @@ -118,10 +118,12 @@ const createApmApi = () => { .add(transactionsLocalFiltersRoute) .add(serviceNodesLocalFiltersRoute) .add(uiFiltersEnvironmentsRoute) - .add(serviceMapRoute) // Transaction - .add(transactionByTraceIdRoute); + .add(transactionByTraceIdRoute) + + // Service map + .add(serviceMapRoute); return api; }; diff --git a/x-pack/legacy/plugins/apm/server/routes/service_map.ts b/x-pack/legacy/plugins/apm/server/routes/service_map.ts new file mode 100644 index 0000000000000..94b176147f7a1 --- /dev/null +++ b/x-pack/legacy/plugins/apm/server/routes/service_map.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; + * you may not use this file except in compliance with the Elastic License. + */ + +import * as t from 'io-ts'; +import Boom from 'boom'; +import { setupRequest } from '../lib/helpers/setup_request'; +import { createRoute } from './create_route'; +import { uiFiltersRt, rangeRt } from './default_api_types'; +import { getServiceMap } from '../lib/service_map/get_service_map'; + +export const serviceMapRoute = createRoute(() => ({ + path: '/api/apm/service-map', + params: { + query: t.intersection([ + t.partial({ environment: t.string, serviceName: t.string }), + uiFiltersRt, + rangeRt, + t.partial({ after: t.string }) + ]) + }, + handler: async ({ context, request }) => { + if (!context.config['xpack.apm.serviceMapEnabled']) { + throw Boom.notFound(); + } + const setup = await setupRequest(context, request); + const { + query: { serviceName, environment, after } + } = context.params; + return getServiceMap({ setup, serviceName, environment, after }); + } +})); diff --git a/x-pack/legacy/plugins/apm/server/routes/services.ts b/x-pack/legacy/plugins/apm/server/routes/services.ts index 78cb092b85db6..18777183ea1de 100644 --- a/x-pack/legacy/plugins/apm/server/routes/services.ts +++ b/x-pack/legacy/plugins/apm/server/routes/services.ts @@ -5,7 +5,6 @@ */ import * as t from 'io-ts'; -import Boom from 'boom'; import { AgentName } from '../../typings/es_schemas/ui/fields/Agent'; import { createApmTelementry, @@ -18,7 +17,6 @@ import { getServiceTransactionTypes } from '../lib/services/get_service_transact import { getServiceNodeMetadata } from '../lib/services/get_service_node_metadata'; import { createRoute } from './create_route'; import { uiFiltersRt, rangeRt } from './default_api_types'; -import { getServiceMap } from '../lib/services/map'; import { getServiceAnnotations } from '../lib/services/annotations'; export const servicesRoute = createRoute(() => ({ @@ -87,19 +85,6 @@ export const serviceNodeMetadataRoute = createRoute(() => ({ } })); -export const serviceMapRoute = createRoute(() => ({ - path: '/api/apm/service-map', - params: { - query: rangeRt - }, - handler: async ({ context }) => { - if (context.config['xpack.apm.serviceMapEnabled']) { - return getServiceMap(); - } - return new Boom('Not found', { statusCode: 404 }); - } -})); - export const serviceAnnotationsRoute = createRoute(() => ({ path: '/api/apm/services/{serviceName}/annotations', params: { diff --git a/x-pack/legacy/plugins/apm/typings/elasticsearch/aggregations.ts b/x-pack/legacy/plugins/apm/typings/elasticsearch/aggregations.ts index 74a9436d7a4bc..6d3620f11a87b 100644 --- a/x-pack/legacy/plugins/apm/typings/elasticsearch/aggregations.ts +++ b/x-pack/legacy/plugins/apm/typings/elasticsearch/aggregations.ts @@ -36,6 +36,19 @@ interface MetricsAggregationResponsePart { value: number | null; } +type GetCompositeKeys< + TAggregationOptionsMap extends AggregationOptionsMap +> = TAggregationOptionsMap extends { + composite: { sources: Array }; +} + ? keyof Source + : never; + +type CompositeOptionsSource = Record< + string, + { terms: { field: string; missing_bucket?: boolean } } | undefined +>; + export interface AggregationOptionsByType { terms: { field: string; @@ -97,6 +110,22 @@ export interface AggregationOptionsByType { buckets_path: BucketsPath; script?: Script; }; + composite: { + size?: number; + sources: CompositeOptionsSource[]; + after?: Record; + }; + diversified_sampler: { + shard_size?: number; + max_docs_per_value?: number; + } & ({ script: Script } | { field: string }); // TODO use MetricsAggregationOptions if possible + scripted_metric: { + params?: Record; + init_script?: Script; + map_script: Script; + combine_script: Script; + reduce_script: Script; + }; } type AggregationType = keyof AggregationOptionsByType; @@ -229,6 +258,24 @@ interface AggregationResponsePart< value: number | null; } | undefined; + composite: { + after_key: Record, number>; + buckets: Array< + { + key: Record, number>; + doc_count: number; + } & BucketSubAggregationResponse< + TAggregationOptionsMap['aggs'], + TDocument + > + >; + }; + diversified_sampler: { + doc_count: number; + } & AggregationResponseMap; + scripted_metric: { + value: unknown; + }; } // Type for debugging purposes. If you see an error in AggregationResponseMap diff --git a/x-pack/legacy/plugins/apm/typings/elasticsearch/index.ts b/x-pack/legacy/plugins/apm/typings/elasticsearch/index.ts index eff39838bd957..064b684cf9aa6 100644 --- a/x-pack/legacy/plugins/apm/typings/elasticsearch/index.ts +++ b/x-pack/legacy/plugins/apm/typings/elasticsearch/index.ts @@ -56,6 +56,7 @@ export interface ESFilter { | string | string[] | number + | boolean | Record | ESFilter[]; }; diff --git a/x-pack/plugins/apm/server/index.ts b/x-pack/plugins/apm/server/index.ts index b0e10d245e0b9..e301d157d2c7c 100644 --- a/x-pack/plugins/apm/server/index.ts +++ b/x-pack/plugins/apm/server/index.ts @@ -16,6 +16,7 @@ export const config = { }, schema: schema.object({ serviceMapEnabled: schema.boolean({ defaultValue: false }), + serviceMapInitialTimeRange: schema.number({ defaultValue: 60 * 1000 * 60 }), // last 1 hour autocreateApmIndexPattern: schema.boolean({ defaultValue: true }), ui: schema.object({ enabled: schema.boolean({ defaultValue: true }), @@ -37,6 +38,7 @@ export function mergeConfigs(apmOssConfig: APMOSSConfig, apmConfig: APMXPackConf 'apm_oss.onboardingIndices': apmOssConfig.onboardingIndices, 'apm_oss.indexPattern': apmOssConfig.indexPattern, 'xpack.apm.serviceMapEnabled': apmConfig.serviceMapEnabled, + 'xpack.apm.serviceMapInitialTimeRange': apmConfig.serviceMapInitialTimeRange, 'xpack.apm.ui.enabled': apmConfig.ui.enabled, 'xpack.apm.ui.maxTraceItems': apmConfig.ui.maxTraceItems, 'xpack.apm.ui.transactionGroupBucketSize': apmConfig.ui.transactionGroupBucketSize, From e9e44ec8518b220c937e598e036be393c625c1d1 Mon Sep 17 00:00:00 2001 From: Nathan Reese Date: Mon, 13 Jan 2020 16:34:56 -0500 Subject: [PATCH 058/139] [Maps] add text halo color and width style properties (#53827) * [Maps] add text halo color and width style properties * fix jest test * update for new editor UI * add removed styling * get halo size from label size * fix label border size with dynamic label size * clean up * fix jest test * fix jest test Co-authored-by: Elastic Machine --- .../components/get_vector_style_label.js | 8 +++ .../vector_style_label_border_size_editor.js | 65 +++++++++++++++++++ .../vector/components/vector_style_editor.js | 22 +++++++ .../properties/dynamic_color_property.js | 5 ++ .../properties/dynamic_color_property.test.js | 7 +- .../properties/dynamic_size_property.js | 18 ++--- .../properties/dynamic_style_property.js | 9 ++- .../properties/label_border_size_property.js | 50 ++++++++++++++ .../properties/static_color_property.js | 4 ++ .../layers/styles/vector/vector_style.js | 14 ++++ .../layers/styles/vector/vector_style.test.js | 11 ++++ .../styles/vector/vector_style_defaults.js | 42 ++++++++++-- 12 files changed, 239 insertions(+), 16 deletions(-) create mode 100644 x-pack/legacy/plugins/maps/public/layers/styles/vector/components/label/vector_style_label_border_size_editor.js create mode 100644 x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/label_border_size_property.js diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/get_vector_style_label.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/get_vector_style_label.js index 325fc28f92051..16cfd34c95ab3 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/get_vector_style_label.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/get_vector_style_label.js @@ -42,6 +42,14 @@ export function getVectorStyleLabel(styleName) { return i18n.translate('xpack.maps.styles.vector.labelSizeLabel', { defaultMessage: 'Label size', }); + case VECTOR_STYLES.LABEL_BORDER_COLOR: + return i18n.translate('xpack.maps.styles.vector.labelBorderColorLabel', { + defaultMessage: 'Label border color', + }); + case VECTOR_STYLES.LABEL_BORDER_SIZE: + return i18n.translate('xpack.maps.styles.vector.labelBorderWidthLabel', { + defaultMessage: 'Label border width', + }); default: return styleName; } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/label/vector_style_label_border_size_editor.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/label/vector_style_label_border_size_editor.js new file mode 100644 index 0000000000000..7d06e8b530011 --- /dev/null +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/label/vector_style_label_border_size_editor.js @@ -0,0 +1,65 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React from 'react'; + +import { EuiFormRow, EuiSelect } from '@elastic/eui'; +import { LABEL_BORDER_SIZES, VECTOR_STYLES } from '../../vector_style_defaults'; +import { getVectorStyleLabel } from '../get_vector_style_label'; +import { i18n } from '@kbn/i18n'; + +const options = [ + { + value: LABEL_BORDER_SIZES.NONE, + text: i18n.translate('xpack.maps.styles.labelBorderSize.noneLabel', { + defaultMessage: 'None', + }), + }, + { + value: LABEL_BORDER_SIZES.SMALL, + text: i18n.translate('xpack.maps.styles.labelBorderSize.smallLabel', { + defaultMessage: 'Small', + }), + }, + { + value: LABEL_BORDER_SIZES.MEDIUM, + text: i18n.translate('xpack.maps.styles.labelBorderSize.mediumLabel', { + defaultMessage: 'Medium', + }), + }, + { + value: LABEL_BORDER_SIZES.LARGE, + text: i18n.translate('xpack.maps.styles.labelBorderSize.largeLabel', { + defaultMessage: 'Large', + }), + }, +]; + +export function VectorStyleLabelBorderSizeEditor({ handlePropertyChange, styleProperty }) { + function onChange(e) { + const styleDescriptor = { + options: { size: e.target.value }, + }; + handlePropertyChange(styleProperty.getStyleName(), styleDescriptor); + } + + return ( + + + + ); +} diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/vector_style_editor.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/vector_style_editor.js index dffe513644db8..bd22b4b9cc5ce 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/vector_style_editor.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/vector_style_editor.js @@ -12,6 +12,7 @@ import { VectorStyleColorEditor } from './color/vector_style_color_editor'; import { VectorStyleSizeEditor } from './size/vector_style_size_editor'; import { VectorStyleSymbolEditor } from './vector_style_symbol_editor'; import { VectorStyleLabelEditor } from './label/vector_style_label_editor'; +import { VectorStyleLabelBorderSizeEditor } from './label/vector_style_label_border_size_editor'; import { VectorStyle } from '../vector_style'; import { OrientationEditor } from './orientation/orientation_editor'; import { @@ -248,6 +249,27 @@ export class VectorStyleEditor extends Component { } /> + + + + + + ); } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js index 57e4d09f3abec..804a0f8975d3e 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js @@ -55,6 +55,11 @@ export class DynamicColorProperty extends DynamicStyleProperty { mbMap.setPaintProperty(mbLayerId, 'text-opacity', alpha); } + syncLabelBorderColorWithMb(mbLayerId, mbMap) { + const color = this._getMbColor(); + mbMap.setPaintProperty(mbLayerId, 'text-halo-color', color); + } + isCustomColorRamp() { return this._options.useCustomColorRamp; } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.test.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.test.js index 0affeefde1313..21c24e837b412 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.test.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.test.js @@ -4,7 +4,12 @@ * you may not use this file except in compliance with the Elastic License. */ -// eslint-disable-next-line no-unused-vars +jest.mock('../components/vector_style_editor', () => ({ + VectorStyleEditor: () => { + return
mockVectorStyleEditor
; + }, +})); + import React from 'react'; import { shallow } from 'enzyme'; diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_size_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_size_property.js index f2e5672226814..5a4da1a80c918 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_size_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_size_property.js @@ -5,7 +5,7 @@ */ import { DynamicStyleProperty } from './dynamic_style_property'; -import { getComputedFieldName } from '../style_util'; + import { HALF_LARGE_MAKI_ICON_SIZE, LARGE_MAKI_ICON_SIZE, @@ -63,7 +63,7 @@ export class DynamicSizeProperty extends DynamicStyleProperty { } syncHaloWidthWithMb(mbLayerId, mbMap) { - const haloWidth = this._getMbSize(); + const haloWidth = this.getMbSizeExpression(); mbMap.setPaintProperty(mbLayerId, 'icon-halo-width', haloWidth); } @@ -76,7 +76,7 @@ export class DynamicSizeProperty extends DynamicStyleProperty { mbMap.setLayoutProperty(symbolLayerId, 'icon-image', `${symbolId}-${iconPixels}`); const halfIconPixels = iconPixels / 2; - const targetName = getComputedFieldName(VECTOR_STYLES.ICON_SIZE, this._options.field.name); + const targetName = this.getComputedFieldName(); // Using property state instead of feature-state because layout properties do not support feature-state mbMap.setLayoutProperty(symbolLayerId, 'icon-size', [ 'interpolate', @@ -94,29 +94,29 @@ export class DynamicSizeProperty extends DynamicStyleProperty { } syncCircleStrokeWidthWithMb(mbLayerId, mbMap) { - const lineWidth = this._getMbSize(); + const lineWidth = this.getMbSizeExpression(); mbMap.setPaintProperty(mbLayerId, 'circle-stroke-width', lineWidth); } syncCircleRadiusWithMb(mbLayerId, mbMap) { - const circleRadius = this._getMbSize(); + const circleRadius = this.getMbSizeExpression(); mbMap.setPaintProperty(mbLayerId, 'circle-radius', circleRadius); } syncLineWidthWithMb(mbLayerId, mbMap) { - const lineWidth = this._getMbSize(); + const lineWidth = this.getMbSizeExpression(); mbMap.setPaintProperty(mbLayerId, 'line-width', lineWidth); } syncLabelSizeWithMb(mbLayerId, mbMap) { - const lineWidth = this._getMbSize(); + const lineWidth = this.getMbSizeExpression(); mbMap.setLayoutProperty(mbLayerId, 'text-size', lineWidth); } - _getMbSize() { + getMbSizeExpression() { if (this._isSizeDynamicConfigComplete(this._options)) { return this._getMbDataDrivenSize({ - targetName: getComputedFieldName(this._styleName, this._options.field.name), + targetName: this.getComputedFieldName(), minSize: this._options.minSize, maxSize: this._options.maxSize, }); diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js index cb5858fa47b3e..97ab7cb78015b 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js @@ -8,7 +8,7 @@ import _ from 'lodash'; import { AbstractStyleProperty } from './style_property'; import { DEFAULT_SIGMA } from '../vector_style_defaults'; import { STYLE_TYPE } from '../../../../../common/constants'; -import { scaleValue } from '../style_util'; +import { scaleValue, getComputedFieldName } from '../style_util'; import React from 'react'; import { OrdinalLegend } from './components/ordinal_legend'; import { CategoricalLegend } from './components/categorical_legend'; @@ -31,6 +31,13 @@ export class DynamicStyleProperty extends AbstractStyleProperty { return this._field; } + getComputedFieldName() { + if (!this.isComplete()) { + return null; + } + return getComputedFieldName(this._styleName, this.getField().getName()); + } + isDynamic() { return true; } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/label_border_size_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/label_border_size_property.js new file mode 100644 index 0000000000000..e08c2875c310e --- /dev/null +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/label_border_size_property.js @@ -0,0 +1,50 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import _ from 'lodash'; +import { AbstractStyleProperty } from './style_property'; +import { DEFAULT_LABEL_SIZE, LABEL_BORDER_SIZES } from '../vector_style_defaults'; + +const SMALL_SIZE = 1 / 16; +const MEDIUM_SIZE = 1 / 8; +const LARGE_SIZE = 1 / 5; // halo of 1/4 is just a square. Use smaller ratio to preserve contour on letters + +function getWidthRatio(size) { + switch (size) { + case LABEL_BORDER_SIZES.LARGE: + return LARGE_SIZE; + case LABEL_BORDER_SIZES.MEDIUM: + return MEDIUM_SIZE; + default: + return SMALL_SIZE; + } +} + +export class LabelBorderSizeProperty extends AbstractStyleProperty { + constructor(options, styleName, labelSizeProperty) { + super(options, styleName); + this._labelSizeProperty = labelSizeProperty; + } + + syncLabelBorderSizeWithMb(mbLayerId, mbMap) { + const widthRatio = getWidthRatio(this.getOptions().size); + + if (this.getOptions().size === LABEL_BORDER_SIZES.NONE) { + mbMap.setPaintProperty(mbLayerId, 'text-halo-width', 0); + } else if (this._labelSizeProperty.isDynamic() && this._labelSizeProperty.isComplete()) { + const labelSizeExpression = this._labelSizeProperty.getMbSizeExpression(); + mbMap.setPaintProperty(mbLayerId, 'text-halo-width', [ + 'max', + ['*', labelSizeExpression, widthRatio], + 1, + ]); + } else { + const labelSize = _.get(this._labelSizeProperty.getOptions(), 'size', DEFAULT_LABEL_SIZE); + const labelBorderSize = Math.max(labelSize * widthRatio, 1); + mbMap.setPaintProperty(mbLayerId, 'text-halo-width', labelBorderSize); + } + } +} diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/static_color_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/static_color_property.js index 658eb6a164556..ebe2a322711fc 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/static_color_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/static_color_property.js @@ -39,4 +39,8 @@ export class StaticColorProperty extends StaticStyleProperty { mbMap.setPaintProperty(mbLayerId, 'text-color', this._options.color); mbMap.setPaintProperty(mbLayerId, 'text-opacity', alpha); } + + syncLabelBorderColorWithMb(mbLayerId, mbMap) { + mbMap.setPaintProperty(mbLayerId, 'text-halo-color', this._options.color); + } } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style.js index d1efcbb72d1a7..30d1c5726ba48 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style.js @@ -38,6 +38,7 @@ import { StaticOrientationProperty } from './properties/static_orientation_prope import { DynamicOrientationProperty } from './properties/dynamic_orientation_property'; import { StaticTextProperty } from './properties/static_text_property'; import { DynamicTextProperty } from './properties/dynamic_text_property'; +import { LabelBorderSizeProperty } from './properties/label_border_size_property'; import { extractColorFromStyleProperty } from './components/legend/extract_color_from_style_property'; const POINTS = [GEO_JSON_TYPE.POINT, GEO_JSON_TYPE.MULTI_POINT]; @@ -100,6 +101,15 @@ export class VectorStyle extends AbstractStyle { this._descriptor.properties[VECTOR_STYLES.LABEL_COLOR], VECTOR_STYLES.LABEL_COLOR ); + this._labelBorderColorStyleProperty = this._makeColorProperty( + this._descriptor.properties[VECTOR_STYLES.LABEL_BORDER_COLOR], + VECTOR_STYLES.LABEL_BORDER_COLOR + ); + this._labelBorderSizeStyleProperty = new LabelBorderSizeProperty( + this._descriptor.properties[VECTOR_STYLES.LABEL_BORDER_SIZE].options, + VECTOR_STYLES.LABEL_BORDER_SIZE, + this._labelSizeStyleProperty + ); } _getAllStyleProperties() { @@ -112,6 +122,8 @@ export class VectorStyle extends AbstractStyle { this._labelStyleProperty, this._labelSizeStyleProperty, this._labelColorStyleProperty, + this._labelBorderColorStyleProperty, + this._labelBorderSizeStyleProperty, ]; } @@ -537,6 +549,8 @@ export class VectorStyle extends AbstractStyle { this._labelStyleProperty.syncTextFieldWithMb(textLayerId, mbMap); this._labelColorStyleProperty.syncLabelColorWithMb(textLayerId, mbMap, alpha); this._labelSizeStyleProperty.syncLabelSizeWithMb(textLayerId, mbMap); + this._labelBorderSizeStyleProperty.syncLabelBorderSizeWithMb(textLayerId, mbMap); + this._labelBorderColorStyleProperty.syncLabelBorderColorWithMb(textLayerId, mbMap); } setMBSymbolPropertiesForPoints({ mbMap, symbolLayerId, alpha }) { diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style.test.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style.test.js index 3d2911720c312..c250d83720580 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style.test.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style.test.js @@ -102,6 +102,17 @@ describe('getDescriptorWithMissingStylePropsRemoved', () => { }, type: 'STATIC', }, + labelBorderColor: { + options: { + color: '#FFFFFF', + }, + type: 'STATIC', + }, + labelBorderSize: { + options: { + size: 'SMALL', + }, + }, labelColor: { options: { color: '#000000', diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style_defaults.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style_defaults.js index 4bae90c3165f2..3631613e7907c 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style_defaults.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/vector_style_defaults.js @@ -16,6 +16,14 @@ export const MAX_SIZE = 64; export const DEFAULT_MIN_SIZE = 4; export const DEFAULT_MAX_SIZE = 32; export const DEFAULT_SIGMA = 3; +export const DEFAULT_LABEL_SIZE = 14; + +export const LABEL_BORDER_SIZES = { + NONE: 'NONE', + SMALL: 'SMALL', + MEDIUM: 'MEDIUM', + LARGE: 'LARGE', +}; export const VECTOR_STYLES = { SYMBOL: 'symbol', @@ -27,6 +35,8 @@ export const VECTOR_STYLES = { LABEL_TEXT: 'labelText', LABEL_COLOR: 'labelColor', LABEL_SIZE: 'labelSize', + LABEL_BORDER_COLOR: 'labelBorderColor', + LABEL_BORDER_SIZE: 'labelBorderSize', }; export const LINE_STYLES = [VECTOR_STYLES.LINE_COLOR, VECTOR_STYLES.LINE_WIDTH]; @@ -45,6 +55,11 @@ export function getDefaultProperties(mapColors = []) { symbolId: DEFAULT_ICON, }, }, + [VECTOR_STYLES.LABEL_BORDER_SIZE]: { + options: { + size: LABEL_BORDER_SIZES.SMALL, + }, + }, }; } @@ -103,7 +118,13 @@ export function getDefaultStaticProperties(mapColors = []) { [VECTOR_STYLES.LABEL_SIZE]: { type: VectorStyle.STYLE_TYPE.STATIC, options: { - size: 14, + size: DEFAULT_LABEL_SIZE, + }, + }, + [VECTOR_STYLES.LABEL_BORDER_COLOR]: { + type: VectorStyle.STYLE_TYPE.STATIC, + options: { + color: isDarkMode ? '#000000' : '#FFFFFF', }, }, }; @@ -158,7 +179,7 @@ export function getDefaultDynamicProperties() { }, }, [VECTOR_STYLES.ICON_ORIENTATION]: { - type: VectorStyle.STYLE_TYPE.STATIC, + type: VectorStyle.STYLE_TYPE.DYNAMIC, options: { field: undefined, fieldMetaOptions: { @@ -168,13 +189,13 @@ export function getDefaultDynamicProperties() { }, }, [VECTOR_STYLES.LABEL_TEXT]: { - type: VectorStyle.STYLE_TYPE.STATIC, + type: VectorStyle.STYLE_TYPE.DYNAMIC, options: { field: undefined, }, }, [VECTOR_STYLES.LABEL_COLOR]: { - type: VectorStyle.STYLE_TYPE.STATIC, + type: VectorStyle.STYLE_TYPE.DYNAMIC, options: { color: COLOR_GRADIENTS[0].value, field: undefined, @@ -185,7 +206,7 @@ export function getDefaultDynamicProperties() { }, }, [VECTOR_STYLES.LABEL_SIZE]: { - type: VectorStyle.STYLE_TYPE.STATIC, + type: VectorStyle.STYLE_TYPE.DYNAMIC, options: { minSize: DEFAULT_MIN_SIZE, maxSize: DEFAULT_MAX_SIZE, @@ -196,5 +217,16 @@ export function getDefaultDynamicProperties() { }, }, }, + [VECTOR_STYLES.LABEL_BORDER_COLOR]: { + type: VectorStyle.STYLE_TYPE.DYNAMIC, + options: { + color: COLOR_GRADIENTS[0].value, + field: undefined, + fieldMetaOptions: { + isEnabled: true, + sigma: DEFAULT_SIGMA, + }, + }, + }, }; } From d879ae8dc0fc078cf253a262687f2135fdd94ace Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Mon, 13 Jan 2020 16:50:47 -0500 Subject: [PATCH 059/139] dont create row with duplicate value --- .../components/color/color_stops_utils.js | 35 +++++++++++-------- 1 file changed, 20 insertions(+), 15 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js index 8bf0ab7babf55..611791673c8d3 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js @@ -17,6 +17,9 @@ import { COLOR_MAP_TYPE } from '../../../../../../common/constants'; import { i18n } from '@kbn/i18n'; import _ from 'lodash'; +export const DEFAULT_CUSTOM_COLOR = '#FF0000'; +export const DEFAULT_NEXT_COLOR = '#00FF00'; + export function removeRow(colorStops, index) { if (colorStops.length === 1) { return colorStops; @@ -35,23 +38,28 @@ export function addCategoricalRow(colorStops, index) { export function addRow(colorStops, index, colorMapType) { const currentStop = colorStops[index].stop; - let delta = 1; - if (index === colorStops.length - 1) { - // Adding row to end of list. - if (index !== 0) { - const prevStop = colorStops[index - 1].stop; - delta = currentStop - prevStop; + + let nextValue; + if (colorMapType === COLOR_MAP_TYPE.ORDINAL) { + let delta = 1; + if (index === colorStops.length - 1) { + // Adding row to end of list. + if (index !== 0) { + const prevStop = colorStops[index - 1].stop; + delta = currentStop - prevStop; + } + } else { + // Adding row in middle of list. + const nextStop = colorStops[index + 1].stop; + delta = (nextStop - currentStop) / 2; } + nextValue = currentStop + delta; } else { - // Adding row in middle of list. - const nextStop = colorStops[index + 1].stop; - delta = (nextStop - currentStop) / 2; + nextValue = currentStop === '' ? currentStop + 'a' : ''; } - - const nextValue = colorMapType === COLOR_MAP_TYPE.ORDINAL ? currentStop + delta : currentStop; const newRow = { stop: nextValue, - color: '#FF0000', + color: DEFAULT_CUSTOM_COLOR, }; return [...colorStops.slice(0, index + 1), newRow, ...colorStops.slice(index + 1)]; } @@ -145,6 +153,3 @@ export function getOtherCategoryLabel() { defaultMessage: 'Other', }); } - -export const DEFAULT_CUSTOM_COLOR = '#FF0000'; -export const DEFAULT_NEXT_COLOR = '#00FF00'; From aa16a9d455c5cc91cd7c36bcc839373ae65e0905 Mon Sep 17 00:00:00 2001 From: Liza Katz Date: Mon, 13 Jan 2020 23:54:41 +0200 Subject: [PATCH 060/139] Support "Deprecated" label in advanced settings (#54539) * Support deprecating label in advanced settings mark courier:batchSearches as deprecated * jest update * Add deprecation to UiSettingsParams type Translate click aria label Use docLinks service * Rename doc link * Remove url option from DeprecationSettings * Simplify code * Updated docs * Revert "Updated docs" This reverts commit c9512ced1f24c315d9bf088ea7d73bdb5e49c0f3. * snapshots * docs --- ...gin-server.uisettingsparams.deprecation.md | 13 +++++++ .../kibana-plugin-server.uisettingsparams.md | 1 + .../public/doc_links/doc_links_service.ts | 3 ++ src/core/server/server.api.md | 2 ++ src/core/server/ui_settings/types.ts | 11 ++++++ .../advanced_settings.test.js.snap | 30 ++++++++++++++++ .../settings/components/field/field.js | 34 +++++++++++++++++++ .../settings/lib/to_editable_config.js | 1 + .../kibana/ui_setting_defaults.js | 6 ++++ .../language_switcher.test.tsx.snap | 6 ++++ .../query_string_input.test.tsx.snap | 18 ++++++++++ 11 files changed, 125 insertions(+) create mode 100644 docs/development/core/server/kibana-plugin-server.uisettingsparams.deprecation.md diff --git a/docs/development/core/server/kibana-plugin-server.uisettingsparams.deprecation.md b/docs/development/core/server/kibana-plugin-server.uisettingsparams.deprecation.md new file mode 100644 index 0000000000000..7ad26b85bf81c --- /dev/null +++ b/docs/development/core/server/kibana-plugin-server.uisettingsparams.deprecation.md @@ -0,0 +1,13 @@ + + +[Home](./index.md) > [kibana-plugin-server](./kibana-plugin-server.md) > [UiSettingsParams](./kibana-plugin-server.uisettingsparams.md) > [deprecation](./kibana-plugin-server.uisettingsparams.deprecation.md) + +## UiSettingsParams.deprecation property + +optional deprecation information. Used to generate a deprecation warning. + +Signature: + +```typescript +deprecation?: DeprecationSettings; +``` diff --git a/docs/development/core/server/kibana-plugin-server.uisettingsparams.md b/docs/development/core/server/kibana-plugin-server.uisettingsparams.md index 89eb5b10b9de5..fc2f8038f973f 100644 --- a/docs/development/core/server/kibana-plugin-server.uisettingsparams.md +++ b/docs/development/core/server/kibana-plugin-server.uisettingsparams.md @@ -17,6 +17,7 @@ export interface UiSettingsParams | Property | Type | Description | | --- | --- | --- | | [category](./kibana-plugin-server.uisettingsparams.category.md) | string[] | used to group the configured setting in the UI | +| [deprecation](./kibana-plugin-server.uisettingsparams.deprecation.md) | DeprecationSettings | optional deprecation information. Used to generate a deprecation warning. | | [description](./kibana-plugin-server.uisettingsparams.description.md) | string | description provided to a user in UI | | [name](./kibana-plugin-server.uisettingsparams.name.md) | string | title in the UI | | [optionLabels](./kibana-plugin-server.uisettingsparams.optionlabels.md) | Record<string, string> | text labels for 'select' type UI element | diff --git a/src/core/public/doc_links/doc_links_service.ts b/src/core/public/doc_links/doc_links_service.ts index 44dc76bfe6e32..36b220f16f395 100644 --- a/src/core/public/doc_links/doc_links_service.ts +++ b/src/core/public/doc_links/doc_links_service.ts @@ -115,6 +115,9 @@ export class DocLinksService { date: { dateMath: `${ELASTICSEARCH_DOCS}common-options.html#date-math`, }, + management: { + kibanaSearchSettings: `${ELASTIC_WEBSITE_URL}guide/en/kibana/${DOC_LINK_VERSION}/advanced-options.html#kibana-search-settings`, + }, }, }); } diff --git a/src/core/server/server.api.md b/src/core/server/server.api.md index 65477e93e225e..7f3a960571012 100644 --- a/src/core/server/server.api.md +++ b/src/core/server/server.api.md @@ -1928,6 +1928,8 @@ export type SharedGlobalConfig = RecursiveReadonly_2<{ // @public export interface UiSettingsParams { category?: string[]; + // Warning: (ae-forgotten-export) The symbol "DeprecationSettings" needs to be exported by the entry point index.d.ts + deprecation?: DeprecationSettings; description?: string; name?: string; optionLabels?: Record; diff --git a/src/core/server/ui_settings/types.ts b/src/core/server/ui_settings/types.ts index 2ab6114e7df88..14eb71a22cefc 100644 --- a/src/core/server/ui_settings/types.ts +++ b/src/core/server/ui_settings/types.ts @@ -73,6 +73,15 @@ export interface UserProvidedValues { isOverridden?: boolean; } +/** + * UiSettings deprecation field options. + * @public + * */ +export interface DeprecationSettings { + message: string; + docLinksKey: string; +} + /** * UI element type to represent the settings. * @public @@ -102,6 +111,8 @@ export interface UiSettingsParams { readonly?: boolean; /** defines a type of UI element {@link UiSettingsType} */ type?: UiSettingsType; + /** optional deprecation information. Used to generate a deprecation warning. */ + deprecation?: DeprecationSettings; /* * Allows defining a custom validation applicable to value change on the client. * @deprecated diff --git a/src/legacy/core_plugins/kibana/public/management/sections/settings/__snapshots__/advanced_settings.test.js.snap b/src/legacy/core_plugins/kibana/public/management/sections/settings/__snapshots__/advanced_settings.test.js.snap index 10d165d0d69c4..eef8f3fc93d90 100644 --- a/src/legacy/core_plugins/kibana/public/management/sections/settings/__snapshots__/advanced_settings.test.js.snap +++ b/src/legacy/core_plugins/kibana/public/management/sections/settings/__snapshots__/advanced_settings.test.js.snap @@ -60,6 +60,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "defVal": Array [ "default_value", ], + "deprecation": undefined, "description": "Description for Test array setting", "displayName": "Test array setting", "isCustom": undefined, @@ -79,6 +80,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "elasticsearch", ], "defVal": true, + "deprecation": undefined, "description": "Description for Test boolean setting", "displayName": "Test boolean setting", "isCustom": undefined, @@ -100,6 +102,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "general", ], "defVal": null, + "deprecation": undefined, "description": "Description for Test custom string setting", "displayName": "Test custom string setting", "isCustom": undefined, @@ -119,6 +122,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "general", ], "defVal": null, + "deprecation": undefined, "description": "Description for Test image setting", "displayName": "Test image setting", "isCustom": undefined, @@ -140,6 +144,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "defVal": "{ \\"foo\\": \\"bar\\" }", + "deprecation": undefined, "description": "Description for overridden json", "displayName": "An overridden json", "isCustom": undefined, @@ -159,6 +164,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "general", ], "defVal": 1234, + "deprecation": undefined, "description": "Description for overridden number", "displayName": "An overridden number", "isCustom": undefined, @@ -178,6 +184,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "general", ], "defVal": "orange", + "deprecation": undefined, "description": "Description for overridden select setting", "displayName": "Test overridden select setting", "isCustom": undefined, @@ -201,6 +208,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "general", ], "defVal": "foo", + "deprecation": undefined, "description": "Description for overridden string", "displayName": "An overridden string", "isCustom": undefined, @@ -220,6 +228,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "general", ], "defVal": "{\\"foo\\": \\"bar\\"}", + "deprecation": undefined, "description": "Description for Test json setting", "displayName": "Test json setting", "isCustom": undefined, @@ -239,6 +248,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "general", ], "defVal": "", + "deprecation": undefined, "description": "Description for Test markdown setting", "displayName": "Test markdown setting", "isCustom": undefined, @@ -258,6 +268,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "general", ], "defVal": 5, + "deprecation": undefined, "description": "Description for Test number setting", "displayName": "Test number setting", "isCustom": undefined, @@ -277,6 +288,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "general", ], "defVal": "orange", + "deprecation": undefined, "description": "Description for Test select setting", "displayName": "Test select setting", "isCustom": undefined, @@ -300,6 +312,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "general", ], "defVal": null, + "deprecation": undefined, "description": "Description for Test string setting", "displayName": "Test string setting", "isCustom": undefined, @@ -345,6 +358,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "defVal": Array [ "default_value", ], + "deprecation": undefined, "description": "Description for Test array setting", "displayName": "Test array setting", "isCustom": undefined, @@ -364,6 +378,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "elasticsearch", ], "defVal": true, + "deprecation": undefined, "description": "Description for Test boolean setting", "displayName": "Test boolean setting", "isCustom": undefined, @@ -385,6 +400,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "general", ], "defVal": null, + "deprecation": undefined, "description": "Description for Test custom string setting", "displayName": "Test custom string setting", "isCustom": undefined, @@ -404,6 +420,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "general", ], "defVal": null, + "deprecation": undefined, "description": "Description for Test image setting", "displayName": "Test image setting", "isCustom": undefined, @@ -425,6 +442,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "defVal": "{ \\"foo\\": \\"bar\\" }", + "deprecation": undefined, "description": "Description for overridden json", "displayName": "An overridden json", "isCustom": undefined, @@ -444,6 +462,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "general", ], "defVal": 1234, + "deprecation": undefined, "description": "Description for overridden number", "displayName": "An overridden number", "isCustom": undefined, @@ -463,6 +482,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "general", ], "defVal": "orange", + "deprecation": undefined, "description": "Description for overridden select setting", "displayName": "Test overridden select setting", "isCustom": undefined, @@ -486,6 +506,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "general", ], "defVal": "foo", + "deprecation": undefined, "description": "Description for overridden string", "displayName": "An overridden string", "isCustom": undefined, @@ -505,6 +526,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "general", ], "defVal": "{\\"foo\\": \\"bar\\"}", + "deprecation": undefined, "description": "Description for Test json setting", "displayName": "Test json setting", "isCustom": undefined, @@ -524,6 +546,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "general", ], "defVal": "", + "deprecation": undefined, "description": "Description for Test markdown setting", "displayName": "Test markdown setting", "isCustom": undefined, @@ -543,6 +566,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "general", ], "defVal": 5, + "deprecation": undefined, "description": "Description for Test number setting", "displayName": "Test number setting", "isCustom": undefined, @@ -562,6 +586,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "general", ], "defVal": "orange", + "deprecation": undefined, "description": "Description for Test select setting", "displayName": "Test select setting", "isCustom": undefined, @@ -585,6 +610,7 @@ exports[`AdvancedSettings should render normally 1`] = ` "general", ], "defVal": null, + "deprecation": undefined, "description": "Description for Test string setting", "displayName": "Test string setting", "isCustom": undefined, @@ -705,6 +731,7 @@ exports[`AdvancedSettings should render read-only when saving is disabled 1`] = "general", ], "defVal": null, + "deprecation": undefined, "description": "Description for Test string setting", "displayName": "Test string setting", "isCustom": undefined, @@ -748,6 +775,7 @@ exports[`AdvancedSettings should render read-only when saving is disabled 1`] = "general", ], "defVal": null, + "deprecation": undefined, "description": "Description for Test string setting", "displayName": "Test string setting", "isCustom": undefined, @@ -886,6 +914,7 @@ exports[`AdvancedSettings should render specific setting if given setting key 1` "general", ], "defVal": null, + "deprecation": undefined, "description": "Description for Test string setting", "displayName": "Test string setting", "isCustom": undefined, @@ -929,6 +958,7 @@ exports[`AdvancedSettings should render specific setting if given setting key 1` "general", ], "defVal": null, + "deprecation": undefined, "description": "Description for Test string setting", "displayName": "Test string setting", "isCustom": undefined, diff --git a/src/legacy/core_plugins/kibana/public/management/sections/settings/components/field/field.js b/src/legacy/core_plugins/kibana/public/management/sections/settings/components/field/field.js index 65d212c23a28c..a2f201cf757f5 100644 --- a/src/legacy/core_plugins/kibana/public/management/sections/settings/components/field/field.js +++ b/src/legacy/core_plugins/kibana/public/management/sections/settings/components/field/field.js @@ -19,12 +19,14 @@ import React, { PureComponent, Fragment } from 'react'; import PropTypes from 'prop-types'; +import { npStart } from 'ui/new_platform'; import 'brace/theme/textmate'; import 'brace/mode/markdown'; import { toastNotifications } from 'ui/notify'; import { + EuiBadge, EuiButton, EuiButtonEmpty, EuiCode, @@ -41,6 +43,7 @@ import { EuiImage, EuiLink, EuiSpacer, + EuiToolTip, EuiText, EuiSelect, EuiSwitch, @@ -565,6 +568,36 @@ export class Field extends PureComponent { renderDescription(setting) { let description; + let deprecation; + + if (setting.deprecation) { + const { links } = npStart.core.docLinks; + + deprecation = ( + <> + + { + window.open(links.management[setting.deprecation.docLinksKey], '_blank'); + }} + onClickAriaLabel={i18n.translate( + 'kbn.management.settings.field.deprecationClickAreaLabel', + { + defaultMessage: 'Click to view deprecation documentation for {settingName}.', + values: { + settingName: setting.name, + }, + } + )} + > + Deprecated + + + + + ); + } if (React.isValidElement(setting.description)) { description = setting.description; @@ -582,6 +615,7 @@ export class Field extends PureComponent { return ( + {deprecation} {description} {this.renderDefaultValue(setting)} diff --git a/src/legacy/core_plugins/kibana/public/management/sections/settings/lib/to_editable_config.js b/src/legacy/core_plugins/kibana/public/management/sections/settings/lib/to_editable_config.js index bb561cbe04212..6efb89cfba2b2 100644 --- a/src/legacy/core_plugins/kibana/public/management/sections/settings/lib/to_editable_config.js +++ b/src/legacy/core_plugins/kibana/public/management/sections/settings/lib/to_editable_config.js @@ -43,6 +43,7 @@ export function toEditableConfig({ def, name, value, isCustom, isOverridden }) { defVal: def.value, type: getValType(def, value), description: def.description, + deprecation: def.deprecation, validation: def.validation && def.validation.regexString ? { diff --git a/src/legacy/core_plugins/kibana/ui_setting_defaults.js b/src/legacy/core_plugins/kibana/ui_setting_defaults.js index 196d9662f8b15..dc8fee4a849c5 100644 --- a/src/legacy/core_plugins/kibana/ui_setting_defaults.js +++ b/src/legacy/core_plugins/kibana/ui_setting_defaults.js @@ -458,6 +458,12 @@ export function getUiSettingDefaults() { away or update the query. When enabled, dashboard panels will load together when all of the data is loaded, and searches will not terminate.`, }), + deprecation: { + message: i18n.translate('kbn.advancedSettings.courier.batchSearchesTextDeprecation', { + defaultMessage: 'This setting is deprecated and will be removed in Kibana 8.0.', + }), + docLinksKey: 'kibanaSearchSettings', + }, category: ['search'], }, 'search:includeFrozen': { diff --git a/src/plugins/data/public/ui/query_string_input/__snapshots__/language_switcher.test.tsx.snap b/src/plugins/data/public/ui/query_string_input/__snapshots__/language_switcher.test.tsx.snap index 7ab7d7653eb5e..4ec29ca409b80 100644 --- a/src/plugins/data/public/ui/query_string_input/__snapshots__/language_switcher.test.tsx.snap +++ b/src/plugins/data/public/ui/query_string_input/__snapshots__/language_switcher.test.tsx.snap @@ -170,6 +170,9 @@ exports[`LanguageSwitcher should toggle off if language is lucene 1`] = ` "logstash": Object { "base": "https://www.elastic.co/guide/en/logstash/mocked-test-branch", }, + "management": Object { + "kibanaSearchSettings": "https://www.elastic.co/guide/en/kibana/mocked-test-branch/advanced-options.html#kibana-search-settings", + }, "metricbeat": Object { "base": "https://www.elastic.co/guide/en/beats/metricbeat/mocked-test-branch", }, @@ -460,6 +463,9 @@ exports[`LanguageSwitcher should toggle on if language is kuery 1`] = ` "logstash": Object { "base": "https://www.elastic.co/guide/en/logstash/mocked-test-branch", }, + "management": Object { + "kibanaSearchSettings": "https://www.elastic.co/guide/en/kibana/mocked-test-branch/advanced-options.html#kibana-search-settings", + }, "metricbeat": Object { "base": "https://www.elastic.co/guide/en/beats/metricbeat/mocked-test-branch", }, diff --git a/src/plugins/data/public/ui/query_string_input/__snapshots__/query_string_input.test.tsx.snap b/src/plugins/data/public/ui/query_string_input/__snapshots__/query_string_input.test.tsx.snap index 6f5f9b3956187..15e74e98920e2 100644 --- a/src/plugins/data/public/ui/query_string_input/__snapshots__/query_string_input.test.tsx.snap +++ b/src/plugins/data/public/ui/query_string_input/__snapshots__/query_string_input.test.tsx.snap @@ -276,6 +276,9 @@ exports[`QueryStringInput Should disable autoFocus on EuiFieldText when disableA "logstash": Object { "base": "https://www.elastic.co/guide/en/logstash/mocked-test-branch", }, + "management": Object { + "kibanaSearchSettings": "https://www.elastic.co/guide/en/kibana/mocked-test-branch/advanced-options.html#kibana-search-settings", + }, "metricbeat": Object { "base": "https://www.elastic.co/guide/en/beats/metricbeat/mocked-test-branch", }, @@ -896,6 +899,9 @@ exports[`QueryStringInput Should disable autoFocus on EuiFieldText when disableA "logstash": Object { "base": "https://www.elastic.co/guide/en/logstash/mocked-test-branch", }, + "management": Object { + "kibanaSearchSettings": "https://www.elastic.co/guide/en/kibana/mocked-test-branch/advanced-options.html#kibana-search-settings", + }, "metricbeat": Object { "base": "https://www.elastic.co/guide/en/beats/metricbeat/mocked-test-branch", }, @@ -1504,6 +1510,9 @@ exports[`QueryStringInput Should pass the query language to the language switche "logstash": Object { "base": "https://www.elastic.co/guide/en/logstash/mocked-test-branch", }, + "management": Object { + "kibanaSearchSettings": "https://www.elastic.co/guide/en/kibana/mocked-test-branch/advanced-options.html#kibana-search-settings", + }, "metricbeat": Object { "base": "https://www.elastic.co/guide/en/beats/metricbeat/mocked-test-branch", }, @@ -2121,6 +2130,9 @@ exports[`QueryStringInput Should pass the query language to the language switche "logstash": Object { "base": "https://www.elastic.co/guide/en/logstash/mocked-test-branch", }, + "management": Object { + "kibanaSearchSettings": "https://www.elastic.co/guide/en/kibana/mocked-test-branch/advanced-options.html#kibana-search-settings", + }, "metricbeat": Object { "base": "https://www.elastic.co/guide/en/beats/metricbeat/mocked-test-branch", }, @@ -2729,6 +2741,9 @@ exports[`QueryStringInput Should render the given query 1`] = ` "logstash": Object { "base": "https://www.elastic.co/guide/en/logstash/mocked-test-branch", }, + "management": Object { + "kibanaSearchSettings": "https://www.elastic.co/guide/en/kibana/mocked-test-branch/advanced-options.html#kibana-search-settings", + }, "metricbeat": Object { "base": "https://www.elastic.co/guide/en/beats/metricbeat/mocked-test-branch", }, @@ -3346,6 +3361,9 @@ exports[`QueryStringInput Should render the given query 1`] = ` "logstash": Object { "base": "https://www.elastic.co/guide/en/logstash/mocked-test-branch", }, + "management": Object { + "kibanaSearchSettings": "https://www.elastic.co/guide/en/kibana/mocked-test-branch/advanced-options.html#kibana-search-settings", + }, "metricbeat": Object { "base": "https://www.elastic.co/guide/en/beats/metricbeat/mocked-test-branch", }, From 6f54c06695e99d3c94c0096d2c2ca3a9a92ac127 Mon Sep 17 00:00:00 2001 From: Garrett Spong Date: Mon, 13 Jan 2020 15:25:24 -0700 Subject: [PATCH 061/139] [SIEM] Use bulk actions API when updating or deleting rules (#54521) ## Summary This PR updates the `All Rules Table` actions to use the new bulk API introduced in https://github.com/elastic/kibana/pull/53543. More robust error reporting has also been added to let the user know exactly which operation has failed. Note that individual `update`/`delete` requests now also go through the bulk API as this simplifies the implementation and error handling. Additional features: * Adds toast error when failing to activate, deactivate or delete a rule (related https://github.com/elastic/kibana/issues/54515) * Extracted commonly used toast utility for better re-use * Removes ability to delete `immutable` rules ##### Activate/Deactivate Before: ![bulk_activate_before](https://user-images.githubusercontent.com/2946766/72196245-0ea50300-33d4-11ea-8d49-5ebdb63db1a1.gif) (Ignore failed requests from test env -- request count is important here) ##### Activate/Deactivate After: ![bulk_activate_after](https://user-images.githubusercontent.com/2946766/72196361-c0443400-33d4-11ea-9a42-11f66c64e925.gif) ##### Delete Before: ![bulk_delete_before](https://user-images.githubusercontent.com/2946766/72196249-149ae400-33d4-11ea-80fc-b2f7fb83245f.gif) (Ignore failed requests from test env -- request count is important here) ##### Delete After: ![bulk_delete_after](https://user-images.githubusercontent.com/2946766/72196366-c803d880-33d4-11ea-90d8-f1917b18035f.gif) ### Checklist Use ~~strikethroughs~~ to remove checklist items you don't feel are applicable to this PR. - [x] This was checked for cross-browser compatibility, [including a check against IE11](https://github.com/elastic/kibana/blob/master/CONTRIBUTING.md#cross-browser-compatibility) - [x] Any text added follows [EUI's writing guidelines](https://elastic.github.io/eui/#/guidelines/writing), uses sentence case text and includes [i18n support](https://github.com/elastic/kibana/blob/master/packages/kbn-i18n/README.md) - [ ] ~[Documentation](https://github.com/elastic/kibana/blob/master/CONTRIBUTING.md#writing-documentation) was added for features that require explanation or tutorials~ - [x] [Unit or functional tests](https://github.com/elastic/kibana/blob/master/CONTRIBUTING.md#cross-browser-compatibility) were updated or added to match the most common scenarios - [ ] ~This was checked for [keyboard-only and screenreader accessibility](https://developer.mozilla.org/en-US/docs/Learn/Tools_and_testing/Cross_browser_testing/Accessibility#Accessibility_testing_checklist)~ ### For maintainers - [ ] ~This was checked for breaking API changes and was [labeled appropriately](https://github.com/elastic/kibana/blob/master/CONTRIBUTING.md#release-notes-process)~ - [ ] ~This includes a feature addition or change that requires a release note and was [labeled appropriately](https://github.com/elastic/kibana/blob/master/CONTRIBUTING.md#release-notes-process)~ --- .../components/embeddables/embedded_map.tsx | 6 +- .../embeddables/embedded_map_helpers.test.tsx | 27 +-- .../embeddables/embedded_map_helpers.tsx | 26 --- .../public/components/toasters/index.test.tsx | 33 +++- .../siem/public/components/toasters/index.tsx | 26 +++ .../containers/detection_engine/rules/api.ts | 39 ++--- .../detection_engine/rules/types.ts | 12 ++ .../rules/all/__mocks__/mock.ts | 154 ++++++++++++++++++ .../detection_engine/rules/all/actions.tsx | 82 ++++++++-- .../rules/all/batch_actions.tsx | 17 +- .../detection_engine/rules/all/columns.tsx | 18 +- .../rules/all/helpers.test.tsx | 61 +++++++ .../detection_engine/rules/all/helpers.ts | 28 +++- .../detection_engine/rules/all/index.tsx | 45 +++-- .../rules/components/rule_switch/index.tsx | 4 +- .../detection_engine/rules/translations.ts | 41 +++++ .../pages/detection_engine/rules/types.ts | 1 + 17 files changed, 500 insertions(+), 120 deletions(-) create mode 100644 x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/__mocks__/mock.ts create mode 100644 x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/helpers.test.tsx diff --git a/x-pack/legacy/plugins/siem/public/components/embeddables/embedded_map.tsx b/x-pack/legacy/plugins/siem/public/components/embeddables/embedded_map.tsx index b39d43cc01b42..771e220a2a0b3 100644 --- a/x-pack/legacy/plugins/siem/public/components/embeddables/embedded_map.tsx +++ b/x-pack/legacy/plugins/siem/public/components/embeddables/embedded_map.tsx @@ -15,10 +15,10 @@ import { DEFAULT_INDEX_KEY } from '../../../common/constants'; import { getIndexPatternTitleIdMapping } from '../../hooks/api/helpers'; import { useIndexPatterns } from '../../hooks/use_index_patterns'; import { Loader } from '../loader'; -import { useStateToaster } from '../toasters'; +import { displayErrorToast, useStateToaster } from '../toasters'; import { Embeddable } from './embeddable'; import { EmbeddableHeader } from './embeddable_header'; -import { createEmbeddable, displayErrorToast } from './embedded_map_helpers'; +import { createEmbeddable } from './embedded_map_helpers'; import { IndexPatternsMissingPrompt } from './index_patterns_missing_prompt'; import { MapToolTip } from './map_tool_tip/map_tool_tip'; import * as i18n from './translations'; @@ -134,7 +134,7 @@ export const EmbeddedMapComponent = ({ } } catch (e) { if (isSubscribed) { - displayErrorToast(i18n.ERROR_CREATING_EMBEDDABLE, e.message, dispatchToaster); + displayErrorToast(i18n.ERROR_CREATING_EMBEDDABLE, [e.message], dispatchToaster); setIsError(true); } } diff --git a/x-pack/legacy/plugins/siem/public/components/embeddables/embedded_map_helpers.test.tsx b/x-pack/legacy/plugins/siem/public/components/embeddables/embedded_map_helpers.test.tsx index 4e5fcee439827..a83e8377deeb6 100644 --- a/x-pack/legacy/plugins/siem/public/components/embeddables/embedded_map_helpers.test.tsx +++ b/x-pack/legacy/plugins/siem/public/components/embeddables/embedded_map_helpers.test.tsx @@ -4,19 +4,12 @@ * you may not use this file except in compliance with the Elastic License. */ -import { createEmbeddable, displayErrorToast } from './embedded_map_helpers'; +import { createEmbeddable } from './embedded_map_helpers'; import { createUiNewPlatformMock } from 'ui/new_platform/__mocks__/helpers'; import { createPortalNode } from 'react-reverse-portal'; jest.mock('ui/new_platform'); -jest.mock('uuid', () => { - return { - v1: jest.fn(() => '27261ae0-0bbb-11ea-b0ea-db767b07ea47'), - v4: jest.fn(() => '9e1f72a9-7c73-4b7f-a562-09940f7daf4a'), - }; -}); - const { npStart } = createUiNewPlatformMock(); npStart.plugins.embeddable.getEmbeddableFactory = jest.fn().mockImplementation(() => ({ createFromState: () => ({ @@ -25,24 +18,6 @@ npStart.plugins.embeddable.getEmbeddableFactory = jest.fn().mockImplementation(( })); describe('embedded_map_helpers', () => { - describe('displayErrorToast', () => { - test('dispatches toast with correct title and message', () => { - const mockToast = { - toast: { - color: 'danger', - errors: ['message'], - iconType: 'alert', - id: '9e1f72a9-7c73-4b7f-a562-09940f7daf4a', - title: 'Title', - }, - type: 'addToaster', - }; - const dispatchToasterMock = jest.fn(); - displayErrorToast('Title', 'message', dispatchToasterMock); - expect(dispatchToasterMock.mock.calls[0][0]).toEqual(mockToast); - }); - }); - describe('createEmbeddable', () => { test('attaches refresh action', async () => { const setQueryMock = jest.fn(); diff --git a/x-pack/legacy/plugins/siem/public/components/embeddables/embedded_map_helpers.tsx b/x-pack/legacy/plugins/siem/public/components/embeddables/embedded_map_helpers.tsx index b9a9df9824eee..838e74cc5624c 100644 --- a/x-pack/legacy/plugins/siem/public/components/embeddables/embedded_map_helpers.tsx +++ b/x-pack/legacy/plugins/siem/public/components/embeddables/embedded_map_helpers.tsx @@ -7,7 +7,6 @@ import uuid from 'uuid'; import React from 'react'; import { OutPortal, PortalNode } from 'react-reverse-portal'; -import { ActionToaster, AppToast } from '../toasters'; import { ViewMode } from '../../../../../../../src/legacy/core_plugins/embeddable_api/public/np_ready/public'; import { IndexPatternMapping, @@ -22,31 +21,6 @@ import { MAP_SAVED_OBJECT_TYPE } from '../../../../maps/common/constants'; import * as i18n from './translations'; import { Query, esFilters } from '../../../../../../../src/plugins/data/public'; -/** - * Displays an error toast for the provided title and message - * - * @param errorTitle Title of error to display in toaster and modal - * @param errorMessage Message to display in error modal when clicked - * @param dispatchToaster provided by useStateToaster() - */ -export const displayErrorToast = ( - errorTitle: string, - errorMessage: string, - dispatchToaster: React.Dispatch -) => { - const toast: AppToast = { - id: uuid.v4(), - title: errorTitle, - color: 'danger', - iconType: 'alert', - errors: [errorMessage], - }; - dispatchToaster({ - type: 'addToaster', - toast, - }); -}; - /** * Creates MapEmbeddable with provided initial configuration * diff --git a/x-pack/legacy/plugins/siem/public/components/toasters/index.test.tsx b/x-pack/legacy/plugins/siem/public/components/toasters/index.test.tsx index 5ef5a5ab31d4b..9338eb9f0fabd 100644 --- a/x-pack/legacy/plugins/siem/public/components/toasters/index.test.tsx +++ b/x-pack/legacy/plugins/siem/public/components/toasters/index.test.tsx @@ -8,7 +8,20 @@ import { cloneDeep, set } from 'lodash/fp'; import { mount } from 'enzyme'; import React, { useEffect } from 'react'; -import { AppToast, useStateToaster, ManageGlobalToaster, GlobalToaster } from '.'; +import { + AppToast, + useStateToaster, + ManageGlobalToaster, + GlobalToaster, + displayErrorToast, +} from '.'; + +jest.mock('uuid', () => { + return { + v1: jest.fn(() => '27261ae0-0bbb-11ea-b0ea-db767b07ea47'), + v4: jest.fn(() => '9e1f72a9-7c73-4b7f-a562-09940f7daf4a'), + }; +}); const mockToast: AppToast = { color: 'danger', @@ -270,4 +283,22 @@ describe('Toaster', () => { expect(wrapper.find('.euiToastHeader__title').text()).toBe('Test & Test'); }); }); + + describe('displayErrorToast', () => { + test('dispatches toast with correct title and message', () => { + const mockErrorToast = { + toast: { + color: 'danger', + errors: ['message'], + iconType: 'alert', + id: '9e1f72a9-7c73-4b7f-a562-09940f7daf4a', + title: 'Title', + }, + type: 'addToaster', + }; + const dispatchToasterMock = jest.fn(); + displayErrorToast('Title', ['message'], dispatchToasterMock); + expect(dispatchToasterMock.mock.calls[0][0]).toEqual(mockErrorToast); + }); + }); }); diff --git a/x-pack/legacy/plugins/siem/public/components/toasters/index.tsx b/x-pack/legacy/plugins/siem/public/components/toasters/index.tsx index 27d59d429913c..7098e618aeb55 100644 --- a/x-pack/legacy/plugins/siem/public/components/toasters/index.tsx +++ b/x-pack/legacy/plugins/siem/public/components/toasters/index.tsx @@ -8,6 +8,7 @@ import { EuiGlobalToastList, EuiGlobalToastListToast as Toast, EuiButton } from import { noop } from 'lodash/fp'; import React, { createContext, Dispatch, useReducer, useContext, useState } from 'react'; import styled from 'styled-components'; +import uuid from 'uuid'; import { ModalAllErrors } from './modal_all_errors'; import * as i18n from './translations'; @@ -122,3 +123,28 @@ const ErrorToastContainer = styled.div` `; ErrorToastContainer.displayName = 'ErrorToastContainer'; + +/** + * Displays an error toast for the provided title and message + * + * @param errorTitle Title of error to display in toaster and modal + * @param errorMessages Message to display in error modal when clicked + * @param dispatchToaster provided by useStateToaster() + */ +export const displayErrorToast = ( + errorTitle: string, + errorMessages: string[], + dispatchToaster: React.Dispatch +) => { + const toast: AppToast = { + id: uuid.v4(), + title: errorTitle, + color: 'danger', + iconType: 'alert', + errors: errorMessages, + }; + dispatchToaster({ + type: 'addToaster', + toast, + }); +}; diff --git a/x-pack/legacy/plugins/siem/public/containers/detection_engine/rules/api.ts b/x-pack/legacy/plugins/siem/public/containers/detection_engine/rules/api.ts index b69a8de29e047..8f8b66ae35a3b 100644 --- a/x-pack/legacy/plugins/siem/public/containers/detection_engine/rules/api.ts +++ b/x-pack/legacy/plugins/siem/public/containers/detection_engine/rules/api.ts @@ -16,6 +16,7 @@ import { Rule, FetchRuleProps, BasicFetchProps, + RuleError, } from './types'; import { throwIfNotOk } from '../../../hooks/api/api'; import { @@ -122,50 +123,50 @@ export const fetchRuleById = async ({ id, signal }: FetchRuleProps): Promise => { - const requests = ids.map(id => - fetch(`${chrome.getBasePath()}${DETECTION_ENGINE_RULES_URL}`, { + const response = await fetch( + `${chrome.getBasePath()}${DETECTION_ENGINE_RULES_URL}/_bulk_update`, + { method: 'PUT', credentials: 'same-origin', headers: { 'content-type': 'application/json', 'kbn-xsrf': 'true', }, - body: JSON.stringify({ id, enabled }), - }) + body: JSON.stringify(ids.map(id => ({ id, enabled }))), + } ); - const responses = await Promise.all(requests); - await responses.map(response => throwIfNotOk(response)); - return Promise.all( - responses.map>(response => response.json()) - ); + await throwIfNotOk(response); + return response.json(); }; /** * Deletes provided Rule ID's * * @param ids array of Rule ID's (not rule_id) to delete + * + * @throws An error if response is not OK */ -export const deleteRules = async ({ ids }: DeleteRulesProps): Promise => { - // TODO: Don't delete if immutable! - const requests = ids.map(id => - fetch(`${chrome.getBasePath()}${DETECTION_ENGINE_RULES_URL}?id=${id}`, { +export const deleteRules = async ({ ids }: DeleteRulesProps): Promise> => { + const response = await fetch( + `${chrome.getBasePath()}${DETECTION_ENGINE_RULES_URL}/_bulk_delete`, + { method: 'DELETE', credentials: 'same-origin', headers: { 'content-type': 'application/json', 'kbn-xsrf': 'true', }, - }) + body: JSON.stringify(ids.map(id => ({ id }))), + } ); - const responses = await Promise.all(requests); - await responses.map(response => throwIfNotOk(response)); - return Promise.all( - responses.map>(response => response.json()) - ); + await throwIfNotOk(response); + return response.json(); }; /** diff --git a/x-pack/legacy/plugins/siem/public/containers/detection_engine/rules/types.ts b/x-pack/legacy/plugins/siem/public/containers/detection_engine/rules/types.ts index a329d96d444aa..147b04567f6c7 100644 --- a/x-pack/legacy/plugins/siem/public/containers/detection_engine/rules/types.ts +++ b/x-pack/legacy/plugins/siem/public/containers/detection_engine/rules/types.ts @@ -78,9 +78,11 @@ export const RuleSchema = t.intersection([ updated_by: t.string, }), t.partial({ + output_index: t.string, saved_id: t.string, timeline_id: t.string, timeline_title: t.string, + version: t.number, }), ]); @@ -89,6 +91,16 @@ export const RulesSchema = t.array(RuleSchema); export type Rule = t.TypeOf; export type Rules = t.TypeOf; +export interface RuleError { + rule_id: string; + error: { status_code: number; message: string }; +} + +export interface RuleResponseBuckets { + rules: Rule[]; + errors: RuleError[]; +} + export interface PaginationOptions { page: number; perPage: number; diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/__mocks__/mock.ts b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/__mocks__/mock.ts new file mode 100644 index 0000000000000..3762cb0a4ba07 --- /dev/null +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/__mocks__/mock.ts @@ -0,0 +1,154 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { Rule, RuleError } from '../../../../../containers/detection_engine/rules'; +import { TableData } from '../../types'; + +export const mockRule = (id: string): Rule => ({ + created_at: '2020-01-10T21:11:45.839Z', + updated_at: '2020-01-10T21:11:45.839Z', + created_by: 'elastic', + description: '24/7', + enabled: true, + false_positives: [], + filters: [], + from: 'now-300s', + id, + immutable: false, + index: ['auditbeat-*'], + interval: '5m', + rule_id: 'b5ba41ab-aaf3-4f43-971b-bdf9434ce0ea', + language: 'kuery', + output_index: '.siem-signals-default', + max_signals: 100, + risk_score: 21, + name: 'Home Grown!', + query: '', + references: [], + saved_id: "Garrett's IP", + timeline_id: '86aa74d0-2136-11ea-9864-ebc8cc1cb8c2', + timeline_title: 'Untitled timeline', + meta: { from: '0m' }, + severity: 'low', + updated_by: 'elastic', + tags: [], + to: 'now', + type: 'saved_query', + threats: [], + version: 1, +}); + +export const mockRuleError = (id: string): RuleError => ({ + rule_id: id, + error: { status_code: 404, message: `id: "${id}" not found` }, +}); + +export const mockRules: Rule[] = [ + mockRule('abe6c564-050d-45a5-aaf0-386c37dd1f61'), + mockRule('63f06f34-c181-4b2d-af35-f2ace572a1ee'), +]; +export const mockTableData: TableData[] = [ + { + activate: true, + id: 'abe6c564-050d-45a5-aaf0-386c37dd1f61', + immutable: false, + isLoading: false, + lastCompletedRun: undefined, + lastResponse: { type: '—' }, + method: 'saved_query', + rule: { + href: '#/detection-engine/rules/id/abe6c564-050d-45a5-aaf0-386c37dd1f61', + name: 'Home Grown!', + status: 'Status Placeholder', + }, + rule_id: 'b5ba41ab-aaf3-4f43-971b-bdf9434ce0ea', + severity: 'low', + sourceRule: { + created_at: '2020-01-10T21:11:45.839Z', + created_by: 'elastic', + description: '24/7', + enabled: true, + false_positives: [], + filters: [], + from: 'now-300s', + id: 'abe6c564-050d-45a5-aaf0-386c37dd1f61', + immutable: false, + index: ['auditbeat-*'], + interval: '5m', + language: 'kuery', + max_signals: 100, + meta: { from: '0m' }, + name: 'Home Grown!', + output_index: '.siem-signals-default', + query: '', + references: [], + risk_score: 21, + rule_id: 'b5ba41ab-aaf3-4f43-971b-bdf9434ce0ea', + saved_id: "Garrett's IP", + severity: 'low', + tags: [], + threats: [], + timeline_id: '86aa74d0-2136-11ea-9864-ebc8cc1cb8c2', + timeline_title: 'Untitled timeline', + to: 'now', + type: 'saved_query', + updated_at: '2020-01-10T21:11:45.839Z', + updated_by: 'elastic', + version: 1, + }, + tags: [], + }, + { + activate: true, + id: '63f06f34-c181-4b2d-af35-f2ace572a1ee', + immutable: false, + isLoading: false, + lastCompletedRun: undefined, + lastResponse: { type: '—' }, + method: 'saved_query', + rule: { + href: '#/detection-engine/rules/id/63f06f34-c181-4b2d-af35-f2ace572a1ee', + name: 'Home Grown!', + status: 'Status Placeholder', + }, + rule_id: 'b5ba41ab-aaf3-4f43-971b-bdf9434ce0ea', + severity: 'low', + sourceRule: { + created_at: '2020-01-10T21:11:45.839Z', + created_by: 'elastic', + description: '24/7', + enabled: true, + false_positives: [], + filters: [], + from: 'now-300s', + id: '63f06f34-c181-4b2d-af35-f2ace572a1ee', + immutable: false, + index: ['auditbeat-*'], + interval: '5m', + language: 'kuery', + max_signals: 100, + meta: { from: '0m' }, + name: 'Home Grown!', + output_index: '.siem-signals-default', + query: '', + references: [], + risk_score: 21, + rule_id: 'b5ba41ab-aaf3-4f43-971b-bdf9434ce0ea', + saved_id: "Garrett's IP", + severity: 'low', + tags: [], + threats: [], + timeline_id: '86aa74d0-2136-11ea-9864-ebc8cc1cb8c2', + timeline_title: 'Untitled timeline', + to: 'now', + type: 'saved_query', + updated_at: '2020-01-10T21:11:45.839Z', + updated_by: 'elastic', + version: 1, + }, + tags: [], + }, +]; diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/actions.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/actions.tsx index 469745262d944..24e3cfde1e448 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/actions.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/actions.tsx @@ -5,7 +5,7 @@ */ import * as H from 'history'; -import React from 'react'; +import React, { Dispatch } from 'react'; import { DETECTION_ENGINE_PAGE_NAME } from '../../../../components/link_to/redirect_to_detection_engine'; import { @@ -16,40 +16,92 @@ import { } from '../../../../containers/detection_engine/rules'; import { Action } from './reducer'; +import { ActionToaster, displayErrorToast } from '../../../../components/toasters'; + +import * as i18n from '../translations'; +import { bucketRulesResponse } from './helpers'; + export const editRuleAction = (rule: Rule, history: H.History) => { history.push(`/${DETECTION_ENGINE_PAGE_NAME}/rules/id/${rule.id}/edit`); }; export const runRuleAction = () => {}; -export const duplicateRuleAction = async (rule: Rule, dispatch: React.Dispatch) => { - dispatch({ type: 'updateLoading', ids: [rule.id], isLoading: true }); - const duplicatedRule = await duplicateRules({ rules: [rule] }); - dispatch({ type: 'updateLoading', ids: [rule.id], isLoading: false }); - dispatch({ type: 'updateRules', rules: duplicatedRule, appendRuleId: rule.id }); +export const duplicateRuleAction = async ( + rule: Rule, + dispatch: React.Dispatch, + dispatchToaster: Dispatch +) => { + try { + dispatch({ type: 'updateLoading', ids: [rule.id], isLoading: true }); + const duplicatedRule = await duplicateRules({ rules: [rule] }); + dispatch({ type: 'updateLoading', ids: [rule.id], isLoading: false }); + dispatch({ type: 'updateRules', rules: duplicatedRule, appendRuleId: rule.id }); + } catch (e) { + displayErrorToast(i18n.DUPLICATE_RULE_ERROR, [e.message], dispatchToaster); + } }; export const exportRulesAction = async (rules: Rule[], dispatch: React.Dispatch) => { dispatch({ type: 'setExportPayload', exportPayload: rules }); }; -export const deleteRulesAction = async (ids: string[], dispatch: React.Dispatch) => { - dispatch({ type: 'updateLoading', ids, isLoading: true }); - const deletedRules = await deleteRules({ ids }); - dispatch({ type: 'deleteRules', rules: deletedRules }); +export const deleteRulesAction = async ( + ids: string[], + dispatch: React.Dispatch, + dispatchToaster: Dispatch +) => { + try { + dispatch({ type: 'updateLoading', ids, isLoading: true }); + + const response = await deleteRules({ ids }); + const { rules, errors } = bucketRulesResponse(response); + + dispatch({ type: 'deleteRules', rules }); + + if (errors.length > 0) { + displayErrorToast( + i18n.BATCH_ACTION_DELETE_SELECTED_ERROR(ids.length), + errors.map(e => e.error.message), + dispatchToaster + ); + } + } catch (e) { + displayErrorToast( + i18n.BATCH_ACTION_DELETE_SELECTED_ERROR(ids.length), + [e.message], + dispatchToaster + ); + } }; export const enableRulesAction = async ( ids: string[], enabled: boolean, - dispatch: React.Dispatch + dispatch: React.Dispatch, + dispatchToaster: Dispatch ) => { + const errorTitle = enabled + ? i18n.BATCH_ACTION_ACTIVATE_SELECTED_ERROR(ids.length) + : i18n.BATCH_ACTION_DEACTIVATE_SELECTED_ERROR(ids.length); + try { dispatch({ type: 'updateLoading', ids, isLoading: true }); - const updatedRules = await enableRules({ ids, enabled }); - dispatch({ type: 'updateRules', rules: updatedRules }); - } catch { - // TODO Add error toast support to actions (and @throw jsdoc to api calls) + + const response = await enableRules({ ids, enabled }); + const { rules, errors } = bucketRulesResponse(response); + + dispatch({ type: 'updateRules', rules }); + + if (errors.length > 0) { + displayErrorToast( + errorTitle, + errors.map(e => e.error.message), + dispatchToaster + ); + } + } catch (e) { + displayErrorToast(errorTitle, [e.message], dispatchToaster); dispatch({ type: 'updateLoading', ids, isLoading: false }); } }; diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/batch_actions.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/batch_actions.tsx index 72d38454ad9bc..3356ef101677d 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/batch_actions.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/batch_actions.tsx @@ -5,20 +5,23 @@ */ import { EuiContextMenuItem } from '@elastic/eui'; -import React from 'react'; +import React, { Dispatch } from 'react'; import * as i18n from '../translations'; import { TableData } from '../types'; import { Action } from './reducer'; import { deleteRulesAction, enableRulesAction, exportRulesAction } from './actions'; +import { ActionToaster } from '../../../../components/toasters'; export const getBatchItems = ( selectedState: TableData[], - dispatch: React.Dispatch, + dispatch: Dispatch, + dispatchToaster: Dispatch, closePopover: () => void ) => { const containsEnabled = selectedState.some(v => v.activate); const containsDisabled = selectedState.some(v => !v.activate); const containsLoading = selectedState.some(v => v.isLoading); + const containsImmutable = selectedState.some(v => v.immutable); return [ { closePopover(); const deactivatedIds = selectedState.filter(s => !s.activate).map(s => s.id); - await enableRulesAction(deactivatedIds, true, dispatch); + await enableRulesAction(deactivatedIds, true, dispatch, dispatchToaster); }} > {i18n.BATCH_ACTION_ACTIVATE_SELECTED} @@ -40,7 +43,7 @@ export const getBatchItems = ( onClick={async () => { closePopover(); const activatedIds = selectedState.filter(s => s.activate).map(s => s.id); - await enableRulesAction(activatedIds, false, dispatch); + await enableRulesAction(activatedIds, false, dispatch, dispatchToaster); }} > {i18n.BATCH_ACTION_DEACTIVATE_SELECTED} @@ -72,12 +75,14 @@ export const getBatchItems = ( { closePopover(); await deleteRulesAction( selectedState.map(({ sourceRule: { id } }) => id), - dispatch + dispatch, + dispatchToaster ); }} > diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/columns.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/columns.tsx index 636cbb8ecb064..0c1804f26ecdd 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/columns.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/columns.tsx @@ -15,7 +15,7 @@ import { EuiTableActionsColumnType, } from '@elastic/eui'; import * as H from 'history'; -import React from 'react'; +import React, { Dispatch } from 'react'; import { getEmptyTagValue } from '../../../../components/empty_value'; import { deleteRulesAction, @@ -31,8 +31,13 @@ import * as i18n from '../translations'; import { PreferenceFormattedDate } from '../../../../components/formatted_date'; import { RuleSwitch } from '../components/rule_switch'; import { SeverityBadge } from '../components/severity_badge'; +import { ActionToaster } from '../../../../components/toasters'; -const getActions = (dispatch: React.Dispatch, history: H.History) => [ +const getActions = ( + dispatch: React.Dispatch, + dispatchToaster: Dispatch, + history: H.History +) => [ { description: i18n.EDIT_RULE_SETTINGS, icon: 'visControls', @@ -51,7 +56,8 @@ const getActions = (dispatch: React.Dispatch, history: H.History) => [ description: i18n.DUPLICATE_RULE, icon: 'copy', name: i18n.DUPLICATE_RULE, - onClick: (rowItem: TableData) => duplicateRuleAction(rowItem.sourceRule, dispatch), + onClick: (rowItem: TableData) => + duplicateRuleAction(rowItem.sourceRule, dispatch, dispatchToaster), }, { description: i18n.EXPORT_RULE, @@ -63,7 +69,8 @@ const getActions = (dispatch: React.Dispatch, history: H.History) => [ description: i18n.DELETE_RULE, icon: 'trash', name: i18n.DELETE_RULE, - onClick: (rowItem: TableData) => deleteRulesAction([rowItem.id], dispatch), + onClick: (rowItem: TableData) => deleteRulesAction([rowItem.id], dispatch, dispatchToaster), + enabled: (rowItem: TableData) => !rowItem.immutable, }, ]; @@ -72,6 +79,7 @@ type RulesColumns = EuiBasicTableColumn | EuiTableActionsColumnType, + dispatchToaster: Dispatch, history: H.History, hasNoPermissions: boolean ): RulesColumns[] => { @@ -164,7 +172,7 @@ export const getColumns = ( ]; const actions: RulesColumns[] = [ { - actions: getActions(dispatch, history), + actions: getActions(dispatch, dispatchToaster, history), width: '40px', } as EuiTableActionsColumnType, ]; diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/helpers.test.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/helpers.test.tsx new file mode 100644 index 0000000000000..e925161444e42 --- /dev/null +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/helpers.test.tsx @@ -0,0 +1,61 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { bucketRulesResponse, formatRules } from './helpers'; +import { mockRule, mockRuleError, mockRules, mockTableData } from './__mocks__/mock'; +import uuid from 'uuid'; +import { Rule, RuleError } from '../../../../containers/detection_engine/rules'; + +describe('AllRulesTable Helpers', () => { + const mockRule1: Readonly = mockRule(uuid.v4()); + const mockRule2: Readonly = mockRule(uuid.v4()); + const mockRuleError1: Readonly = mockRuleError(uuid.v4()); + const mockRuleError2: Readonly = mockRuleError(uuid.v4()); + + describe('formatRules', () => { + test('formats rules with no selection', () => { + const formattedRules = formatRules(mockRules); + expect(formattedRules).toEqual(mockTableData); + }); + + test('formats rules with selection', () => { + const mockTableDataWithSelected = [...mockTableData]; + mockTableDataWithSelected[0].isLoading = true; + const formattedRules = formatRules(mockRules, [mockRules[0].id]); + expect(formattedRules).toEqual(mockTableDataWithSelected); + }); + }); + + describe('bucketRulesResponse', () => { + test('buckets empty response', () => { + const bucketedResponse = bucketRulesResponse([]); + expect(bucketedResponse).toEqual({ rules: [], errors: [] }); + }); + + test('buckets all error response', () => { + const bucketedResponse = bucketRulesResponse([mockRuleError1, mockRuleError2]); + expect(bucketedResponse).toEqual({ rules: [], errors: [mockRuleError1, mockRuleError2] }); + }); + + test('buckets all success response', () => { + const bucketedResponse = bucketRulesResponse([mockRule1, mockRule2]); + expect(bucketedResponse).toEqual({ rules: [mockRule1, mockRule2], errors: [] }); + }); + + test('buckets mixed success/error response', () => { + const bucketedResponse = bucketRulesResponse([ + mockRule1, + mockRuleError1, + mockRule2, + mockRuleError2, + ]); + expect(bucketedResponse).toEqual({ + rules: [mockRule1, mockRule2], + errors: [mockRuleError1, mockRuleError2], + }); + }); + }); +}); diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/helpers.ts b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/helpers.ts index f5d3955314242..b18938920082d 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/helpers.ts +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/helpers.ts @@ -4,13 +4,24 @@ * you may not use this file except in compliance with the Elastic License. */ -import { Rule } from '../../../../containers/detection_engine/rules'; +import { + Rule, + RuleError, + RuleResponseBuckets, +} from '../../../../containers/detection_engine/rules'; import { TableData } from '../types'; import { getEmptyValue } from '../../../../components/empty_value'; +/** + * Formats rules into the correct format for the AllRulesTable + * + * @param rules as returned from the Rules API + * @param selectedIds ids of the currently selected rules + */ export const formatRules = (rules: Rule[], selectedIds?: string[]): TableData[] => rules.map(rule => ({ id: rule.id, + immutable: rule.immutable, rule_id: rule.rule_id, rule: { href: `#/detection-engine/rules/id/${encodeURIComponent(rule.id)}`, @@ -28,3 +39,18 @@ export const formatRules = (rules: Rule[], selectedIds?: string[]): TableData[] sourceRule: rule, isLoading: selectedIds?.includes(rule.id) ?? false, })); + +/** + * Separates rules/errors from bulk rules API response (create/update/delete) + * + * @param response Array from bulk rules API + */ +export const bucketRulesResponse = (response: Array) => + response.reduce( + (acc, cv): RuleResponseBuckets => { + return 'error' in cv + ? { rules: [...acc.rules], errors: [...acc.errors, cv] } + : { rules: [...acc.rules, cv], errors: [...acc.errors] }; + }, + { rules: [], errors: [] } + ); diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/index.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/index.tsx index d928cc0949851..202be75f09e69 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/index.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/index.tsx @@ -84,11 +84,35 @@ export const AllRules = React.memo<{ const getBatchItemsPopoverContent = useCallback( (closePopover: () => void) => ( - + ), - [selectedItems, dispatch] + [selectedItems, dispatch, dispatchToaster] + ); + + const tableOnChangeCallback = useCallback( + ({ page, sort }: EuiBasicTableOnChange) => { + dispatch({ + type: 'updatePagination', + pagination: { ...pagination, page: page.index + 1, perPage: page.size }, + }); + dispatch({ + type: 'updateFilterOptions', + filterOptions: { + ...filterOptions, + sortField: 'enabled', // Only enabled is supported for sorting currently + sortOrder: sort?.direction ?? 'desc', + }, + }); + }, + [dispatch, filterOptions, pagination] ); + const columns = useMemo(() => { + return getColumns(dispatch, dispatchToaster, history, hasNoPermissions); + }, [dispatch, dispatchToaster, history]); + useEffect(() => { dispatch({ type: 'loading', isLoading: isLoadingRules }); @@ -195,24 +219,11 @@ export const AllRules = React.memo<{ { - dispatch({ - type: 'updatePagination', - pagination: { ...pagination, page: page.index + 1, perPage: page.size }, - }); - dispatch({ - type: 'updateFilterOptions', - filterOptions: { - ...filterOptions, - sortField: 'enabled', // Only enabled is supported for sorting currently - sortOrder: sort!.direction, - }, - }); - }} + onChange={tableOnChangeCallback} pagination={{ pageIndex: pagination.page - 1, pageSize: pagination.perPage, diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/rule_switch/index.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/rule_switch/index.tsx index 09be3df7d6929..9cb0323ed8987 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/rule_switch/index.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/rule_switch/index.tsx @@ -18,6 +18,7 @@ import React, { useCallback, useState, useEffect } from 'react'; import { enableRules } from '../../../../../containers/detection_engine/rules'; import { enableRulesAction } from '../../all/actions'; import { Action } from '../../all/reducer'; +import { useStateToaster } from '../../../../../components/toasters'; const StaticSwitch = styled(EuiSwitch)` .euiSwitch__thumb, @@ -50,12 +51,13 @@ export const RuleSwitchComponent = ({ }: RuleSwitchProps) => { const [myIsLoading, setMyIsLoading] = useState(false); const [myEnabled, setMyEnabled] = useState(enabled ?? false); + const [, dispatchToaster] = useStateToaster(); const onRuleStateChange = useCallback( async (event: EuiSwitchEvent) => { setMyIsLoading(true); if (dispatch != null) { - await enableRulesAction([id], event.target.checked!, dispatch); + await enableRulesAction([id], event.target.checked!, dispatch, dispatchToaster); } else { try { const updatedRules = await enableRules({ diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/translations.ts b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/translations.ts index 8d4407b9f73e8..d55e08e9ecd73 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/translations.ts +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/translations.ts @@ -50,6 +50,15 @@ export const BATCH_ACTION_ACTIVATE_SELECTED = i18n.translate( } ); +export const BATCH_ACTION_ACTIVATE_SELECTED_ERROR = (totalRules: number) => + i18n.translate( + 'xpack.siem.detectionEngine.rules.allRules.batchActions.activateSelectedErrorTitle', + { + values: { totalRules }, + defaultMessage: 'Error activating {totalRules, plural, =1 {rule} other {rules}}…', + } + ); + export const BATCH_ACTION_DEACTIVATE_SELECTED = i18n.translate( 'xpack.siem.detectionEngine.rules.allRules.batchActions.deactivateSelectedTitle', { @@ -57,6 +66,15 @@ export const BATCH_ACTION_DEACTIVATE_SELECTED = i18n.translate( } ); +export const BATCH_ACTION_DEACTIVATE_SELECTED_ERROR = (totalRules: number) => + i18n.translate( + 'xpack.siem.detectionEngine.rules.allRules.batchActions.deactivateSelectedErrorTitle', + { + values: { totalRules }, + defaultMessage: 'Error deactivating {totalRules, plural, =1 {rule} other {rules}}…', + } + ); + export const BATCH_ACTION_EXPORT_SELECTED = i18n.translate( 'xpack.siem.detectionEngine.rules.allRules.batchActions.exportSelectedTitle', { @@ -78,6 +96,22 @@ export const BATCH_ACTION_DELETE_SELECTED = i18n.translate( } ); +export const BATCH_ACTION_DELETE_SELECTED_IMMUTABLE = i18n.translate( + 'xpack.siem.detectionEngine.rules.allRules.batchActions.deleteSelectedImmutableTitle', + { + defaultMessage: 'Selection contains immutable rules which cannot be deleted', + } +); + +export const BATCH_ACTION_DELETE_SELECTED_ERROR = (totalRules: number) => + i18n.translate( + 'xpack.siem.detectionEngine.rules.allRules.batchActions.deleteSelectedErrorTitle', + { + values: { totalRules }, + defaultMessage: 'Error deleting {totalRules, plural, =1 {rule} other {rules}}…', + } + ); + export const EXPORT_FILENAME = i18n.translate( 'xpack.siem.detectionEngine.rules.allRules.exportFilenameTitle', { @@ -143,6 +177,13 @@ export const DUPLICATE_RULE = i18n.translate( } ); +export const DUPLICATE_RULE_ERROR = i18n.translate( + 'xpack.siem.detectionEngine.rules.allRules.actions.duplicateRuleErrorDescription', + { + defaultMessage: 'Error duplicating rule…', + } +); + export const EXPORT_RULE = i18n.translate( 'xpack.siem.detectionEngine.rules.allRules.actions.exportRuleDescription', { diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/types.ts b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/types.ts index 13b328e9061c9..3da294fc9b845 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/types.ts +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/types.ts @@ -25,6 +25,7 @@ export interface EuiBasicTableOnChange { export interface TableData { id: string; + immutable: boolean; rule_id: string; rule: { href: string; From 130a4a6f4d97c246c3990e7efac0d90934622b53 Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Mon, 13 Jan 2020 17:29:04 -0500 Subject: [PATCH 062/139] remove dupe --- .../maps/public/layers/styles/color_utils.js | 3 + .../components/color/color_map_select.js | 81 ++++++------------- .../color/color_stops_categorical.js | 2 +- .../components/color/dynamic_color_form.js | 26 ++++-- 4 files changed, 46 insertions(+), 66 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.js b/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.js index 857f7c2c67869..8caaf89723237 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/color_utils.js @@ -63,6 +63,9 @@ export function getColorRampCenterColor(colorRampName) { // Returns an array of color stops // [ stop_input_1: number, stop_output_1: color, stop_input_n: number, stop_output_n: color ] export function getOrdinalColorRampStops(colorRampName, numberColors = GRADIENT_INTERVALS) { + if (!colorRampName) { + return null; + } return getHexColorRangeStrings(colorRampName, numberColors).reduce( (accu, stopColor, idx, srcArr) => { const stopNumber = idx / srcArr.length; // number between 0 and 1, increasing as index increases diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js index d0ffb32415590..b7a8f7289c884 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js @@ -17,40 +17,19 @@ export class ColorMapSelect extends Component { state = {}; static getDerivedStateFromProps(nextProps, prevState) { - let newState = null; - if (nextProps.customColorRamp !== prevState.prevPropsCustomColorRamp) { - newState = { - ...{ - prevPropsCustomColorRamp: nextProps.customColorRamp, // reset tracker to latest value - customColorRamp: nextProps.customColorRamp, // reset customColorRamp to latest value - }, - }; - } - - if (nextProps.customColorPalette !== prevState.prevPropsCustomColorPalette) { - if (!newState) { - newState = {}; - } - newState = { - ...newState, - ...{ - prevPropsCustomColorPalette: nextProps.customColorPalette, // reset tracker to latest value - customColorPalette: nextProps.customColorPalette, // reset customColorRamp to latest value - }, - }; + if (nextProps.customColorMap === prevState.prevPropsCustomColorMap) { + return null; } - return newState; + return { + prevPropsCustomColorMap: nextProps.customColorMap, // reset tracker to latest value + customColorMap: nextProps.customColorMap, // reset customColorMap to latest value + }; } _onColorMapSelect = selectedValue => { const useCustomColorMap = selectedValue === CUSTOM_COLOR_MAP; - const newProps = {}; - if (this.props.colorMapType === COLOR_MAP_TYPE.ORDINAL) { - newProps.useCustomColorRamp = useCustomColorMap; - } else if (this.props.colorMapType === COLOR_MAP_TYPE.CATEGORICAL) { - newProps.useCustomColorPalette = useCustomColorMap; - } + const newProps = { useCustomColorMap }; newProps.color = useCustomColorMap ? null : selectedValue; this.props.onChange({ @@ -60,53 +39,43 @@ export class ColorMapSelect extends Component { }; _onCustomColorMapChange = ({ colorStops, isInvalid }) => { - // Manage invalid custom color ramp in local state + // Manage invalid custom color map in local state if (isInvalid) { - const newState = {}; - if (this.props.colorMapType === COLOR_MAP_TYPE.ORDINAL) { - newState.customColorRamp = colorStops; - } else if (this.props.colorMapType === COLOR_MAP_TYPE.CATEGORICAL) { - newState.customColorPalette = colorStops; - } + const newState = { + customColorMap: colorStops, + }; this.setState(newState); return; } const newProps = {}; - if (this.props.colorMapType === COLOR_MAP_TYPE.ORDINAL) { - newProps.useCustomColorRamp = true; - newProps.customColorRamp = colorStops; - } else if (this.props.colorMapType === COLOR_MAP_TYPE.CATEGORICAL) { - newProps.useCustomColorPalette = true; - newProps.customColorPalette = colorStops; - } + newProps.useCustomColorMap = true; + newProps.customColorMap = colorStops; newProps.type = this.props.colorMapType; this.props.onChange(newProps); }; render() { - const { color, useCustomColorRamp, useCustomColorPalette } = this.props; + const { color, useCustomColorMap } = this.props; let colorStopsInput; - if (this.props.colorMapType === COLOR_MAP_TYPE.ORDINAL) { - if (useCustomColorRamp) { + if (useCustomColorMap) { + if (this.props.colorMapType === COLOR_MAP_TYPE.ORDINAL) { colorStopsInput = ( ); - } - } else if (this.props.colorMapType === COLOR_MAP_TYPE.CATEGORICAL) { - if (useCustomColorPalette) { + } else if (this.props.colorMapType === COLOR_MAP_TYPE.CATEGORICAL) { colorStopsInput = ( @@ -115,7 +84,7 @@ export class ColorMapSelect extends Component { } let valueOfSelected; - const colorMapOptions = [ + const colorMapOptionsWithCustom = [ { value: CUSTOM_COLOR_MAP, inputDisplay: this.props.customOptionLabel, @@ -123,14 +92,10 @@ export class ColorMapSelect extends Component { ...this.props.colorMapOptions, ]; - const useCustom = - this.props.colorMapType === COLOR_MAP_TYPE.ORDINAL - ? useCustomColorRamp - : useCustomColorPalette; - if (useCustom) { + if (useCustomColorMap) { valueOfSelected = CUSTOM_COLOR_MAP; } else { - if (colorMapOptions.find(option => option.value === color)) { + if (colorMapOptionsWithCustom.find(option => option.value === color)) { valueOfSelected = color; } else { valueOfSelected = this.props.colorMapOptions[0].value; @@ -141,7 +106,7 @@ export class ColorMapSelect extends Component { return ( { + const newColorOptions = { + type: colorOptions.type, + color: colorOptions.color, + }; + if (colorOptions.type === COLOR_MAP_TYPE.ORDINAL) { + newColorOptions.useCustomColorRamp = colorOptions.useCustomColorMap; + newColorOptions.customColorRamp = colorOptions.customColorMap; + } else { + newColorOptions.useCustomColorPalette = colorOptions.useCustomColorMap; + newColorOptions.customColorPalette = colorOptions.customColorMap; + } + const oldStyleOptions = { ...styleOptions }; - if (oldStyleOptions.type === !colorOptions.type) { + if (oldStyleOptions.type === !newColorOptions.type) { delete oldStyleOptions.type; - if (colorOptions.type === COLOR_MAP_TYPE.ORDINAL) { + if (newColorOptions.type === COLOR_MAP_TYPE.ORDINAL) { delete oldStyleOptions.useCustomColorPalette; delete oldStyleOptions.customColorPalette; } else { @@ -81,7 +93,7 @@ export class DynamicColorForm extends React.Component { const newOptions = { ...oldStyleOptions, - ...colorOptions, + ...newColorOptions, }; onDynamicStyleChange(styleProperty.getStyleName(), newOptions); }; @@ -100,8 +112,8 @@ export class DynamicColorForm extends React.Component { onChange={options => onColorChange(options)} colorMapType={COLOR_MAP_TYPE.ORDINAL} color={styleOptions.color} - customColorRamp={styleOptions.customColorRamp} - useCustomColorRamp={_.get(styleOptions, 'useCustomColorRamp', false)} + customColorMap={styleOptions.customColorRamp} + useCustomColorMap={_.get(styleOptions, 'useCustomColorRamp', false)} compressed /> ); @@ -119,8 +131,8 @@ export class DynamicColorForm extends React.Component { onChange={options => onColorChange(options)} colorMapType={COLOR_MAP_TYPE.CATEGORICAL} color={styleOptions.color} - customColorPalette={styleOptions.customColorPalette} - useCustomColorPalette={_.get(styleOptions, 'useCustomColorPalette', false)} + customColorMap={styleOptions.customColorPalette} + useCustomColorMap={_.get(styleOptions, 'useCustomColorPalette', false)} compressed /> ); From 5e6071162dbbe14ec9a476da29a5b1e3c50c577c Mon Sep 17 00:00:00 2001 From: Spencer Date: Mon, 13 Jan 2020 15:37:33 -0700 Subject: [PATCH 063/139] [dev/build/sass] build stylesheets for disabled plugins too (#54654) --- src/dev/sass/build_sass.js | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/src/dev/sass/build_sass.js b/src/dev/sass/build_sass.js index 14f03a7a116a6..1ff7c700d0386 100644 --- a/src/dev/sass/build_sass.js +++ b/src/dev/sass/build_sass.js @@ -19,6 +19,7 @@ import { resolve } from 'path'; +import * as Rx from 'rxjs'; import { toArray } from 'rxjs/operators'; import { createFailError } from '@kbn/dev-utils'; @@ -61,9 +62,11 @@ export async function buildSass({ log, kibanaDir, watch }) { const scanDirs = [resolve(kibanaDir, 'src/legacy/core_plugins')]; const paths = [resolve(kibanaDir, 'x-pack')]; - const { spec$ } = findPluginSpecs({ plugins: { scanDirs, paths } }); - const enabledPlugins = await spec$.pipe(toArray()).toPromise(); - const uiExports = collectUiExports(enabledPlugins); + const { spec$, disabledSpec$ } = findPluginSpecs({ plugins: { scanDirs, paths } }); + const allPlugins = await Rx.merge(spec$, disabledSpec$) + .pipe(toArray()) + .toPromise(); + const uiExports = collectUiExports(allPlugins); const { styleSheetPaths } = uiExports; log.info('%s %d styleSheetPaths', watch ? 'watching' : 'found', styleSheetPaths.length); From 1ad304f2fcedce453853916abfa5962018d58ad9 Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Mon, 13 Jan 2020 17:47:52 -0500 Subject: [PATCH 064/139] reformat --- .../styles/vector/components/color/color_map_select.js | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js index b7a8f7289c884..8d7e1aec1bd7d 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js @@ -48,10 +48,11 @@ export class ColorMapSelect extends Component { return; } - const newProps = {}; - newProps.useCustomColorMap = true; - newProps.customColorMap = colorStops; - newProps.type = this.props.colorMapType; + const newProps = { + useCustomColorMap: true, + customColorMap: colorStops, + type: this.props.colorMapType, + }; this.props.onChange(newProps); }; From 8259445350434f6a53f9bcde5b0551ae37d47fa8 Mon Sep 17 00:00:00 2001 From: Yuliia Naumenko Date: Mon, 13 Jan 2020 16:16:20 -0800 Subject: [PATCH 065/139] Create UI for alerting and actions plugin (#48959) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Refactored reducers type definitions * Fixed dependancy objects * Fixed action add * Fixed logging app icon * Added action types params fields * Added fields for check and re-notify alert * Add tags to alert list * Adjusted threshold expression with validation, added visualization * Move delete button to the left and hide when no selection * Rename action list title column to name * fixed request * Removed watcher labels * Design cleanup * Added expression default values * Added visualization for index threshold alert * Rename Actions tab to Connectors * Rename "create action" to "create connector" * Remove actions column name * Add count per action type * Hide checkboxes when user can't delete * Add title to home, rename Alerting UI breadcrumb (remove UI part) * Added correct binding for interval and throttle * Added tags support for create Alert UI * Added server error display in UI on save alert * Added connectors for action forms * Update button styles * Switch inputs to compressed forms * Fixed some fields for add alert form * Fixed updating action by index * Fixed filter for index/fields api requests * Remove the test alert type that was in the init function * Fixed action type icon on add connector form and did small refactoring on action forms; added action validation * Rename alerting UI plugin to triggers and actions UI (or something else) #50305 * Implemented action connector edit UI * Add bulk actions to alerts list * Update home title spacing * Fixed editing secrets action property * Changing behaviour of bulk actions and disable buttons during request * Refactored plugin definition with appdependency interface * Moved add dependencies to the separate file * Enable visualization if only hasExpressionErrors passed * Fixed add action twice on click card * Fix actions column in alert list * Fixed action canSave capability * Renamed Actions to ActionConnectors in appropriate UI files * Renamed alertTypeParams to params in UI code * Add filter for tags * Cleanup previous commit * Fix alert type filter * Refactored edit form to use ActionTableItem * Renamed ActionTableItem to ActionConnectorTableItem * Fixed missing button key error for alerts list filter * Renamed translation labels for connectors * Enable UI plugin by default * Rename buildin to builtin * Fix some type checks * Add API tests * Split API file into smaller files * Rename plugin id * Remove dependency on actions plugin (should be optional dep in NP) * Fix some translation ids * Revert "Rename plugin id" This reverts commit f6daeb3d5ea8c281fa3ce7393015ce5684cbd25a. * Rename method for loading connectors * Added functional tests base * Fix functional test type filter * Add test alert type for now * Initial connectors functional tests * Rename description to name * Use unique connector names to allow re-running tests * Assert on more things * Update alert/action menu items. Flyout width. Add index.scss file * Added action connector list unit tests * Add bulk delete functional test * Move tests to SSL functional environment * Fix tests * Added unit tests for actionTypeRegistry and alertTypeRegistry * Fixed update connector with only properties * Added some functional tests for alerts with TODOs * connectors list page cleanup * empty state cleanup * Added connector edit flyout unit test * Fix functional tests * text cleanup * zindex fix for index threshold trigger * Expand the functional tests, add assertions * Fixed edit connector from the Name column, and removed pencil button * Remove tags filter, use search bar instead * Finalize functional tests * Support filtering alerts by action type * Rename plugin name for translations * Rename default breadcrumb title to alerts and actions * Added unit tests for connectors empty prompt, fixed api tests * Added unit test for select action type menu for create connector; Fixed update selected connector for edit form * Added unit test for edit connector flyout * Added alerts list unit tests * Added connector form unit tests * Added connector reducer unit tests * Fixed some failing unit tests * Fixed alerts list unit tests * Set alert tab default if it is available * Added doc_title and get_time_units unit tests * Added some test fixes * Fixed index threshold expression to display only index and fields * Added email building action unit tests * Added unit tests for builtin action types * Remove test alert type * Move create alert UI behind feature flag 'createAlertUiEnabled' * Fix functional tests * Update codeowners * Update codeowners for tests * Revert watcher changes * Fix type check failure * Fix unit test failures * Fixed typecheck failures * Fixed language check errors * Did some text/type fixes * Fixed typecheck * Fixed unit tests warning * Fix failing functional tests * Fix registry tests to have cleaner diff when it fails * Make DEFAULT_SECTION a Section type * Remove unused constructor * Make app dependency error string same line * Remove unused error pages * Set interface to alerts context * Fix action_connector_form.tsx label * Fix label in connector_add_flyout.tsx * Fix label in alert_add.tsx * Move alert_types to builtin_alert_types * Move some threshold constants into threshold folder * Move api.ts within threshold folder * Removed duplication logic from action type and alert type registry list * Fixed email action type test and adjusted validation to support arrays ony * Added missing connector fields for email action type * Fixed building action types issues due to comments * Refactored with more new platform structure; fixed some comments from review * Capitalize Actions in 'Alerts and Actions' labels * Skip flaky tests * Fix failing functional test * Fixed failing unit tests, added new deps * Fixed type checks * Fixed language check failing * Fix broken functional tests * Refactored actionConnectors and alerting context * Removed doc title service * added get time options type definitions * removed obsolete code * Made generic registry type for actionTypes and alert types * Fixed some enum types * fixed type check CI * Convert EuiSearchBar to normal text field * Fix typo * Fix conditional rendering * Fix bug where selection doesn't reset * Fix broken functional test, wait for ENTER key to search alerts * Make app section hide from menu when user doesn't have access * Fixed connector name validation (error due to renaming from description) * Removed obsolete useEffect * Removed unused ShareRouter * Fixed key validation error * Mobed wrongly wrapped objects * Removed useEffect from connectors form * Replaced error forms with eui controls props * Added delete confirmation dialog for connectors list * Fixed build errors * Fixed failing test * Skip flaky tests * Added null check for app context - render components tree only if it isn't null * Fixed type check eror * Did changes on the UX and text/labels commnets * Fixed failing tests * Fixed error handling * Refactored Webhook form http headers due to the mockup * Fixed build * Fix labels issue * Fix spacing and form row alignment * Fixed failing type check * put ownfocus on popover in actions list * fix spacing and flex * fix color on conectors list * clean up webhook headers form * fix logic check for headers * Made changes due to review comments * Fixed delete connector test * Fixed all flaky test for delete connectors 53956 * Fixed type check due to NP changes * Disable plugin by default * Added configuration props for functional tests to enable triggers and actions ui * removed timeout from test * added enable triggers and actions to functional/config.js * fix the build * Changed ci group and disabled plugin * changed config setting to root * Changed disable approach * Experiment with index managment * Set back configuration settings for triggers and actions * Enable plugins * Set index management to disabled to see the failing issue * Revert experimental back for index_managment * Fixed type check Co-authored-by: Mike Côté Co-authored-by: dave.snider@gmail.com Co-authored-by: DeFazio Co-authored-by: Elastic Machine Co-authored-by: Peter Schretlen --- .github/CODEOWNERS | 3 + x-pack/.i18nrc.json | 1 + x-pack/index.js | 2 + .../server/builtin_action_types/email.test.ts | 2 +- .../server/builtin_action_types/email.ts | 4 +- .../builtin_action_types/es_index.test.ts | 2 +- .../server/builtin_action_types/es_index.ts | 4 +- .../builtin_action_types/pagerduty.test.ts | 2 +- .../server/builtin_action_types/pagerduty.ts | 4 +- .../builtin_action_types/server_log.test.ts | 4 +- .../server/builtin_action_types/server_log.ts | 2 +- .../server/builtin_action_types/slack.test.ts | 2 +- .../server/builtin_action_types/slack.ts | 4 +- .../builtin_action_types/webhook.test.ts | 2 +- .../server/builtin_action_types/webhook.ts | 4 +- x-pack/legacy/plugins/siem/server/plugin.ts | 21 +- .../plugins/triggers_actions_ui/index.ts | 43 + .../triggers_actions_ui/np_ready/kibana.json | 6 + .../application/action_type_registry.mock.ts | 21 + .../application/alert_type_registry.mock.ts | 21 + .../np_ready/public/application/app.tsx | 64 ++ .../public/application/app_context.tsx | 30 + .../np_ready/public/application/boot.tsx | 34 + .../builtin_action_types/email.test.tsx | 228 ++++ .../components/builtin_action_types/email.tsx | 545 +++++++++ .../builtin_action_types/es_index.test.tsx | 140 +++ .../builtin_action_types/es_index.tsx | 124 ++ .../components/builtin_action_types/index.ts | 27 + .../builtin_action_types/pagerduty.test.tsx | 179 +++ .../builtin_action_types/pagerduty.tsx | 361 ++++++ .../builtin_action_types/server_log.test.tsx | 130 +++ .../builtin_action_types/server_log.tsx | 116 ++ .../builtin_action_types/slack.test.tsx | 152 +++ .../components/builtin_action_types/slack.tsx | 175 +++ .../builtin_action_types/webhook.test.tsx | 174 +++ .../builtin_action_types/webhook.tsx | 501 +++++++++ .../components/builtin_alert_types/index.ts | 17 + .../threshold/constants/aggregation_types.ts | 17 + .../threshold/constants/comparators.ts | 13 + .../threshold/constants/index.ts | 8 + .../threshold/expression.tsx | 1000 +++++++++++++++++ .../builtin_alert_types/threshold/lib/api.ts | 79 ++ .../builtin_alert_types/threshold/types.ts | 25 + .../threshold/visualization.tsx | 303 +++++ .../components/delete_connectors_modal.tsx | 91 ++ .../components/section_loading.tsx | 23 + .../application/constants/action_groups.ts | 11 + .../public/application/constants/index.ts | 21 + .../public/application/constants/plugin.ts | 14 + .../application/constants/time_units.ts | 12 + .../context/actions_connectors_context.tsx | 39 + .../application/context/alerts_context.tsx | 32 + .../np_ready/public/application/home.tsx | 126 +++ .../lib/action_connector_api.test.ts | 135 +++ .../application/lib/action_connector_api.ts | 85 ++ .../public/application/lib/alert_api.test.ts | 406 +++++++ .../public/application/lib/alert_api.ts | 126 +++ .../public/application/lib/breadcrumb.test.ts | 31 + .../public/application/lib/breadcrumb.ts | 35 + .../public/application/lib/capabilities.ts | 53 + .../public/application/lib/doc_title.test.ts | 14 + .../public/application/lib/doc_title.ts | 28 + .../application/lib/get_time_options.test.ts | 36 + .../application/lib/get_time_options.ts | 37 + .../application/lib/get_time_unit_label.ts | 33 + .../action_connector_form.test.tsx | 113 ++ .../action_connector_form.tsx | 270 +++++ .../action_type_menu.test.tsx | 91 ++ .../action_type_menu.tsx | 83 ++ .../connector_add_flyout.test.tsx | 100 ++ .../connector_add_flyout.tsx | 104 ++ .../connector_edit_flyout.test.tsx | 100 ++ .../connector_edit_flyout.tsx | 68 ++ .../connector_reducer.test.ts | 91 ++ .../connector_reducer.ts | 78 ++ .../sections/action_connector_form/index.ts | 8 + .../components/_index.scss | 1 + .../components/actions_connectors_list.scss | 3 + .../actions_connectors_list.test.tsx | 362 ++++++ .../components/actions_connectors_list.tsx | 399 +++++++ .../sections/alert_add/alert_add.tsx | 803 +++++++++++++ .../sections/alert_add/alert_reducer.ts | 121 ++ .../application/sections/alert_add/index.ts | 7 + .../components/action_type_filter.tsx | 72 ++ .../components/alerts_list.test.tsx | 453 ++++++++ .../alerts_list/components/alerts_list.tsx | 330 ++++++ .../components/bulk_action_popover.tsx | 253 +++++ .../components/collapsed_item_actions.tsx | 140 +++ .../alerts_list/components/type_filter.tsx | 74 ++ .../public/application/type_registry.test.ts | 117 ++ .../public/application/type_registry.ts | 56 + .../np_ready/public/index.ts | 15 + .../np_ready/public/plugin.ts | 107 ++ .../np_ready/public/types.ts | 120 ++ .../public/hacks/register.ts | 25 + .../triggers_actions_ui/public/index.scss | 5 + .../triggers_actions_ui/public/legacy.ts | 98 ++ .../public/manage_angular_lifecycle.ts | 28 + x-pack/scripts/functional_tests.js | 1 + x-pack/test/functional/services/index.ts | 1 + .../apps/triggers_actions_ui/alerts.ts | 344 ++++++ .../apps/triggers_actions_ui/connectors.ts | 202 ++++ .../apps/triggers_actions_ui/home_page.ts | 60 + .../apps/triggers_actions_ui/index.ts | 16 + x-pack/test/functional_with_es_ssl/config.ts | 59 + .../fixtures/plugins/alerts/index.ts | 24 + .../fixtures/plugins/alerts/package.json | 7 + .../ftr_provider_context.d.ts | 12 + .../page_objects/index.ts | 13 + .../page_objects/triggers_actions_ui_page.ts | 97 ++ .../functional_with_es_ssl/services/index.ts | 11 + 111 files changed, 11511 insertions(+), 15 deletions(-) create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/index.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/kibana.json create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/action_type_registry.mock.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/alert_type_registry.mock.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/app.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/app_context.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/boot.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/email.test.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/email.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/es_index.test.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/es_index.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/index.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/pagerduty.test.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/pagerduty.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/server_log.test.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/server_log.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/slack.test.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/slack.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/webhook.test.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/webhook.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/index.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/constants/aggregation_types.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/constants/comparators.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/constants/index.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/expression.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/lib/api.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/types.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/visualization.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/delete_connectors_modal.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/section_loading.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/constants/action_groups.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/constants/index.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/constants/plugin.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/constants/time_units.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/context/actions_connectors_context.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/context/alerts_context.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/home.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/action_connector_api.test.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/action_connector_api.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/alert_api.test.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/alert_api.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/breadcrumb.test.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/breadcrumb.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/capabilities.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/doc_title.test.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/doc_title.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/get_time_options.test.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/get_time_options.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/get_time_unit_label.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/action_connector_form.test.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/action_connector_form.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/action_type_menu.test.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/action_type_menu.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_add_flyout.test.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_add_flyout.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_edit_flyout.test.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_edit_flyout.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_reducer.test.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_reducer.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/index.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/actions_connectors_list/components/_index.scss create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/actions_connectors_list/components/actions_connectors_list.scss create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/actions_connectors_list/components/actions_connectors_list.test.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/actions_connectors_list/components/actions_connectors_list.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alert_add/alert_add.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alert_add/alert_reducer.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alert_add/index.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/action_type_filter.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/alerts_list.test.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/alerts_list.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/bulk_action_popover.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/collapsed_item_actions.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/type_filter.tsx create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/type_registry.test.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/type_registry.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/index.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/plugin.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/types.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/public/hacks/register.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/public/index.scss create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/public/legacy.ts create mode 100644 x-pack/legacy/plugins/triggers_actions_ui/public/manage_angular_lifecycle.ts create mode 100644 x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/alerts.ts create mode 100644 x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/connectors.ts create mode 100644 x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/home_page.ts create mode 100644 x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/index.ts create mode 100644 x-pack/test/functional_with_es_ssl/config.ts create mode 100644 x-pack/test/functional_with_es_ssl/fixtures/plugins/alerts/index.ts create mode 100644 x-pack/test/functional_with_es_ssl/fixtures/plugins/alerts/package.json create mode 100644 x-pack/test/functional_with_es_ssl/ftr_provider_context.d.ts create mode 100644 x-pack/test/functional_with_es_ssl/page_objects/index.ts create mode 100644 x-pack/test/functional_with_es_ssl/page_objects/triggers_actions_ui_page.ts create mode 100644 x-pack/test/functional_with_es_ssl/services/index.ts diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index 9a4f2b71da1ff..acfb7307f49c4 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -132,6 +132,9 @@ /x-pack/test/alerting_api_integration @elastic/kibana-alerting-services /x-pack/test/plugin_api_integration/plugins/task_manager @elastic/kibana-alerting-services /x-pack/test/plugin_api_integration/test_suites/task_manager @elastic/kibana-alerting-services +/x-pack/legacy/plugins/triggers_actions_ui/ @elastic/kibana-alerting-services +/x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/ @elastic/kibana-alerting-services +/x-pack/test/functional_with_es_ssl/fixtures/plugins/alerts/ @elastic/kibana-alerting-services # Design **/*.scss @elastic/kibana-design diff --git a/x-pack/.i18nrc.json b/x-pack/.i18nrc.json index 7e86d2f1dc435..71e3bdd6c8c84 100644 --- a/x-pack/.i18nrc.json +++ b/x-pack/.i18nrc.json @@ -4,6 +4,7 @@ "xpack.actions": "legacy/plugins/actions", "xpack.advancedUiActions": "plugins/advanced_ui_actions", "xpack.alerting": "legacy/plugins/alerting", + "xpack.triggersActionsUI": "legacy/plugins/triggers_actions_ui", "xpack.apm": "legacy/plugins/apm", "xpack.beatsManagement": "legacy/plugins/beats_management", "xpack.canvas": "legacy/plugins/canvas", diff --git a/x-pack/index.js b/x-pack/index.js index 56547f89b1e90..83a7b5540334f 100644 --- a/x-pack/index.js +++ b/x-pack/index.js @@ -42,6 +42,7 @@ import { transform } from './legacy/plugins/transform'; import { actions } from './legacy/plugins/actions'; import { alerting } from './legacy/plugins/alerting'; import { lens } from './legacy/plugins/lens'; +import { triggersActionsUI } from './legacy/plugins/triggers_actions_ui'; module.exports = function(kibana) { return [ @@ -83,5 +84,6 @@ module.exports = function(kibana) { snapshotRestore(kibana), actions(kibana), alerting(kibana), + triggersActionsUI(kibana), ]; }; diff --git a/x-pack/legacy/plugins/actions/server/builtin_action_types/email.test.ts b/x-pack/legacy/plugins/actions/server/builtin_action_types/email.test.ts index 4aaecc8e9d7df..74263c603c11e 100644 --- a/x-pack/legacy/plugins/actions/server/builtin_action_types/email.test.ts +++ b/x-pack/legacy/plugins/actions/server/builtin_action_types/email.test.ts @@ -49,7 +49,7 @@ beforeEach(() => { describe('actionTypeRegistry.get() works', () => { test('action type static data is as expected', () => { expect(actionType.id).toEqual(ACTION_TYPE_ID); - expect(actionType.name).toEqual('email'); + expect(actionType.name).toEqual('Email'); }); }); diff --git a/x-pack/legacy/plugins/actions/server/builtin_action_types/email.ts b/x-pack/legacy/plugins/actions/server/builtin_action_types/email.ts index dd2bd328ce53f..94d7852e76fad 100644 --- a/x-pack/legacy/plugins/actions/server/builtin_action_types/email.ts +++ b/x-pack/legacy/plugins/actions/server/builtin_action_types/email.ts @@ -118,7 +118,9 @@ export function getActionType(params: GetActionTypeParams): ActionType { const { logger, configurationUtilities } = params; return { id: '.email', - name: 'email', + name: i18n.translate('xpack.actions.builtin.emailTitle', { + defaultMessage: 'Email', + }), validate: { config: schema.object(ConfigSchemaProps, { validate: curry(validateConfig)(configurationUtilities), diff --git a/x-pack/legacy/plugins/actions/server/builtin_action_types/es_index.test.ts b/x-pack/legacy/plugins/actions/server/builtin_action_types/es_index.test.ts index 1da8b06e1587a..dbac84ef681f1 100644 --- a/x-pack/legacy/plugins/actions/server/builtin_action_types/es_index.test.ts +++ b/x-pack/legacy/plugins/actions/server/builtin_action_types/es_index.test.ts @@ -37,7 +37,7 @@ beforeEach(() => { describe('actionTypeRegistry.get() works', () => { test('action type static data is as expected', () => { expect(actionType.id).toEqual(ACTION_TYPE_ID); - expect(actionType.name).toEqual('index'); + expect(actionType.name).toEqual('Index'); }); }); diff --git a/x-pack/legacy/plugins/actions/server/builtin_action_types/es_index.ts b/x-pack/legacy/plugins/actions/server/builtin_action_types/es_index.ts index 0e9fe0483ee1e..ddf33ba63f71a 100644 --- a/x-pack/legacy/plugins/actions/server/builtin_action_types/es_index.ts +++ b/x-pack/legacy/plugins/actions/server/builtin_action_types/es_index.ts @@ -38,7 +38,9 @@ const ParamsSchema = schema.object({ export function getActionType({ logger }: { logger: Logger }): ActionType { return { id: '.index', - name: 'index', + name: i18n.translate('xpack.actions.builtin.esIndexTitle', { + defaultMessage: 'Index', + }), validate: { config: ConfigSchema, params: ParamsSchema, diff --git a/x-pack/legacy/plugins/actions/server/builtin_action_types/pagerduty.test.ts b/x-pack/legacy/plugins/actions/server/builtin_action_types/pagerduty.test.ts index cb3548524ebbb..f60fdf7fef95e 100644 --- a/x-pack/legacy/plugins/actions/server/builtin_action_types/pagerduty.test.ts +++ b/x-pack/legacy/plugins/actions/server/builtin_action_types/pagerduty.test.ts @@ -38,7 +38,7 @@ beforeAll(() => { describe('get()', () => { test('should return correct action type', () => { expect(actionType.id).toEqual(ACTION_TYPE_ID); - expect(actionType.name).toEqual('pagerduty'); + expect(actionType.name).toEqual('PagerDuty'); }); }); diff --git a/x-pack/legacy/plugins/actions/server/builtin_action_types/pagerduty.ts b/x-pack/legacy/plugins/actions/server/builtin_action_types/pagerduty.ts index 250c169278c57..b26621702cf5b 100644 --- a/x-pack/legacy/plugins/actions/server/builtin_action_types/pagerduty.ts +++ b/x-pack/legacy/plugins/actions/server/builtin_action_types/pagerduty.ts @@ -96,7 +96,9 @@ export function getActionType({ }): ActionType { return { id: '.pagerduty', - name: 'pagerduty', + name: i18n.translate('xpack.actions.builtin.pagerdutyTitle', { + defaultMessage: 'PagerDuty', + }), validate: { config: schema.object(configSchemaProps, { validate: curry(valdiateActionTypeConfig)(configurationUtilities), diff --git a/x-pack/legacy/plugins/actions/server/builtin_action_types/server_log.test.ts b/x-pack/legacy/plugins/actions/server/builtin_action_types/server_log.test.ts index c59ddf97017fd..8f28b9e8f5125 100644 --- a/x-pack/legacy/plugins/actions/server/builtin_action_types/server_log.test.ts +++ b/x-pack/legacy/plugins/actions/server/builtin_action_types/server_log.test.ts @@ -25,7 +25,7 @@ beforeAll(() => { describe('get()', () => { test('returns action type', () => { expect(actionType.id).toEqual(ACTION_TYPE_ID); - expect(actionType.name).toEqual('server-log'); + expect(actionType.name).toEqual('Server log'); }); }); @@ -98,6 +98,6 @@ describe('execute()', () => { config: {}, secrets: {}, }); - expect(mockedLogger.info).toHaveBeenCalledWith('server-log: message text here'); + expect(mockedLogger.info).toHaveBeenCalledWith('Server log: message text here'); }); }); diff --git a/x-pack/legacy/plugins/actions/server/builtin_action_types/server_log.ts b/x-pack/legacy/plugins/actions/server/builtin_action_types/server_log.ts index 0edf409e4d46c..34b8602eeba36 100644 --- a/x-pack/legacy/plugins/actions/server/builtin_action_types/server_log.ts +++ b/x-pack/legacy/plugins/actions/server/builtin_action_types/server_log.ts @@ -12,7 +12,7 @@ import { Logger } from '../../../../../../src/core/server'; import { ActionType, ActionTypeExecutorOptions, ActionTypeExecutorResult } from '../types'; import { withoutControlCharacters } from './lib/string_utils'; -const ACTION_NAME = 'server-log'; +const ACTION_NAME = 'Server log'; // params definition diff --git a/x-pack/legacy/plugins/actions/server/builtin_action_types/slack.test.ts b/x-pack/legacy/plugins/actions/server/builtin_action_types/slack.test.ts index a2b0db8bdb70f..aebc9c4993599 100644 --- a/x-pack/legacy/plugins/actions/server/builtin_action_types/slack.test.ts +++ b/x-pack/legacy/plugins/actions/server/builtin_action_types/slack.test.ts @@ -29,7 +29,7 @@ beforeAll(() => { describe('action registeration', () => { test('returns action type', () => { expect(actionType.id).toEqual(ACTION_TYPE_ID); - expect(actionType.name).toEqual('slack'); + expect(actionType.name).toEqual('Slack'); }); }); diff --git a/x-pack/legacy/plugins/actions/server/builtin_action_types/slack.ts b/x-pack/legacy/plugins/actions/server/builtin_action_types/slack.ts index 92611d6f162ff..b8989e59a2257 100644 --- a/x-pack/legacy/plugins/actions/server/builtin_action_types/slack.ts +++ b/x-pack/legacy/plugins/actions/server/builtin_action_types/slack.ts @@ -49,7 +49,9 @@ export function getActionType({ }): ActionType { return { id: '.slack', - name: 'slack', + name: i18n.translate('xpack.actions.builtin.slackTitle', { + defaultMessage: 'Slack', + }), validate: { secrets: schema.object(secretsSchemaProps, { validate: curry(valdiateActionTypeConfig)(configurationUtilities), diff --git a/x-pack/legacy/plugins/actions/server/builtin_action_types/webhook.test.ts b/x-pack/legacy/plugins/actions/server/builtin_action_types/webhook.test.ts index 64dd3a485f8e2..b95fef97ac7b9 100644 --- a/x-pack/legacy/plugins/actions/server/builtin_action_types/webhook.test.ts +++ b/x-pack/legacy/plugins/actions/server/builtin_action_types/webhook.test.ts @@ -25,7 +25,7 @@ beforeAll(() => { describe('actionType', () => { test('exposes the action as `webhook` on its Id and Name', () => { expect(actionType.id).toEqual('.webhook'); - expect(actionType.name).toEqual('webhook'); + expect(actionType.name).toEqual('Webhook'); }); }); diff --git a/x-pack/legacy/plugins/actions/server/builtin_action_types/webhook.ts b/x-pack/legacy/plugins/actions/server/builtin_action_types/webhook.ts index 06fe2fb0e591c..fa88d3c72c163 100644 --- a/x-pack/legacy/plugins/actions/server/builtin_action_types/webhook.ts +++ b/x-pack/legacy/plugins/actions/server/builtin_action_types/webhook.ts @@ -56,7 +56,9 @@ export function getActionType({ }): ActionType { return { id: '.webhook', - name: 'webhook', + name: i18n.translate('xpack.actions.builtin.webhookTitle', { + defaultMessage: 'Webhook', + }), validate: { config: schema.object(configSchemaProps, { validate: curry(valdiateActionTypeConfig)(configurationUtilities), diff --git a/x-pack/legacy/plugins/siem/server/plugin.ts b/x-pack/legacy/plugins/siem/server/plugin.ts index 90ae79ef19d5b..9d1983cf1d4da 100644 --- a/x-pack/legacy/plugins/siem/server/plugin.ts +++ b/x-pack/legacy/plugins/siem/server/plugin.ts @@ -60,7 +60,16 @@ export class Plugin { ], read: ['config'], }, - ui: ['show', 'crud'], + ui: [ + 'show', + 'crud', + 'alerting:show', + 'actions:show', + 'alerting:save', + 'actions:save', + 'alerting:delete', + 'actions:delete', + ], }, read: { api: ['siem', 'actions-read', 'actions-all', 'alerting-read', 'alerting-all'], @@ -73,7 +82,15 @@ export class Plugin { timelineSavedObjectType, ], }, - ui: ['show'], + ui: [ + 'show', + 'alerting:show', + 'actions:show', + 'alerting:save', + 'actions:save', + 'alerting:delete', + 'actions:delete', + ], }, }, }); diff --git a/x-pack/legacy/plugins/triggers_actions_ui/index.ts b/x-pack/legacy/plugins/triggers_actions_ui/index.ts new file mode 100644 index 0000000000000..c6ac3649a1477 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/index.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; + * you may not use this file except in compliance with the Elastic License. + */ + +import { Legacy } from 'kibana'; +import { Root } from 'joi'; +import { resolve } from 'path'; + +export function triggersActionsUI(kibana: any) { + return new kibana.Plugin({ + id: 'triggers_actions_ui', + configPrefix: 'xpack.triggers_actions_ui', + isEnabled(config: Legacy.KibanaConfig) { + return ( + config.get('xpack.triggers_actions_ui.enabled') && + (config.get('xpack.actions.enabled') || config.get('xpack.alerting.enabled')) + ); + }, + publicDir: resolve(__dirname, 'public'), + require: ['kibana'], + config(Joi: Root) { + return Joi.object() + .keys({ + enabled: Joi.boolean().default(false), + createAlertUiEnabled: Joi.boolean().default(false), + }) + .default(); + }, + uiExports: { + home: ['plugins/triggers_actions_ui/hacks/register'], + managementSections: ['plugins/triggers_actions_ui/legacy'], + styleSheetPaths: resolve(__dirname, 'public/index.scss'), + injectDefaultVars(server: Legacy.Server) { + const serverConfig = server.config(); + return { + createAlertUiEnabled: serverConfig.get('xpack.triggers_actions_ui.createAlertUiEnabled'), + }; + }, + }, + }); +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/kibana.json b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/kibana.json new file mode 100644 index 0000000000000..3fd7389aef494 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/kibana.json @@ -0,0 +1,6 @@ +{ + "id": "triggers_actions_ui", + "version": "kibana", + "server": false, + "ui": true + } diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/action_type_registry.mock.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/action_type_registry.mock.ts new file mode 100644 index 0000000000000..8ebfd7f933cd3 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/action_type_registry.mock.ts @@ -0,0 +1,21 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { ActionTypeRegistryContract } from '../types'; + +const createActionTypeRegistryMock = () => { + const mocked: jest.Mocked = { + has: jest.fn(x => true), + register: jest.fn(), + get: jest.fn(), + list: jest.fn(), + }; + return mocked; +}; + +export const actionTypeRegistryMock = { + create: createActionTypeRegistryMock, +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/alert_type_registry.mock.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/alert_type_registry.mock.ts new file mode 100644 index 0000000000000..89eca7563a4e1 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/alert_type_registry.mock.ts @@ -0,0 +1,21 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { AlertTypeRegistryContract } from '../types'; + +const createAlertTypeRegistryMock = () => { + const mocked: jest.Mocked = { + has: jest.fn(), + register: jest.fn(), + get: jest.fn(), + list: jest.fn(), + }; + return mocked; +}; + +export const alertTypeRegistryMock = { + create: createAlertTypeRegistryMock, +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/app.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/app.tsx new file mode 100644 index 0000000000000..3ad6b5b7c697d --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/app.tsx @@ -0,0 +1,64 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import React from 'react'; +import { Switch, Route, Redirect, HashRouter } from 'react-router-dom'; +import { + ChromeStart, + DocLinksStart, + ToastsSetup, + HttpSetup, + IUiSettingsClient, +} from 'kibana/public'; +import { BASE_PATH, Section } from './constants'; +import { TriggersActionsUIHome } from './home'; +import { AppContextProvider, useAppDependencies } from './app_context'; +import { hasShowAlertsCapability } from './lib/capabilities'; +import { LegacyDependencies, ActionTypeModel, AlertTypeModel } from '../types'; +import { TypeRegistry } from './type_registry'; + +export interface AppDeps { + chrome: ChromeStart; + docLinks: DocLinksStart; + toastNotifications: ToastsSetup; + injectedMetadata: any; + http: HttpSetup; + uiSettings: IUiSettingsClient; + legacy: LegacyDependencies; + actionTypeRegistry: TypeRegistry; + alertTypeRegistry: TypeRegistry; +} + +export const App = (appDeps: AppDeps) => { + const sections: Section[] = ['alerts', 'connectors']; + + const sectionsRegex = sections.join('|'); + + return ( + + + + + + ); +}; + +export const AppWithoutRouter = ({ sectionsRegex }: any) => { + const { + legacy: { capabilities }, + } = useAppDependencies(); + const canShowAlerts = hasShowAlertsCapability(capabilities.get()); + const DEFAULT_SECTION: Section = canShowAlerts ? 'alerts' : 'connectors'; + return ( + + + + + ); +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/app_context.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/app_context.tsx new file mode 100644 index 0000000000000..bf2e0c7274e7b --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/app_context.tsx @@ -0,0 +1,30 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React, { createContext, useContext } from 'react'; +import { AppDeps } from './app'; + +const AppContext = createContext(null); + +export const AppContextProvider = ({ + children, + appDeps, +}: { + appDeps: AppDeps | null; + children: React.ReactNode; +}) => { + return appDeps ? {children} : null; +}; + +export const useAppDependencies = (): AppDeps => { + const ctx = useContext(AppContext); + if (!ctx) { + throw new Error( + 'The app dependencies Context has not been set. Use the "setAppDependencies()" method when bootstrapping the app.' + ); + } + return ctx; +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/boot.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/boot.tsx new file mode 100644 index 0000000000000..a37bedbfbdda8 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/boot.tsx @@ -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; + * you may not use this file except in compliance with the Elastic License. + */ + +import React from 'react'; +import { render, unmountComponentAtNode } from 'react-dom'; +import { SavedObjectsClientContract } from 'src/core/public'; + +import { App, AppDeps } from './app'; +import { setSavedObjectsClient } from '../application/components/builtin_alert_types/threshold/lib/api'; +import { LegacyDependencies } from '../types'; + +interface BootDeps extends AppDeps { + element: HTMLElement; + savedObjects: SavedObjectsClientContract; + I18nContext: any; + legacy: LegacyDependencies; +} + +export const boot = (bootDeps: BootDeps) => { + const { I18nContext, element, legacy, savedObjects, ...appDeps } = bootDeps; + + setSavedObjectsClient(savedObjects); + + render( + + + , + element + ); + return () => unmountComponentAtNode(element); +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/email.test.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/email.test.tsx new file mode 100644 index 0000000000000..5c924982c3536 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/email.test.tsx @@ -0,0 +1,228 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import React from 'react'; +import { mountWithIntl } from 'test_utils/enzyme_helpers'; +import { TypeRegistry } from '../../type_registry'; +import { registerBuiltInActionTypes } from './index'; +import { ActionTypeModel, ActionConnector } from '../../../types'; + +const ACTION_TYPE_ID = '.email'; +let actionTypeModel: ActionTypeModel; + +beforeAll(() => { + const actionTypeRegistry = new TypeRegistry(); + registerBuiltInActionTypes({ actionTypeRegistry }); + const getResult = actionTypeRegistry.get(ACTION_TYPE_ID); + if (getResult !== null) { + actionTypeModel = getResult; + } +}); + +describe('actionTypeRegistry.get() works', () => { + test('action type static data is as expected', () => { + expect(actionTypeModel.id).toEqual(ACTION_TYPE_ID); + expect(actionTypeModel.iconClass).toEqual('email'); + }); +}); + +describe('connector validation', () => { + test('connector validation succeeds when connector config is valid', () => { + const actionConnector = { + secrets: { + user: 'user', + password: 'pass', + }, + id: 'test', + actionTypeId: '.email', + name: 'email', + config: { + from: 'test@test.com', + port: '2323', + host: 'localhost', + test: 'test', + }, + } as ActionConnector; + + expect(actionTypeModel.validateConnector(actionConnector)).toEqual({ + errors: { + from: [], + service: [], + port: [], + host: [], + user: [], + password: [], + }, + }); + + delete actionConnector.config.test; + actionConnector.config.host = 'elastic.co'; + actionConnector.config.port = 8080; + expect(actionTypeModel.validateConnector(actionConnector)).toEqual({ + errors: { + from: [], + service: [], + port: [], + host: [], + user: [], + password: [], + }, + }); + delete actionConnector.config.host; + delete actionConnector.config.port; + actionConnector.config.service = 'testService'; + expect(actionTypeModel.validateConnector(actionConnector)).toEqual({ + errors: { + from: [], + service: [], + port: [], + host: [], + user: [], + password: [], + }, + }); + }); + + test('connector validation fails when connector config is not valid', () => { + const actionConnector = { + secrets: { + user: 'user', + password: 'pass', + }, + id: 'test', + actionTypeId: '.email', + name: 'email', + config: { + from: 'test@test.com', + }, + } as ActionConnector; + + expect(actionTypeModel.validateConnector(actionConnector)).toEqual({ + errors: { + from: [], + service: ['Service is required.'], + port: ['Port is required.'], + host: ['Host is required.'], + user: [], + password: [], + }, + }); + }); +}); + +describe('action params validation', () => { + test('action params validation succeeds when action params is valid', () => { + const actionParams = { + to: [], + cc: ['test1@test.com'], + message: 'message {test}', + subject: 'test', + }; + + expect(actionTypeModel.validateParams(actionParams)).toEqual({ + errors: { + to: [], + cc: [], + bcc: [], + message: [], + subject: [], + }, + }); + }); + + test('action params validation fails when action params is not valid', () => { + const actionParams = { + to: ['test@test.com'], + subject: 'test', + }; + + expect(actionTypeModel.validateParams(actionParams)).toEqual({ + errors: { + to: [], + cc: [], + bcc: [], + message: ['Message is required.'], + subject: [], + }, + }); + }); +}); + +describe('EmailActionConnectorFields renders', () => { + test('all connector fields is rendered', () => { + expect(actionTypeModel.actionConnectorFields).not.toBeNull(); + if (!actionTypeModel.actionConnectorFields) { + return; + } + const ConnectorFields = actionTypeModel.actionConnectorFields; + const actionConnector = { + secrets: { + user: 'user', + password: 'pass', + }, + id: 'test', + actionTypeId: '.email', + name: 'email', + config: { + from: 'test@test.com', + }, + } as ActionConnector; + const wrapper = mountWithIntl( + {}} + editActionSecrets={() => {}} + hasErrors={false} + /> + ); + expect(wrapper.find('[data-test-subj="emailFromInput"]').length > 0).toBeTruthy(); + expect( + wrapper + .find('[data-test-subj="emailFromInput"]') + .first() + .prop('value') + ).toBe('test@test.com'); + expect(wrapper.find('[data-test-subj="emailHostInput"]').length > 0).toBeTruthy(); + expect(wrapper.find('[data-test-subj="emailPortInput"]').length > 0).toBeTruthy(); + expect(wrapper.find('[data-test-subj="emailUserInput"]').length > 0).toBeTruthy(); + expect(wrapper.find('[data-test-subj="emailPasswordInput"]').length > 0).toBeTruthy(); + }); +}); + +describe('EmailParamsFields renders', () => { + test('all params fields is rendered', () => { + expect(actionTypeModel.actionParamsFields).not.toBeNull(); + if (!actionTypeModel.actionParamsFields) { + return; + } + const ParamsFields = actionTypeModel.actionParamsFields; + const actionParams = { + to: ['test@test.com'], + subject: 'test', + message: 'test message', + }; + const wrapper = mountWithIntl( + {}} + index={0} + hasErrors={false} + /> + ); + expect(wrapper.find('[data-test-subj="toEmailAddressInput"]').length > 0).toBeTruthy(); + expect( + wrapper + .find('[data-test-subj="toEmailAddressInput"]') + .first() + .prop('selectedOptions') + ).toStrictEqual([{ label: 'test@test.com' }]); + expect(wrapper.find('[data-test-subj="ccEmailAddressInput"]').length > 0).toBeTruthy(); + expect(wrapper.find('[data-test-subj="bccEmailAddressInput"]').length > 0).toBeTruthy(); + expect(wrapper.find('[data-test-subj="emailSubjectInput"]').length > 0).toBeTruthy(); + expect(wrapper.find('[data-test-subj="emailMessageInput"]').length > 0).toBeTruthy(); + }); +}); diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/email.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/email.tsx new file mode 100644 index 0000000000000..a6750ccf96deb --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/email.tsx @@ -0,0 +1,545 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import React, { Fragment } from 'react'; +import { + EuiFieldText, + EuiFlexItem, + EuiFlexGroup, + EuiFieldNumber, + EuiFieldPassword, + EuiComboBox, + EuiTextArea, + EuiSwitch, + EuiFormRow, +} from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; +import { + ActionTypeModel, + ActionConnectorFieldsProps, + ActionConnector, + ValidationResult, + ActionParamsProps, +} from '../../../types'; + +export function getActionType(): ActionTypeModel { + const mailformat = /^[^@\s]+@[^@\s]+$/; + return { + id: '.email', + iconClass: 'email', + selectMessage: i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.emailAction.selectMessageText', + { + defaultMessage: 'Send email from your server.', + } + ), + validateConnector: (action: ActionConnector): ValidationResult => { + const validationResult = { errors: {} }; + const errors = { + from: new Array(), + service: new Array(), + port: new Array(), + host: new Array(), + user: new Array(), + password: new Array(), + }; + validationResult.errors = errors; + if (!action.config.from) { + errors.from.push( + i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.error.requiredFromText', + { + defaultMessage: 'Sender is required.', + } + ) + ); + } + if (action.config.from && !action.config.from.trim().match(mailformat)) { + errors.from.push( + i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.error.formatFromText', + { + defaultMessage: 'Sender is not a valid email address.', + } + ) + ); + } + if (!action.config.port && !action.config.service) { + errors.port.push( + i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.error.requiredPortText', + { + defaultMessage: 'Port is required.', + } + ) + ); + } + if (!action.config.service && (!action.config.port || !action.config.host)) { + errors.service.push( + i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.error.requiredServiceText', + { + defaultMessage: 'Service is required.', + } + ) + ); + } + if (!action.config.host && !action.config.service) { + errors.host.push( + i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.error.requiredHostText', + { + defaultMessage: 'Host is required.', + } + ) + ); + } + if (!action.secrets.user) { + errors.user.push( + i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.error.requiredUserText', + { + defaultMessage: 'Username is required.', + } + ) + ); + } + if (!action.secrets.password) { + errors.password.push( + i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.error.requiredPasswordText', + { + defaultMessage: 'Password is required.', + } + ) + ); + } + return validationResult; + }, + validateParams: (actionParams: any): ValidationResult => { + const validationResult = { errors: {} }; + const errors = { + to: new Array(), + cc: new Array(), + bcc: new Array(), + message: new Array(), + subject: new Array(), + }; + validationResult.errors = errors; + if ( + (!(actionParams.to instanceof Array) || actionParams.to.length === 0) && + (!(actionParams.cc instanceof Array) || actionParams.cc.length === 0) && + (!(actionParams.bcc instanceof Array) || actionParams.bcc.length === 0) + ) { + const errorText = i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.error.requiredEntryText', + { + defaultMessage: 'No [to], [cc], or [bcc] entries. At least one entry is required.', + } + ); + errors.to.push(errorText); + errors.cc.push(errorText); + errors.bcc.push(errorText); + } + if (!actionParams.message) { + errors.message.push( + i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.error.requiredMessageText', + { + defaultMessage: 'Message is required.', + } + ) + ); + } + if (!actionParams.subject) { + errors.subject.push( + i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.error.requiredSubjectText', + { + defaultMessage: 'Subject is required.', + } + ) + ); + } + return validationResult; + }, + actionConnectorFields: EmailActionConnectorFields, + actionParamsFields: EmailParamsFields, + }; +} + +const EmailActionConnectorFields: React.FunctionComponent = ({ + action, + editActionConfig, + editActionSecrets, + errors, +}) => { + const { from, host, port, secure } = action.config; + const { user, password } = action.secrets; + + return ( + + + + 0 && from !== undefined} + label={i18n.translate( + 'xpack.triggersActionsUI.sections.builtinActionTypes.emailAction.fromTextFieldLabel', + { + defaultMessage: 'Sender', + } + )} + > + 0 && from !== undefined} + name="from" + value={from || ''} + data-test-subj="emailFromInput" + onChange={e => { + editActionConfig('from', e.target.value); + }} + onBlur={() => { + if (!from) { + editActionConfig('from', ''); + } + }} + /> + + + + + + 0 && host !== undefined} + label={i18n.translate( + 'xpack.triggersActionsUI.sections.builtinActionTypes.emailAction.hostTextFieldLabel', + { + defaultMessage: 'Host', + } + )} + > + 0 && host !== undefined} + name="host" + value={host || ''} + data-test-subj="emailHostInput" + onChange={e => { + editActionConfig('host', e.target.value); + }} + onBlur={() => { + if (!host) { + editActionConfig('host', ''); + } + }} + /> + + + + + + 0 && port !== undefined} + label={i18n.translate( + 'xpack.triggersActionsUI.sections.builtinActionTypes.emailAction.portTextFieldLabel', + { + defaultMessage: 'Port', + } + )} + > + 0 && port !== undefined} + fullWidth + name="port" + value={port || ''} + data-test-subj="emailPortInput" + onChange={e => { + editActionConfig('port', parseInt(e.target.value, 10)); + }} + onBlur={() => { + if (!port) { + editActionConfig('port', ''); + } + }} + /> + + + + + + { + editActionConfig('secure', e.target.checked); + }} + /> + + + + + + + + + 0 && user !== undefined} + label={i18n.translate( + 'xpack.triggersActionsUI.sections.builtinActionTypes.emailAction.userTextFieldLabel', + { + defaultMessage: 'Username', + } + )} + > + 0 && user !== undefined} + name="user" + value={user || ''} + data-test-subj="emailUserInput" + onChange={e => { + editActionSecrets('user', e.target.value); + }} + onBlur={() => { + if (!user) { + editActionSecrets('user', ''); + } + }} + /> + + + + 0 && password !== undefined} + label={i18n.translate( + 'xpack.triggersActionsUI.sections.builtinActionTypes.emailAction.passwordFieldLabel', + { + defaultMessage: 'Password', + } + )} + > + 0 && password !== undefined} + name="password" + value={password || ''} + data-test-subj="emailPasswordInput" + onChange={e => { + editActionSecrets('password', e.target.value); + }} + onBlur={() => { + if (!password) { + editActionSecrets('password', ''); + } + }} + /> + + + + + ); +}; + +const EmailParamsFields: React.FunctionComponent = ({ + action, + editAction, + index, + errors, + hasErrors, +}) => { + const { to, cc, bcc, subject, message } = action; + const toOptions = to ? to.map((label: string) => ({ label })) : []; + const ccOptions = cc ? cc.map((label: string) => ({ label })) : []; + const bccOptions = bcc ? bcc.map((label: string) => ({ label })) : []; + + return ( + + + { + const newOptions = [...toOptions, { label: searchValue }]; + editAction( + 'to', + newOptions.map(newOption => newOption.label), + index + ); + }} + onChange={(selectedOptions: Array<{ label: string }>) => { + editAction( + 'to', + selectedOptions.map(selectedOption => selectedOption.label), + index + ); + }} + onBlur={() => { + if (!to) { + editAction('to', [], index); + } + }} + /> + + + { + const newOptions = [...ccOptions, { label: searchValue }]; + editAction( + 'cc', + newOptions.map(newOption => newOption.label), + index + ); + }} + onChange={(selectedOptions: Array<{ label: string }>) => { + editAction( + 'cc', + selectedOptions.map(selectedOption => selectedOption.label), + index + ); + }} + onBlur={() => { + if (!cc) { + editAction('cc', [], index); + } + }} + /> + + + { + const newOptions = [...bccOptions, { label: searchValue }]; + editAction( + 'bcc', + newOptions.map(newOption => newOption.label), + index + ); + }} + onChange={(selectedOptions: Array<{ label: string }>) => { + editAction( + 'bcc', + selectedOptions.map(selectedOption => selectedOption.label), + index + ); + }} + onBlur={() => { + if (!bcc) { + editAction('bcc', [], index); + } + }} + /> + + + { + editAction('subject', e.target.value, index); + }} + /> + + + { + editAction('message', e.target.value, index); + }} + /> + + + ); +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/es_index.test.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/es_index.test.tsx new file mode 100644 index 0000000000000..b6a7c4d82aca4 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/es_index.test.tsx @@ -0,0 +1,140 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import React from 'react'; +import { mountWithIntl } from 'test_utils/enzyme_helpers'; +import { TypeRegistry } from '../../type_registry'; +import { registerBuiltInActionTypes } from './index'; +import { ActionTypeModel, ActionConnector } from '../../../types'; + +const ACTION_TYPE_ID = '.index'; +let actionTypeModel: ActionTypeModel; + +beforeAll(() => { + const actionTypeRegistry = new TypeRegistry(); + registerBuiltInActionTypes({ actionTypeRegistry }); + const getResult = actionTypeRegistry.get(ACTION_TYPE_ID); + if (getResult !== null) { + actionTypeModel = getResult; + } +}); + +describe('actionTypeRegistry.get() works', () => { + test('action type .index is registered', () => { + expect(actionTypeModel.id).toEqual(ACTION_TYPE_ID); + expect(actionTypeModel.iconClass).toEqual('indexOpen'); + }); +}); + +describe('index connector validation', () => { + test('connector validation succeeds when connector config is valid', () => { + const actionConnector = { + secrets: {}, + id: 'test', + actionTypeId: '.index', + name: 'es_index', + config: { + index: 'test_es_index', + }, + } as ActionConnector; + + expect(actionTypeModel.validateConnector(actionConnector)).toEqual({ + errors: {}, + }); + + delete actionConnector.config.index; + expect(actionTypeModel.validateConnector(actionConnector)).toEqual({ + errors: {}, + }); + }); +}); + +describe('action params validation', () => { + test('action params validation succeeds when action params is valid', () => { + const actionParams = { + index: 'test', + refresh: false, + executionTimeField: '1', + documents: ['test'], + }; + + expect(actionTypeModel.validateParams(actionParams)).toEqual({ + errors: {}, + }); + + const emptyActionParams = {}; + + expect(actionTypeModel.validateParams(emptyActionParams)).toEqual({ + errors: {}, + }); + }); +}); + +describe('IndexActionConnectorFields renders', () => { + test('all connector fields is rendered', () => { + expect(actionTypeModel.actionConnectorFields).not.toBeNull(); + if (!actionTypeModel.actionConnectorFields) { + return; + } + const ConnectorFields = actionTypeModel.actionConnectorFields; + const actionConnector = { + secrets: {}, + id: 'test', + actionTypeId: '.index', + name: 'es_index', + config: { + index: 'test', + }, + } as ActionConnector; + const wrapper = mountWithIntl( + {}} + editActionSecrets={() => {}} + hasErrors={false} + /> + ); + expect(wrapper.find('[data-test-subj="indexInput"]').length > 0).toBeTruthy(); + expect( + wrapper + .find('[data-test-subj="indexInput"]') + .first() + .prop('value') + ).toBe('test'); + }); +}); + +describe('IndexParamsFields renders', () => { + test('all params fields is rendered', () => { + expect(actionTypeModel.actionParamsFields).not.toBeNull(); + if (!actionTypeModel.actionParamsFields) { + return; + } + const ParamsFields = actionTypeModel.actionParamsFields; + const actionParams = { + index: 'test_index', + refresh: false, + documents: ['test'], + }; + const wrapper = mountWithIntl( + {}} + index={0} + hasErrors={false} + /> + ); + expect(wrapper.find('[data-test-subj="indexInput"]').length > 0).toBeTruthy(); + expect( + wrapper + .find('[data-test-subj="indexInput"]') + .first() + .prop('value') + ).toBe('test_index'); + expect(wrapper.find('[data-test-subj="indexRefreshCheckbox"]').length > 0).toBeTruthy(); + }); +}); diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/es_index.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/es_index.tsx new file mode 100644 index 0000000000000..aa15195cdc286 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/es_index.tsx @@ -0,0 +1,124 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import React, { Fragment } from 'react'; +import { EuiFieldText, EuiFormRow, EuiSwitch } from '@elastic/eui'; +import { FormattedMessage } from '@kbn/i18n/react'; +import { i18n } from '@kbn/i18n'; +import { + ActionTypeModel, + ActionConnectorFieldsProps, + ValidationResult, + ActionParamsProps, +} from '../../../types'; + +export function getActionType(): ActionTypeModel { + return { + id: '.index', + iconClass: 'indexOpen', + selectMessage: i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.indexAction.selectMessageText', + { + defaultMessage: 'Index data into Elasticsearch.', + } + ), + validateConnector: (): ValidationResult => { + return { errors: {} }; + }, + actionConnectorFields: IndexActionConnectorFields, + actionParamsFields: IndexParamsFields, + validateParams: (actionParams: any): ValidationResult => { + const validationResult = { errors: {} }; + return validationResult; + }, + }; +} + +const IndexActionConnectorFields: React.FunctionComponent = ({ + action, + editActionConfig, +}) => { + const { index } = action.config; + return ( + + ) => { + editActionConfig('index', e.target.value); + }} + onBlur={() => { + if (!index) { + editActionConfig('index', ''); + } + }} + /> + + ); +}; + +const IndexParamsFields: React.FunctionComponent = ({ + action, + index, + editAction, + errors, + hasErrors, +}) => { + const { refresh } = action; + return ( + + + ) => { + editAction('index', e.target.value, index); + }} + onBlur={() => { + if (!action.index) { + editAction('index', '', index); + } + }} + /> + + { + editAction('refresh', e.target.checked, index); + }} + label={ + + } + /> + + ); +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/index.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/index.ts new file mode 100644 index 0000000000000..6ffd9b2c9ffde --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/index.ts @@ -0,0 +1,27 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { getActionType as getServerLogActionType } from './server_log'; +import { getActionType as getSlackActionType } from './slack'; +import { getActionType as getEmailActionType } from './email'; +import { getActionType as getIndexActionType } from './es_index'; +import { getActionType as getPagerDutyActionType } from './pagerduty'; +import { getActionType as getWebhookActionType } from './webhook'; +import { TypeRegistry } from '../../type_registry'; +import { ActionTypeModel } from '../../../types'; + +export function registerBuiltInActionTypes({ + actionTypeRegistry, +}: { + actionTypeRegistry: TypeRegistry; +}) { + actionTypeRegistry.register(getServerLogActionType()); + actionTypeRegistry.register(getSlackActionType()); + actionTypeRegistry.register(getEmailActionType()); + actionTypeRegistry.register(getIndexActionType()); + actionTypeRegistry.register(getPagerDutyActionType()); + actionTypeRegistry.register(getWebhookActionType()); +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/pagerduty.test.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/pagerduty.test.tsx new file mode 100644 index 0000000000000..582315c95812a --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/pagerduty.test.tsx @@ -0,0 +1,179 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import React from 'react'; +import { mountWithIntl } from 'test_utils/enzyme_helpers'; +import { TypeRegistry } from '../../type_registry'; +import { registerBuiltInActionTypes } from './index'; +import { ActionTypeModel, ActionConnector } from '../../../types'; + +const ACTION_TYPE_ID = '.pagerduty'; +let actionTypeModel: ActionTypeModel; + +beforeAll(() => { + const actionTypeRegistry = new TypeRegistry(); + registerBuiltInActionTypes({ actionTypeRegistry }); + const getResult = actionTypeRegistry.get(ACTION_TYPE_ID); + if (getResult !== null) { + actionTypeModel = getResult; + } +}); + +describe('actionTypeRegistry.get() works', () => { + test('action type static data is as expected', () => { + expect(actionTypeModel.id).toEqual(ACTION_TYPE_ID); + expect(actionTypeModel.iconClass).toEqual('apps'); + }); +}); + +describe('pagerduty connector validation', () => { + test('connector validation succeeds when connector config is valid', () => { + const actionConnector = { + secrets: { + routingKey: 'test', + }, + id: 'test', + actionTypeId: '.pagerduty', + name: 'pagerduty', + config: { + apiUrl: 'http:\\test', + }, + } as ActionConnector; + + expect(actionTypeModel.validateConnector(actionConnector)).toEqual({ + errors: { + routingKey: [], + }, + }); + + delete actionConnector.config.apiUrl; + actionConnector.secrets.routingKey = 'test1'; + expect(actionTypeModel.validateConnector(actionConnector)).toEqual({ + errors: { + routingKey: [], + }, + }); + }); + + test('connector validation fails when connector config is not valid', () => { + const actionConnector = { + secrets: {}, + id: 'test', + actionTypeId: '.pagerduty', + name: 'pagerduty', + config: { + apiUrl: 'http:\\test', + }, + } as ActionConnector; + + expect(actionTypeModel.validateConnector(actionConnector)).toEqual({ + errors: { + routingKey: ['A routing key is required.'], + }, + }); + }); +}); + +describe('pagerduty action params validation', () => { + test('action params validation succeeds when action params is valid', () => { + const actionParams = { + eventAction: 'trigger', + dedupKey: 'test', + summary: '2323', + source: 'source', + severity: 'critical', + timestamp: '234654564654', + component: 'test', + group: 'group', + class: 'test class', + }; + + expect(actionTypeModel.validateParams(actionParams)).toEqual({ + errors: {}, + }); + }); +}); + +describe('PagerDutyActionConnectorFields renders', () => { + test('all connector fields is rendered', () => { + expect(actionTypeModel.actionConnectorFields).not.toBeNull(); + if (!actionTypeModel.actionConnectorFields) { + return; + } + const ConnectorFields = actionTypeModel.actionConnectorFields; + const actionConnector = { + secrets: { + routingKey: 'test', + }, + id: 'test', + actionTypeId: '.pagerduty', + name: 'pagerduty', + config: { + apiUrl: 'http:\\test', + }, + } as ActionConnector; + const wrapper = mountWithIntl( + {}} + editActionSecrets={() => {}} + hasErrors={false} + /> + ); + expect(wrapper.find('[data-test-subj="pagerdutyApiUrlInput"]').length > 0).toBeTruthy(); + expect( + wrapper + .find('[data-test-subj="pagerdutyApiUrlInput"]') + .first() + .prop('value') + ).toBe('http:\\test'); + expect(wrapper.find('[data-test-subj="pagerdutyRoutingKeyInput"]').length > 0).toBeTruthy(); + }); +}); + +describe('PagerDutyParamsFields renders', () => { + test('all params fields is rendered', () => { + expect(actionTypeModel.actionParamsFields).not.toBeNull(); + if (!actionTypeModel.actionParamsFields) { + return; + } + const ParamsFields = actionTypeModel.actionParamsFields; + const actionParams = { + eventAction: 'trigger', + dedupKey: 'test', + summary: '2323', + source: 'source', + severity: 'critical', + timestamp: '234654564654', + component: 'test', + group: 'group', + class: 'test class', + }; + const wrapper = mountWithIntl( + {}} + index={0} + hasErrors={false} + /> + ); + expect(wrapper.find('[data-test-subj="severitySelect"]').length > 0).toBeTruthy(); + expect( + wrapper + .find('[data-test-subj="severitySelect"]') + .first() + .prop('value') + ).toStrictEqual('critical'); + expect(wrapper.find('[data-test-subj="eventActionSelect"]').length > 0).toBeTruthy(); + expect(wrapper.find('[data-test-subj="dedupKeyInput"]').length > 0).toBeTruthy(); + expect(wrapper.find('[data-test-subj="timestampInput"]').length > 0).toBeTruthy(); + expect(wrapper.find('[data-test-subj="componentInput"]').length > 0).toBeTruthy(); + expect(wrapper.find('[data-test-subj="groupInput"]').length > 0).toBeTruthy(); + expect(wrapper.find('[data-test-subj="sourceInput"]').length > 0).toBeTruthy(); + expect(wrapper.find('[data-test-subj="pagerdutyDescriptionInput"]').length > 0).toBeTruthy(); + }); +}); diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/pagerduty.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/pagerduty.tsx new file mode 100644 index 0000000000000..69c7ec166df60 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/pagerduty.tsx @@ -0,0 +1,361 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import React, { Fragment } from 'react'; +import { + EuiFieldText, + EuiFlexGroup, + EuiFlexItem, + EuiFormRow, + EuiSelect, + EuiLink, +} from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; +import { FormattedMessage } from '@kbn/i18n/react'; +import { + ActionTypeModel, + ActionConnectorFieldsProps, + ActionConnector, + ValidationResult, + ActionParamsProps, +} from '../../../types'; + +export function getActionType(): ActionTypeModel { + return { + id: '.pagerduty', + iconClass: 'apps', + selectMessage: i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.pagerDutyAction.selectMessageText', + { + defaultMessage: 'Send an event in PagerDuty.', + } + ), + validateConnector: (action: ActionConnector): ValidationResult => { + const validationResult = { errors: {} }; + const errors = { + routingKey: new Array(), + }; + validationResult.errors = errors; + if (!action.secrets.routingKey) { + errors.routingKey.push( + i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.pagerDutyAction.error.requiredRoutingKeyText', + { + defaultMessage: 'A routing key is required.', + } + ) + ); + } + return validationResult; + }, + validateParams: (actionParams: any): ValidationResult => { + const validationResult = { errors: {} }; + return validationResult; + }, + actionConnectorFields: PagerDutyActionConnectorFields, + actionParamsFields: PagerDutyParamsFields, + }; +} + +const PagerDutyActionConnectorFields: React.FunctionComponent = ({ + errors, + action, + editActionConfig, + editActionSecrets, +}) => { + const { apiUrl } = action.config; + const { routingKey } = action.secrets; + return ( + + + ) => { + editActionConfig('apiUrl', e.target.value); + }} + onBlur={() => { + if (!apiUrl) { + editActionConfig('apiUrl', ''); + } + }} + /> + + + + + } + error={errors.routingKey} + isInvalid={errors.routingKey.length > 0 && routingKey !== undefined} + label={i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.pagerDutyAction.routingKeyTextFieldLabel', + { + defaultMessage: 'Routing key', + } + )} + > + 0 && routingKey !== undefined} + name="routingKey" + value={routingKey || ''} + data-test-subj="pagerdutyRoutingKeyInput" + onChange={(e: React.ChangeEvent) => { + editActionSecrets('routingKey', e.target.value); + }} + onBlur={() => { + if (!routingKey) { + editActionSecrets('routingKey', ''); + } + }} + /> + + + ); +}; + +const PagerDutyParamsFields: React.FunctionComponent = ({ + action, + editAction, + index, + errors, + hasErrors, +}) => { + const { eventAction, dedupKey, summary, source, severity, timestamp, component, group } = action; + const severityOptions = [ + { value: 'critical', text: 'Critical' }, + { value: 'info', text: 'Info' }, + { value: 'warning', text: 'Warning' }, + { value: 'error', text: 'Error' }, + ]; + const eventActionOptions = [ + { value: 'trigger', text: 'Trigger' }, + { value: 'resolve', text: 'Resolve' }, + { value: 'acknowledge', text: 'Acknowledge' }, + ]; + return ( + + + + + { + editAction('severity', e.target.value, index); + }} + /> + + + + + { + editAction('eventAction', e.target.value, index); + }} + /> + + + + + + + ) => { + editAction('dedupKey', e.target.value, index); + }} + onBlur={() => { + if (!index) { + editAction('dedupKey', '', index); + } + }} + /> + + + + + ) => { + editAction('timestamp', e.target.value, index); + }} + onBlur={() => { + if (!index) { + editAction('timestamp', '', index); + } + }} + /> + + + + + ) => { + editAction('component', e.target.value, index); + }} + onBlur={() => { + if (!index) { + editAction('component', '', index); + } + }} + /> + + + ) => { + editAction('group', e.target.value, index); + }} + onBlur={() => { + if (!index) { + editAction('group', '', index); + } + }} + /> + + + ) => { + editAction('source', e.target.value, index); + }} + onBlur={() => { + if (!index) { + editAction('source', '', index); + } + }} + /> + + + ) => { + editAction('summary', e.target.value, index); + }} + onBlur={() => { + if (!summary) { + editAction('summary', '', index); + } + }} + /> + + + ); +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/server_log.test.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/server_log.test.tsx new file mode 100644 index 0000000000000..b79be4eef523b --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/server_log.test.tsx @@ -0,0 +1,130 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import React from 'react'; +import { mountWithIntl } from 'test_utils/enzyme_helpers'; +import { TypeRegistry } from '../../type_registry'; +import { registerBuiltInActionTypes } from './index'; +import { ActionTypeModel, ActionConnector } from '../../../types'; + +const ACTION_TYPE_ID = '.server-log'; +let actionTypeModel: ActionTypeModel; + +beforeAll(() => { + const actionTypeRegistry = new TypeRegistry(); + registerBuiltInActionTypes({ actionTypeRegistry }); + const getResult = actionTypeRegistry.get(ACTION_TYPE_ID); + if (getResult !== null) { + actionTypeModel = getResult; + } +}); + +describe('actionTypeRegistry.get() works', () => { + test('action type static data is as expected', () => { + expect(actionTypeModel.id).toEqual(ACTION_TYPE_ID); + expect(actionTypeModel.iconClass).toEqual('logsApp'); + }); +}); + +describe('server-log connector validation', () => { + test('connector validation succeeds when connector config is valid', () => { + const actionConnector = { + secrets: {}, + id: 'test', + actionTypeId: '.server-log', + name: 'server-log', + config: {}, + } as ActionConnector; + + expect(actionTypeModel.validateConnector(actionConnector)).toEqual({ + errors: {}, + }); + }); +}); + +describe('action params validation', () => { + test('action params validation succeeds when action params is valid', () => { + const actionParams = { + message: 'test message', + level: 'trace', + }; + + expect(actionTypeModel.validateParams(actionParams)).toEqual({ + errors: { message: [] }, + }); + }); +}); + +describe('ServerLogParamsFields renders', () => { + test('all params fields is rendered', () => { + expect(actionTypeModel.actionParamsFields).not.toBeNull(); + if (!actionTypeModel.actionParamsFields) { + return; + } + const ParamsFields = actionTypeModel.actionParamsFields; + const actionParams = { + message: 'test message', + level: 'trace', + }; + const wrapper = mountWithIntl( + {}} + index={0} + hasErrors={false} + /> + ); + expect(wrapper.find('[data-test-subj="loggingLevelSelect"]').length > 0).toBeTruthy(); + expect( + wrapper + .find('[data-test-subj="loggingLevelSelect"]') + .first() + .prop('value') + ).toStrictEqual('trace'); + expect(wrapper.find('[data-test-subj="loggingMessageInput"]').length > 0).toBeTruthy(); + }); + + test('level param field is rendered with default value if not selected', () => { + expect(actionTypeModel.actionParamsFields).not.toBeNull(); + if (!actionTypeModel.actionParamsFields) { + return; + } + const ParamsFields = actionTypeModel.actionParamsFields; + const actionParams = { + message: 'test message', + level: 'info', + }; + const wrapper = mountWithIntl( + {}} + index={0} + hasErrors={false} + /> + ); + expect(wrapper.find('[data-test-subj="loggingLevelSelect"]').length > 0).toBeTruthy(); + expect( + wrapper + .find('[data-test-subj="loggingLevelSelect"]') + .first() + .prop('value') + ).toStrictEqual('info'); + expect(wrapper.find('[data-test-subj="loggingMessageInput"]').length > 0).toBeTruthy(); + }); + + test('params validation fails when message is not valid', () => { + const actionParams = { + message: '', + }; + + expect(actionTypeModel.validateParams(actionParams)).toEqual({ + errors: { + message: ['Message is required.'], + }, + }); + }); +}); diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/server_log.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/server_log.tsx new file mode 100644 index 0000000000000..885061aa81924 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/server_log.tsx @@ -0,0 +1,116 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import React, { Fragment } from 'react'; +import { i18n } from '@kbn/i18n'; +import { EuiSelect, EuiTextArea, EuiFormRow } from '@elastic/eui'; +import { ActionTypeModel, ValidationResult, ActionParamsProps } from '../../../types'; + +export function getActionType(): ActionTypeModel { + return { + id: '.server-log', + iconClass: 'logsApp', + selectMessage: i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.serverLogAction.selectMessageText', + { + defaultMessage: 'Add a message to a Kibana log.', + } + ), + validateConnector: (): ValidationResult => { + return { errors: {} }; + }, + validateParams: (actionParams: any): ValidationResult => { + const validationResult = { errors: {} }; + const errors = { + message: new Array(), + }; + validationResult.errors = errors; + if (!actionParams.message || actionParams.message.length === 0) { + errors.message.push( + i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.error.requiredServerLogMessageText', + { + defaultMessage: 'Message is required.', + } + ) + ); + } + return validationResult; + }, + actionConnectorFields: null, + actionParamsFields: ServerLogParamsFields, + }; +} + +export const ServerLogParamsFields: React.FunctionComponent = ({ + action, + editAction, + index, + errors, + hasErrors, +}) => { + const { message, level } = action; + const levelOptions = [ + { value: 'trace', text: 'Trace' }, + { value: 'debug', text: 'Debug' }, + { value: 'info', text: 'Info' }, + { value: 'warn', text: 'Warning' }, + { value: 'error', text: 'Error' }, + { value: 'fatal', text: 'Fatal' }, + ]; + + // Set default value 'info' for level param + editAction('level', 'info', index); + + return ( + + + { + editAction('level', e.target.value, index); + }} + /> + + + { + editAction('message', e.target.value, index); + }} + /> + + + ); +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/slack.test.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/slack.test.tsx new file mode 100644 index 0000000000000..36beea4d2f2be --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/slack.test.tsx @@ -0,0 +1,152 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import React from 'react'; +import { mountWithIntl } from 'test_utils/enzyme_helpers'; +import { TypeRegistry } from '../../type_registry'; +import { registerBuiltInActionTypes } from './index'; +import { ActionTypeModel, ActionConnector } from '../../../types'; + +const ACTION_TYPE_ID = '.slack'; +let actionTypeModel: ActionTypeModel; + +beforeAll(() => { + const actionTypeRegistry = new TypeRegistry(); + registerBuiltInActionTypes({ actionTypeRegistry }); + const getResult = actionTypeRegistry.get(ACTION_TYPE_ID); + if (getResult !== null) { + actionTypeModel = getResult; + } +}); + +describe('actionTypeRegistry.get() works', () => { + test('action type static data is as expected', () => { + expect(actionTypeModel.id).toEqual(ACTION_TYPE_ID); + expect(actionTypeModel.iconClass).toEqual('logoSlack'); + }); +}); + +describe('slack connector validation', () => { + test('connector validation succeeds when connector config is valid', () => { + const actionConnector = { + secrets: { + webhookUrl: 'http:\\test', + }, + id: 'test', + actionTypeId: '.email', + name: 'email', + config: {}, + } as ActionConnector; + + expect(actionTypeModel.validateConnector(actionConnector)).toEqual({ + errors: { + webhookUrl: [], + }, + }); + }); + + test('connector validation fails when connector config is not valid', () => { + const actionConnector = { + secrets: {}, + id: 'test', + actionTypeId: '.email', + name: 'email', + config: {}, + } as ActionConnector; + + expect(actionTypeModel.validateConnector(actionConnector)).toEqual({ + errors: { + webhookUrl: ['Webhook URL is required.'], + }, + }); + }); +}); + +describe('slack action params validation', () => { + test('if action params validation succeeds when action params is valid', () => { + const actionParams = { + message: 'message {test}', + }; + + expect(actionTypeModel.validateParams(actionParams)).toEqual({ + errors: { message: [] }, + }); + }); +}); + +describe('SlackActionFields renders', () => { + test('all connector fields is rendered', () => { + expect(actionTypeModel.actionConnectorFields).not.toBeNull(); + if (!actionTypeModel.actionConnectorFields) { + return; + } + const ConnectorFields = actionTypeModel.actionConnectorFields; + const actionConnector = { + secrets: { + webhookUrl: 'http:\\test', + }, + id: 'test', + actionTypeId: '.email', + name: 'email', + config: {}, + } as ActionConnector; + const wrapper = mountWithIntl( + {}} + editActionSecrets={() => {}} + /> + ); + expect(wrapper.find('[data-test-subj="slackWebhookUrlInput"]').length > 0).toBeTruthy(); + expect( + wrapper + .find('[data-test-subj="slackWebhookUrlInput"]') + .first() + .prop('value') + ).toBe('http:\\test'); + }); +}); + +describe('SlackParamsFields renders', () => { + test('all params fields is rendered', () => { + expect(actionTypeModel.actionParamsFields).not.toBeNull(); + if (!actionTypeModel.actionParamsFields) { + return; + } + const ParamsFields = actionTypeModel.actionParamsFields; + const actionParams = { + message: 'test message', + }; + const wrapper = mountWithIntl( + {}} + index={0} + hasErrors={false} + /> + ); + expect(wrapper.find('[data-test-subj="slackMessageTextarea"]').length > 0).toBeTruthy(); + expect( + wrapper + .find('[data-test-subj="slackMessageTextarea"]') + .first() + .prop('value') + ).toStrictEqual('test message'); + }); + + test('params validation fails when message is not valid', () => { + const actionParams = { + message: '', + }; + + expect(actionTypeModel.validateParams(actionParams)).toEqual({ + errors: { + message: ['Message is required.'], + }, + }); + }); +}); diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/slack.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/slack.tsx new file mode 100644 index 0000000000000..0ae51725169bf --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/slack.tsx @@ -0,0 +1,175 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import React, { Fragment } from 'react'; +import { + EuiFieldText, + EuiTextArea, + EuiFlexGroup, + EuiFlexItem, + EuiButtonIcon, + EuiFormRow, + EuiLink, +} from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; +import { FormattedMessage } from '@kbn/i18n/react'; +import { + ActionTypeModel, + ActionConnectorFieldsProps, + ActionConnector, + ValidationResult, + ActionParamsProps, +} from '../../../types'; + +export function getActionType(): ActionTypeModel { + return { + id: '.slack', + iconClass: 'logoSlack', + selectMessage: i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.slackAction.selectMessageText', + { + defaultMessage: 'Send a message to a Slack channel or user.', + } + ), + validateConnector: (action: ActionConnector): ValidationResult => { + const validationResult = { errors: {} }; + const errors = { + webhookUrl: new Array(), + }; + validationResult.errors = errors; + if (!action.secrets.webhookUrl) { + errors.webhookUrl.push( + i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.slackAction.error.requiredWebhookUrlText', + { + defaultMessage: 'Webhook URL is required.', + } + ) + ); + } + return validationResult; + }, + validateParams: (actionParams: any): ValidationResult => { + const validationResult = { errors: {} }; + const errors = { + message: new Array(), + }; + validationResult.errors = errors; + if (!actionParams.message || actionParams.message.length === 0) { + errors.message.push( + i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.error.requiredSlackMessageText', + { + defaultMessage: 'Message is required.', + } + ) + ); + } + return validationResult; + }, + actionConnectorFields: SlackActionFields, + actionParamsFields: SlackParamsFields, + }; +} + +const SlackActionFields: React.FunctionComponent = ({ + action, + editActionSecrets, + errors, +}) => { + const { webhookUrl } = action.secrets; + + return ( + + + + + } + error={errors.webhookUrl} + isInvalid={errors.webhookUrl.length > 0 && webhookUrl !== undefined} + label={i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.slackAction.webhookUrlTextFieldLabel', + { + defaultMessage: 'Webhook URL', + } + )} + > + 0 && webhookUrl !== undefined} + name="webhookUrl" + placeholder="URL like https://hooks.slack.com/services" + value={webhookUrl || ''} + data-test-subj="slackWebhookUrlInput" + onChange={e => { + editActionSecrets('webhookUrl', e.target.value); + }} + onBlur={() => { + if (!webhookUrl) { + editActionSecrets('webhookUrl', ''); + } + }} + /> + + + ); +}; + +const SlackParamsFields: React.FunctionComponent = ({ + action, + editAction, + index, + errors, + hasErrors, +}) => { + const { message } = action; + + return ( + + + + window.alert('Button clicked')} + iconType="indexOpen" + aria-label="Add variable" + /> + + + + { + editAction('message', e.target.value, index); + }} + /> + + + ); +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/webhook.test.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/webhook.test.tsx new file mode 100644 index 0000000000000..cd342f2e19969 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/webhook.test.tsx @@ -0,0 +1,174 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import React from 'react'; +import { mountWithIntl } from 'test_utils/enzyme_helpers'; +import { TypeRegistry } from '../../type_registry'; +import { registerBuiltInActionTypes } from './index'; +import { ActionTypeModel, ActionConnector } from '../../../types'; + +const ACTION_TYPE_ID = '.webhook'; +let actionTypeModel: ActionTypeModel; + +beforeAll(() => { + const actionTypeRegistry = new TypeRegistry(); + registerBuiltInActionTypes({ actionTypeRegistry }); + const getResult = actionTypeRegistry.get(ACTION_TYPE_ID); + if (getResult !== null) { + actionTypeModel = getResult; + } +}); + +describe('actionTypeRegistry.get() works', () => { + test('action type static data is as expected', () => { + expect(actionTypeModel.id).toEqual(ACTION_TYPE_ID); + expect(actionTypeModel.iconClass).toEqual('logoWebhook'); + }); +}); + +describe('webhook connector validation', () => { + test('connector validation succeeds when connector config is valid', () => { + const actionConnector = { + secrets: { + user: 'user', + password: 'pass', + }, + id: 'test', + actionTypeId: '.webhook', + name: 'webhook', + config: { + method: 'PUT', + url: 'http:\\test', + headers: ['content-type: text'], + }, + } as ActionConnector; + + expect(actionTypeModel.validateConnector(actionConnector)).toEqual({ + errors: { + url: [], + method: [], + user: [], + password: [], + }, + }); + }); + + test('connector validation fails when connector config is not valid', () => { + const actionConnector = { + secrets: { + user: 'user', + }, + id: 'test', + actionTypeId: '.webhook', + name: 'webhook', + config: { + method: 'PUT', + }, + } as ActionConnector; + + expect(actionTypeModel.validateConnector(actionConnector)).toEqual({ + errors: { + url: ['URL is required.'], + method: [], + user: [], + password: ['Password is required.'], + }, + }); + }); +}); + +describe('webhook action params validation', () => { + test('action params validation succeeds when action params is valid', () => { + const actionParams = { + body: 'message {test}', + }; + + expect(actionTypeModel.validateParams(actionParams)).toEqual({ + errors: { body: [] }, + }); + }); +}); + +describe('WebhookActionConnectorFields renders', () => { + test('all connector fields is rendered', () => { + expect(actionTypeModel.actionConnectorFields).not.toBeNull(); + if (!actionTypeModel.actionConnectorFields) { + return; + } + const ConnectorFields = actionTypeModel.actionConnectorFields; + const actionConnector = { + secrets: { + user: 'user', + password: 'pass', + }, + id: 'test', + actionTypeId: '.webhook', + name: 'webhook', + config: { + method: 'PUT', + url: 'http:\\test', + headers: ['content-type: text'], + }, + } as ActionConnector; + const wrapper = mountWithIntl( + {}} + editActionSecrets={() => {}} + /> + ); + expect(wrapper.find('[data-test-subj="webhookViewHeadersSwitch"]').length > 0).toBeTruthy(); + wrapper + .find('[data-test-subj="webhookViewHeadersSwitch"]') + .first() + .simulate('click'); + expect(wrapper.find('[data-test-subj="webhookMethodSelect"]').length > 0).toBeTruthy(); + expect(wrapper.find('[data-test-subj="webhookUrlText"]').length > 0).toBeTruthy(); + expect(wrapper.find('[data-test-subj="webhookUserInput"]').length > 0).toBeTruthy(); + expect(wrapper.find('[data-test-subj="webhookPasswordInput"]').length > 0).toBeTruthy(); + }); +}); + +describe('WebhookParamsFields renders', () => { + test('all params fields is rendered', () => { + expect(actionTypeModel.actionParamsFields).not.toBeNull(); + if (!actionTypeModel.actionParamsFields) { + return; + } + const ParamsFields = actionTypeModel.actionParamsFields; + const actionParams = { + body: 'test message', + }; + const wrapper = mountWithIntl( + {}} + index={0} + hasErrors={false} + /> + ); + expect(wrapper.find('[data-test-subj="webhookBodyEditor"]').length > 0).toBeTruthy(); + expect( + wrapper + .find('[data-test-subj="webhookBodyEditor"]') + .first() + .prop('value') + ).toStrictEqual('test message'); + }); + + test('params validation fails when body is not valid', () => { + const actionParams = { + body: '', + }; + + expect(actionTypeModel.validateParams(actionParams)).toEqual({ + errors: { + body: ['Body is required.'], + }, + }); + }); +}); diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/webhook.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/webhook.tsx new file mode 100644 index 0000000000000..70a9a6f3d75b3 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_action_types/webhook.tsx @@ -0,0 +1,501 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import React, { Fragment, useState } from 'react'; +import { FormattedMessage } from '@kbn/i18n/react'; + +import { + EuiFieldPassword, + EuiFieldText, + EuiFormRow, + EuiSelect, + EuiFlexGroup, + EuiFlexItem, + EuiSpacer, + EuiButtonIcon, + EuiDescriptionList, + EuiDescriptionListDescription, + EuiDescriptionListTitle, + EuiTitle, + EuiCodeEditor, + EuiSwitch, + EuiButtonEmpty, +} from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; +import { + ActionTypeModel, + ActionConnectorFieldsProps, + ActionConnector, + ValidationResult, + ActionParamsProps, +} from '../../../types'; + +const HTTP_VERBS = ['post', 'put']; + +export function getActionType(): ActionTypeModel { + return { + id: '.webhook', + iconClass: 'logoWebhook', + selectMessage: i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.webhookAction.selectMessageText', + { + defaultMessage: 'Send a request to a web service.', + } + ), + validateConnector: (action: ActionConnector): ValidationResult => { + const validationResult = { errors: {} }; + const errors = { + url: new Array(), + method: new Array(), + user: new Array(), + password: new Array(), + }; + validationResult.errors = errors; + if (!action.config.url) { + errors.url.push( + i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.webhookAction.error.requiredUrlText', + { + defaultMessage: 'URL is required.', + } + ) + ); + } + if (!action.config.method) { + errors.method.push( + i18n.translate( + 'xpack.triggersActionsUI.sections.addAction.webhookAction.error.requiredMethodText', + { + defaultMessage: 'Method is required.', + } + ) + ); + } + if (!action.secrets.user) { + errors.user.push( + i18n.translate( + 'xpack.triggersActionsUI.sections.addAction.webhookAction.error.requiredHostText', + { + defaultMessage: 'Username is required.', + } + ) + ); + } + if (!action.secrets.password) { + errors.password.push( + i18n.translate( + 'xpack.triggersActionsUI.sections.addAction.webhookAction.error.requiredPasswordText', + { + defaultMessage: 'Password is required.', + } + ) + ); + } + return validationResult; + }, + validateParams: (actionParams: any): ValidationResult => { + const validationResult = { errors: {} }; + const errors = { + body: new Array(), + }; + validationResult.errors = errors; + if (!actionParams.body || actionParams.body.length === 0) { + errors.body.push( + i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.error.requiredWebhookBodyText', + { + defaultMessage: 'Body is required.', + } + ) + ); + } + return validationResult; + }, + actionConnectorFields: WebhookActionConnectorFields, + actionParamsFields: WebhookParamsFields, + }; +} + +const WebhookActionConnectorFields: React.FunctionComponent = ({ + action, + editActionConfig, + editActionSecrets, + errors, +}) => { + const [httpHeaderKey, setHttpHeaderKey] = useState(''); + const [httpHeaderValue, setHttpHeaderValue] = useState(''); + const [hasHeaders, setHasHeaders] = useState(false); + + const { user, password } = action.secrets; + const { method, url, headers } = action.config; + + editActionConfig('method', 'post'); // set method to POST by default + + const headerErrors = { + keyHeader: new Array(), + valueHeader: new Array(), + }; + if (!httpHeaderKey && httpHeaderValue) { + headerErrors.keyHeader.push( + i18n.translate( + 'xpack.triggersActionsUI.sections.addAction.webhookAction.error.requiredHeaderKeyText', + { + defaultMessage: 'Header key is required.', + } + ) + ); + } + if (httpHeaderKey && !httpHeaderValue) { + headerErrors.valueHeader.push( + i18n.translate( + 'xpack.triggersActionsUI.sections.addAction.webhookAction.error.requiredHeaderValueText', + { + defaultMessage: 'Header value is required.', + } + ) + ); + } + const hasHeaderErrors = headerErrors.keyHeader.length > 0 || headerErrors.valueHeader.length > 0; + + function addHeader() { + if (headers && !!Object.keys(headers).find(key => key === httpHeaderKey)) { + return; + } + const updatedHeaders = headers + ? { ...headers, [httpHeaderKey]: httpHeaderValue } + : { [httpHeaderKey]: httpHeaderValue }; + editActionConfig('headers', updatedHeaders); + setHttpHeaderKey(''); + setHttpHeaderValue(''); + } + + function viewHeaders() { + setHasHeaders(!hasHeaders); + if (!hasHeaders) { + editActionConfig('headers', {}); + } + } + + function removeHeader(keyToRemove: string) { + const updatedHeaders = Object.keys(headers) + .filter(key => key !== keyToRemove) + .reduce((headerToRemove: Record, key: string) => { + headerToRemove[key] = headers[key]; + return headerToRemove; + }, {}); + editActionConfig('headers', updatedHeaders); + } + + let headerControl; + if (hasHeaders) { + headerControl = ( + + +
+ +
+
+ + + + + { + setHttpHeaderKey(e.target.value); + }} + /> + + + + + { + setHttpHeaderValue(e.target.value); + }} + /> + + + + + addHeader()} + > + + + + + +
+ ); + } + + const headersList = Object.keys(headers || {}).map((key: string) => { + return ( + + + removeHeader(key)} + /> + + + + {key} + {headers[key]} + + + + ); + }); + + return ( + + + + + ({ text: verb.toUpperCase(), value: verb }))} + onChange={e => { + editActionConfig('method', e.target.value); + }} + /> + + + + 0 && url !== undefined} + label={i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.webhookAction.urlTextFieldLabel', + { + defaultMessage: 'URL', + } + )} + > + 0 && url !== undefined} + fullWidth + value={url || ''} + data-test-subj="webhookUrlText" + onChange={e => { + editActionConfig('url', e.target.value); + }} + onBlur={() => { + if (!url) { + editActionConfig('url', ''); + } + }} + /> + + + + + + 0 && user !== undefined} + label={i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.webhookAction.userTextFieldLabel', + { + defaultMessage: 'Username', + } + )} + > + 0 && user !== undefined} + name="user" + value={user || ''} + data-test-subj="webhookUserInput" + onChange={e => { + editActionSecrets('user', e.target.value); + }} + onBlur={() => { + if (!user) { + editActionSecrets('user', ''); + } + }} + /> + + + + 0 && password !== undefined} + label={i18n.translate( + 'xpack.triggersActionsUI.components.builtinActionTypes.webhookAction.passwordTextFieldLabel', + { + defaultMessage: 'Password', + } + )} + > + 0 && password !== undefined} + value={password || ''} + data-test-subj="webhookPasswordInput" + onChange={e => { + editActionSecrets('password', e.target.value); + }} + onBlur={() => { + if (!password) { + editActionSecrets('password', ''); + } + }} + /> + + + + + + viewHeaders()} + /> + + +
+ {hasHeaders && Object.keys(headers || {}).length > 0 ? ( + + + +
+ +
+
+ + {headersList} +
+ ) : null} + + {headerControl} + +
+
+ ); +}; + +const WebhookParamsFields: React.FunctionComponent = ({ + action, + editAction, + index, + errors, + hasErrors, +}) => { + const { body } = action; + + return ( + + + { + editAction('body', json, index); + }} + /> + + + ); +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/index.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/index.ts new file mode 100644 index 0000000000000..6c5d440e47888 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/index.ts @@ -0,0 +1,17 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { getActionType as getThresholdAlertType } from './threshold/expression'; +import { TypeRegistry } from '../../type_registry'; +import { AlertTypeModel } from '../../../types'; + +export function registerBuiltInAlertTypes({ + alertTypeRegistry, +}: { + alertTypeRegistry: TypeRegistry; +}) { + alertTypeRegistry.register(getThresholdAlertType()); +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/constants/aggregation_types.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/constants/aggregation_types.ts new file mode 100644 index 0000000000000..68c2818502b2c --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/constants/aggregation_types.ts @@ -0,0 +1,17 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export const AGGREGATION_TYPES: { [key: string]: string } = { + COUNT: 'count', + + AVERAGE: 'avg', + + SUM: 'sum', + + MIN: 'min', + + MAX: 'max', +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/constants/comparators.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/constants/comparators.ts new file mode 100644 index 0000000000000..21b350c0f8ce4 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/constants/comparators.ts @@ -0,0 +1,13 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export const COMPARATORS: { [key: string]: string } = { + GREATER_THAN: '>', + GREATER_THAN_OR_EQUALS: '>=', + BETWEEN: 'between', + LESS_THAN: '<', + LESS_THAN_OR_EQUALS: '<=', +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/constants/index.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/constants/index.ts new file mode 100644 index 0000000000000..f88ee5ee23f90 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/constants/index.ts @@ -0,0 +1,8 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export { COMPARATORS } from './comparators'; +export { AGGREGATION_TYPES } from './aggregation_types'; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/expression.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/expression.tsx new file mode 100644 index 0000000000000..907a61677b263 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/expression.tsx @@ -0,0 +1,1000 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React, { useState, Fragment, useEffect } from 'react'; +import { i18n } from '@kbn/i18n'; +import { FormattedMessage } from '@kbn/i18n/react'; +import { + EuiFlexItem, + EuiFlexGroup, + EuiExpression, + EuiPopover, + EuiPopoverTitle, + EuiSelect, + EuiSpacer, + EuiComboBox, + EuiFieldNumber, + EuiComboBoxOptionProps, + EuiText, + EuiFormRow, + EuiCallOut, +} from '@elastic/eui'; +import { AlertTypeModel, Alert, ValidationResult } from '../../../../types'; +import { Comparator, AggregationType, GroupByType } from './types'; +import { AGGREGATION_TYPES, COMPARATORS } from './constants'; +import { + getMatchingIndicesForThresholdAlertType, + getThresholdAlertTypeFields, + loadIndexPatterns, +} from './lib/api'; +import { useAppDependencies } from '../../../app_context'; +import { getTimeOptions, getTimeFieldOptions } from '../../../lib/get_time_options'; +import { getTimeUnitLabel } from '../../../lib/get_time_unit_label'; +import { ThresholdVisualization } from './visualization'; + +const DEFAULT_VALUES = { + AGGREGATION_TYPE: 'count', + TERM_SIZE: 5, + THRESHOLD_COMPARATOR: COMPARATORS.GREATER_THAN, + TIME_WINDOW_SIZE: 5, + TIME_WINDOW_UNIT: 'm', + TRIGGER_INTERVAL_SIZE: 1, + TRIGGER_INTERVAL_UNIT: 'm', + THRESHOLD: [1000, 5000], + GROUP_BY: 'all', +}; + +const expressionFieldsWithValidation = [ + 'index', + 'timeField', + 'aggField', + 'termSize', + 'termField', + 'threshold0', + 'threshold1', + 'timeWindowSize', +]; + +const validateAlertType = (alert: Alert): ValidationResult => { + const { + index, + timeField, + aggType, + aggField, + groupBy, + termSize, + termField, + threshold, + timeWindowSize, + } = alert.params; + const validationResult = { errors: {} }; + const errors = { + aggField: new Array(), + termSize: new Array(), + termField: new Array(), + timeWindowSize: new Array(), + threshold0: new Array(), + threshold1: new Array(), + index: new Array(), + timeField: new Array(), + }; + validationResult.errors = errors; + if (!index) { + errors.index.push( + i18n.translate('xpack.triggersActionsUI.sections.addAlert.error.requiredIndexText', { + defaultMessage: 'Index is required.', + }) + ); + } + if (!timeField) { + errors.timeField.push( + i18n.translate('xpack.triggersActionsUI.sections.addAlert.error.requiredTimeFieldText', { + defaultMessage: 'Time field is required.', + }) + ); + } + if (aggType && aggregationTypes[aggType].fieldRequired && !aggField) { + errors.aggField.push( + i18n.translate('xpack.triggersActionsUI.sections.addAlert.error.requiredAggFieldText', { + defaultMessage: 'Aggregation field is required.', + }) + ); + } + if (!termSize) { + errors.termSize.push( + i18n.translate('xpack.triggersActionsUI.sections.addAlert.error.requiredTermSizedText', { + defaultMessage: 'Term size is required.', + }) + ); + } + if (groupBy && groupByTypes[groupBy].sizeRequired && !termField) { + errors.termField.push( + i18n.translate('xpack.triggersActionsUI.sections.addAlert.error.requiredtTermFieldText', { + defaultMessage: 'Term field is required.', + }) + ); + } + if (!timeWindowSize) { + errors.timeWindowSize.push( + i18n.translate('xpack.triggersActionsUI.sections.addAlert.error.requiredTimeWindowSizeText', { + defaultMessage: 'Time window size is required.', + }) + ); + } + if (threshold && threshold.length > 0 && !threshold[0]) { + errors.threshold0.push( + i18n.translate('xpack.triggersActionsUI.sections.addAlert.error.requiredThreshold0Text', { + defaultMessage: 'Threshold0, is required.', + }) + ); + } + if (threshold && threshold.length > 1 && !threshold[1]) { + errors.threshold1.push( + i18n.translate('xpack.triggersActionsUI.sections.addAlert.error.requiredThreshold1Text', { + defaultMessage: 'Threshold1 is required.', + }) + ); + } + return validationResult; +}; + +export function getActionType(): AlertTypeModel { + return { + id: 'threshold', + name: 'Index Threshold', + iconClass: 'alert', + alertParamsExpression: IndexThresholdAlertTypeExpression, + validate: validateAlertType, + }; +} + +export const aggregationTypes: { [key: string]: AggregationType } = { + count: { + text: 'count()', + fieldRequired: false, + value: AGGREGATION_TYPES.COUNT, + validNormalizedTypes: [], + }, + avg: { + text: 'average()', + fieldRequired: true, + validNormalizedTypes: ['number'], + value: AGGREGATION_TYPES.AVERAGE, + }, + sum: { + text: 'sum()', + fieldRequired: true, + validNormalizedTypes: ['number'], + value: AGGREGATION_TYPES.SUM, + }, + min: { + text: 'min()', + fieldRequired: true, + validNormalizedTypes: ['number', 'date'], + value: AGGREGATION_TYPES.MIN, + }, + max: { + text: 'max()', + fieldRequired: true, + validNormalizedTypes: ['number', 'date'], + value: AGGREGATION_TYPES.MAX, + }, +}; + +export const comparators: { [key: string]: Comparator } = { + [COMPARATORS.GREATER_THAN]: { + text: i18n.translate( + 'xpack.triggersActionsUI.sections.alertAdd.threshold.comparators.isAboveLabel', + { + defaultMessage: 'Is above', + } + ), + value: COMPARATORS.GREATER_THAN, + requiredValues: 1, + }, + [COMPARATORS.GREATER_THAN_OR_EQUALS]: { + text: i18n.translate( + 'xpack.triggersActionsUI.sections.alertAdd.threshold.comparators.isAboveOrEqualsLabel', + { + defaultMessage: 'Is above or equals', + } + ), + value: COMPARATORS.GREATER_THAN_OR_EQUALS, + requiredValues: 1, + }, + [COMPARATORS.LESS_THAN]: { + text: i18n.translate( + 'xpack.triggersActionsUI.sections.alertAdd.threshold.comparators.isBelowLabel', + { + defaultMessage: 'Is below', + } + ), + value: COMPARATORS.LESS_THAN, + requiredValues: 1, + }, + [COMPARATORS.LESS_THAN_OR_EQUALS]: { + text: i18n.translate( + 'xpack.triggersActionsUI.sections.alertAdd.threshold.comparators.isBelowOrEqualsLabel', + { + defaultMessage: 'Is below or equals', + } + ), + value: COMPARATORS.LESS_THAN_OR_EQUALS, + requiredValues: 1, + }, + [COMPARATORS.BETWEEN]: { + text: i18n.translate( + 'xpack.triggersActionsUI.sections.alertAdd.threshold.comparators.isBetweenLabel', + { + defaultMessage: 'Is between', + } + ), + value: COMPARATORS.BETWEEN, + requiredValues: 2, + }, +}; + +export const groupByTypes: { [key: string]: GroupByType } = { + all: { + text: i18n.translate( + 'xpack.triggersActionsUI.sections.alertAdd.threshold.groupByLabel.allDocumentsLabel', + { + defaultMessage: 'all documents', + } + ), + sizeRequired: false, + value: 'all', + validNormalizedTypes: [], + }, + top: { + text: i18n.translate( + 'xpack.triggersActionsUI.sections.alertAdd.threshold.groupByLabel.topLabel', + { + defaultMessage: 'top', + } + ), + sizeRequired: true, + value: 'top', + validNormalizedTypes: ['number', 'date', 'keyword'], + }, +}; + +interface Props { + alert: Alert; + setAlertParams: (property: string, value: any) => void; + setAlertProperty: (key: string, value: any) => void; + errors: { [key: string]: string[] }; + hasErrors?: boolean; +} + +export const IndexThresholdAlertTypeExpression: React.FunctionComponent = ({ + alert, + setAlertParams, + setAlertProperty, + errors, + hasErrors, +}) => { + const { http } = useAppDependencies(); + + const { + index, + timeField, + aggType, + aggField, + groupBy, + termSize, + termField, + thresholdComparator, + threshold, + timeWindowSize, + timeWindowUnit, + } = alert.params; + + const firstFieldOption = { + text: i18n.translate( + 'xpack.triggersActionsUI.sections.alertAdd.threshold.timeFieldOptionLabel', + { + defaultMessage: 'Select a field', + } + ), + value: '', + }; + + const [aggTypePopoverOpen, setAggTypePopoverOpen] = useState(false); + const [indexPopoverOpen, setIndexPopoverOpen] = useState(false); + const [indexPatterns, setIndexPatterns] = useState([]); + const [esFields, setEsFields] = useState>([]); + const [indexOptions, setIndexOptions] = useState([]); + const [timeFieldOptions, setTimeFieldOptions] = useState([firstFieldOption]); + const [isIndiciesLoading, setIsIndiciesLoading] = useState(false); + const [alertThresholdPopoverOpen, setAlertThresholdPopoverOpen] = useState(false); + const [alertDurationPopoverOpen, setAlertDurationPopoverOpen] = useState(false); + const [aggFieldPopoverOpen, setAggFieldPopoverOpen] = useState(false); + const [groupByPopoverOpen, setGroupByPopoverOpen] = useState(false); + + const andThresholdText = i18n.translate( + 'xpack.triggersActionsUI.sections.alertAdd.threshold.andLabel', + { + defaultMessage: 'AND', + } + ); + + const hasExpressionErrors = !!Object.keys(errors).find( + errorKey => expressionFieldsWithValidation.includes(errorKey) && errors[errorKey].length >= 1 + ); + + const getIndexPatterns = async () => { + const indexPatternObjects = await loadIndexPatterns(); + const titles = indexPatternObjects.map((indexPattern: any) => indexPattern.attributes.title); + setIndexPatterns(titles); + }; + + const expressionErrorMessage = i18n.translate( + 'xpack.triggersActionsUI.sections.alertAdd.threshold.fixErrorInExpressionBelowValidationMessage', + { + defaultMessage: 'Expression contains errors.', + } + ); + + const setDefaultExpressionValues = () => { + setAlertProperty('params', { + aggType: DEFAULT_VALUES.AGGREGATION_TYPE, + termSize: DEFAULT_VALUES.TERM_SIZE, + thresholdComparator: DEFAULT_VALUES.THRESHOLD_COMPARATOR, + timeWindowSize: DEFAULT_VALUES.TIME_WINDOW_SIZE, + timeWindowUnit: DEFAULT_VALUES.TIME_WINDOW_UNIT, + triggerIntervalUnit: DEFAULT_VALUES.TRIGGER_INTERVAL_UNIT, + groupBy: DEFAULT_VALUES.GROUP_BY, + threshold: DEFAULT_VALUES.THRESHOLD, + }); + }; + + const getFields = async (indexes: string[]) => { + return await getThresholdAlertTypeFields({ indexes, http }); + }; + + useEffect(() => { + getIndexPatterns(); + }, []); + + useEffect(() => { + setDefaultExpressionValues(); + // eslint-disable-next-line react-hooks/exhaustive-deps + }, []); + + interface IOption { + label: string; + options: Array<{ value: string; label: string }>; + } + + const getIndexOptions = async (pattern: string, indexPatternsParam: string[]) => { + const options: IOption[] = []; + + if (!pattern) { + return options; + } + + const matchingIndices = (await getMatchingIndicesForThresholdAlertType({ + pattern, + http, + })) as string[]; + const matchingIndexPatterns = indexPatternsParam.filter(anIndexPattern => { + return anIndexPattern.includes(pattern); + }) as string[]; + + if (matchingIndices.length || matchingIndexPatterns.length) { + const matchingOptions = _.uniq([...matchingIndices, ...matchingIndexPatterns]); + + options.push({ + label: i18n.translate( + 'xpack.triggersActionsUI.sections.alertAdd.threshold.indicesAndIndexPatternsLabel', + { + defaultMessage: 'Based on your indices and index patterns', + } + ), + options: matchingOptions.map(match => { + return { + label: match, + value: match, + }; + }), + }); + } + + options.push({ + label: i18n.translate('xpack.triggersActionsUI.sections.alertAdd.threshold.chooseLabel', { + defaultMessage: 'Choose…', + }), + options: [ + { + value: pattern, + label: pattern, + }, + ], + }); + + return options; + }; + + const indexPopover = ( + + + + + + } + isInvalid={hasErrors && index !== undefined} + error={errors.index} + helpText={ + + } + > + { + return { + label: anIndex, + value: anIndex, + }; + })} + onChange={async (selected: EuiComboBoxOptionProps[]) => { + setAlertParams( + 'index', + selected.map(aSelected => aSelected.value) + ); + const indices = selected.map(s => s.value as string); + + // reset time field and expression fields if indices are deleted + if (indices.length === 0) { + setTimeFieldOptions([firstFieldOption]); + setAlertParams('timeFields', []); + + setDefaultExpressionValues(); + return; + } + const currentEsFields = await getFields(indices); + const timeFields = getTimeFieldOptions(currentEsFields as any); + + setEsFields(currentEsFields); + setAlertParams('timeFields', timeFields); + setTimeFieldOptions([firstFieldOption, ...timeFields]); + }} + onSearchChange={async search => { + setIsIndiciesLoading(true); + setIndexOptions(await getIndexOptions(search, indexPatterns)); + setIsIndiciesLoading(false); + }} + onBlur={() => { + if (!index) { + setAlertParams('index', []); + } + }} + /> + + + + + } + isInvalid={hasErrors && timeField !== undefined} + error={errors.timeField} + > + { + setAlertParams('timeField', e.target.value); + }} + onBlur={() => { + if (timeField === undefined) { + setAlertParams('timeField', ''); + } + }} + /> + + + + + + ); + + return ( + + {hasExpressionErrors ? ( + + + + + + ) : null} + + + { + setIndexPopoverOpen(true); + }} + color={index ? 'secondary' : 'danger'} + /> + } + isOpen={indexPopoverOpen} + closePopover={() => { + setIndexPopoverOpen(false); + }} + ownFocus + withTitle + anchorPosition="downLeft" + zIndex={8000} + > +
+ + {i18n.translate( + 'xpack.triggersActionsUI.sections.alertAdd.threshold.indexButtonLabel', + { + defaultMessage: 'index', + } + )} + + {indexPopover} +
+
+
+ + { + setAggTypePopoverOpen(true); + }} + /> + } + isOpen={aggTypePopoverOpen} + closePopover={() => { + setAggTypePopoverOpen(false); + }} + ownFocus + withTitle + anchorPosition="downLeft" + > +
+ + {i18n.translate( + 'xpack.triggersActionsUI.sections.alertAdd.threshold.whenButtonLabel', + { + defaultMessage: 'when', + } + )} + + { + setAlertParams('aggType', e.target.value); + setAggTypePopoverOpen(false); + }} + options={Object.values(aggregationTypes).map(({ text, value }) => { + return { + text, + value, + }; + })} + /> +
+
+
+ {aggType && aggregationTypes[aggType].fieldRequired ? ( + + { + setAggFieldPopoverOpen(true); + }} + color={aggField ? 'secondary' : 'danger'} + /> + } + isOpen={aggFieldPopoverOpen} + closePopover={() => { + setAggFieldPopoverOpen(false); + }} + anchorPosition="downLeft" + > +
+ + {i18n.translate( + 'xpack.triggersActionsUI.sections.alertAdd.threshold.ofButtonLabel', + { + defaultMessage: 'of', + } + )} + + + + + { + if ( + aggregationTypes[aggType].validNormalizedTypes.includes( + field.normalizedType + ) + ) { + esFieldOptions.push({ + label: field.name, + }); + } + return esFieldOptions; + }, [])} + selectedOptions={aggField ? [{ label: aggField }] : []} + onChange={selectedOptions => { + setAlertParams( + 'aggField', + selectedOptions.length === 1 ? selectedOptions[0].label : undefined + ); + setAggFieldPopoverOpen(false); + }} + /> + + + +
+
+
+ ) : null} + + { + setGroupByPopoverOpen(true); + }} + color={groupBy === 'all' || (termSize && termField) ? 'secondary' : 'danger'} + /> + } + isOpen={groupByPopoverOpen} + closePopover={() => { + setGroupByPopoverOpen(false); + }} + ownFocus + withTitle + anchorPosition="downLeft" + > +
+ + {i18n.translate( + 'xpack.triggersActionsUI.sections.alertAdd.threshold.overButtonLabel', + { + defaultMessage: 'over', + } + )} + + + + { + setAlertParams('termSize', null); + setAlertParams('termField', null); + setAlertParams('groupBy', e.target.value); + }} + options={Object.values(groupByTypes).map(({ text, value }) => { + return { + text, + value, + }; + })} + /> + + + {groupByTypes[groupBy || DEFAULT_VALUES.GROUP_BY].sizeRequired ? ( + + + + { + const { value } = e.target; + const termSizeVal = value !== '' ? parseFloat(value) : value; + setAlertParams('termSize', termSizeVal); + }} + min={1} + /> + + + + + { + setAlertParams('termField', e.target.value); + }} + options={esFields.reduce( + (options: any, field: any) => { + if ( + groupByTypes[ + groupBy || DEFAULT_VALUES.GROUP_BY + ].validNormalizedTypes.includes(field.normalizedType) + ) { + options.push({ + text: field.name, + value: field.name, + }); + } + return options; + }, + [firstFieldOption] + )} + /> + + + + ) : null} + +
+
+
+ + { + setAlertThresholdPopoverOpen(true); + }} + color={ + (errors.threshold0 && errors.threshold0.length) || + (errors.threshold1 && errors.threshold1.length) + ? 'danger' + : 'secondary' + } + /> + } + isOpen={alertThresholdPopoverOpen} + closePopover={() => { + setAlertThresholdPopoverOpen(false); + }} + ownFocus + withTitle + anchorPosition="downLeft" + > +
+ + {comparators[thresholdComparator || DEFAULT_VALUES.THRESHOLD_COMPARATOR].text} + + + + { + setAlertParams('thresholdComparator', e.target.value); + }} + options={Object.values(comparators).map(({ text, value }) => { + return { text, value }; + })} + /> + + {Array.from( + Array( + comparators[thresholdComparator || DEFAULT_VALUES.THRESHOLD_COMPARATOR] + .requiredValues + ) + ).map((_notUsed, i) => { + return ( + + {i > 0 ? ( + + {andThresholdText} + {hasErrors && } + + ) : null} + + + { + const { value } = e.target; + const thresholdVal = value !== '' ? parseFloat(value) : value; + const newThreshold = [...threshold]; + newThreshold[i] = thresholdVal; + setAlertParams('threshold', newThreshold); + }} + /> + + + + ); + })} + +
+
+
+ + { + setAlertDurationPopoverOpen(true); + }} + color={timeWindowSize ? 'secondary' : 'danger'} + /> + } + isOpen={alertDurationPopoverOpen} + closePopover={() => { + setAlertDurationPopoverOpen(false); + }} + ownFocus + withTitle + anchorPosition="downLeft" + > +
+ + + + + + + { + const { value } = e.target; + const timeWindowSizeVal = value !== '' ? parseInt(value, 10) : value; + setAlertParams('timeWindowSize', timeWindowSizeVal); + }} + /> + + + + { + setAlertParams('timeWindowUnit', e.target.value); + }} + options={getTimeOptions(timeWindowSize)} + /> + + +
+
+
+
+ {hasExpressionErrors ? null : ( + + + + )} +
+ ); +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/lib/api.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/lib/api.ts new file mode 100644 index 0000000000000..956007049a821 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/lib/api.ts @@ -0,0 +1,79 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import { HttpSetup } from 'kibana/public'; + +const WATCHER_API_ROOT = '/api/watcher'; + +// TODO: replace watcher api with the proper from alerts + +export async function getMatchingIndicesForThresholdAlertType({ + pattern, + http, +}: { + pattern: string; + http: HttpSetup; +}): Promise> { + if (!pattern.startsWith('*')) { + pattern = `*${pattern}`; + } + if (!pattern.endsWith('*')) { + pattern = `${pattern}*`; + } + const { indices } = await http.post(`${WATCHER_API_ROOT}/indices`, { + body: JSON.stringify({ pattern }), + }); + return indices; +} + +export async function getThresholdAlertTypeFields({ + indexes, + http, +}: { + indexes: string[]; + http: HttpSetup; +}): Promise> { + const { fields } = await http.post(`${WATCHER_API_ROOT}/fields`, { + body: JSON.stringify({ indexes }), + }); + return fields; +} + +let savedObjectsClient: any; + +export const setSavedObjectsClient = (aSavedObjectsClient: any) => { + savedObjectsClient = aSavedObjectsClient; +}; + +export const getSavedObjectsClient = () => { + return savedObjectsClient; +}; + +export const loadIndexPatterns = async () => { + const { savedObjects } = await getSavedObjectsClient().find({ + type: 'index-pattern', + fields: ['title'], + perPage: 10000, + }); + return savedObjects; +}; + +export async function getThresholdAlertVisualizationData({ + model, + visualizeOptions, + http, +}: { + model: any; + visualizeOptions: any; + http: HttpSetup; +}): Promise> { + const { visualizeData } = await http.post(`${WATCHER_API_ROOT}/watch/visualize`, { + body: JSON.stringify({ + watch: model, + options: visualizeOptions, + }), + }); + return visualizeData; +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/types.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/types.ts new file mode 100644 index 0000000000000..fd2a401fe59f3 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/types.ts @@ -0,0 +1,25 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export interface Comparator { + text: string; + value: string; + requiredValues: number; +} + +export interface AggregationType { + text: string; + fieldRequired: boolean; + value: string; + validNormalizedTypes: string[]; +} + +export interface GroupByType { + text: string; + sizeRequired: boolean; + value: string; + validNormalizedTypes: string[]; +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/visualization.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/visualization.tsx new file mode 100644 index 0000000000000..8433c585ef3e5 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/builtin_alert_types/threshold/visualization.tsx @@ -0,0 +1,303 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React, { Fragment, useEffect, useState } from 'react'; +import { IUiSettingsClient } from 'kibana/public'; +import { i18n } from '@kbn/i18n'; +import { + AnnotationDomainTypes, + Axis, + getAxisId, + getSpecId, + Chart, + LineAnnotation, + LineSeries, + Position, + ScaleType, + Settings, +} from '@elastic/charts'; +import { TimeBuckets } from 'ui/time_buckets'; +import dateMath from '@elastic/datemath'; +import moment from 'moment-timezone'; +import { EuiCallOut, EuiLoadingChart, EuiSpacer, EuiEmptyPrompt, EuiText } from '@elastic/eui'; +import { FormattedMessage } from '@kbn/i18n/react'; +import { npStart } from 'ui/new_platform'; +import { getThresholdAlertVisualizationData } from './lib/api'; +import { comparators, aggregationTypes } from './expression'; +import { useAppDependencies } from '../../../app_context'; +import { Alert } from '../../../../types'; + +const customTheme = () => { + return { + lineSeriesStyle: { + line: { + strokeWidth: 3, + }, + point: { + visible: false, + }, + }, + }; +}; + +const getTimezone = (uiSettings: IUiSettingsClient) => { + const config = uiSettings; + const DATE_FORMAT_CONFIG_KEY = 'dateFormat:tz'; + const isCustomTimezone = !config.isDefault(DATE_FORMAT_CONFIG_KEY); + if (isCustomTimezone) { + return config.get(DATE_FORMAT_CONFIG_KEY); + } + + const detectedTimezone = moment.tz.guess(); + if (detectedTimezone) { + return detectedTimezone; + } + // default to UTC if we can't figure out the timezone + const tzOffset = moment().format('Z'); + return tzOffset; +}; + +const getDomain = (alertParams: any) => { + const VISUALIZE_TIME_WINDOW_MULTIPLIER = 5; + const fromExpression = `now-${alertParams.timeWindowSize * VISUALIZE_TIME_WINDOW_MULTIPLIER}${ + alertParams.timeWindowUnit + }`; + const toExpression = 'now'; + const fromMoment = dateMath.parse(fromExpression); + const toMoment = dateMath.parse(toExpression); + const visualizeTimeWindowFrom = fromMoment ? fromMoment.valueOf() : 0; + const visualizeTimeWindowTo = toMoment ? toMoment.valueOf() : 0; + return { + min: visualizeTimeWindowFrom, + max: visualizeTimeWindowTo, + }; +}; + +const getThreshold = (alertParams: any) => { + return alertParams.threshold.slice( + 0, + comparators[alertParams.thresholdComparator].requiredValues + ); +}; + +const getTimeBuckets = (alertParams: any) => { + const domain = getDomain(alertParams); + const timeBuckets = new TimeBuckets(); + timeBuckets.setBounds(domain); + return timeBuckets; +}; + +interface Props { + alert: Alert; +} + +export const ThresholdVisualization: React.FunctionComponent = ({ alert }) => { + const { http, uiSettings, toastNotifications } = useAppDependencies(); + const [isLoading, setIsLoading] = useState(false); + const [error, setError] = useState(undefined); + const [visualizationData, setVisualizationData] = useState>([]); + + const chartsTheme = npStart.plugins.eui_utils.useChartsTheme(); + const { + index, + timeField, + triggerIntervalSize, + triggerIntervalUnit, + aggType, + aggField, + termSize, + termField, + thresholdComparator, + timeWindowSize, + timeWindowUnit, + groupBy, + threshold, + } = alert.params; + + const domain = getDomain(alert.params); + const timeBuckets = new TimeBuckets(); + timeBuckets.setBounds(domain); + const interval = timeBuckets.getInterval().expression; + const visualizeOptions = { + rangeFrom: domain.min, + rangeTo: domain.max, + interval, + timezone: getTimezone(uiSettings), + }; + + // Fetching visualization data is independent of alert actions + const alertWithoutActions = { ...alert.params, actions: [], type: 'threshold' }; + + useEffect(() => { + (async () => { + try { + setIsLoading(true); + setVisualizationData( + await getThresholdAlertVisualizationData({ + model: alertWithoutActions, + visualizeOptions, + http, + }) + ); + } catch (e) { + toastNotifications.addDanger({ + title: i18n.translate( + 'xpack.triggersActionsUI.sections.alertAdd.unableToLoadVisualizationMessage', + { defaultMessage: 'Unable to load visualization' } + ), + }); + setError(e); + } finally { + setIsLoading(false); + } + })(); + /* eslint-disable react-hooks/exhaustive-deps */ + }, [ + index, + timeField, + triggerIntervalSize, + triggerIntervalUnit, + aggType, + aggField, + termSize, + termField, + thresholdComparator, + timeWindowSize, + timeWindowUnit, + groupBy, + threshold, + ]); + /* eslint-enable react-hooks/exhaustive-deps */ + + if (isLoading) { + return ( + } + body={ + + + + } + /> + ); + } + + if (error) { + return ( + + + + } + color="danger" + iconType="alert" + > + {error} + + + + ); + } + + if (visualizationData) { + const alertVisualizationDataKeys = Object.keys(visualizationData); + const timezone = getTimezone(uiSettings); + const actualThreshold = getThreshold(alert.params); + let maxY = actualThreshold[actualThreshold.length - 1]; + + (Object.values(visualizationData) as number[][][]).forEach(data => { + data.forEach(([, y]) => { + if (y > maxY) { + maxY = y; + } + }); + }); + const dateFormatter = (d: number) => { + return moment(d) + .tz(timezone) + .format(getTimeBuckets(alert.params).getScaledDateFormat()); + }; + const aggLabel = aggregationTypes[aggType].text; + return ( +
+ + {alertVisualizationDataKeys.length ? ( + + + + + {alertVisualizationDataKeys.map((key: string) => { + return ( + + ); + })} + {actualThreshold.map((_value: any, i: number) => { + const specId = i === 0 ? 'threshold' : `threshold${i}`; + return ( + + ); + })} + + ) : ( + + } + color="warning" + > + + + )} + +
+ ); + } + + return null; +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/delete_connectors_modal.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/delete_connectors_modal.tsx new file mode 100644 index 0000000000000..b7d1a4ffe2966 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/delete_connectors_modal.tsx @@ -0,0 +1,91 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import { EuiConfirmModal, EuiOverlayMask } from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; +import React from 'react'; +import { useAppDependencies } from '../app_context'; +import { deleteActions } from '../lib/action_connector_api'; + +export const DeleteConnectorsModal = ({ + connectorsToDelete, + callback, +}: { + connectorsToDelete: string[]; + callback: (deleted?: string[]) => void; +}) => { + const { http, toastNotifications } = useAppDependencies(); + const numConnectorsToDelete = connectorsToDelete.length; + if (!numConnectorsToDelete) { + return null; + } + const confirmModalText = i18n.translate( + 'xpack.triggersActionsUI.deleteSelectedConnectorsConfirmModal.descriptionText', + { + defaultMessage: + "You can't recover {numConnectorsToDelete, plural, one {a deleted connector} other {deleted connectors}}.", + values: { numConnectorsToDelete }, + } + ); + const confirmButtonText = i18n.translate( + 'xpack.triggersActionsUI.deleteSelectedConnectorsConfirmModal.deleteButtonLabel', + { + defaultMessage: + 'Delete {numConnectorsToDelete, plural, one {connector} other {# connectors}} ', + values: { numConnectorsToDelete }, + } + ); + const cancelButtonText = i18n.translate( + 'xpack.triggersActionsUI.deleteSelectedConnectorsConfirmModal.cancelButtonLabel', + { + defaultMessage: 'Cancel', + } + ); + return ( + + callback()} + onConfirm={async () => { + const { successes, errors } = await deleteActions({ ids: connectorsToDelete, http }); + const numSuccesses = successes.length; + const numErrors = errors.length; + callback(successes); + if (numSuccesses > 0) { + toastNotifications.addSuccess( + i18n.translate( + 'xpack.triggersActionsUI.sections.connectorsList.deleteSelectedConnectorsSuccessNotification.descriptionText', + { + defaultMessage: + 'Deleted {numSuccesses, number} {numSuccesses, plural, one {connector} other {connectors}}', + values: { numSuccesses }, + } + ) + ); + } + + if (numErrors > 0) { + toastNotifications.addDanger( + i18n.translate( + 'xpack.triggersActionsUI.sections.connectorsList.deleteSelectedConnectorsErrorNotification.descriptionText', + { + defaultMessage: + 'Failed to delete {numErrors, number} {numErrors, plural, one {connector} other {connectors}}', + values: { numErrors }, + } + ) + ); + } + }} + cancelButtonText={cancelButtonText} + confirmButtonText={confirmButtonText} + > + {confirmModalText} + + + ); +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/section_loading.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/section_loading.tsx new file mode 100644 index 0000000000000..4c6273682a0e4 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/components/section_loading.tsx @@ -0,0 +1,23 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React from 'react'; + +import { EuiEmptyPrompt, EuiLoadingSpinner, EuiText } from '@elastic/eui'; + +interface Props { + children: React.ReactNode; +} + +export const SectionLoading: React.FunctionComponent = ({ children }) => { + return ( + } + body={{children}} + data-test-subj="sectionLoading" + /> + ); +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/constants/action_groups.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/constants/action_groups.ts new file mode 100644 index 0000000000000..83a03010d55ad --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/constants/action_groups.ts @@ -0,0 +1,11 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export enum ACTION_GROUPS { + ALERT = 'alert', + WARNING = 'warning', + UNACKNOWLEDGED = 'unacknowledged', +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/constants/index.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/constants/index.ts new file mode 100644 index 0000000000000..a8364ffe21019 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/constants/index.ts @@ -0,0 +1,21 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export const BASE_PATH = '/management/kibana/triggersActions'; +export const BASE_ACTION_API_PATH = '/api/action'; +export const BASE_ALERT_API_PATH = '/api/alert'; + +export type Section = 'connectors' | 'alerts'; + +export const routeToHome = `${BASE_PATH}`; +export const routeToConnectors = `${BASE_PATH}/connectors`; +export const routeToAlerts = `${BASE_PATH}/alerts`; + +export { TIME_UNITS } from './time_units'; +export enum SORT_ORDERS { + ASCENDING = 'asc', + DESCENDING = 'desc', +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/constants/plugin.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/constants/plugin.ts new file mode 100644 index 0000000000000..63ba7df2556de --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/constants/plugin.ts @@ -0,0 +1,14 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export const PLUGIN = { + ID: 'triggers_actions_ui', + getI18nName: (i18n: any): string => { + return i18n.translate('xpack.triggersActionsUI.appName', { + defaultMessage: 'Alerts and Actions', + }); + }, +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/constants/time_units.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/constants/time_units.ts new file mode 100644 index 0000000000000..2a4f8fbd421ed --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/constants/time_units.ts @@ -0,0 +1,12 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export enum TIME_UNITS { + SECOND = 's', + MINUTE = 'm', + HOUR = 'h', + DAY = 'd', +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/context/actions_connectors_context.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/context/actions_connectors_context.tsx new file mode 100644 index 0000000000000..11786950d0f26 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/context/actions_connectors_context.tsx @@ -0,0 +1,39 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React, { createContext, useContext } from 'react'; +import { ActionType } from '../../types'; + +export interface ActionsConnectorsContextValue { + addFlyoutVisible: boolean; + editFlyoutVisible: boolean; + setEditFlyoutVisibility: React.Dispatch>; + setAddFlyoutVisibility: React.Dispatch>; + actionTypesIndex: Record | undefined; + reloadConnectors: () => Promise; +} + +const ActionsConnectorsContext = createContext(null as any); + +export const ActionsConnectorsContextProvider = ({ + children, + value, +}: { + value: ActionsConnectorsContextValue; + children: React.ReactNode; +}) => { + return ( + {children} + ); +}; + +export const useActionsConnectorsContext = () => { + const ctx = useContext(ActionsConnectorsContext); + if (!ctx) { + throw new Error('ActionsConnectorsContext has not been set.'); + } + return ctx; +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/context/alerts_context.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/context/alerts_context.tsx new file mode 100644 index 0000000000000..06be1bb7c5851 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/context/alerts_context.tsx @@ -0,0 +1,32 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React, { useContext, createContext } from 'react'; + +export interface AlertsContextValue { + alertFlyoutVisible: boolean; + setAlertFlyoutVisibility: React.Dispatch>; +} + +const AlertsContext = createContext(null as any); + +export const AlertsContextProvider = ({ + children, + value, +}: { + value: AlertsContextValue; + children: React.ReactNode; +}) => { + return {children}; +}; + +export const useAlertsContext = () => { + const ctx = useContext(AlertsContext); + if (!ctx) { + throw new Error('ActionsConnectorsContext has not been set.'); + } + return ctx; +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/home.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/home.tsx new file mode 100644 index 0000000000000..3312f1a103b29 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/home.tsx @@ -0,0 +1,126 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React, { useEffect } from 'react'; +import { Route, RouteComponentProps, Switch } from 'react-router-dom'; +import { FormattedMessage } from '@kbn/i18n/react'; +import { + EuiPageBody, + EuiPageContent, + EuiPageContentHeader, + EuiPageContentHeaderSection, + EuiSpacer, + EuiTab, + EuiTabs, + EuiTitle, +} from '@elastic/eui'; + +import { BASE_PATH, Section, routeToConnectors, routeToAlerts } from './constants'; +import { getCurrentBreadcrumb } from './lib/breadcrumb'; +import { getCurrentDocTitle } from './lib/doc_title'; +import { useAppDependencies } from './app_context'; +import { hasShowActionsCapability, hasShowAlertsCapability } from './lib/capabilities'; + +import { ActionsConnectorsList } from './sections/actions_connectors_list/components/actions_connectors_list'; +import { AlertsList } from './sections/alerts_list/components/alerts_list'; + +interface MatchParams { + section: Section; +} + +export const TriggersActionsUIHome: React.FunctionComponent> = ({ + match: { + params: { section }, + }, + history, +}) => { + const { + chrome, + legacy: { MANAGEMENT_BREADCRUMB, capabilities }, + } = useAppDependencies(); + + const canShowActions = hasShowActionsCapability(capabilities.get()); + const canShowAlerts = hasShowAlertsCapability(capabilities.get()); + const tabs: Array<{ + id: Section; + name: React.ReactNode; + }> = []; + + if (canShowAlerts) { + tabs.push({ + id: 'alerts', + name: ( + + ), + }); + } + + if (canShowActions) { + tabs.push({ + id: 'connectors', + name: ( + + ), + }); + } + + const onSectionChange = (newSection: Section) => { + history.push(`${BASE_PATH}/${newSection}`); + }; + + // Set breadcrumb and page title + useEffect(() => { + chrome.setBreadcrumbs([MANAGEMENT_BREADCRUMB, getCurrentBreadcrumb(section || 'home')]); + chrome.docTitle.change(getCurrentDocTitle(section || 'home')); + }, [section, chrome, MANAGEMENT_BREADCRUMB]); + + return ( + + + + + +

+ +

+
+
+
+ + + {tabs.map(tab => ( + onSectionChange(tab.id)} + isSelected={tab.id === section} + key={tab.id} + data-test-subj={`${tab.id}Tab`} + > + {tab.name} + + ))} + + + + + + {canShowActions && ( + + )} + {canShowAlerts && } + +
+
+ ); +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/action_connector_api.test.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/action_connector_api.test.ts new file mode 100644 index 0000000000000..bc2949917edea --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/action_connector_api.test.ts @@ -0,0 +1,135 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { ActionConnector, ActionConnectorWithoutId, ActionType } from '../../types'; +import { httpServiceMock } from '../../../../../../../../src/core/public/mocks'; +import { + createActionConnector, + deleteActions, + loadActionTypes, + loadAllActions, + updateActionConnector, +} from './action_connector_api'; + +const http = httpServiceMock.createStartContract(); + +beforeEach(() => jest.resetAllMocks()); + +describe('loadActionTypes', () => { + test('should call get types API', async () => { + const resolvedValue: ActionType[] = [ + { + id: 'test', + name: 'Test', + }, + ]; + http.get.mockResolvedValueOnce(resolvedValue); + + const result = await loadActionTypes({ http }); + expect(result).toEqual(resolvedValue); + expect(http.get.mock.calls[0]).toMatchInlineSnapshot(` + Array [ + "/api/action/types", + ] + `); + }); +}); + +describe('loadAllActions', () => { + test('should call find actions API', async () => { + const resolvedValue = { + page: 1, + perPage: 10000, + total: 0, + data: [], + }; + http.get.mockResolvedValueOnce(resolvedValue); + + const result = await loadAllActions({ http }); + expect(result).toEqual(resolvedValue); + expect(http.get.mock.calls[0]).toMatchInlineSnapshot(` + Array [ + "/api/action/_find", + Object { + "query": Object { + "per_page": 10000, + }, + }, + ] + `); + }); +}); + +describe('createActionConnector', () => { + test('should call create action API', async () => { + const connector: ActionConnectorWithoutId = { + actionTypeId: 'test', + name: 'My test', + config: {}, + secrets: {}, + }; + const resolvedValue: ActionConnector = { ...connector, id: '123' }; + http.post.mockResolvedValueOnce(resolvedValue); + + const result = await createActionConnector({ http, connector }); + expect(result).toEqual(resolvedValue); + expect(http.post.mock.calls[0]).toMatchInlineSnapshot(` + Array [ + "/api/action", + Object { + "body": "{\\"actionTypeId\\":\\"test\\",\\"name\\":\\"My test\\",\\"config\\":{},\\"secrets\\":{}}", + }, + ] + `); + }); +}); + +describe('updateActionConnector', () => { + test('should call the update API', async () => { + const id = '123'; + const connector: ActionConnectorWithoutId = { + actionTypeId: 'test', + name: 'My test', + config: {}, + secrets: {}, + }; + const resolvedValue = { ...connector, id }; + http.put.mockResolvedValueOnce(resolvedValue); + + const result = await updateActionConnector({ http, connector, id }); + expect(result).toEqual(resolvedValue); + expect(http.put.mock.calls[0]).toMatchInlineSnapshot(` + Array [ + "/api/action/123", + Object { + "body": "{\\"name\\":\\"My test\\",\\"config\\":{},\\"secrets\\":{}}", + }, + ] + `); + }); +}); + +describe('deleteActions', () => { + test('should call delete API per action', async () => { + const ids = ['1', '2', '3']; + + const result = await deleteActions({ ids, http }); + expect(result).toEqual({ errors: [], successes: [undefined, undefined, undefined] }); + expect(http.delete.mock.calls).toMatchInlineSnapshot(` + Array [ + Array [ + "/api/action/1", + ], + Array [ + "/api/action/2", + ], + Array [ + "/api/action/3", + ], + ] + `); + }); +}); diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/action_connector_api.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/action_connector_api.ts new file mode 100644 index 0000000000000..5b2b59603d281 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/action_connector_api.ts @@ -0,0 +1,85 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { HttpSetup } from 'kibana/public'; +import { BASE_ACTION_API_PATH } from '../constants'; +import { ActionConnector, ActionConnectorWithoutId, ActionType } from '../../types'; + +// We are assuming there won't be many actions. This is why we will load +// all the actions in advance and assume the total count to not go over 100 or so. +// We'll set this max setting assuming it's never reached. +const MAX_ACTIONS_RETURNED = 10000; + +export async function loadActionTypes({ http }: { http: HttpSetup }): Promise { + return await http.get(`${BASE_ACTION_API_PATH}/types`); +} + +export async function loadAllActions({ + http, +}: { + http: HttpSetup; +}): Promise<{ + page: number; + perPage: number; + total: number; + data: ActionConnector[]; +}> { + return await http.get(`${BASE_ACTION_API_PATH}/_find`, { + query: { + per_page: MAX_ACTIONS_RETURNED, + }, + }); +} + +export async function createActionConnector({ + http, + connector, +}: { + http: HttpSetup; + connector: Omit; +}): Promise { + return await http.post(`${BASE_ACTION_API_PATH}`, { + body: JSON.stringify(connector), + }); +} + +export async function updateActionConnector({ + http, + connector, + id, +}: { + http: HttpSetup; + connector: Pick; + id: string; +}): Promise { + return await http.put(`${BASE_ACTION_API_PATH}/${id}`, { + body: JSON.stringify({ + name: connector.name, + config: connector.config, + secrets: connector.secrets, + }), + }); +} + +export async function deleteActions({ + ids, + http, +}: { + ids: string[]; + http: HttpSetup; +}): Promise<{ successes: string[]; errors: string[] }> { + const successes: string[] = []; + const errors: string[] = []; + await Promise.all(ids.map(id => http.delete(`${BASE_ACTION_API_PATH}/${id}`))).then( + function(fulfilled) { + successes.push(...fulfilled); + }, + function(rejected) { + errors.push(...rejected); + } + ); + return { successes, errors }; +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/alert_api.test.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/alert_api.test.ts new file mode 100644 index 0000000000000..858c90258247e --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/alert_api.test.ts @@ -0,0 +1,406 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { Alert, AlertType } from '../../types'; +import { httpServiceMock } from '../../../../../../../../src/core/public/mocks'; +import { + createAlert, + deleteAlerts, + disableAlerts, + enableAlerts, + loadAlerts, + loadAlertTypes, + muteAlerts, + unmuteAlerts, + updateAlert, +} from './alert_api'; + +const http = httpServiceMock.createStartContract(); + +beforeEach(() => jest.resetAllMocks()); + +describe('loadAlertTypes', () => { + test('should call get alert types API', async () => { + const resolvedValue: AlertType[] = [ + { + id: 'test', + name: 'Test', + }, + ]; + http.get.mockResolvedValueOnce(resolvedValue); + + const result = await loadAlertTypes({ http }); + expect(result).toEqual(resolvedValue); + expect(http.get.mock.calls[0]).toMatchInlineSnapshot(` + Array [ + "/api/alert/types", + ] + `); + }); +}); + +describe('loadAlerts', () => { + test('should call find API with base parameters', async () => { + const resolvedValue = { + page: 1, + perPage: 10, + total: 0, + data: [], + }; + http.get.mockResolvedValueOnce(resolvedValue); + + const result = await loadAlerts({ http, page: { index: 0, size: 10 } }); + expect(result).toEqual(resolvedValue); + expect(http.get.mock.calls[0]).toMatchInlineSnapshot(` + Array [ + "/api/alert/_find", + Object { + "query": Object { + "default_search_operator": "AND", + "filter": undefined, + "page": 1, + "per_page": 10, + "search": undefined, + "search_fields": undefined, + }, + }, + ] + `); + }); + + test('should call find API with searchText', async () => { + const resolvedValue = { + page: 1, + perPage: 10, + total: 0, + data: [], + }; + http.get.mockResolvedValueOnce(resolvedValue); + + const result = await loadAlerts({ http, searchText: 'apples', page: { index: 0, size: 10 } }); + expect(result).toEqual(resolvedValue); + expect(http.get.mock.calls[0]).toMatchInlineSnapshot(` + Array [ + "/api/alert/_find", + Object { + "query": Object { + "default_search_operator": "AND", + "filter": undefined, + "page": 1, + "per_page": 10, + "search": "apples", + "search_fields": "[\\"name\\",\\"tags\\"]", + }, + }, + ] + `); + }); + + test('should call find API with actionTypesFilter', async () => { + const resolvedValue = { + page: 1, + perPage: 10, + total: 0, + data: [], + }; + http.get.mockResolvedValueOnce(resolvedValue); + + const result = await loadAlerts({ + http, + searchText: 'foo', + page: { index: 0, size: 10 }, + }); + expect(result).toEqual(resolvedValue); + expect(http.get.mock.calls[0]).toMatchInlineSnapshot(` + Array [ + "/api/alert/_find", + Object { + "query": Object { + "default_search_operator": "AND", + "filter": undefined, + "page": 1, + "per_page": 10, + "search": "foo", + "search_fields": "[\\"name\\",\\"tags\\"]", + }, + }, + ] + `); + }); + + test('should call find API with typesFilter', async () => { + const resolvedValue = { + page: 1, + perPage: 10, + total: 0, + data: [], + }; + http.get.mockResolvedValueOnce(resolvedValue); + + const result = await loadAlerts({ + http, + typesFilter: ['foo', 'bar'], + page: { index: 0, size: 10 }, + }); + expect(result).toEqual(resolvedValue); + expect(http.get.mock.calls[0]).toMatchInlineSnapshot(` + Array [ + "/api/alert/_find", + Object { + "query": Object { + "default_search_operator": "AND", + "filter": "alert.attributes.alertTypeId:(foo or bar)", + "page": 1, + "per_page": 10, + "search": undefined, + "search_fields": undefined, + }, + }, + ] + `); + }); + + test('should call find API with actionTypesFilter and typesFilter', async () => { + const resolvedValue = { + page: 1, + perPage: 10, + total: 0, + data: [], + }; + http.get.mockResolvedValueOnce(resolvedValue); + + const result = await loadAlerts({ + http, + searchText: 'baz', + typesFilter: ['foo', 'bar'], + page: { index: 0, size: 10 }, + }); + expect(result).toEqual(resolvedValue); + expect(http.get.mock.calls[0]).toMatchInlineSnapshot(` + Array [ + "/api/alert/_find", + Object { + "query": Object { + "default_search_operator": "AND", + "filter": "alert.attributes.alertTypeId:(foo or bar)", + "page": 1, + "per_page": 10, + "search": "baz", + "search_fields": "[\\"name\\",\\"tags\\"]", + }, + }, + ] + `); + }); + + test('should call find API with searchText and tagsFilter and typesFilter', async () => { + const resolvedValue = { + page: 1, + perPage: 10, + total: 0, + data: [], + }; + http.get.mockResolvedValueOnce(resolvedValue); + + const result = await loadAlerts({ + http, + searchText: 'apples, foo, baz', + typesFilter: ['foo', 'bar'], + page: { index: 0, size: 10 }, + }); + expect(result).toEqual(resolvedValue); + expect(http.get.mock.calls[0]).toMatchInlineSnapshot(` + Array [ + "/api/alert/_find", + Object { + "query": Object { + "default_search_operator": "AND", + "filter": "alert.attributes.alertTypeId:(foo or bar)", + "page": 1, + "per_page": 10, + "search": "apples, foo, baz", + "search_fields": "[\\"name\\",\\"tags\\"]", + }, + }, + ] + `); + }); +}); + +describe('deleteAlerts', () => { + test('should call delete API for each alert', async () => { + const ids = ['1', '2', '3']; + const result = await deleteAlerts({ http, ids }); + expect(result).toEqual(undefined); + expect(http.delete.mock.calls).toMatchInlineSnapshot(` + Array [ + Array [ + "/api/alert/1", + ], + Array [ + "/api/alert/2", + ], + Array [ + "/api/alert/3", + ], + ] + `); + }); +}); + +describe('createAlert', () => { + test('should call create alert API', async () => { + const alertToCreate = { + name: 'test', + tags: ['foo'], + enabled: true, + alertTypeId: 'test', + interval: '1m', + actions: [], + params: {}, + throttle: null, + }; + const resolvedValue: Alert = { + ...alertToCreate, + id: '123', + createdBy: null, + updatedBy: null, + muteAll: false, + mutedInstanceIds: [], + }; + http.post.mockResolvedValueOnce(resolvedValue); + + const result = await createAlert({ http, alert: alertToCreate }); + expect(result).toEqual(resolvedValue); + expect(http.post.mock.calls[0]).toMatchInlineSnapshot(` + Array [ + "/api/alert", + Object { + "body": "{\\"name\\":\\"test\\",\\"tags\\":[\\"foo\\"],\\"enabled\\":true,\\"alertTypeId\\":\\"test\\",\\"interval\\":\\"1m\\",\\"actions\\":[],\\"params\\":{},\\"throttle\\":null}", + }, + ] + `); + }); +}); + +describe('updateAlert', () => { + test('should call alert update API', async () => { + const alertToUpdate = { + throttle: '1m', + name: 'test', + tags: ['foo'], + interval: '1m', + params: {}, + actions: [], + }; + const resolvedValue: Alert = { + ...alertToUpdate, + id: '123', + enabled: true, + alertTypeId: 'test', + createdBy: null, + updatedBy: null, + muteAll: false, + mutedInstanceIds: [], + }; + http.put.mockResolvedValueOnce(resolvedValue); + + const result = await updateAlert({ http, id: '123', alert: alertToUpdate }); + expect(result).toEqual(resolvedValue); + expect(http.put.mock.calls[0]).toMatchInlineSnapshot(` + Array [ + "/api/alert/123", + Object { + "body": "{\\"throttle\\":\\"1m\\",\\"name\\":\\"test\\",\\"tags\\":[\\"foo\\"],\\"interval\\":\\"1m\\",\\"params\\":{},\\"actions\\":[]}", + }, + ] + `); + }); +}); + +describe('enableAlerts', () => { + test('should call enable alert API per alert', async () => { + const ids = ['1', '2', '3']; + const result = await enableAlerts({ http, ids }); + expect(result).toEqual(undefined); + expect(http.post.mock.calls).toMatchInlineSnapshot(` + Array [ + Array [ + "/api/alert/1/_enable", + ], + Array [ + "/api/alert/2/_enable", + ], + Array [ + "/api/alert/3/_enable", + ], + ] + `); + }); +}); + +describe('disableAlerts', () => { + test('should call disable alert API per alert', async () => { + const ids = ['1', '2', '3']; + const result = await disableAlerts({ http, ids }); + expect(result).toEqual(undefined); + expect(http.post.mock.calls).toMatchInlineSnapshot(` + Array [ + Array [ + "/api/alert/1/_disable", + ], + Array [ + "/api/alert/2/_disable", + ], + Array [ + "/api/alert/3/_disable", + ], + ] + `); + }); +}); + +describe('muteAlerts', () => { + test('should call mute alert API per alert', async () => { + const ids = ['1', '2', '3']; + const result = await muteAlerts({ http, ids }); + expect(result).toEqual(undefined); + expect(http.post.mock.calls).toMatchInlineSnapshot(` + Array [ + Array [ + "/api/alert/1/_mute_all", + ], + Array [ + "/api/alert/2/_mute_all", + ], + Array [ + "/api/alert/3/_mute_all", + ], + ] + `); + }); +}); + +describe('unmuteAlerts', () => { + test('should call unmute alert API per alert', async () => { + const ids = ['1', '2', '3']; + const result = await unmuteAlerts({ http, ids }); + expect(result).toEqual(undefined); + expect(http.post.mock.calls).toMatchInlineSnapshot(` + Array [ + Array [ + "/api/alert/1/_unmute_all", + ], + Array [ + "/api/alert/2/_unmute_all", + ], + Array [ + "/api/alert/3/_unmute_all", + ], + ] + `); + }); +}); diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/alert_api.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/alert_api.ts new file mode 100644 index 0000000000000..9867acbd7a622 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/alert_api.ts @@ -0,0 +1,126 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { HttpSetup } from 'kibana/public'; +import { BASE_ALERT_API_PATH } from '../constants'; +import { Alert, AlertType, AlertWithoutId } from '../../types'; + +export async function loadAlertTypes({ http }: { http: HttpSetup }): Promise { + return await http.get(`${BASE_ALERT_API_PATH}/types`); +} + +export async function loadAlerts({ + http, + page, + searchText, + typesFilter, + actionTypesFilter, +}: { + http: HttpSetup; + page: { index: number; size: number }; + searchText?: string; + typesFilter?: string[]; + actionTypesFilter?: string[]; +}): Promise<{ + page: number; + perPage: number; + total: number; + data: Alert[]; +}> { + const filters = []; + if (typesFilter && typesFilter.length) { + filters.push(`alert.attributes.alertTypeId:(${typesFilter.join(' or ')})`); + } + if (actionTypesFilter && actionTypesFilter.length) { + filters.push( + [ + '(', + actionTypesFilter.map(id => `alert.attributes.actions:{ actionTypeId:${id} }`).join(' OR '), + ')', + ].join('') + ); + } + return await http.get(`${BASE_ALERT_API_PATH}/_find`, { + query: { + page: page.index + 1, + per_page: page.size, + search_fields: searchText ? JSON.stringify(['name', 'tags']) : undefined, + search: searchText, + filter: filters.length ? filters.join(' and ') : undefined, + default_search_operator: 'AND', + }, + }); +} + +export async function deleteAlerts({ + ids, + http, +}: { + ids: string[]; + http: HttpSetup; +}): Promise { + await Promise.all(ids.map(id => http.delete(`${BASE_ALERT_API_PATH}/${id}`))); +} + +export async function createAlert({ + http, + alert, +}: { + http: HttpSetup; + alert: Omit; +}): Promise { + return await http.post(`${BASE_ALERT_API_PATH}`, { + body: JSON.stringify(alert), + }); +} + +export async function updateAlert({ + http, + alert, + id, +}: { + http: HttpSetup; + alert: Pick; + id: string; +}): Promise { + return await http.put(`${BASE_ALERT_API_PATH}/${id}`, { + body: JSON.stringify(alert), + }); +} + +export async function enableAlerts({ + ids, + http, +}: { + ids: string[]; + http: HttpSetup; +}): Promise { + await Promise.all(ids.map(id => http.post(`${BASE_ALERT_API_PATH}/${id}/_enable`))); +} + +export async function disableAlerts({ + ids, + http, +}: { + ids: string[]; + http: HttpSetup; +}): Promise { + await Promise.all(ids.map(id => http.post(`${BASE_ALERT_API_PATH}/${id}/_disable`))); +} + +export async function muteAlerts({ ids, http }: { ids: string[]; http: HttpSetup }): Promise { + await Promise.all(ids.map(id => http.post(`${BASE_ALERT_API_PATH}/${id}/_mute_all`))); +} + +export async function unmuteAlerts({ + ids, + http, +}: { + ids: string[]; + http: HttpSetup; +}): Promise { + await Promise.all(ids.map(id => http.post(`${BASE_ALERT_API_PATH}/${id}/_unmute_all`))); +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/breadcrumb.test.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/breadcrumb.test.ts new file mode 100644 index 0000000000000..b75e014640d72 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/breadcrumb.test.ts @@ -0,0 +1,31 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import { getCurrentBreadcrumb } from './breadcrumb'; +import { i18n } from '@kbn/i18n'; +import { routeToConnectors, routeToAlerts, routeToHome } from '../constants'; + +describe('getCurrentBreadcrumb', () => { + test('if change calls return proper breadcrumb title ', async () => { + expect(getCurrentBreadcrumb('connectors')).toMatchObject({ + text: i18n.translate('xpack.triggersActionsUI.connectors.breadcrumbTitle', { + defaultMessage: 'Connectors', + }), + href: `#${routeToConnectors}`, + }); + expect(getCurrentBreadcrumb('alerts')).toMatchObject({ + text: i18n.translate('xpack.triggersActionsUI.alerts.breadcrumbTitle', { + defaultMessage: 'Alerts', + }), + href: `#${routeToAlerts}`, + }); + expect(getCurrentBreadcrumb('home')).toMatchObject({ + text: i18n.translate('xpack.triggersActionsUI.home.breadcrumbTitle', { + defaultMessage: 'Alerts and Actions', + }), + href: `#${routeToHome}`, + }); + }); +}); diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/breadcrumb.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/breadcrumb.ts new file mode 100644 index 0000000000000..f833ae9eb39ac --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/breadcrumb.ts @@ -0,0 +1,35 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { i18n } from '@kbn/i18n'; +import { routeToHome, routeToConnectors, routeToAlerts } from '../constants'; + +export const getCurrentBreadcrumb = (type: string): { text: string; href: string } => { + // Home and sections + switch (type) { + case 'connectors': + return { + text: i18n.translate('xpack.triggersActionsUI.connectors.breadcrumbTitle', { + defaultMessage: 'Connectors', + }), + href: `#${routeToConnectors}`, + }; + case 'alerts': + return { + text: i18n.translate('xpack.triggersActionsUI.alerts.breadcrumbTitle', { + defaultMessage: 'Alerts', + }), + href: `#${routeToAlerts}`, + }; + default: + return { + text: i18n.translate('xpack.triggersActionsUI.home.breadcrumbTitle', { + defaultMessage: 'Alerts and Actions', + }), + href: `#${routeToHome}`, + }; + } +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/capabilities.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/capabilities.ts new file mode 100644 index 0000000000000..e5693e31c2d66 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/capabilities.ts @@ -0,0 +1,53 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +/** + * NOTE: Applications that want to show the alerting UIs will need to add + * check against their features here until we have a better solution. This + * will possibly go away with https://github.com/elastic/kibana/issues/52300. + */ + +export function hasShowAlertsCapability(capabilities: any): boolean { + if (capabilities.siem && capabilities.siem['alerting:show']) { + return true; + } + return false; +} + +export function hasShowActionsCapability(capabilities: any): boolean { + if (capabilities.siem && capabilities.siem['actions:show']) { + return true; + } + return false; +} + +export function hasSaveAlertsCapability(capabilities: any): boolean { + if (capabilities.siem && capabilities.siem['alerting:save']) { + return true; + } + return false; +} + +export function hasSaveActionsCapability(capabilities: any): boolean { + if (capabilities.siem && capabilities.siem['actions:save']) { + return true; + } + return false; +} + +export function hasDeleteAlertsCapability(capabilities: any): boolean { + if (capabilities.siem && capabilities.siem['alerting:delete']) { + return true; + } + return false; +} + +export function hasDeleteActionsCapability(capabilities: any): boolean { + if (capabilities.siem && capabilities.siem['actions:delete']) { + return true; + } + return false; +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/doc_title.test.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/doc_title.test.ts new file mode 100644 index 0000000000000..f351adf79eb2c --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/doc_title.test.ts @@ -0,0 +1,14 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import { getCurrentDocTitle } from './doc_title'; + +describe('getCurrentDocTitle', () => { + test('if change calls return the proper doc title ', async () => { + expect(getCurrentDocTitle('home') === 'Alerts and Actions').toBeTruthy(); + expect(getCurrentDocTitle('connectors') === 'Connectors').toBeTruthy(); + expect(getCurrentDocTitle('alerts') === 'Alerts').toBeTruthy(); + }); +}); diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/doc_title.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/doc_title.ts new file mode 100644 index 0000000000000..15bd6bc77b132 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/doc_title.ts @@ -0,0 +1,28 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import { i18n } from '@kbn/i18n'; + +export const getCurrentDocTitle = (page: string): string => { + let updatedTitle: string; + + switch (page) { + case 'connectors': + updatedTitle = i18n.translate('xpack.triggersActionsUI.connectors.breadcrumbTitle', { + defaultMessage: 'Connectors', + }); + break; + case 'alerts': + updatedTitle = i18n.translate('xpack.triggersActionsUI.alerts.breadcrumbTitle', { + defaultMessage: 'Alerts', + }); + break; + default: + updatedTitle = i18n.translate('xpack.triggersActionsUI.home.breadcrumbTitle', { + defaultMessage: 'Alerts and Actions', + }); + } + return updatedTitle; +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/get_time_options.test.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/get_time_options.test.ts new file mode 100644 index 0000000000000..3ed7eea026db4 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/get_time_options.test.ts @@ -0,0 +1,36 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import { getTimeOptions, getTimeFieldOptions } from './get_time_options'; + +describe('get_time_options', () => { + test('if getTimeOptions return single unit time options', () => { + const timeUnitValue = getTimeOptions('1'); + expect(timeUnitValue).toMatchObject([ + { text: 'second', value: 's' }, + { text: 'minute', value: 'm' }, + { text: 'hour', value: 'h' }, + { text: 'day', value: 'd' }, + ]); + }); + + test('if getTimeOptions return multiple unit time options', () => { + const timeUnitValue = getTimeOptions('10'); + expect(timeUnitValue).toMatchObject([ + { text: 'seconds', value: 's' }, + { text: 'minutes', value: 'm' }, + { text: 'hours', value: 'h' }, + { text: 'days', value: 'd' }, + ]); + }); + + test('if getTimeFieldOptions return only date type fields', () => { + const timeOnlyTypeFields = getTimeFieldOptions([ + { type: 'date', name: 'order_date' }, + { type: 'number', name: 'sum' }, + ]); + expect(timeOnlyTypeFields).toMatchObject([{ text: 'order_date', value: 'order_date' }]); + }); +}); diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/get_time_options.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/get_time_options.ts new file mode 100644 index 0000000000000..d24f20a4fc289 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/get_time_options.ts @@ -0,0 +1,37 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { getTimeUnitLabel } from './get_time_unit_label'; +import { TIME_UNITS } from '../constants'; + +export const getTimeOptions = (unitSize: string) => + Object.entries(TIME_UNITS).map(([_key, value]) => { + return { + text: getTimeUnitLabel(value, unitSize), + value, + }; + }); + +interface TimeFieldOptions { + text: string; + value: string; +} + +export const getTimeFieldOptions = ( + fields: Array<{ type: string; name: string }> +): TimeFieldOptions[] => { + const options: TimeFieldOptions[] = []; + + fields.forEach((field: { type: string; name: string }) => { + if (field.type === 'date') { + options.push({ + text: field.name, + value: field.name, + }); + } + }); + return options; +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/get_time_unit_label.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/get_time_unit_label.ts new file mode 100644 index 0000000000000..a621855415328 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/lib/get_time_unit_label.ts @@ -0,0 +1,33 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { i18n } from '@kbn/i18n'; +import { TIME_UNITS } from '../constants'; + +export function getTimeUnitLabel(timeUnit = TIME_UNITS.SECOND, timeValue = '0') { + switch (timeUnit) { + case TIME_UNITS.SECOND: + return i18n.translate('xpack.triggersActionsUI.timeUnits.secondLabel', { + defaultMessage: '{timeValue, plural, one {second} other {seconds}}', + values: { timeValue }, + }); + case TIME_UNITS.MINUTE: + return i18n.translate('xpack.triggersActionsUI.timeUnits.minuteLabel', { + defaultMessage: '{timeValue, plural, one {minute} other {minutes}}', + values: { timeValue }, + }); + case TIME_UNITS.HOUR: + return i18n.translate('xpack.triggersActionsUI.timeUnits.hourLabel', { + defaultMessage: '{timeValue, plural, one {hour} other {hours}}', + values: { timeValue }, + }); + case TIME_UNITS.DAY: + return i18n.translate('xpack.triggersActionsUI.timeUnits.dayLabel', { + defaultMessage: '{timeValue, plural, one {day} other {days}}', + values: { timeValue }, + }); + } +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/action_connector_form.test.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/action_connector_form.test.tsx new file mode 100644 index 0000000000000..c129ce73c7176 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/action_connector_form.test.tsx @@ -0,0 +1,113 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import * as React from 'react'; +import { mountWithIntl } from 'test_utils/enzyme_helpers'; +import { coreMock } from '../../../../../../../../../src/core/public/mocks'; +import { ReactWrapper } from 'enzyme'; +import { act } from 'react-dom/test-utils'; +import { ActionsConnectorsContextProvider } from '../../context/actions_connectors_context'; +import { actionTypeRegistryMock } from '../../action_type_registry.mock'; +import { ValidationResult, ActionConnector } from '../../../types'; +import { ActionConnectorForm } from './action_connector_form'; +import { AppContextProvider } from '../../app_context'; +const actionTypeRegistry = actionTypeRegistryMock.create(); + +describe('action_connector_form', () => { + let wrapper: ReactWrapper; + + beforeAll(async () => { + const mockes = coreMock.createSetup(); + const [{ chrome, docLinks }] = await mockes.getStartServices(); + const deps = { + chrome, + docLinks, + toastNotifications: mockes.notifications.toasts, + injectedMetadata: mockes.injectedMetadata, + http: mockes.http, + uiSettings: mockes.uiSettings, + legacy: { + capabilities: { + get() { + return { + actions: { + delete: true, + save: true, + show: true, + }, + }; + }, + } as any, + MANAGEMENT_BREADCRUMB: { set: () => {} } as any, + }, + actionTypeRegistry: actionTypeRegistry as any, + alertTypeRegistry: {} as any, + }; + + const actionType = { + id: 'my-action-type', + iconClass: 'test', + selectMessage: 'test', + validateConnector: (): ValidationResult => { + return { errors: {} }; + }, + validateParams: (): ValidationResult => { + const validationResult = { errors: {} }; + return validationResult; + }, + actionConnectorFields: null, + actionParamsFields: null, + }; + actionTypeRegistry.get.mockReturnValue(actionType); + actionTypeRegistry.has.mockReturnValue(true); + + const initialConnector = { + actionTypeId: actionType.id, + config: {}, + secrets: {}, + } as ActionConnector; + + await act(async () => { + wrapper = mountWithIntl( + + {}, + editFlyoutVisible: false, + setEditFlyoutVisibility: () => {}, + actionTypesIndex: { + 'my-action-type': { id: 'my-action-type', name: 'my-action-type-name' }, + }, + reloadConnectors: () => { + return new Promise(() => {}); + }, + }} + > + {}} + /> + + + ); + }); + + await waitForRender(wrapper); + }); + + it('renders action_connector_form', () => { + const connectorNameField = wrapper.find('[data-test-subj="nameInput"]'); + expect(connectorNameField.exists()).toBeTruthy(); + expect(connectorNameField.first().prop('value')).toBe(''); + }); +}); + +async function waitForRender(wrapper: ReactWrapper) { + await Promise.resolve(); + await Promise.resolve(); + wrapper.update(); +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/action_connector_form.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/action_connector_form.tsx new file mode 100644 index 0000000000000..682c1fbb54b67 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/action_connector_form.tsx @@ -0,0 +1,270 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import React, { Fragment, useState, useReducer } from 'react'; +import { + EuiButton, + EuiFlexGroup, + EuiFlexItem, + EuiForm, + EuiCallOut, + EuiLink, + EuiText, + EuiSpacer, + EuiButtonEmpty, + EuiFlyoutFooter, + EuiFieldText, + EuiFlyoutBody, + EuiFormRow, +} from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; +import { FormattedMessage } from '@kbn/i18n/react'; +import { createActionConnector, updateActionConnector } from '../../lib/action_connector_api'; +import { useAppDependencies } from '../../app_context'; +import { connectorReducer } from './connector_reducer'; +import { useActionsConnectorsContext } from '../../context/actions_connectors_context'; +import { ActionConnector, IErrorObject } from '../../../types'; +import { hasSaveActionsCapability } from '../../lib/capabilities'; + +interface ActionConnectorProps { + initialConnector: ActionConnector; + actionTypeName: string; + setFlyoutVisibility: React.Dispatch>; +} + +export const ActionConnectorForm = ({ + initialConnector, + actionTypeName, + setFlyoutVisibility, +}: ActionConnectorProps) => { + const { + http, + toastNotifications, + legacy: { capabilities }, + actionTypeRegistry, + } = useAppDependencies(); + + const { reloadConnectors } = useActionsConnectorsContext(); + const canSave = hasSaveActionsCapability(capabilities.get()); + + // hooks + const [{ connector }, dispatch] = useReducer(connectorReducer, { connector: initialConnector }); + + const setActionProperty = (key: string, value: any) => { + dispatch({ command: { type: 'setProperty' }, payload: { key, value } }); + }; + + const setActionConfigProperty = (key: string, value: any) => { + dispatch({ command: { type: 'setConfigProperty' }, payload: { key, value } }); + }; + + const setActionSecretsProperty = (key: string, value: any) => { + dispatch({ command: { type: 'setSecretsProperty' }, payload: { key, value } }); + }; + + const [isSaving, setIsSaving] = useState(false); + const [serverError, setServerError] = useState<{ + body: { message: string; error: string }; + } | null>(null); + + const actionTypeRegistered = actionTypeRegistry.get(initialConnector.actionTypeId); + if (!actionTypeRegistered) return null; + + function validateBaseProperties(actionObject: ActionConnector) { + const validationResult = { errors: {} }; + const errors = { + name: new Array(), + }; + validationResult.errors = errors; + if (!actionObject.name) { + errors.name.push( + i18n.translate( + 'xpack.triggersActionsUI.sections.actionConnectorForm.error.requiredNameText', + { + defaultMessage: 'Name is required.', + } + ) + ); + } + return validationResult; + } + + const FieldsComponent = actionTypeRegistered.actionConnectorFields; + const errors = { + ...actionTypeRegistered.validateConnector(connector).errors, + ...validateBaseProperties(connector).errors, + } as IErrorObject; + const hasErrors = !!Object.keys(errors).find(errorKey => errors[errorKey].length >= 1); + + async function onActionConnectorSave(): Promise { + let message: string; + let savedConnector: ActionConnector | undefined; + let error; + if (connector.id === undefined) { + await createActionConnector({ http, connector }) + .then(res => { + savedConnector = res; + }) + .catch(errorRes => { + error = errorRes; + }); + + message = 'Created'; + } else { + await updateActionConnector({ http, connector, id: connector.id }) + .then(res => { + savedConnector = res; + }) + .catch(errorRes => { + error = errorRes; + }); + message = 'Updated'; + } + if (error) { + return { + error, + }; + } + toastNotifications.addSuccess( + i18n.translate( + 'xpack.triggersActionsUI.sections.actionConnectorForm.updateSuccessNotificationText', + { + defaultMessage: "{message} '{connectorName}'", + values: { + message, + connectorName: savedConnector ? savedConnector.name : '', + }, + } + ) + ); + return savedConnector; + } + + return ( + + + + + } + isInvalid={errors.name.length > 0 && connector.name !== undefined} + error={errors.name} + > + 0 && connector.name !== undefined} + name="name" + placeholder="Untitled" + data-test-subj="nameInput" + value={connector.name || ''} + onChange={e => { + setActionProperty('name', e.target.value); + }} + onBlur={() => { + if (!connector.name) { + setActionProperty('name', ''); + } + }} + /> + + + {FieldsComponent !== null ? ( + + {initialConnector.actionTypeId === null ? ( + + + +

+ + + + ), + }} + /> +

+
+
+ +
+ ) : null} +
+ ) : null} +
+
+ + + + setFlyoutVisibility(false)}> + {i18n.translate( + 'xpack.triggersActionsUI.sections.actionConnectorForm.cancelButtonLabel', + { + defaultMessage: 'Cancel', + } + )} + + + {canSave ? ( + + { + setIsSaving(true); + const savedAction = await onActionConnectorSave(); + setIsSaving(false); + if (savedAction && savedAction.error) { + return setServerError(savedAction.error); + } + setFlyoutVisibility(false); + reloadConnectors(); + }} + > + + + + ) : null} + + +
+ ); +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/action_type_menu.test.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/action_type_menu.test.tsx new file mode 100644 index 0000000000000..a9e2afb061720 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/action_type_menu.test.tsx @@ -0,0 +1,91 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import * as React from 'react'; +import { mountWithIntl } from 'test_utils/enzyme_helpers'; +import { coreMock } from '../../../../../../../../../src/core/public/mocks'; +import { ActionsConnectorsContextProvider } from '../../context/actions_connectors_context'; +import { actionTypeRegistryMock } from '../../action_type_registry.mock'; +import { ActionTypeMenu } from './action_type_menu'; +import { ValidationResult } from '../../../types'; +import { AppContextProvider } from '../../app_context'; +const actionTypeRegistry = actionTypeRegistryMock.create(); + +describe('connector_add_flyout', () => { + let deps: any; + + beforeAll(async () => { + const mockes = coreMock.createSetup(); + const [{ chrome, docLinks }] = await mockes.getStartServices(); + deps = { + chrome, + docLinks, + toastNotifications: mockes.notifications.toasts, + injectedMetadata: mockes.injectedMetadata, + http: mockes.http, + uiSettings: mockes.uiSettings, + legacy: { + capabilities: { + get() { + return { + actions: { + delete: true, + save: true, + show: true, + }, + }; + }, + } as any, + MANAGEMENT_BREADCRUMB: { set: () => {} } as any, + }, + actionTypeRegistry: actionTypeRegistry as any, + alertTypeRegistry: {} as any, + }; + }); + + it('renders action type menu with proper EuiCards for registered action types', () => { + const onActionTypeChange = jest.fn(); + const actionType = { + id: 'my-action-type', + iconClass: 'test', + selectMessage: 'test', + validateConnector: (): ValidationResult => { + return { errors: {} }; + }, + validateParams: (): ValidationResult => { + const validationResult = { errors: {} }; + return validationResult; + }, + actionConnectorFields: null, + actionParamsFields: null, + }; + actionTypeRegistry.get.mockReturnValueOnce(actionType); + + const wrapper = mountWithIntl( + + {}, + editFlyoutVisible: false, + setEditFlyoutVisibility: state => {}, + actionTypesIndex: { + 'first-action-type': { id: 'first-action-type', name: 'first' }, + 'second-action-type': { id: 'second-action-type', name: 'second' }, + }, + reloadConnectors: () => { + return new Promise(() => {}); + }, + }} + > + + + + ); + + expect(wrapper.find('[data-test-subj="first-action-type-card"]').exists()).toBeTruthy(); + expect(wrapper.find('[data-test-subj="second-action-type-card"]').exists()).toBeTruthy(); + }); +}); diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/action_type_menu.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/action_type_menu.tsx new file mode 100644 index 0000000000000..19373fda79b9e --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/action_type_menu.tsx @@ -0,0 +1,83 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import React, { Fragment } from 'react'; +import { + EuiFlexGroup, + EuiFlexItem, + EuiCard, + EuiIcon, + EuiFlexGrid, + EuiFlyoutBody, + EuiFlyoutFooter, + EuiButtonEmpty, +} from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; +import { ActionType } from '../../../types'; +import { useActionsConnectorsContext } from '../../context/actions_connectors_context'; +import { useAppDependencies } from '../../app_context'; + +interface Props { + onActionTypeChange: (actionType: ActionType) => void; +} + +export const ActionTypeMenu = ({ onActionTypeChange }: Props) => { + const { actionTypeRegistry } = useAppDependencies(); + const { actionTypesIndex, setAddFlyoutVisibility } = useActionsConnectorsContext(); + if (!actionTypesIndex) { + return null; + } + + const actionTypes = Object.entries(actionTypesIndex) + .filter(([index]) => actionTypeRegistry.has(index)) + .map(([index, actionType]) => { + const actionTypeModel = actionTypeRegistry.get(index); + return { + iconClass: actionTypeModel ? actionTypeModel.iconClass : '', + selectMessage: actionTypeModel ? actionTypeModel.selectMessage : '', + actionType, + name: actionType.name, + typeName: index.replace('.', ''), + }; + }); + + const cardNodes = actionTypes + .sort((a, b) => a.name.localeCompare(b.name)) + .map((item, index): any => { + return ( + + } + title={item.name} + description={item.selectMessage} + onClick={() => onActionTypeChange(item.actionType)} + /> + + ); + }); + + return ( + + + {cardNodes} + + + + + setAddFlyoutVisibility(false)}> + {i18n.translate( + 'xpack.triggersActionsUI.sections.actionConnectorForm.cancelButtonLabel', + { + defaultMessage: 'Cancel', + } + )} + + + + + + ); +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_add_flyout.test.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_add_flyout.test.tsx new file mode 100644 index 0000000000000..5095cc140f9c9 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_add_flyout.test.tsx @@ -0,0 +1,100 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import * as React from 'react'; +import { mountWithIntl } from 'test_utils/enzyme_helpers'; +import { coreMock } from '../../../../../../../../../src/core/public/mocks'; +import { ReactWrapper } from 'enzyme'; +import { act } from 'react-dom/test-utils'; +import { ConnectorAddFlyout } from './connector_add_flyout'; +import { ActionsConnectorsContextProvider } from '../../context/actions_connectors_context'; +import { actionTypeRegistryMock } from '../../action_type_registry.mock'; +import { ValidationResult } from '../../../types'; +import { AppContextProvider } from '../../app_context'; +const actionTypeRegistry = actionTypeRegistryMock.create(); + +describe('connector_add_flyout', () => { + let wrapper: ReactWrapper; + + beforeAll(async () => { + const mockes = coreMock.createSetup(); + const [{ chrome, docLinks }] = await mockes.getStartServices(); + const deps = { + chrome, + docLinks, + toastNotifications: mockes.notifications.toasts, + injectedMetadata: mockes.injectedMetadata, + http: mockes.http, + uiSettings: mockes.uiSettings, + legacy: { + capabilities: { + get() { + return { + actions: { + delete: true, + save: true, + show: true, + }, + }; + }, + } as any, + MANAGEMENT_BREADCRUMB: { set: () => {} } as any, + }, + actionTypeRegistry: actionTypeRegistry as any, + alertTypeRegistry: {} as any, + }; + + await act(async () => { + wrapper = mountWithIntl( + + {}, + editFlyoutVisible: false, + setEditFlyoutVisibility: state => {}, + actionTypesIndex: { 'my-action-type': { id: 'my-action-type', name: 'test' } }, + reloadConnectors: () => { + return new Promise(() => {}); + }, + }} + > + + + + ); + }); + + await waitForRender(wrapper); + }); + + it('renders action type menu on flyout open', () => { + const actionType = { + id: 'my-action-type', + iconClass: 'test', + selectMessage: 'test', + validateConnector: (): ValidationResult => { + return { errors: {} }; + }, + validateParams: (): ValidationResult => { + const validationResult = { errors: {} }; + return validationResult; + }, + actionConnectorFields: null, + actionParamsFields: null, + }; + actionTypeRegistry.get.mockReturnValueOnce(actionType); + actionTypeRegistry.has.mockReturnValue(true); + + expect(wrapper.find('ActionTypeMenu')).toHaveLength(1); + expect(wrapper.find('[data-test-subj="my-action-type-card"]').exists()).toBeTruthy(); + }); +}); + +async function waitForRender(wrapper: ReactWrapper) { + await Promise.resolve(); + await Promise.resolve(); + wrapper.update(); +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_add_flyout.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_add_flyout.tsx new file mode 100644 index 0000000000000..a3ec7ab4b3ab9 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_add_flyout.tsx @@ -0,0 +1,104 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import React, { useCallback, useState, Fragment } from 'react'; +import { FormattedMessage } from '@kbn/i18n/react'; +import { + EuiTitle, + EuiFlyoutHeader, + EuiFlyout, + EuiFlexGroup, + EuiFlexItem, + EuiIcon, + EuiText, +} from '@elastic/eui'; +import { useActionsConnectorsContext } from '../../context/actions_connectors_context'; +import { ActionTypeMenu } from './action_type_menu'; +import { ActionConnectorForm } from './action_connector_form'; +import { ActionType, ActionConnector } from '../../../types'; +import { useAppDependencies } from '../../app_context'; + +export const ConnectorAddFlyout = () => { + const { actionTypeRegistry } = useAppDependencies(); + const { addFlyoutVisible, setAddFlyoutVisibility } = useActionsConnectorsContext(); + const [actionType, setActionType] = useState(undefined); + const closeFlyout = useCallback(() => { + setAddFlyoutVisibility(false); + setActionType(undefined); + }, [setAddFlyoutVisibility, setActionType]); + + if (!addFlyoutVisible) { + return null; + } + + function onActionTypeChange(newActionType: ActionType) { + setActionType(newActionType); + } + + let currentForm; + let actionTypeModel; + if (!actionType) { + currentForm = ; + } else { + actionTypeModel = actionTypeRegistry.get(actionType.id); + const initialConnector = { + actionTypeId: actionType.id, + config: {}, + secrets: {}, + } as ActionConnector; + + currentForm = ( + + ); + } + + return ( + + + + {actionTypeModel && actionTypeModel.iconClass ? ( + + + + ) : null} + + {actionTypeModel && actionType ? ( + + +

+ +

+
+ + {actionTypeModel.selectMessage} + +
+ ) : ( + +

+ +

+
+ )} +
+
+
+ {currentForm} +
+ ); +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_edit_flyout.test.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_edit_flyout.test.tsx new file mode 100644 index 0000000000000..d01539d7232fa --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_edit_flyout.test.tsx @@ -0,0 +1,100 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import * as React from 'react'; +import { mountWithIntl } from 'test_utils/enzyme_helpers'; +import { coreMock } from '../../../../../../../../../src/core/public/mocks'; +import { ActionsConnectorsContextProvider } from '../../context/actions_connectors_context'; +import { actionTypeRegistryMock } from '../../action_type_registry.mock'; +import { ValidationResult } from '../../../types'; +import { ConnectorEditFlyout } from './connector_edit_flyout'; +import { AppContextProvider } from '../../app_context'; +const actionTypeRegistry = actionTypeRegistryMock.create(); +let deps: any; + +describe('connector_edit_flyout', () => { + beforeAll(async () => { + const mockes = coreMock.createSetup(); + const [{ chrome, docLinks }] = await mockes.getStartServices(); + deps = { + chrome, + docLinks, + toastNotifications: mockes.notifications.toasts, + injectedMetadata: mockes.injectedMetadata, + http: mockes.http, + uiSettings: mockes.uiSettings, + legacy: { + capabilities: { + get() { + return { + actions: { + delete: true, + save: true, + show: true, + }, + }; + }, + } as any, + MANAGEMENT_BREADCRUMB: { set: () => {} } as any, + }, + actionTypeRegistry: actionTypeRegistry as any, + alertTypeRegistry: {} as any, + }; + }); + + test('if input connector render correct in the edit form', () => { + const connector = { + secrets: {}, + id: 'test', + actionTypeId: 'test-action-type-id', + actionType: 'test-action-type-name', + name: 'action-connector', + referencedByCount: 0, + config: {}, + }; + + const actionType = { + id: 'test-action-type-id', + iconClass: 'test', + selectMessage: 'test', + validateConnector: (): ValidationResult => { + return { errors: {} }; + }, + validateParams: (): ValidationResult => { + const validationResult = { errors: {} }; + return validationResult; + }, + actionConnectorFields: null, + actionParamsFields: null, + }; + actionTypeRegistry.get.mockReturnValue(actionType); + actionTypeRegistry.has.mockReturnValue(true); + + const wrapper = mountWithIntl( + + {}, + editFlyoutVisible: true, + setEditFlyoutVisibility: state => {}, + actionTypesIndex: { + 'test-action-type-id': { id: 'test-action-type-id', name: 'test' }, + }, + reloadConnectors: () => { + return new Promise(() => {}); + }, + }} + > + + + + ); + + const connectorNameField = wrapper.find('[data-test-subj="nameInput"]'); + expect(connectorNameField.exists()).toBeTruthy(); + expect(connectorNameField.first().prop('value')).toBe('action-connector'); + }); +}); diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_edit_flyout.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_edit_flyout.tsx new file mode 100644 index 0000000000000..408989609d2ec --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_edit_flyout.tsx @@ -0,0 +1,68 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import React, { useCallback } from 'react'; +import { FormattedMessage } from '@kbn/i18n/react'; +import { + EuiTitle, + EuiFlyoutHeader, + EuiFlyout, + EuiFlexGroup, + EuiFlexItem, + EuiIcon, +} from '@elastic/eui'; +import { useActionsConnectorsContext } from '../../context/actions_connectors_context'; +import { ActionConnectorForm } from './action_connector_form'; +import { useAppDependencies } from '../../app_context'; +import { ActionConnectorTableItem } from '../../../types'; + +export interface ConnectorEditProps { + connector: ActionConnectorTableItem; +} + +export const ConnectorEditFlyout = ({ connector }: ConnectorEditProps) => { + const { actionTypeRegistry } = useAppDependencies(); + const { editFlyoutVisible, setEditFlyoutVisibility } = useActionsConnectorsContext(); + const closeFlyout = useCallback(() => setEditFlyoutVisibility(false), [setEditFlyoutVisibility]); + + if (!editFlyoutVisible) { + return null; + } + + const actionTypeModel = actionTypeRegistry.get(connector.actionTypeId); + + return ( + + + + {actionTypeModel ? ( + + + + ) : null} + + +

+ +

+
+
+
+
+ +
+ ); +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_reducer.test.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_reducer.test.ts new file mode 100644 index 0000000000000..df7e5d8fe9a78 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_reducer.test.ts @@ -0,0 +1,91 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import { connectorReducer } from './connector_reducer'; +import { ActionConnector } from '../../../types'; + +describe('connector reducer', () => { + let initialConnector: ActionConnector; + beforeAll(() => { + initialConnector = { + secrets: {}, + id: 'test', + actionTypeId: 'test-action-type-id', + name: 'action-connector', + referencedByCount: 0, + config: {}, + }; + }); + + test('if property name was changed', () => { + const updatedConnector = connectorReducer( + { connector: initialConnector }, + { + command: { type: 'setProperty' }, + payload: { + key: 'name', + value: 'new name', + }, + } + ); + expect(updatedConnector.connector.name).toBe('new name'); + }); + + test('if config property was added and updated', () => { + const updatedConnector = connectorReducer( + { connector: initialConnector }, + { + command: { type: 'setConfigProperty' }, + payload: { + key: 'testConfig', + value: 'new test config property', + }, + } + ); + expect(updatedConnector.connector.config.testConfig).toBe('new test config property'); + + const updatedConnectorUpdatedProperty = connectorReducer( + { connector: updatedConnector.connector }, + { + command: { type: 'setConfigProperty' }, + payload: { + key: 'testConfig', + value: 'test config property updated', + }, + } + ); + expect(updatedConnectorUpdatedProperty.connector.config.testConfig).toBe( + 'test config property updated' + ); + }); + + test('if secrets property was added', () => { + const updatedConnector = connectorReducer( + { connector: initialConnector }, + { + command: { type: 'setSecretsProperty' }, + payload: { + key: 'testSecret', + value: 'new test secret property', + }, + } + ); + expect(updatedConnector.connector.secrets.testSecret).toBe('new test secret property'); + + const updatedConnectorUpdatedProperty = connectorReducer( + { connector: updatedConnector.connector }, + { + command: { type: 'setSecretsProperty' }, + payload: { + key: 'testSecret', + value: 'test secret property updated', + }, + } + ); + expect(updatedConnectorUpdatedProperty.connector.secrets.testSecret).toBe( + 'test secret property updated' + ); + }); +}); diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_reducer.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_reducer.ts new file mode 100644 index 0000000000000..4a2610f965735 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/connector_reducer.ts @@ -0,0 +1,78 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import { isEqual } from 'lodash'; + +interface CommandType { + type: 'setProperty' | 'setConfigProperty' | 'setSecretsProperty'; +} + +export interface ActionState { + connector: any; +} + +export interface ReducerAction { + command: CommandType; + payload: { + key: string; + value: any; + }; +} + +export const connectorReducer = (state: ActionState, action: ReducerAction) => { + const { command, payload } = action; + const { connector } = state; + + switch (command.type) { + case 'setProperty': { + const { key, value } = payload; + if (isEqual(connector[key], value)) { + return state; + } else { + return { + ...state, + connector: { + ...connector, + [key]: value, + }, + }; + } + } + case 'setConfigProperty': { + const { key, value } = payload; + if (isEqual(connector.config[key], value)) { + return state; + } else { + return { + ...state, + connector: { + ...connector, + config: { + ...connector.config, + [key]: value, + }, + }, + }; + } + } + case 'setSecretsProperty': { + const { key, value } = payload; + if (isEqual(connector.secrets[key], value)) { + return state; + } else { + return { + ...state, + connector: { + ...connector, + secrets: { + ...connector.secrets, + [key]: value, + }, + }, + }; + } + } + } +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/index.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/index.ts new file mode 100644 index 0000000000000..aac7a514948d1 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/action_connector_form/index.ts @@ -0,0 +1,8 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export { ConnectorAddFlyout } from './connector_add_flyout'; +export { ConnectorEditFlyout } from './connector_edit_flyout'; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/actions_connectors_list/components/_index.scss b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/actions_connectors_list/components/_index.scss new file mode 100644 index 0000000000000..98c6c2a307a74 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/actions_connectors_list/components/_index.scss @@ -0,0 +1 @@ +@import 'actions_connectors_list'; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/actions_connectors_list/components/actions_connectors_list.scss b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/actions_connectors_list/components/actions_connectors_list.scss new file mode 100644 index 0000000000000..7a824aaeaa8d8 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/actions_connectors_list/components/actions_connectors_list.scss @@ -0,0 +1,3 @@ +.actConnectorsList__logo + .actConnectorsList__logo { + margin-left: $euiSize; +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/actions_connectors_list/components/actions_connectors_list.test.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/actions_connectors_list/components/actions_connectors_list.test.tsx new file mode 100644 index 0000000000000..511deb8cf3b0d --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/actions_connectors_list/components/actions_connectors_list.test.tsx @@ -0,0 +1,362 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import * as React from 'react'; +import { mountWithIntl } from 'test_utils/enzyme_helpers'; +import { ActionsConnectorsList } from './actions_connectors_list'; +import { coreMock } from '../../../../../../../../../../src/core/public/mocks'; +import { ReactWrapper } from 'enzyme'; +import { act } from 'react-dom/test-utils'; +import { actionTypeRegistryMock } from '../../../action_type_registry.mock'; +import { AppContextProvider } from '../../../app_context'; +jest.mock('../../../lib/action_connector_api', () => ({ + loadAllActions: jest.fn(), + loadActionTypes: jest.fn(), +})); + +const actionTypeRegistry = actionTypeRegistryMock.create(); + +describe('actions_connectors_list component empty', () => { + let wrapper: ReactWrapper; + + beforeAll(async () => { + const { loadAllActions, loadActionTypes } = jest.requireMock( + '../../../lib/action_connector_api' + ); + loadAllActions.mockResolvedValueOnce({ + page: 1, + perPage: 10000, + total: 0, + data: [], + }); + loadActionTypes.mockResolvedValueOnce([ + { + id: 'test', + name: 'Test', + }, + { + id: 'test2', + name: 'Test2', + }, + ]); + const mockes = coreMock.createSetup(); + const [{ chrome, docLinks }] = await mockes.getStartServices(); + const deps = { + chrome, + docLinks, + toastNotifications: mockes.notifications.toasts, + injectedMetadata: mockes.injectedMetadata, + http: mockes.http, + uiSettings: mockes.uiSettings, + legacy: { + capabilities: { + get() { + return { + siem: { + 'actions:show': true, + 'actions:save': true, + 'actions:delete': true, + }, + }; + }, + } as any, + MANAGEMENT_BREADCRUMB: { set: () => {} } as any, + }, + actionTypeRegistry: actionTypeRegistry as any, + alertTypeRegistry: {} as any, + }; + actionTypeRegistry.has.mockReturnValue(true); + + await act(async () => { + wrapper = mountWithIntl( + + + + ); + }); + + await waitForRender(wrapper); + }); + + it('renders empty prompt', () => { + expect(wrapper.find('EuiEmptyPrompt')).toHaveLength(1); + expect( + wrapper.find('[data-test-subj="createFirstActionButton"]').find('EuiButton') + ).toHaveLength(1); + }); + + test('if click create button should render ConnectorAddFlyout', () => { + wrapper + .find('[data-test-subj="createFirstActionButton"]') + .first() + .simulate('click'); + expect(wrapper.find('ConnectorAddFlyout')).toHaveLength(1); + }); +}); + +describe('actions_connectors_list component with items', () => { + let wrapper: ReactWrapper; + + beforeAll(async () => { + const { loadAllActions, loadActionTypes } = jest.requireMock( + '../../../lib/action_connector_api' + ); + loadAllActions.mockResolvedValueOnce({ + page: 1, + perPage: 10000, + total: 2, + data: [ + { + id: '1', + actionTypeId: 'test', + description: 'My test', + referencedByCount: 1, + config: {}, + }, + { + id: '2', + actionTypeId: 'test2', + description: 'My test 2', + referencedByCount: 1, + config: {}, + }, + ], + }); + loadActionTypes.mockResolvedValueOnce([ + { + id: 'test', + name: 'Test', + }, + { + id: 'test2', + name: 'Test2', + }, + ]); + + const mockes = coreMock.createSetup(); + const [{ chrome, docLinks }] = await mockes.getStartServices(); + const deps = { + chrome, + docLinks, + toastNotifications: mockes.notifications.toasts, + injectedMetadata: mockes.injectedMetadata, + http: mockes.http, + uiSettings: mockes.uiSettings, + legacy: { + capabilities: { + get() { + return { + siem: { + 'actions:show': true, + 'actions:save': true, + 'actions:delete': true, + }, + }; + }, + } as any, + MANAGEMENT_BREADCRUMB: { set: () => {} } as any, + }, + actionTypeRegistry: { + get() { + return null; + }, + } as any, + alertTypeRegistry: {} as any, + }; + + await act(async () => { + wrapper = mountWithIntl( + + + + ); + }); + + await waitForRender(wrapper); + + expect(loadAllActions).toHaveBeenCalled(); + }); + + it('renders table of connectors', () => { + expect(wrapper.find('EuiInMemoryTable')).toHaveLength(1); + expect(wrapper.find('EuiTableRow')).toHaveLength(2); + }); + + test('if select item for edit should render ConnectorEditFlyout', () => { + wrapper + .find('[data-test-subj="edit1"]') + .first() + .simulate('click'); + expect(wrapper.find('ConnectorEditFlyout')).toHaveLength(1); + }); +}); + +describe('actions_connectors_list component empty with show only capability', () => { + let wrapper: ReactWrapper; + + beforeAll(async () => { + const { loadAllActions, loadActionTypes } = jest.requireMock( + '../../../lib/action_connector_api' + ); + loadAllActions.mockResolvedValueOnce({ + page: 1, + perPage: 10000, + total: 0, + data: [], + }); + loadActionTypes.mockResolvedValueOnce([ + { + id: 'test', + name: 'Test', + }, + { + id: 'test2', + name: 'Test2', + }, + ]); + const mockes = coreMock.createSetup(); + const [{ chrome, docLinks }] = await mockes.getStartServices(); + const deps = { + chrome, + docLinks, + toastNotifications: mockes.notifications.toasts, + injectedMetadata: mockes.injectedMetadata, + http: mockes.http, + uiSettings: mockes.uiSettings, + legacy: { + capabilities: { + get() { + return { + siem: { + 'actions:show': true, + 'actions:save': false, + 'actions:delete': false, + }, + }; + }, + } as any, + MANAGEMENT_BREADCRUMB: { set: () => {} } as any, + }, + actionTypeRegistry: { + get() { + return null; + }, + } as any, + alertTypeRegistry: {} as any, + }; + + await act(async () => { + wrapper = mountWithIntl( + + + + ); + }); + + await waitForRender(wrapper); + }); + + it('renders no permissions to create connector', () => { + expect(wrapper.find('[defaultMessage="No permissions to create connector"]')).toHaveLength(1); + expect(wrapper.find('[data-test-subj="createActionButton"]')).toHaveLength(0); + }); +}); + +describe('actions_connectors_list with show only capability', () => { + let wrapper: ReactWrapper; + + beforeAll(async () => { + const { loadAllActions, loadActionTypes } = jest.requireMock( + '../../../lib/action_connector_api' + ); + loadAllActions.mockResolvedValueOnce({ + page: 1, + perPage: 10000, + total: 2, + data: [ + { + id: '1', + actionTypeId: 'test', + description: 'My test', + referencedByCount: 1, + config: {}, + }, + { + id: '2', + actionTypeId: 'test2', + description: 'My test 2', + referencedByCount: 1, + config: {}, + }, + ], + }); + loadActionTypes.mockResolvedValueOnce([ + { + id: 'test', + name: 'Test', + }, + { + id: 'test2', + name: 'Test2', + }, + ]); + const mockes = coreMock.createSetup(); + const [{ chrome, docLinks }] = await mockes.getStartServices(); + const deps = { + chrome, + docLinks, + toastNotifications: mockes.notifications.toasts, + injectedMetadata: mockes.injectedMetadata, + http: mockes.http, + uiSettings: mockes.uiSettings, + legacy: { + capabilities: { + get() { + return { + siem: { + 'actions:show': true, + 'actions:save': false, + 'actions:delete': false, + }, + }; + }, + } as any, + MANAGEMENT_BREADCRUMB: { set: () => {} } as any, + }, + actionTypeRegistry: { + get() { + return null; + }, + } as any, + alertTypeRegistry: {} as any, + }; + + await act(async () => { + wrapper = mountWithIntl( + + + + ); + }); + + await waitForRender(wrapper); + }); + + it('renders table of connectors with delete button disabled', () => { + expect(wrapper.find('EuiInMemoryTable')).toHaveLength(1); + expect(wrapper.find('EuiTableRow')).toHaveLength(2); + wrapper.find('EuiTableRow').forEach(elem => { + const deleteButton = elem.find('[data-test-subj="deleteConnector"]').first(); + expect(deleteButton).toBeTruthy(); + expect(deleteButton.prop('isDisabled')).toBeTruthy(); + }); + }); +}); + +async function waitForRender(wrapper: ReactWrapper) { + await Promise.resolve(); + await Promise.resolve(); + wrapper.update(); +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/actions_connectors_list/components/actions_connectors_list.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/actions_connectors_list/components/actions_connectors_list.tsx new file mode 100644 index 0000000000000..1990ffefdf84e --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/actions_connectors_list/components/actions_connectors_list.tsx @@ -0,0 +1,399 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React, { Fragment, useState, useEffect } from 'react'; +import { + EuiBadge, + EuiInMemoryTable, + EuiSpacer, + EuiButton, + EuiIcon, + EuiEmptyPrompt, + EuiTitle, + EuiLink, +} from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; +import { FormattedMessage } from '@kbn/i18n/react'; +import { ActionsConnectorsContextProvider } from '../../../context/actions_connectors_context'; +import { useAppDependencies } from '../../../app_context'; +import { loadAllActions, loadActionTypes } from '../../../lib/action_connector_api'; +import { ActionConnector, ActionConnectorTableItem, ActionTypeIndex } from '../../../../types'; +import { ConnectorAddFlyout, ConnectorEditFlyout } from '../../action_connector_form'; +import { hasDeleteActionsCapability, hasSaveActionsCapability } from '../../../lib/capabilities'; +import { DeleteConnectorsModal } from '../../../components/delete_connectors_modal'; + +export const ActionsConnectorsList: React.FunctionComponent = () => { + const { + http, + toastNotifications, + legacy: { capabilities }, + } = useAppDependencies(); + const canDelete = hasDeleteActionsCapability(capabilities.get()); + const canSave = hasSaveActionsCapability(capabilities.get()); + + const [actionTypesIndex, setActionTypesIndex] = useState(undefined); + const [actions, setActions] = useState([]); + const [data, setData] = useState([]); + const [selectedItems, setSelectedItems] = useState([]); + const [isLoadingActionTypes, setIsLoadingActionTypes] = useState(false); + const [isLoadingActions, setIsLoadingActions] = useState(false); + const [editFlyoutVisible, setEditFlyoutVisibility] = useState(false); + const [addFlyoutVisible, setAddFlyoutVisibility] = useState(false); + const [actionTypesList, setActionTypesList] = useState>( + [] + ); + const [editedConnectorItem, setEditedConnectorItem] = useState< + ActionConnectorTableItem | undefined + >(undefined); + const [connectorsToDelete, setConnectorsToDelete] = useState([]); + + useEffect(() => { + loadActions(); + // eslint-disable-next-line react-hooks/exhaustive-deps + }, []); + + useEffect(() => { + (async () => { + try { + setIsLoadingActionTypes(true); + const actionTypes = await loadActionTypes({ http }); + const index: ActionTypeIndex = {}; + for (const actionTypeItem of actionTypes) { + index[actionTypeItem.id] = actionTypeItem; + } + setActionTypesIndex(index); + } catch (e) { + toastNotifications.addDanger({ + title: i18n.translate( + 'xpack.triggersActionsUI.sections.actionsConnectorsList.unableToLoadActionTypesMessage', + { defaultMessage: 'Unable to load action types' } + ), + }); + } finally { + setIsLoadingActionTypes(false); + } + })(); + // eslint-disable-next-line react-hooks/exhaustive-deps + }, []); + + useEffect(() => { + // Avoid flickering before action types load + if (typeof actionTypesIndex === 'undefined') { + return; + } + // Update the data for the table + const updatedData = actions.map(action => { + return { + ...action, + actionType: actionTypesIndex[action.actionTypeId] + ? actionTypesIndex[action.actionTypeId].name + : action.actionTypeId, + }; + }); + setData(updatedData); + // Update the action types list for the filter + const actionTypes = Object.values(actionTypesIndex) + .map(actionType => ({ + value: actionType.id, + name: `${actionType.name} (${getActionsCountByActionType(actions, actionType.id)})`, + })) + .sort((a, b) => a.name.localeCompare(b.name)); + setActionTypesList(actionTypes); + }, [actions, actionTypesIndex]); + + async function loadActions() { + setIsLoadingActions(true); + try { + const actionsResponse = await loadAllActions({ http }); + setActions(actionsResponse.data); + } catch (e) { + toastNotifications.addDanger({ + title: i18n.translate( + 'xpack.triggersActionsUI.sections.actionsConnectorsList.unableToLoadActionsMessage', + { + defaultMessage: 'Unable to load actions', + } + ), + }); + } finally { + setIsLoadingActions(false); + } + } + + async function editItem(connectorTableItem: ActionConnectorTableItem) { + setEditedConnectorItem(connectorTableItem); + setEditFlyoutVisibility(true); + } + + const actionsTableColumns = [ + { + field: 'name', + 'data-test-subj': 'connectorsTableCell-name', + name: i18n.translate( + 'xpack.triggersActionsUI.sections.actionsConnectorsList.connectorsListTable.columns.nameTitle', + { + defaultMessage: 'Name', + } + ), + sortable: false, + truncateText: true, + render: (value: string, item: ActionConnectorTableItem) => { + return ( + editItem(item)} key={item.id}> + {value} + + ); + }, + }, + { + field: 'actionType', + 'data-test-subj': 'connectorsTableCell-actionType', + name: i18n.translate( + 'xpack.triggersActionsUI.sections.actionsConnectorsList.connectorsListTable.columns.actionTypeTitle', + { + defaultMessage: 'Type', + } + ), + sortable: false, + truncateText: true, + }, + { + field: 'referencedByCount', + 'data-test-subj': 'connectorsTableCell-referencedByCount', + name: i18n.translate( + 'xpack.triggersActionsUI.sections.actionsConnectorsList.connectorsListTable.columns.referencedByCountTitle', + { defaultMessage: 'Actions' } + ), + sortable: false, + truncateText: true, + render: (value: number, item: ActionConnectorTableItem) => { + return ( + + {value} + + ); + }, + }, + { + field: '', + name: '', + actions: [ + { + enabled: () => canDelete, + 'data-test-subj': 'deleteConnector', + name: i18n.translate( + 'xpack.triggersActionsUI.sections.actionsConnectorsList.connectorsListTable.columns.actions.deleteActionName', + { defaultMessage: 'Delete' } + ), + description: canDelete + ? i18n.translate( + 'xpack.triggersActionsUI.sections.actionsConnectorsList.connectorsListTable.columns.actions.deleteActionDescription', + { defaultMessage: 'Delete this action' } + ) + : i18n.translate( + 'xpack.triggersActionsUI.sections.actionsConnectorsList.connectorsListTable.columns.actions.deleteActionDisabledDescription', + { defaultMessage: 'Unable to delete actions' } + ), + type: 'icon', + icon: 'trash', + color: 'danger', + onClick: (item: ActionConnectorTableItem) => setConnectorsToDelete([item.id]), + }, + ], + }, + ]; + + const table = ( + ({ + 'data-test-subj': 'connectors-row', + })} + cellProps={() => ({ + 'data-test-subj': 'cell', + })} + data-test-subj="actionsTable" + pagination={true} + selection={ + canDelete + ? { + onSelectionChange(updatedSelectedItemsList: ActionConnectorTableItem[]) { + setSelectedItems(updatedSelectedItemsList); + }, + } + : undefined + } + search={{ + filters: [ + { + type: 'field_value_selection', + field: 'actionTypeId', + name: i18n.translate( + 'xpack.triggersActionsUI.sections.actionsConnectorsList.filters.actionTypeIdName', + { defaultMessage: 'Type' } + ), + multiSelect: 'or', + options: actionTypesList, + }, + ], + toolsLeft: + selectedItems.length === 0 || !canDelete + ? [] + : [ + { + setConnectorsToDelete(selectedItems.map((selected: any) => selected.id)); + }} + title={ + canDelete + ? undefined + : i18n.translate( + 'xpack.triggersActionsUI.sections.actionsConnectorsList.buttons.deleteDisabledTitle', + { defaultMessage: 'Unable to delete actions' } + ) + } + > + + , + ], + toolsRight: [ + setAddFlyoutVisibility(true)} + > + + , + ], + }} + /> + ); + + const emptyPrompt = ( + + + + + + +

+ +

+
+
+ } + body={ +

+ +

+ } + actions={ + setAddFlyoutVisibility(true)} + > + + + } + /> + ); + + const noPermissionPrompt = ( +

+ +

+ ); + + return ( +
+ { + if (deleted) { + if (selectedItems.length === 0 || selectedItems.length === deleted.length) { + const updatedActions = actions.filter( + action => action.id && !connectorsToDelete.includes(action.id) + ); + setActions(updatedActions); + setSelectedItems([]); + } else { + toastNotifications.addDanger({ + title: i18n.translate( + 'xpack.triggersActionsUI.sections.actionsConnectorsList.failedToDeleteActionsMessage', + { defaultMessage: 'Failed to delete action(s)' } + ), + }); + // Refresh the actions from the server, some actions may have beend deleted + loadActions(); + } + } + setConnectorsToDelete([]); + }} + connectorsToDelete={connectorsToDelete} + /> + + {/* Render the view based on if there's data or if they can save */} + {data.length !== 0 && table} + {data.length === 0 && canSave && emptyPrompt} + {data.length === 0 && !canSave && noPermissionPrompt} + + + {editedConnectorItem ? : null} + +
+ ); +}; + +function getActionsCountByActionType(actions: ActionConnector[], actionTypeId: string) { + return actions.filter(action => action.actionTypeId === actionTypeId).length; +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alert_add/alert_add.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alert_add/alert_add.tsx new file mode 100644 index 0000000000000..9380392112c8e --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alert_add/alert_add.tsx @@ -0,0 +1,803 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import React, { Fragment, useState, useCallback, useReducer, useEffect } from 'react'; +import { i18n } from '@kbn/i18n'; +import { FormattedMessage } from '@kbn/i18n/react'; +import { + EuiButton, + EuiFlexGroup, + EuiFlexItem, + EuiIcon, + EuiTitle, + EuiForm, + EuiSpacer, + EuiButtonEmpty, + EuiFlyoutFooter, + EuiFlyoutBody, + EuiFlyoutHeader, + EuiFlyout, + EuiFieldText, + EuiFlexGrid, + EuiFormRow, + EuiComboBox, + EuiKeyPadMenuItem, + EuiTabs, + EuiTab, + EuiLink, + EuiFieldNumber, + EuiSelect, + EuiIconTip, + EuiPortal, + EuiAccordion, + EuiButtonIcon, +} from '@elastic/eui'; +import { useAppDependencies } from '../../app_context'; +import { createAlert } from '../../lib/alert_api'; +import { loadActionTypes, loadAllActions } from '../../lib/action_connector_api'; +import { useAlertsContext } from '../../context/alerts_context'; +import { alertReducer } from './alert_reducer'; +import { + AlertTypeModel, + Alert, + IErrorObject, + ActionTypeModel, + AlertAction, + ActionTypeIndex, + ActionConnector, +} from '../../../types'; +import { ACTION_GROUPS } from '../../constants/action_groups'; +import { getTimeOptions } from '../../lib/get_time_options'; +import { SectionLoading } from '../../components/section_loading'; + +interface Props { + refreshList: () => Promise; +} + +function validateBaseProperties(alertObject: Alert) { + const validationResult = { errors: {} }; + const errors = { + name: new Array(), + interval: new Array(), + alertTypeId: new Array(), + actionConnectors: new Array(), + }; + validationResult.errors = errors; + if (!alertObject.name) { + errors.name.push( + i18n.translate('xpack.triggersActionsUI.sections.alertAdd.error.requiredNameText', { + defaultMessage: 'Name is required.', + }) + ); + } + if (!alertObject.interval) { + errors.interval.push( + i18n.translate('xpack.triggersActionsUI.sections.alertAdd.error.requiredIntervalText', { + defaultMessage: 'Check interval is required.', + }) + ); + } + if (!alertObject.alertTypeId) { + errors.alertTypeId.push( + i18n.translate('xpack.triggersActionsUI.sections.alertAdd.error.requiredAlertTypeIdText', { + defaultMessage: 'Alert trigger is required.', + }) + ); + } + return validationResult; +} + +export const AlertAdd = ({ refreshList }: Props) => { + const { http, toastNotifications, alertTypeRegistry, actionTypeRegistry } = useAppDependencies(); + const initialAlert = { + params: {}, + alertTypeId: null, + interval: '1m', + actions: [], + tags: [], + }; + + const { alertFlyoutVisible, setAlertFlyoutVisibility } = useAlertsContext(); + // hooks + const [alertType, setAlertType] = useState(undefined); + const [{ alert }, dispatch] = useReducer(alertReducer, { alert: initialAlert }); + const [isSaving, setIsSaving] = useState(false); + const [isLoadingActionTypes, setIsLoadingActionTypes] = useState(false); + const [selectedTabId, setSelectedTabId] = useState('alert'); + const [actionTypesIndex, setActionTypesIndex] = useState(undefined); + const [alertInterval, setAlertInterval] = useState(null); + const [alertIntervalUnit, setAlertIntervalUnit] = useState('m'); + const [alertThrottle, setAlertThrottle] = useState(null); + const [alertThrottleUnit, setAlertThrottleUnit] = useState(''); + const [serverError, setServerError] = useState<{ + body: { message: string; error: string }; + } | null>(null); + const [isAddActionPanelOpen, setIsAddActionPanelOpen] = useState(true); + const [connectors, setConnectors] = useState([]); + + useEffect(() => { + (async () => { + try { + setIsLoadingActionTypes(true); + const actionTypes = await loadActionTypes({ http }); + const index: ActionTypeIndex = {}; + for (const actionTypeItem of actionTypes) { + index[actionTypeItem.id] = actionTypeItem; + } + setActionTypesIndex(index); + } catch (e) { + toastNotifications.addDanger({ + title: i18n.translate( + 'xpack.triggersActionsUI.sections.alertAdd.unableToLoadActionTypesMessage', + { defaultMessage: 'Unable to load action types' } + ), + }); + } finally { + setIsLoadingActionTypes(false); + } + })(); + }, [toastNotifications, http]); + + useEffect(() => { + dispatch({ + command: { type: 'setAlert' }, + payload: { + key: 'alert', + value: { + params: {}, + alertTypeId: null, + interval: '1m', + actions: [], + tags: [], + }, + }, + }); + }, [alertFlyoutVisible]); + + useEffect(() => { + loadConnectors(); + // eslint-disable-next-line react-hooks/exhaustive-deps + }, [alertFlyoutVisible]); + + const setAlertProperty = (key: string, value: any) => { + dispatch({ command: { type: 'setProperty' }, payload: { key, value } }); + }; + + const setAlertParams = (key: string, value: any) => { + dispatch({ command: { type: 'setAlertParams' }, payload: { key, value } }); + }; + + const setActionParamsProperty = (key: string, value: any, index: number) => { + dispatch({ command: { type: 'setAlertActionParams' }, payload: { key, value, index } }); + }; + + const setActionProperty = (key: string, value: any, index: number) => { + dispatch({ command: { type: 'setAlertActionProperty' }, payload: { key, value, index } }); + }; + + const closeFlyout = useCallback(() => { + setAlertFlyoutVisibility(false); + setAlertType(undefined); + setIsAddActionPanelOpen(true); + setSelectedTabId('alert'); + setServerError(null); + }, [setAlertFlyoutVisibility]); + + if (!alertFlyoutVisible) { + return null; + } + + const tagsOptions = alert.tags ? alert.tags.map((label: string) => ({ label })) : []; + + async function loadConnectors() { + try { + const actionsResponse = await loadAllActions({ http }); + setConnectors(actionsResponse.data); + } catch (e) { + toastNotifications.addDanger({ + title: i18n.translate( + 'xpack.triggersActionsUI.sections.alertAdd.unableToLoadActionsMessage', + { + defaultMessage: 'Unable to load connectors', + } + ), + }); + } + } + + const AlertParamsExpressionComponent = alertType ? alertType.alertParamsExpression : null; + + const errors = { + ...(alertType ? alertType.validate(alert).errors : []), + ...validateBaseProperties(alert).errors, + } as IErrorObject; + const hasErrors = !!Object.keys(errors).find(errorKey => errors[errorKey].length >= 1); + + const actionErrors = alert.actions.reduce((acc: any, alertAction: AlertAction) => { + const actionTypeConnectors = connectors.find(field => field.id === alertAction.id); + if (!actionTypeConnectors) { + return []; + } + const actionType = actionTypeRegistry.get(actionTypeConnectors.actionTypeId); + if (!actionType) { + return []; + } + const actionValidationErrors = actionType.validateParams(alertAction.params); + acc[alertAction.id] = actionValidationErrors; + return acc; + }, {}); + + const hasActionErrors = !!Object.keys(actionErrors).find(actionError => { + return !!Object.keys(actionErrors[actionError]).find((actionErrorKey: string) => { + return actionErrors[actionError][actionErrorKey].length >= 1; + }); + }); + + const tabs = [ + { + id: ACTION_GROUPS.ALERT, + name: i18n.translate('xpack.triggersActionsUI.sections.alertAdd.alertTabText', { + defaultMessage: 'Alert', + }), + }, + { + id: ACTION_GROUPS.WARNING, + name: i18n.translate('xpack.triggersActionsUI.sections.alertAdd.warningTabText', { + defaultMessage: 'Warning', + }), + }, + { + id: ACTION_GROUPS.UNACKNOWLEDGED, + name: i18n.translate('xpack.triggersActionsUI.sections.alertAdd.unacknowledgedTabText', { + defaultMessage: 'If unacknowledged', + }), + disabled: false, + }, + ]; + + async function onSaveAlert(): Promise { + try { + const newAlert = await createAlert({ http, alert }); + toastNotifications.addSuccess( + i18n.translate('xpack.triggersActionsUI.sections.alertAdd.saveSuccessNotificationText', { + defaultMessage: "Saved '{alertName}'", + values: { + alertName: newAlert.id, + }, + }) + ); + return newAlert; + } catch (error) { + return { + error, + }; + } + } + + function addActionType(actionTypeModel: ActionTypeModel) { + setIsAddActionPanelOpen(false); + const actionTypeConnectors = connectors.filter( + field => field.actionTypeId === actionTypeModel.id + ); + if (actionTypeConnectors.length > 0) { + alert.actions.push({ id: actionTypeConnectors[0].id, group: selectedTabId, params: {} }); + } + } + + const alertTypeNodes = alertTypeRegistry.list().map(function(item, index) { + return ( + { + setAlertProperty('alertTypeId', item.id); + setAlertType(item); + }} + > + + + ); + }); + + const actionTypeNodes = actionTypeRegistry.list().map(function(item, index) { + return ( + addActionType(item)} + > + + + ); + }); + + const alertTabs = tabs.map(function(tab, index): any { + return ( + { + setSelectedTabId(tab.id); + if (!alert.actions.find((action: AlertAction) => action.group === tab.id)) { + setIsAddActionPanelOpen(true); + } else { + setIsAddActionPanelOpen(false); + } + }} + isSelected={tab.id === selectedTabId} + disabled={tab.disabled} + key={index} + > + {tab.name} + + ); + }); + + const alertTypeDetails = ( + + + + +
+ +
+
+
+ + { + setAlertProperty('alertTypeId', null); + setAlertType(undefined); + }} + > + + + +
+ {AlertParamsExpressionComponent ? ( + + ) : null} +
+ ); + + const getSelectedOptions = (actionItemId: string) => { + const val = connectors.find(connector => connector.id === actionItemId); + if (!val) { + return []; + } + return [ + { + label: val.name, + value: val.name, + id: actionItemId, + }, + ]; + }; + + const actionsListForGroup = ( + + {alert.actions.map((actionItem: AlertAction, index: number) => { + const actionConnector = connectors.find(field => field.id === actionItem.id); + if (!actionConnector) { + return null; + } + const optionsList = connectors + .filter(field => field.actionTypeId === actionConnector.actionTypeId) + .map(({ name, id }) => ({ + label: name, + key: id, + id, + })); + const actionTypeRegisterd = actionTypeRegistry.get(actionConnector.actionTypeId); + if (actionTypeRegisterd === null || actionItem.group !== selectedTabId) return null; + const ParamsFieldsComponent = actionTypeRegisterd.actionParamsFields; + const actionParamsErrors = + Object.keys(actionErrors).length > 0 ? actionErrors[actionItem.id] : []; + const hasActionParamsErrors = !!Object.keys(actionParamsErrors).find( + errorKey => actionParamsErrors[errorKey].length >= 1 + ); + return ( + + + + + + +
+ +
+
+
+ + } + extraAction={ + { + const updatedActions = alert.actions.filter( + (item: AlertAction) => item.id !== actionItem.id + ); + setAlertProperty('actions', updatedActions); + }} + /> + } + paddingSize="l" + > + + } + // errorKey="name" + // isShowingErrors={hasErrors} + // errors={errors} + > + { + setActionProperty('id', selectedOptions[0].id, index); + }} + isClearable={false} + /> + + + {ParamsFieldsComponent ? ( + + ) : null} +
+ ); + })} + + {!isAddActionPanelOpen ? ( + setIsAddActionPanelOpen(true)} + > + + + ) : null} +
+ ); + + let alertTypeArea; + if (alertType) { + alertTypeArea = {alertTypeDetails}; + } else { + alertTypeArea = ( + + +
+ +
+
+ + + {alertTypeNodes} + +
+ ); + } + + const labelForAlertChecked = ( + <> + {' '} + + + ); + + const labelForAlertRenotify = ( + <> + {' '} + + + ); + + return ( + + + + +

+ +

+
+
+ + + + + + } + isInvalid={hasErrors && alert.name !== undefined} + error={errors.name} + > + { + setAlertProperty('name', e.target.value); + }} + onBlur={() => { + if (!alert.name) { + setAlertProperty('name', ''); + } + }} + /> + + + + + { + const newOptions = [...tagsOptions, { label: searchValue }]; + setAlertProperty( + 'tags', + newOptions.map(newOption => newOption.label) + ); + }} + onChange={(selectedOptions: Array<{ label: string }>) => { + setAlertProperty( + 'tags', + selectedOptions.map(selectedOption => selectedOption.label) + ); + }} + onBlur={() => { + if (!alert.tags) { + setAlertProperty('tags', []); + } + }} + /> + + + + + + + + + + { + const interval = + e.target.value !== '' ? parseInt(e.target.value, 10) : null; + setAlertInterval(interval); + setAlertProperty('interval', `${e.target.value}${alertIntervalUnit}`); + }} + /> + + + { + setAlertIntervalUnit(e.target.value); + setAlertProperty('interval', `${alertInterval}${e.target.value}`); + }} + /> + + + + + + + + + { + const throttle = + e.target.value !== '' ? parseInt(e.target.value, 10) : null; + setAlertThrottle(throttle); + setAlertProperty('throttle', `${e.target.value}${alertThrottleUnit}`); + }} + /> + + + { + setAlertThrottleUnit(e.target.value); + setAlertProperty('throttle', `${alertThrottle}${e.target.value}`); + }} + /> + + + + + + + {alertTabs} + + {alertTypeArea} + + {actionsListForGroup} + {isAddActionPanelOpen ? ( + + +
+ +
+
+ + + {isLoadingActionTypes ? ( + + + + ) : ( + actionTypeNodes + )} + +
+ ) : null} +
+
+ + + + + {i18n.translate('xpack.triggersActionsUI.sections.alertAdd.cancelButtonLabel', { + defaultMessage: 'Cancel', + })} + + + + { + setIsSaving(true); + const savedAlert = await onSaveAlert(); + setIsSaving(false); + if (savedAlert && savedAlert.error) { + return setServerError(savedAlert.error); + } + closeFlyout(); + refreshList(); + }} + > + + + + + +
+
+ ); +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alert_add/alert_reducer.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alert_add/alert_reducer.ts new file mode 100644 index 0000000000000..9c2260f0178be --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alert_add/alert_reducer.ts @@ -0,0 +1,121 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import { isEqual } from 'lodash'; + +interface CommandType { + type: + | 'setAlert' + | 'setProperty' + | 'setAlertParams' + | 'setAlertActionParams' + | 'setAlertActionProperty'; +} + +export interface AlertState { + alert: any; +} + +export interface AlertReducerAction { + command: CommandType; + payload: { + key: string; + value: {}; + index?: number; + }; +} + +export const alertReducer = (state: any, action: AlertReducerAction) => { + const { command, payload } = action; + const { alert } = state; + + switch (command.type) { + case 'setAlert': { + const { key, value } = payload; + if (key === 'alert') { + return { + ...state, + alert: value, + }; + } else { + return state; + } + } + case 'setProperty': { + const { key, value } = payload; + if (isEqual(alert[key], value)) { + return state; + } else { + return { + ...state, + alert: { + ...alert, + [key]: value, + }, + }; + } + } + case 'setAlertParams': { + const { key, value } = payload; + if (isEqual(alert.params[key], value)) { + return state; + } else { + return { + ...state, + alert: { + ...alert, + params: { + ...alert.params, + [key]: value, + }, + }, + }; + } + } + case 'setAlertActionParams': { + const { key, value, index } = payload; + if (index === undefined || isEqual(alert.actions[index][key], value)) { + return state; + } else { + const oldAction = alert.actions.splice(index, 1)[0]; + const updatedAction = { + ...oldAction, + params: { + ...oldAction.params, + [key]: value, + }, + }; + alert.actions.splice(index, 0, updatedAction); + return { + ...state, + alert: { + ...alert, + actions: [...alert.actions], + }, + }; + } + } + case 'setAlertActionProperty': { + const { key, value, index } = payload; + if (index === undefined || isEqual(alert.actions[index][key], value)) { + return state; + } else { + const oldAction = alert.actions.splice(index, 1)[0]; + const updatedAction = { + ...oldAction, + [key]: value, + }; + alert.actions.splice(index, 0, updatedAction); + return { + ...state, + alert: { + ...alert, + actions: [...alert.actions], + }, + }; + } + } + } +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alert_add/index.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alert_add/index.ts new file mode 100644 index 0000000000000..f88a8bb1c49d0 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alert_add/index.ts @@ -0,0 +1,7 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export { AlertAdd } from './alert_add'; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/action_type_filter.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/action_type_filter.tsx new file mode 100644 index 0000000000000..7a25a241b0162 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/action_type_filter.tsx @@ -0,0 +1,72 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React, { useEffect, useState } from 'react'; +import { FormattedMessage } from '@kbn/i18n/react'; +import { EuiFilterGroup, EuiPopover, EuiFilterButton, EuiFilterSelectItem } from '@elastic/eui'; +import { ActionType } from '../../../../types'; + +interface ActionTypeFilterProps { + actionTypes: ActionType[]; + onChange?: (selectedActionTypeIds: string[]) => void; +} + +export const ActionTypeFilter: React.FunctionComponent = ({ + actionTypes, + onChange, +}: ActionTypeFilterProps) => { + const [selectedValues, setSelectedValues] = useState([]); + const [isPopoverOpen, setIsPopoverOpen] = useState(false); + + useEffect(() => { + if (onChange) { + onChange(selectedValues); + } + // eslint-disable-next-line react-hooks/exhaustive-deps + }, [selectedValues]); + + return ( + + setIsPopoverOpen(false)} + button={ + 0} + numActiveFilters={selectedValues.length} + numFilters={selectedValues.length} + onClick={() => setIsPopoverOpen(!isPopoverOpen)} + > + + + } + > +
+ {actionTypes.map(item => ( + { + const isPreviouslyChecked = selectedValues.includes(item.id); + if (isPreviouslyChecked) { + setSelectedValues(selectedValues.filter(val => val !== item.id)); + } else { + setSelectedValues(selectedValues.concat(item.id)); + } + }} + checked={selectedValues.includes(item.id) ? 'on' : undefined} + > + {item.name} + + ))} +
+
+
+ ); +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/alerts_list.test.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/alerts_list.test.tsx new file mode 100644 index 0000000000000..8f8aef5a16bd5 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/alerts_list.test.tsx @@ -0,0 +1,453 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import * as React from 'react'; +import { mountWithIntl } from 'test_utils/enzyme_helpers'; +import { coreMock } from '../../../../../../../../../../src/core/public/mocks'; +import { ReactWrapper } from 'enzyme'; +import { act } from 'react-dom/test-utils'; +import { actionTypeRegistryMock } from '../../../action_type_registry.mock'; +import { alertTypeRegistryMock } from '../../../alert_type_registry.mock'; +import { AlertsList } from './alerts_list'; +import { ValidationResult } from '../../../../types'; +import { AppContextProvider } from '../../../app_context'; +jest.mock('../../../lib/action_connector_api', () => ({ + loadActionTypes: jest.fn(), + loadAllActions: jest.fn(), +})); +jest.mock('../../../lib/alert_api', () => ({ + loadAlerts: jest.fn(), + loadAlertTypes: jest.fn(), +})); + +const actionTypeRegistry = actionTypeRegistryMock.create(); +const alertTypeRegistry = alertTypeRegistryMock.create(); + +const alertType = { + id: 'test_alert_type', + name: 'some alert type', + iconClass: 'test', + validate: (): ValidationResult => { + return { errors: {} }; + }, + alertParamsExpression: () => null, +}; +alertTypeRegistry.list.mockReturnValue([alertType]); +actionTypeRegistry.list.mockReturnValue([]); + +describe('alerts_list component empty', () => { + let wrapper: ReactWrapper; + + beforeEach(async () => { + const { loadAlerts, loadAlertTypes } = jest.requireMock('../../../lib/alert_api'); + const { loadActionTypes, loadAllActions } = jest.requireMock( + '../../../lib/action_connector_api' + ); + loadAlerts.mockResolvedValue({ + page: 1, + perPage: 10000, + total: 0, + data: [], + }); + loadActionTypes.mockResolvedValue([ + { + id: 'test', + name: 'Test', + }, + { + id: 'test2', + name: 'Test2', + }, + ]); + loadAlertTypes.mockResolvedValue([{ id: 'test_alert_type', name: 'some alert type' }]); + loadAllActions.mockResolvedValue({ + page: 1, + perPage: 10000, + total: 0, + data: [], + }); + + const mockes = coreMock.createSetup(); + const [{ chrome, docLinks }] = await mockes.getStartServices(); + const deps = { + chrome, + docLinks, + toastNotifications: mockes.notifications.toasts, + injectedMetadata: { + getInjectedVar(name: string) { + if (name === 'createAlertUiEnabled') { + return true; + } + }, + } as any, + http: mockes.http, + uiSettings: mockes.uiSettings, + legacy: { + capabilities: { + get() { + return { + siem: { + 'alerting:show': true, + 'alerting:save': true, + 'alerting:delete': true, + }, + }; + }, + } as any, + MANAGEMENT_BREADCRUMB: { set: () => {} } as any, + }, + actionTypeRegistry: actionTypeRegistry as any, + alertTypeRegistry: alertTypeRegistry as any, + }; + + await act(async () => { + wrapper = mountWithIntl( + + + + ); + }); + + await waitForRender(wrapper); + }); + + it('renders empty list', () => { + expect(wrapper.find('[data-test-subj="createAlertButton"]').find('EuiButton')).toHaveLength(1); + }); + + test('if click create button should render AlertAdd', () => { + wrapper + .find('[data-test-subj="createAlertButton"]') + .first() + .simulate('click'); + expect(wrapper.find('AlertAdd')).toHaveLength(1); + }); +}); + +describe('alerts_list component with items', () => { + let wrapper: ReactWrapper; + + beforeEach(async () => { + const { loadAlerts, loadAlertTypes } = jest.requireMock('../../../lib/alert_api'); + const { loadActionTypes, loadAllActions } = jest.requireMock( + '../../../lib/action_connector_api' + ); + loadAlerts.mockResolvedValue({ + page: 1, + perPage: 10000, + total: 2, + data: [ + { + id: '1', + name: 'test alert', + tags: ['tag1'], + enabled: true, + alertTypeId: 'test_alert_type', + interval: '5d', + actions: [], + params: { name: 'test alert type name' }, + scheduledTaskId: null, + createdBy: null, + updatedBy: null, + apiKeyOwner: null, + throttle: '1m', + muteAll: false, + mutedInstanceIds: [], + }, + { + id: '2', + name: 'test alert 2', + tags: ['tag1'], + enabled: true, + alertTypeId: 'test_alert_type', + interval: '5d', + actions: [{ id: 'test', group: 'alert', params: { message: 'test' } }], + params: { name: 'test alert type name' }, + scheduledTaskId: null, + createdBy: null, + updatedBy: null, + apiKeyOwner: null, + throttle: '1m', + muteAll: false, + mutedInstanceIds: [], + }, + ], + }); + loadActionTypes.mockResolvedValue([ + { + id: 'test', + name: 'Test', + }, + { + id: 'test2', + name: 'Test2', + }, + ]); + loadAlertTypes.mockResolvedValue([{ id: 'test_alert_type', name: 'some alert type' }]); + loadAllActions.mockResolvedValue({ + page: 1, + perPage: 10000, + total: 0, + data: [], + }); + const mockes = coreMock.createSetup(); + const [{ chrome, docLinks }] = await mockes.getStartServices(); + const deps = { + chrome, + docLinks, + toastNotifications: mockes.notifications.toasts, + injectedMetadata: { + getInjectedVar(name: string) { + if (name === 'createAlertUiEnabled') { + return true; + } + }, + } as any, + http: mockes.http, + uiSettings: mockes.uiSettings, + legacy: { + capabilities: { + get() { + return { + siem: { + 'alerting:show': true, + 'alerting:save': true, + 'alerting:delete': true, + }, + }; + }, + } as any, + MANAGEMENT_BREADCRUMB: { set: () => {} } as any, + }, + actionTypeRegistry: actionTypeRegistry as any, + alertTypeRegistry: alertTypeRegistry as any, + }; + + await act(async () => { + wrapper = mountWithIntl( + + + + ); + }); + + await waitForRender(wrapper); + + expect(loadAlerts).toHaveBeenCalled(); + expect(loadActionTypes).toHaveBeenCalled(); + }); + + it('renders table of connectors', () => { + expect(wrapper.find('EuiBasicTable')).toHaveLength(1); + expect(wrapper.find('EuiTableRow')).toHaveLength(2); + }); +}); + +describe('alerts_list component empty with show only capability', () => { + let wrapper: ReactWrapper; + + beforeEach(async () => { + const { loadAlerts, loadAlertTypes } = jest.requireMock('../../../lib/alert_api'); + const { loadActionTypes, loadAllActions } = jest.requireMock( + '../../../lib/action_connector_api' + ); + loadAlerts.mockResolvedValue({ + page: 1, + perPage: 10000, + total: 0, + data: [], + }); + loadActionTypes.mockResolvedValue([ + { + id: 'test', + name: 'Test', + }, + { + id: 'test2', + name: 'Test2', + }, + ]); + loadAlertTypes.mockResolvedValue([{ id: 'test_alert_type', name: 'some alert type' }]); + loadAllActions.mockResolvedValue({ + page: 1, + perPage: 10000, + total: 0, + data: [], + }); + const mockes = coreMock.createSetup(); + const [{ chrome, docLinks }] = await mockes.getStartServices(); + const deps = { + chrome, + docLinks, + toastNotifications: mockes.notifications.toasts, + injectedMetadata: { + getInjectedVar(name: string) { + if (name === 'createAlertUiEnabled') { + return true; + } + }, + } as any, + http: mockes.http, + uiSettings: mockes.uiSettings, + legacy: { + capabilities: { + get() { + return { + siem: { + 'alerting:show': true, + 'alerting:save': false, + 'alerting:delete': false, + }, + }; + }, + } as any, + MANAGEMENT_BREADCRUMB: { set: () => {} } as any, + }, + actionTypeRegistry: { + get() { + return null; + }, + } as any, + alertTypeRegistry: {} as any, + }; + + await act(async () => { + wrapper = mountWithIntl( + + + + ); + }); + + await waitForRender(wrapper); + }); + + it('not renders create alert button', () => { + expect(wrapper.find('[data-test-subj="createAlertButton"]')).toHaveLength(0); + }); +}); + +describe('alerts_list with show only capability', () => { + let wrapper: ReactWrapper; + + beforeEach(async () => { + const { loadAlerts, loadAlertTypes } = jest.requireMock('../../../lib/alert_api'); + const { loadActionTypes, loadAllActions } = jest.requireMock( + '../../../lib/action_connector_api' + ); + loadAlerts.mockResolvedValue({ + page: 1, + perPage: 10000, + total: 2, + data: [ + { + id: '1', + name: 'test alert', + tags: ['tag1'], + enabled: true, + alertTypeId: 'test_alert_type', + interval: '5d', + actions: [], + params: { name: 'test alert type name' }, + scheduledTaskId: null, + createdBy: null, + updatedBy: null, + apiKeyOwner: null, + throttle: '1m', + muteAll: false, + mutedInstanceIds: [], + }, + { + id: '2', + name: 'test alert 2', + tags: ['tag1'], + enabled: true, + alertTypeId: 'test_alert_type', + interval: '5d', + actions: [{ id: 'test', group: 'alert', params: { message: 'test' } }], + params: { name: 'test alert type name' }, + scheduledTaskId: null, + createdBy: null, + updatedBy: null, + apiKeyOwner: null, + throttle: '1m', + muteAll: false, + mutedInstanceIds: [], + }, + ], + }); + loadActionTypes.mockResolvedValue([ + { + id: 'test', + name: 'Test', + }, + { + id: 'test2', + name: 'Test2', + }, + ]); + loadAlertTypes.mockResolvedValue([{ id: 'test_alert_type', name: 'some alert type' }]); + loadAllActions.mockResolvedValue({ + page: 1, + perPage: 10000, + total: 0, + data: [], + }); + const mockes = coreMock.createSetup(); + const [{ chrome, docLinks }] = await mockes.getStartServices(); + const deps = { + chrome, + docLinks, + toastNotifications: mockes.notifications.toasts, + injectedMetadata: { + getInjectedVar(name: string) { + if (name === 'createAlertUiEnabled') { + return true; + } + }, + } as any, + http: mockes.http, + uiSettings: mockes.uiSettings, + legacy: { + capabilities: { + get() { + return { + siem: { + 'alerting:show': true, + 'alerting:save': false, + 'alerting:delete': false, + }, + }; + }, + } as any, + MANAGEMENT_BREADCRUMB: { set: () => {} } as any, + }, + actionTypeRegistry: actionTypeRegistry as any, + alertTypeRegistry: alertTypeRegistry as any, + }; + + await act(async () => { + wrapper = mountWithIntl( + + + + ); + }); + + await waitForRender(wrapper); + }); + + it('renders table of alerts with delete button disabled', () => { + expect(wrapper.find('EuiBasicTable')).toHaveLength(1); + expect(wrapper.find('EuiTableRow')).toHaveLength(2); + // TODO: check delete button + }); +}); + +async function waitForRender(wrapper: ReactWrapper) { + await Promise.resolve(); + await Promise.resolve(); + wrapper.update(); +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/alerts_list.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/alerts_list.tsx new file mode 100644 index 0000000000000..64f06521c0f9d --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/alerts_list.tsx @@ -0,0 +1,330 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { i18n } from '@kbn/i18n'; +import { FormattedMessage } from '@kbn/i18n/react'; +import React, { Fragment, useEffect, useState } from 'react'; +import { + EuiBasicTable, + EuiButton, + EuiFieldText, + EuiFlexGroup, + EuiFlexItem, + EuiIcon, + EuiSpacer, +} from '@elastic/eui'; + +import { AlertsContextProvider } from '../../../context/alerts_context'; +import { useAppDependencies } from '../../../app_context'; +import { ActionType, Alert, AlertTableItem, AlertTypeIndex, Pagination } from '../../../../types'; +import { AlertAdd } from '../../alert_add'; +import { BulkActionPopover } from './bulk_action_popover'; +import { CollapsedItemActions } from './collapsed_item_actions'; +import { TypeFilter } from './type_filter'; +import { ActionTypeFilter } from './action_type_filter'; +import { loadAlerts, loadAlertTypes } from '../../../lib/alert_api'; +import { loadActionTypes } from '../../../lib/action_connector_api'; +import { hasDeleteAlertsCapability, hasSaveAlertsCapability } from '../../../lib/capabilities'; + +const ENTER_KEY = 13; + +export const AlertsList: React.FunctionComponent = () => { + const { + http, + injectedMetadata, + toastNotifications, + legacy: { capabilities }, + } = useAppDependencies(); + const canDelete = hasDeleteAlertsCapability(capabilities.get()); + const canSave = hasSaveAlertsCapability(capabilities.get()); + const createAlertUiEnabled = injectedMetadata.getInjectedVar('createAlertUiEnabled'); + + const [actionTypes, setActionTypes] = useState([]); + const [alertTypesIndex, setAlertTypesIndex] = useState(undefined); + const [alerts, setAlerts] = useState([]); + const [data, setData] = useState([]); + const [selectedIds, setSelectedIds] = useState([]); + const [isLoadingAlertTypes, setIsLoadingAlertTypes] = useState(false); + const [isLoadingAlerts, setIsLoadingAlerts] = useState(false); + const [isPerformingAction, setIsPerformingAction] = useState(false); + const [totalItemCount, setTotalItemCount] = useState(0); + const [page, setPage] = useState({ index: 0, size: 10 }); + const [searchText, setSearchText] = useState(); + const [inputText, setInputText] = useState(); + const [typesFilter, setTypesFilter] = useState([]); + const [actionTypesFilter, setActionTypesFilter] = useState([]); + const [alertFlyoutVisible, setAlertFlyoutVisibility] = useState(false); + + useEffect(() => { + loadAlertsData(); + // eslint-disable-next-line react-hooks/exhaustive-deps + }, [page, searchText, typesFilter, actionTypesFilter]); + + useEffect(() => { + (async () => { + try { + setIsLoadingAlertTypes(true); + const alertTypes = await loadAlertTypes({ http }); + const index: AlertTypeIndex = {}; + for (const alertType of alertTypes) { + index[alertType.id] = alertType; + } + setAlertTypesIndex(index); + } catch (e) { + toastNotifications.addDanger({ + title: i18n.translate( + 'xpack.triggersActionsUI.sections.alertsList.unableToLoadAlertTypesMessage', + { defaultMessage: 'Unable to load alert types' } + ), + }); + } finally { + setIsLoadingAlertTypes(false); + } + })(); + // eslint-disable-next-line react-hooks/exhaustive-deps + }, []); + + useEffect(() => { + (async () => { + try { + const result = await loadActionTypes({ http }); + setActionTypes(result); + } catch (e) { + toastNotifications.addDanger({ + title: i18n.translate( + 'xpack.triggersActionsUI.sections.alertsList.unableToLoadActionTypesMessage', + { defaultMessage: 'Unable to load action types' } + ), + }); + } + })(); + // eslint-disable-next-line react-hooks/exhaustive-deps + }, []); + + useEffect(() => { + // Avoid flickering before alert types load + if (typeof alertTypesIndex === 'undefined') { + return; + } + const updatedData = alerts.map(alert => ({ + ...alert, + tagsText: alert.tags.join(', '), + alertType: alertTypesIndex[alert.alertTypeId] + ? alertTypesIndex[alert.alertTypeId].name + : alert.alertTypeId, + })); + setData(updatedData); + }, [alerts, alertTypesIndex]); + + async function loadAlertsData() { + setIsLoadingAlerts(true); + try { + const alertsResponse = await loadAlerts({ + http, + page, + searchText, + typesFilter, + actionTypesFilter, + }); + setAlerts(alertsResponse.data); + setTotalItemCount(alertsResponse.total); + } catch (e) { + toastNotifications.addDanger({ + title: i18n.translate( + 'xpack.triggersActionsUI.sections.alertsList.unableToLoadAlertsMessage', + { + defaultMessage: 'Unable to load alerts', + } + ), + }); + } finally { + setIsLoadingAlerts(false); + } + } + + const alertsTableColumns = [ + { + field: 'name', + name: i18n.translate( + 'xpack.triggersActionsUI.sections.alertsList.alertsListTable.columns.nameTitle', + { defaultMessage: 'Name' } + ), + sortable: false, + truncateText: true, + 'data-test-subj': 'alertsTableCell-name', + }, + { + field: 'tagsText', + name: i18n.translate( + 'xpack.triggersActionsUI.sections.alertsList.alertsListTable.columns.tagsText', + { defaultMessage: 'Tags' } + ), + sortable: false, + 'data-test-subj': 'alertsTableCell-tagsText', + }, + { + field: 'alertType', + name: i18n.translate( + 'xpack.triggersActionsUI.sections.alertsList.alertsListTable.columns.alertTypeTitle', + { defaultMessage: 'Type' } + ), + sortable: false, + truncateText: true, + 'data-test-subj': 'alertsTableCell-alertType', + }, + { + field: 'schedule.interval', + name: i18n.translate( + 'xpack.triggersActionsUI.sections.alertsList.alertsListTable.columns.intervalTitle', + { defaultMessage: 'Runs every' } + ), + sortable: false, + truncateText: false, + 'data-test-subj': 'alertsTableCell-interval', + }, + { + name: '', + width: '40px', + render(item: AlertTableItem) { + return ( + loadAlertsData()} /> + ); + }, + }, + ]; + + const toolsRight = [ + setTypesFilter(types)} + options={Object.values(alertTypesIndex || {}) + .map(alertType => ({ + value: alertType.id, + name: alertType.name, + })) + .sort((a, b) => a.name.localeCompare(b.name))} + />, + setActionTypesFilter(ids)} + />, + ]; + + if (canSave && createAlertUiEnabled) { + toolsRight.push( + setAlertFlyoutVisibility(true)} + > + + + ); + } + + return ( +
+ + + + + {selectedIds.length > 0 && canDelete && ( + + setIsPerformingAction(true)} + onActionPerformed={() => { + loadAlertsData(); + setIsPerformingAction(false); + }} + /> + + )} + + } + onChange={e => setInputText(e.target.value)} + onKeyUp={e => { + if (e.keyCode === ENTER_KEY) { + setSearchText(inputText); + } + }} + placeholder={i18n.translate( + 'xpack.triggersActionsUI.sections.alertsList.searchPlaceholderTitle', + { defaultMessage: 'Search...' } + )} + /> + + + + {toolsRight.map((tool, index: number) => ( + + {tool} + + ))} + + + + + {/* Large to remain consistent with ActionsList table spacing */} + + + ({ + 'data-test-subj': 'alert-row', + })} + cellProps={() => ({ + 'data-test-subj': 'cell', + })} + data-test-subj="alertsList" + pagination={{ + pageIndex: page.index, + pageSize: page.size, + totalItemCount, + }} + selection={ + canDelete + ? { + onSelectionChange(updatedSelectedItemsList: AlertTableItem[]) { + setSelectedIds(updatedSelectedItemsList.map(item => item.id)); + }, + } + : undefined + } + onChange={({ page: changedPage }: { page: Pagination }) => { + setPage(changedPage); + }} + /> + + + +
+ ); +}; + +function pickFromData(data: AlertTableItem[], ids: string[]): AlertTableItem[] { + const result: AlertTableItem[] = []; + for (const id of ids) { + const match = data.find(item => item.id === id); + if (match) { + result.push(match); + } + } + return result; +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/bulk_action_popover.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/bulk_action_popover.tsx new file mode 100644 index 0000000000000..59ec52ac83a6c --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/bulk_action_popover.tsx @@ -0,0 +1,253 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { i18n } from '@kbn/i18n'; +import React, { useState } from 'react'; +import { FormattedMessage } from '@kbn/i18n/react'; +import { EuiButton, EuiButtonEmpty, EuiFormRow, EuiPopover } from '@elastic/eui'; + +import { AlertTableItem } from '../../../../types'; +import { useAppDependencies } from '../../../app_context'; +import { + deleteAlerts, + disableAlerts, + enableAlerts, + muteAlerts, + unmuteAlerts, +} from '../../../lib/alert_api'; + +export interface ComponentOpts { + selectedItems: AlertTableItem[]; + onPerformingAction: () => void; + onActionPerformed: () => void; +} + +export const BulkActionPopover: React.FunctionComponent = ({ + selectedItems, + onPerformingAction, + onActionPerformed, +}: ComponentOpts) => { + const { http, toastNotifications } = useAppDependencies(); + + const [isPopoverOpen, setIsPopoverOpen] = useState(false); + const [isMutingAlerts, setIsMutingAlerts] = useState(false); + const [isUnmutingAlerts, setIsUnmutingAlerts] = useState(false); + const [isEnablingAlerts, setIsEnablingAlerts] = useState(false); + const [isDisablingAlerts, setIsDisablingAlerts] = useState(false); + const [isDeletingAlerts, setIsDeletingAlerts] = useState(false); + + const allAlertsMuted = selectedItems.every(isAlertMuted); + const allAlertsDisabled = selectedItems.every(isAlertDisabled); + const isPerformingAction = + isMutingAlerts || isUnmutingAlerts || isEnablingAlerts || isDisablingAlerts || isDeletingAlerts; + + async function onmMuteAllClick() { + onPerformingAction(); + setIsMutingAlerts(true); + const ids = selectedItems.filter(item => !isAlertMuted(item)).map(item => item.id); + try { + await muteAlerts({ http, ids }); + } catch (e) { + toastNotifications.addDanger({ + title: i18n.translate( + 'xpack.triggersActionsUI.sections.alertsList.bulkActionPopover.failedToMuteAlertsMessage', + { + defaultMessage: 'Failed to mute alert(s)', + } + ), + }); + } finally { + setIsMutingAlerts(false); + onActionPerformed(); + } + } + + async function onUnmuteAllClick() { + onPerformingAction(); + setIsUnmutingAlerts(true); + const ids = selectedItems.filter(isAlertMuted).map(item => item.id); + try { + await unmuteAlerts({ http, ids }); + } catch (e) { + toastNotifications.addDanger({ + title: i18n.translate( + 'xpack.triggersActionsUI.sections.alertsList.bulkActionPopover.failedToUnmuteAlertsMessage', + { + defaultMessage: 'Failed to unmute alert(s)', + } + ), + }); + } finally { + setIsUnmutingAlerts(false); + onActionPerformed(); + } + } + + async function onEnableAllClick() { + onPerformingAction(); + setIsEnablingAlerts(true); + const ids = selectedItems.filter(isAlertDisabled).map(item => item.id); + try { + await enableAlerts({ http, ids }); + } catch (e) { + toastNotifications.addDanger({ + title: i18n.translate( + 'xpack.triggersActionsUI.sections.alertsList.bulkActionPopover.failedToEnableAlertsMessage', + { + defaultMessage: 'Failed to enable alert(s)', + } + ), + }); + } finally { + setIsEnablingAlerts(false); + onActionPerformed(); + } + } + + async function onDisableAllClick() { + onPerformingAction(); + setIsDisablingAlerts(true); + const ids = selectedItems.filter(item => !isAlertDisabled(item)).map(item => item.id); + try { + await disableAlerts({ http, ids }); + } catch (e) { + toastNotifications.addDanger({ + title: i18n.translate( + 'xpack.triggersActionsUI.sections.alertsList.bulkActionPopover.failedToDisableAlertsMessage', + { + defaultMessage: 'Failed to disable alert(s)', + } + ), + }); + } finally { + setIsDisablingAlerts(false); + onActionPerformed(); + } + } + + async function deleteSelectedItems() { + onPerformingAction(); + setIsDeletingAlerts(true); + const ids = selectedItems.map(item => item.id); + try { + await deleteAlerts({ http, ids }); + } catch (e) { + toastNotifications.addDanger({ + title: i18n.translate( + 'xpack.triggersActionsUI.sections.alertsList.bulkActionPopover.failedToDeleteAlertsMessage', + { + defaultMessage: 'Failed to delete alert(s)', + } + ), + }); + } finally { + setIsDeletingAlerts(false); + onActionPerformed(); + } + } + + return ( + setIsPopoverOpen(false)} + data-test-subj="bulkAction" + button={ + setIsPopoverOpen(!isPopoverOpen)} + > + + + } + > + {!allAlertsMuted && ( + + + + + + )} + {allAlertsMuted && ( + + + + + + )} + {allAlertsDisabled && ( + + + + + + )} + {!allAlertsDisabled && ( + + + + + + )} + + + + + + + ); +}; + +function isAlertDisabled(alert: AlertTableItem) { + return alert.enabled === false; +} + +function isAlertMuted(alert: AlertTableItem) { + return alert.muteAll === true; +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/collapsed_item_actions.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/collapsed_item_actions.tsx new file mode 100644 index 0000000000000..f063ab4f7cde3 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/collapsed_item_actions.tsx @@ -0,0 +1,140 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { i18n } from '@kbn/i18n'; +import React, { useState } from 'react'; +import { FormattedMessage } from '@kbn/i18n/react'; +import { + EuiButtonEmpty, + EuiButtonIcon, + EuiFormRow, + EuiPopover, + EuiPopoverFooter, + EuiSwitch, +} from '@elastic/eui'; + +import { AlertTableItem } from '../../../../types'; +import { useAppDependencies } from '../../../app_context'; +import { hasDeleteAlertsCapability, hasSaveAlertsCapability } from '../../../lib/capabilities'; +import { + deleteAlerts, + disableAlerts, + enableAlerts, + muteAlerts, + unmuteAlerts, +} from '../../../lib/alert_api'; + +export interface ComponentOpts { + item: AlertTableItem; + onAlertChanged: () => void; +} + +export const CollapsedItemActions: React.FunctionComponent = ({ + item, + onAlertChanged, +}: ComponentOpts) => { + const { + http, + legacy: { capabilities }, + } = useAppDependencies(); + + const canDelete = hasDeleteAlertsCapability(capabilities.get()); + const canSave = hasSaveAlertsCapability(capabilities.get()); + + const [isEnabled, setIsEnabled] = useState(item.enabled); + const [isMuted, setIsMuted] = useState(item.muteAll); + const [isPopoverOpen, setIsPopoverOpen] = useState(false); + + const button = ( + setIsPopoverOpen(!isPopoverOpen)} + aria-label={i18n.translate( + 'xpack.triggersActionsUI.sections.alertsList.collapsedItemActons.popoverButtonTitle', + { defaultMessage: 'Actions' } + )} + /> + ); + + return ( + setIsPopoverOpen(false)} + ownFocus + data-test-subj="collapsedItemActions" + > + + { + if (isEnabled) { + setIsEnabled(false); + await disableAlerts({ http, ids: [item.id] }); + } else { + setIsEnabled(true); + await enableAlerts({ http, ids: [item.id] }); + } + onAlertChanged(); + }} + label={ + + } + /> + + + { + if (isMuted) { + setIsMuted(false); + await unmuteAlerts({ http, ids: [item.id] }); + } else { + setIsMuted(true); + await muteAlerts({ http, ids: [item.id] }); + } + onAlertChanged(); + }} + label={ + + } + /> + + + + { + await deleteAlerts({ http, ids: [item.id] }); + onAlertChanged(); + }} + > + + + + + + ); +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/type_filter.tsx b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/type_filter.tsx new file mode 100644 index 0000000000000..f9cf7a6efd461 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/sections/alerts_list/components/type_filter.tsx @@ -0,0 +1,74 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React, { useEffect, useState } from 'react'; +import { FormattedMessage } from '@kbn/i18n/react'; +import { EuiFilterGroup, EuiPopover, EuiFilterButton, EuiFilterSelectItem } from '@elastic/eui'; + +interface TypeFilterProps { + options: Array<{ + value: string; + name: string; + }>; + onChange?: (selectedTags: string[]) => void; +} + +export const TypeFilter: React.FunctionComponent = ({ + options, + onChange, +}: TypeFilterProps) => { + const [selectedValues, setSelectedValues] = useState([]); + const [isPopoverOpen, setIsPopoverOpen] = useState(false); + + useEffect(() => { + if (onChange) { + onChange(selectedValues); + } + // eslint-disable-next-line react-hooks/exhaustive-deps + }, [selectedValues]); + + return ( + + setIsPopoverOpen(false)} + button={ + 0} + numActiveFilters={selectedValues.length} + numFilters={selectedValues.length} + onClick={() => setIsPopoverOpen(!isPopoverOpen)} + > + + + } + > +
+ {options.map((item, index) => ( + { + const isPreviouslyChecked = selectedValues.includes(item.value); + if (isPreviouslyChecked) { + setSelectedValues(selectedValues.filter(val => val !== item.value)); + } else { + setSelectedValues(selectedValues.concat(item.value)); + } + }} + checked={selectedValues.includes(item.value) ? 'on' : undefined} + > + {item.name} + + ))} +
+
+
+ ); +}; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/type_registry.test.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/type_registry.test.ts new file mode 100644 index 0000000000000..efe58aedb8353 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/type_registry.test.ts @@ -0,0 +1,117 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { TypeRegistry } from './type_registry'; +import { ValidationResult, AlertTypeModel, ActionTypeModel } from '../types'; + +export const ExpressionComponent: React.FunctionComponent = () => { + return null; +}; + +const getTestAlertType = (id?: string, name?: string, iconClass?: string) => { + return { + id: id || 'test-alet-type', + name: name || 'Test alert type', + iconClass: iconClass || 'icon', + validate: (): ValidationResult => { + return { errors: {} }; + }, + alertParamsExpression: ExpressionComponent, + }; +}; + +const getTestActionType = (id?: string, iconClass?: string, selectedMessage?: string) => { + return { + id: id || 'my-action-type', + iconClass: iconClass || 'test', + selectMessage: selectedMessage || 'test', + validateConnector: (): ValidationResult => { + return { errors: {} }; + }, + validateParams: (): ValidationResult => { + const validationResult = { errors: {} }; + return validationResult; + }, + actionConnectorFields: null, + actionParamsFields: null, + }; +}; + +beforeEach(() => jest.resetAllMocks()); + +describe('register()', () => { + test('able to register alert types', () => { + const alertTypeRegistry = new TypeRegistry(); + alertTypeRegistry.register(getTestAlertType()); + expect(alertTypeRegistry.has('test-alet-type')).toEqual(true); + }); + + test('throws error if alert type already registered', () => { + const alertTypeRegistry = new TypeRegistry(); + alertTypeRegistry.register(getTestAlertType('my-test-alert-type-1')); + expect(() => + alertTypeRegistry.register(getTestAlertType('my-test-alert-type-1')) + ).toThrowErrorMatchingInlineSnapshot( + `"Object type \\"my-test-alert-type-1\\" is already registered."` + ); + }); +}); + +describe('get()', () => { + test('returns action type', () => { + const actionTypeRegistry = new TypeRegistry(); + actionTypeRegistry.register(getTestActionType('my-action-type-snapshot')); + const actionType = actionTypeRegistry.get('my-action-type-snapshot'); + expect(actionType).toMatchInlineSnapshot(` + Object { + "actionConnectorFields": null, + "actionParamsFields": null, + "iconClass": "test", + "id": "my-action-type-snapshot", + "selectMessage": "test", + "validateConnector": [Function], + "validateParams": [Function], + } + `); + }); + + test(`return null when action type doesn't exist`, () => { + const actionTypeRegistry = new TypeRegistry(); + expect(actionTypeRegistry.get('not-exist-action-type')).toBeNull(); + }); +}); + +describe('list()', () => { + test('returns list of action types', () => { + const actionTypeRegistry = new TypeRegistry(); + actionTypeRegistry.register(getTestActionType()); + const actionTypes = actionTypeRegistry.list(); + expect(actionTypes).toEqual([ + { + id: 'my-action-type', + iconClass: 'test', + selectMessage: 'test', + actionConnectorFields: null, + actionParamsFields: null, + validateConnector: actionTypes[0].validateConnector, + validateParams: actionTypes[0].validateParams, + }, + ]); + }); +}); + +describe('has()', () => { + test('returns false for unregistered alert types', () => { + const alertTypeRegistry = new TypeRegistry(); + expect(alertTypeRegistry.has('my-alert-type')).toEqual(false); + }); + + test('returns true after registering an alert type', () => { + const alertTypeRegistry = new TypeRegistry(); + alertTypeRegistry.register(getTestAlertType()); + expect(alertTypeRegistry.has('test-alet-type')); + }); +}); diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/type_registry.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/type_registry.ts new file mode 100644 index 0000000000000..3390d8910a45f --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/application/type_registry.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; + * you may not use this file except in compliance with the Elastic License. + */ + +import { i18n } from '@kbn/i18n'; + +interface BaseObjectType { + id: string; +} + +export class TypeRegistry { + private readonly objectTypes: Map = new Map(); + + /** + * Returns if the object type registry has the given type registered + */ + public has(id: string) { + return this.objectTypes.has(id); + } + + /** + * Registers an object type to the type registry + */ + public register(objectType: T) { + if (this.has(objectType.id)) { + throw new Error( + i18n.translate( + 'xpack.triggersActionsUI.typeRegistry.register.duplicateObjectTypeErrorMessage', + { + defaultMessage: 'Object type "{id}" is already registered.', + values: { + id: objectType.id, + }, + } + ) + ); + } + this.objectTypes.set(objectType.id, objectType); + } + + /** + * Returns an object type, null if not registered + */ + public get(id: string): T | null { + if (!this.has(id)) { + return null; + } + return this.objectTypes.get(id)!; + } + + public list() { + return Array.from(this.objectTypes).map(([id, objectType]) => objectType); + } +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/index.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/index.ts new file mode 100644 index 0000000000000..7eed516019dd0 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/index.ts @@ -0,0 +1,15 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { PluginInitializerContext } from 'src/core/public'; +import { Plugin } from './plugin'; + +export function plugin(ctx: PluginInitializerContext) { + return new Plugin(ctx); +} + +export { Plugin }; +export * from './plugin'; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/plugin.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/plugin.ts new file mode 100644 index 0000000000000..0b0f8a4ee6790 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/plugin.ts @@ -0,0 +1,107 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { + CoreSetup, + CoreStart, + Plugin as CorePlugin, + PluginInitializerContext, +} from 'src/core/public'; + +import { i18n } from '@kbn/i18n'; +import { registerBuiltInActionTypes } from './application/components/builtin_action_types'; +import { registerBuiltInAlertTypes } from './application/components/builtin_alert_types'; +import { hasShowActionsCapability, hasShowAlertsCapability } from './application/lib/capabilities'; +import { PLUGIN } from './application/constants/plugin'; +import { LegacyDependencies, ActionTypeModel, AlertTypeModel } from './types'; +import { TypeRegistry } from './application/type_registry'; + +export type Setup = void; +export type Start = void; + +interface LegacyPlugins { + __LEGACY: LegacyDependencies; +} + +export class Plugin implements CorePlugin { + private actionTypeRegistry: TypeRegistry; + private alertTypeRegistry: TypeRegistry; + + constructor(initializerContext: PluginInitializerContext) { + const actionTypeRegistry = new TypeRegistry(); + this.actionTypeRegistry = actionTypeRegistry; + + const alertTypeRegistry = new TypeRegistry(); + this.alertTypeRegistry = alertTypeRegistry; + } + + public setup( + { application, notifications, http, uiSettings, injectedMetadata }: CoreSetup, + { __LEGACY }: LegacyPlugins + ): Setup { + const canShowActions = hasShowActionsCapability(__LEGACY.capabilities.get()); + const canShowAlerts = hasShowAlertsCapability(__LEGACY.capabilities.get()); + + if (!canShowActions && !canShowAlerts) { + return; + } + registerBuiltInActionTypes({ + actionTypeRegistry: this.actionTypeRegistry, + }); + + registerBuiltInAlertTypes({ + alertTypeRegistry: this.alertTypeRegistry, + }); + application.register({ + id: PLUGIN.ID, + title: PLUGIN.getI18nName(i18n), + mount: async ( + { + core: { + docLinks, + chrome, + // Waiting for types to be updated. + // @ts-ignore + savedObjects, + i18n: { Context: I18nContext }, + }, + }, + { element } + ) => { + const { boot } = await import('./application/boot'); + return boot({ + element, + toastNotifications: notifications.toasts, + injectedMetadata, + http, + uiSettings, + docLinks, + chrome, + savedObjects: savedObjects.client, + I18nContext, + legacy: { + ...__LEGACY, + }, + actionTypeRegistry: this.actionTypeRegistry, + alertTypeRegistry: this.alertTypeRegistry, + }); + }, + }); + } + + public start(core: CoreStart, { __LEGACY }: LegacyPlugins) { + const { capabilities } = __LEGACY; + const canShowActions = hasShowActionsCapability(capabilities.get()); + const canShowAlerts = hasShowAlertsCapability(capabilities.get()); + + // Don't register routes when user doesn't have access to the application + if (!canShowActions && !canShowAlerts) { + return; + } + } + + public stop() {} +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/types.ts b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/types.ts new file mode 100644 index 0000000000000..4cf28d3bbd06f --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/np_ready/public/types.ts @@ -0,0 +1,120 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import { capabilities } from 'ui/capabilities'; +import { TypeRegistry } from './application/type_registry'; + +export type ActionTypeIndex = Record; +export type AlertTypeIndex = Record; +export type ActionTypeRegistryContract = PublicMethodsOf>; +export type AlertTypeRegistryContract = PublicMethodsOf>; + +export interface ActionConnectorFieldsProps { + action: ActionConnector; + editActionConfig: (property: string, value: any) => void; + editActionSecrets: (property: string, value: any) => void; + errors: { [key: string]: string[] }; + hasErrors?: boolean; +} + +export interface ActionParamsProps { + action: any; + index: number; + editAction: (property: string, value: any, index: number) => void; + errors: { [key: string]: string[] }; + hasErrors?: boolean; +} + +export interface Pagination { + index: number; + size: number; +} + +export interface ActionTypeModel { + id: string; + iconClass: string; + selectMessage: string; + validateConnector: (action: ActionConnector) => ValidationResult; + validateParams: (actionParams: any) => ValidationResult; + actionConnectorFields: React.FunctionComponent | null; + actionParamsFields: React.FunctionComponent | null; +} + +export interface ValidationResult { + errors: Record; +} + +export interface ActionType { + id: string; + name: string; +} + +export interface ActionConnector { + secrets: Record; + id: string; + actionTypeId: string; + name: string; + referencedByCount?: number; + config: Record; +} + +export type ActionConnectorWithoutId = Omit; + +export interface ActionConnectorTableItem extends ActionConnector { + actionType: ActionType['name']; +} + +export interface AlertType { + id: string; + name: string; +} + +export interface AlertAction { + group: string; + id: string; + params: Record; +} + +export interface Alert { + id: string; + name: string; + tags: string[]; + enabled: boolean; + alertTypeId: string; + interval: string; + actions: AlertAction[]; + params: Record; + scheduledTaskId?: string; + createdBy: string | null; + updatedBy: string | null; + apiKeyOwner?: string; + throttle: string | null; + muteAll: boolean; + mutedInstanceIds: string[]; +} + +export type AlertWithoutId = Omit; + +export interface AlertTableItem extends Alert { + alertType: AlertType['name']; + tagsText: string; +} + +export interface AlertTypeModel { + id: string; + name: string; + iconClass: string; + validate: (alert: Alert) => ValidationResult; + alertParamsExpression: React.FunctionComponent; +} + +export interface IErrorObject { + [key: string]: string[]; +} + +export interface LegacyDependencies { + MANAGEMENT_BREADCRUMB: { text: string; href?: string }; + capabilities: typeof capabilities; +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/public/hacks/register.ts b/x-pack/legacy/plugins/triggers_actions_ui/public/hacks/register.ts new file mode 100644 index 0000000000000..7991604fcc667 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/public/hacks/register.ts @@ -0,0 +1,25 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { i18n } from '@kbn/i18n'; +import { + FeatureCatalogueRegistryProvider, + FeatureCatalogueCategory, +} from 'ui/registry/feature_catalogue'; + +FeatureCatalogueRegistryProvider.register(() => { + return { + id: 'triggersActions', + title: 'Alerts and Actions', // This is a product name so we don't translate it. + description: i18n.translate('xpack.triggersActionsUI.triggersActionsDescription', { + defaultMessage: 'Data by creating, managing, and monitoring triggers and actions.', + }), + icon: 'triggersActionsApp', + path: '/app/kibana#/management/kibana/triggersActions', + showOnHomePage: true, + category: FeatureCatalogueCategory.ADMIN, + }; +}); diff --git a/x-pack/legacy/plugins/triggers_actions_ui/public/index.scss b/x-pack/legacy/plugins/triggers_actions_ui/public/index.scss new file mode 100644 index 0000000000000..6faad81630b2b --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/public/index.scss @@ -0,0 +1,5 @@ +// Imported EUI +@import 'src/legacy/ui/public/styles/_styling_constants'; + +// Styling within the app +@import '../np_ready/public/application/sections/actions_connectors_list/components/index'; diff --git a/x-pack/legacy/plugins/triggers_actions_ui/public/legacy.ts b/x-pack/legacy/plugins/triggers_actions_ui/public/legacy.ts new file mode 100644 index 0000000000000..bae9104081267 --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/public/legacy.ts @@ -0,0 +1,98 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { CoreSetup, App, AppUnmount } from 'src/core/public'; +import { capabilities } from 'ui/capabilities'; +import { i18n } from '@kbn/i18n'; + +/* Legacy UI imports */ +import { npSetup, npStart } from 'ui/new_platform'; +import routes from 'ui/routes'; +import { management, MANAGEMENT_BREADCRUMB } from 'ui/management'; +// @ts-ignore +import { xpackInfo } from 'plugins/xpack_main/services/xpack_info'; +/* Legacy UI imports */ + +import { plugin } from '../np_ready/public'; +import { manageAngularLifecycle } from './manage_angular_lifecycle'; +import { BASE_PATH } from '../np_ready/public/application/constants'; +import { + hasShowActionsCapability, + hasShowAlertsCapability, +} from '../np_ready/public/application/lib/capabilities'; + +const REACT_ROOT_ID = 'triggersActionsRoot'; +const canShowActions = hasShowActionsCapability(capabilities.get()); +const canShowAlerts = hasShowAlertsCapability(capabilities.get()); + +const template = ` +
+
`; + +let elem: HTMLElement; +let mountApp: () => AppUnmount | Promise; +let unmountApp: AppUnmount | Promise; +routes.when(`${BASE_PATH}:section?/:subsection?/:view?/:id?`, { + template, + controller: (() => { + return ($route: any, $scope: any) => { + const shimCore: CoreSetup = { + ...npSetup.core, + application: { + ...npSetup.core.application, + register(app: App): void { + mountApp = () => + app.mount(npStart as any, { + element: elem, + appBasePath: BASE_PATH, + onAppLeave: () => undefined, + }); + }, + }, + }; + + // clean up previously rendered React app if one exists + // this happens because of React Router redirects + if (elem) { + ((unmountApp as unknown) as AppUnmount)(); + } + + $scope.$$postDigest(() => { + elem = document.getElementById(REACT_ROOT_ID)!; + const instance = plugin({} as any); + instance.setup(shimCore, { + ...(npSetup.plugins as typeof npSetup.plugins), + __LEGACY: { + MANAGEMENT_BREADCRUMB, + capabilities, + }, + }); + + instance.start(npStart.core, { + ...(npSetup.plugins as typeof npSetup.plugins), + __LEGACY: { + MANAGEMENT_BREADCRUMB, + capabilities, + }, + }); + + (mountApp() as Promise).then(fn => (unmountApp = fn)); + + manageAngularLifecycle($scope, $route, elem); + }); + }; + })(), +}); + +if (canShowActions || canShowAlerts) { + management.getSection('kibana').register('triggersActions', { + display: i18n.translate('xpack.triggersActionsUI.managementSection.displayName', { + defaultMessage: 'Alerts and Actions', + }), + order: 7, + url: `#${BASE_PATH}`, + }); +} diff --git a/x-pack/legacy/plugins/triggers_actions_ui/public/manage_angular_lifecycle.ts b/x-pack/legacy/plugins/triggers_actions_ui/public/manage_angular_lifecycle.ts new file mode 100644 index 0000000000000..efd40eaf83daa --- /dev/null +++ b/x-pack/legacy/plugins/triggers_actions_ui/public/manage_angular_lifecycle.ts @@ -0,0 +1,28 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { unmountComponentAtNode } from 'react-dom'; + +export const manageAngularLifecycle = ($scope: any, $route: any, elem: HTMLElement) => { + const lastRoute = $route.current; + + const deregister = $scope.$on('$locationChangeSuccess', () => { + const currentRoute = $route.current; + if (lastRoute.$$route.template === currentRoute.$$route.template) { + $route.current = lastRoute; + } + }); + + $scope.$on('$destroy', () => { + if (deregister) { + deregister(); + } + + if (elem) { + unmountComponentAtNode(elem); + } + }); +}; diff --git a/x-pack/scripts/functional_tests.js b/x-pack/scripts/functional_tests.js index bda5b51623d05..11ee038cf39f0 100644 --- a/x-pack/scripts/functional_tests.js +++ b/x-pack/scripts/functional_tests.js @@ -9,6 +9,7 @@ const onlyNotInCoverageTests = [ require.resolve('../test/reporting/configs/chromium_api.js'), require.resolve('../test/reporting/configs/chromium_functional.js'), require.resolve('../test/reporting/configs/generate_api.js'), + require.resolve('../test/functional_with_es_ssl/config.ts'), require.resolve('../test/functional/config_security_basic.js'), require.resolve('../test/api_integration/config_security_basic.js'), require.resolve('../test/api_integration/config.js'), diff --git a/x-pack/test/functional/services/index.ts b/x-pack/test/functional/services/index.ts index 5ab8933a4804a..84d5a792ae6ca 100644 --- a/x-pack/test/functional/services/index.ts +++ b/x-pack/test/functional/services/index.ts @@ -57,6 +57,7 @@ export const services = { ...kibanaFunctionalServices, ...commonServices, + supertest: kibanaApiIntegrationServices.supertest, esSupertest: kibanaApiIntegrationServices.esSupertest, monitoringNoData: MonitoringNoDataProvider, monitoringClusterList: MonitoringClusterListProvider, diff --git a/x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/alerts.ts b/x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/alerts.ts new file mode 100644 index 0000000000000..4fdfe0d32ace3 --- /dev/null +++ b/x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/alerts.ts @@ -0,0 +1,344 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import uuid from 'uuid'; +import expect from '@kbn/expect'; +import { FtrProviderContext } from '../../ftr_provider_context'; + +function generateUniqueKey() { + return uuid.v4().replace(/-/g, ''); +} + +export default ({ getPageObjects, getService }: FtrProviderContext) => { + const testSubjects = getService('testSubjects'); + const pageObjects = getPageObjects(['common', 'triggersActionsUI', 'header']); + const supertest = getService('supertest'); + const retry = getService('retry'); + + async function createAlert() { + const { body: createdAlert } = await supertest + .post(`/api/alert`) + .set('kbn-xsrf', 'foo') + .send({ + enabled: true, + name: generateUniqueKey(), + tags: ['foo', 'bar'], + alertTypeId: 'test.noop', + consumer: 'test', + schedule: { interval: '1m' }, + throttle: '1m', + actions: [], + params: {}, + }) + .expect(200); + return createdAlert; + } + + describe('alerts', function() { + before(async () => { + await pageObjects.common.navigateToApp('triggersActions'); + const alertsTab = await testSubjects.find('alertsTab'); + await alertsTab.click(); + }); + + it('should search for alert', async () => { + const createdAlert = await createAlert(); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const searchResults = await pageObjects.triggersActionsUI.getAlertsList(); + expect(searchResults).to.eql([ + { + name: createdAlert.name, + tagsText: 'foo, bar', + alertType: 'Test: Noop', + interval: '1m', + }, + ]); + }); + + it('should search for tags', async () => { + const createdAlert = await createAlert(); + + await pageObjects.triggersActionsUI.searchAlerts(`${createdAlert.name} foo`); + + const searchResults = await pageObjects.triggersActionsUI.getAlertsList(); + expect(searchResults).to.eql([ + { + name: createdAlert.name, + tagsText: 'foo, bar', + alertType: 'Test: Noop', + interval: '1m', + }, + ]); + }); + + // Flaky until https://github.com/elastic/eui/issues/2612 fixed + it.skip('should disable single alert', async () => { + const createdAlert = await createAlert(); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const collapsedItemActions = await testSubjects.find('collapsedItemActions'); + await collapsedItemActions.click(); + + const enableSwitch = await testSubjects.find('enableSwitch'); + await enableSwitch.click(); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const collapsedItemActionsAfterDisable = await testSubjects.find('collapsedItemActions'); + await collapsedItemActionsAfterDisable.click(); + + const enableSwitchAfterDisable = await testSubjects.find('enableSwitch'); + const isChecked = await enableSwitchAfterDisable.getAttribute('aria-checked'); + expect(isChecked).to.eql('false'); + }); + + // Flaky until https://github.com/elastic/eui/issues/2612 fixed + it.skip('should re-enable single alert', async () => { + const createdAlert = await createAlert(); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const collapsedItemActions = await testSubjects.find('collapsedItemActions'); + await collapsedItemActions.click(); + + const enableSwitch = await testSubjects.find('enableSwitch'); + await enableSwitch.click(); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const collapsedItemActionsAfterDisable = await testSubjects.find('collapsedItemActions'); + await collapsedItemActionsAfterDisable.click(); + + const enableSwitchAfterDisable = await testSubjects.find('enableSwitch'); + await enableSwitchAfterDisable.click(); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const collapsedItemActionsAfterReEnable = await testSubjects.find('collapsedItemActions'); + await collapsedItemActionsAfterReEnable.click(); + + const enableSwitchAfterReEnable = await testSubjects.find('enableSwitch'); + const isChecked = await enableSwitchAfterReEnable.getAttribute('aria-checked'); + expect(isChecked).to.eql('true'); + }); + + // Flaky until https://github.com/elastic/eui/issues/2612 fixed + it.skip('should mute single alert', async () => { + const createdAlert = await createAlert(); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const collapsedItemActions = await testSubjects.find('collapsedItemActions'); + await collapsedItemActions.click(); + + const muteSwitch = await testSubjects.find('muteSwitch'); + await muteSwitch.click(); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const collapsedItemActionsAfterMute = await testSubjects.find('collapsedItemActions'); + await collapsedItemActionsAfterMute.click(); + + const muteSwitchAfterMute = await testSubjects.find('muteSwitch'); + const isChecked = await muteSwitchAfterMute.getAttribute('aria-checked'); + expect(isChecked).to.eql('true'); + }); + + // Flaky until https://github.com/elastic/eui/issues/2612 fixed + it.skip('should unmute single alert', async () => { + const createdAlert = await createAlert(); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const collapsedItemActions = await testSubjects.find('collapsedItemActions'); + await collapsedItemActions.click(); + + const muteSwitch = await testSubjects.find('muteSwitch'); + await muteSwitch.click(); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const collapsedItemActionsAfterMute = await testSubjects.find('collapsedItemActions'); + await collapsedItemActionsAfterMute.click(); + + const muteSwitchAfterMute = await testSubjects.find('muteSwitch'); + await muteSwitchAfterMute.click(); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const collapsedItemActionsAfterUnmute = await testSubjects.find('collapsedItemActions'); + await collapsedItemActionsAfterUnmute.click(); + + const muteSwitchAfterUnmute = await testSubjects.find('muteSwitch'); + const isChecked = await muteSwitchAfterUnmute.getAttribute('aria-checked'); + expect(isChecked).to.eql('false'); + }); + + // Flaky, will be fixed with https://github.com/elastic/kibana/issues/53956 + it.skip('should delete single alert', async () => { + const createdAlert = await createAlert(); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const collapsedItemActions = await testSubjects.find('collapsedItemActions'); + await collapsedItemActions.click(); + + const deleteBtn = await testSubjects.find('deleteAlert'); + await deleteBtn.click(); + + retry.try(async () => { + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const searchResults = await pageObjects.triggersActionsUI.getAlertsList(); + expect(searchResults.length).to.eql(0); + }); + }); + + // Flaky, will be fixed with https://github.com/elastic/kibana/issues/49830 + it.skip('should mute all selection', async () => { + const createdAlert = await createAlert(); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const checkbox = await testSubjects.find(`checkboxSelectRow-${createdAlert.id}`); + await checkbox.click(); + + const bulkActionBtn = await testSubjects.find('bulkAction'); + await bulkActionBtn.click(); + + const muteAllBtn = await testSubjects.find('muteAll'); + await muteAllBtn.click(); + + // Unmute all button shows after clicking mute all + await testSubjects.existOrFail('unmuteAll'); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const collapsedItemActions = await testSubjects.find('collapsedItemActions'); + await collapsedItemActions.click(); + + const muteSwitch = await testSubjects.find('muteSwitch'); + const isChecked = await muteSwitch.getAttribute('aria-checked'); + expect(isChecked).to.eql('true'); + }); + + // Flaky, will be fixed with https://github.com/elastic/kibana/issues/49830 + it.skip('should unmute all selection', async () => { + const createdAlert = await createAlert(); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const checkbox = await testSubjects.find(`checkboxSelectRow-${createdAlert.id}`); + await checkbox.click(); + + const bulkActionBtn = await testSubjects.find('bulkAction'); + await bulkActionBtn.click(); + + const muteAllBtn = await testSubjects.find('muteAll'); + await muteAllBtn.click(); + + const unmuteAllBtn = await testSubjects.find('unmuteAll'); + await unmuteAllBtn.click(); + + // Mute all button shows after clicking unmute all + await testSubjects.existOrFail('muteAll'); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const collapsedItemActions = await testSubjects.find('collapsedItemActions'); + await collapsedItemActions.click(); + + const muteSwitch = await testSubjects.find('muteSwitch'); + const isChecked = await muteSwitch.getAttribute('aria-checked'); + expect(isChecked).to.eql('false'); + }); + + // Flaky, will be fixed with https://github.com/elastic/kibana/issues/49830 + it.skip('should disable all selection', async () => { + const createdAlert = await createAlert(); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const checkbox = await testSubjects.find(`checkboxSelectRow-${createdAlert.id}`); + await checkbox.click(); + + const bulkActionBtn = await testSubjects.find('bulkAction'); + await bulkActionBtn.click(); + + const disableAllBtn = await testSubjects.find('disableAll'); + await disableAllBtn.click(); + + // Enable all button shows after clicking disable all + await testSubjects.existOrFail('enableAll'); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const collapsedItemActions = await testSubjects.find('collapsedItemActions'); + await collapsedItemActions.click(); + + const enableSwitch = await testSubjects.find('enableSwitch'); + const isChecked = await enableSwitch.getAttribute('aria-checked'); + expect(isChecked).to.eql('false'); + }); + + // Flaky, will be fixed with https://github.com/elastic/kibana/issues/49830 + it.skip('should enable all selection', async () => { + const createdAlert = await createAlert(); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const checkbox = await testSubjects.find(`checkboxSelectRow-${createdAlert.id}`); + await checkbox.click(); + + const bulkActionBtn = await testSubjects.find('bulkAction'); + await bulkActionBtn.click(); + + const disableAllBtn = await testSubjects.find('disableAll'); + await disableAllBtn.click(); + + const enableAllBtn = await testSubjects.find('enableAll'); + await enableAllBtn.click(); + + // Disable all button shows after clicking enable all + await testSubjects.existOrFail('disableAll'); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const collapsedItemActions = await testSubjects.find('collapsedItemActions'); + await collapsedItemActions.click(); + + const enableSwitch = await testSubjects.find('enableSwitch'); + const isChecked = await enableSwitch.getAttribute('aria-checked'); + expect(isChecked).to.eql('true'); + }); + + // Flaky, will be fixed with https://github.com/elastic/kibana/issues/53956 + it.skip('should delete all selection', async () => { + const createdAlert = await createAlert(); + + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const checkbox = await testSubjects.find(`checkboxSelectRow-${createdAlert.id}`); + await checkbox.click(); + + const bulkActionBtn = await testSubjects.find('bulkAction'); + await bulkActionBtn.click(); + + const deleteAllBtn = await testSubjects.find('deleteAll'); + await deleteAllBtn.click(); + + retry.try(async () => { + await pageObjects.triggersActionsUI.searchAlerts(createdAlert.name); + + const searchResults = await pageObjects.triggersActionsUI.getAlertsList(); + expect(searchResults.length).to.eql(0); + }); + }); + }); +}; diff --git a/x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/connectors.ts b/x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/connectors.ts new file mode 100644 index 0000000000000..7b60685225ac6 --- /dev/null +++ b/x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/connectors.ts @@ -0,0 +1,202 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import uuid from 'uuid'; +import expect from '@kbn/expect'; +import { FtrProviderContext } from '../../ftr_provider_context'; + +function generateUniqueKey() { + return uuid.v4().replace(/-/g, ''); +} + +export default ({ getPageObjects, getService }: FtrProviderContext) => { + const testSubjects = getService('testSubjects'); + const pageObjects = getPageObjects(['common', 'triggersActionsUI', 'header']); + const find = getService('find'); + + describe('Connectors', function() { + before(async () => { + await pageObjects.common.navigateToApp('triggersActions'); + const alertsTab = await testSubjects.find('connectorsTab'); + await alertsTab.click(); + }); + + it('should create a connector', async () => { + const connectorName = generateUniqueKey(); + + await pageObjects.triggersActionsUI.clickCreateConnectorButton(); + + const serverLogCard = await testSubjects.find('.server-log-card'); + await serverLogCard.click(); + + const nameInput = await testSubjects.find('nameInput'); + await nameInput.click(); + await nameInput.clearValue(); + await nameInput.type(connectorName); + + const saveButton = await find.byCssSelector( + '[data-test-subj="saveActionButton"]:not(disabled)' + ); + await saveButton.click(); + + const toastTitle = await pageObjects.common.closeToast(); + expect(toastTitle).to.eql(`Created '${connectorName}'`); + + await pageObjects.triggersActionsUI.searchConnectors(connectorName); + + const searchResults = await pageObjects.triggersActionsUI.getConnectorsList(); + expect(searchResults).to.eql([ + { + name: connectorName, + actionType: 'Server log', + referencedByCount: '0', + }, + ]); + }); + + it('should edit a connector', async () => { + const connectorName = generateUniqueKey(); + const updatedConnectorName = `${connectorName}updated`; + + await pageObjects.triggersActionsUI.clickCreateConnectorButton(); + + const serverLogCard = await testSubjects.find('.server-log-card'); + await serverLogCard.click(); + + const nameInput = await testSubjects.find('nameInput'); + await nameInput.click(); + await nameInput.clearValue(); + await nameInput.type(connectorName); + + const saveButton = await find.byCssSelector( + '[data-test-subj="saveActionButton"]:not(disabled)' + ); + await saveButton.click(); + + await pageObjects.common.closeToast(); + + await pageObjects.triggersActionsUI.searchConnectors(connectorName); + + const searchResultsBeforeEdit = await pageObjects.triggersActionsUI.getConnectorsList(); + expect(searchResultsBeforeEdit.length).to.eql(1); + + const editConnectorBtn = await find.byCssSelector( + '[data-test-subj="connectorsTableCell-name"] button' + ); + await editConnectorBtn.click(); + + const nameInputToUpdate = await testSubjects.find('nameInput'); + await nameInputToUpdate.click(); + await nameInputToUpdate.clearValue(); + await nameInputToUpdate.type(updatedConnectorName); + + const saveEditButton = await find.byCssSelector( + '[data-test-subj="saveActionButton"]:not(disabled)' + ); + await saveEditButton.click(); + + const toastTitle = await pageObjects.common.closeToast(); + expect(toastTitle).to.eql(`Updated '${updatedConnectorName}'`); + + await pageObjects.triggersActionsUI.searchConnectors(updatedConnectorName); + + const searchResultsAfterEdit = await pageObjects.triggersActionsUI.getConnectorsList(); + expect(searchResultsAfterEdit).to.eql([ + { + name: updatedConnectorName, + actionType: 'Server log', + referencedByCount: '0', + }, + ]); + }); + + it('should delete a connector', async () => { + async function createConnector(connectorName: string) { + await pageObjects.triggersActionsUI.clickCreateConnectorButton(); + + const serverLogCard = await testSubjects.find('.server-log-card'); + await serverLogCard.click(); + + const nameInput = await testSubjects.find('nameInput'); + await nameInput.click(); + await nameInput.clearValue(); + await nameInput.type(connectorName); + + const saveButton = await find.byCssSelector( + '[data-test-subj="saveActionButton"]:not(disabled)' + ); + await saveButton.click(); + await pageObjects.common.closeToast(); + } + const connectorName = generateUniqueKey(); + await createConnector(connectorName); + + await createConnector(generateUniqueKey()); + + await pageObjects.triggersActionsUI.searchConnectors(connectorName); + + const searchResultsBeforeDelete = await pageObjects.triggersActionsUI.getConnectorsList(); + expect(searchResultsBeforeDelete.length).to.eql(1); + + const deleteConnectorBtn = await testSubjects.find('deleteConnector'); + await deleteConnectorBtn.click(); + await testSubjects.existOrFail('deleteConnectorsConfirmation'); + await testSubjects.click('deleteConnectorsConfirmation > confirmModalConfirmButton'); + await testSubjects.missingOrFail('deleteConnectorsConfirmation'); + + await pageObjects.triggersActionsUI.searchConnectors(connectorName); + + const searchResultsAfterDelete = await pageObjects.triggersActionsUI.getConnectorsList(); + expect(searchResultsAfterDelete.length).to.eql(0); + }); + + it('should bulk delete connectors', async () => { + async function createConnector(connectorName: string) { + await pageObjects.triggersActionsUI.clickCreateConnectorButton(); + + const serverLogCard = await testSubjects.find('.server-log-card'); + await serverLogCard.click(); + + const nameInput = await testSubjects.find('nameInput'); + await nameInput.click(); + await nameInput.clearValue(); + await nameInput.type(connectorName); + + const saveButton = await find.byCssSelector( + '[data-test-subj="saveActionButton"]:not(disabled)' + ); + await saveButton.click(); + await pageObjects.common.closeToast(); + } + + const connectorName = generateUniqueKey(); + await createConnector(connectorName); + + await createConnector(generateUniqueKey()); + + await pageObjects.triggersActionsUI.searchConnectors(connectorName); + + const searchResultsBeforeDelete = await pageObjects.triggersActionsUI.getConnectorsList(); + expect(searchResultsBeforeDelete.length).to.eql(1); + + const deleteCheckbox = await find.byCssSelector( + '.euiTableRowCellCheckbox .euiCheckbox__input' + ); + await deleteCheckbox.click(); + + const bulkDeleteBtn = await testSubjects.find('bulkDelete'); + await bulkDeleteBtn.click(); + await testSubjects.existOrFail('deleteConnectorsConfirmation'); + await testSubjects.click('deleteConnectorsConfirmation > confirmModalConfirmButton'); + await testSubjects.missingOrFail('deleteConnectorsConfirmation'); + + await pageObjects.triggersActionsUI.searchConnectors(connectorName); + + const searchResultsAfterDelete = await pageObjects.triggersActionsUI.getConnectorsList(); + expect(searchResultsAfterDelete.length).to.eql(0); + }); + }); +}; diff --git a/x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/home_page.ts b/x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/home_page.ts new file mode 100644 index 0000000000000..13f50a505b0b6 --- /dev/null +++ b/x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/home_page.ts @@ -0,0 +1,60 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import expect from '@kbn/expect'; +import { FtrProviderContext } from '../../ftr_provider_context'; + +export default ({ getPageObjects, getService }: FtrProviderContext) => { + const testSubjects = getService('testSubjects'); + const pageObjects = getPageObjects(['common', 'triggersActionsUI', 'header']); + const log = getService('log'); + const browser = getService('browser'); + + describe('Home page', function() { + before(async () => { + await pageObjects.common.navigateToApp('triggersActions'); + }); + + it('Loads the app', async () => { + await log.debug('Checking for section heading to say Triggers and Actions.'); + + const headingText = await pageObjects.triggersActionsUI.getSectionHeadingText(); + expect(headingText).to.be('Alerts and Actions'); + }); + + describe('Connectors tab', () => { + it('renders the connectors tab', async () => { + // Navigate to the connectors tab + pageObjects.triggersActionsUI.changeTabs('connectorsTab'); + + await pageObjects.header.waitUntilLoadingHasFinished(); + + // Verify url + const url = await browser.getCurrentUrl(); + expect(url).to.contain(`/connectors`); + + // Verify content + await testSubjects.existOrFail('actionsList'); + }); + }); + + describe('Alerts tab', () => { + it('renders the alerts tab', async () => { + // Navigate to the alerts tab + pageObjects.triggersActionsUI.changeTabs('alertsTab'); + + await pageObjects.header.waitUntilLoadingHasFinished(); + + // Verify url + const url = await browser.getCurrentUrl(); + expect(url).to.contain(`/alerts`); + + // Verify content + await testSubjects.existOrFail('alertsList'); + }); + }); + }); +}; diff --git a/x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/index.ts b/x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/index.ts new file mode 100644 index 0000000000000..c76f477c8cfbe --- /dev/null +++ b/x-pack/test/functional_with_es_ssl/apps/triggers_actions_ui/index.ts @@ -0,0 +1,16 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { FtrProviderContext } from '../../ftr_provider_context'; + +export default ({ loadTestFile, getService }: FtrProviderContext) => { + describe('Actions and Triggers app', function() { + this.tags('ciGroup3'); + loadTestFile(require.resolve('./home_page')); + loadTestFile(require.resolve('./connectors')); + loadTestFile(require.resolve('./alerts')); + }); +}; diff --git a/x-pack/test/functional_with_es_ssl/config.ts b/x-pack/test/functional_with_es_ssl/config.ts new file mode 100644 index 0000000000000..1a9736b0b4773 --- /dev/null +++ b/x-pack/test/functional_with_es_ssl/config.ts @@ -0,0 +1,59 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { resolve, join } from 'path'; +import { CA_CERT_PATH } from '@kbn/dev-utils'; +import { FtrConfigProviderContext } from '@kbn/test/types/ftr'; +import { services } from './services'; +import { pageObjects } from './page_objects'; + +// eslint-disable-next-line import/no-default-export +export default async function({ readConfigFile }: FtrConfigProviderContext) { + const xpackFunctionalConfig = await readConfigFile(require.resolve('../functional/config.js')); + + const servers = { + ...xpackFunctionalConfig.get('servers'), + elasticsearch: { + ...xpackFunctionalConfig.get('servers.elasticsearch'), + protocol: 'https', + }, + }; + + const returnedObject = { + ...xpackFunctionalConfig.getAll(), + servers, + services, + pageObjects, + // list paths to the files that contain your plugins tests + testFiles: [resolve(__dirname, './apps/triggers_actions_ui')], + apps: { + ...xpackFunctionalConfig.get('apps'), + triggersActions: { + pathname: '/app/kibana', + hash: '/management/kibana/triggersActions', + }, + }, + esTestCluster: { + ...xpackFunctionalConfig.get('esTestCluster'), + ssl: true, + }, + kbnTestServer: { + ...xpackFunctionalConfig.get('kbnTestServer'), + serverArgs: [ + ...xpackFunctionalConfig.get('kbnTestServer.serverArgs'), + `--elasticsearch.hosts=https://${servers.elasticsearch.hostname}:${servers.elasticsearch.port}`, + `--elasticsearch.ssl.certificateAuthorities=${CA_CERT_PATH}`, + `--plugin-path=${join(__dirname, 'fixtures', 'plugins', 'alerts')}`, + '--xpack.actions.enabled=true', + '--xpack.alerting.enabled=true', + '--xpack.triggers_actions_ui.enabled=true', + '--xpack.triggers_actions_ui.createAlertUiEnabled=true', + ], + }, + }; + + return returnedObject; +} diff --git a/x-pack/test/functional_with_es_ssl/fixtures/plugins/alerts/index.ts b/x-pack/test/functional_with_es_ssl/fixtures/plugins/alerts/index.ts new file mode 100644 index 0000000000000..df651c67c2c28 --- /dev/null +++ b/x-pack/test/functional_with_es_ssl/fixtures/plugins/alerts/index.ts @@ -0,0 +1,24 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { AlertType } from '../../../../../legacy/plugins/alerting'; + +// eslint-disable-next-line import/no-default-export +export default function(kibana: any) { + return new kibana.Plugin({ + require: ['alerting'], + name: 'alerts', + init(server: any) { + const noopAlertType: AlertType = { + id: 'test.noop', + name: 'Test: Noop', + actionGroups: ['default'], + async executor() {}, + }; + server.plugins.alerting.setup.registerType(noopAlertType); + }, + }); +} diff --git a/x-pack/test/functional_with_es_ssl/fixtures/plugins/alerts/package.json b/x-pack/test/functional_with_es_ssl/fixtures/plugins/alerts/package.json new file mode 100644 index 0000000000000..836fa09855d8f --- /dev/null +++ b/x-pack/test/functional_with_es_ssl/fixtures/plugins/alerts/package.json @@ -0,0 +1,7 @@ +{ + "name": "alerts", + "version": "0.0.0", + "kibana": { + "version": "kibana" + } +} diff --git a/x-pack/test/functional_with_es_ssl/ftr_provider_context.d.ts b/x-pack/test/functional_with_es_ssl/ftr_provider_context.d.ts new file mode 100644 index 0000000000000..bb257cdcbfe1b --- /dev/null +++ b/x-pack/test/functional_with_es_ssl/ftr_provider_context.d.ts @@ -0,0 +1,12 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { GenericFtrProviderContext } from '@kbn/test/types/ftr'; + +import { pageObjects } from './page_objects'; +import { services } from './services'; + +export type FtrProviderContext = GenericFtrProviderContext; diff --git a/x-pack/test/functional_with_es_ssl/page_objects/index.ts b/x-pack/test/functional_with_es_ssl/page_objects/index.ts new file mode 100644 index 0000000000000..a068ba7dfe81d --- /dev/null +++ b/x-pack/test/functional_with_es_ssl/page_objects/index.ts @@ -0,0 +1,13 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { pageObjects as xpackFunctionalPageObjects } from '../../functional/page_objects'; +import { TriggersActionsPageProvider } from './triggers_actions_ui_page'; + +export const pageObjects = { + ...xpackFunctionalPageObjects, + triggersActionsUI: TriggersActionsPageProvider, +}; diff --git a/x-pack/test/functional_with_es_ssl/page_objects/triggers_actions_ui_page.ts b/x-pack/test/functional_with_es_ssl/page_objects/triggers_actions_ui_page.ts new file mode 100644 index 0000000000000..ce68109771487 --- /dev/null +++ b/x-pack/test/functional_with_es_ssl/page_objects/triggers_actions_ui_page.ts @@ -0,0 +1,97 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { FtrProviderContext } from '../ftr_provider_context'; + +const ENTER_KEY = '\uE007'; + +export function TriggersActionsPageProvider({ getService }: FtrProviderContext) { + const find = getService('find'); + const testSubjects = getService('testSubjects'); + + return { + async getSectionHeadingText() { + return await testSubjects.getVisibleText('appTitle'); + }, + async clickCreateConnectorButton() { + const createBtn = await find.byCssSelector( + '[data-test-subj="createActionButton"],[data-test-subj="createFirstActionButton"]' + ); + await createBtn.click(); + }, + async searchConnectors(searchText: string) { + const searchBox = await find.byCssSelector('[data-test-subj="actionsList"] .euiFieldSearch'); + await searchBox.click(); + await searchBox.clearValue(); + await searchBox.type(searchText); + await searchBox.pressKeys(ENTER_KEY); + await find.byCssSelector( + '.euiBasicTable[data-test-subj="actionsTable"]:not(.euiBasicTable-loading)' + ); + }, + async searchAlerts(searchText: string) { + const searchBox = await testSubjects.find('alertSearchField'); + await searchBox.click(); + await searchBox.clearValue(); + await searchBox.type(searchText); + await searchBox.pressKeys(ENTER_KEY); + await find.byCssSelector( + '.euiBasicTable[data-test-subj="alertsList"]:not(.euiBasicTable-loading)' + ); + }, + async getConnectorsList() { + const table = await find.byCssSelector('[data-test-subj="actionsList"] table'); + const $ = await table.parseDomContent(); + return $.findTestSubjects('connectors-row') + .toArray() + .map(row => { + return { + name: $(row) + .findTestSubject('connectorsTableCell-name') + .find('.euiTableCellContent') + .text(), + actionType: $(row) + .findTestSubject('connectorsTableCell-actionType') + .find('.euiTableCellContent') + .text(), + referencedByCount: $(row) + .findTestSubject('connectorsTableCell-referencedByCount') + .find('.euiTableCellContent') + .text(), + }; + }); + }, + async getAlertsList() { + const table = await find.byCssSelector('[data-test-subj="alertsList"] table'); + const $ = await table.parseDomContent(); + return $.findTestSubjects('alert-row') + .toArray() + .map(row => { + return { + name: $(row) + .findTestSubject('alertsTableCell-name') + .find('.euiTableCellContent') + .text(), + tagsText: $(row) + .findTestSubject('alertsTableCell-tagsText') + .find('.euiTableCellContent') + .text(), + alertType: $(row) + .findTestSubject('alertsTableCell-alertType') + .find('.euiTableCellContent') + .text(), + interval: $(row) + .findTestSubject('alertsTableCell-interval') + .find('.euiTableCellContent') + .text(), + }; + }); + }, + async changeTabs(tab: 'alertsTab' | 'connectorsTab') { + return await testSubjects.click(tab); + }, + }; +} diff --git a/x-pack/test/functional_with_es_ssl/services/index.ts b/x-pack/test/functional_with_es_ssl/services/index.ts new file mode 100644 index 0000000000000..6e96921c25a31 --- /dev/null +++ b/x-pack/test/functional_with_es_ssl/services/index.ts @@ -0,0 +1,11 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { services as xpackFunctionalServices } from '../../functional/services'; + +export const services = { + ...xpackFunctionalServices, +}; From e5c17fb0cdc6ce00e0c64da75ec4a7d45db9e52d Mon Sep 17 00:00:00 2001 From: Brian Seeders Date: Mon, 13 Jan 2020 21:53:35 -0500 Subject: [PATCH 066/139] Skip failing uptime tests --- .../location_map/__tests__/location_status_tags.test.tsx | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/location_status_tags.test.tsx b/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/location_status_tags.test.tsx index 21e5881654533..40ce2169fa00f 100644 --- a/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/location_status_tags.test.tsx +++ b/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/location_status_tags.test.tsx @@ -10,7 +10,8 @@ import { renderWithIntl } from 'test_utils/enzyme_helpers'; import { MonitorLocation } from '../../../../../common/runtime_types/monitor'; import { LocationStatusTags } from '../'; -describe('StatusByLocation component', () => { +// Failing: https://github.com/elastic/kibana/issues/54672 +describe.skip('StatusByLocation component', () => { let monitorLocations: MonitorLocation[]; const start = moment('2020-01-10T12:22:32.567Z'); From 72dd68e3b424f3c0510e45d279b455b0ded9b845 Mon Sep 17 00:00:00 2001 From: Andrew Cholakian Date: Mon, 13 Jan 2020 21:05:07 -0600 Subject: [PATCH 067/139] [Uptime] Temporarily skip flakey tests (#54675) * [Uptime] Temporarily skip flakey tests * Fix further flakey tests due to hardcoding times + using snapshots --- .../location_map/__tests__/location_status_tags.test.tsx | 1 + .../__test__/status_by_location.test.tsx | 2 +- x-pack/test/functional/apps/uptime/overview.ts | 6 ++++-- 3 files changed, 6 insertions(+), 3 deletions(-) diff --git a/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/location_status_tags.test.tsx b/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/location_status_tags.test.tsx index 40ce2169fa00f..de04347148bb2 100644 --- a/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/location_status_tags.test.tsx +++ b/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/location_status_tags.test.tsx @@ -10,6 +10,7 @@ import { renderWithIntl } from 'test_utils/enzyme_helpers'; import { MonitorLocation } from '../../../../../common/runtime_types/monitor'; import { LocationStatusTags } from '../'; +// These tests use absolute time // Failing: https://github.com/elastic/kibana/issues/54672 describe.skip('StatusByLocation component', () => { let monitorLocations: MonitorLocation[]; diff --git a/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/__test__/status_by_location.test.tsx b/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/__test__/status_by_location.test.tsx index 38864103564ca..ac6a1baf8a110 100644 --- a/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/__test__/status_by_location.test.tsx +++ b/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/__test__/status_by_location.test.tsx @@ -9,7 +9,7 @@ import { renderWithIntl } from 'test_utils/enzyme_helpers'; import { MonitorLocation } from '../../../../../common/runtime_types'; import { StatusByLocations } from '../'; -describe('StatusByLocation component', () => { +describe.skip('StatusByLocation component', () => { let monitorLocations: MonitorLocation[]; it('renders when up in all locations', () => { diff --git a/x-pack/test/functional/apps/uptime/overview.ts b/x-pack/test/functional/apps/uptime/overview.ts index bcfb72967b75a..ba701da6e517d 100644 --- a/x-pack/test/functional/apps/uptime/overview.ts +++ b/x-pack/test/functional/apps/uptime/overview.ts @@ -50,7 +50,8 @@ export default ({ getPageObjects }: FtrProviderContext) => { ]); }); - it('pagination is cleared when filter criteria changes', async () => { + // flakey see https://github.com/elastic/kibana/issues/54527 + it.skip('pagination is cleared when filter criteria changes', async () => { await pageObjects.uptime.goToUptimePageAndSetDateRange(DEFAULT_DATE_START, DEFAULT_DATE_END); await pageObjects.uptime.changePage('next'); // there should now be pagination data in the URL @@ -86,7 +87,8 @@ export default ({ getPageObjects }: FtrProviderContext) => { ]); }); - describe('snapshot counts', () => { + // Flakey, see https://github.com/elastic/kibana/issues/54541 + describe.skip('snapshot counts', () => { it('updates the snapshot count when status filter is set to down', async () => { await pageObjects.uptime.goToUptimePageAndSetDateRange( DEFAULT_DATE_START, From 1db7a9a0b91bc04eceea50764a8d0cd9859319ef Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Tue, 14 Jan 2020 00:00:20 -0500 Subject: [PATCH 068/139] check for valid config --- .../vector/components/color/color_map_select.js | 12 ++++++++++-- .../vector/properties/dynamic_color_property.js | 7 ++++++- 2 files changed, 16 insertions(+), 3 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js index 8d7e1aec1bd7d..6e9ca464133ac 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js @@ -56,6 +56,15 @@ export class ColorMapSelect extends Component { this.props.onChange(newProps); }; + componentDidUpdate(prevProps) { + if (!prevProps.useCustomColorMap) { + if (!prevProps.colorMapOptions.find(option => option.value === prevProps.color)) { + const nw = this.props.colorMapOptions[0].value; + this._onColorMapSelect(nw); + } + } + } + render() { const { color, useCustomColorMap } = this.props; @@ -99,8 +108,7 @@ export class ColorMapSelect extends Component { if (colorMapOptionsWithCustom.find(option => option.value === color)) { valueOfSelected = color; } else { - valueOfSelected = this.props.colorMapOptions[0].value; - this._onColorMapSelect(valueOfSelected); + return null; } } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js index 26bfb087f119c..7cf85e936d4eb 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js @@ -123,6 +123,10 @@ export class DynamicColorProperty extends DynamicStyleProperty { } const colorStops = this._getMbOrdinalColorStops(); + if (!colorStops) { + return null; + } + if (this._options.useCustomColorRamp) { const firstStopValue = colorStops[0]; const lessThenFirstStopValue = firstStopValue - 1; @@ -198,7 +202,8 @@ export class DynamicColorProperty extends DynamicStyleProperty { } const paletteStops = this._getColorPaletteStops(); - if (!paletteStops.length) { + if (paletteStops.length < 2) { + //occurs when no data return null; } From c4b44751a7e3a3aaba6ebceddeb1f771b9cf3fba Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Tue, 14 Jan 2020 00:24:22 -0500 Subject: [PATCH 069/139] also on mount --- .../components/color/color_map_select.js | 54 +++++++++++-------- 1 file changed, 33 insertions(+), 21 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js index 6e9ca464133ac..8149e9b5c58a9 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js @@ -14,7 +14,9 @@ import { ColorStopsCategorical } from './color_stops_categorical'; const CUSTOM_COLOR_MAP = 'CUSTOM_COLOR_MAP'; export class ColorMapSelect extends Component { - state = {}; + state = { + selected: null, + }; static getDerivedStateFromProps(nextProps, prevState) { if (nextProps.customColorMap === prevState.prevPropsCustomColorMap) { @@ -56,20 +58,41 @@ export class ColorMapSelect extends Component { this.props.onChange(newProps); }; - componentDidUpdate(prevProps) { - if (!prevProps.useCustomColorMap) { - if (!prevProps.colorMapOptions.find(option => option.value === prevProps.color)) { - const nw = this.props.colorMapOptions[0].value; - this._onColorMapSelect(nw); + componentDidMount() { + this._updateSelected(); + } + + componentDidUpdate() { + this._updateSelected(); + } + + _updateSelected() { + const { color, useCustomColorMap, colorMapOptions } = this.props; + let valueOfSelected; + let shouldUpdate = false; + if (useCustomColorMap) { + valueOfSelected = CUSTOM_COLOR_MAP; + } else { + if (colorMapOptions.find(option => option.value === color)) { + valueOfSelected = color; + } else { + valueOfSelected = colorMapOptions[0].value; + shouldUpdate = true; } } + + if (this.state.selected !== valueOfSelected) { + this.setState({ selected: valueOfSelected }, () => { + if (shouldUpdate) { + this._onColorMapSelect(valueOfSelected); + } + }); + } } render() { - const { color, useCustomColorMap } = this.props; - let colorStopsInput; - if (useCustomColorMap) { + if (this.props.useCustomColorMap) { if (this.props.colorMapType === COLOR_MAP_TYPE.ORDINAL) { colorStopsInput = ( @@ -93,7 +116,6 @@ export class ColorMapSelect extends Component { } } - let valueOfSelected; const colorMapOptionsWithCustom = [ { value: CUSTOM_COLOR_MAP, @@ -102,22 +124,12 @@ export class ColorMapSelect extends Component { ...this.props.colorMapOptions, ]; - if (useCustomColorMap) { - valueOfSelected = CUSTOM_COLOR_MAP; - } else { - if (colorMapOptionsWithCustom.find(option => option.value === color)) { - valueOfSelected = color; - } else { - return null; - } - } - return ( {colorStopsInput} From 748a753923b83b1995905070bac5fefc02d2cce7 Mon Sep 17 00:00:00 2001 From: Eli Perelman Date: Tue, 14 Jan 2020 00:39:56 -0600 Subject: [PATCH 070/139] Remove extraneous public import to prevent failing Kibana startup (#54676) Co-authored-by: Elastic Machine --- src/core/server/types.ts | 1 - 1 file changed, 1 deletion(-) diff --git a/src/core/server/types.ts b/src/core/server/types.ts index 9919c7f0386b5..2433aad1a2be5 100644 --- a/src/core/server/types.ts +++ b/src/core/server/types.ts @@ -23,4 +23,3 @@ export * from './saved_objects/types'; export * from './ui_settings/types'; export * from './legacy/types'; export { EnvironmentMode, PackageInfo } from './config/types'; -export { ICspConfig } from './csp'; From f71142dcd39e68aa4ddd9ea86bd903e124c2853b Mon Sep 17 00:00:00 2001 From: Pierre Gayvallet Date: Tue, 14 Jan 2020 08:40:15 +0100 Subject: [PATCH 071/139] Fix chromeless NP apps not using full page width (#54550) * add missing conditional classes on app-wrapper and application containers * update snapshot * refactor and add unit tests for service * typo * use consistent classNames naming --- src/core/public/chrome/chrome_service.tsx | 2 +- .../public/rendering/app_containers.test.tsx | 105 ++++++++++++ src/core/public/rendering/app_containers.tsx | 37 +++++ .../rendering/rendering_service.test.tsx | 151 ++++++++++++------ .../public/rendering/rendering_service.tsx | 7 +- .../test_suites/core_plugins/applications.ts | 14 ++ 6 files changed, 264 insertions(+), 52 deletions(-) create mode 100644 src/core/public/rendering/app_containers.test.tsx create mode 100644 src/core/public/rendering/app_containers.tsx diff --git a/src/core/public/chrome/chrome_service.tsx b/src/core/public/chrome/chrome_service.tsx index a674b49a8e134..09ea1afe35766 100644 --- a/src/core/public/chrome/chrome_service.tsx +++ b/src/core/public/chrome/chrome_service.tsx @@ -127,7 +127,7 @@ export class ChromeService { ) ) ); - this.isVisible$ = combineLatest(this.appHidden$, this.toggleHidden$).pipe( + this.isVisible$ = combineLatest([this.appHidden$, this.toggleHidden$]).pipe( map(([appHidden, toggleHidden]) => !(appHidden || toggleHidden)), takeUntil(this.stop$) ); diff --git a/src/core/public/rendering/app_containers.test.tsx b/src/core/public/rendering/app_containers.test.tsx new file mode 100644 index 0000000000000..746e37b1214d9 --- /dev/null +++ b/src/core/public/rendering/app_containers.test.tsx @@ -0,0 +1,105 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +import { BehaviorSubject } from 'rxjs'; +import { act } from 'react-dom/test-utils'; +import { mount } from 'enzyme'; +import React from 'react'; + +import { AppWrapper, AppContainer } from './app_containers'; + +describe('AppWrapper', () => { + it('toggles the `hidden-chrome` class depending on the chrome visibility state', () => { + const chromeVisible$ = new BehaviorSubject(true); + + const component = mount(app-content); + expect(component.getDOMNode()).toMatchInlineSnapshot(` +
+ app-content +
+ `); + + act(() => chromeVisible$.next(false)); + component.update(); + expect(component.getDOMNode()).toMatchInlineSnapshot(` +
+ app-content +
+ `); + + act(() => chromeVisible$.next(true)); + component.update(); + expect(component.getDOMNode()).toMatchInlineSnapshot(` +
+ app-content +
+ `); + }); +}); + +describe('AppContainer', () => { + it('adds classes supplied by chrome', () => { + const appClasses$ = new BehaviorSubject([]); + + const component = mount(app-content); + expect(component.getDOMNode()).toMatchInlineSnapshot(` +
+ app-content +
+ `); + + act(() => appClasses$.next(['classA', 'classB'])); + component.update(); + expect(component.getDOMNode()).toMatchInlineSnapshot(` +
+ app-content +
+ `); + + act(() => appClasses$.next(['classC'])); + component.update(); + expect(component.getDOMNode()).toMatchInlineSnapshot(` +
+ app-content +
+ `); + + act(() => appClasses$.next([])); + component.update(); + expect(component.getDOMNode()).toMatchInlineSnapshot(` +
+ app-content +
+ `); + }); +}); diff --git a/src/core/public/rendering/app_containers.tsx b/src/core/public/rendering/app_containers.tsx new file mode 100644 index 0000000000000..72faaeac588be --- /dev/null +++ b/src/core/public/rendering/app_containers.tsx @@ -0,0 +1,37 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +import React from 'react'; +import { Observable } from 'rxjs'; +import useObservable from 'react-use/lib/useObservable'; +import classNames from 'classnames'; + +export const AppWrapper: React.FunctionComponent<{ + chromeVisible$: Observable; +}> = ({ chromeVisible$, children }) => { + const visible = useObservable(chromeVisible$); + return
{children}
; +}; + +export const AppContainer: React.FunctionComponent<{ + classes$: Observable; +}> = ({ classes$, children }) => { + const classes = useObservable(classes$); + return
{children}
; +}; diff --git a/src/core/public/rendering/rendering_service.test.tsx b/src/core/public/rendering/rendering_service.test.tsx index ed835574a32f9..437a602a3d447 100644 --- a/src/core/public/rendering/rendering_service.test.tsx +++ b/src/core/public/rendering/rendering_service.test.tsx @@ -18,72 +18,129 @@ */ import React from 'react'; +import { act } from 'react-dom/test-utils'; -import { chromeServiceMock } from '../chrome/chrome_service.mock'; import { RenderingService } from './rendering_service'; -import { InternalApplicationStart } from '../application'; +import { applicationServiceMock } from '../application/application_service.mock'; +import { chromeServiceMock } from '../chrome/chrome_service.mock'; import { injectedMetadataServiceMock } from '../injected_metadata/injected_metadata_service.mock'; import { overlayServiceMock } from '../overlays/overlay_service.mock'; +import { BehaviorSubject } from 'rxjs'; describe('RenderingService#start', () => { - const getService = ({ legacyMode = false }: { legacyMode?: boolean } = {}) => { - const rendering = new RenderingService(); - const application = { - getComponent: () =>
Hello application!
, - } as InternalApplicationStart; - const chrome = chromeServiceMock.createStartContract(); + let application: ReturnType; + let chrome: ReturnType; + let overlays: ReturnType; + let injectedMetadata: ReturnType; + let targetDomElement: HTMLDivElement; + let rendering: RenderingService; + + beforeEach(() => { + application = applicationServiceMock.createInternalStartContract(); + application.getComponent.mockReturnValue(
Hello application!
); + + chrome = chromeServiceMock.createStartContract(); chrome.getHeaderComponent.mockReturnValue(
Hello chrome!
); - const overlays = overlayServiceMock.createStartContract(); + + overlays = overlayServiceMock.createStartContract(); overlays.banners.getComponent.mockReturnValue(
I'm a banner!
); - const injectedMetadata = injectedMetadataServiceMock.createStartContract(); - injectedMetadata.getLegacyMode.mockReturnValue(legacyMode); - const targetDomElement = document.createElement('div'); - const start = rendering.start({ + injectedMetadata = injectedMetadataServiceMock.createStartContract(); + + targetDomElement = document.createElement('div'); + + rendering = new RenderingService(); + }); + + const startService = () => { + return rendering.start({ application, chrome, injectedMetadata, overlays, targetDomElement, }); - return { start, targetDomElement }; }; - it('renders application service into provided DOM element', () => { - const { targetDomElement } = getService(); - expect(targetDomElement.querySelector('div.application')).toMatchInlineSnapshot(` -
-
- Hello application! -
-
- `); - }); + describe('standard mode', () => { + beforeEach(() => { + injectedMetadata.getLegacyMode.mockReturnValue(false); + }); - it('contains wrapper divs', () => { - const { targetDomElement } = getService(); - expect(targetDomElement.querySelector('div.app-wrapper')).toBeDefined(); - expect(targetDomElement.querySelector('div.app-wrapper-pannel')).toBeDefined(); - }); + it('renders application service into provided DOM element', () => { + startService(); + expect(targetDomElement.querySelector('div.application')).toMatchInlineSnapshot(` +
+
+ Hello application! +
+
+ `); + }); + + it('adds the `chrome-hidden` class to the AppWrapper when chrome is hidden', () => { + const isVisible$ = new BehaviorSubject(true); + chrome.getIsVisible$.mockReturnValue(isVisible$); + startService(); + + const appWrapper = targetDomElement.querySelector('div.app-wrapper')!; + expect(appWrapper.className).toEqual('app-wrapper'); + + act(() => isVisible$.next(false)); + expect(appWrapper.className).toEqual('app-wrapper hidden-chrome'); - it('renders the banner UI', () => { - const { targetDomElement } = getService(); - expect(targetDomElement.querySelector('#globalBannerList')).toMatchInlineSnapshot(` -
-
- I'm a banner! -
-
- `); + act(() => isVisible$.next(true)); + expect(appWrapper.className).toEqual('app-wrapper'); + }); + + it('adds the application classes to the AppContainer', () => { + const applicationClasses$ = new BehaviorSubject([]); + chrome.getApplicationClasses$.mockReturnValue(applicationClasses$); + startService(); + + const appContainer = targetDomElement.querySelector('div.application')!; + expect(appContainer.className).toEqual('application'); + + act(() => applicationClasses$.next(['classA', 'classB'])); + expect(appContainer.className).toEqual('application classA classB'); + + act(() => applicationClasses$.next(['classC'])); + expect(appContainer.className).toEqual('application classC'); + + act(() => applicationClasses$.next([])); + expect(appContainer.className).toEqual('application'); + }); + + it('contains wrapper divs', () => { + startService(); + expect(targetDomElement.querySelector('div.app-wrapper')).toBeDefined(); + expect(targetDomElement.querySelector('div.app-wrapper-pannel')).toBeDefined(); + }); + + it('renders the banner UI', () => { + startService(); + expect(targetDomElement.querySelector('#globalBannerList')).toMatchInlineSnapshot(` +
+
+ I'm a banner! +
+
+ `); + }); }); - describe('legacyMode', () => { + describe('legacy mode', () => { + beforeEach(() => { + injectedMetadata.getLegacyMode.mockReturnValue(true); + }); + it('renders into provided DOM element', () => { - const { targetDomElement } = getService({ legacyMode: true }); + startService(); + expect(targetDomElement).toMatchInlineSnapshot(`
{ }); it('returns a div for the legacy service to render into', () => { - const { - start: { legacyTargetDomElement }, - targetDomElement, - } = getService({ legacyMode: true }); + const { legacyTargetDomElement } = startService(); + expect(targetDomElement.contains(legacyTargetDomElement!)).toBe(true); }); }); diff --git a/src/core/public/rendering/rendering_service.tsx b/src/core/public/rendering/rendering_service.tsx index 7a747faa2673f..58b8c1921e333 100644 --- a/src/core/public/rendering/rendering_service.tsx +++ b/src/core/public/rendering/rendering_service.tsx @@ -25,6 +25,7 @@ import { InternalChromeStart } from '../chrome'; import { InternalApplicationStart } from '../application'; import { InjectedMetadataStart } from '../injected_metadata'; import { OverlayStart } from '../overlays'; +import { AppWrapper, AppContainer } from './app_containers'; interface StartDeps { application: InternalApplicationStart; @@ -65,12 +66,12 @@ export class RenderingService { {chromeUi} {!legacyMode && ( -
+
{bannerUi}
-
{appUi}
+ {appUi}
-
+ )} {legacyMode &&
} diff --git a/test/plugin_functional/test_suites/core_plugins/applications.ts b/test/plugin_functional/test_suites/core_plugins/applications.ts index a3c9d9d63e353..231458fad155b 100644 --- a/test/plugin_functional/test_suites/core_plugins/applications.ts +++ b/test/plugin_functional/test_suites/core_plugins/applications.ts @@ -27,12 +27,18 @@ export default function({ getService, getPageObjects }: PluginFunctionalProvider const browser = getService('browser'); const appsMenu = getService('appsMenu'); const testSubjects = getService('testSubjects'); + const find = getService('find'); const loadingScreenNotShown = async () => expect(await testSubjects.exists('kbnLoadingMessage')).to.be(false); const loadingScreenShown = () => testSubjects.existOrFail('kbnLoadingMessage'); + const getAppWrapperWidth = async () => { + const wrapper = await find.byClassName('app-wrapper'); + return (await wrapper.getSize()).width; + }; + const getKibanaUrl = (pathname?: string, search?: string) => url.format({ protocol: 'http:', @@ -99,12 +105,20 @@ export default function({ getService, getPageObjects }: PluginFunctionalProvider await PageObjects.common.navigateToApp('chromeless'); await loadingScreenNotShown(); expect(await testSubjects.exists('headerGlobalNav')).to.be(false); + + const wrapperWidth = await getAppWrapperWidth(); + const windowWidth = (await browser.getWindowSize()).width; + expect(wrapperWidth).to.eql(windowWidth); }); it('navigating away from chromeless application shows chrome', async () => { await PageObjects.common.navigateToApp('foo'); await loadingScreenNotShown(); expect(await testSubjects.exists('headerGlobalNav')).to.be(true); + + const wrapperWidth = await getAppWrapperWidth(); + const windowWidth = (await browser.getWindowSize()).width; + expect(wrapperWidth).to.be.below(windowWidth); }); it.skip('can navigate from NP apps to legacy apps', async () => { From 7c4a531ae7b42d306ca353a283d096d5521c605c Mon Sep 17 00:00:00 2001 From: patrykkopycinski Date: Tue, 14 Jan 2020 08:50:49 +0100 Subject: [PATCH 072/139] =?UTF-8?q?[SIEM]=20Fix=20Inspect=20query=20'reque?= =?UTF-8?q?st=20timestamp'=20value=20changes=20when=20curso=E2=80=A6=20(#5?= =?UTF-8?q?4223)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../events_viewer/events_viewer.tsx | 307 +++-- .../components/events_viewer/index.test.tsx | 38 +- .../public/components/events_viewer/index.tsx | 249 ++-- .../components/header_section/index.test.tsx | 30 - .../components/header_section/index.tsx | 78 +- .../public/components/inspect/index.test.tsx | 62 +- .../siem/public/components/inspect/index.tsx | 196 +-- .../components/matrix_histogram/index.tsx | 63 +- .../page/hosts/host_overview/index.tsx | 45 +- .../page/network/ip_overview/index.tsx | 45 +- .../page/overview/overview_host/index.tsx | 23 +- .../page/overview/overview_network/index.tsx | 24 +- .../__snapshots__/index.test.tsx.snap | 2 +- .../components/paginated_table/index.tsx | 228 ++-- .../__snapshots__/index.test.tsx.snap | 1138 ++++++++--------- .../public/components/stat_items/index.tsx | 128 +- .../timeline/properties/properties_right.tsx | 97 +- 17 files changed, 1327 insertions(+), 1426 deletions(-) diff --git a/x-pack/legacy/plugins/siem/public/components/events_viewer/events_viewer.tsx b/x-pack/legacy/plugins/siem/public/components/events_viewer/events_viewer.tsx index aaf88e68684ca..2c669c259d07e 100644 --- a/x-pack/legacy/plugins/siem/public/components/events_viewer/events_viewer.tsx +++ b/x-pack/legacy/plugins/siem/public/components/events_viewer/events_viewer.tsx @@ -59,7 +59,6 @@ interface Props { kqlMode: KqlMode; onChangeItemsPerPage: OnChangeItemsPerPage; query: Query; - showInspect: boolean; start: number; sort: Sort; timelineTypeContext: TimelineTypeContextProps; @@ -67,171 +66,171 @@ interface Props { utilityBar?: (totalCount: number) => React.ReactNode; } -export const EventsViewer = React.memo( - ({ - browserFields, - columns, +const EventsViewerComponent: React.FC = ({ + browserFields, + columns, + dataProviders, + deletedEventIds, + end, + filters, + headerFilterGroup, + height = DEFAULT_EVENTS_VIEWER_HEIGHT, + id, + indexPattern, + isLive, + itemsPerPage, + itemsPerPageOptions, + kqlMode, + onChangeItemsPerPage, + query, + start, + sort, + timelineTypeContext, + toggleColumn, + utilityBar, +}) => { + const columnsHeader = isEmpty(columns) ? defaultHeaders : columns; + const kibana = useKibana(); + const combinedQueries = combineQueries({ + config: esQuery.getEsQueryConfig(kibana.services.uiSettings), dataProviders, - deletedEventIds, - end, - filters, - headerFilterGroup, - height = DEFAULT_EVENTS_VIEWER_HEIGHT, - id, indexPattern, - isLive, - itemsPerPage, - itemsPerPageOptions, + browserFields, + filters, + kqlQuery: query, kqlMode, - onChangeItemsPerPage, - query, - showInspect, start, - sort, - timelineTypeContext, - toggleColumn, - utilityBar, - }) => { - const columnsHeader = isEmpty(columns) ? defaultHeaders : columns; - const kibana = useKibana(); - const combinedQueries = combineQueries({ - config: esQuery.getEsQueryConfig(kibana.services.uiSettings), - dataProviders, - indexPattern, - browserFields, - filters, - kqlQuery: query, - kqlMode, - start, - end, - isEventViewer: true, - }); - const queryFields = useMemo( - () => - union( - columnsHeader.map(c => c.id), - timelineTypeContext.queryFields ?? [] - ), - [columnsHeader, timelineTypeContext.queryFields] - ); + end, + isEventViewer: true, + }); + const queryFields = useMemo( + () => + union( + columnsHeader.map(c => c.id), + timelineTypeContext.queryFields ?? [] + ), + [columnsHeader, timelineTypeContext.queryFields] + ); - return ( - - - {({ measureRef, content: { width = 0 } }) => ( - <> - -
- + return ( + + + {({ measureRef, content: { width = 0 } }) => ( + <> + +
+ - {combinedQueries != null ? ( - - {({ - events, - getUpdatedAt, - inspect, - loading, - loadMore, - pageInfo, - refetch, - totalCount = 0, - }) => { - const totalCountMinusDeleted = - totalCount > 0 ? totalCount - deletedEventIds.length : 0; + {combinedQueries != null ? ( + + {({ + events, + getUpdatedAt, + inspect, + loading, + loadMore, + pageInfo, + refetch, + totalCount = 0, + }) => { + const totalCountMinusDeleted = + totalCount > 0 ? totalCount - deletedEventIds.length : 0; - // TODO: Reset eventDeletedIds/eventLoadingIds on refresh/loadmore (getUpdatedAt) - return ( - <> - - {headerFilterGroup} - + // TODO: Reset eventDeletedIds/eventLoadingIds on refresh/loadmore (getUpdatedAt) + return ( + <> + + {headerFilterGroup} + - {utilityBar?.(totalCountMinusDeleted)} + {utilityBar?.(totalCountMinusDeleted)} -
+ - - + refetch={refetch} + /> + + !deletedEventIds.includes(e._id))} + id={id} + isEventViewer={true} + height={height} + sort={sort} + toggleColumn={toggleColumn} + /> - !deletedEventIds.includes(e._id))} - id={id} - isEventViewer={true} - height={height} - sort={sort} - toggleColumn={toggleColumn} - /> +
+ +
+ + ); + }} +
+ ) : null} + + )} + + + ); +}; -
- -
- - ); - }} - - ) : null} - - )} -
-
- ); - }, +export const EventsViewer = React.memo( + EventsViewerComponent, (prevProps, nextProps) => prevProps.browserFields === nextProps.browserFields && prevProps.columns === nextProps.columns && @@ -247,10 +246,8 @@ export const EventsViewer = React.memo( prevProps.itemsPerPageOptions === nextProps.itemsPerPageOptions && prevProps.kqlMode === nextProps.kqlMode && isEqual(prevProps.query, nextProps.query) && - prevProps.showInspect === nextProps.showInspect && prevProps.start === nextProps.start && prevProps.sort === nextProps.sort && isEqual(prevProps.timelineTypeContext, nextProps.timelineTypeContext) && prevProps.utilityBar === nextProps.utilityBar ); -EventsViewer.displayName = 'EventsViewer'; diff --git a/x-pack/legacy/plugins/siem/public/components/events_viewer/index.test.tsx b/x-pack/legacy/plugins/siem/public/components/events_viewer/index.test.tsx index 1e225dabb2541..ec8d329f1dfe3 100644 --- a/x-pack/legacy/plugins/siem/public/components/events_viewer/index.test.tsx +++ b/x-pack/legacy/plugins/siem/public/components/events_viewer/index.test.tsx @@ -57,7 +57,8 @@ describe('StatefulEventsViewer', () => { ).toBe(true); }); - test('it renders a transparent inspect button when it does NOT have mouse focus', async () => { + // InspectButtonContainer controls displaying InspectButton components + test('it renders InspectButtonContainer', async () => { const wrapper = mount( @@ -74,39 +75,6 @@ describe('StatefulEventsViewer', () => { await wait(); wrapper.update(); - expect( - wrapper - .find(`[data-test-subj="transparent-inspect-container"]`) - .first() - .exists() - ).toBe(true); - }); - - test('it renders an opaque inspect button when it has mouse focus', async () => { - const wrapper = mount( - - - - - - ); - - await wait(); - wrapper.update(); - - wrapper.simulate('mouseenter'); - wrapper.update(); - - expect( - wrapper - .find(`[data-test-subj="opaque-inspect-container"]`) - .first() - .exists() - ).toBe(true); + expect(wrapper.find(`InspectButtonContainer`).exists()).toBe(true); }); }); diff --git a/x-pack/legacy/plugins/siem/public/components/events_viewer/index.tsx b/x-pack/legacy/plugins/siem/public/components/events_viewer/index.tsx index 9b8ec243d5f38..99d174d74f3f8 100644 --- a/x-pack/legacy/plugins/siem/public/components/events_viewer/index.tsx +++ b/x-pack/legacy/plugins/siem/public/components/events_viewer/index.tsx @@ -5,7 +5,7 @@ */ import { isEqual } from 'lodash/fp'; -import React, { useCallback, useEffect, useState } from 'react'; +import React, { useCallback, useEffect } from 'react'; import { connect } from 'react-redux'; import { ActionCreator } from 'typescript-fsa'; import { inputsModel, inputsSelectors, State, timelineSelectors } from '../../store'; @@ -23,6 +23,7 @@ import { InputsModelId } from '../../store/inputs/constants'; import { useFetchIndexPatterns } from '../../containers/detection_engine/rules/fetch_index_patterns'; import { TimelineTypeContextProps } from '../timeline/timeline_context'; import { DEFAULT_INDEX_KEY } from '../../../common/constants'; +import { InspectButtonContainer } from '../inspect'; import * as i18n from './translations'; export interface OwnProps { @@ -83,133 +84,102 @@ interface DispatchProps { type Props = OwnProps & StateReduxProps & DispatchProps; -const StatefulEventsViewerComponent = React.memo( - ({ - createTimeline, - columns, - dataProviders, - defaultModel, - deletedEventIds, - defaultIndices, - deleteEventQuery, - end, - filters, - headerFilterGroup, - id, - isLive, - itemsPerPage, - itemsPerPageOptions, - kqlMode, - pageFilters = [], - query, - removeColumn, - start, - showCheckboxes, - showRowRenderers, - sort, - timelineTypeContext = { - loadingText: i18n.LOADING_EVENTS, - }, - updateItemsPerPage, - upsertColumn, - utilityBar, - }) => { - const [showInspect, setShowInspect] = useState(false); - const [{ browserFields, indexPatterns }] = useFetchIndexPatterns( - defaultIndices ?? useUiSetting(DEFAULT_INDEX_KEY) - ); - - useEffect(() => { - if (createTimeline != null) { - createTimeline({ id, columns, sort, itemsPerPage, showCheckboxes, showRowRenderers }); - } - return () => { - deleteEventQuery({ id, inputId: 'global' }); - }; - }, []); - - const onChangeItemsPerPage: OnChangeItemsPerPage = useCallback( - itemsChangedPerPage => updateItemsPerPage({ id, itemsPerPage: itemsChangedPerPage }), - [id, updateItemsPerPage] - ); - - const toggleColumn = useCallback( - (column: ColumnHeader) => { - const exists = columns.findIndex(c => c.id === column.id) !== -1; - - if (!exists && upsertColumn != null) { - upsertColumn({ - column, - id, - index: 1, - }); - } - - if (exists && removeColumn != null) { - removeColumn({ - columnId: column.id, - id, - }); - } - }, - [columns, id, upsertColumn, removeColumn] - ); - - const handleOnMouseEnter = useCallback(() => setShowInspect(true), []); - const handleOnMouseLeave = useCallback(() => setShowInspect(false), []); - - return ( -
- -
- ); +const StatefulEventsViewerComponent: React.FC = ({ + createTimeline, + columns, + dataProviders, + deletedEventIds, + defaultIndices, + deleteEventQuery, + end, + filters, + headerFilterGroup, + id, + isLive, + itemsPerPage, + itemsPerPageOptions, + kqlMode, + pageFilters = [], + query, + removeColumn, + start, + showCheckboxes, + showRowRenderers, + sort, + timelineTypeContext = { + loadingText: i18n.LOADING_EVENTS, }, - (prevProps, nextProps) => - prevProps.id === nextProps.id && - isEqual(prevProps.columns, nextProps.columns) && - isEqual(prevProps.dataProviders, nextProps.dataProviders) && - prevProps.deletedEventIds === nextProps.deletedEventIds && - prevProps.end === nextProps.end && - isEqual(prevProps.filters, nextProps.filters) && - prevProps.isLive === nextProps.isLive && - prevProps.itemsPerPage === nextProps.itemsPerPage && - isEqual(prevProps.itemsPerPageOptions, nextProps.itemsPerPageOptions) && - prevProps.kqlMode === nextProps.kqlMode && - isEqual(prevProps.query, nextProps.query) && - prevProps.pageCount === nextProps.pageCount && - isEqual(prevProps.sort, nextProps.sort) && - prevProps.start === nextProps.start && - isEqual(prevProps.pageFilters, nextProps.pageFilters) && - prevProps.showCheckboxes === nextProps.showCheckboxes && - prevProps.showRowRenderers === nextProps.showRowRenderers && - prevProps.start === nextProps.start && - isEqual(prevProps.timelineTypeContext, nextProps.timelineTypeContext) && - prevProps.utilityBar === nextProps.utilityBar -); + updateItemsPerPage, + upsertColumn, + utilityBar, +}) => { + const [{ browserFields, indexPatterns }] = useFetchIndexPatterns( + defaultIndices ?? useUiSetting(DEFAULT_INDEX_KEY) + ); + + useEffect(() => { + if (createTimeline != null) { + createTimeline({ id, columns, sort, itemsPerPage, showCheckboxes, showRowRenderers }); + } + return () => { + deleteEventQuery({ id, inputId: 'global' }); + }; + }, []); + + const onChangeItemsPerPage: OnChangeItemsPerPage = useCallback( + itemsChangedPerPage => updateItemsPerPage({ id, itemsPerPage: itemsChangedPerPage }), + [id, updateItemsPerPage] + ); + + const toggleColumn = useCallback( + (column: ColumnHeader) => { + const exists = columns.findIndex(c => c.id === column.id) !== -1; + + if (!exists && upsertColumn != null) { + upsertColumn({ + column, + id, + index: 1, + }); + } -StatefulEventsViewerComponent.displayName = 'StatefulEventsViewerComponent'; + if (exists && removeColumn != null) { + removeColumn({ + columnId: column.id, + id, + }); + } + }, + [columns, id, upsertColumn, removeColumn] + ); + + return ( + + + + ); +}; const makeMapStateToProps = () => { const getInputsTimeline = inputsSelectors.getTimelineSelector(); @@ -256,4 +226,29 @@ export const StatefulEventsViewer = connect(makeMapStateToProps, { updateItemsPerPage: timelineActions.updateItemsPerPage, removeColumn: timelineActions.removeColumn, upsertColumn: timelineActions.upsertColumn, -})(StatefulEventsViewerComponent); +})( + React.memo( + StatefulEventsViewerComponent, + (prevProps, nextProps) => + prevProps.id === nextProps.id && + isEqual(prevProps.columns, nextProps.columns) && + isEqual(prevProps.dataProviders, nextProps.dataProviders) && + prevProps.deletedEventIds === nextProps.deletedEventIds && + prevProps.end === nextProps.end && + isEqual(prevProps.filters, nextProps.filters) && + prevProps.isLive === nextProps.isLive && + prevProps.itemsPerPage === nextProps.itemsPerPage && + isEqual(prevProps.itemsPerPageOptions, nextProps.itemsPerPageOptions) && + prevProps.kqlMode === nextProps.kqlMode && + isEqual(prevProps.query, nextProps.query) && + prevProps.pageCount === nextProps.pageCount && + isEqual(prevProps.sort, nextProps.sort) && + prevProps.start === nextProps.start && + isEqual(prevProps.pageFilters, nextProps.pageFilters) && + prevProps.showCheckboxes === nextProps.showCheckboxes && + prevProps.showRowRenderers === nextProps.showRowRenderers && + prevProps.start === nextProps.start && + isEqual(prevProps.timelineTypeContext, nextProps.timelineTypeContext) && + prevProps.utilityBar === nextProps.utilityBar + ) +); diff --git a/x-pack/legacy/plugins/siem/public/components/header_section/index.test.tsx b/x-pack/legacy/plugins/siem/public/components/header_section/index.test.tsx index 2bc80be20e42d..bc4692b6fe0c5 100644 --- a/x-pack/legacy/plugins/siem/public/components/header_section/index.test.tsx +++ b/x-pack/legacy/plugins/siem/public/components/header_section/index.test.tsx @@ -63,36 +63,6 @@ describe('HeaderSection', () => { ).toBe(false); }); - test('it renders a transparent inspect button when showInspect is false', () => { - const wrapper = mount( - - - - ); - - expect( - wrapper - .find('[data-test-subj="transparent-inspect-container"]') - .first() - .exists() - ).toBe(true); - }); - - test('it renders an opaque inspect button when showInspect is true', () => { - const wrapper = mount( - - - - ); - - expect( - wrapper - .find('[data-test-subj="opaque-inspect-container"]') - .first() - .exists() - ).toBe(true); - }); - test('it renders supplements when children provided', () => { const wrapper = mount( diff --git a/x-pack/legacy/plugins/siem/public/components/header_section/index.tsx b/x-pack/legacy/plugins/siem/public/components/header_section/index.tsx index 14af10eb6cd9b..3153e785a8a32 100644 --- a/x-pack/legacy/plugins/siem/public/components/header_section/index.tsx +++ b/x-pack/legacy/plugins/siem/public/components/header_section/index.tsx @@ -35,48 +35,54 @@ export interface HeaderSectionProps extends HeaderProps { id?: string; split?: boolean; subtitle?: string | React.ReactNode; - showInspect?: boolean; title: string | React.ReactNode; tooltip?: string; } -export const HeaderSection = React.memo( - ({ border, children, id, showInspect = false, split, subtitle, title, tooltip }) => ( -
- - - - - -

- {title} - {tooltip && ( - <> - {' '} - - - )} -

-
+const HeaderSectionComponent: React.FC = ({ + border, + children, + id, + split, + subtitle, + title, + tooltip, +}) => ( +
+ + + + + +

+ {title} + {tooltip && ( + <> + {' '} + + + )} +

+
- {subtitle && } + {subtitle && } +
+ + {id && ( + + + )} +
+
- {id && ( - - - - )} -
+ {children && ( + + {children} - - {children && ( - - {children} - - )} - -
- ) + )} +
+
); -HeaderSection.displayName = 'HeaderSection'; + +export const HeaderSection = React.memo(HeaderSectionComponent); diff --git a/x-pack/legacy/plugins/siem/public/components/inspect/index.test.tsx b/x-pack/legacy/plugins/siem/public/components/inspect/index.test.tsx index 26c5f499717e9..9492002717e2b 100644 --- a/x-pack/legacy/plugins/siem/public/components/inspect/index.test.tsx +++ b/x-pack/legacy/plugins/siem/public/components/inspect/index.test.tsx @@ -17,7 +17,7 @@ import { import { createStore, State } from '../../store'; import { UpdateQueryParams, upsertQuery } from '../../store/inputs/helpers'; -import { InspectButton } from '.'; +import { InspectButton, InspectButtonContainer, BUTTON_CLASS } from '.'; import { cloneDeep } from 'lodash/fp'; describe('Inspect Button', () => { @@ -44,7 +44,7 @@ describe('Inspect Button', () => { test('Eui Empty Button', () => { const wrapper = mount( - + ); expect( @@ -58,13 +58,7 @@ describe('Inspect Button', () => { test('it does NOT render the Eui Empty Button when timeline is timeline and compact is true', () => { const wrapper = mount( - + ); expect( @@ -78,7 +72,7 @@ describe('Inspect Button', () => { test('Eui Icon Button', () => { const wrapper = mount( - + ); expect( @@ -92,13 +86,7 @@ describe('Inspect Button', () => { test('renders the Icon Button when inputId does NOT equal global, but compact is true', () => { const wrapper = mount( - + ); expect( @@ -112,7 +100,7 @@ describe('Inspect Button', () => { test('Eui Empty Button disabled', () => { const wrapper = mount( - + ); expect(wrapper.find('.euiButtonIcon').get(0).props.disabled).toBe(true); @@ -121,11 +109,41 @@ describe('Inspect Button', () => { test('Eui Icon Button disabled', () => { const wrapper = mount( - + ); expect(wrapper.find('.euiButtonIcon').get(0).props.disabled).toBe(true); }); + + describe('InspectButtonContainer', () => { + test('it renders a transparent inspect button by default', async () => { + const wrapper = mount( + + + + + + ); + + expect(wrapper.find(`InspectButtonContainer`)).toHaveStyleRule('opacity', '0', { + modifier: `.${BUTTON_CLASS}`, + }); + }); + + test('it renders an opaque inspect button when it has mouse focus', async () => { + const wrapper = mount( + + + + + + ); + + expect(wrapper.find(`InspectButtonContainer`)).toHaveStyleRule('opacity', '1', { + modifier: `:hover .${BUTTON_CLASS}`, + }); + }); + }); }); describe('Modal Inspect - happy path', () => { @@ -143,7 +161,7 @@ describe('Inspect Button', () => { const wrapper = mount( - + ); @@ -167,7 +185,7 @@ describe('Inspect Button', () => { const wrapper = mount( - + ); @@ -197,7 +215,7 @@ describe('Inspect Button', () => { test('Do not Open Inspect Modal if it is loading', () => { const wrapper = mount( - + ); store.getState().inputs.global.queries[0].loading = true; diff --git a/x-pack/legacy/plugins/siem/public/components/inspect/index.tsx b/x-pack/legacy/plugins/siem/public/components/inspect/index.tsx index a2a0ffdde34a5..32e71b3db575f 100644 --- a/x-pack/legacy/plugins/siem/public/components/inspect/index.tsx +++ b/x-pack/legacy/plugins/siem/public/components/inspect/index.tsx @@ -9,7 +9,7 @@ import { getOr } from 'lodash/fp'; import React, { useCallback } from 'react'; import { connect } from 'react-redux'; import { ActionCreator } from 'typescript-fsa'; -import styled from 'styled-components'; +import styled, { css } from 'styled-components'; import { inputsModel, inputsSelectors, State } from '../../store'; import { InputsModelId } from '../../store/inputs/constants'; @@ -18,14 +18,31 @@ import { inputsActions } from '../../store/inputs'; import { ModalInspectQuery } from './modal'; import * as i18n from './translations'; -const InspectContainer = styled.div<{ showInspect: boolean }>` - .euiButtonIcon { - ${props => (props.showInspect ? 'opacity: 1;' : 'opacity: 0;')} +export const BUTTON_CLASS = 'inspectButtonComponent'; + +export const InspectButtonContainer = styled.div<{ show?: boolean }>` + display: flex; + flex-grow: 1; + + .${BUTTON_CLASS} { + opacity: 0; transition: opacity ${props => getOr(250, 'theme.eui.euiAnimSpeedNormal', props)} ease; } + + ${({ show }) => + show && + css` + &:hover .${BUTTON_CLASS} { + opacity: 1; + } + `} `; -InspectContainer.displayName = 'InspectContainer'; +InspectButtonContainer.displayName = 'InspectButtonContainer'; + +InspectButtonContainer.defaultProps = { + show: true, +}; interface OwnProps { compact?: boolean; @@ -34,7 +51,6 @@ interface OwnProps { inspectIndex?: number; isDisabled?: boolean; onCloseInspect?: () => void; - show: boolean; title: string | React.ReactElement | React.ReactNode; } @@ -57,89 +73,84 @@ interface InspectButtonDispatch { type InspectButtonProps = OwnProps & InspectButtonReducer & InspectButtonDispatch; -const InspectButtonComponent = React.memo( - ({ - compact = false, - inputId = 'global', - inspect, - isDisabled, - isInspected, - loading, - inspectIndex = 0, - onCloseInspect, - queryId = '', - selectedInspectIndex, - setIsInspected, - show, - title = '', - }: InspectButtonProps) => { - const handleClick = useCallback(() => { - setIsInspected({ - id: queryId, - inputId, - isInspected: true, - selectedInspectIndex: inspectIndex, - }); - }, [setIsInspected, queryId, inputId, inspectIndex]); - - const handleCloseModal = useCallback(() => { - if (onCloseInspect != null) { - onCloseInspect(); - } - setIsInspected({ - id: queryId, - inputId, - isInspected: false, - selectedInspectIndex: inspectIndex, - }); - }, [onCloseInspect, setIsInspected, queryId, inputId, inspectIndex]); - - return ( - - {inputId === 'timeline' && !compact && ( - - {i18n.INSPECT} - - )} - {(inputId === 'global' || compact) && ( - - )} - 0 ? inspect.dsl[inspectIndex] : null} - response={ - inspect != null && inspect.response.length > 0 ? inspect.response[inspectIndex] : null - } - title={title} - data-test-subj="inspect-modal" - /> - - ); - } -); +const InspectButtonComponent: React.FC = ({ + compact = false, + inputId = 'global', + inspect, + isDisabled, + isInspected, + loading, + inspectIndex = 0, + onCloseInspect, + queryId = '', + selectedInspectIndex, + setIsInspected, + title = '', +}) => { + const isShowingModal = !loading && selectedInspectIndex === inspectIndex && isInspected; + const handleClick = useCallback(() => { + setIsInspected({ + id: queryId, + inputId, + isInspected: true, + selectedInspectIndex: inspectIndex, + }); + }, [setIsInspected, queryId, inputId, inspectIndex]); -InspectButtonComponent.displayName = 'InspectButtonComponent'; + const handleCloseModal = useCallback(() => { + if (onCloseInspect != null) { + onCloseInspect(); + } + setIsInspected({ + id: queryId, + inputId, + isInspected: false, + selectedInspectIndex: inspectIndex, + }); + }, [onCloseInspect, setIsInspected, queryId, inputId, inspectIndex]); + + return ( + <> + {inputId === 'timeline' && !compact && ( + + {i18n.INSPECT} + + )} + {(inputId === 'global' || compact) && ( + + )} + 0 ? inspect.dsl[inspectIndex] : null} + response={ + inspect != null && inspect.response.length > 0 ? inspect.response[inspectIndex] : null + } + title={title} + data-test-subj="inspect-modal" + /> + + ); +}; const makeMapStateToProps = () => { const getGlobalQuery = inputsSelectors.globalQueryByIdSelector(); @@ -150,6 +161,11 @@ const makeMapStateToProps = () => { return mapStateToProps; }; -export const InspectButton = connect(makeMapStateToProps, { +const mapDispatchToProps = { setIsInspected: inputsActions.setInspectionParameter, -})(InspectButtonComponent); +}; + +export const InspectButton = connect( + makeMapStateToProps, + mapDispatchToProps +)(React.memo(InspectButtonComponent)); diff --git a/x-pack/legacy/plugins/siem/public/components/matrix_histogram/index.tsx b/x-pack/legacy/plugins/siem/public/components/matrix_histogram/index.tsx index c29b5282e13af..94c05d00d5462 100644 --- a/x-pack/legacy/plugins/siem/public/components/matrix_histogram/index.tsx +++ b/x-pack/legacy/plugins/siem/public/components/matrix_histogram/index.tsx @@ -4,7 +4,7 @@ * you may not use this file except in compliance with the Elastic License. */ -import React, { useState, useEffect, useCallback } from 'react'; +import React, { useState, useEffect } from 'react'; import { ScaleType } from '@elastic/charts'; import darkTheme from '@elastic/eui/dist/eui_theme_dark.json'; @@ -17,10 +17,11 @@ import { DEFAULT_DARK_MODE } from '../../../common/constants'; import { useUiSetting$ } from '../../lib/kibana'; import { Loader } from '../loader'; import { Panel } from '../panel'; +import { InspectButtonContainer } from '../inspect'; import { getBarchartConfigs, getCustomChartData } from './utils'; import { MatrixHistogramProps, MatrixHistogramDataTypes } from './types'; -export const MatrixHistogram = ({ +export const MatrixHistogramComponent: React.FC> = ({ data, dataKey, endDate, @@ -35,7 +36,7 @@ export const MatrixHistogram = ({ updateDateRange, yTickFormatter, showLegend, -}: MatrixHistogramProps) => { +}) => { const barchartConfigs = getBarchartConfigs({ from: startDate, to: endDate, @@ -44,7 +45,6 @@ export const MatrixHistogram = ({ yTickFormatter, showLegend, }); - const [showInspect, setShowInspect] = useState(false); const [darkMode] = useUiSetting$(DEFAULT_DARK_MODE); const [loadingInitial, setLoadingInitial] = useState(false); @@ -56,40 +56,31 @@ export const MatrixHistogram = ({ } }, [loading, loadingInitial, totalCount]); - const handleOnMouseEnter = useCallback(() => setShowInspect(true), []); - const handleOnMouseLeave = useCallback(() => setShowInspect(false), []); - return ( - - + + + - {loadingInitial ? ( - - ) : ( - <> - + {loadingInitial ? ( + + ) : ( + <> + - {loading && ( - - )} - - )} - + {loading && ( + + )} + + )} + + ); }; + +export const MatrixHistogram = React.memo(MatrixHistogramComponent); diff --git a/x-pack/legacy/plugins/siem/public/components/page/hosts/host_overview/index.tsx b/x-pack/legacy/plugins/siem/public/components/page/hosts/host_overview/index.tsx index 9e3f8f91d5cf7..bf32a33af1eac 100644 --- a/x-pack/legacy/plugins/siem/public/components/page/hosts/host_overview/index.tsx +++ b/x-pack/legacy/plugins/siem/public/components/page/hosts/host_overview/index.tsx @@ -8,14 +8,14 @@ import { EuiFlexItem } from '@elastic/eui'; import darkTheme from '@elastic/eui/dist/eui_theme_dark.json'; import lightTheme from '@elastic/eui/dist/eui_theme_light.json'; import { getOr } from 'lodash/fp'; -import React, { useContext, useState, useCallback } from 'react'; +import React, { useContext } from 'react'; import { DEFAULT_DARK_MODE } from '../../../../../common/constants'; import { DescriptionList } from '../../../../../common/utility_types'; import { useUiSetting$ } from '../../../../lib/kibana'; import { getEmptyTagValue } from '../../../empty_value'; import { DefaultFieldRenderer, hostIdRenderer } from '../../../field_renderers/field_renderers'; -import { InspectButton } from '../../../inspect'; +import { InspectButton, InspectButtonContainer } from '../../../inspect'; import { HostItem } from '../../../../graphql/types'; import { Loader } from '../../../loader'; import { IPDetailsLink } from '../../../links'; @@ -56,7 +56,6 @@ export const HostOverview = React.memo( anomaliesData, narrowDateRange, }) => { - const [showInspect, setShowInspect] = useState(false); const capabilities = useContext(MlCapabilitiesContext); const userPermissions = hasMlUserPermissions(capabilities); const [darkMode] = useUiSetting$(DEFAULT_DARK_MODE); @@ -165,32 +164,26 @@ export const HostOverview = React.memo( ], ]; - const handleOnMouseEnter = useCallback(() => setShowInspect(true), []); - const handleOnMouseLeave = useCallback(() => setShowInspect(false), []); - return ( - - + + + - {descriptionLists.map((descriptionList, index) => - getDescriptionList(descriptionList, index) - )} + {descriptionLists.map((descriptionList, index) => + getDescriptionList(descriptionList, index) + )} - {loading && ( - - )} - + {loading && ( + + )} + + ); } ); diff --git a/x-pack/legacy/plugins/siem/public/components/page/network/ip_overview/index.tsx b/x-pack/legacy/plugins/siem/public/components/page/network/ip_overview/index.tsx index 0c4e594399517..901b82210a661 100644 --- a/x-pack/legacy/plugins/siem/public/components/page/network/ip_overview/index.tsx +++ b/x-pack/legacy/plugins/siem/public/components/page/network/ip_overview/index.tsx @@ -7,7 +7,7 @@ import { EuiFlexItem } from '@elastic/eui'; import darkTheme from '@elastic/eui/dist/eui_theme_dark.json'; import lightTheme from '@elastic/eui/dist/eui_theme_light.json'; -import React, { useContext, useState, useCallback } from 'react'; +import React, { useContext } from 'react'; import { DEFAULT_DARK_MODE } from '../../../../../common/constants'; import { DescriptionList } from '../../../../../common/utility_types'; @@ -32,7 +32,7 @@ import { Anomalies, NarrowDateRange } from '../../../ml/types'; import { AnomalyScores } from '../../../ml/score/anomaly_scores'; import { MlCapabilitiesContext } from '../../../ml/permissions/ml_capabilities_provider'; import { hasMlUserPermissions } from '../../../ml/permissions/has_ml_user_permissions'; -import { InspectButton } from '../../../inspect'; +import { InspectButton, InspectButtonContainer } from '../../../inspect'; interface OwnProps { data: IpOverviewData; @@ -71,7 +71,6 @@ export const IpOverview = React.memo( anomaliesData, narrowDateRange, }) => { - const [showInspect, setShowInspect] = useState(false); const capabilities = useContext(MlCapabilitiesContext); const userPermissions = hasMlUserPermissions(capabilities); const [darkMode] = useUiSetting$(DEFAULT_DARK_MODE); @@ -140,32 +139,26 @@ export const IpOverview = React.memo( ], ]; - const handleOnMouseEnter = useCallback(() => setShowInspect(true), []); - const handleOnMouseLeave = useCallback(() => setShowInspect(false), []); - return ( - - + + + - {descriptionLists.map((descriptionList, index) => - getDescriptionList(descriptionList, index) - )} + {descriptionLists.map((descriptionList, index) => + getDescriptionList(descriptionList, index) + )} - {loading && ( - - )} - + {loading && ( + + )} + + ); } ); diff --git a/x-pack/legacy/plugins/siem/public/components/page/overview/overview_host/index.tsx b/x-pack/legacy/plugins/siem/public/components/page/overview/overview_host/index.tsx index 302917c3de93e..a70d9d0080271 100644 --- a/x-pack/legacy/plugins/siem/public/components/page/overview/overview_host/index.tsx +++ b/x-pack/legacy/plugins/siem/public/components/page/overview/overview_host/index.tsx @@ -6,7 +6,7 @@ import { EuiButton, EuiFlexItem, EuiPanel } from '@elastic/eui'; import { FormattedMessage } from '@kbn/i18n/react'; -import React, { useState, useCallback } from 'react'; +import React from 'react'; import { HeaderSection } from '../../../header_section'; import { manageQuery } from '../../../page/manage_query'; @@ -17,6 +17,7 @@ import { import { inputsModel } from '../../../../store/inputs'; import { OverviewHostStats } from '../overview_host_stats'; import { getHostsUrl } from '../../../link_to'; +import { InspectButtonContainer } from '../../../inspect'; export interface OwnProps { startDate: number; @@ -36,18 +37,14 @@ export interface OwnProps { const OverviewHostStatsManage = manageQuery(OverviewHostStats); type OverviewHostProps = OwnProps; -export const OverviewHost = React.memo(({ endDate, startDate, setQuery }) => { - const [isHover, setIsHover] = useState(false); - const handleMouseEnter = useCallback(() => setIsHover(true), [setIsHover]); - const handleMouseLeave = useCallback(() => setIsHover(false), [setIsHover]); - return ( - - +const OverviewHostComponent: React.FC = ({ endDate, startDate, setQuery }) => ( + + + (({ endDate, startDate, )} - - ); -}); + + +); -OverviewHost.displayName = 'OverviewHost'; +export const OverviewHost = React.memo(OverviewHostComponent); diff --git a/x-pack/legacy/plugins/siem/public/components/page/overview/overview_network/index.tsx b/x-pack/legacy/plugins/siem/public/components/page/overview/overview_network/index.tsx index f60957cf7b485..af8c87ff38596 100644 --- a/x-pack/legacy/plugins/siem/public/components/page/overview/overview_network/index.tsx +++ b/x-pack/legacy/plugins/siem/public/components/page/overview/overview_network/index.tsx @@ -6,7 +6,7 @@ import { EuiButton, EuiFlexItem, EuiPanel } from '@elastic/eui'; import { FormattedMessage } from '@kbn/i18n/react'; -import React, { useState, useCallback } from 'react'; +import React from 'react'; import { HeaderSection } from '../../../header_section'; import { manageQuery } from '../../../page/manage_query'; @@ -17,6 +17,7 @@ import { import { inputsModel } from '../../../../store/inputs'; import { OverviewNetworkStats } from '../overview_network_stats'; import { getNetworkUrl } from '../../../link_to'; +import { InspectButtonContainer } from '../../../inspect'; export interface OwnProps { startDate: number; @@ -36,18 +37,13 @@ export interface OwnProps { const OverviewNetworkStatsManage = manageQuery(OverviewNetworkStats); -export const OverviewNetwork = React.memo(({ endDate, startDate, setQuery }) => { - const [isHover, setIsHover] = useState(false); - const handleMouseEnter = useCallback(() => setIsHover(true), [setIsHover]); - const handleMouseLeave = useCallback(() => setIsHover(false), [setIsHover]); - - return ( - - +const OverviewNetworkComponent: React.FC = ({ endDate, startDate, setQuery }) => ( + + + (({ endDate, startDate, setQu )} - - ); -}); + + +); -OverviewNetwork.displayName = 'OverviewNetwork'; +export const OverviewNetwork = React.memo(OverviewNetworkComponent); diff --git a/x-pack/legacy/plugins/siem/public/components/paginated_table/__snapshots__/index.test.tsx.snap b/x-pack/legacy/plugins/siem/public/components/paginated_table/__snapshots__/index.test.tsx.snap index 9c3bf7b11e3ed..98c9fc202dd6b 100644 --- a/x-pack/legacy/plugins/siem/public/components/paginated_table/__snapshots__/index.test.tsx.snap +++ b/x-pack/legacy/plugins/siem/public/components/paginated_table/__snapshots__/index.test.tsx.snap @@ -520,7 +520,7 @@ exports[`Paginated Table Component rendering it renders the default load more ta } } > - { width?: string; } -export const PaginatedTable = memo( - ({ - activePage, - columns, - dataTestSubj = DEFAULT_DATA_TEST_SUBJ, - headerCount, - headerSupplement, - headerTitle, - headerTooltip, - headerUnit, - id, - isInspect, - itemsPerRow, - limit, - loading, - loadPage, - onChange = noop, - pageOfItems, - showMorePagesIndicator, - sorting = null, - totalCount, - updateActivePage, - updateLimitPagination, - }) => { - const [myLoading, setMyLoading] = useState(loading); - const [myActivePage, setActivePage] = useState(activePage); - const [showInspect, setShowInspect] = useState(false); - const [loadingInitial, setLoadingInitial] = useState(headerCount === -1); - const [isPopoverOpen, setPopoverOpen] = useState(false); - - const pageCount = Math.ceil(totalCount / limit); - const dispatchToaster = useStateToaster()[1]; - - useEffect(() => { - setActivePage(activePage); - }, [activePage]); - - useEffect(() => { - if (headerCount >= 0 && loadingInitial) { - setLoadingInitial(false); - } - }, [loadingInitial, headerCount]); - - useEffect(() => { - setMyLoading(loading); - }, [loading]); - - const onButtonClick = () => { - setPopoverOpen(!isPopoverOpen); - }; - - const closePopover = () => { - setPopoverOpen(false); - }; - - const goToPage = (newActivePage: number) => { - if ((newActivePage + 1) * limit >= DEFAULT_MAX_TABLE_QUERY_SIZE) { - const toast: Toast = { - id: 'PaginationWarningMsg', - title: headerTitle + i18n.TOAST_TITLE, - color: 'warning', - iconType: 'alert', - toastLifeTimeMs: 10000, - text: i18n.TOAST_TEXT, - }; - return dispatchToaster({ - type: 'addToaster', - toast, - }); - } - setActivePage(newActivePage); - loadPage(newActivePage); - updateActivePage(newActivePage); - }; - - const button = ( - - {`${i18n.ROWS}: ${limit}`} - - ); - - const rowItems = - itemsPerRow && - itemsPerRow.map((item: ItemsPerRow) => ( - { - closePopover(); - updateLimitPagination(item.numberOfRow); - updateActivePage(0); // reset results to first page - }} - > - {item.text} - - )); - const PaginationWrapper = showMorePagesIndicator ? PaginationEuiFlexItem : EuiFlexItem; - const handleOnMouseEnter = useCallback(() => setShowInspect(true), []); - const handleOnMouseLeave = useCallback(() => setShowInspect(false), []); - - return ( - = ({ + activePage, + columns, + dataTestSubj = DEFAULT_DATA_TEST_SUBJ, + headerCount, + headerSupplement, + headerTitle, + headerTooltip, + headerUnit, + id, + isInspect, + itemsPerRow, + limit, + loading, + loadPage, + onChange = noop, + pageOfItems, + showMorePagesIndicator, + sorting = null, + totalCount, + updateActivePage, + updateLimitPagination, +}) => { + const [myLoading, setMyLoading] = useState(loading); + const [myActivePage, setActivePage] = useState(activePage); + const [loadingInitial, setLoadingInitial] = useState(headerCount === -1); + const [isPopoverOpen, setPopoverOpen] = useState(false); + + const pageCount = Math.ceil(totalCount / limit); + const dispatchToaster = useStateToaster()[1]; + + useEffect(() => { + setActivePage(activePage); + }, [activePage]); + + useEffect(() => { + if (headerCount >= 0 && loadingInitial) { + setLoadingInitial(false); + } + }, [loadingInitial, headerCount]); + + useEffect(() => { + setMyLoading(loading); + }, [loading]); + + const onButtonClick = () => { + setPopoverOpen(!isPopoverOpen); + }; + + const closePopover = () => { + setPopoverOpen(false); + }; + + const goToPage = (newActivePage: number) => { + if ((newActivePage + 1) * limit >= DEFAULT_MAX_TABLE_QUERY_SIZE) { + const toast: Toast = { + id: 'PaginationWarningMsg', + title: headerTitle + i18n.TOAST_TITLE, + color: 'warning', + iconType: 'alert', + toastLifeTimeMs: 10000, + text: i18n.TOAST_TEXT, + }; + return dispatchToaster({ + type: 'addToaster', + toast, + }); + } + setActivePage(newActivePage); + loadPage(newActivePage); + updateActivePage(newActivePage); + }; + + const button = ( + + {`${i18n.ROWS}: ${limit}`} + + ); + + const rowItems = + itemsPerRow && + itemsPerRow.map((item: ItemsPerRow) => ( + { + closePopover(); + updateLimitPagination(item.numberOfRow); + updateActivePage(0); // reset results to first page + }} > + {item.text} + + )); + const PaginationWrapper = showMorePagesIndicator ? PaginationEuiFlexItem : EuiFlexItem; + + return ( + + = 0 ? headerCount.toLocaleString() : 0} ${headerUnit}` @@ -306,11 +298,11 @@ export const PaginatedTable = memo( )} - ); - } -); + + ); +}; -PaginatedTable.displayName = 'PaginatedTable'; +export const PaginatedTable = memo(PaginatedTableComponent); type BasicTableType = ComponentType>; // eslint-disable-line @typescript-eslint/no-explicit-any const BasicTable: typeof EuiBasicTable & { displayName: string } = styled( diff --git a/x-pack/legacy/plugins/siem/public/components/stat_items/__snapshots__/index.test.tsx.snap b/x-pack/legacy/plugins/siem/public/components/stat_items/__snapshots__/index.test.tsx.snap index 5ed750b519cbf..ca06c484dc8a2 100644 --- a/x-pack/legacy/plugins/siem/public/components/stat_items/__snapshots__/index.test.tsx.snap +++ b/x-pack/legacy/plugins/siem/public/components/stat_items/__snapshots__/index.test.tsx.snap @@ -45,71 +45,63 @@ exports[`Stat Items Component disable charts it renders the default widget 1`] = className="euiFlexItem sc-AykKG krmHWP" data-test-subj="stat-item" > -
- +
- -
- -
- HOSTS -
-
-
-
-
- +
+ +
+ HOSTS +
+
+
+ + - - -
-
-
-
+ + +
+
- -
- - -
- - + +
-
-
- - +
-
- - + +
-

- - + +

- — - - - -

- - -
-
- + + + — + + + +

+
+
+
+ + +
+
-
-
- - + + +
+
+ +
+
-
- -
- +
- +
@@ -287,71 +279,63 @@ exports[`Stat Items Component disable charts it renders the default widget 2`] = className="euiFlexItem sc-AykKG krmHWP" data-test-subj="stat-item" > -
- +
- -
- -
- HOSTS -
-
-
-
-
- +
+ +
+ HOSTS +
+
+
+ + - - -
-
-
-
+ + +
+
- -
-
- -
- - + +
-
-
- 0 - - +
-
- - + +
-

- - + +

- — - - - -

- - -
-
- + + + — + + + +

+
+
+
+ + +
+
-
-
- - + + +
+
+ +
+
-
- -
- +
- +
@@ -599,71 +583,63 @@ exports[`Stat Items Component rendering kpis with charts it renders the default className="euiFlexItem sc-AykKG krmHWP" data-test-subj="stat-item" > -
- +
- -
- -
- UNIQUE_PRIVATE_IPS -
-
-
-
-
- +
+ +
+ UNIQUE_PRIVATE_IPS +
+
+
+ + - - -
-
-
-
+ + +
+
- -
-
- -
- - + +
-
-
- - -
- - - + - - -
-
-
- - -
- - + + + +
+
+
+ + +
-

- 1,714 - - Source -

- - -
-
-
+ + +

+ 1,714 + + Source +

+
+
+
+ + +
+
-
-
- - - - -
+ + -
- - -
- - - + - - -
-
-
- - -
- - + + + +
+
+
+ + +
-

- 2,359 - - Dest. -

- - -
-
-
+ + +

+ 2,359 + + Dest. +

+
+
+
+ +
+
+
- -
- - -
- - -
-
- -
- - + +
+
+ +
+
+ +
-
- + +
+ +
+ +
+ + + +
- -
-
-
- - -
- + -
- -
- - + } + } + > +
+ +
+ + +
+
- +
- +
diff --git a/x-pack/legacy/plugins/siem/public/components/stat_items/index.tsx b/x-pack/legacy/plugins/siem/public/components/stat_items/index.tsx index 2d081468599a2..a5c883ebd0e05 100644 --- a/x-pack/legacy/plugins/siem/public/components/stat_items/index.tsx +++ b/x-pack/legacy/plugins/siem/public/components/stat_items/index.tsx @@ -21,7 +21,7 @@ import { IconType, } from '@elastic/eui'; import { get, getOr } from 'lodash/fp'; -import React, { useState, useEffect, useCallback } from 'react'; +import React, { useState, useEffect } from 'react'; import styled from 'styled-components'; import { KpiHostsData, KpiNetworkData } from '../../graphql/types'; @@ -30,7 +30,7 @@ import { BarChart } from '../charts/barchart'; import { ChartSeriesData, ChartData, ChartSeriesConfigs, UpdateDateRange } from '../charts/common'; import { getEmptyTagValue } from '../empty_value'; -import { InspectButton } from '../inspect'; +import { InspectButton, InspectButtonContainer } from '../inspect'; const FlexItem = styled(EuiFlexItem)` min-width: 0; @@ -209,9 +209,6 @@ export const StatItemsComponent = React.memo( statKey = 'item', to, }) => { - const [isHover, setIsHover] = useState(false); - const handleMouseEnter = useCallback(() => setIsHover(true), [setIsHover]); - const handleMouseLeave = useCallback(() => setIsHover(false), [setIsHover]); const isBarChartDataAvailable = barChart && barChart.length && @@ -223,72 +220,69 @@ export const StatItemsComponent = React.memo( return ( - - - - -
{description}
-
-
- - - -
+ + + + + +
{description}
+
+
+ + + +
- - {fields.map(field => ( - - - {(isAreaChartDataAvailable || isBarChartDataAvailable) && field.icon && ( - - - - )} + + {fields.map(field => ( + + + {(isAreaChartDataAvailable || isBarChartDataAvailable) && field.icon && ( + + + + )} - - -

- {field.value != null ? field.value.toLocaleString() : getEmptyTagValue()}{' '} - {field.description} -

-
-
-
-
- ))} -
+ + +

+ {field.value != null ? field.value.toLocaleString() : getEmptyTagValue()}{' '} + {field.description} +

+
+
+
+
+ ))} +
- {(enableAreaChart || enableBarChart) && } - - {enableBarChart && ( - - - - )} + {(enableAreaChart || enableBarChart) && } + + {enableBarChart && ( + + + + )} - {enableAreaChart && from != null && to != null && ( - - - - )} - -
+ {enableAreaChart && from != null && to != null && ( + + + + )} +
+ + ); } diff --git a/x-pack/legacy/plugins/siem/public/components/timeline/properties/properties_right.tsx b/x-pack/legacy/plugins/siem/public/components/timeline/properties/properties_right.tsx index 4027682282dcd..b21ab5063441e 100644 --- a/x-pack/legacy/plugins/siem/public/components/timeline/properties/properties_right.tsx +++ b/x-pack/legacy/plugins/siem/public/components/timeline/properties/properties_right.tsx @@ -17,7 +17,7 @@ import { import { NewTimeline, Description, NotesButton } from './helpers'; import { OpenTimelineModalButton } from '../../open_timeline/open_timeline_modal/open_timeline_modal_button'; import { OpenTimelineModal } from '../../open_timeline/open_timeline_modal'; -import { InspectButton } from '../../inspect'; +import { InspectButton, InspectButtonContainer } from '../../inspect'; import * as i18n from './translations'; import { AssociateNote } from '../../notes/helpers'; @@ -82,32 +82,32 @@ interface Props { updateNote: UpdateNote; } -export const PropertiesRight = React.memo( - ({ - onButtonClick, - showActions, - onClosePopover, - createTimeline, - timelineId, - isDataInTimeline, - showNotesFromWidth, - showNotes, - showDescription, - showUsersView, - usersViewing, - description, - updateDescription, - associateNote, - getNotesByIds, - noteIds, - onToggleShowNotes, - updateNote, - showTimelineModal, - onCloseTimelineModal, - onOpenTimelineModal, - }) => ( - - +const PropertiesRightComponent: React.FC = ({ + onButtonClick, + showActions, + onClosePopover, + createTimeline, + timelineId, + isDataInTimeline, + showNotesFromWidth, + showNotes, + showDescription, + showUsersView, + usersViewing, + description, + updateDescription, + associateNote, + getNotesByIds, + noteIds, + onToggleShowNotes, + updateNote, + showTimelineModal, + onCloseTimelineModal, + onOpenTimelineModal, +}) => ( + + + ( inspectIndex={0} isDisabled={!isDataInTimeline} onCloseInspect={onClosePopover} - show={true} title={i18n.INSPECT_TIMELINE_TITLE} /> @@ -177,26 +176,26 @@ export const PropertiesRight = React.memo( ) : null} - - - {showUsersView - ? usersViewing.map(user => ( - // Hide the hard-coded elastic user avatar as the 7.2 release does not implement - // support for multi-user-collaboration as proposed in elastic/ingest-dev#395 - - - - - - )) - : null} - - {showTimelineModal ? : null} - - ) + + + + {showUsersView + ? usersViewing.map(user => ( + // Hide the hard-coded elastic user avatar as the 7.2 release does not implement + // support for multi-user-collaboration as proposed in elastic/ingest-dev#395 + + + + + + )) + : null} + + {showTimelineModal ? : null} + ); -PropertiesRight.displayName = 'PropertiesRight'; +export const PropertiesRight = React.memo(PropertiesRightComponent); From 9a871d2a7a8c4861a3f620ac4571eefb501c1b7d Mon Sep 17 00:00:00 2001 From: Dima Arnautov Date: Tue, 14 Jan 2020 08:58:43 +0100 Subject: [PATCH 073/139] [ML] MML calculator enhancements for multi-metric job wizard (#54573) * [ML] fix fieldNames provided to calculateModelMemoryLimit * [ML] calculateModelMemoryLimit when the influencers are changed --- .../new_job/common/job_creator/multi_metric_job_creator.ts | 3 +-- .../pick_fields_step/components/influencers/influencers.tsx | 3 +++ 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/x-pack/legacy/plugins/ml/public/application/jobs/new_job/common/job_creator/multi_metric_job_creator.ts b/x-pack/legacy/plugins/ml/public/application/jobs/new_job/common/job_creator/multi_metric_job_creator.ts index 947c1bcf6c1a4..8a4411bf9025f 100644 --- a/x-pack/legacy/plugins/ml/public/application/jobs/new_job/common/job_creator/multi_metric_job_creator.ts +++ b/x-pack/legacy/plugins/ml/public/application/jobs/new_job/common/job_creator/multi_metric_job_creator.ts @@ -92,12 +92,11 @@ export class MultiMetricJobCreator extends JobCreator { // not split field, use the default this.modelMemoryLimit = DEFAULT_MODEL_MEMORY_LIMIT; } else { - const fieldNames = this._detectors.map(d => d.field_name).filter(fn => fn !== undefined); const { modelMemoryLimit } = await ml.calculateModelMemoryLimit({ indexPattern: this._indexPatternTitle, splitFieldName: this._splitField.name, query: this._datafeed_config.query, - fieldNames, + fieldNames: this.fields.map(f => f.id), influencerNames: this._influencers, timeFieldName: this._job_config.data_description.time_field, earliestMs: this._start, diff --git a/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/components/pick_fields_step/components/influencers/influencers.tsx b/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/components/pick_fields_step/components/influencers/influencers.tsx index c55bdeef4dde8..5c5ba38b1c5a1 100644 --- a/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/components/pick_fields_step/components/influencers/influencers.tsx +++ b/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/components/pick_fields_step/components/influencers/influencers.tsx @@ -25,6 +25,9 @@ export const Influencers: FC = () => { useEffect(() => { jobCreator.removeAllInfluencers(); influencers.forEach(i => jobCreator.addInfluencer(i)); + if (jobCreator instanceof MultiMetricJobCreator) { + jobCreator.calculateModelMemoryLimit(); + } jobCreatorUpdate(); }, [influencers.join()]); From 9380b6408b2e3bf296e0bd6d9f81d31fc3a5c055 Mon Sep 17 00:00:00 2001 From: "Christiane (Tina) Heiligers" Date: Tue, 14 Jan 2020 01:32:56 -0700 Subject: [PATCH 074/139] Np migration tsvb route validation (#51850) --- .../visualize_embeddable.ts | 1 + .../core_plugins/vis_type_timeseries/index.ts | 14 + .../vis_type_timeseries/public/metrics_fn.ts | 8 + .../public/request_handler.js | 10 +- .../vis_type_timeseries/server/init.ts | 9 +- .../server/routes/post_vis_schema.ts | 247 ++++++++++++++++++ .../server/routes/{vis.js => vis.ts} | 22 +- .../np_ready/public/legacy/build_pipeline.ts | 18 +- src/plugins/vis_type_timeseries/kibana.json | 5 +- .../vis_type_timeseries/server/index.ts | 2 + .../vis_type_timeseries/server/plugin.ts | 20 +- .../server/validation_telemetry/index.ts | 20 ++ .../validation_telemetry_service.ts | 84 ++++++ 13 files changed, 447 insertions(+), 13 deletions(-) create mode 100644 src/legacy/core_plugins/vis_type_timeseries/server/routes/post_vis_schema.ts rename src/legacy/core_plugins/vis_type_timeseries/server/routes/{vis.js => vis.ts} (59%) create mode 100644 src/plugins/vis_type_timeseries/server/validation_telemetry/index.ts create mode 100644 src/plugins/vis_type_timeseries/server/validation_telemetry/validation_telemetry_service.ts diff --git a/src/legacy/core_plugins/kibana/public/visualize_embeddable/visualize_embeddable.ts b/src/legacy/core_plugins/kibana/public/visualize_embeddable/visualize_embeddable.ts index fc91742c53cca..b7a3a0f000d72 100644 --- a/src/legacy/core_plugins/kibana/public/visualize_embeddable/visualize_embeddable.ts +++ b/src/legacy/core_plugins/kibana/public/visualize_embeddable/visualize_embeddable.ts @@ -379,6 +379,7 @@ export class VisualizeEmbeddable extends Embeddable ({}), + mappings: { + 'tsvb-validation-telemetry': { + properties: { + failedRequests: { + type: 'long', + }, + }, + }, + }, + savedObjectSchemas: { + 'tsvb-validation-telemetry': { + isNamespaceAgnostic: true, + }, + }, }, init: (server: Legacy.Server) => { const visTypeTimeSeriesPlugin = server.newPlatform.setup.plugins diff --git a/src/legacy/core_plugins/vis_type_timeseries/public/metrics_fn.ts b/src/legacy/core_plugins/vis_type_timeseries/public/metrics_fn.ts index 8740f84dab3b9..225d81b71b8e0 100644 --- a/src/legacy/core_plugins/vis_type_timeseries/public/metrics_fn.ts +++ b/src/legacy/core_plugins/vis_type_timeseries/public/metrics_fn.ts @@ -31,6 +31,7 @@ type Context = KibanaContext | null; interface Arguments { params: string; uiState: string; + savedObjectId: string | null; } type VisParams = Required; @@ -64,10 +65,16 @@ export const createMetricsFn = (): ExpressionFunction { +export const metricsRequestHandler = async ({ + uiState, + timeRange, + filters, + query, + visParams, + savedObjectId, +}) => { const config = getUISettings(); const timezone = timezoneProvider(config)(); const uiStateObj = uiState.get(visParams.type, {}); @@ -49,6 +56,7 @@ export const metricsRequestHandler = async ({ uiState, timeRange, filters, query filters, panels: [visParams], state: uiStateObj, + savedObjectId: savedObjectId || 'unsaved', }), }); diff --git a/src/legacy/core_plugins/vis_type_timeseries/server/init.ts b/src/legacy/core_plugins/vis_type_timeseries/server/init.ts index 7b42ae8098016..ae6eebc00fc1b 100644 --- a/src/legacy/core_plugins/vis_type_timeseries/server/init.ts +++ b/src/legacy/core_plugins/vis_type_timeseries/server/init.ts @@ -26,12 +26,17 @@ import { SearchStrategiesRegister } from './lib/search_strategies/search_strateg // @ts-ignore import { getVisData } from './lib/get_vis_data'; import { Framework } from '../../../../plugins/vis_type_timeseries/server'; +import { ValidationTelemetryServiceSetup } from '../../../../plugins/vis_type_timeseries/server'; -export const init = async (framework: Framework, __LEGACY: any) => { +export const init = async ( + framework: Framework, + __LEGACY: any, + validationTelemetry: ValidationTelemetryServiceSetup +) => { const { core } = framework; const router = core.http.createRouter(); - visDataRoutes(router, framework); + visDataRoutes(router, framework, validationTelemetry); // [LEGACY_TODO] fieldsRoutes(__LEGACY.server); diff --git a/src/legacy/core_plugins/vis_type_timeseries/server/routes/post_vis_schema.ts b/src/legacy/core_plugins/vis_type_timeseries/server/routes/post_vis_schema.ts new file mode 100644 index 0000000000000..3aca50b5b4710 --- /dev/null +++ b/src/legacy/core_plugins/vis_type_timeseries/server/routes/post_vis_schema.ts @@ -0,0 +1,247 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +import Joi from 'joi'; +const stringOptionalNullable = Joi.string() + .allow('', null) + .optional(); +const stringRequired = Joi.string() + .allow('') + .required(); +const arrayNullable = Joi.array().allow(null); +const numberIntegerOptional = Joi.number() + .integer() + .optional(); +const numberIntegerRequired = Joi.number() + .integer() + .required(); +const numberOptional = Joi.number().optional(); +const numberRequired = Joi.number().required(); +const queryObject = Joi.object({ + language: Joi.string().allow(''), + query: Joi.string().allow(''), +}); + +const annotationsItems = Joi.object({ + color: stringOptionalNullable, + fields: stringOptionalNullable, + hidden: Joi.boolean().optional(), + icon: stringOptionalNullable, + id: stringOptionalNullable, + ignore_global_filters: numberIntegerOptional, + ignore_panel_filters: numberIntegerOptional, + index_pattern: stringOptionalNullable, + query_string: queryObject.optional(), + template: stringOptionalNullable, + time_field: stringOptionalNullable, +}); + +const backgroundColorRulesItems = Joi.object({ + value: Joi.number() + .allow(null) + .optional(), + id: stringOptionalNullable, + background_color: stringOptionalNullable, + color: stringOptionalNullable, +}); + +const gaugeColorRulesItems = Joi.object({ + gauge: stringOptionalNullable, + id: stringOptionalNullable, + operator: stringOptionalNullable, + value: Joi.number(), +}); +const metricsItems = Joi.object({ + field: stringOptionalNullable, + id: stringRequired, + metric_agg: stringOptionalNullable, + numerator: stringOptionalNullable, + denominator: stringOptionalNullable, + sigma: stringOptionalNullable, + function: stringOptionalNullable, + script: stringOptionalNullable, + variables: Joi.array() + .items( + Joi.object({ + field: stringOptionalNullable, + id: stringRequired, + name: stringOptionalNullable, + }) + ) + .optional(), + type: stringRequired, + value: stringOptionalNullable, + values: Joi.array() + .items(Joi.string().allow('', null)) + .allow(null) + .optional(), +}); + +const splitFiltersItems = Joi.object({ + id: stringOptionalNullable, + color: stringOptionalNullable, + filter: Joi.object({ + language: Joi.string().allow(''), + query: Joi.string().allow(''), + }).optional(), + label: stringOptionalNullable, +}); + +const seriesItems = Joi.object({ + aggregate_by: stringOptionalNullable, + aggregate_function: stringOptionalNullable, + axis_position: stringRequired, + axis_max: stringOptionalNullable, + axis_min: stringOptionalNullable, + chart_type: stringRequired, + color: stringRequired, + color_rules: Joi.array() + .items( + Joi.object({ + value: numberOptional, + id: stringRequired, + text: stringOptionalNullable, + operator: stringOptionalNullable, + }) + ) + .optional(), + fill: numberOptional, + filter: Joi.object({ + query: stringRequired, + language: stringOptionalNullable, + }).optional(), + formatter: stringRequired, + hide_in_legend: numberIntegerOptional, + hidden: Joi.boolean().optional(), + id: stringRequired, + label: stringOptionalNullable, + line_width: numberOptional, + metrics: Joi.array().items(metricsItems), + offset_time: stringOptionalNullable, + override_index_pattern: numberOptional, + point_size: numberRequired, + separate_axis: numberIntegerOptional, + seperate_axis: numberIntegerOptional, + series_index_pattern: stringOptionalNullable, + series_time_field: stringOptionalNullable, + series_interval: stringOptionalNullable, + series_drop_last_bucket: numberIntegerOptional, + split_color_mode: stringOptionalNullable, + split_filters: Joi.array() + .items(splitFiltersItems) + .optional(), + split_mode: stringRequired, + stacked: stringRequired, + steps: numberIntegerOptional, + terms_field: stringOptionalNullable, + terms_order_by: stringOptionalNullable, + terms_size: stringOptionalNullable, + terms_direction: stringOptionalNullable, + terms_include: stringOptionalNullable, + terms_exclude: stringOptionalNullable, + time_range_mode: stringOptionalNullable, + trend_arrows: numberOptional, + type: stringOptionalNullable, + value_template: stringOptionalNullable, + var_name: stringOptionalNullable, +}); + +export const visPayloadSchema = Joi.object({ + filters: arrayNullable, + panels: Joi.array().items( + Joi.object({ + annotations: Joi.array() + .items(annotationsItems) + .optional(), + axis_formatter: stringRequired, + axis_position: stringRequired, + axis_scale: stringRequired, + axis_min: stringOptionalNullable, + axis_max: stringOptionalNullable, + bar_color_rules: arrayNullable.optional(), + background_color: stringOptionalNullable, + background_color_rules: Joi.array() + .items(backgroundColorRulesItems) + .optional(), + default_index_pattern: stringOptionalNullable, + default_timefield: stringOptionalNullable, + drilldown_url: stringOptionalNullable, + drop_last_bucket: numberIntegerOptional, + filter: Joi.alternatives( + stringOptionalNullable, + Joi.object({ + language: stringOptionalNullable, + query: stringOptionalNullable, + }) + ), + gauge_color_rules: Joi.array() + .items(gaugeColorRulesItems) + .optional(), + gauge_width: [stringOptionalNullable, numberOptional], + gauge_inner_color: stringOptionalNullable, + gauge_inner_width: Joi.alternatives(stringOptionalNullable, numberIntegerOptional), + gauge_style: stringOptionalNullable, + gauge_max: stringOptionalNullable, + id: stringRequired, + ignore_global_filters: numberOptional, + ignore_global_filter: numberOptional, + index_pattern: stringRequired, + interval: stringRequired, + isModelInvalid: Joi.boolean().optional(), + legend_position: stringOptionalNullable, + markdown: stringOptionalNullable, + markdown_scrollbars: numberIntegerOptional, + markdown_openLinksInNewTab: numberIntegerOptional, + markdown_vertical_align: stringOptionalNullable, + markdown_less: stringOptionalNullable, + markdown_css: stringOptionalNullable, + pivot_id: stringOptionalNullable, + pivot_label: stringOptionalNullable, + pivot_type: stringOptionalNullable, + pivot_rows: stringOptionalNullable, + series: Joi.array() + .items(seriesItems) + .required(), + show_grid: numberIntegerRequired, + show_legend: numberIntegerRequired, + time_field: stringOptionalNullable, + time_range_mode: stringOptionalNullable, + type: stringRequired, + }) + ), + // general + query: Joi.array() + .items(queryObject) + .allow(null) + .required(), + state: Joi.object({ + sort: Joi.object({ + column: stringRequired, + order: Joi.string() + .valid(['asc', 'desc']) + .required(), + }).optional(), + }).required(), + savedObjectId: Joi.string().optional(), + timerange: Joi.object({ + timezone: stringRequired, + min: stringRequired, + max: stringRequired, + }).required(), +}); diff --git a/src/legacy/core_plugins/vis_type_timeseries/server/routes/vis.js b/src/legacy/core_plugins/vis_type_timeseries/server/routes/vis.ts similarity index 59% rename from src/legacy/core_plugins/vis_type_timeseries/server/routes/vis.js rename to src/legacy/core_plugins/vis_type_timeseries/server/routes/vis.ts index d2ded81309ffa..32e87f5a3f666 100644 --- a/src/legacy/core_plugins/vis_type_timeseries/server/routes/vis.js +++ b/src/legacy/core_plugins/vis_type_timeseries/server/routes/vis.ts @@ -17,12 +17,22 @@ * under the License. */ +import { IRouter } from 'kibana/server'; import { schema } from '@kbn/config-schema'; import { getVisData } from '../lib/get_vis_data'; +import { visPayloadSchema } from './post_vis_schema'; +import { + Framework, + ValidationTelemetryServiceSetup, +} from '../../../../../plugins/vis_type_timeseries/server'; const escapeHatch = schema.object({}, { allowUnknowns: true }); -export const visDataRoutes = (router, framework) => { +export const visDataRoutes = ( + router: IRouter, + framework: Framework, + { logFailedValidation }: ValidationTelemetryServiceSetup +) => { router.post( { path: '/api/metrics/vis/data', @@ -31,6 +41,16 @@ export const visDataRoutes = (router, framework) => { }, }, async (requestContext, request, response) => { + const { error: validationError } = visPayloadSchema.validate(request.body); + if (validationError) { + logFailedValidation(); + const savedObjectId = + (typeof request.body === 'object' && (request.body as any).savedObjectId) || + 'unavailable'; + framework.logger.warn( + `Request validation error: ${validationError.message} (saved object id: ${savedObjectId}). This most likely means your TSVB visualization contains outdated configuration. You can report this problem under https://github.com/elastic/kibana/issues/new?template=Bug_report.md` + ); + } try { const results = await getVisData(requestContext, request.body, framework); return response.ok({ body: results }); diff --git a/src/legacy/core_plugins/visualizations/public/np_ready/public/legacy/build_pipeline.ts b/src/legacy/core_plugins/visualizations/public/np_ready/public/legacy/build_pipeline.ts index cc2ab133941db..ab1664d612b35 100644 --- a/src/legacy/core_plugins/visualizations/public/np_ready/public/legacy/build_pipeline.ts +++ b/src/legacy/core_plugins/visualizations/public/np_ready/public/legacy/build_pipeline.ts @@ -59,7 +59,12 @@ export interface Schemas { [key: string]: any[] | undefined; } -type buildVisFunction = (visState: VisState, schemas: Schemas, uiState: any) => string; +type buildVisFunction = ( + visState: VisState, + schemas: Schemas, + uiState: any, + meta?: { savedObjectId?: string } +) => string; type buildVisConfigFunction = (schemas: Schemas, visParams?: VisParams) => VisParams; interface BuildPipelineVisFunction { @@ -248,11 +253,13 @@ export const buildPipelineVisFunction: BuildPipelineVisFunction = { input_control_vis: visState => { return `input_control_vis ${prepareJson('visConfig', visState.params)}`; }, - metrics: (visState, schemas, uiState = {}) => { + metrics: (visState, schemas, uiState = {}, meta) => { const paramsJson = prepareJson('params', visState.params); const uiStateJson = prepareJson('uiState', uiState); + const savedObjectIdParam = prepareString('savedObjectId', meta?.savedObjectId); - return `tsvb ${paramsJson} ${uiStateJson}`; + const params = [paramsJson, uiStateJson, savedObjectIdParam].filter(param => Boolean(param)); + return `tsvb ${params.join(' ')}`; }, timelion: visState => { const expression = prepareString('expression', visState.params.expression); @@ -488,6 +495,7 @@ export const buildPipeline = async ( params: { searchSource: ISearchSource; timeRange?: any; + savedObjectId?: string; } ) => { const { searchSource } = params; @@ -521,7 +529,9 @@ export const buildPipeline = async ( const schemas = getSchemas(vis, params.timeRange); if (buildPipelineVisFunction[vis.type.name]) { - pipeline += buildPipelineVisFunction[vis.type.name](visState, schemas, uiState); + pipeline += buildPipelineVisFunction[vis.type.name](visState, schemas, uiState, { + savedObjectId: params.savedObjectId, + }); } else if (vislibCharts.includes(vis.type.name)) { const visConfig = visState.params; visConfig.dimensions = await buildVislibDimensions(vis, params); diff --git a/src/plugins/vis_type_timeseries/kibana.json b/src/plugins/vis_type_timeseries/kibana.json index f9a368e85ed49..d77f4ac92da16 100644 --- a/src/plugins/vis_type_timeseries/kibana.json +++ b/src/plugins/vis_type_timeseries/kibana.json @@ -2,5 +2,6 @@ "id": "metrics", "version": "8.0.0", "kibanaVersion": "kibana", - "server": true -} \ No newline at end of file + "server": true, + "optionalPlugins": ["usageCollection"] +} diff --git a/src/plugins/vis_type_timeseries/server/index.ts b/src/plugins/vis_type_timeseries/server/index.ts index 599726612a936..dfb2394af237b 100644 --- a/src/plugins/vis_type_timeseries/server/index.ts +++ b/src/plugins/vis_type_timeseries/server/index.ts @@ -30,6 +30,8 @@ export const config = { export type VisTypeTimeseriesConfig = TypeOf; +export { ValidationTelemetryServiceSetup } from './validation_telemetry'; + export function plugin(initializerContext: PluginInitializerContext) { return new VisTypeTimeseriesPlugin(initializerContext); } diff --git a/src/plugins/vis_type_timeseries/server/plugin.ts b/src/plugins/vis_type_timeseries/server/plugin.ts index f508aa250454f..dcd0cd500bbc3 100644 --- a/src/plugins/vis_type_timeseries/server/plugin.ts +++ b/src/plugins/vis_type_timeseries/server/plugin.ts @@ -35,11 +35,17 @@ import { GetVisData, GetVisDataOptions, } from '../../../legacy/core_plugins/vis_type_timeseries/server'; +import { ValidationTelemetryService } from './validation_telemetry/validation_telemetry_service'; +import { UsageCollectionSetup } from '../../usage_collection/server'; export interface LegacySetup { server: Server; } +interface VisTypeTimeseriesPluginSetupDependencies { + usageCollection?: UsageCollectionSetup; +} + export interface VisTypeTimeseriesSetup { /** @deprecated */ __legacy: { @@ -61,11 +67,14 @@ export interface Framework { } export class VisTypeTimeseriesPlugin implements Plugin { + private validationTelementryService: ValidationTelemetryService; + constructor(private readonly initializerContext: PluginInitializerContext) { this.initializerContext = initializerContext; + this.validationTelementryService = new ValidationTelemetryService(); } - public setup(core: CoreSetup, plugins: any) { + public setup(core: CoreSetup, plugins: VisTypeTimeseriesPluginSetupDependencies) { const logger = this.initializerContext.logger.get('visTypeTimeseries'); const config$ = this.initializerContext.config.create(); // Global config contains things like the ES shard timeout @@ -82,8 +91,13 @@ export class VisTypeTimeseriesPlugin implements Plugin { return { __legacy: { config$, - registerLegacyAPI: once((__LEGACY: LegacySetup) => { - init(framework, __LEGACY); + registerLegacyAPI: once(async (__LEGACY: LegacySetup) => { + const validationTelemetrySetup = await this.validationTelementryService.setup(core, { + ...plugins, + globalConfig$, + }); + + await init(framework, __LEGACY, validationTelemetrySetup); }), }, getVisData: async (requestContext: RequestHandlerContext, options: GetVisDataOptions) => { diff --git a/src/plugins/vis_type_timeseries/server/validation_telemetry/index.ts b/src/plugins/vis_type_timeseries/server/validation_telemetry/index.ts new file mode 100644 index 0000000000000..140f61fa2f3fd --- /dev/null +++ b/src/plugins/vis_type_timeseries/server/validation_telemetry/index.ts @@ -0,0 +1,20 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +export * from './validation_telemetry_service'; diff --git a/src/plugins/vis_type_timeseries/server/validation_telemetry/validation_telemetry_service.ts b/src/plugins/vis_type_timeseries/server/validation_telemetry/validation_telemetry_service.ts new file mode 100644 index 0000000000000..136f5b9e5cfad --- /dev/null +++ b/src/plugins/vis_type_timeseries/server/validation_telemetry/validation_telemetry_service.ts @@ -0,0 +1,84 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +import { APICaller, CoreSetup, Plugin, PluginInitializerContext } from 'kibana/server'; +import { UsageCollectionSetup } from '../../../usage_collection/server'; + +export interface ValidationTelemetryServiceSetup { + logFailedValidation: () => void; +} + +export class ValidationTelemetryService implements Plugin { + private kibanaIndex: string = ''; + async setup( + core: CoreSetup, + { + usageCollection, + globalConfig$, + }: { + usageCollection?: UsageCollectionSetup; + globalConfig$: PluginInitializerContext['config']['legacy']['globalConfig$']; + } + ) { + globalConfig$.subscribe(config => { + this.kibanaIndex = config.kibana.index; + }); + if (usageCollection) { + usageCollection.registerCollector( + usageCollection.makeUsageCollector({ + type: 'tsvb-validation', + isReady: () => this.kibanaIndex !== '', + fetch: async (callCluster: APICaller) => { + try { + const response = await callCluster('get', { + index: this.kibanaIndex, + id: 'tsvb-validation-telemetry:tsvb-validation-telemetry', + ignore: [404], + }); + return { + failed_validations: + response?._source?.['tsvb-validation-telemetry']?.failedRequests || 0, + }; + } catch (err) { + return { + failed_validations: 0, + }; + } + }, + }) + ); + } + const internalRepository = core.savedObjects.createInternalRepository(); + + return { + logFailedValidation: async () => { + try { + await internalRepository.incrementCounter( + 'tsvb-validation-telemetry', + 'tsvb-validation-telemetry', + 'failedRequests' + ); + } catch (e) { + // swallow error, validation telemetry shouldn't fail anything else + } + }, + }; + } + start() {} +} From 3f46e2bec6efea84f390c43e881c0a330fe0d921 Mon Sep 17 00:00:00 2001 From: Dario Gieselaar Date: Tue, 14 Jan 2020 09:37:22 +0100 Subject: [PATCH 075/139] [APM] Support error.{log,exception}.stacktrace.classname (#54577) In elastic/apm-server/pull/3096, an alternative to stacktrace.filename was introduced: stacktrace.classname. This change makes sure classname is properly represented in the UI and in our types. --- .../public/components/shared/Stacktrace/FrameHeading.tsx | 6 +++++- .../apm/typings/es_schemas/raw/fields/Stackframe.ts | 9 ++++----- 2 files changed, 9 insertions(+), 6 deletions(-) diff --git a/x-pack/legacy/plugins/apm/public/components/shared/Stacktrace/FrameHeading.tsx b/x-pack/legacy/plugins/apm/public/components/shared/Stacktrace/FrameHeading.tsx index 84c2801a45049..51056fae50360 100644 --- a/x-pack/legacy/plugins/apm/public/components/shared/Stacktrace/FrameHeading.tsx +++ b/x-pack/legacy/plugins/apm/public/components/shared/Stacktrace/FrameHeading.tsx @@ -35,9 +35,13 @@ const FrameHeading: React.FC = ({ stackframe, isLibraryFrame }) => { ? LibraryFrameFileDetail : AppFrameFileDetail; const lineNumber = stackframe.line.number; + + const name = + 'filename' in stackframe ? stackframe.filename : stackframe.classname; + return ( - {stackframe.filename} in{' '} + {name} in{' '} {stackframe.function} {lineNumber > 0 && ( diff --git a/x-pack/legacy/plugins/apm/typings/es_schemas/raw/fields/Stackframe.ts b/x-pack/legacy/plugins/apm/typings/es_schemas/raw/fields/Stackframe.ts index a1b1a8198bb35..993fac46ad7cb 100644 --- a/x-pack/legacy/plugins/apm/typings/es_schemas/raw/fields/Stackframe.ts +++ b/x-pack/legacy/plugins/apm/typings/es_schemas/raw/fields/Stackframe.ts @@ -4,8 +4,7 @@ * you may not use this file except in compliance with the Elastic License. */ -interface IStackframeBase { - filename: string; +type IStackframeBase = { function?: string; library_frame?: boolean; exclude_from_grouping?: boolean; @@ -19,13 +18,13 @@ interface IStackframeBase { line: { number: number; }; -} +} & ({ classname: string } | { filename: string }); -export interface IStackframeWithLineContext extends IStackframeBase { +export type IStackframeWithLineContext = IStackframeBase & { line: { number: number; context: string; }; -} +}; export type IStackframe = IStackframeBase | IStackframeWithLineContext; From b93d8100e5933953a39393a3274351a34eb9bdab Mon Sep 17 00:00:00 2001 From: Jean-Louis Leysens Date: Tue, 14 Jan 2020 10:24:27 +0100 Subject: [PATCH 076/139] Take page offset into account too (#54567) --- .../models/legacy_core_editor/legacy_core_editor.ts | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/legacy/core_plugins/console/public/np_ready/application/models/legacy_core_editor/legacy_core_editor.ts b/src/legacy/core_plugins/console/public/np_ready/application/models/legacy_core_editor/legacy_core_editor.ts index 6262c304e307b..8301daa675b5c 100644 --- a/src/legacy/core_plugins/console/public/np_ready/application/models/legacy_core_editor/legacy_core_editor.ts +++ b/src/legacy/core_plugins/console/public/np_ready/application/models/legacy_core_editor/legacy_core_editor.ts @@ -303,7 +303,9 @@ export class LegacyCoreEditor implements CoreEditor { const maxLineLength = this.getWrapLimit() - 5; const isWrapping = firstLine.length > maxLineLength; const getScreenCoords = (line: number) => - this.editor.renderer.textToScreenCoordinates(line - 1, startColumn).pageY - offsetFromPage; + this.editor.renderer.textToScreenCoordinates(line - 1, startColumn).pageY - + offsetFromPage + + (window.pageYOffset || 0); const topOfReq = getScreenCoords(startLine); if (topOfReq >= 0) { From cd9ead87c5f7a908c68eda0f18c4087324ba2cd3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Felix=20St=C3=BCrmer?= Date: Tue, 14 Jan 2020 12:00:36 +0100 Subject: [PATCH 077/139] [Logs UI] Reduce panel paddings in ML integration result tabs (#54574) This reduces the panel paddings on the log rate and categorization result tabs from `l` to `m` as per elastic/logs#7 and brings a title padding in line with the rest. --- .../logs/log_entry_categories/page_results_content.tsx | 4 ++-- .../pages/logs/log_entry_rate/page_results_content.tsx | 6 +++--- .../pages/logs/log_entry_rate/sections/anomalies/index.tsx | 2 +- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/page_results_content.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/page_results_content.tsx index ffffba0691749..a810ce447d369 100644 --- a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/page_results_content.tsx +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/page_results_content.tsx @@ -156,7 +156,7 @@ export const LogEntryCategoriesResultsContent: React.FunctionComponent = () => { - + @@ -188,7 +188,7 @@ export const LogEntryCategoriesResultsContent: React.FunctionComponent = () => { ) : null} - + { - + {logEntryRate ? ( @@ -196,7 +196,7 @@ export const LogEntryRateResultsContent: React.FunctionComponent = () => { - + {isFirstUse && !hasResults ? ( <> @@ -212,7 +212,7 @@ export const LogEntryRateResultsContent: React.FunctionComponent = () => { - + - +

{title}

From 0326f34948e100f882fc2e45ea8228bb5f692d8b Mon Sep 17 00:00:00 2001 From: Tim Roes Date: Tue, 14 Jan 2020 12:34:10 +0100 Subject: [PATCH 078/139] Make promotion behave the same as alias button (#54608) Co-authored-by: Elastic Machine --- .../wizard/__snapshots__/new_vis_modal.test.tsx.snap | 4 ++-- .../np_ready/wizard/type_selection/new_vis_help.test.tsx | 4 ++-- .../np_ready/wizard/type_selection/new_vis_help.tsx | 5 +++-- .../np_ready/wizard/type_selection/type_selection.tsx | 2 +- 4 files changed, 8 insertions(+), 7 deletions(-) diff --git a/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/__snapshots__/new_vis_modal.test.tsx.snap b/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/__snapshots__/new_vis_modal.test.tsx.snap index 0b44c7dc4e860..f0905cf0dce82 100644 --- a/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/__snapshots__/new_vis_modal.test.tsx.snap +++ b/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/__snapshots__/new_vis_modal.test.tsx.snap @@ -1594,7 +1594,7 @@ exports[`NewVisModal filter for visualization types should render as expected 1` /> @@ -3218,7 +3218,7 @@ exports[`NewVisModal should render as expected 1`] = ` /> diff --git a/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/type_selection/new_vis_help.test.tsx b/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/type_selection/new_vis_help.test.tsx index 3093499a030c8..a33a82c252fb3 100644 --- a/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/type_selection/new_vis_help.test.tsx +++ b/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/type_selection/new_vis_help.test.tsx @@ -41,7 +41,7 @@ describe('NewVisHelp', () => { stage: 'production', }, ]} - addBasePath={(url: string) => `testbasepath${url}`} + onPromotionClicked={() => {}} /> ) ).toMatchInlineSnapshot(` @@ -60,9 +60,9 @@ describe('NewVisHelp', () => {

Do it now! diff --git a/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/type_selection/new_vis_help.tsx b/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/type_selection/new_vis_help.tsx index 107cbc0e754b5..2f7effb7a33c8 100644 --- a/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/type_selection/new_vis_help.tsx +++ b/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/type_selection/new_vis_help.tsx @@ -21,10 +21,11 @@ import { FormattedMessage } from '@kbn/i18n/react'; import React, { Fragment } from 'react'; import { EuiText, EuiButton } from '@elastic/eui'; import { VisTypeAliasListEntry } from './type_selection'; +import { VisTypeAlias } from '../../../../../../visualizations/public'; interface Props { promotedTypes: VisTypeAliasListEntry[]; - addBasePath: (path: string) => string; + onPromotionClicked: (visType: VisTypeAlias) => void; } export function NewVisHelp(props: Props) { @@ -42,7 +43,7 @@ export function NewVisHelp(props: Props) { {t.promotion!.description}

props.onPromotionClicked(t)} fill size="s" iconType="popout" diff --git a/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/type_selection/type_selection.tsx b/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/type_selection/type_selection.tsx index 28cafde45a714..44da7cc8f2c45 100644 --- a/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/type_selection/type_selection.tsx +++ b/src/legacy/core_plugins/kibana/public/visualize/np_ready/wizard/type_selection/type_selection.tsx @@ -154,7 +154,7 @@ class TypeSelection extends React.Component t.promotion)} - addBasePath={this.props.addBasePath} + onPromotionClicked={this.props.onVisTypeSelected} /> )} From 47222e7263548be9e6954ee3e8d721df2bcd0b64 Mon Sep 17 00:00:00 2001 From: Pierre Gayvallet Date: Tue, 14 Jan 2020 12:39:56 +0100 Subject: [PATCH 079/139] fix np app navlink url (#54691) Co-authored-by: Elastic Machine --- src/core/public/chrome/ui/header/header.tsx | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/src/core/public/chrome/ui/header/header.tsx b/src/core/public/chrome/ui/header/header.tsx index 0447add491788..d05a6bb53405c 100644 --- a/src/core/public/chrome/ui/header/header.tsx +++ b/src/core/public/chrome/ui/header/header.tsx @@ -57,7 +57,7 @@ import { } from '../..'; import { HttpStart } from '../../../http'; import { ChromeHelpExtension } from '../../chrome_service'; -import { ApplicationStart, InternalApplicationStart } from '../../../application/types'; +import { InternalApplicationStart } from '../../../application/types'; // Providing a buffer between the limit and the cut off index // protects from truncating just the last couple (6) characters @@ -108,7 +108,7 @@ function extendRecentlyAccessedHistoryItem( }; } -function extendNavLink(navLink: ChromeNavLink, urlForApp: ApplicationStart['getUrlForApp']) { +function extendNavLink(navLink: ChromeNavLink) { if (navLink.legacy) { return { ...navLink, @@ -118,7 +118,7 @@ function extendNavLink(navLink: ChromeNavLink, urlForApp: ApplicationStart['getU return { ...navLink, - href: urlForApp(navLink.id), + href: navLink.baseUrl, }; } @@ -229,9 +229,7 @@ class HeaderUI extends Component { appTitle, isVisible, forceNavigation, - navLinks: navLinks.map(navLink => - extendNavLink(navLink, this.props.application.getUrlForApp) - ), + navLinks: navLinks.map(extendNavLink), recentlyAccessed: recentlyAccessed.map(ra => extendRecentlyAccessedHistoryItem(navLinks, ra, this.props.basePath) ), From ca6beecb0d384e6f89a9bae966f366d2dbae9199 Mon Sep 17 00:00:00 2001 From: Mikhail Shustov Date: Tue, 14 Jan 2020 13:16:06 +0100 Subject: [PATCH 080/139] Fix invalid version check logging for the legacy plugins (#54690) * use NP env to retrieve kibana version. settings has none * update tests --- src/core/server/legacy/legacy_service.test.ts | 2 +- src/core/server/legacy/legacy_service.ts | 6 +++++- .../server/legacy/plugins/find_legacy_plugin_specs.ts | 11 ++++++++--- 3 files changed, 14 insertions(+), 5 deletions(-) diff --git a/src/core/server/legacy/legacy_service.test.ts b/src/core/server/legacy/legacy_service.test.ts index 608392e4943f9..af4db68ee95e1 100644 --- a/src/core/server/legacy/legacy_service.test.ts +++ b/src/core/server/legacy/legacy_service.test.ts @@ -424,7 +424,7 @@ describe('#discoverPlugins()', () => { await legacyService.discoverPlugins(); expect(findLegacyPluginSpecs).toHaveBeenCalledTimes(1); - expect(findLegacyPluginSpecs).toHaveBeenCalledWith(expect.any(Object), logger); + expect(findLegacyPluginSpecs).toHaveBeenCalledWith(expect.any(Object), logger, env.packageInfo); }); it(`register legacy plugin's deprecation providers`, async () => { diff --git a/src/core/server/legacy/legacy_service.ts b/src/core/server/legacy/legacy_service.ts index cc36b90ec526d..7a03cefc38c1a 100644 --- a/src/core/server/legacy/legacy_service.ts +++ b/src/core/server/legacy/legacy_service.ts @@ -125,7 +125,11 @@ export class LegacyService implements CoreService { disabledPluginSpecs, uiExports, navLinks, - } = await findLegacyPluginSpecs(this.settings, this.coreContext.logger); + } = await findLegacyPluginSpecs( + this.settings, + this.coreContext.logger, + this.coreContext.env.packageInfo + ); this.legacyPlugins = { pluginSpecs, diff --git a/src/core/server/legacy/plugins/find_legacy_plugin_specs.ts b/src/core/server/legacy/plugins/find_legacy_plugin_specs.ts index d2e7a39236d0a..9867274d224bd 100644 --- a/src/core/server/legacy/plugins/find_legacy_plugin_specs.ts +++ b/src/core/server/legacy/plugins/find_legacy_plugin_specs.ts @@ -29,6 +29,8 @@ import { import { collectUiExports as collectLegacyUiExports } from '../../../../legacy/ui/ui_exports/collect_ui_exports'; import { LoggerFactory } from '../../logging'; +import { PackageInfo } from '../../config'; + import { LegacyUiExports, LegacyNavLink, @@ -92,7 +94,11 @@ function getNavLinks(uiExports: LegacyUiExports, pluginSpecs: LegacyPluginSpec[] .sort((a, b) => a.order - b.order); } -export async function findLegacyPluginSpecs(settings: unknown, loggerFactory: LoggerFactory) { +export async function findLegacyPluginSpecs( + settings: unknown, + loggerFactory: LoggerFactory, + packageInfo: PackageInfo +) { const configToMutate: LegacyConfig = defaultConfig(settings); const { pack$, @@ -152,8 +158,7 @@ export async function findLegacyPluginSpecs(settings: unknown, loggerFactory: Lo map(spec => { const name = spec.getId(); const pluginVersion = spec.getExpectedKibanaVersion(); - // @ts-ignore - const kibanaVersion = settings.pkg.version; + const kibanaVersion = packageInfo.version; return `Plugin "${name}" was disabled because it expected Kibana version "${pluginVersion}", and found "${kibanaVersion}".`; }), distinct(), From 7c7be987caf5ca424486f131626a43211cda1ab8 Mon Sep 17 00:00:00 2001 From: Daniil Suleiman <31325372+sulemanof@users.noreply.github.com> Date: Tue, 14 Jan 2020 15:36:22 +0300 Subject: [PATCH 081/139] Fix color ranges validation (#54253) Co-authored-by: Elastic Machine --- .../public/components/common/color_ranges.tsx | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/legacy/core_plugins/kbn_vislib_vis_types/public/components/common/color_ranges.tsx b/src/legacy/core_plugins/kbn_vislib_vis_types/public/components/common/color_ranges.tsx index 276e765ae7fe6..947c7ae7e6e36 100644 --- a/src/legacy/core_plugins/kbn_vislib_vis_types/public/components/common/color_ranges.tsx +++ b/src/legacy/core_plugins/kbn_vislib_vis_types/public/components/common/color_ranges.tsx @@ -48,6 +48,10 @@ function ColorRanges({ const validateRange = useCallback( ({ from, to }, index) => { + if (!colorsRange[index]) { + return [false, false]; + } + const leftBound = index === 0 ? -Infinity : colorsRange[index - 1].to || 0; const isFromValid = from >= leftBound; const isToValid = to >= from; From 6b6bc39450ef5e207f7999043bd1fd4a15a1d4fc Mon Sep 17 00:00:00 2001 From: Aleh Zasypkin Date: Tue, 14 Jan 2020 13:37:19 +0100 Subject: [PATCH 082/139] =?UTF-8?q?Update=20`fstream`=20dependency=20(`1.0?= =?UTF-8?q?.11`=20=E2=86=92=20`1.0.12`).=20(#53932)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- yarn.lock | 12 +----------- 1 file changed, 1 insertion(+), 11 deletions(-) diff --git a/yarn.lock b/yarn.lock index ff098b7b9c891..768c7be700667 100644 --- a/yarn.lock +++ b/yarn.lock @@ -13257,17 +13257,7 @@ fsevents@~2.1.0: resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.1.0.tgz#ce1a5f9ac71c6d75278b0c5bd236d7dfece4cbaa" integrity sha512-+iXhW3LuDQsno8dOIrCIT/CBjeBWuP7PXe8w9shnj9Lebny/Gx1ZjVBYwexLz36Ri2jKuXMNpV6CYNh8lHHgrQ== -fstream@^1.0.0: - version "1.0.11" - resolved "https://registry.yarnpkg.com/fstream/-/fstream-1.0.11.tgz#5c1fb1f117477114f0632a0eb4b71b3cb0fd3171" - integrity sha1-XB+x8RdHcRTwYyoOtLcbPLD9MXE= - dependencies: - graceful-fs "^4.1.2" - inherits "~2.0.0" - mkdirp ">=0.5 0" - rimraf "2" - -fstream@^1.0.12: +fstream@^1.0.0, fstream@^1.0.12: version "1.0.12" resolved "https://registry.yarnpkg.com/fstream/-/fstream-1.0.12.tgz#4e8ba8ee2d48be4f7d0de505455548eae5932045" integrity sha512-WvJ193OHa0GHPEL+AycEJgxvBEwyfRkN1vhjca23OaPVMCaLCXTd5qAu82AjTcgP1UJmytkOKb63Ypde7raDIg== From c976094f5446ea91b7113c55cc5885099fcaea2d Mon Sep 17 00:00:00 2001 From: "Devin W. Hurley" Date: Tue, 14 Jan 2020 07:59:57 -0500 Subject: [PATCH 083/139] [SIEM][Detection Engine] Rule Status Monitoring (#54452) * Working status updates in executor. Need to update read rules api endpoint to only respond with 'status' and not status info. Will create another endpoint to get status details for a rule which will include last five errors (if there are any). Still need tests * adds new route for getting statuses for a list of given alert ids, adds try-catch and more logic in executor for logging errors, adds scripts and rules for testing, updates find_rules endpoint to display statuses too. Would like to look into using the alerts executor state to better manage logic for statuses, and need to update some types. Also needs unit tests still. * updated types for routes, updated how merging of alert-to-rule and rule status happens when formatting REST response. * typecast test server as ServerFacade type * fix bug where we were not awaiting the accumulated result in the reducer * update rule status saved object interfaces to play nicely with interfaces provided by saved objects module. Update tests to pass - Need to write new unit tests in an upcoming commit. Next commit will be cleanup from comments then new unit tests. * fix missed conflicts after rebase * replace id param with rule.id when searching in statuses, adds sort fields to the saved objects find queries. * fixes bug where 'executing' statuses were being written into failing historical status list * camelCase to snake_case in new statuses route, also fix merge conflict * add deletion of rule statuses to delete_rules_bulk_route. Statuses are created inside of executor so we will not be needing to create statuses directly inside of the create rules bulk route, so I removed that extraneous code. * pr feedback I forgot to fix earlier * remove unused import. fixes type check error generated in previous commit * removes status information from rule when saved to signals index and updates tests to represent this change. Also removes extraneous quotes inserted around alertId field when creating a new historical status. * adds new bash script to delete all rule statuses, updates error messages in rule statuses to just store actual message, moved querying of rules statuses under a null check, initialize everything to null when first creating rule status, update number of results returned when querying saved objects based on usage, updates saved objects mapping types to use date for dates and keyword for alertId. * use lodash snake case and update total number of saved objects to return for find rules, delete rules, and read rules. * updates how statuses are transformed inside of read_rules_route, only update updated_at in rule on update of rule, removes unlabeled todo comment, updates scripts descriptions, removes interval from query_with_rule_id.json sample query, removes debug statement, removes verbose from curl script. * display rule status on update --- x-pack/legacy/plugins/siem/index.ts | 1 + .../plugins/siem/server/kibana.index.ts | 2 + .../routes/__mocks__/_mock_server.ts | 12 +- .../routes/__mocks__/request_responses.ts | 10 +- .../privileges/read_privileges_route.test.ts | 3 +- .../rules/create_rules_bulk_route.test.ts | 9 +- .../routes/rules/create_rules_bulk_route.ts | 6 +- .../routes/rules/create_rules_route.test.ts | 31 ++- .../routes/rules/create_rules_route.ts | 21 +- .../rules/delete_rules_bulk_route.test.ts | 16 +- .../routes/rules/delete_rules_bulk_route.ts | 21 +- .../routes/rules/delete_rules_route.test.ts | 21 +- .../routes/rules/delete_rules_route.ts | 23 +- .../routes/rules/find_rules_route.test.ts | 10 +- .../routes/rules/find_rules_route.ts | 24 +- .../routes/rules/find_rules_status_route.ts | 82 ++++++ .../routes/rules/read_rules_route.test.ts | 17 +- .../routes/rules/read_rules_route.ts | 21 +- .../routes/rules/update_rules_bulk.test.ts | 10 +- .../routes/rules/update_rules_route.test.ts | 21 +- .../routes/rules/update_rules_route.ts | 21 +- .../detection_engine/routes/rules/utils.ts | 56 +++- .../schemas/find_rules_statuses_schema.ts | 11 + .../routes/signals/open_close_signals.test.ts | 4 +- .../signals/query_signals_route.test.ts | 4 +- .../rules/saved_object_mappings.ts | 40 +++ .../lib/detection_engine/rules/types.ts | 61 +++++ .../scripts/delete_all_statuses.sh | 23 ++ .../scripts/find_rules_statuses_by_ids.sh | 17 ++ .../detection_engine/scripts/hard_reset.sh | 1 + .../rules/test_cases/query_with_errors.json | 12 + .../signals/signal_rule_alert_type.ts | 252 ++++++++++++++---- .../siem/server/lib/detection_engine/types.ts | 41 ++- .../plugins/siem/server/saved_objects.ts | 2 + x-pack/legacy/plugins/siem/server/types.ts | 2 + .../utils/typed_elasticsearch_mappings.ts | 2 +- 36 files changed, 755 insertions(+), 155 deletions(-) create mode 100644 x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/find_rules_status_route.ts create mode 100644 x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/schemas/find_rules_statuses_schema.ts create mode 100644 x-pack/legacy/plugins/siem/server/lib/detection_engine/rules/saved_object_mappings.ts create mode 100755 x-pack/legacy/plugins/siem/server/lib/detection_engine/scripts/delete_all_statuses.sh create mode 100755 x-pack/legacy/plugins/siem/server/lib/detection_engine/scripts/find_rules_statuses_by_ids.sh create mode 100644 x-pack/legacy/plugins/siem/server/lib/detection_engine/scripts/rules/test_cases/query_with_errors.json diff --git a/x-pack/legacy/plugins/siem/index.ts b/x-pack/legacy/plugins/siem/index.ts index c5038626fdfc2..fe8b16471a7ce 100644 --- a/x-pack/legacy/plugins/siem/index.ts +++ b/x-pack/legacy/plugins/siem/index.ts @@ -147,6 +147,7 @@ export const siem = (kibana: any) => { alerting: plugins.alerting, elasticsearch: plugins.elasticsearch, spaces: plugins.spaces, + savedObjects: server.savedObjects.SavedObjectsClient, }, route: route.bind(server), }; diff --git a/x-pack/legacy/plugins/siem/server/kibana.index.ts b/x-pack/legacy/plugins/siem/server/kibana.index.ts index 7060a3f662914..9ceb8e02864ec 100644 --- a/x-pack/legacy/plugins/siem/server/kibana.index.ts +++ b/x-pack/legacy/plugins/siem/server/kibana.index.ts @@ -27,6 +27,7 @@ import { updateRulesBulkRoute } from './lib/detection_engine/routes/rules/update import { deleteRulesBulkRoute } from './lib/detection_engine/routes/rules/delete_rules_bulk_route'; import { importRulesRoute } from './lib/detection_engine/routes/rules/import_rules_route'; import { exportRulesRoute } from './lib/detection_engine/routes/rules/export_rules_route'; +import { findRulesStatusesRoute } from './lib/detection_engine/routes/rules/find_rules_status_route'; const APP_ID = 'siem'; @@ -54,6 +55,7 @@ export const initServerWithKibana = (context: PluginInitializerContext, __legacy deleteRulesBulkRoute(__legacy); importRulesRoute(__legacy); exportRulesRoute(__legacy); + findRulesStatusesRoute(__legacy); // Detection Engine Signals routes that have the REST endpoints of /api/detection_engine/signals // POST /api/detection_engine/signals/status diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/__mocks__/_mock_server.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/__mocks__/_mock_server.ts index 8b7f6c765e710..1e475f2014fa2 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/__mocks__/_mock_server.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/__mocks__/_mock_server.ts @@ -7,7 +7,7 @@ import Hapi from 'hapi'; import { KibanaConfig } from 'src/legacy/server/kbn_server'; import { ElasticsearchPlugin } from 'src/legacy/core_plugins/elasticsearch'; - +import { savedObjectsClientMock } from '../../../../../../../../../src/core/server/mocks'; import { alertsClientMock } from '../../../../../../alerting/server/alerts_client.mock'; import { actionsClientMock } from '../../../../../../actions/server/actions_client.mock'; @@ -48,6 +48,7 @@ export const createMockServer = (config: Record = defaultConfig) const actionsClient = actionsClientMock.create(); const alertsClient = alertsClientMock.create(); + const savedObjectsClient = savedObjectsClientMock.create(); const elasticsearch = { getCluster: jest.fn().mockImplementation(() => ({ callWithRequest: jest.fn(), @@ -57,8 +58,15 @@ export const createMockServer = (config: Record = defaultConfig) server.decorate('request', 'getBasePath', () => '/s/default'); server.decorate('request', 'getActionsClient', () => actionsClient); server.plugins.elasticsearch = (elasticsearch as unknown) as ElasticsearchPlugin; + server.decorate('request', 'getSavedObjectsClient', () => savedObjectsClient); - return { server, alertsClient, actionsClient, elasticsearch }; + return { + server, + alertsClient, + actionsClient, + elasticsearch, + savedObjectsClient, + }; }; export const createMockServerWithoutAlertClientDecoration = ( diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/__mocks__/request_responses.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/__mocks__/request_responses.ts index 8ed5333bd2a25..01f30a3ebbdea 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/__mocks__/request_responses.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/__mocks__/request_responses.ts @@ -5,6 +5,7 @@ */ import { ServerInjectOptions } from 'hapi'; +import { SavedObjectsFindResponse } from 'kibana/server'; import { ActionResult } from '../../../../../../actions/server/types'; import { SignalsStatusRestParams, SignalsQueryRestParams } from '../../signals/types'; import { @@ -15,7 +16,7 @@ import { INTERNAL_RULE_ID_KEY, INTERNAL_IMMUTABLE_KEY, } from '../../../../../common/constants'; -import { RuleAlertType } from '../../rules/types'; +import { RuleAlertType, IRuleSavedAttributesSavedObjectAttributes } from '../../rules/types'; import { RuleAlertParamsRest } from '../../types'; export const fullRuleAlertParamsRest = (): RuleAlertParamsRest => ({ @@ -383,3 +384,10 @@ export const getMockPrivileges = () => ({ application: {}, isAuthenticated: false, }); + +export const getFindResultStatus = (): SavedObjectsFindResponse => ({ + page: 1, + per_page: 1, + total: 0, + saved_objects: [], +}); diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/privileges/read_privileges_route.test.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/privileges/read_privileges_route.test.ts index 1ea681afb7949..54872f80a4c6d 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/privileges/read_privileges_route.test.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/privileges/read_privileges_route.test.ts @@ -7,6 +7,7 @@ import { createMockServer } from '../__mocks__/_mock_server'; import { getPrivilegeRequest, getMockPrivileges } from '../__mocks__/request_responses'; import { readPrivilegesRoute } from './read_privileges_route'; +import { ServerFacade } from '../../../../types'; import * as myUtils from '../utils'; describe('read_privileges', () => { @@ -18,7 +19,7 @@ describe('read_privileges', () => { elasticsearch.getCluster = jest.fn(() => ({ callWithRequest: jest.fn(() => getMockPrivileges()), })); - readPrivilegesRoute(server); + readPrivilegesRoute((server as unknown) as ServerFacade); }); afterEach(() => { diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/create_rules_bulk_route.test.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/create_rules_bulk_route.test.ts index d3890f82c8abf..d5650b078e678 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/create_rules_bulk_route.test.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/create_rules_bulk_route.test.ts @@ -12,6 +12,7 @@ import { } from '../__mocks__/_mock_server'; import { createRulesRoute } from './create_rules_route'; import { ServerInjectOptions } from 'hapi'; +import { ServerFacade } from '../../../../types'; import { getFindResult, getResult, @@ -32,7 +33,7 @@ describe('create_rules_bulk', () => { callWithRequest: jest.fn().mockImplementation(() => true), })); - createRulesBulkRoute(server); + createRulesBulkRoute((server as unknown) as ServerFacade); }); describe('status codes with actionClient and alertClient', () => { @@ -47,14 +48,14 @@ describe('create_rules_bulk', () => { test('returns 404 if actionClient is not available on the route', async () => { const { serverWithoutActionClient } = createMockServerWithoutActionClientDecoration(); - createRulesRoute(serverWithoutActionClient); + createRulesRoute((serverWithoutActionClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutActionClient.inject(getReadBulkRequest()); expect(statusCode).toBe(404); }); test('returns 404 if alertClient is not available on the route', async () => { const { serverWithoutAlertClient } = createMockServerWithoutAlertClientDecoration(); - createRulesRoute(serverWithoutAlertClient); + createRulesRoute((serverWithoutAlertClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutAlertClient.inject(getReadBulkRequest()); expect(statusCode).toBe(404); }); @@ -63,7 +64,7 @@ describe('create_rules_bulk', () => { const { serverWithoutActionOrAlertClient, } = createMockServerWithoutActionOrAlertClientDecoration(); - createRulesRoute(serverWithoutActionOrAlertClient); + createRulesRoute((serverWithoutActionOrAlertClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutActionOrAlertClient.inject(getReadBulkRequest()); expect(statusCode).toBe(404); }); diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/create_rules_bulk_route.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/create_rules_bulk_route.ts index 3d9719a7b248b..15e3361986ab9 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/create_rules_bulk_route.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/create_rules_bulk_route.ts @@ -40,8 +40,10 @@ export const createCreateRulesBulkRoute = (server: ServerFacade): Hapi.ServerRou const actionsClient = isFunction(request.getActionsClient) ? request.getActionsClient() : null; - - if (!alertsClient || !actionsClient) { + const savedObjectsClient = isFunction(request.getSavedObjectsClient) + ? request.getSavedObjectsClient() + : null; + if (!alertsClient || !actionsClient || !savedObjectsClient) { return headers.response().code(404); } diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/create_rules_route.test.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/create_rules_route.test.ts index 10dc14f7ed610..466d150d58466 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/create_rules_route.test.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/create_rules_route.test.ts @@ -12,28 +12,43 @@ import { } from '../__mocks__/_mock_server'; import { createRulesRoute } from './create_rules_route'; import { ServerInjectOptions } from 'hapi'; +import { ServerFacade } from '../../../../types'; + import { getFindResult, getResult, createActionResult, getCreateRequest, typicalPayload, + getFindResultStatus, } from '../__mocks__/request_responses'; import { DETECTION_ENGINE_RULES_URL } from '../../../../../common/constants'; describe('create_rules', () => { - let { server, alertsClient, actionsClient, elasticsearch } = createMockServer(); + let { + server, + alertsClient, + actionsClient, + elasticsearch, + savedObjectsClient, + } = createMockServer(); beforeEach(() => { jest.resetAllMocks(); - ({ server, alertsClient, actionsClient, elasticsearch } = createMockServer()); + ({ + server, + alertsClient, + actionsClient, + elasticsearch, + savedObjectsClient, + } = createMockServer()); elasticsearch.getCluster = jest.fn().mockImplementation(() => ({ callWithRequest: jest .fn() .mockImplementation((endpoint, params) => ({ _shards: { total: 1 } })), })); - createRulesRoute(server); + createRulesRoute((server as unknown) as ServerFacade); }); describe('status codes with actionClient and alertClient', () => { @@ -42,20 +57,21 @@ describe('create_rules', () => { alertsClient.get.mockResolvedValue(getResult()); actionsClient.create.mockResolvedValue(createActionResult()); alertsClient.create.mockResolvedValue(getResult()); + savedObjectsClient.find.mockResolvedValue(getFindResultStatus()); const { statusCode } = await server.inject(getCreateRequest()); expect(statusCode).toBe(200); }); test('returns 404 if actionClient is not available on the route', async () => { const { serverWithoutActionClient } = createMockServerWithoutActionClientDecoration(); - createRulesRoute(serverWithoutActionClient); + createRulesRoute((serverWithoutActionClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutActionClient.inject(getCreateRequest()); expect(statusCode).toBe(404); }); test('returns 404 if alertClient is not available on the route', async () => { const { serverWithoutAlertClient } = createMockServerWithoutAlertClientDecoration(); - createRulesRoute(serverWithoutAlertClient); + createRulesRoute((serverWithoutAlertClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutAlertClient.inject(getCreateRequest()); expect(statusCode).toBe(404); }); @@ -64,7 +80,7 @@ describe('create_rules', () => { const { serverWithoutActionOrAlertClient, } = createMockServerWithoutActionOrAlertClientDecoration(); - createRulesRoute(serverWithoutActionOrAlertClient); + createRulesRoute((serverWithoutActionOrAlertClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutActionOrAlertClient.inject(getCreateRequest()); expect(statusCode).toBe(404); }); @@ -76,6 +92,7 @@ describe('create_rules', () => { alertsClient.get.mockResolvedValue(getResult()); actionsClient.create.mockResolvedValue(createActionResult()); alertsClient.create.mockResolvedValue(getResult()); + savedObjectsClient.find.mockResolvedValue(getFindResultStatus()); // missing rule_id should return 200 as it will be auto generated if not given const { rule_id, ...noRuleId } = typicalPayload(); const request: ServerInjectOptions = { @@ -92,6 +109,7 @@ describe('create_rules', () => { alertsClient.get.mockResolvedValue(getResult()); actionsClient.create.mockResolvedValue(createActionResult()); alertsClient.create.mockResolvedValue(getResult()); + savedObjectsClient.find.mockResolvedValue(getFindResultStatus()); const { type, ...noType } = typicalPayload(); const request: ServerInjectOptions = { method: 'POST', @@ -110,6 +128,7 @@ describe('create_rules', () => { alertsClient.get.mockResolvedValue(getResult()); actionsClient.create.mockResolvedValue(createActionResult()); alertsClient.create.mockResolvedValue(getResult()); + savedObjectsClient.find.mockResolvedValue(getFindResultStatus()); const { type, ...noType } = typicalPayload(); const request: ServerInjectOptions = { method: 'POST', diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/create_rules_route.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/create_rules_route.ts index cf8fb2a28288f..3e173e358557a 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/create_rules_route.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/create_rules_route.ts @@ -10,10 +10,11 @@ import Boom from 'boom'; import uuid from 'uuid'; import { DETECTION_ENGINE_RULES_URL } from '../../../../../common/constants'; import { createRules } from '../../rules/create_rules'; -import { RulesRequest } from '../../rules/types'; +import { RulesRequest, IRuleSavedAttributesSavedObjectAttributes } from '../../rules/types'; import { createRulesSchema } from '../schemas/create_rules_schema'; import { ServerFacade } from '../../../../types'; import { readRules } from '../../rules/read_rules'; +import { ruleStatusSavedObjectType } from '../../rules/saved_object_mappings'; import { transformOrError } from './utils'; import { getIndexExists } from '../../index/get_index_exists'; import { callWithRequestFactory, getIndex, transformError } from '../utils'; @@ -65,8 +66,10 @@ export const createCreateRulesRoute = (server: ServerFacade): Hapi.ServerRoute = const actionsClient = isFunction(request.getActionsClient) ? request.getActionsClient() : null; - - if (!alertsClient || !actionsClient) { + const savedObjectsClient = isFunction(request.getSavedObjectsClient) + ? request.getSavedObjectsClient() + : null; + if (!alertsClient || !actionsClient || !savedObjectsClient) { return headers.response().code(404); } @@ -120,7 +123,17 @@ export const createCreateRulesRoute = (server: ServerFacade): Hapi.ServerRoute = references, version: 1, }); - return transformOrError(createdRule); + const ruleStatuses = await savedObjectsClient.find< + IRuleSavedAttributesSavedObjectAttributes + >({ + type: ruleStatusSavedObjectType, + perPage: 1, + sortField: 'statusDate', + sortOrder: 'desc', + search: `${createdRule.id}`, + searchFields: ['alertId'], + }); + return transformOrError(createdRule, ruleStatuses.saved_objects[0]); } catch (err) { return transformError(err); } diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/delete_rules_bulk_route.test.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/delete_rules_bulk_route.test.ts index bab05b065f6f7..3c429c3e38f3a 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/delete_rules_bulk_route.test.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/delete_rules_bulk_route.test.ts @@ -20,18 +20,20 @@ import { getDeleteBulkRequestById, getDeleteAsPostBulkRequest, getDeleteAsPostBulkRequestById, + getFindResultStatus, } from '../__mocks__/request_responses'; +import { ServerFacade } from '../../../../types'; import { DETECTION_ENGINE_RULES_URL } from '../../../../../common/constants'; import { deleteRulesBulkRoute } from './delete_rules_bulk_route'; import { BulkError } from '../utils'; describe('delete_rules', () => { - let { server, alertsClient } = createMockServer(); + let { server, alertsClient, savedObjectsClient } = createMockServer(); beforeEach(() => { - ({ server, alertsClient } = createMockServer()); - deleteRulesBulkRoute(server); + ({ server, alertsClient, savedObjectsClient } = createMockServer()); + deleteRulesBulkRoute((server as unknown) as ServerFacade); }); afterEach(() => { @@ -83,6 +85,8 @@ describe('delete_rules', () => { alertsClient.find.mockResolvedValue(getFindResult()); alertsClient.get.mockResolvedValue(getResult()); alertsClient.delete.mockResolvedValue({}); + savedObjectsClient.find.mockResolvedValue(getFindResultStatus()); + savedObjectsClient.delete.mockResolvedValue({}); const { payload } = await server.inject(getDeleteBulkRequest()); const parsed: BulkError[] = JSON.parse(payload); const expected: BulkError[] = [ @@ -96,14 +100,14 @@ describe('delete_rules', () => { test('returns 404 if actionClient is not available on the route', async () => { const { serverWithoutActionClient } = createMockServerWithoutActionClientDecoration(); - deleteRulesBulkRoute(serverWithoutActionClient); + deleteRulesBulkRoute((serverWithoutActionClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutActionClient.inject(getDeleteBulkRequest()); expect(statusCode).toBe(404); }); test('returns 404 if alertClient is not available on the route', async () => { const { serverWithoutAlertClient } = createMockServerWithoutAlertClientDecoration(); - deleteRulesBulkRoute(serverWithoutAlertClient); + deleteRulesBulkRoute((serverWithoutAlertClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutAlertClient.inject(getDeleteBulkRequest()); expect(statusCode).toBe(404); }); @@ -112,7 +116,7 @@ describe('delete_rules', () => { const { serverWithoutActionOrAlertClient, } = createMockServerWithoutActionOrAlertClientDecoration(); - deleteRulesBulkRoute(serverWithoutActionOrAlertClient); + deleteRulesBulkRoute((serverWithoutActionOrAlertClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutActionOrAlertClient.inject(getDeleteBulkRequest()); expect(statusCode).toBe(404); }); diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/delete_rules_bulk_route.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/delete_rules_bulk_route.ts index a0801930f879a..b77ae56a486c8 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/delete_rules_bulk_route.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/delete_rules_bulk_route.ts @@ -13,7 +13,8 @@ import { ServerFacade } from '../../../../types'; import { queryRulesBulkSchema } from '../schemas/query_rules_bulk_schema'; import { transformOrBulkError, getIdBulkError } from './utils'; import { transformBulkError } from '../utils'; -import { QueryBulkRequest } from '../../rules/types'; +import { QueryBulkRequest, IRuleSavedAttributesSavedObjectAttributes } from '../../rules/types'; +import { ruleStatusSavedObjectType } from '../../rules/saved_object_mappings'; export const createDeleteRulesBulkRoute: Hapi.ServerRoute = { method: ['POST', 'DELETE'], // allow both POST and DELETE in case their client does not support bodies in DELETE @@ -30,8 +31,10 @@ export const createDeleteRulesBulkRoute: Hapi.ServerRoute = { async handler(request: QueryBulkRequest, headers) { const alertsClient = isFunction(request.getAlertsClient) ? request.getAlertsClient() : null; const actionsClient = isFunction(request.getActionsClient) ? request.getActionsClient() : null; - - if (alertsClient == null || actionsClient == null) { + const savedObjectsClient = isFunction(request.getSavedObjectsClient) + ? request.getSavedObjectsClient() + : null; + if (!alertsClient || !actionsClient || !savedObjectsClient) { return headers.response().code(404); } const rules = Promise.all( @@ -45,8 +48,18 @@ export const createDeleteRulesBulkRoute: Hapi.ServerRoute = { id, ruleId, }); - if (rule != null) { + const ruleStatuses = await savedObjectsClient.find< + IRuleSavedAttributesSavedObjectAttributes + >({ + type: ruleStatusSavedObjectType, + perPage: 6, + search: rule.id, + searchFields: ['alertId'], + }); + ruleStatuses.saved_objects.forEach(async obj => + savedObjectsClient.delete(ruleStatusSavedObjectType, obj.id) + ); return transformOrBulkError(idOrRuleIdOrUnknown, rule); } else { return getIdBulkError({ id, ruleId }); diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/delete_rules_route.test.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/delete_rules_route.test.ts index cacafcf741e6a..ee4edada52b6a 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/delete_rules_route.test.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/delete_rules_route.test.ts @@ -13,21 +13,24 @@ import { import { deleteRulesRoute } from './delete_rules_route'; import { ServerInjectOptions } from 'hapi'; +import { ServerFacade } from '../../../../types'; + import { getFindResult, getResult, getDeleteRequest, getFindResultWithSingleHit, getDeleteRequestById, + getFindResultStatus, } from '../__mocks__/request_responses'; import { DETECTION_ENGINE_RULES_URL } from '../../../../../common/constants'; describe('delete_rules', () => { - let { server, alertsClient } = createMockServer(); + let { server, alertsClient, savedObjectsClient } = createMockServer(); beforeEach(() => { - ({ server, alertsClient } = createMockServer()); - deleteRulesRoute(server); + ({ server, alertsClient, savedObjectsClient } = createMockServer()); + deleteRulesRoute((server as unknown) as ServerFacade); }); afterEach(() => { @@ -39,6 +42,8 @@ describe('delete_rules', () => { alertsClient.find.mockResolvedValue(getFindResultWithSingleHit()); alertsClient.get.mockResolvedValue(getResult()); alertsClient.delete.mockResolvedValue({}); + savedObjectsClient.find.mockResolvedValue(getFindResultStatus()); + savedObjectsClient.delete.mockResolvedValue({}); const { statusCode } = await server.inject(getDeleteRequest()); expect(statusCode).toBe(200); }); @@ -47,6 +52,8 @@ describe('delete_rules', () => { alertsClient.find.mockResolvedValue(getFindResultWithSingleHit()); alertsClient.get.mockResolvedValue(getResult()); alertsClient.delete.mockResolvedValue({}); + savedObjectsClient.find.mockResolvedValue(getFindResultStatus()); + savedObjectsClient.delete.mockResolvedValue({}); const { statusCode } = await server.inject(getDeleteRequestById()); expect(statusCode).toBe(200); }); @@ -55,20 +62,22 @@ describe('delete_rules', () => { alertsClient.find.mockResolvedValue(getFindResult()); alertsClient.get.mockResolvedValue(getResult()); alertsClient.delete.mockResolvedValue({}); + savedObjectsClient.find.mockResolvedValue(getFindResultStatus()); + savedObjectsClient.delete.mockResolvedValue({}); const { statusCode } = await server.inject(getDeleteRequest()); expect(statusCode).toBe(404); }); test('returns 404 if actionClient is not available on the route', async () => { const { serverWithoutActionClient } = createMockServerWithoutActionClientDecoration(); - deleteRulesRoute(serverWithoutActionClient); + deleteRulesRoute((serverWithoutActionClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutActionClient.inject(getDeleteRequest()); expect(statusCode).toBe(404); }); test('returns 404 if alertClient is not available on the route', async () => { const { serverWithoutAlertClient } = createMockServerWithoutAlertClientDecoration(); - deleteRulesRoute(serverWithoutAlertClient); + deleteRulesRoute((serverWithoutAlertClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutAlertClient.inject(getDeleteRequest()); expect(statusCode).toBe(404); }); @@ -77,7 +86,7 @@ describe('delete_rules', () => { const { serverWithoutActionOrAlertClient, } = createMockServerWithoutActionOrAlertClientDecoration(); - deleteRulesRoute(serverWithoutActionOrAlertClient); + deleteRulesRoute((serverWithoutActionOrAlertClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutActionOrAlertClient.inject(getDeleteRequest()); expect(statusCode).toBe(404); }); diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/delete_rules_route.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/delete_rules_route.ts index 8f771236269d9..ea8b54a79a5e3 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/delete_rules_route.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/delete_rules_route.ts @@ -13,7 +13,8 @@ import { ServerFacade } from '../../../../types'; import { queryRulesSchema } from '../schemas/query_rules_schema'; import { getIdError, transformOrError } from './utils'; import { transformError } from '../utils'; -import { QueryRequest } from '../../rules/types'; +import { QueryRequest, IRuleSavedAttributesSavedObjectAttributes } from '../../rules/types'; +import { ruleStatusSavedObjectType } from '../../rules/saved_object_mappings'; export const createDeleteRulesRoute: Hapi.ServerRoute = { method: 'DELETE', @@ -31,8 +32,10 @@ export const createDeleteRulesRoute: Hapi.ServerRoute = { const { id, rule_id: ruleId } = request.query; const alertsClient = isFunction(request.getAlertsClient) ? request.getAlertsClient() : null; const actionsClient = isFunction(request.getActionsClient) ? request.getActionsClient() : null; - - if (alertsClient == null || actionsClient == null) { + const savedObjectsClient = isFunction(request.getSavedObjectsClient) + ? request.getSavedObjectsClient() + : null; + if (!alertsClient || !actionsClient || !savedObjectsClient) { return headers.response().code(404); } @@ -43,9 +46,19 @@ export const createDeleteRulesRoute: Hapi.ServerRoute = { id, ruleId, }); - if (rule != null) { - return transformOrError(rule); + const ruleStatuses = await savedObjectsClient.find< + IRuleSavedAttributesSavedObjectAttributes + >({ + type: ruleStatusSavedObjectType, + perPage: 6, + search: rule.id, + searchFields: ['alertId'], + }); + ruleStatuses.saved_objects.forEach(async obj => + savedObjectsClient.delete(ruleStatusSavedObjectType, obj.id) + ); + return transformOrError(rule, ruleStatuses.saved_objects[0]); } else { return getIdError({ id, ruleId }); } diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/find_rules_route.test.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/find_rules_route.test.ts index 38937c13d302c..639e4877f7f72 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/find_rules_route.test.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/find_rules_route.test.ts @@ -13,6 +13,8 @@ import { import { findRulesRoute } from './find_rules_route'; import { ServerInjectOptions } from 'hapi'; +import { ServerFacade } from '../../../../types'; + import { getFindResult, getResult, getFindRequest } from '../__mocks__/request_responses'; import { DETECTION_ENGINE_RULES_URL } from '../../../../../common/constants'; @@ -21,7 +23,7 @@ describe('find_rules', () => { beforeEach(() => { ({ server, alertsClient, actionsClient } = createMockServer()); - findRulesRoute(server); + findRulesRoute((server as unknown) as ServerFacade); }); afterEach(() => { @@ -44,14 +46,14 @@ describe('find_rules', () => { test('returns 404 if actionClient is not available on the route', async () => { const { serverWithoutActionClient } = createMockServerWithoutActionClientDecoration(); - findRulesRoute(serverWithoutActionClient); + findRulesRoute((serverWithoutActionClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutActionClient.inject(getFindRequest()); expect(statusCode).toBe(404); }); test('returns 404 if alertClient is not available on the route', async () => { const { serverWithoutAlertClient } = createMockServerWithoutAlertClientDecoration(); - findRulesRoute(serverWithoutAlertClient); + findRulesRoute((serverWithoutAlertClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutAlertClient.inject(getFindRequest()); expect(statusCode).toBe(404); }); @@ -60,7 +62,7 @@ describe('find_rules', () => { const { serverWithoutActionOrAlertClient, } = createMockServerWithoutActionOrAlertClientDecoration(); - findRulesRoute(serverWithoutActionOrAlertClient); + findRulesRoute((serverWithoutActionOrAlertClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutActionOrAlertClient.inject(getFindRequest()); expect(statusCode).toBe(404); }); diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/find_rules_route.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/find_rules_route.ts index 6e89ddb19017d..6cbc794751f9f 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/find_rules_route.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/find_rules_route.ts @@ -8,11 +8,12 @@ import Hapi from 'hapi'; import { isFunction } from 'lodash/fp'; import { DETECTION_ENGINE_RULES_URL } from '../../../../../common/constants'; import { findRules } from '../../rules/find_rules'; -import { FindRulesRequest } from '../../rules/types'; +import { FindRulesRequest, IRuleSavedAttributesSavedObjectAttributes } from '../../rules/types'; import { findRulesSchema } from '../schemas/find_rules_schema'; import { ServerFacade } from '../../../../types'; import { transformFindAlertsOrError } from './utils'; import { transformError } from '../utils'; +import { ruleStatusSavedObjectType } from '../../rules/saved_object_mappings'; export const createFindRulesRoute: Hapi.ServerRoute = { method: 'GET', @@ -30,8 +31,10 @@ export const createFindRulesRoute: Hapi.ServerRoute = { const { query } = request; const alertsClient = isFunction(request.getAlertsClient) ? request.getAlertsClient() : null; const actionsClient = isFunction(request.getActionsClient) ? request.getActionsClient() : null; - - if (!alertsClient || !actionsClient) { + const savedObjectsClient = isFunction(request.getSavedObjectsClient) + ? request.getSavedObjectsClient() + : null; + if (!alertsClient || !actionsClient || !savedObjectsClient) { return headers.response().code(404); } @@ -44,7 +47,20 @@ export const createFindRulesRoute: Hapi.ServerRoute = { sortOrder: query.sort_order, filter: query.filter, }); - return transformFindAlertsOrError(rules); + const ruleStatuses = await Promise.all( + rules.data.map(async rule => { + const results = await savedObjectsClient.find({ + type: ruleStatusSavedObjectType, + perPage: 1, + sortField: 'statusDate', + sortOrder: 'desc', + search: rule.id, + searchFields: ['alertId'], + }); + return results; + }) + ); + return transformFindAlertsOrError(rules, ruleStatuses); } catch (err) { return transformError(err); } diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/find_rules_status_route.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/find_rules_status_route.ts new file mode 100644 index 0000000000000..e56c440f5a415 --- /dev/null +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/find_rules_status_route.ts @@ -0,0 +1,82 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import Hapi from 'hapi'; +import { isFunction, snakeCase } from 'lodash/fp'; + +import { DETECTION_ENGINE_RULES_URL } from '../../../../../common/constants'; +import { ServerFacade } from '../../../../types'; +import { findRulesStatusesSchema } from '../schemas/find_rules_statuses_schema'; +import { + FindRulesStatusesRequest, + IRuleSavedAttributesSavedObjectAttributes, +} from '../../rules/types'; +import { ruleStatusSavedObjectType } from '../../rules/saved_object_mappings'; + +const convertToSnakeCase = (obj: IRuleSavedAttributesSavedObjectAttributes) => { + return Object.keys(obj).reduce((acc, item) => { + const newKey = snakeCase(item); + return { ...acc, [newKey]: obj[item] }; + }, {}); +}; + +export const createFindRulesStatusRoute: Hapi.ServerRoute = { + method: 'GET', + path: `${DETECTION_ENGINE_RULES_URL}/_find_statuses`, + options: { + tags: ['access:siem'], + validate: { + options: { + abortEarly: false, + }, + query: findRulesStatusesSchema, + }, + }, + async handler(request: FindRulesStatusesRequest, headers) { + const { query } = request; + const alertsClient = isFunction(request.getAlertsClient) ? request.getAlertsClient() : null; + const actionsClient = isFunction(request.getActionsClient) ? request.getActionsClient() : null; + const savedObjectsClient = isFunction(request.getSavedObjectsClient) + ? request.getSavedObjectsClient() + : null; + if (!alertsClient || !actionsClient || !savedObjectsClient) { + return headers.response().code(404); + } + + // build return object with ids as keys and errors as values. + /* looks like this + { + "someAlertId": [{"myerrorobject": "some error value"}, etc..], + "anotherAlertId": ... + } + */ + const statuses = await query.ids.reduce(async (acc, id) => { + const lastFiveErrorsForId = await savedObjectsClient.find< + IRuleSavedAttributesSavedObjectAttributes + >({ + type: ruleStatusSavedObjectType, + perPage: 6, + sortField: 'statusDate', + sortOrder: 'desc', + search: id, + searchFields: ['alertId'], + }); + const toDisplay = + lastFiveErrorsForId.saved_objects.length <= 5 + ? lastFiveErrorsForId.saved_objects + : lastFiveErrorsForId.saved_objects.slice(1); + return { + ...(await acc), + [id]: toDisplay.map(errorItem => convertToSnakeCase(errorItem.attributes)), + }; + }, {}); + return statuses; + }, +}; + +export const findRulesStatusesRoute = (server: ServerFacade): void => { + server.route(createFindRulesStatusRoute); +}; diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/read_rules_route.test.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/read_rules_route.test.ts index 0d77583573c13..92db4be1c9ff9 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/read_rules_route.test.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/read_rules_route.test.ts @@ -13,20 +13,23 @@ import { import { readRulesRoute } from './read_rules_route'; import { ServerInjectOptions } from 'hapi'; +import { ServerFacade } from '../../../../types'; + import { getFindResult, getResult, getReadRequest, getFindResultWithSingleHit, + getFindResultStatus, } from '../__mocks__/request_responses'; import { DETECTION_ENGINE_RULES_URL } from '../../../../../common/constants'; describe('read_signals', () => { - let { server, alertsClient } = createMockServer(); + let { server, alertsClient, savedObjectsClient } = createMockServer(); beforeEach(() => { - ({ server, alertsClient } = createMockServer()); - readRulesRoute(server); + ({ server, alertsClient, savedObjectsClient } = createMockServer()); + readRulesRoute((server as unknown) as ServerFacade); }); afterEach(() => { @@ -37,20 +40,21 @@ describe('read_signals', () => { test('returns 200 when reading a single rule with a valid actionClient and alertClient', async () => { alertsClient.find.mockResolvedValue(getFindResultWithSingleHit()); alertsClient.get.mockResolvedValue(getResult()); + savedObjectsClient.find.mockResolvedValue(getFindResultStatus()); const { statusCode } = await server.inject(getReadRequest()); expect(statusCode).toBe(200); }); test('returns 404 if actionClient is not available on the route', async () => { const { serverWithoutActionClient } = createMockServerWithoutActionClientDecoration(); - readRulesRoute(serverWithoutActionClient); + readRulesRoute((serverWithoutActionClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutActionClient.inject(getReadRequest()); expect(statusCode).toBe(404); }); test('returns 404 if alertClient is not available on the route', async () => { const { serverWithoutAlertClient } = createMockServerWithoutAlertClientDecoration(); - readRulesRoute(serverWithoutAlertClient); + readRulesRoute((serverWithoutAlertClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutAlertClient.inject(getReadRequest()); expect(statusCode).toBe(404); }); @@ -59,7 +63,7 @@ describe('read_signals', () => { const { serverWithoutActionOrAlertClient, } = createMockServerWithoutActionOrAlertClientDecoration(); - readRulesRoute(serverWithoutActionOrAlertClient); + readRulesRoute((serverWithoutActionOrAlertClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutActionOrAlertClient.inject(getReadRequest()); expect(statusCode).toBe(404); }); @@ -70,6 +74,7 @@ describe('read_signals', () => { alertsClient.find.mockResolvedValue(getFindResult()); alertsClient.get.mockResolvedValue(getResult()); alertsClient.delete.mockResolvedValue({}); + savedObjectsClient.find.mockResolvedValue(getFindResultStatus()); const request: ServerInjectOptions = { method: 'GET', url: DETECTION_ENGINE_RULES_URL, diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/read_rules_route.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/read_rules_route.ts index 4ff26ae99bd13..25d8e6770f699 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/read_rules_route.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/read_rules_route.ts @@ -13,7 +13,8 @@ import { transformError } from '../utils'; import { readRules } from '../../rules/read_rules'; import { ServerFacade } from '../../../../types'; import { queryRulesSchema } from '../schemas/query_rules_schema'; -import { QueryRequest } from '../../rules/types'; +import { QueryRequest, IRuleSavedAttributesSavedObjectAttributes } from '../../rules/types'; +import { ruleStatusSavedObjectType } from '../../rules/saved_object_mappings'; export const createReadRulesRoute: Hapi.ServerRoute = { method: 'GET', @@ -31,8 +32,10 @@ export const createReadRulesRoute: Hapi.ServerRoute = { const { id, rule_id: ruleId } = request.query; const alertsClient = isFunction(request.getAlertsClient) ? request.getAlertsClient() : null; const actionsClient = isFunction(request.getActionsClient) ? request.getActionsClient() : null; - - if (!alertsClient || !actionsClient) { + const savedObjectsClient = isFunction(request.getSavedObjectsClient) + ? request.getSavedObjectsClient() + : null; + if (!alertsClient || !actionsClient || !savedObjectsClient) { return headers.response().code(404); } try { @@ -42,7 +45,17 @@ export const createReadRulesRoute: Hapi.ServerRoute = { ruleId, }); if (rule != null) { - return transformOrError(rule); + const ruleStatuses = await savedObjectsClient.find< + IRuleSavedAttributesSavedObjectAttributes + >({ + type: ruleStatusSavedObjectType, + perPage: 1, + sortField: 'statusDate', + sortOrder: 'desc', + search: rule.id, + searchFields: ['alertId'], + }); + return transformOrError(rule, ruleStatuses.saved_objects[0]); } else { return getIdError({ id, ruleId }); } diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/update_rules_bulk.test.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/update_rules_bulk.test.ts index 2410dcee203f6..2ab2610834195 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/update_rules_bulk.test.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/update_rules_bulk.test.ts @@ -13,6 +13,8 @@ import { import { updateRulesRoute } from './update_rules_route'; import { ServerInjectOptions } from 'hapi'; +import { ServerFacade } from '../../../../types'; + import { getFindResult, getResult, @@ -31,7 +33,7 @@ describe('update_rules_bulk', () => { beforeEach(() => { jest.resetAllMocks(); ({ server, alertsClient, actionsClient } = createMockServer()); - updateRulesBulkRoute(server); + updateRulesBulkRoute((server as unknown) as ServerFacade); }); describe('status codes with actionClient and alertClient', () => { @@ -71,14 +73,14 @@ describe('update_rules_bulk', () => { test('returns 404 if actionClient is not available on the route', async () => { const { serverWithoutActionClient } = createMockServerWithoutActionClientDecoration(); - updateRulesRoute(serverWithoutActionClient); + updateRulesRoute((serverWithoutActionClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutActionClient.inject(getUpdateBulkRequest()); expect(statusCode).toBe(404); }); test('returns 404 if alertClient is not available on the route', async () => { const { serverWithoutAlertClient } = createMockServerWithoutAlertClientDecoration(); - updateRulesRoute(serverWithoutAlertClient); + updateRulesRoute((serverWithoutAlertClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutAlertClient.inject(getUpdateBulkRequest()); expect(statusCode).toBe(404); }); @@ -87,7 +89,7 @@ describe('update_rules_bulk', () => { const { serverWithoutActionOrAlertClient, } = createMockServerWithoutActionOrAlertClientDecoration(); - updateRulesRoute(serverWithoutActionOrAlertClient); + updateRulesRoute((serverWithoutActionOrAlertClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutActionOrAlertClient.inject(getUpdateBulkRequest()); expect(statusCode).toBe(404); }); diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/update_rules_route.test.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/update_rules_route.test.ts index 3cf5c07655d92..d33989b8a7ce5 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/update_rules_route.test.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/update_rules_route.test.ts @@ -13,8 +13,11 @@ import { import { updateRulesRoute } from './update_rules_route'; import { ServerInjectOptions } from 'hapi'; +import { ServerFacade } from '../../../../types'; + import { getFindResult, + getFindResultStatus, getResult, updateActionResult, getUpdateRequest, @@ -24,12 +27,12 @@ import { import { DETECTION_ENGINE_RULES_URL } from '../../../../../common/constants'; describe('update_rules', () => { - let { server, alertsClient, actionsClient } = createMockServer(); + let { server, alertsClient, actionsClient, savedObjectsClient } = createMockServer(); beforeEach(() => { jest.resetAllMocks(); - ({ server, alertsClient, actionsClient } = createMockServer()); - updateRulesRoute(server); + ({ server, alertsClient, actionsClient, savedObjectsClient } = createMockServer()); + updateRulesRoute((server as unknown) as ServerFacade); }); describe('status codes with actionClient and alertClient', () => { @@ -38,6 +41,7 @@ describe('update_rules', () => { alertsClient.get.mockResolvedValue(getResult()); actionsClient.update.mockResolvedValue(updateActionResult()); alertsClient.update.mockResolvedValue(getResult()); + savedObjectsClient.find.mockResolvedValue(getFindResultStatus()); const { statusCode } = await server.inject(getUpdateRequest()); expect(statusCode).toBe(200); }); @@ -47,20 +51,21 @@ describe('update_rules', () => { alertsClient.get.mockResolvedValue(getResult()); actionsClient.update.mockResolvedValue(updateActionResult()); alertsClient.update.mockResolvedValue(getResult()); + savedObjectsClient.find.mockResolvedValue(getFindResultStatus()); const { statusCode } = await server.inject(getUpdateRequest()); expect(statusCode).toBe(404); }); test('returns 404 if actionClient is not available on the route', async () => { const { serverWithoutActionClient } = createMockServerWithoutActionClientDecoration(); - updateRulesRoute(serverWithoutActionClient); + updateRulesRoute((serverWithoutActionClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutActionClient.inject(getUpdateRequest()); expect(statusCode).toBe(404); }); test('returns 404 if alertClient is not available on the route', async () => { const { serverWithoutAlertClient } = createMockServerWithoutAlertClientDecoration(); - updateRulesRoute(serverWithoutAlertClient); + updateRulesRoute((serverWithoutAlertClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutAlertClient.inject(getUpdateRequest()); expect(statusCode).toBe(404); }); @@ -69,7 +74,7 @@ describe('update_rules', () => { const { serverWithoutActionOrAlertClient, } = createMockServerWithoutActionOrAlertClientDecoration(); - updateRulesRoute(serverWithoutActionOrAlertClient); + updateRulesRoute((serverWithoutActionOrAlertClient as unknown) as ServerFacade); const { statusCode } = await serverWithoutActionOrAlertClient.inject(getUpdateRequest()); expect(statusCode).toBe(404); }); @@ -79,6 +84,7 @@ describe('update_rules', () => { test('returns 400 if id is not given in either the body or the url', async () => { alertsClient.find.mockResolvedValue(getFindResultWithSingleHit()); alertsClient.get.mockResolvedValue(getResult()); + savedObjectsClient.find.mockResolvedValue(getFindResultStatus()); const { rule_id, ...noId } = typicalPayload(); const request: ServerInjectOptions = { method: 'PUT', @@ -95,6 +101,7 @@ describe('update_rules', () => { alertsClient.find.mockResolvedValue(getFindResult()); actionsClient.update.mockResolvedValue(updateActionResult()); alertsClient.update.mockResolvedValue(getResult()); + savedObjectsClient.find.mockResolvedValue(getFindResultStatus()); const request: ServerInjectOptions = { method: 'PUT', url: DETECTION_ENGINE_RULES_URL, @@ -109,6 +116,7 @@ describe('update_rules', () => { alertsClient.get.mockResolvedValue(getResult()); actionsClient.update.mockResolvedValue(updateActionResult()); alertsClient.update.mockResolvedValue(getResult()); + savedObjectsClient.find.mockResolvedValue(getFindResultStatus()); const request: ServerInjectOptions = { method: 'PUT', url: DETECTION_ENGINE_RULES_URL, @@ -123,6 +131,7 @@ describe('update_rules', () => { alertsClient.get.mockResolvedValue(getResult()); actionsClient.update.mockResolvedValue(updateActionResult()); alertsClient.update.mockResolvedValue(getResult()); + savedObjectsClient.find.mockResolvedValue(getFindResultStatus()); const { type, ...noType } = typicalPayload(); const request: ServerInjectOptions = { method: 'PUT', diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/update_rules_route.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/update_rules_route.ts index 6db8a8902915a..147f3f9afa549 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/update_rules_route.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/update_rules_route.ts @@ -8,11 +8,12 @@ import Hapi from 'hapi'; import { isFunction } from 'lodash/fp'; import { DETECTION_ENGINE_RULES_URL } from '../../../../../common/constants'; import { updateRules } from '../../rules/update_rules'; -import { UpdateRulesRequest } from '../../rules/types'; +import { UpdateRulesRequest, IRuleSavedAttributesSavedObjectAttributes } from '../../rules/types'; import { updateRulesSchema } from '../schemas/update_rules_schema'; import { ServerFacade } from '../../../../types'; import { getIdError, transformOrError } from './utils'; import { transformError } from '../utils'; +import { ruleStatusSavedObjectType } from '../../rules/saved_object_mappings'; export const createUpdateRulesRoute: Hapi.ServerRoute = { method: 'PUT', @@ -59,8 +60,10 @@ export const createUpdateRulesRoute: Hapi.ServerRoute = { const alertsClient = isFunction(request.getAlertsClient) ? request.getAlertsClient() : null; const actionsClient = isFunction(request.getActionsClient) ? request.getActionsClient() : null; - - if (!alertsClient || !actionsClient) { + const savedObjectsClient = isFunction(request.getSavedObjectsClient) + ? request.getSavedObjectsClient() + : null; + if (!alertsClient || !actionsClient || !savedObjectsClient) { return headers.response().code(404); } @@ -97,7 +100,17 @@ export const createUpdateRulesRoute: Hapi.ServerRoute = { version, }); if (rule != null) { - return transformOrError(rule); + const ruleStatuses = await savedObjectsClient.find< + IRuleSavedAttributesSavedObjectAttributes + >({ + type: ruleStatusSavedObjectType, + perPage: 1, + sortField: 'statusDate', + sortOrder: 'desc', + search: rule.id, + searchFields: ['alertId'], + }); + return transformOrError(rule, ruleStatuses.saved_objects[0]); } else { return getIdError({ id, ruleId }); } diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/utils.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/utils.ts index 21972905a5063..7d4fb43b58ef1 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/utils.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/rules/utils.ts @@ -6,8 +6,17 @@ import Boom from 'boom'; import { pickBy } from 'lodash/fp'; +import { SavedObject } from 'kibana/server'; import { INTERNAL_IDENTIFIER } from '../../../../../common/constants'; -import { RuleAlertType, isAlertType, isAlertTypes } from '../../rules/types'; +import { + RuleAlertType, + isAlertType, + isAlertTypes, + IRuleSavedAttributesSavedObjectAttributes, + isRuleStatusFindType, + isRuleStatusFindTypes, + isRuleStatusSavedObjectType, +} from '../../rules/types'; import { OutputRuleAlertRest } from '../../types'; import { createBulkErrorObject, @@ -67,7 +76,10 @@ export const transformTags = (tags: string[]): string[] => { // Transforms the data but will remove any null or undefined it encounters and not include // those on the export -export const transformAlertToRule = (alert: RuleAlertType): Partial => { +export const transformAlertToRule = ( + alert: RuleAlertType, + ruleStatus?: SavedObject +): Partial => { return pickBy((value: unknown) => value != null, { created_at: alert.params.createdAt, updated_at: alert.params.updatedAt, @@ -100,6 +112,12 @@ export const transformAlertToRule = (alert: RuleAlertType): Partial transformAlertToRule(alert)); }; -export const transformFindAlertsOrError = (findResults: { data: unknown[] }): unknown | Boom => { - if (isAlertTypes(findResults.data)) { +export const transformFindAlertsOrError = ( + findResults: { data: unknown[] }, + ruleStatuses?: unknown[] +): unknown | Boom => { + if (!ruleStatuses && isAlertTypes(findResults.data)) { findResults.data = findResults.data.map(alert => transformAlertToRule(alert)); return findResults; + } + if (isAlertTypes(findResults.data) && isRuleStatusFindTypes(ruleStatuses)) { + findResults.data = findResults.data.map((alert, idx) => + transformAlertToRule(alert, ruleStatuses[idx].saved_objects[0]) + ); + return findResults; } else { return new Boom('Internal error transforming', { statusCode: 500 }); } }; -export const transformOrError = (alert: unknown): Partial | Boom => { - if (isAlertType(alert)) { +export const transformOrError = ( + alert: unknown, + ruleStatus?: unknown +): Partial | Boom => { + if (!ruleStatus && isAlertType(alert)) { return transformAlertToRule(alert); + } + if (isAlertType(alert) && isRuleStatusFindType(ruleStatus)) { + return transformAlertToRule(alert, ruleStatus.saved_objects[0]); + } else if (isAlertType(alert) && isRuleStatusSavedObjectType(ruleStatus)) { + return transformAlertToRule(alert, ruleStatus); } else { return new Boom('Internal error transforming', { statusCode: 500 }); } @@ -137,10 +172,15 @@ export const transformOrError = (alert: unknown): Partial | export const transformOrBulkError = ( ruleId: string, - alert: unknown + alert: unknown, + ruleStatus?: unknown ): Partial | BulkError => { if (isAlertType(alert)) { - return transformAlertToRule(alert); + if (isRuleStatusFindType(ruleStatus)) { + return transformAlertToRule(alert, ruleStatus?.saved_objects[0] ?? ruleStatus); + } else { + return transformAlertToRule(alert); + } } else { return createBulkErrorObject({ ruleId, diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/schemas/find_rules_statuses_schema.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/schemas/find_rules_statuses_schema.ts new file mode 100644 index 0000000000000..5b8661e69e206 --- /dev/null +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/schemas/find_rules_statuses_schema.ts @@ -0,0 +1,11 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import Joi from 'joi'; + +export const findRulesStatusesSchema = Joi.object({ + ids: Joi.array().items(Joi.string()), +}); diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/signals/open_close_signals.test.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/signals/open_close_signals.test.ts index 3cb64586d6cb5..2b7ee443880e5 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/signals/open_close_signals.test.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/signals/open_close_signals.test.ts @@ -8,6 +8,8 @@ import { createMockServer } from '../__mocks__/_mock_server'; import { setSignalsStatusRoute } from './open_close_signals_route'; import * as myUtils from '../utils'; import { ServerInjectOptions } from 'hapi'; +import { ServerFacade } from '../../../../types'; + import { getSetSignalStatusByIdsRequest, getSetSignalStatusByQueryRequest, @@ -27,7 +29,7 @@ describe('set signal status', () => { elasticsearch.getCluster = jest.fn(() => ({ callWithRequest: jest.fn(() => true), })); - setSignalsStatusRoute(server); + setSignalsStatusRoute((server as unknown) as ServerFacade); }); describe('status on signal', () => { diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/signals/query_signals_route.test.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/signals/query_signals_route.test.ts index 1b990e8c1ff57..aef499675b884 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/signals/query_signals_route.test.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/routes/signals/query_signals_route.test.ts @@ -8,6 +8,8 @@ import { createMockServer } from '../__mocks__/_mock_server'; import { querySignalsRoute } from './query_signals_route'; import * as myUtils from '../utils'; import { ServerInjectOptions } from 'hapi'; +import { ServerFacade } from '../../../../types'; + import { getSignalsQueryRequest, getSignalsAggsQueryRequest, @@ -26,7 +28,7 @@ describe('query for signal', () => { elasticsearch.getCluster = jest.fn(() => ({ callWithRequest: jest.fn(() => true), })); - querySignalsRoute(server); + querySignalsRoute((server as unknown) as ServerFacade); }); describe('query and agg on signals index', () => { diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/rules/saved_object_mappings.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/rules/saved_object_mappings.ts new file mode 100644 index 0000000000000..fd3d35e9f6785 --- /dev/null +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/rules/saved_object_mappings.ts @@ -0,0 +1,40 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { ElasticsearchMappingOf } from '../../../utils/typed_elasticsearch_mappings'; +import { IRuleStatusAttributes } from './types'; + +export const ruleStatusSavedObjectType = 'siem-detection-engine-rule-status'; + +export const ruleStatusSavedObjectMappings: { + [ruleStatusSavedObjectType]: ElasticsearchMappingOf; +} = { + [ruleStatusSavedObjectType]: { + properties: { + alertId: { + type: 'keyword', + }, + status: { + type: 'keyword', + }, + statusDate: { + type: 'date', + }, + lastFailureAt: { + type: 'date', + }, + lastSuccessAt: { + type: 'date', + }, + lastFailureMessage: { + type: 'text', + }, + lastSuccessMessage: { + type: 'text', + }, + }, + }, +}; diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/rules/types.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/rules/types.ts index 4d9073e4b38d9..5a3f19c0bf0ef 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/rules/types.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/rules/types.ts @@ -7,6 +7,7 @@ import { get } from 'lodash/fp'; import { Readable } from 'stream'; +import { SavedObject, SavedObjectAttributes, SavedObjectsFindResponse } from 'kibana/server'; import { SIGNALS_ID } from '../../../../common/constants'; import { AlertsClient } from '../../../../../alerting/server/alerts_client'; import { ActionsClient } from '../../../../../actions/server/actions_client'; @@ -40,6 +41,38 @@ export interface RuleAlertType extends Alert { params: RuleTypeParams; } +export interface IRuleStatusAttributes { + alertId: string; // created alert id. + statusDate: string; + lastFailureAt: string | null | undefined; + lastFailureMessage: string | null | undefined; + lastSuccessAt: string | null | undefined; + lastSuccessMessage: string | null | undefined; + status: RuleStatusString; +} + +export interface IRuleSavedAttributesSavedObjectAttributes + extends IRuleStatusAttributes, + SavedObjectAttributes {} + +export interface IRuleStatusSavedObject { + type: string; + id: string; + attributes: Array>; + references: unknown[]; + updated_at: string; + version: string; +} + +export interface IRuleStatusFindType { + page: number; + per_page: number; + total: number; + saved_objects: IRuleStatusSavedObject[]; +} + +export type RuleStatusString = 'succeeded' | 'failed' | 'going to run' | 'executing'; + export interface RulesRequest extends RequestFacade { payload: RuleAlertParamsRest; } @@ -96,6 +129,12 @@ export interface FindRulesRequest extends Omit { }; } +export interface FindRulesStatusesRequest extends Omit { + query: { + ids: string[]; + }; +} + export interface Clients { alertsClient: AlertsClient; actionsClient: ActionsClient; @@ -125,3 +164,25 @@ export const isAlertTypes = (obj: unknown[]): obj is RuleAlertType[] => { export const isAlertType = (obj: unknown): obj is RuleAlertType => { return get('alertTypeId', obj) === SIGNALS_ID; }; + +export const isRuleStatusAttributes = (obj: unknown): obj is IRuleStatusAttributes => { + return get('lastSuccessMessage', obj) != null; +}; + +export const isRuleStatusSavedObjectType = ( + obj: unknown +): obj is SavedObject => { + return get('attributes', obj) != null; +}; + +export const isRuleStatusFindType = ( + obj: unknown +): obj is SavedObjectsFindResponse => { + return get('saved_objects', obj) != null; +}; + +export const isRuleStatusFindTypes = ( + obj: unknown[] | undefined +): obj is Array> => { + return obj ? obj.every(ruleStatus => isRuleStatusFindType(ruleStatus)) : false; +}; diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/scripts/delete_all_statuses.sh b/x-pack/legacy/plugins/siem/server/lib/detection_engine/scripts/delete_all_statuses.sh new file mode 100755 index 0000000000000..1a19cdb7552d1 --- /dev/null +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/scripts/delete_all_statuses.sh @@ -0,0 +1,23 @@ +#!/bin/sh + +# +# Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one +# or more contributor license agreements. Licensed under the Elastic License; +# you may not use this file except in compliance with the Elastic License. +# + +set -e +./check_env_variables.sh + +# Example: ./delete_all_statuses.sh +# https://www.elastic.co/guide/en/elasticsearch/reference/current/docs-delete-by-query.html +curl -s -k \ + -H "Content-Type: application/json" \ + -u ${ELASTICSEARCH_USERNAME}:${ELASTICSEARCH_PASSWORD} \ + -X POST ${ELASTICSEARCH_URL}/${KIBANA_INDEX}*/_delete_by_query \ + --data '{ + "query": { + "exists": { "field": "siem-detection-engine-rule-status" } + } + }' \ + | jq . diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/scripts/find_rules_statuses_by_ids.sh b/x-pack/legacy/plugins/siem/server/lib/detection_engine/scripts/find_rules_statuses_by_ids.sh new file mode 100755 index 0000000000000..543c019067e8e --- /dev/null +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/scripts/find_rules_statuses_by_ids.sh @@ -0,0 +1,17 @@ +#!/bin/sh + +# +# Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one +# or more contributor license agreements. Licensed under the Elastic License; +# you may not use this file except in compliance with the Elastic License. +# + +set -e +./check_env_variables.sh + + +# Example: ./find_rules_statuses_by_ids.sh '["12345","6789abc"]' +curl -g -k \ + -u ${ELASTICSEARCH_USERNAME}:${ELASTICSEARCH_PASSWORD} \ + -X GET "${KIBANA_URL}${SPACE_URL}/api/detection_engine/rules/_find_statuses?ids=$1" \ + | jq . diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/scripts/hard_reset.sh b/x-pack/legacy/plugins/siem/server/lib/detection_engine/scripts/hard_reset.sh index 3cd0bff7ee8ab..a56d788d69c16 100755 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/scripts/hard_reset.sh +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/scripts/hard_reset.sh @@ -12,5 +12,6 @@ set -e ./delete_all_actions.sh ./delete_all_alerts.sh ./delete_all_alert_tasks.sh +./delete_all_statuses.sh ./delete_signal_index.sh ./post_signal_index.sh diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/scripts/rules/test_cases/query_with_errors.json b/x-pack/legacy/plugins/siem/server/lib/detection_engine/scripts/rules/test_cases/query_with_errors.json new file mode 100644 index 0000000000000..6ac276f787cd3 --- /dev/null +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/scripts/rules/test_cases/query_with_errors.json @@ -0,0 +1,12 @@ +{ + "name": "Query with a rule_id that causes an error", + "description": "Query with a rule_id that acts like an external id", + "rule_id": "query-rule-id-errors-2", + "risk_score": 1, + "interval": "30s", + "severity": "high", + "type": "query", + "from": "now-6m", + "to": "now", + "query": "user.name: root badstringcauseserror user.name: admin" +} diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/signals/signal_rule_alert_type.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/signals/signal_rule_alert_type.ts index 774afb6d7deb0..d80eadd2c088b 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/signals/signal_rule_alert_type.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/signals/signal_rule_alert_type.ts @@ -19,6 +19,8 @@ import { searchAfterAndBulkCreate } from './search_after_bulk_create'; import { getFilter } from './get_filter'; import { SignalRuleAlertTypeDefinition } from './types'; import { getGapBetweenRuns } from './utils'; +import { ruleStatusSavedObjectType } from '../rules/saved_object_mappings'; +import { IRuleSavedAttributesSavedObjectAttributes } from '../rules/types'; export const signalRulesAlertType = ({ logger, @@ -75,6 +77,46 @@ export const signalRulesAlertType = ({ } = params; // TODO: Remove this hard extraction of name once this is fixed: https://github.com/elastic/kibana/issues/50522 const savedObject = await services.savedObjectsClient.get('alert', alertId); + const ruleStatusSavedObjects = await services.savedObjectsClient.find< + IRuleSavedAttributesSavedObjectAttributes + >({ + type: ruleStatusSavedObjectType, + perPage: 6, // 0th element is current status, 1-5 is last 5 failures. + sortField: 'statusDate', + sortOrder: 'desc', + search: `${alertId}`, + searchFields: ['alertId'], + }); + let currentStatusSavedObject; + if (ruleStatusSavedObjects.saved_objects.length === 0) { + // create + const date = new Date().toISOString(); + currentStatusSavedObject = await services.savedObjectsClient.create< + IRuleSavedAttributesSavedObjectAttributes + >(ruleStatusSavedObjectType, { + alertId, // do a search for this id. + statusDate: date, + status: 'executing', + lastFailureAt: null, + lastSuccessAt: null, + lastFailureMessage: null, + lastSuccessMessage: null, + }); + } else { + // update 0th to executing. + currentStatusSavedObject = ruleStatusSavedObjects.saved_objects[0]; + const sDate = new Date().toISOString(); + currentStatusSavedObject.attributes.status = 'executing'; + currentStatusSavedObject.attributes.statusDate = sDate; + await services.savedObjectsClient.update( + ruleStatusSavedObjectType, + currentStatusSavedObject.id, + { + ...currentStatusSavedObject.attributes, + } + ); + } + const name: string = savedObject.attributes.name; const tags: string[] = savedObject.attributes.tags; @@ -98,77 +140,169 @@ export const signalRulesAlertType = ({ DEFAULT_SEARCH_AFTER_PAGE_SIZE <= params.maxSignals ? DEFAULT_SEARCH_AFTER_PAGE_SIZE : params.maxSignals; - - const inputIndex = await getInputIndex(services, version, index); - const esFilter = await getFilter({ - type, - filters, - language, - query, - savedId, - services, - index: inputIndex, - }); - - const noReIndex = buildEventsSearchQuery({ - index: inputIndex, - from, - to, - filter: esFilter, - size: searchAfterSize, - searchAfterSortId: undefined, - }); - try { - logger.debug( - `Starting signal rule name: "${name}", id: "${alertId}", rule_id: "${ruleId}"` - ); - logger.debug( - `[+] Initial search call of signal rule name: "${name}", id: "${alertId}", rule_id: "${ruleId}"` - ); - const noReIndexResult = await services.callCluster('search', noReIndex); - if (noReIndexResult.hits.total.value !== 0) { - logger.info( - `Found ${ - noReIndexResult.hits.total.value - } signals from the indexes of "[${inputIndex.join( - ', ' - )}]" using signal rule name: "${name}", id: "${alertId}", rule_id: "${ruleId}", pushing signals to index "${outputIndex}"` - ); - } - - const bulkIndexResult = await searchAfterAndBulkCreate({ - someResult: noReIndexResult, - ruleParams: params, + const inputIndex = await getInputIndex(services, version, index); + const esFilter = await getFilter({ + type, + filters, + language, + query, + savedId, services, - logger, - id: alertId, - signalsIndex: outputIndex, + index: inputIndex, + }); + + const noReIndex = buildEventsSearchQuery({ + index: inputIndex, + from, + to, filter: esFilter, - name, - createdBy, - updatedBy, - interval, - enabled, - pageSize: searchAfterSize, - tags, + size: searchAfterSize, + searchAfterSortId: undefined, }); - if (bulkIndexResult) { + try { + logger.debug( + `Starting signal rule name: "${name}", id: "${alertId}", rule_id: "${ruleId}"` + ); logger.debug( - `Finished signal rule name: "${name}", id: "${alertId}", rule_id: "${ruleId}"` + `[+] Initial search call of signal rule name: "${name}", id: "${alertId}", rule_id: "${ruleId}"` ); - } else { + const noReIndexResult = await services.callCluster('search', noReIndex); + if (noReIndexResult.hits.total.value !== 0) { + logger.info( + `Found ${ + noReIndexResult.hits.total.value + } signals from the indexes of "[${inputIndex.join( + ', ' + )}]" using signal rule name: "${name}", id: "${alertId}", rule_id: "${ruleId}", pushing signals to index "${outputIndex}"` + ); + } + + const bulkIndexResult = await searchAfterAndBulkCreate({ + someResult: noReIndexResult, + ruleParams: params, + services, + logger, + id: alertId, + signalsIndex: outputIndex, + filter: esFilter, + name, + createdBy, + updatedBy, + interval, + enabled, + pageSize: searchAfterSize, + tags, + }); + + if (bulkIndexResult) { + logger.debug( + `Finished signal rule name: "${name}", id: "${alertId}", rule_id: "${ruleId}"` + ); + const sDate = new Date().toISOString(); + currentStatusSavedObject.attributes.status = 'succeeded'; + currentStatusSavedObject.attributes.statusDate = sDate; + currentStatusSavedObject.attributes.lastSuccessAt = sDate; + currentStatusSavedObject.attributes.lastSuccessMessage = 'succeeded'; + await services.savedObjectsClient.update( + ruleStatusSavedObjectType, + currentStatusSavedObject.id, + { + ...currentStatusSavedObject.attributes, + } + ); + } else { + logger.error( + `Error processing signal rule name: "${name}", id: "${alertId}", rule_id: "${ruleId}"` + ); + const sDate = new Date().toISOString(); + currentStatusSavedObject.attributes.status = 'failed'; + currentStatusSavedObject.attributes.statusDate = sDate; + currentStatusSavedObject.attributes.lastFailureAt = sDate; + currentStatusSavedObject.attributes.lastFailureMessage = `Bulk Indexing signals failed. Check logs for further details \nRule name: "${name}"\nid: "${alertId}"\nrule_id: "${ruleId}"\n`; + // current status is failing + await services.savedObjectsClient.update( + ruleStatusSavedObjectType, + currentStatusSavedObject.id, + { + ...currentStatusSavedObject.attributes, + } + ); + // create new status for historical purposes + await services.savedObjectsClient.create(ruleStatusSavedObjectType, { + ...currentStatusSavedObject.attributes, + }); + + if (ruleStatusSavedObjects.saved_objects.length >= 6) { + // delete fifth status and prepare to insert a newer one. + const toDelete = ruleStatusSavedObjects.saved_objects.slice(5); + await toDelete.forEach(async item => + services.savedObjectsClient.delete(ruleStatusSavedObjectType, item.id) + ); + } + } + } catch (err) { + // TODO: Error handling and writing of errors into a signal that has error + // handling/conditions logger.error( - `Error processing signal rule name: "${name}", id: "${alertId}", rule_id: "${ruleId}"` + `Error from signal rule name: "${name}", id: "${alertId}", rule_id: "${ruleId}"` + ); + const sDate = new Date().toISOString(); + currentStatusSavedObject.attributes.status = 'failed'; + currentStatusSavedObject.attributes.statusDate = sDate; + currentStatusSavedObject.attributes.lastFailureAt = sDate; + currentStatusSavedObject.attributes.lastFailureMessage = err.message; + // current status is failing + await services.savedObjectsClient.update( + ruleStatusSavedObjectType, + currentStatusSavedObject.id, + { + ...currentStatusSavedObject.attributes, + } ); + // create new status for historical purposes + await services.savedObjectsClient.create(ruleStatusSavedObjectType, { + ...currentStatusSavedObject.attributes, + }); + + if (ruleStatusSavedObjects.saved_objects.length >= 6) { + // delete fifth status and prepare to insert a newer one. + const toDelete = ruleStatusSavedObjects.saved_objects.slice(5); + await toDelete.forEach(async item => + services.savedObjectsClient.delete(ruleStatusSavedObjectType, item.id) + ); + } } - } catch (err) { - // TODO: Error handling and writing of errors into a signal that has error - // handling/conditions + } catch (exception) { logger.error( - `Error from signal rule name: "${name}", id: "${alertId}", rule_id: "${ruleId}" message: ${err.message}` + `Error from signal rule name: "${name}", id: "${alertId}", rule_id: "${ruleId}" message: ${exception.message}` + ); + const sDate = new Date().toISOString(); + currentStatusSavedObject.attributes.status = 'failed'; + currentStatusSavedObject.attributes.statusDate = sDate; + currentStatusSavedObject.attributes.lastFailureAt = sDate; + currentStatusSavedObject.attributes.lastFailureMessage = exception.message; + // current status is failing + await services.savedObjectsClient.update( + ruleStatusSavedObjectType, + currentStatusSavedObject.id, + { + ...currentStatusSavedObject.attributes, + } ); + // create new status for historical purposes + await services.savedObjectsClient.create(ruleStatusSavedObjectType, { + ...currentStatusSavedObject.attributes, + }); + + if (ruleStatusSavedObjects.saved_objects.length >= 6) { + // delete fifth status and prepare to insert a newer one. + const toDelete = ruleStatusSavedObjects.saved_objects.slice(5); + await toDelete.forEach(async item => + services.savedObjectsClient.delete(ruleStatusSavedObjectType, item.id) + ); + } } }, }; diff --git a/x-pack/legacy/plugins/siem/server/lib/detection_engine/types.ts b/x-pack/legacy/plugins/siem/server/lib/detection_engine/types.ts index 968c7d9cb1cf0..8a9e050c039b4 100644 --- a/x-pack/legacy/plugins/siem/server/lib/detection_engine/types.ts +++ b/x-pack/legacy/plugins/siem/server/lib/detection_engine/types.ts @@ -5,6 +5,7 @@ */ import { esFilters } from '../../../../../../../src/plugins/data/server'; +import { IRuleStatusAttributes } from './rules/types'; export type PartialFilter = Partial; @@ -65,18 +66,34 @@ export type RuleAlertParamsRest = Omit< | 'outputIndex' | 'updatedAt' | 'createdAt' -> & { - rule_id: RuleAlertParams['ruleId']; - false_positives: RuleAlertParams['falsePositives']; - saved_id: RuleAlertParams['savedId']; - timeline_id: RuleAlertParams['timelineId']; - timeline_title: RuleAlertParams['timelineTitle']; - max_signals: RuleAlertParams['maxSignals']; - risk_score: RuleAlertParams['riskScore']; - output_index: RuleAlertParams['outputIndex']; - created_at: RuleAlertParams['createdAt']; - updated_at: RuleAlertParams['updatedAt']; -}; +> & + Omit< + IRuleStatusAttributes, + | 'status' + | 'alertId' + | 'statusDate' + | 'lastFailureAt' + | 'lastSuccessAt' + | 'lastSuccessMessage' + | 'lastFailureMessage' + > & { + rule_id: RuleAlertParams['ruleId']; + false_positives: RuleAlertParams['falsePositives']; + saved_id: RuleAlertParams['savedId']; + timeline_id: RuleAlertParams['timelineId']; + timeline_title: RuleAlertParams['timelineTitle']; + max_signals: RuleAlertParams['maxSignals']; + risk_score: RuleAlertParams['riskScore']; + output_index: RuleAlertParams['outputIndex']; + created_at: RuleAlertParams['createdAt']; + updated_at: RuleAlertParams['updatedAt']; + status?: IRuleStatusAttributes['status'] | undefined; + status_date?: IRuleStatusAttributes['statusDate'] | undefined; + last_failure_at?: IRuleStatusAttributes['lastFailureAt'] | undefined; + last_success_at?: IRuleStatusAttributes['lastSuccessAt'] | undefined; + last_failure_message?: IRuleStatusAttributes['lastFailureMessage'] | undefined; + last_success_message?: IRuleStatusAttributes['lastSuccessMessage'] | undefined; + }; export type OutputRuleAlertRest = RuleAlertParamsRest & { id: string; diff --git a/x-pack/legacy/plugins/siem/server/saved_objects.ts b/x-pack/legacy/plugins/siem/server/saved_objects.ts index 8311d17f00ce9..1d65e351fc86a 100644 --- a/x-pack/legacy/plugins/siem/server/saved_objects.ts +++ b/x-pack/legacy/plugins/siem/server/saved_objects.ts @@ -12,10 +12,12 @@ import { timelineSavedObjectType, timelineSavedObjectMappings, } from './lib/timeline/saved_object_mappings'; +import { ruleStatusSavedObjectMappings } from './lib/detection_engine/rules/saved_object_mappings'; export { noteSavedObjectType, pinnedEventSavedObjectType, timelineSavedObjectType }; export const savedObjectMappings = { ...timelineSavedObjectMappings, ...noteSavedObjectMappings, ...pinnedEventSavedObjectMappings, + ...ruleStatusSavedObjectMappings, }; diff --git a/x-pack/legacy/plugins/siem/server/types.ts b/x-pack/legacy/plugins/siem/server/types.ts index 989aaf2b6eeea..bbcfbe7b9c0ec 100644 --- a/x-pack/legacy/plugins/siem/server/types.ts +++ b/x-pack/legacy/plugins/siem/server/types.ts @@ -12,6 +12,7 @@ export interface ServerFacade { alerting?: Legacy.Server['plugins']['alerting']; elasticsearch: Legacy.Server['plugins']['elasticsearch']; spaces: Legacy.Server['plugins']['spaces']; + savedObjects: Legacy.Server['savedObjects']['SavedObjectsClient']; }; route: Legacy.Server['route']; } @@ -20,6 +21,7 @@ export interface RequestFacade { auth: Legacy.Request['auth']; getAlertsClient?: Legacy.Request['getAlertsClient']; getActionsClient?: Legacy.Request['getActionsClient']; + getSavedObjectsClient?: Legacy.Request['getSavedObjectsClient']; headers: Legacy.Request['headers']; method: Legacy.Request['method']; params: Legacy.Request['params']; diff --git a/x-pack/legacy/plugins/siem/server/utils/typed_elasticsearch_mappings.ts b/x-pack/legacy/plugins/siem/server/utils/typed_elasticsearch_mappings.ts index f34c6ab72b3ec..a777236345d89 100644 --- a/x-pack/legacy/plugins/siem/server/utils/typed_elasticsearch_mappings.ts +++ b/x-pack/legacy/plugins/siem/server/utils/typed_elasticsearch_mappings.ts @@ -17,7 +17,7 @@ export type ElasticsearchMappingOf = Type extends string | string[] : never; export interface ElasticsearchStringFieldMapping { - type: 'keyword' | 'text'; + type: 'keyword' | 'text' | 'date'; } export interface ElasticsearchBooleanFieldMapping { From 5216b382f4e2b4c79125264f78f1c10441079c66 Mon Sep 17 00:00:00 2001 From: Gidi Meir Morris Date: Tue, 14 Jan 2020 13:49:43 +0000 Subject: [PATCH 084/139] fix broken configuration in Task manager (#54695) Fixes an issue that prevents custom configuration in Task Manager --- x-pack/legacy/plugins/task_manager/server/index.ts | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/x-pack/legacy/plugins/task_manager/server/index.ts b/x-pack/legacy/plugins/task_manager/server/index.ts index 56135bb27326b..98d67a38c20d0 100644 --- a/x-pack/legacy/plugins/task_manager/server/index.ts +++ b/x-pack/legacy/plugins/task_manager/server/index.ts @@ -39,7 +39,9 @@ export function taskManager(kibana: any) { .description('The name of the index used to store task information.') .default('.kibana_task_manager') .invalid(['.tasks']), - }).default(); + }) + .unknown(true) + .default(); }, init(server: Legacy.Server) { /* From 2feba4fa24a1f1d10b8c4ccc4ea8e2d89e4dbf4f Mon Sep 17 00:00:00 2001 From: Silvia Mitter Date: Tue, 14 Jan 2020 14:51:21 +0100 Subject: [PATCH 085/139] [apm] update apm index pattern (#54693) --- .../kibana/server/tutorials/apm/index_pattern.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/legacy/core_plugins/kibana/server/tutorials/apm/index_pattern.json b/src/legacy/core_plugins/kibana/server/tutorials/apm/index_pattern.json index 090586a612d4f..4052f4050a31b 100644 --- a/src/legacy/core_plugins/kibana/server/tutorials/apm/index_pattern.json +++ b/src/legacy/core_plugins/kibana/server/tutorials/apm/index_pattern.json @@ -1,7 +1,7 @@ { "attributes": { - "fieldFormatMap": "{\"client.bytes\":{\"id\":\"bytes\"},\"client.nat.port\":{\"id\":\"string\"},\"client.port\":{\"id\":\"string\"},\"destination.bytes\":{\"id\":\"bytes\"},\"destination.nat.port\":{\"id\":\"string\"},\"destination.port\":{\"id\":\"string\"},\"event.duration\":{\"id\":\"duration\",\"params\":{\"inputFormat\":\"nanoseconds\",\"outputFormat\":\"asMilliseconds\",\"outputPrecision\":1}},\"event.sequence\":{\"id\":\"string\"},\"event.severity\":{\"id\":\"string\"},\"http.request.body.bytes\":{\"id\":\"bytes\"},\"http.request.bytes\":{\"id\":\"bytes\"},\"http.response.body.bytes\":{\"id\":\"bytes\"},\"http.response.bytes\":{\"id\":\"bytes\"},\"http.response.status_code\":{\"id\":\"string\"},\"log.syslog.facility.code\":{\"id\":\"string\"},\"log.syslog.priority\":{\"id\":\"string\"},\"network.bytes\":{\"id\":\"bytes\"},\"package.size\":{\"id\":\"string\"},\"process.pgid\":{\"id\":\"string\"},\"process.pid\":{\"id\":\"string\"},\"process.ppid\":{\"id\":\"string\"},\"process.thread.id\":{\"id\":\"string\"},\"server.bytes\":{\"id\":\"bytes\"},\"server.nat.port\":{\"id\":\"string\"},\"server.port\":{\"id\":\"string\"},\"source.bytes\":{\"id\":\"bytes\"},\"source.nat.port\":{\"id\":\"string\"},\"source.port\":{\"id\":\"string\"},\"system.cpu.total.norm.pct\":{\"id\":\"percent\"},\"system.memory.actual.free\":{\"id\":\"bytes\"},\"system.memory.total\":{\"id\":\"bytes\"},\"system.process.cpu.total.norm.pct\":{\"id\":\"percent\"},\"system.process.memory.rss.bytes\":{\"id\":\"bytes\"},\"system.process.memory.size\":{\"id\":\"bytes\"},\"url.port\":{\"id\":\"string\"},\"view spans\":{\"id\":\"url\",\"params\":{\"labelTemplate\":\"View Spans\"}}}", - "fields": "[{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"@timestamp\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"labels\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"message\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tags\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"agent.ephemeral_id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"agent.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"agent.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"agent.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"agent.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"as.number\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"as.organization.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.address\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.as.number\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.as.organization.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.geo.city_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.geo.continent_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.geo.country_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.geo.country_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.geo.location\",\"scripted\":false,\"searchable\":true,\"type\":\"geo_point\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.geo.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.geo.region_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.geo.region_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.mac\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.nat.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.nat.port\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.packets\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.port\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.registered_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.top_level_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.user.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.user.email\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.user.full_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.user.group.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.user.group.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.user.group.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.user.hash\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.user.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.user.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"cloud.account.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"cloud.availability_zone\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"cloud.instance.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"cloud.instance.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"cloud.machine.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"cloud.provider\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"cloud.region\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"container.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"container.image.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"container.image.tag\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"container.labels\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"container.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"container.runtime\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.address\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.as.number\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.as.organization.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.geo.city_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.geo.continent_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.geo.country_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.geo.country_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.geo.location\",\"scripted\":false,\"searchable\":true,\"type\":\"geo_point\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.geo.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.geo.region_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.geo.region_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.mac\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.nat.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.nat.port\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.packets\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.port\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.registered_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.top_level_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.user.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.user.email\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.user.full_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.user.group.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.user.group.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.user.group.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.user.hash\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.user.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.user.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.answers\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.answers.class\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.answers.data\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.answers.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.answers.ttl\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.answers.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.header_flags\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.op_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.question.class\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.question.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.question.registered_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.question.subdomain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.question.top_level_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.question.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.resolved_ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.response_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"ecs.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":4,\"doc_values\":true,\"indexed\":true,\"name\":\"error.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.message\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.stack_trace\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.action\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.category\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.created\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.dataset\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.duration\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.end\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.hash\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.kind\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.module\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.original\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.outcome\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.provider\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.risk_score\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.risk_score_norm\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.sequence\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.severity\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.start\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.timezone\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.accessed\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.created\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.ctime\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.device\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.directory\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.extension\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.gid\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.group\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.hash.md5\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.hash.sha1\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.hash.sha256\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.hash.sha512\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.inode\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.mode\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.mtime\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.owner\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.path\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.size\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.target_path\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.uid\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"geo.city_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"geo.continent_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"geo.country_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"geo.country_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"geo.location\",\"scripted\":false,\"searchable\":true,\"type\":\"geo_point\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"geo.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"geo.region_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"geo.region_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"group.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"group.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"group.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"hash.md5\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"hash.sha1\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"hash.sha256\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"hash.sha512\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.architecture\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.geo.city_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.geo.continent_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.geo.country_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.geo.country_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.geo.location\",\"scripted\":false,\"searchable\":true,\"type\":\"geo_point\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.geo.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.geo.region_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.geo.region_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.hostname\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.mac\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.os.family\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.os.full\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.os.kernel\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.os.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.os.platform\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.os.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.uptime\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.user.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.user.email\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.user.full_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.user.group.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.user.group.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.user.group.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.user.hash\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.user.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.user.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.request.body.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.request.body.content\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.request.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.request.method\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.request.referrer\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.response.body.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.response.body.content\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.response.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.response.status_code\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.level\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.logger\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.origin.file.line\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.origin.file.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.origin.function\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.original\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.syslog\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.syslog.facility.code\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.syslog.facility.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.syslog.priority\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.syslog.severity.code\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.syslog.severity.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.application\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.community_id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.direction\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.forwarded_ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.iana_number\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.packets\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.protocol\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.transport\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.geo.city_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.geo.continent_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.geo.country_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.geo.country_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.geo.location\",\"scripted\":false,\"searchable\":true,\"type\":\"geo_point\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.geo.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.geo.region_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.geo.region_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.hostname\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.mac\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.os.family\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.os.full\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.os.kernel\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.os.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.os.platform\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.os.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.product\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.serial_number\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.vendor\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"organization.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"organization.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"os.family\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"os.full\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"os.kernel\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"os.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"os.platform\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"os.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.architecture\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.checksum\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.description\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.install_scope\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.installed\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.license\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.path\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.size\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.args\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.executable\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.hash.md5\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.hash.sha1\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.hash.sha256\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.hash.sha512\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.pgid\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.pid\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.ppid\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.start\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.thread.id\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.thread.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.title\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.uptime\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.working_directory\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"related.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.address\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.as.number\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.as.organization.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.geo.city_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.geo.continent_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.geo.country_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.geo.country_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.geo.location\",\"scripted\":false,\"searchable\":true,\"type\":\"geo_point\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.geo.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.geo.region_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.geo.region_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.mac\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.nat.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.nat.port\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.packets\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.port\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.registered_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.top_level_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.user.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.user.email\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.user.full_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.user.group.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.user.group.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.user.group.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.user.hash\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.user.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.user.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.ephemeral_id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.node.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.state\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.address\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.as.number\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.as.organization.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.geo.city_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.geo.continent_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.geo.country_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.geo.country_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.geo.location\",\"scripted\":false,\"searchable\":true,\"type\":\"geo_point\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.geo.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.geo.region_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.geo.region_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.mac\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.nat.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.nat.port\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.packets\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.port\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.registered_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.top_level_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.user.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.user.email\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.user.full_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.user.group.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.user.group.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.user.group.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.user.hash\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.user.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.user.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"threat.framework\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"threat.tactic.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"threat.tactic.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"threat.tactic.reference\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"threat.technique.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"threat.technique.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"threat.technique.reference\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tracing.trace.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tracing.transaction.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.extension\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.fragment\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.full\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.original\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.password\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.path\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.port\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.query\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.registered_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.scheme\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.top_level_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.username\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user.email\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user.full_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user.group.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user.group.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user.group.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user.hash\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.device.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.original\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.os.family\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.os.full\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.os.kernel\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.os.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.os.platform\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.os.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"agent.hostname\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"fields\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"timeseries.instance\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"cloud.project.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"cloud.image.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"docker.container.labels\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.containerized\",\"scripted\":false,\"searchable\":true,\"type\":\"boolean\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.os.build\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.os.codename\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.pod.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.pod.uid\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.namespace\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.node.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.labels.*\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.annotations.*\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.replicaset.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.deployment.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.statefulset.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.container.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.container.image\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"processor.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"processor.event\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"timestamp.us\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":false,\"enabled\":false,\"indexed\":false,\"name\":\"http.request.headers\",\"scripted\":false,\"searchable\":false},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.response.finished\",\"scripted\":false,\"searchable\":true,\"type\":\"boolean\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":false,\"enabled\":false,\"indexed\":false,\"name\":\"http.response.headers\",\"scripted\":false,\"searchable\":false},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.environment\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.language.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.language.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.runtime.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.runtime.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.framework.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.framework.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.sampled\",\"scripted\":false,\"searchable\":true,\"type\":\"boolean\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.duration.count\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.duration.sum.us\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.self_time.count\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.self_time.sum.us\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.breakdown.count\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"span.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"span.subtype\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.self_time.count\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.self_time.sum.us\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"trace.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"parent.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.listening\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.version_major\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.original.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"experimental\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":true,\"analyzed\":false,\"count\":2,\"doc_values\":true,\"indexed\":true,\"name\":\"error.culprit\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.grouping_key\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.exception.code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":2,\"doc_values\":true,\"indexed\":true,\"name\":\"error.exception.message\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.exception.module\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":4,\"doc_values\":true,\"indexed\":true,\"name\":\"error.exception.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":2,\"doc_values\":true,\"indexed\":true,\"name\":\"error.exception.handled\",\"scripted\":false,\"searchable\":true,\"type\":\"boolean\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.log.level\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.log.logger_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":2,\"doc_values\":true,\"indexed\":true,\"name\":\"error.log.message\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.log.param_message\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"system.cpu.total.norm.pct\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"system.memory.total\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"system.memory.actual.free\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"system.process.cpu.total.norm.pct\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"system.process.memory.size\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"system.process.memory.rss.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.cpu.ns\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.samples.count\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.alloc_objects.count\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.alloc_space.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.inuse_objects.count\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.inuse_space.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.duration\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.top.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.top.function\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.top.filename\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.top.line\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.stack.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.stack.function\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.stack.filename\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.stack.line\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"sourcemap.service.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"sourcemap.service.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"sourcemap.bundle_filepath\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"view spans\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"span.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"span.action\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"span.start.us\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"span.duration.us\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.sync\",\"scripted\":false,\"searchable\":true,\"type\":\"boolean\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.db.link\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.db.rows_affected\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.destination.service.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.destination.service.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.destination.service.resource\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.message.queue.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.message.age.ms\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.duration.us\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.result\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.marks\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.marks.*.*\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.span_count.dropped\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.message.queue.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.message.age.ms\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":false,\"indexed\":false,\"name\":\"_id\",\"scripted\":false,\"searchable\":false,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":false,\"indexed\":false,\"name\":\"_type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":false,\"indexed\":false,\"name\":\"_index\",\"scripted\":false,\"searchable\":false,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":false,\"indexed\":false,\"name\":\"_score\",\"scripted\":false,\"searchable\":false,\"type\":\"number\"}]", + "fieldFormatMap": "{\"client.bytes\":{\"id\":\"bytes\"},\"client.nat.port\":{\"id\":\"string\"},\"client.port\":{\"id\":\"string\"},\"destination.bytes\":{\"id\":\"bytes\"},\"destination.nat.port\":{\"id\":\"string\"},\"destination.port\":{\"id\":\"string\"},\"event.duration\":{\"id\":\"duration\",\"params\":{\"inputFormat\":\"nanoseconds\",\"outputFormat\":\"asMilliseconds\",\"outputPrecision\":1}},\"event.sequence\":{\"id\":\"string\"},\"event.severity\":{\"id\":\"string\"},\"http.request.body.bytes\":{\"id\":\"bytes\"},\"http.request.bytes\":{\"id\":\"bytes\"},\"http.response.body.bytes\":{\"id\":\"bytes\"},\"http.response.bytes\":{\"id\":\"bytes\"},\"http.response.status_code\":{\"id\":\"string\"},\"log.syslog.facility.code\":{\"id\":\"string\"},\"log.syslog.priority\":{\"id\":\"string\"},\"network.bytes\":{\"id\":\"bytes\"},\"package.size\":{\"id\":\"string\"},\"process.parent.pgid\":{\"id\":\"string\"},\"process.parent.pid\":{\"id\":\"string\"},\"process.parent.ppid\":{\"id\":\"string\"},\"process.parent.thread.id\":{\"id\":\"string\"},\"process.pgid\":{\"id\":\"string\"},\"process.pid\":{\"id\":\"string\"},\"process.ppid\":{\"id\":\"string\"},\"process.thread.id\":{\"id\":\"string\"},\"server.bytes\":{\"id\":\"bytes\"},\"server.nat.port\":{\"id\":\"string\"},\"server.port\":{\"id\":\"string\"},\"source.bytes\":{\"id\":\"bytes\"},\"source.nat.port\":{\"id\":\"string\"},\"source.port\":{\"id\":\"string\"},\"system.cpu.total.norm.pct\":{\"id\":\"percent\"},\"system.memory.actual.free\":{\"id\":\"bytes\"},\"system.memory.total\":{\"id\":\"bytes\"},\"system.process.cpu.total.norm.pct\":{\"id\":\"percent\"},\"system.process.memory.rss.bytes\":{\"id\":\"bytes\"},\"system.process.memory.size\":{\"id\":\"bytes\"},\"url.port\":{\"id\":\"string\"},\"view spans\":{\"id\":\"url\",\"params\":{\"labelTemplate\":\"View Spans\"}}}", + "fields": "[{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"@timestamp\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"labels\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"message\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tags\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"agent.ephemeral_id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"agent.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"agent.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"agent.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"agent.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"as.number\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"as.organization.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"as.organization.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.address\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.as.number\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.as.organization.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.as.organization.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.geo.city_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.geo.continent_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.geo.country_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.geo.country_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.geo.location\",\"scripted\":false,\"searchable\":true,\"type\":\"geo_point\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.geo.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.geo.region_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.geo.region_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.mac\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.nat.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.nat.port\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.packets\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.port\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.registered_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.top_level_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.user.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.user.email\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.user.full_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.user.full_name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.user.group.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.user.group.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.user.group.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.user.hash\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.user.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.user.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"client.user.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"cloud.account.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"cloud.availability_zone\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"cloud.instance.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"cloud.instance.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"cloud.machine.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"cloud.provider\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"cloud.region\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"container.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"container.image.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"container.image.tag\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"container.labels\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"container.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"container.runtime\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.address\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.as.number\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.as.organization.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.as.organization.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.geo.city_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.geo.continent_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.geo.country_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.geo.country_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.geo.location\",\"scripted\":false,\"searchable\":true,\"type\":\"geo_point\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.geo.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.geo.region_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.geo.region_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.mac\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.nat.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.nat.port\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.packets\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.port\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.registered_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.top_level_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.user.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.user.email\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.user.full_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.user.full_name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.user.group.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.user.group.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.user.group.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.user.hash\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.user.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.user.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"destination.user.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.answers\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.answers.class\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.answers.data\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.answers.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.answers.ttl\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.answers.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.header_flags\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.op_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.question.class\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.question.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.question.registered_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.question.subdomain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.question.top_level_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.question.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.resolved_ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.response_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"dns.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"ecs.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":4,\"doc_values\":true,\"indexed\":true,\"name\":\"error.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.message\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.stack_trace\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.stack_trace.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.action\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.category\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.created\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.dataset\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.duration\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.end\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.hash\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.ingested\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.kind\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.module\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.original\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.outcome\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.provider\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.risk_score\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.risk_score_norm\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.sequence\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.severity\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.start\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.timezone\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"event.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.accessed\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.attributes\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.created\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.ctime\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.device\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.directory\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.drive_letter\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.extension\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.gid\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.group\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.hash.md5\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.hash.sha1\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.hash.sha256\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.hash.sha512\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.inode\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.mode\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.mtime\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.owner\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.path\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.path.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.size\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.target_path\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.target_path.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"file.uid\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"geo.city_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"geo.continent_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"geo.country_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"geo.country_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"geo.location\",\"scripted\":false,\"searchable\":true,\"type\":\"geo_point\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"geo.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"geo.region_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"geo.region_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"group.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"group.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"group.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"hash.md5\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"hash.sha1\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"hash.sha256\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"hash.sha512\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.architecture\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.geo.city_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.geo.continent_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.geo.country_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.geo.country_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.geo.location\",\"scripted\":false,\"searchable\":true,\"type\":\"geo_point\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.geo.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.geo.region_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.geo.region_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.hostname\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.mac\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.os.family\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.os.full\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.os.full.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.os.kernel\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.os.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.os.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.os.platform\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.os.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.uptime\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.user.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.user.email\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.user.full_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.user.full_name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.user.group.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.user.group.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.user.group.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.user.hash\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.user.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.user.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.user.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.request.body.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.request.body.content\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.request.body.content.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.request.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.request.method\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.request.referrer\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.response.body.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.response.body.content\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.response.body.content.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.response.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.response.status_code\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.level\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.logger\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.origin.file.line\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.origin.file.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.origin.function\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.original\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.syslog\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.syslog.facility.code\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.syslog.facility.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.syslog.priority\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.syslog.severity.code\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"log.syslog.severity.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.application\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.community_id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.direction\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.forwarded_ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.iana_number\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.packets\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.protocol\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.transport\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"network.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.geo.city_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.geo.continent_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.geo.country_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.geo.country_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.geo.location\",\"scripted\":false,\"searchable\":true,\"type\":\"geo_point\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.geo.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.geo.region_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.geo.region_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.hostname\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.mac\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.os.family\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.os.full\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.os.full.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.os.kernel\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.os.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.os.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.os.platform\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.os.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.product\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.serial_number\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.vendor\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"organization.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"organization.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"organization.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"os.family\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"os.full\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"os.full.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"os.kernel\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"os.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"os.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"os.platform\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"os.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.architecture\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.build_version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.checksum\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.description\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.install_scope\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.installed\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.license\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.path\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.reference\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.size\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"package.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.args\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.args_count\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.command_line\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.command_line.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.executable\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.executable.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.exit_code\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.hash.md5\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.hash.sha1\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.hash.sha256\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.hash.sha512\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.parent.args\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.parent.args_count\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.parent.command_line\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.parent.command_line.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.parent.executable\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.parent.executable.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.parent.exit_code\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.parent.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.parent.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.parent.pgid\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.parent.pid\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.parent.ppid\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.parent.start\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.parent.thread.id\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.parent.thread.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.parent.title\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.parent.title.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.parent.uptime\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.parent.working_directory\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.parent.working_directory.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.pgid\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.pid\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.ppid\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.start\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.thread.id\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.thread.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.title\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.title.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.uptime\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.working_directory\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"process.working_directory.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"registry.data.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"registry.data.strings\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"registry.data.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"registry.hive\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"registry.key\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"registry.path\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"registry.value\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"related.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"related.user\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"rule.category\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"rule.description\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"rule.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"rule.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"rule.reference\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"rule.ruleset\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"rule.uuid\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"rule.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.address\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.as.number\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.as.organization.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.as.organization.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.geo.city_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.geo.continent_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.geo.country_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.geo.country_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.geo.location\",\"scripted\":false,\"searchable\":true,\"type\":\"geo_point\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.geo.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.geo.region_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.geo.region_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.mac\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.nat.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.nat.port\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.packets\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.port\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.registered_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.top_level_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.user.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.user.email\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.user.full_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.user.full_name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.user.group.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.user.group.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.user.group.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.user.hash\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.user.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.user.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"server.user.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.ephemeral_id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.node.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.state\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.address\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.as.number\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.as.organization.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.as.organization.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.geo.city_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.geo.continent_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.geo.country_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.geo.country_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.geo.location\",\"scripted\":false,\"searchable\":true,\"type\":\"geo_point\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.geo.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.geo.region_iso_code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.geo.region_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.mac\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.nat.ip\",\"scripted\":false,\"searchable\":true,\"type\":\"ip\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.nat.port\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.packets\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.port\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.registered_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.top_level_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.user.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.user.email\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.user.full_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.user.full_name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.user.group.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.user.group.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.user.group.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.user.hash\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.user.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.user.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"source.user.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"threat.framework\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"threat.tactic.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"threat.tactic.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"threat.tactic.reference\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"threat.technique.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"threat.technique.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"threat.technique.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"threat.technique.reference\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.cipher\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.client.certificate\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.client.certificate_chain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.client.hash.md5\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.client.hash.sha1\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.client.hash.sha256\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.client.issuer\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.client.ja3\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.client.not_after\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.client.not_before\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.client.server_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.client.subject\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.client.supported_ciphers\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.curve\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.established\",\"scripted\":false,\"searchable\":true,\"type\":\"boolean\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.next_protocol\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.resumed\",\"scripted\":false,\"searchable\":true,\"type\":\"boolean\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.server.certificate\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.server.certificate_chain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.server.hash.md5\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.server.hash.sha1\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.server.hash.sha256\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.server.issuer\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.server.ja3s\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.server.not_after\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.server.not_before\",\"scripted\":false,\"searchable\":true,\"type\":\"date\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.server.subject\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tls.version_protocol\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tracing.trace.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"tracing.transaction.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.extension\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.fragment\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.full\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.full.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.original\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.original.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.password\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.path\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.port\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.query\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.registered_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.scheme\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.top_level_domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"url.username\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user.email\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user.full_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user.full_name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user.group.domain\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user.group.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user.group.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user.hash\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.device.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.original\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.original.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.os.family\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.os.full\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.os.full.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.os.kernel\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.os.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.os.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.os.platform\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.os.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"user_agent.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"vulnerability.category\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"vulnerability.classification\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"vulnerability.description\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"vulnerability.description.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"vulnerability.enumeration\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"vulnerability.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"vulnerability.reference\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"vulnerability.report_id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"vulnerability.scanner.vendor\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"vulnerability.score.base\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"vulnerability.score.environmental\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"vulnerability.score.temporal\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"vulnerability.score.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"vulnerability.severity\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"agent.hostname\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"fields\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"timeseries.instance\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"cloud.project.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"cloud.image.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"docker.container.labels\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.containerized\",\"scripted\":false,\"searchable\":true,\"type\":\"boolean\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.os.build\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"host.os.codename\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.pod.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.pod.uid\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.namespace\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.node.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.labels.*\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.annotations.*\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.replicaset.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.deployment.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.statefulset.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.container.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"kubernetes.container.image\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"processor.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"processor.event\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"timestamp.us\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":false,\"enabled\":false,\"indexed\":false,\"name\":\"http.request.headers\",\"scripted\":false,\"searchable\":false},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"http.response.finished\",\"scripted\":false,\"searchable\":true,\"type\":\"boolean\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":false,\"enabled\":false,\"indexed\":false,\"name\":\"http.response.headers\",\"scripted\":false,\"searchable\":false},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.environment\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.language.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.language.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.runtime.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.runtime.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.framework.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"service.framework.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.sampled\",\"scripted\":false,\"searchable\":true,\"type\":\"boolean\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.name.text\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.duration.count\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.duration.sum.us\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.self_time.count\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.self_time.sum.us\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.breakdown.count\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"span.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"span.subtype\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.self_time.count\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.self_time.sum.us\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"trace.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"parent.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.listening\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"observer.version_major\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"experimental\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":true,\"analyzed\":false,\"count\":2,\"doc_values\":true,\"indexed\":true,\"name\":\"error.culprit\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.grouping_key\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.exception.code\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":2,\"doc_values\":true,\"indexed\":true,\"name\":\"error.exception.message\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.exception.module\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":4,\"doc_values\":true,\"indexed\":true,\"name\":\"error.exception.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":2,\"doc_values\":true,\"indexed\":true,\"name\":\"error.exception.handled\",\"scripted\":false,\"searchable\":true,\"type\":\"boolean\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.log.level\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.log.logger_name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":2,\"doc_values\":true,\"indexed\":true,\"name\":\"error.log.message\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"error.log.param_message\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"system.cpu.total.norm.pct\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"system.memory.total\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"system.memory.actual.free\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"system.process.cpu.total.norm.pct\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"system.process.memory.size\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"system.process.memory.rss.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.cpu.ns\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.samples.count\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.alloc_objects.count\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.alloc_space.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.inuse_objects.count\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.inuse_space.bytes\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.duration\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.top.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.top.function\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.top.filename\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.top.line\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.stack.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.stack.function\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.stack.filename\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"profile.stack.line\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"sourcemap.service.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"sourcemap.service.version\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"sourcemap.bundle_filepath\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"view spans\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.id\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"span.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"span.action\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"span.start.us\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":1,\"doc_values\":true,\"indexed\":true,\"name\":\"span.duration.us\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.sync\",\"scripted\":false,\"searchable\":true,\"type\":\"boolean\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.db.link\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.db.rows_affected\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.destination.service.type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.destination.service.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.destination.service.resource\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.message.queue.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"span.message.age.ms\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.duration.us\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.result\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.marks\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.marks.*.*\",\"scripted\":false,\"searchable\":true},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.span_count.dropped\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.message.queue.name\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":true,\"indexed\":true,\"name\":\"transaction.message.age.ms\",\"scripted\":false,\"searchable\":true,\"type\":\"number\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":false,\"indexed\":false,\"name\":\"_id\",\"scripted\":false,\"searchable\":false,\"type\":\"string\"},{\"aggregatable\":true,\"analyzed\":false,\"count\":0,\"doc_values\":false,\"indexed\":false,\"name\":\"_type\",\"scripted\":false,\"searchable\":true,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":false,\"indexed\":false,\"name\":\"_index\",\"scripted\":false,\"searchable\":false,\"type\":\"string\"},{\"aggregatable\":false,\"analyzed\":false,\"count\":0,\"doc_values\":false,\"indexed\":false,\"name\":\"_score\",\"scripted\":false,\"searchable\":false,\"type\":\"number\"}]", "sourceFilters": "[{\"value\":\"sourcemap.sourcemap\"}]", "timeFieldName": "@timestamp" }, From 45f8ca90a3082a1b7baf8e57e17ee264d0352c5e Mon Sep 17 00:00:00 2001 From: Katrin Freihofner Date: Tue, 14 Jan 2020 14:52:52 +0100 Subject: [PATCH 086/139] changes alignment of location column in monitor details view (#54709) --- .../ping_list/__tests__/__snapshots__/ping_list.test.tsx.snap | 2 +- .../uptime/public/components/functional/ping_list/ping_list.tsx | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/x-pack/legacy/plugins/uptime/public/components/functional/ping_list/__tests__/__snapshots__/ping_list.test.tsx.snap b/x-pack/legacy/plugins/uptime/public/components/functional/ping_list/__tests__/__snapshots__/ping_list.test.tsx.snap index 692675baa8950..58bbf721e05de 100644 --- a/x-pack/legacy/plugins/uptime/public/components/functional/ping_list/__tests__/__snapshots__/ping_list.test.tsx.snap +++ b/x-pack/legacy/plugins/uptime/public/components/functional/ping_list/__tests__/__snapshots__/ping_list.test.tsx.snap @@ -121,7 +121,7 @@ exports[`PingList component renders sorted list without errors 1`] = ` "render": [Function], }, Object { - "align": "center", + "align": "left", "field": "observer.geo.name", "name": "Location", "render": [Function], diff --git a/x-pack/legacy/plugins/uptime/public/components/functional/ping_list/ping_list.tsx b/x-pack/legacy/plugins/uptime/public/components/functional/ping_list/ping_list.tsx index 71b1255b3b37e..3f0ec298e3289 100644 --- a/x-pack/legacy/plugins/uptime/public/components/functional/ping_list/ping_list.tsx +++ b/x-pack/legacy/plugins/uptime/public/components/functional/ping_list/ping_list.tsx @@ -139,7 +139,7 @@ export const PingListComponent = ({ ), }, { - align: 'center', + align: 'left', field: 'observer.geo.name', name: i18n.translate('xpack.uptime.pingList.locationNameColumnLabel', { defaultMessage: 'Location', From 69730cef73d7c4bd927a1b02e76af0f68321c3b0 Mon Sep 17 00:00:00 2001 From: Melissa Alvarez Date: Tue, 14 Jan 2020 08:58:36 -0500 Subject: [PATCH 087/139] [ML] DataFrame Analytics use field caps api to set column type (#54543) * wip: initialize newJobCaps service in parent element * wip: use jobCaps service to create columns * add render and types to talble columns * add keyword suffix when constructing query. ensure pagination works * Ensure search query and sorting works * wip: update regression table to use jobCaps api * move shared resources to central location * ensure 0 and false values show up in table * add error handling to jobCaps initialization * ensure outlier detection table can toggle columns * check for undefined before using moment to create date * add tests for fix for getNestedProperty --- .../legacy/plugins/ml/common/types/fields.ts | 2 +- .../data_frame_analytics/common/analytics.ts | 10 +- .../data_frame_analytics/common/fields.ts | 107 ++++++- .../data_frame_analytics/common/index.ts | 2 + .../classification_exploration.tsx | 64 +++- .../evaluate_panel.tsx | 32 +- .../results_table.tsx | 294 ++++++++++-------- .../use_explore_data.ts | 52 ++-- .../components/exploration/exploration.tsx | 4 +- .../regression_exploration.tsx | 64 +++- .../regression_exploration/results_table.tsx | 293 +++++++++-------- .../use_explore_data.ts | 52 ++-- .../form_options_validation.ts | 15 +- .../application/util/object_utils.test.ts | 19 ++ .../public/application/util/object_utils.ts | 6 +- 15 files changed, 623 insertions(+), 393 deletions(-) diff --git a/x-pack/legacy/plugins/ml/common/types/fields.ts b/x-pack/legacy/plugins/ml/common/types/fields.ts index 9e1b992eec907..4860ab955d066 100644 --- a/x-pack/legacy/plugins/ml/common/types/fields.ts +++ b/x-pack/legacy/plugins/ml/common/types/fields.ts @@ -23,7 +23,7 @@ export interface Field { id: FieldId; name: string; type: ES_FIELD_TYPES; - aggregatable: boolean; + aggregatable?: boolean; aggIds?: AggId[]; aggs?: Aggregation[]; } diff --git a/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/common/analytics.ts b/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/common/analytics.ts index ce832513c4adc..12d441a9a23ec 100644 --- a/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/common/analytics.ts +++ b/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/common/analytics.ts @@ -13,6 +13,7 @@ import { ml } from '../../services/ml_api_service'; import { Dictionary } from '../../../../common/types/common'; import { getErrorMessage } from '../pages/analytics_management/hooks/use_create_analytics_form'; import { SavedSearchQuery } from '../../contexts/kibana'; +import { SortDirection } from '../../components/ml_in_memory_table'; export type IndexName = string; export type IndexPattern = string; @@ -39,6 +40,13 @@ interface ClassificationAnalysis { }; } +export interface LoadExploreDataArg { + field: string; + direction: SortDirection; + searchQuery: SavedSearchQuery; + requiresKeyword?: boolean; +} + export const SEARCH_SIZE = 1000; export const defaultSearchQuery = { @@ -182,7 +190,7 @@ export const getPredictedFieldName = ( const defaultPredictionField = `${getDependentVar(analysis)}_prediction`; const predictedField = `${resultsField}.${ predictionFieldName ? predictionFieldName : defaultPredictionField - }${isClassificationAnalysis(analysis) && !forSort ? '.keyword' : ''}`; + }`; return predictedField; }; diff --git a/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/common/fields.ts b/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/common/fields.ts index 216836db4ccbc..e7d5afeba371f 100644 --- a/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/common/fields.ts +++ b/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/common/fields.ts @@ -5,7 +5,15 @@ */ import { getNestedProperty } from '../../util/object_utils'; -import { DataFrameAnalyticsConfig, getPredictedFieldName, getDependentVar } from './analytics'; +import { + DataFrameAnalyticsConfig, + getPredictedFieldName, + getDependentVar, + getPredictionFieldName, +} from './analytics'; +import { Field } from '../../../../common/types/fields'; +import { ES_FIELD_TYPES } from '../../../../../../../../src/plugins/data/public'; +import { newJobCapsService } from '../../services/new_job_capabilities_service'; export type EsId = string; export type EsDocSource = Record; @@ -19,8 +27,41 @@ export interface EsDoc extends Record { export const MAX_COLUMNS = 20; export const DEFAULT_REGRESSION_COLUMNS = 8; +export const BASIC_NUMERICAL_TYPES = new Set([ + ES_FIELD_TYPES.LONG, + ES_FIELD_TYPES.INTEGER, + ES_FIELD_TYPES.SHORT, + ES_FIELD_TYPES.BYTE, +]); + +export const EXTENDED_NUMERICAL_TYPES = new Set([ + ES_FIELD_TYPES.DOUBLE, + ES_FIELD_TYPES.FLOAT, + ES_FIELD_TYPES.HALF_FLOAT, + ES_FIELD_TYPES.SCALED_FLOAT, +]); + const ML__ID_COPY = 'ml__id_copy'; +export const isKeywordAndTextType = (fieldName: string): boolean => { + const { fields } = newJobCapsService; + + const fieldType = fields.find(field => field.name === fieldName)?.type; + let isBothTypes = false; + + // If it's a keyword type - check if it has a corresponding text type + if (fieldType !== undefined && fieldType === ES_FIELD_TYPES.KEYWORD) { + const field = newJobCapsService.getFieldById(fieldName.replace(/\.keyword$/, '')); + isBothTypes = field !== null && field.type === ES_FIELD_TYPES.TEXT; + } else if (fieldType !== undefined && fieldType === ES_FIELD_TYPES.TEXT) { + // If text, check if has corresponding keyword type + const field = newJobCapsService.getFieldById(`${fieldName}.keyword`); + isBothTypes = field !== null && field.type === ES_FIELD_TYPES.KEYWORD; + } + + return isBothTypes; +}; + // Used to sort columns: // - string based columns are moved to the left // - followed by the outlier_score column @@ -90,10 +131,10 @@ export const sortRegressionResultsFields = ( if (b === predictedField) { return 1; } - if (a === dependentVariable) { + if (a === dependentVariable || a === dependentVariable.replace(/\.keyword$/, '')) { return -1; } - if (b === dependentVariable) { + if (b === dependentVariable || b === dependentVariable.replace(/\.keyword$/, '')) { return 1; } @@ -200,6 +241,50 @@ export function getFlattenedFields(obj: EsDocSource, resultsField: string): EsFi return flatDocFields.filter(f => f !== ML__ID_COPY); } +export const getDefaultFieldsFromJobCaps = ( + fields: Field[], + jobConfig: DataFrameAnalyticsConfig +): { selectedFields: Field[]; docFields: Field[] } => { + const fieldsObj = { selectedFields: [], docFields: [] }; + if (fields.length === 0) { + return fieldsObj; + } + + const dependentVariable = getDependentVar(jobConfig.analysis); + const type = newJobCapsService.getFieldById(dependentVariable)?.type; + const predictionFieldName = getPredictionFieldName(jobConfig.analysis); + // default is 'ml' + const resultsField = jobConfig.dest.results_field; + + const defaultPredictionField = `${dependentVariable}_prediction`; + const predictedField = `${resultsField}.${ + predictionFieldName ? predictionFieldName : defaultPredictionField + }`; + + const allFields: any = [ + { + id: `${resultsField}.is_training`, + name: `${resultsField}.is_training`, + type: ES_FIELD_TYPES.BOOLEAN, + }, + { id: predictedField, name: predictedField, type }, + ...fields, + ].sort(({ name: a }, { name: b }) => sortRegressionResultsFields(a, b, jobConfig)); + + let selectedFields = allFields + .slice(0, DEFAULT_REGRESSION_COLUMNS * 2) + .filter((field: any) => field.name === predictedField || !field.name.includes('.keyword')); + + if (selectedFields.length > DEFAULT_REGRESSION_COLUMNS) { + selectedFields = selectedFields.slice(0, DEFAULT_REGRESSION_COLUMNS); + } + + return { + selectedFields, + docFields: allFields, + }; +}; + export const getDefaultClassificationFields = ( docs: EsDoc[], jobConfig: DataFrameAnalyticsConfig @@ -290,11 +375,12 @@ export const getDefaultSelectableFields = (docs: EsDoc[], resultsField: string): .slice(0, MAX_COLUMNS); }; -export const toggleSelectedField = ( +export const toggleSelectedFieldSimple = ( selectedFields: EsFieldName[], column: EsFieldName ): EsFieldName[] => { const index = selectedFields.indexOf(column); + if (index === -1) { selectedFields.push(column); } else { @@ -302,3 +388,16 @@ export const toggleSelectedField = ( } return selectedFields; }; + +export const toggleSelectedField = (selectedFields: Field[], column: EsFieldName): Field[] => { + const index = selectedFields.map(field => field.name).indexOf(column); + if (index === -1) { + const columnField = newJobCapsService.getFieldById(column); + if (columnField !== null) { + selectedFields.push(columnField); + } + } else { + selectedFields.splice(index, 1); + } + return selectedFields; +}; diff --git a/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/common/index.ts b/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/common/index.ts index f7794af8b5861..62ef73670d8f5 100644 --- a/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/common/index.ts +++ b/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/common/index.ts @@ -33,11 +33,13 @@ export { getDefaultSelectableFields, getDefaultRegressionFields, getDefaultClassificationFields, + getDefaultFieldsFromJobCaps, getFlattenedFields, sortColumns, sortRegressionResultsColumns, sortRegressionResultsFields, toggleSelectedField, + toggleSelectedFieldSimple, EsId, EsDoc, EsDocSource, diff --git a/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_exploration/components/classification_exploration/classification_exploration.tsx b/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_exploration/components/classification_exploration/classification_exploration.tsx index f424ebee58120..95e1b15d548c1 100644 --- a/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_exploration/components/classification_exploration/classification_exploration.tsx +++ b/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_exploration/components/classification_exploration/classification_exploration.tsx @@ -14,6 +14,10 @@ import { ResultsTable } from './results_table'; import { DATA_FRAME_TASK_STATE } from '../../../analytics_management/components/analytics_list/common'; import { ResultsSearchQuery, defaultSearchQuery } from '../../../../common/analytics'; import { LoadingPanel } from '../loading_panel'; +import { getIndexPatternIdFromName } from '../../../../../util/index_utils'; +import { IIndexPattern } from '../../../../../../../../../../../src/plugins/data/common/index_patterns'; +import { newJobCapsService } from '../../../../../services/new_job_capabilities_service'; +import { useKibanaContext } from '../../../../../contexts/kibana'; interface GetDataFrameAnalyticsResponse { count: number; @@ -31,6 +35,21 @@ export const ExplorationTitle: React.FC<{ jobId: string }> = ({ jobId }) => (
); +const jobConfigErrorTitle = i18n.translate( + 'xpack.ml.dataframe.analytics.classificationExploration.jobConfigurationFetchError', + { + defaultMessage: + 'Unable to fetch results. An error occurred loading the job configuration data.', + } +); + +const jobCapsErrorTitle = i18n.translate( + 'xpack.ml.dataframe.analytics.classificationExploration.jobCapsFetchError', + { + defaultMessage: "Unable to fetch results. An error occurred loading the index's field data.", + } +); + interface Props { jobId: string; jobStatus: DATA_FRAME_TASK_STATE; @@ -39,8 +58,13 @@ interface Props { export const ClassificationExploration: FC = ({ jobId, jobStatus }) => { const [jobConfig, setJobConfig] = useState(undefined); const [isLoadingJobConfig, setIsLoadingJobConfig] = useState(false); + const [isInitialized, setIsInitialized] = useState(false); const [jobConfigErrorMessage, setJobConfigErrorMessage] = useState(undefined); + const [jobCapsServiceErrorMessage, setJobCapsServiceErrorMessage] = useState( + undefined + ); const [searchQuery, setSearchQuery] = useState(defaultSearchQuery); + const kibanaContext = useKibanaContext(); const loadJobConfig = async () => { setIsLoadingJobConfig(true); @@ -78,23 +102,41 @@ export const ClassificationExploration: FC = ({ jobId, jobStatus }) => { loadJobConfig(); }, []); - if (jobConfigErrorMessage !== undefined) { + const initializeJobCapsService = async () => { + if (jobConfig !== undefined) { + try { + const sourceIndex = jobConfig.source.index[0]; + const indexPatternId = getIndexPatternIdFromName(sourceIndex) || sourceIndex; + const indexPattern: IIndexPattern = await kibanaContext.indexPatterns.get(indexPatternId); + if (indexPattern !== undefined) { + await newJobCapsService.initializeFromIndexPattern(indexPattern, false, false); + } + setIsInitialized(true); + } catch (e) { + if (e.message !== undefined) { + setJobCapsServiceErrorMessage(e.message); + } else { + setJobCapsServiceErrorMessage(JSON.stringify(e)); + } + } + } + }; + + useEffect(() => { + initializeJobCapsService(); + }, [JSON.stringify(jobConfig)]); + + if (jobConfigErrorMessage !== undefined || jobCapsServiceErrorMessage !== undefined) { return ( -

{jobConfigErrorMessage}

+

{jobConfigErrorMessage ? jobConfigErrorMessage : jobCapsServiceErrorMessage}

); @@ -103,12 +145,12 @@ export const ClassificationExploration: FC = ({ jobId, jobStatus }) => { return ( {isLoadingJobConfig === true && jobConfig === undefined && } - {isLoadingJobConfig === false && jobConfig !== undefined && ( + {isLoadingJobConfig === false && jobConfig !== undefined && isInitialized === true && ( )} {isLoadingJobConfig === true && jobConfig === undefined && } - {isLoadingJobConfig === false && jobConfig !== undefined && ( + {isLoadingJobConfig === false && jobConfig !== undefined && isInitialized === true && ( = ({ jobConfig, jobStatus, searchQuery }) const [visibleColumns, setVisibleColumns] = useState(() => columns.map(({ id }: { id: string }) => id) ); - const kibanaContext = useKibanaContext(); const index = jobConfig.dest.index; - const sourceIndex = jobConfig.source.index[0]; const dependentVariable = getDependentVar(jobConfig.analysis); const predictionFieldName = getPredictionFieldName(jobConfig.analysis); // default is 'ml' @@ -86,25 +80,7 @@ export const EvaluatePanel: FC = ({ jobConfig, jobStatus, searchQuery }) setIsLoading(true); try { - const indexPatternId = getIndexPatternIdFromName(sourceIndex) || sourceIndex; - const indexPattern: IIndexPattern = await kibanaContext.indexPatterns.get(indexPatternId); - - if (indexPattern !== undefined) { - await newJobCapsService.initializeFromIndexPattern(indexPattern, false, false); - // If dependent_variable is of type keyword and text .keyword suffix is required for evaluate endpoint - const { fields } = newJobCapsService; - const depVarFieldType = fields.find(field => field.name === dependentVariable)?.type; - - // If it's a keyword type - check if it has a corresponding text type - if (depVarFieldType !== undefined && depVarFieldType === ES_FIELD_TYPES.KEYWORD) { - const field = newJobCapsService.getFieldById(dependentVariable.replace(/\.keyword$/, '')); - requiresKeyword = field !== null && field.type === ES_FIELD_TYPES.TEXT; - } else if (depVarFieldType !== undefined && depVarFieldType === ES_FIELD_TYPES.TEXT) { - // If text, check if has corresponding keyword type - const field = newJobCapsService.getFieldById(`${dependentVariable}.keyword`); - requiresKeyword = field !== null && field.type === ES_FIELD_TYPES.KEYWORD; - } - } + requiresKeyword = isKeywordAndTextType(dependentVariable); } catch (e) { // Additional error handling due to missing field type is handled by loadEvalData console.error('Unable to load new field types', error); // eslint-disable-line no-console @@ -359,9 +335,9 @@ export const EvaluatePanel: FC = ({ jobConfig, jobStatus, searchQuery })
- + = React.memo( ({ jobConfig, jobStatus, setEvaluateSearchQuery }) => { const [pageIndex, setPageIndex] = useState(0); const [pageSize, setPageSize] = useState(25); - const [selectedFields, setSelectedFields] = useState([] as EsFieldName[]); + const [selectedFields, setSelectedFields] = useState([] as Field[]); + const [docFields, setDocFields] = useState([] as Field[]); const [isColumnsPopoverVisible, setColumnsPopoverVisible] = useState(false); const [searchQuery, setSearchQuery] = useState(defaultSearchQuery); const [searchError, setSearchError] = useState(undefined); const [searchString, setSearchString] = useState(undefined); + const predictedFieldName = getPredictedFieldName( + jobConfig.dest.results_field, + jobConfig.analysis + ); + + const dependentVariable = getDependentVar(jobConfig.analysis); + function toggleColumnsPopover() { setColumnsPopoverVisible(!isColumnsPopoverVisible); } @@ -99,147 +113,140 @@ export const ResultsTable: FC = React.memo( sortDirection, status, tableItems, - } = useExploreData(jobConfig, selectedFields, setSelectedFields); - - let docFields: EsFieldName[] = []; - let docFieldsCount = 0; - if (tableItems.length > 0) { - docFields = Object.keys(tableItems[0]); - docFields.sort((a, b) => sortRegressionResultsFields(a, b, jobConfig)); - docFieldsCount = docFields.length; - } - - const columns: Array> = []; - - if (jobConfig !== undefined && selectedFields.length > 0 && tableItems.length > 0) { - columns.push( - ...selectedFields.sort(sortRegressionResultsColumns(tableItems[0], jobConfig)).map(k => { - const column: ColumnType = { - field: k, - name: k, - sortable: true, - truncateText: true, - }; - - const render = (d: any, fullItem: EsDoc) => { - if (Array.isArray(d) && d.every(item => typeof item === 'string')) { - // If the cells data is an array of strings, return as a comma separated list. - // The list will get limited to 5 items with `…` at the end if there's more in the original array. - return `${d.slice(0, 5).join(', ')}${d.length > 5 ? ', …' : ''}`; - } else if (Array.isArray(d)) { - // If the cells data is an array of e.g. objects, display a 'array' badge with a - // tooltip that explains that this type of field is not supported in this table. - return ( - - - {i18n.translate( - 'xpack.ml.dataframe.analytics.classificationExploration.indexArrayBadgeContent', - { - defaultMessage: 'array', - } - )} - - - ); - } else if (typeof d === 'object' && d !== null) { - // If the cells data is an object, display a 'object' badge with a - // tooltip that explains that this type of field is not supported in this table. - return ( - - - {i18n.translate( - 'xpack.ml.dataframe.analytics.classificationExploration.indexObjectBadgeContent', - { - defaultMessage: 'object', - } - )} - - - ); - } - - return d; - }; + } = useExploreData(jobConfig, selectedFields, setSelectedFields, setDocFields); + + const columns: Array> = selectedFields.map(field => { + const { type } = field; + const isNumber = + type !== undefined && + (BASIC_NUMERICAL_TYPES.has(type) || EXTENDED_NUMERICAL_TYPES.has(type)); + + const column: ColumnType = { + field: field.name, + name: field.name, + sortable: true, + truncateText: true, + }; - let columnType; + const render = (d: any, fullItem: EsDoc) => { + if (Array.isArray(d) && d.every(item => typeof item === 'string')) { + // If the cells data is an array of strings, return as a comma separated list. + // The list will get limited to 5 items with `…` at the end if there's more in the original array. + return `${d.slice(0, 5).join(', ')}${d.length > 5 ? ', …' : ''}`; + } else if (Array.isArray(d)) { + // If the cells data is an array of e.g. objects, display a 'array' badge with a + // tooltip that explains that this type of field is not supported in this table. + return ( + + + {i18n.translate( + 'xpack.ml.dataframe.analytics.classificationExploration.indexArrayBadgeContent', + { + defaultMessage: 'array', + } + )} + + + ); + } - if (tableItems.length > 0) { - columnType = typeof tableItems[0][k]; - } + return d; + }; - if (typeof columnType !== 'undefined') { - switch (columnType) { - case 'boolean': - column.dataType = 'boolean'; - break; - case 'Date': - column.align = 'right'; - column.render = (d: any) => - formatHumanReadableDateTimeSeconds(moment(d).unix() * 1000); - break; - case 'number': - column.dataType = 'number'; - column.render = render; - break; - default: - column.render = render; - break; - } - } else { + if (isNumber) { + column.dataType = 'number'; + column.render = render; + } else if (typeof type !== 'undefined') { + switch (type) { + case ES_FIELD_TYPES.BOOLEAN: + column.dataType = ES_FIELD_TYPES.BOOLEAN; + break; + case ES_FIELD_TYPES.DATE: + column.align = 'right'; + column.render = (d: any) => { + if (d !== undefined) { + return formatHumanReadableDateTimeSeconds(moment(d).unix() * 1000); + } + return d; + }; + break; + default: column.render = render; - } + break; + } + } else { + column.render = render; + } - return column; - }) - ); - } + return column; + }); + + const docFieldsCount = docFields.length; useEffect(() => { - if (jobConfig !== undefined) { - const predictedFieldName = getPredictedFieldName( - jobConfig.dest.results_field, - jobConfig.analysis - ); - const predictedFieldSelected = selectedFields.includes(predictedFieldName); + if ( + jobConfig !== undefined && + columns.length > 0 && + selectedFields.length > 0 && + sortField !== undefined && + sortDirection !== undefined && + selectedFields.some(field => field.name === sortField) + ) { + let field = sortField; + // If sorting by predictedField use dependentVar type + if (predictedFieldName === sortField) { + field = dependentVariable; + } + const requiresKeyword = isKeywordAndTextType(field); - const field = predictedFieldSelected ? predictedFieldName : selectedFields[0]; - const direction = predictedFieldSelected ? SORT_DIRECTION.DESC : SORT_DIRECTION.ASC; - loadExploreData({ field, direction, searchQuery }); + loadExploreData({ + field: sortField, + direction: sortDirection, + searchQuery, + requiresKeyword, + }); } }, [JSON.stringify(searchQuery)]); useEffect(() => { - // by default set the sorting to descending on the prediction field (`_prediction`). - // if that's not available sort ascending on the first column. - // also check if the current sorting field is still available. - if (jobConfig !== undefined && columns.length > 0 && !selectedFields.includes(sortField)) { - const predictedFieldName = getPredictedFieldName( - jobConfig.dest.results_field, - jobConfig.analysis + // By default set sorting to descending on the prediction field (`_prediction`). + // if that's not available sort ascending on the first column. Check if the current sorting field is still available. + if ( + jobConfig !== undefined && + columns.length > 0 && + selectedFields.length > 0 && + !selectedFields.some(field => field.name === sortField) + ) { + const predictedFieldSelected = selectedFields.some( + field => field.name === predictedFieldName ); - const predictedFieldSelected = selectedFields.includes(predictedFieldName); - const field = predictedFieldSelected ? predictedFieldName : selectedFields[0]; + // CHECK IF keyword suffix is needed (if predicted field is selected we have to check the dependent variable type) + let sortByField = predictedFieldSelected ? dependentVariable : selectedFields[0].name; + + const requiresKeyword = isKeywordAndTextType(sortByField); + + sortByField = predictedFieldSelected ? predictedFieldName : sortByField; + const direction = predictedFieldSelected ? SORT_DIRECTION.DESC : SORT_DIRECTION.ASC; - loadExploreData({ field, direction, searchQuery }); + loadExploreData({ field: sortByField, direction, searchQuery, requiresKeyword }); } - }, [jobConfig, columns.length, sortField, sortDirection, tableItems.length]); + }, [ + jobConfig, + columns.length, + selectedFields.length, + sortField, + sortDirection, + tableItems.length, + ]); let sorting: SortingPropType = false; let onTableChange; @@ -261,7 +268,17 @@ export const ResultsTable: FC = React.memo( setPageSize(size); if (sort.field !== sortField || sort.direction !== sortDirection) { - loadExploreData({ ...sort, searchQuery }); + let field = sort.field; + // If sorting by predictedField use depVar for type check + if (predictedFieldName === sort.field) { + field = dependentVariable; + } + + loadExploreData({ + ...sort, + searchQuery, + requiresKeyword: isKeywordAndTextType(field), + }); } }; } @@ -422,14 +439,17 @@ export const ResultsTable: FC = React.memo( )}
- {docFields.map(d => ( + {docFields.map(({ name }) => ( toggleColumn(d)} - disabled={selectedFields.includes(d) && selectedFields.length === 1} + key={name} + id={name} + label={name} + checked={selectedFields.some(field => field.name === name)} + onChange={() => toggleColumn(name)} + disabled={ + selectedFields.some(field => field.name === name) && + selectedFields.length === 1 + } /> ))}
diff --git a/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_exploration/components/classification_exploration/use_explore_data.ts b/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_exploration/components/classification_exploration/use_explore_data.ts index ba12fcab98a36..b61f9f6524116 100644 --- a/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_exploration/components/classification_exploration/use_explore_data.ts +++ b/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_exploration/components/classification_exploration/use_explore_data.ts @@ -17,27 +17,22 @@ import { SortDirection, SORT_DIRECTION } from '../../../../../components/ml_in_m import { ml } from '../../../../../services/ml_api_service'; import { getNestedProperty } from '../../../../../util/object_utils'; -import { SavedSearchQuery } from '../../../../../contexts/kibana'; +import { newJobCapsService } from '../../../../../services/new_job_capabilities_service'; +import { Field } from '../../../../../../../common/types/fields'; +import { LoadExploreDataArg } from '../../../../common/analytics'; import { - getDefaultClassificationFields, + getDefaultFieldsFromJobCaps, getFlattenedFields, DataFrameAnalyticsConfig, EsFieldName, - getPredictedFieldName, INDEX_STATUS, SEARCH_SIZE, - defaultSearchQuery, SearchQuery, } from '../../../../common'; export type TableItem = Record; -interface LoadExploreDataArg { - field: string; - direction: SortDirection; - searchQuery: SavedSearchQuery; -} export interface UseExploreDataReturnType { errorMessage: string; loadExploreData: (arg: LoadExploreDataArg) => void; @@ -49,8 +44,9 @@ export interface UseExploreDataReturnType { export const useExploreData = ( jobConfig: DataFrameAnalyticsConfig | undefined, - selectedFields: EsFieldName[], - setSelectedFields: React.Dispatch> + selectedFields: Field[], + setSelectedFields: React.Dispatch>, + setDocFields: React.Dispatch> ): UseExploreDataReturnType => { const [errorMessage, setErrorMessage] = useState(''); const [status, setStatus] = useState(INDEX_STATUS.UNUSED); @@ -58,7 +54,26 @@ export const useExploreData = ( const [sortField, setSortField] = useState(''); const [sortDirection, setSortDirection] = useState(SORT_DIRECTION.ASC); - const loadExploreData = async ({ field, direction, searchQuery }: LoadExploreDataArg) => { + const getDefaultSelectedFields = () => { + const { fields } = newJobCapsService; + + if (selectedFields.length === 0 && jobConfig !== undefined) { + const { selectedFields: defaultSelected, docFields } = getDefaultFieldsFromJobCaps( + fields, + jobConfig + ); + + setSelectedFields(defaultSelected); + setDocFields(docFields); + } + }; + + const loadExploreData = async ({ + field, + direction, + searchQuery, + requiresKeyword, + }: LoadExploreDataArg) => { if (jobConfig !== undefined) { setErrorMessage(''); setStatus(INDEX_STATUS.LOADING); @@ -72,7 +87,7 @@ export const useExploreData = ( if (field !== undefined) { body.sort = [ { - [field]: { + [`${field}${requiresKeyword ? '.keyword' : ''}`]: { order: direction, }, }, @@ -96,11 +111,6 @@ export const useExploreData = ( return; } - if (selectedFields.length === 0) { - const newSelectedFields = getDefaultClassificationFields(docs, jobConfig); - setSelectedFields(newSelectedFields); - } - // Create a version of the doc's source with flattened field names. // This avoids confusion later on if a field name has dots in its name // or is a nested fields when displaying it via EuiInMemoryTable. @@ -144,11 +154,7 @@ export const useExploreData = ( useEffect(() => { if (jobConfig !== undefined) { - loadExploreData({ - field: getPredictedFieldName(jobConfig.dest.results_field, jobConfig.analysis), - direction: SORT_DIRECTION.DESC, - searchQuery: defaultSearchQuery, - }); + getDefaultSelectedFields(); } }, [jobConfig && jobConfig.id]); diff --git a/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_exploration/components/exploration/exploration.tsx b/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_exploration/components/exploration/exploration.tsx index 31e6d409b1c4f..9691a0706121c 100644 --- a/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_exploration/components/exploration/exploration.tsx +++ b/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_exploration/components/exploration/exploration.tsx @@ -46,7 +46,7 @@ import { ml } from '../../../../../services/ml_api_service'; import { sortColumns, - toggleSelectedField, + toggleSelectedFieldSimple, DataFrameAnalyticsConfig, EsFieldName, EsDoc, @@ -138,7 +138,7 @@ export const Exploration: FC = React.memo(({ jobId, jobStatus }) => { function toggleColumn(column: EsFieldName) { if (tableItems.length > 0 && jobConfig !== undefined) { // spread to a new array otherwise the component wouldn't re-render - setSelectedFields([...toggleSelectedField(selectedFields, column)]); + setSelectedFields([...toggleSelectedFieldSimple(selectedFields, column)]); } } diff --git a/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_exploration/components/regression_exploration/regression_exploration.tsx b/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_exploration/components/regression_exploration/regression_exploration.tsx index 12a41e1e7d851..7399828bcd642 100644 --- a/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_exploration/components/regression_exploration/regression_exploration.tsx +++ b/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_exploration/components/regression_exploration/regression_exploration.tsx @@ -14,6 +14,10 @@ import { ResultsTable } from './results_table'; import { DATA_FRAME_TASK_STATE } from '../../../analytics_management/components/analytics_list/common'; import { ResultsSearchQuery, defaultSearchQuery } from '../../../../common/analytics'; import { LoadingPanel } from '../loading_panel'; +import { getIndexPatternIdFromName } from '../../../../../util/index_utils'; +import { IIndexPattern } from '../../../../../../../../../../../src/plugins/data/common/index_patterns'; +import { newJobCapsService } from '../../../../../services/new_job_capabilities_service'; +import { useKibanaContext } from '../../../../../contexts/kibana'; interface GetDataFrameAnalyticsResponse { count: number; @@ -31,6 +35,21 @@ export const ExplorationTitle: React.FC<{ jobId: string }> = ({ jobId }) => ( ); +const jobConfigErrorTitle = i18n.translate( + 'xpack.ml.dataframe.analytics.regressionExploration.jobConfigurationFetchError', + { + defaultMessage: + 'Unable to fetch results. An error occurred loading the job configuration data.', + } +); + +const jobCapsErrorTitle = i18n.translate( + 'xpack.ml.dataframe.analytics.regressionExploration.jobCapsFetchError', + { + defaultMessage: "Unable to fetch results. An error occurred loading the index's field data.", + } +); + interface Props { jobId: string; jobStatus: DATA_FRAME_TASK_STATE; @@ -39,8 +58,13 @@ interface Props { export const RegressionExploration: FC = ({ jobId, jobStatus }) => { const [jobConfig, setJobConfig] = useState(undefined); const [isLoadingJobConfig, setIsLoadingJobConfig] = useState(false); + const [isInitialized, setIsInitialized] = useState(false); const [jobConfigErrorMessage, setJobConfigErrorMessage] = useState(undefined); + const [jobCapsServiceErrorMessage, setJobCapsServiceErrorMessage] = useState( + undefined + ); const [searchQuery, setSearchQuery] = useState(defaultSearchQuery); + const kibanaContext = useKibanaContext(); const loadJobConfig = async () => { setIsLoadingJobConfig(true); @@ -69,23 +93,41 @@ export const RegressionExploration: FC = ({ jobId, jobStatus }) => { loadJobConfig(); }, []); - if (jobConfigErrorMessage !== undefined) { + const initializeJobCapsService = async () => { + if (jobConfig !== undefined) { + try { + const sourceIndex = jobConfig.source.index[0]; + const indexPatternId = getIndexPatternIdFromName(sourceIndex) || sourceIndex; + const indexPattern: IIndexPattern = await kibanaContext.indexPatterns.get(indexPatternId); + if (indexPattern !== undefined) { + await newJobCapsService.initializeFromIndexPattern(indexPattern, false, false); + } + setIsInitialized(true); + } catch (e) { + if (e.message !== undefined) { + setJobCapsServiceErrorMessage(e.message); + } else { + setJobCapsServiceErrorMessage(JSON.stringify(e)); + } + } + } + }; + + useEffect(() => { + initializeJobCapsService(); + }, [JSON.stringify(jobConfig)]); + + if (jobConfigErrorMessage !== undefined || jobCapsServiceErrorMessage !== undefined) { return ( -

{jobConfigErrorMessage}

+

{jobConfigErrorMessage ? jobConfigErrorMessage : jobCapsServiceErrorMessage}

); @@ -94,12 +136,12 @@ export const RegressionExploration: FC = ({ jobId, jobStatus }) => { return ( {isLoadingJobConfig === true && jobConfig === undefined && } - {isLoadingJobConfig === false && jobConfig !== undefined && ( + {isLoadingJobConfig === false && jobConfig !== undefined && isInitialized === true && ( )} {isLoadingJobConfig === true && jobConfig === undefined && } - {isLoadingJobConfig === false && jobConfig !== undefined && ( + {isLoadingJobConfig === false && jobConfig !== undefined && isInitialized === true && ( = React.memo( ({ jobConfig, jobStatus, setEvaluateSearchQuery }) => { const [pageIndex, setPageIndex] = useState(0); const [pageSize, setPageSize] = useState(25); - const [selectedFields, setSelectedFields] = useState([] as EsFieldName[]); + const [selectedFields, setSelectedFields] = useState([] as Field[]); + const [docFields, setDocFields] = useState([] as Field[]); const [isColumnsPopoverVisible, setColumnsPopoverVisible] = useState(false); const [searchQuery, setSearchQuery] = useState(defaultSearchQuery); const [searchError, setSearchError] = useState(undefined); const [searchString, setSearchString] = useState(undefined); + const predictedFieldName = getPredictedFieldName( + jobConfig.dest.results_field, + jobConfig.analysis + ); + + const dependentVariable = getDependentVar(jobConfig.analysis); + function toggleColumnsPopover() { setColumnsPopoverVisible(!isColumnsPopoverVisible); } @@ -100,147 +114,140 @@ export const ResultsTable: FC = React.memo( sortDirection, status, tableItems, - } = useExploreData(jobConfig, selectedFields, setSelectedFields); - - let docFields: EsFieldName[] = []; - let docFieldsCount = 0; - if (tableItems.length > 0) { - docFields = Object.keys(tableItems[0]); - docFields.sort((a, b) => sortRegressionResultsFields(a, b, jobConfig)); - docFieldsCount = docFields.length; - } - - const columns: Array> = []; - - if (jobConfig !== undefined && selectedFields.length > 0 && tableItems.length > 0) { - columns.push( - ...selectedFields.sort(sortRegressionResultsColumns(tableItems[0], jobConfig)).map(k => { - const column: ColumnType = { - field: k, - name: k, - sortable: true, - truncateText: true, - }; - - const render = (d: any, fullItem: EsDoc) => { - if (Array.isArray(d) && d.every(item => typeof item === 'string')) { - // If the cells data is an array of strings, return as a comma separated list. - // The list will get limited to 5 items with `…` at the end if there's more in the original array. - return `${d.slice(0, 5).join(', ')}${d.length > 5 ? ', …' : ''}`; - } else if (Array.isArray(d)) { - // If the cells data is an array of e.g. objects, display a 'array' badge with a - // tooltip that explains that this type of field is not supported in this table. - return ( - - - {i18n.translate( - 'xpack.ml.dataframe.analytics.regressionExploration.indexArrayBadgeContent', - { - defaultMessage: 'array', - } - )} - - - ); - } else if (typeof d === 'object' && d !== null) { - // If the cells data is an object, display a 'object' badge with a - // tooltip that explains that this type of field is not supported in this table. - return ( - - - {i18n.translate( - 'xpack.ml.dataframe.analytics.regressionExploration.indexObjectBadgeContent', - { - defaultMessage: 'object', - } - )} - - - ); - } - - return d; - }; + } = useExploreData(jobConfig, selectedFields, setSelectedFields, setDocFields); + + const columns: Array> = selectedFields.map(field => { + const { type } = field; + const isNumber = + type !== undefined && + (BASIC_NUMERICAL_TYPES.has(type) || EXTENDED_NUMERICAL_TYPES.has(type)); + + const column: ColumnType = { + field: field.name, + name: field.name, + sortable: true, + truncateText: true, + }; - let columnType; + const render = (d: any, fullItem: EsDoc) => { + if (Array.isArray(d) && d.every(item => typeof item === 'string')) { + // If the cells data is an array of strings, return as a comma separated list. + // The list will get limited to 5 items with `…` at the end if there's more in the original array. + return `${d.slice(0, 5).join(', ')}${d.length > 5 ? ', …' : ''}`; + } else if (Array.isArray(d)) { + // If the cells data is an array of e.g. objects, display a 'array' badge with a + // tooltip that explains that this type of field is not supported in this table. + return ( + + + {i18n.translate( + 'xpack.ml.dataframe.analytics.regressionExploration.indexArrayBadgeContent', + { + defaultMessage: 'array', + } + )} + + + ); + } - if (tableItems.length > 0) { - columnType = typeof tableItems[0][k]; - } + return d; + }; - if (typeof columnType !== 'undefined') { - switch (columnType) { - case 'boolean': - column.dataType = 'boolean'; - break; - case 'Date': - column.align = 'right'; - column.render = (d: any) => - formatHumanReadableDateTimeSeconds(moment(d).unix() * 1000); - break; - case 'number': - column.dataType = 'number'; - column.render = render; - break; - default: - column.render = render; - break; - } - } else { + if (isNumber) { + column.dataType = 'number'; + column.render = render; + } else if (typeof type !== 'undefined') { + switch (type) { + case ES_FIELD_TYPES.BOOLEAN: + column.dataType = ES_FIELD_TYPES.BOOLEAN; + break; + case ES_FIELD_TYPES.DATE: + column.align = 'right'; + column.render = (d: any) => { + if (d !== undefined) { + return formatHumanReadableDateTimeSeconds(moment(d).unix() * 1000); + } + return d; + }; + break; + default: column.render = render; - } + break; + } + } else { + column.render = render; + } - return column; - }) - ); - } + return column; + }); + + const docFieldsCount = docFields.length; useEffect(() => { - if (jobConfig !== undefined) { - const predictedFieldName = getPredictedFieldName( - jobConfig.dest.results_field, - jobConfig.analysis - ); - const predictedFieldSelected = selectedFields.includes(predictedFieldName); + if ( + jobConfig !== undefined && + columns.length > 0 && + selectedFields.length > 0 && + sortField !== undefined && + sortDirection !== undefined && + selectedFields.some(field => field.name === sortField) + ) { + let field = sortField; + // If sorting by predictedField use dependentVar type + if (predictedFieldName === sortField) { + field = dependentVariable; + } + const requiresKeyword = isKeywordAndTextType(field); - const field = predictedFieldSelected ? predictedFieldName : selectedFields[0]; - const direction = predictedFieldSelected ? SORT_DIRECTION.DESC : SORT_DIRECTION.ASC; - loadExploreData({ field, direction, searchQuery }); + loadExploreData({ + field: sortField, + direction: sortDirection, + searchQuery, + requiresKeyword, + }); } }, [JSON.stringify(searchQuery)]); useEffect(() => { - // by default set the sorting to descending on the prediction field (`_prediction`). - // if that's not available sort ascending on the first column. - // also check if the current sorting field is still available. - if (jobConfig !== undefined && columns.length > 0 && !selectedFields.includes(sortField)) { - const predictedFieldName = getPredictedFieldName( - jobConfig.dest.results_field, - jobConfig.analysis + // By default set sorting to descending on the prediction field (`_prediction`). + // if that's not available sort ascending on the first column. Check if the current sorting field is still available. + if ( + jobConfig !== undefined && + columns.length > 0 && + selectedFields.length > 0 && + !selectedFields.some(field => field.name === sortField) + ) { + const predictedFieldSelected = selectedFields.some( + field => field.name === predictedFieldName ); - const predictedFieldSelected = selectedFields.includes(predictedFieldName); - const field = predictedFieldSelected ? predictedFieldName : selectedFields[0]; + // CHECK IF keyword suffix is needed (if predicted field is selected we have to check the dependent variable type) + let sortByField = predictedFieldSelected ? dependentVariable : selectedFields[0].name; + + const requiresKeyword = isKeywordAndTextType(sortByField); + + sortByField = predictedFieldSelected ? predictedFieldName : sortByField; + const direction = predictedFieldSelected ? SORT_DIRECTION.DESC : SORT_DIRECTION.ASC; - loadExploreData({ field, direction, searchQuery }); + loadExploreData({ field: sortByField, direction, searchQuery, requiresKeyword }); } - }, [jobConfig, columns.length, sortField, sortDirection, tableItems.length]); + }, [ + jobConfig, + columns.length, + selectedFields.length, + sortField, + sortDirection, + tableItems.length, + ]); let sorting: SortingPropType = false; let onTableChange; @@ -262,7 +269,17 @@ export const ResultsTable: FC = React.memo( setPageSize(size); if (sort.field !== sortField || sort.direction !== sortDirection) { - loadExploreData({ ...sort, searchQuery }); + let field = sort.field; + // If sorting by predictedField use depVar for type check + if (predictedFieldName === sort.field) { + field = dependentVariable; + } + + loadExploreData({ + ...sort, + searchQuery, + requiresKeyword: isKeywordAndTextType(field), + }); } }; } @@ -423,14 +440,16 @@ export const ResultsTable: FC = React.memo( )}
- {docFields.map(d => ( + {docFields.map(({ name }) => ( toggleColumn(d)} - disabled={selectedFields.includes(d) && selectedFields.length === 1} + id={name} + label={name} + checked={selectedFields.some(field => field.name === name)} + onChange={() => toggleColumn(name)} + disabled={ + selectedFields.some(field => field.name === name) && + selectedFields.length === 1 + } /> ))}
diff --git a/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_exploration/components/regression_exploration/use_explore_data.ts b/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_exploration/components/regression_exploration/use_explore_data.ts index 8e9cf45c14ec7..f6aa3e490f3ec 100644 --- a/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_exploration/components/regression_exploration/use_explore_data.ts +++ b/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_exploration/components/regression_exploration/use_explore_data.ts @@ -12,27 +12,22 @@ import { SortDirection, SORT_DIRECTION } from '../../../../../components/ml_in_m import { ml } from '../../../../../services/ml_api_service'; import { getNestedProperty } from '../../../../../util/object_utils'; -import { SavedSearchQuery } from '../../../../../contexts/kibana'; +import { newJobCapsService } from '../../../../../services/new_job_capabilities_service'; import { - getDefaultRegressionFields, + getDefaultFieldsFromJobCaps, getFlattenedFields, DataFrameAnalyticsConfig, EsFieldName, - getPredictedFieldName, INDEX_STATUS, SEARCH_SIZE, - defaultSearchQuery, SearchQuery, } from '../../../../common'; +import { Field } from '../../../../../../../common/types/fields'; +import { LoadExploreDataArg } from '../../../../common/analytics'; export type TableItem = Record; -interface LoadExploreDataArg { - field: string; - direction: SortDirection; - searchQuery: SavedSearchQuery; -} export interface UseExploreDataReturnType { errorMessage: string; loadExploreData: (arg: LoadExploreDataArg) => void; @@ -44,8 +39,9 @@ export interface UseExploreDataReturnType { export const useExploreData = ( jobConfig: DataFrameAnalyticsConfig | undefined, - selectedFields: EsFieldName[], - setSelectedFields: React.Dispatch> + selectedFields: Field[], + setSelectedFields: React.Dispatch>, + setDocFields: React.Dispatch> ): UseExploreDataReturnType => { const [errorMessage, setErrorMessage] = useState(''); const [status, setStatus] = useState(INDEX_STATUS.UNUSED); @@ -53,7 +49,26 @@ export const useExploreData = ( const [sortField, setSortField] = useState(''); const [sortDirection, setSortDirection] = useState(SORT_DIRECTION.ASC); - const loadExploreData = async ({ field, direction, searchQuery }: LoadExploreDataArg) => { + const getDefaultSelectedFields = () => { + const { fields } = newJobCapsService; + + if (selectedFields.length === 0 && jobConfig !== undefined) { + const { selectedFields: defaultSelected, docFields } = getDefaultFieldsFromJobCaps( + fields, + jobConfig + ); + + setSelectedFields(defaultSelected); + setDocFields(docFields); + } + }; + + const loadExploreData = async ({ + field, + direction, + searchQuery, + requiresKeyword, + }: LoadExploreDataArg) => { if (jobConfig !== undefined) { setErrorMessage(''); setStatus(INDEX_STATUS.LOADING); @@ -67,7 +82,7 @@ export const useExploreData = ( if (field !== undefined) { body.sort = [ { - [field]: { + [`${field}${requiresKeyword ? '.keyword' : ''}`]: { order: direction, }, }, @@ -91,11 +106,6 @@ export const useExploreData = ( return; } - if (selectedFields.length === 0) { - const newSelectedFields = getDefaultRegressionFields(docs, jobConfig); - setSelectedFields(newSelectedFields); - } - // Create a version of the doc's source with flattened field names. // This avoids confusion later on if a field name has dots in its name // or is a nested fields when displaying it via EuiInMemoryTable. @@ -139,11 +149,7 @@ export const useExploreData = ( useEffect(() => { if (jobConfig !== undefined) { - loadExploreData({ - field: getPredictedFieldName(jobConfig.dest.results_field, jobConfig.analysis), - direction: SORT_DIRECTION.DESC, - searchQuery: defaultSearchQuery, - }); + getDefaultSelectedFields(); } }, [jobConfig && jobConfig.id]); diff --git a/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_management/components/create_analytics_form/form_options_validation.ts b/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_management/components/create_analytics_form/form_options_validation.ts index 337d3768f2408..51982541ccc3b 100644 --- a/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_management/components/create_analytics_form/form_options_validation.ts +++ b/x-pack/legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_management/components/create_analytics_form/form_options_validation.ts @@ -7,20 +7,7 @@ import { ES_FIELD_TYPES } from '../../../../../../../../../../../src/plugins/data/public'; import { Field, EVENT_RATE_FIELD_ID } from '../../../../../../../common/types/fields'; import { JOB_TYPES, AnalyticsJobType } from '../../hooks/use_create_analytics_form/state'; - -const BASIC_NUMERICAL_TYPES = new Set([ - ES_FIELD_TYPES.LONG, - ES_FIELD_TYPES.INTEGER, - ES_FIELD_TYPES.SHORT, - ES_FIELD_TYPES.BYTE, -]); - -const EXTENDED_NUMERICAL_TYPES = new Set([ - ES_FIELD_TYPES.DOUBLE, - ES_FIELD_TYPES.FLOAT, - ES_FIELD_TYPES.HALF_FLOAT, - ES_FIELD_TYPES.SCALED_FLOAT, -]); +import { BASIC_NUMERICAL_TYPES, EXTENDED_NUMERICAL_TYPES } from '../../../../common/fields'; const CATEGORICAL_TYPES = new Set(['ip', 'keyword', 'text']); diff --git a/x-pack/legacy/plugins/ml/public/application/util/object_utils.test.ts b/x-pack/legacy/plugins/ml/public/application/util/object_utils.test.ts index ffd0adcbe542d..7ac68b41b625c 100644 --- a/x-pack/legacy/plugins/ml/public/application/util/object_utils.test.ts +++ b/x-pack/legacy/plugins/ml/public/application/util/object_utils.test.ts @@ -16,6 +16,17 @@ describe('object_utils', () => { }, }; + const falseyObj = { + the: { + nested: { + value: false, + }, + other_nested: { + value: 0, + }, + }, + }; + const test1 = getNestedProperty(testObj, 'the'); expect(typeof test1).toBe('object'); expect(Object.keys(test1)).toStrictEqual(['nested']); @@ -47,5 +58,13 @@ describe('object_utils', () => { const test9 = getNestedProperty(testObj, 'the.nested.value.doesntExist', 'the-default-value'); expect(typeof test9).toBe('string'); expect(test9).toBe('the-default-value'); + + const test10 = getNestedProperty(falseyObj, 'the.nested.value'); + expect(typeof test10).toBe('boolean'); + expect(test10).toBe(false); + + const test11 = getNestedProperty(falseyObj, 'the.other_nested.value'); + expect(typeof test11).toBe('number'); + expect(test11).toBe(0); }); }); diff --git a/x-pack/legacy/plugins/ml/public/application/util/object_utils.ts b/x-pack/legacy/plugins/ml/public/application/util/object_utils.ts index 589803b33e11c..dfdcd0959260d 100644 --- a/x-pack/legacy/plugins/ml/public/application/util/object_utils.ts +++ b/x-pack/legacy/plugins/ml/public/application/util/object_utils.ts @@ -11,5 +11,9 @@ export const getNestedProperty = ( accessor: string, defaultValue?: any ) => { - return accessor.split('.').reduce((o, i) => o?.[i], obj) || defaultValue; + const value = accessor.split('.').reduce((o, i) => o?.[i], obj); + + if (value === undefined) return defaultValue; + + return value; }; From c42d23347a901ae7b7af5855eaddc8c2972762cc Mon Sep 17 00:00:00 2001 From: Matthias Wilhelm Date: Tue, 14 Jan 2020 15:15:30 +0100 Subject: [PATCH 088/139] [Discover] Fix context view for date_nanos format with custom timestamps (#54089) * Switch from _source to fields when fetching anchor records with date_nanos timestamps * Add testdata * Add functional test --- .../np_ready/angular/context/api/context.ts | 4 +- .../api/utils/get_es_query_search_after.ts | 4 +- .../context/_date_nanos_custom_timestamp.js | 57 +++++++++++++++++++ test/functional/apps/context/index.js | 1 + .../es_archiver/date_nanos_custom/data.json | 56 ++++++++++++++++++ .../date_nanos_custom/mappings.json | 31 ++++++++++ 6 files changed, 149 insertions(+), 4 deletions(-) create mode 100644 test/functional/apps/context/_date_nanos_custom_timestamp.js create mode 100644 test/functional/fixtures/es_archiver/date_nanos_custom/data.json create mode 100644 test/functional/fixtures/es_archiver/date_nanos_custom/mappings.json diff --git a/src/legacy/core_plugins/kibana/public/discover/np_ready/angular/context/api/context.ts b/src/legacy/core_plugins/kibana/public/discover/np_ready/angular/context/api/context.ts index a6c6d91084625..6054b9f8d03c5 100644 --- a/src/legacy/core_plugins/kibana/public/discover/np_ready/angular/context/api/context.ts +++ b/src/legacy/core_plugins/kibana/public/discover/np_ready/angular/context/api/context.ts @@ -74,9 +74,9 @@ function fetchContextProvider(indexPatterns: IndexPatternsContract) { const searchSource = await createSearchSource(indexPattern, filters); const sortDirToApply = type === 'successors' ? sortDir : reverseSortDir(sortDir); - const nanos = indexPattern.isTimeNanosBased() ? extractNanos(anchor._source[timeField]) : ''; + const nanos = indexPattern.isTimeNanosBased() ? extractNanos(anchor.fields[timeField][0]) : ''; const timeValueMillis = - nanos !== '' ? convertIsoToMillis(anchor._source[timeField]) : anchor.sort[0]; + nanos !== '' ? convertIsoToMillis(anchor.fields[timeField][0]) : anchor.sort[0]; const intervals = generateIntervals(LOOKUP_OFFSETS, timeValueMillis, type, sortDir); let documents: EsHitRecordList = []; diff --git a/src/legacy/core_plugins/kibana/public/discover/np_ready/angular/context/api/utils/get_es_query_search_after.ts b/src/legacy/core_plugins/kibana/public/discover/np_ready/angular/context/api/utils/get_es_query_search_after.ts index 3f9bf255aefa9..d4ee9e0e0f287 100644 --- a/src/legacy/core_plugins/kibana/public/discover/np_ready/angular/context/api/utils/get_es_query_search_after.ts +++ b/src/legacy/core_plugins/kibana/public/discover/np_ready/angular/context/api/utils/get_es_query_search_after.ts @@ -39,14 +39,14 @@ export function getEsQuerySearchAfter( const afterTimeRecIdx = type === 'successors' && documents.length ? documents.length - 1 : 0; const afterTimeDoc = documents[afterTimeRecIdx]; const afterTimeValue = nanoSeconds - ? convertIsoToNanosAsStr(afterTimeDoc._source[timeFieldName]) + ? convertIsoToNanosAsStr(afterTimeDoc.fields[timeFieldName][0]) : afterTimeDoc.sort[0]; return [afterTimeValue, afterTimeDoc.sort[1]]; } // if data_nanos adapt timestamp value for sorting, since numeric value was rounded by browser // ES search_after also works when number is provided as string return [ - nanoSeconds ? convertIsoToNanosAsStr(anchor._source[timeFieldName]) : anchor.sort[0], + nanoSeconds ? convertIsoToNanosAsStr(anchor.fields[timeFieldName][0]) : anchor.sort[0], anchor.sort[1], ]; } diff --git a/test/functional/apps/context/_date_nanos_custom_timestamp.js b/test/functional/apps/context/_date_nanos_custom_timestamp.js new file mode 100644 index 0000000000000..3901fa936e719 --- /dev/null +++ b/test/functional/apps/context/_date_nanos_custom_timestamp.js @@ -0,0 +1,57 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +import expect from '@kbn/expect'; + +const TEST_INDEX_PATTERN = 'date_nanos_custom_timestamp'; +const TEST_DEFAULT_CONTEXT_SIZE = 1; +const TEST_STEP_SIZE = 3; + +export default function({ getService, getPageObjects }) { + const kibanaServer = getService('kibanaServer'); + const docTable = getService('docTable'); + const PageObjects = getPageObjects(['common', 'context', 'timePicker', 'discover']); + const esArchiver = getService('esArchiver'); + + describe('context view for date_nanos with custom timestamp', () => { + before(async function() { + await esArchiver.loadIfNeeded('date_nanos_custom'); + await kibanaServer.uiSettings.replace({ defaultIndex: TEST_INDEX_PATTERN }); + await kibanaServer.uiSettings.update({ + 'context:defaultSize': `${TEST_DEFAULT_CONTEXT_SIZE}`, + 'context:step': `${TEST_STEP_SIZE}`, + }); + }); + + after(function unloadMakelogs() { + return esArchiver.unload('date_nanos_custom'); + }); + + it('displays predessors - anchor - successors in right order ', async function() { + await PageObjects.context.navigateTo(TEST_INDEX_PATTERN, '1'); + const actualRowsText = await docTable.getRowsText(); + const expectedRowsText = [ + 'Oct 21, 2019 @ 08:30:04.828733000 -', + 'Oct 21, 2019 @ 00:30:04.828740000 -', + 'Oct 21, 2019 @ 00:30:04.828723000 -', + ]; + expect(actualRowsText).to.eql(expectedRowsText); + }); + }); +} diff --git a/test/functional/apps/context/index.js b/test/functional/apps/context/index.js index 9e1b04ad45874..c3c938c623731 100644 --- a/test/functional/apps/context/index.js +++ b/test/functional/apps/context/index.js @@ -42,5 +42,6 @@ export default function({ getService, getPageObjects, loadTestFile }) { loadTestFile(require.resolve('./_filters')); loadTestFile(require.resolve('./_size')); loadTestFile(require.resolve('./_date_nanos')); + loadTestFile(require.resolve('./_date_nanos_custom_timestamp')); }); } diff --git a/test/functional/fixtures/es_archiver/date_nanos_custom/data.json b/test/functional/fixtures/es_archiver/date_nanos_custom/data.json new file mode 100644 index 0000000000000..73cba70a8b93d --- /dev/null +++ b/test/functional/fixtures/es_archiver/date_nanos_custom/data.json @@ -0,0 +1,56 @@ +{ + "type": "doc", + "value": { + "id": "index-pattern:date_nanos_custom_timestamp", + "index": ".kibana", + "source": { + "index-pattern": { + "fields": "[{\"name\":\"_id\",\"type\":\"string\",\"esTypes\":[\"_id\"],\"count\":0,\"scripted\":false,\"searchable\":true,\"aggregatable\":true,\"readFromDocValues\":false},{\"name\":\"_index\",\"type\":\"string\",\"esTypes\":[\"_index\"],\"count\":0,\"scripted\":false,\"searchable\":true,\"aggregatable\":true,\"readFromDocValues\":false},{\"name\":\"_score\",\"type\":\"number\",\"count\":0,\"scripted\":false,\"searchable\":false,\"aggregatable\":false,\"readFromDocValues\":false},{\"name\":\"_source\",\"type\":\"_source\",\"esTypes\":[\"_source\"],\"count\":0,\"scripted\":false,\"searchable\":false,\"aggregatable\":false,\"readFromDocValues\":false},{\"name\":\"_type\",\"type\":\"string\",\"esTypes\":[\"_type\"],\"count\":0,\"scripted\":false,\"searchable\":true,\"aggregatable\":true,\"readFromDocValues\":false},{\"name\":\"test\",\"type\":\"string\",\"esTypes\":[\"text\"],\"count\":0,\"scripted\":false,\"searchable\":true,\"aggregatable\":false,\"readFromDocValues\":false},{\"name\":\"test.keyword\",\"type\":\"string\",\"esTypes\":[\"keyword\"],\"count\":0,\"scripted\":false,\"searchable\":true,\"aggregatable\":true,\"readFromDocValues\":true,\"subType\":{\"multi\":{\"parent\":\"test\"}}},{\"name\":\"timestamp\",\"type\":\"date\",\"esTypes\":[\"date_nanos\"],\"count\":0,\"scripted\":false,\"searchable\":true,\"aggregatable\":true,\"readFromDocValues\":true}]", + "timeFieldName": "timestamp", + "title": "date_nanos_custom_timestamp" + }, + "references": [ + ], + "type": "index-pattern", + "updated_at": "2020-01-09T21:43:20.283Z" + } + } +} + +{ + "type": "doc", + "value": { + "id": "1", + "index": "date_nanos_custom_timestamp", + "source": { + "test": "1", + "timestamp": "2019-10-21 00:30:04.828740" + } + } +} + +{ + "type": "doc", + "value": { + "id": "2", + "index": "date_nanos_custom_timestamp", + "source": { + "test": "1", + "timestamp": "2019-10-21 08:30:04.828733" + } + } +} + +{ + "type": "doc", + "value": { + "id": "3", + "index": "date_nanos_custom_timestamp", + "source": { + "test": "1", + "timestamp": "2019-10-21 00:30:04.828723" + } + } +} + + diff --git a/test/functional/fixtures/es_archiver/date_nanos_custom/mappings.json b/test/functional/fixtures/es_archiver/date_nanos_custom/mappings.json new file mode 100644 index 0000000000000..98af509c4e6f2 --- /dev/null +++ b/test/functional/fixtures/es_archiver/date_nanos_custom/mappings.json @@ -0,0 +1,31 @@ +{ + "type": "index", + "value": { + "aliases": { + }, + "index": "date_nanos_custom_timestamp", + "mappings": { + "properties": { + "test": { + "fields": { + "keyword": { + "ignore_above": 256, + "type": "keyword" + } + }, + "type": "text" + }, + "timestamp": { + "format": "yyyy-MM-dd HH:mm:ss.SSSSSS", + "type": "date_nanos" + } + } + }, + "settings": { + "index": { + "number_of_replicas": "1", + "number_of_shards": "1" + } + } + } +} From 038c2b1ce36aa2c991fb5726a44b45d03e139c5a Mon Sep 17 00:00:00 2001 From: Shahzad Date: Tue, 14 Jan 2020 15:18:07 +0100 Subject: [PATCH 089/139] [Uptime] Fix Jest test with absolute time (#54684) * fix test * update more skipped tests * update test --- .../location_status_tags.test.tsx.snap | 32 +++++----- .../__tests__/location_status_tags.test.tsx | 59 ++++++++++++------- .../status_by_location.test.tsx.snap | 17 ++++++ .../__test__/status_by_location.test.tsx | 26 +++++--- 4 files changed, 88 insertions(+), 46 deletions(-) diff --git a/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/__snapshots__/location_status_tags.test.tsx.snap b/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/__snapshots__/location_status_tags.test.tsx.snap index 6228183e7c2b2..1547bc781acdc 100644 --- a/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/__snapshots__/location_status_tags.test.tsx.snap +++ b/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/__snapshots__/location_status_tags.test.tsx.snap @@ -1,6 +1,6 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`StatusByLocation component renders when all locations are down 1`] = ` +exports[`LocationStatusTags component renders when all locations are down 1`] = ` .c3 { display: inline-block; margin-left: 4px; @@ -58,7 +58,7 @@ exports[`StatusByLocation component renders when all locations are down 1`] = `
- 3d ago + 5s ago
@@ -97,7 +97,7 @@ exports[`StatusByLocation component renders when all locations are down 1`] = `
- 3d ago + 5m ago
@@ -107,7 +107,7 @@ exports[`StatusByLocation component renders when all locations are down 1`] = ` `; -exports[`StatusByLocation component renders when all locations are up 1`] = ` +exports[`LocationStatusTags component renders when all locations are up 1`] = ` .c3 { display: inline-block; margin-left: 4px; @@ -166,7 +166,7 @@ exports[`StatusByLocation component renders when all locations are up 1`] = `
- 3d ago + 5s ago
@@ -205,7 +205,7 @@ exports[`StatusByLocation component renders when all locations are up 1`] = `
- 3d ago + 5d ago
@@ -214,7 +214,7 @@ exports[`StatusByLocation component renders when all locations are up 1`] = ` `; -exports[`StatusByLocation component renders when there are many location 1`] = ` +exports[`LocationStatusTags component renders when there are many location 1`] = ` Array [ .c3 { display: inline-block; @@ -273,7 +273,7 @@ Array [
- 3d ago + 5s ago
@@ -312,7 +312,7 @@ Array [
- 3d ago + 5m ago
@@ -351,7 +351,7 @@ Array [
- 3d ago + 5h ago
@@ -375,7 +375,7 @@ Array [
- Tokya + Tokyo
@@ -390,7 +390,7 @@ Array [
- 3d ago + 5d ago
@@ -429,7 +429,7 @@ Array [
- 3d ago + 1 Mon ago
@@ -468,7 +468,7 @@ Array [
- 3d ago + 5 Mon ago
@@ -507,7 +507,7 @@ Array [
- 3d ago + 5 Yr ago
@@ -546,7 +546,7 @@ Array [
- 3d ago + 5 Yr ago
diff --git a/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/location_status_tags.test.tsx b/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/location_status_tags.test.tsx index de04347148bb2..d3e126a074686 100644 --- a/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/location_status_tags.test.tsx +++ b/x-pack/legacy/plugins/uptime/public/components/functional/location_map/__tests__/location_status_tags.test.tsx @@ -10,57 +10,66 @@ import { renderWithIntl } from 'test_utils/enzyme_helpers'; import { MonitorLocation } from '../../../../../common/runtime_types/monitor'; import { LocationStatusTags } from '../'; -// These tests use absolute time -// Failing: https://github.com/elastic/kibana/issues/54672 -describe.skip('StatusByLocation component', () => { +describe('LocationStatusTags component', () => { let monitorLocations: MonitorLocation[]; - const start = moment('2020-01-10T12:22:32.567Z'); - beforeAll(() => { - moment.prototype.fromNow = jest.fn((date: string) => start.from(date)); - }); - it('renders when there are many location', () => { monitorLocations = [ { summary: { up: 0, down: 1 }, geo: { name: 'Islamabad', location: { lat: '52.487448', lon: ' 13.394798' } }, - timestamp: '2020-01-09T12:22:32.567Z', + timestamp: moment() + .subtract('5', 's') + .toISOString(), }, { summary: { up: 0, down: 1 }, geo: { name: 'Berlin', location: { lat: '52.487448', lon: ' 13.394798' } }, - timestamp: '2020-01-09T12:22:28.825Z', + timestamp: moment() + .subtract('5', 'm') + .toISOString(), }, { summary: { up: 0, down: 1 }, geo: { name: 'st-paul', location: { lat: '52.487448', lon: ' 13.394798' } }, - timestamp: '2020-01-09T12:22:31.586Z', + timestamp: moment() + .subtract('5', 'h') + .toISOString(), }, { summary: { up: 0, down: 1 }, - geo: { name: 'Tokya', location: { lat: '52.487448', lon: ' 13.394798' } }, - timestamp: '2020-01-09T12:22:25.771Z', + geo: { name: 'Tokyo', location: { lat: '52.487448', lon: ' 13.394798' } }, + timestamp: moment() + .subtract('5', 'd') + .toISOString(), }, { summary: { up: 0, down: 1 }, geo: { name: 'New York', location: { lat: '52.487448', lon: ' 13.394798' } }, - timestamp: '2020-01-09T12:22:27.485Z', + timestamp: moment() + .subtract('5', 'w') + .toISOString(), }, { summary: { up: 0, down: 1 }, geo: { name: 'Toronto', location: { lat: '52.487448', lon: ' 13.394798' } }, - timestamp: '2020-01-09T12:22:28.815Z', + timestamp: moment() + .subtract('5', 'M') + .toISOString(), }, { summary: { up: 0, down: 1 }, geo: { name: 'Sydney', location: { lat: '52.487448', lon: ' 13.394798' } }, - timestamp: '2020-01-09T12:22:32.132Z', + timestamp: moment() + .subtract('5', 'y') + .toISOString(), }, { summary: { up: 0, down: 1 }, geo: { name: 'Paris', location: { lat: '52.487448', lon: ' 13.394798' } }, - timestamp: '2020-01-09T12:22:32.973Z', + timestamp: moment() + .subtract('5', 'y') + .toISOString(), }, ]; const component = renderWithIntl(); @@ -72,12 +81,16 @@ describe.skip('StatusByLocation component', () => { { summary: { up: 4, down: 0 }, geo: { name: 'Islamabad', location: { lat: '52.487448', lon: ' 13.394798' } }, - timestamp: '2020-01-09T12:22:32.567Z', + timestamp: moment() + .subtract('5', 's') + .toISOString(), }, { summary: { up: 4, down: 0 }, geo: { name: 'Berlin', location: { lat: '52.487448', lon: ' 13.394798' } }, - timestamp: '2020-01-08T12:22:28.825Z', + timestamp: moment() + .subtract('5', 'd') + .toISOString(), }, ]; const component = renderWithIntl(); @@ -89,12 +102,16 @@ describe.skip('StatusByLocation component', () => { { summary: { up: 0, down: 2 }, geo: { name: 'Islamabad', location: { lat: '52.487448', lon: ' 13.394798' } }, - timestamp: '2020-01-06T12:22:32.567Z', + timestamp: moment() + .subtract('5', 's') + .toISOString(), }, { summary: { up: 0, down: 2 }, geo: { name: 'Berlin', location: { lat: '52.487448', lon: ' 13.394798' } }, - timestamp: '2020-01-09T12:22:28.825Z', + timestamp: moment() + .subtract('5', 'm') + .toISOString(), }, ]; const component = renderWithIntl(); diff --git a/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/__test__/__snapshots__/status_by_location.test.tsx.snap b/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/__test__/__snapshots__/status_by_location.test.tsx.snap index c6b18501ffa0f..b98da10f78729 100644 --- a/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/__test__/__snapshots__/status_by_location.test.tsx.snap +++ b/x-pack/legacy/plugins/uptime/public/components/functional/monitor_status_details/__test__/__snapshots__/status_by_location.test.tsx.snap @@ -10,6 +10,23 @@ exports[`StatusByLocation component renders all locations are down 1`] = ` `; +exports[`StatusByLocation component renders properly against props 1`] = ` + +

+ +

+
+`; + exports[`StatusByLocation component renders when down in some locations 1`] = `
{ +describe('StatusByLocation component', () => { let monitorLocations: MonitorLocation[]; + it('renders properly against props', () => { + monitorLocations = [ + { + summary: { up: 4, down: 0 }, + geo: { name: 'Berlin', location: { lat: '52.487448', lon: ' 13.394798' } }, + }, + { + summary: { up: 4, down: 0 }, + geo: { name: 'st-paul', location: { lat: '52.487448', lon: ' 13.394798' } }, + }, + ]; + const component = shallowWithIntl(); + expect(component).toMatchSnapshot(); + }); + it('renders when up in all locations', () => { monitorLocations = [ { summary: { up: 4, down: 0 }, geo: { name: 'Berlin', location: { lat: '52.487448', lon: ' 13.394798' } }, - timestamp: '2020-01-09T12:22:32.567Z', }, { summary: { up: 4, down: 0 }, @@ -33,7 +47,6 @@ describe.skip('StatusByLocation component', () => { { summary: { up: 4, down: 0 }, geo: { name: 'Berlin', location: { lat: '52.487448', lon: ' 13.394798' } }, - timestamp: '2020-01-09T12:22:32.567Z', }, ]; const component = renderWithIntl(); @@ -45,7 +58,6 @@ describe.skip('StatusByLocation component', () => { { summary: { up: 0, down: 4 }, geo: { name: 'Berlin', location: { lat: '52.487448', lon: ' 13.394798' } }, - timestamp: '2020-01-09T12:22:32.567Z', }, ]; const component = renderWithIntl(); @@ -57,12 +69,10 @@ describe.skip('StatusByLocation component', () => { { summary: { up: 0, down: 4 }, geo: { name: 'Berlin', location: { lat: '52.487448', lon: ' 13.394798' } }, - timestamp: '2020-01-09T12:22:32.567Z', }, { summary: { up: 0, down: 4 }, geo: { name: 'st-paul', location: { lat: '52.487448', lon: ' 13.394798' } }, - timestamp: '2020-01-09T12:22:32.567Z', }, ]; const component = renderWithIntl(); @@ -74,12 +84,10 @@ describe.skip('StatusByLocation component', () => { { summary: { up: 0, down: 4 }, geo: { name: 'Berlin', location: { lat: '52.487448', lon: ' 13.394798' } }, - timestamp: '2020-01-09T12:22:32.567Z', }, { summary: { up: 4, down: 0 }, geo: { name: 'st-paul', location: { lat: '52.487448', lon: ' 13.394798' } }, - timestamp: '2020-01-09T12:22:32.567Z', }, ]; const component = renderWithIntl(); From 824a3822385a1d537b819957c5c9747cf636340c Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Tue, 14 Jan 2020 09:15:44 -0500 Subject: [PATCH 090/139] add feedback feedback feedback --- .../components/color/color_map_select.js | 17 +-- .../vector/components/color/color_stops.js | 62 +++++++++- .../color/color_stops_categorical.js | 6 +- .../components/color/color_stops_utils.js | 109 ++++-------------- 4 files changed, 91 insertions(+), 103 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js index 8149e9b5c58a9..62b3ea0c3fcd6 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js @@ -31,11 +31,9 @@ export class ColorMapSelect extends Component { _onColorMapSelect = selectedValue => { const useCustomColorMap = selectedValue === CUSTOM_COLOR_MAP; - const newProps = { useCustomColorMap }; - newProps.color = useCustomColorMap ? null : selectedValue; - this.props.onChange({ - ...newProps, + color: useCustomColorMap ? null : selectedValue, + useCustomColorMap, type: this.props.colorMapType, }); }; @@ -50,12 +48,11 @@ export class ColorMapSelect extends Component { return; } - const newProps = { + this.props.onChange({ useCustomColorMap: true, customColorMap: colorStops, type: this.props.colorMapType, - }; - this.props.onChange(newProps); + }); }; componentDidMount() { @@ -90,7 +87,7 @@ export class ColorMapSelect extends Component { } } - render() { + _renderColorStopsInput() { let colorStopsInput; if (this.props.useCustomColorMap) { if (this.props.colorMapType === COLOR_MAP_TYPE.ORDINAL) { @@ -115,7 +112,11 @@ export class ColorMapSelect extends Component { ); } } + return colorStopsInput; + } + render() { + const colorStopsInput = this._renderColorStopsInput(); const colorMapOptionsWithCustom = [ { value: CUSTOM_COLOR_MAP, diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops.js index 9b0f9695bfdfb..6b403ff61532d 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops.js @@ -6,7 +6,54 @@ import _ from 'lodash'; import React from 'react'; -import { removeRow, getColorInput, getDeleteButton, getColorStopRow } from './color_stops_utils'; +import { removeRow, isColorInvalid } from './color_stops_utils'; +import { i18n } from '@kbn/i18n'; +import { EuiButtonIcon, EuiColorPicker, EuiFlexGroup, EuiFlexItem, EuiFormRow } from '@elastic/eui'; + +function getColorStopRow({ index, errors, stopInput, colorInput, deleteButton, onAdd }) { + return ( + +
+ + {stopInput} + {colorInput} + +
+ {deleteButton} + +
+
+
+ ); +} + +export function getDeleteButton(onRemove) { + return ( + + ); +} export const ColorStops = ({ onChange, @@ -36,6 +83,17 @@ export const ColorStops = ({ }; } + function getColorInput(onColorChange, color) { + return { + colorError: isColorInvalid(color) + ? i18n.translate('xpack.maps.styles.colorStops.hexWarningLabel', { + defaultMessage: 'Color must provide a valid hex value', + }) + : undefined, + colorInput: , + }; + } + const rows = colorStops.map((colorStop, index) => { const onColorChange = color => { const newColorStops = _.cloneDeep(colorStops); @@ -47,7 +105,7 @@ export const ColorStops = ({ }; const { stopError, stopInput } = getStopInput(colorStop.stop, index); - const { colorError, colorInput } = getColorInput(colorStops, onColorChange, colorStop.color); + const { colorError, colorInput } = getColorInput(onColorChange, colorStop.color); const errors = []; if (stopError) { errors.push(stopError); diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js index 8f116c3a94aa3..9adc2fdfcaaef 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_categorical.js @@ -45,9 +45,8 @@ export const ColorStopsCategorical = ({ }; const renderStopInput = (stop, onStopChange, index) => { - let stopInput; if (index === 0) { - stopInput = ( + return ( ); } else { - stopInput = ( + return ( ); } - return stopInput; }; const canDeleteStop = (colorStops, index) => { diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js index 611791673c8d3..3eaa6acf435dc 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_stops_utils.js @@ -4,16 +4,7 @@ * you may not use this file except in compliance with the Elastic License. */ -import { - EuiButtonIcon, - EuiColorPicker, - EuiFlexGroup, - EuiFlexItem, - EuiFormRow, - isValidHex, -} from '@elastic/eui'; -import React from 'react'; -import { COLOR_MAP_TYPE } from '../../../../../../common/constants'; +import { isValidHex } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; import _ from 'lodash'; @@ -29,34 +20,30 @@ export function removeRow(colorStops, index) { } export function addOrdinalRow(colorStops, index) { - return addRow(colorStops, index, COLOR_MAP_TYPE.ORDINAL); + const currentStop = colorStops[index].stop; + let delta = 1; + if (index === colorStops.length - 1) { + // Adding row to end of list. + if (index !== 0) { + const prevStop = colorStops[index - 1].stop; + delta = currentStop - prevStop; + } + } else { + // Adding row in middle of list. + const nextStop = colorStops[index + 1].stop; + delta = (nextStop - currentStop) / 2; + } + const nextValue = currentStop + delta; + return addRow(colorStops, index, nextValue); } export function addCategoricalRow(colorStops, index) { - return addRow(colorStops, index, COLOR_MAP_TYPE.CATEGORICAL); -} - -export function addRow(colorStops, index, colorMapType) { const currentStop = colorStops[index].stop; + const nextValue = currentStop === '' ? currentStop + 'a' : ''; + return addRow(colorStops, index, nextValue); +} - let nextValue; - if (colorMapType === COLOR_MAP_TYPE.ORDINAL) { - let delta = 1; - if (index === colorStops.length - 1) { - // Adding row to end of list. - if (index !== 0) { - const prevStop = colorStops[index - 1].stop; - delta = currentStop - prevStop; - } - } else { - // Adding row in middle of list. - const nextStop = colorStops[index + 1].stop; - delta = (nextStop - currentStop) / 2; - } - nextValue = currentStop + delta; - } else { - nextValue = currentStop === '' ? currentStop + 'a' : ''; - } +function addRow(colorStops, index, nextValue) { const newRow = { stop: nextValue, color: DEFAULT_CUSTOM_COLOR, @@ -64,62 +51,6 @@ export function addRow(colorStops, index, colorMapType) { return [...colorStops.slice(0, index + 1), newRow, ...colorStops.slice(index + 1)]; } -export function getDeleteButton(onRemove) { - return ( - - ); -} - -export function getColorInput(colorStops, onColorChange, color) { - return { - colorError: isColorInvalid(color) - ? i18n.translate('xpack.maps.styles.colorStops.hexWarningLabel', { - defaultMessage: 'Color must provide a valid hex value', - }) - : undefined, - colorInput: , - }; -} - -export function getColorStopRow({ index, errors, stopInput, colorInput, deleteButton, onAdd }) { - return ( - -
- - {stopInput} - {colorInput} - -
- {deleteButton} - -
-
-
- ); -} - export function isColorInvalid(color) { return !isValidHex(color) || color === ''; } From b7f37822a28ce138b9670ce288f9501512830f58 Mon Sep 17 00:00:00 2001 From: Vadim Dalecky Date: Tue, 14 Jan 2020 06:32:08 -0800 Subject: [PATCH 091/139] =?UTF-8?q?test:=20=F0=9F=92=8D=20re-enable=20Dash?= =?UTF-8?q?board=20sample=20data=20functional=20tests=20(#54717)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Closes: #40670 --- .../home/{_sample_data.js => _sample_data.ts} | 14 +++++++++----- test/functional/page_objects/home_page.ts | 19 ++++++++----------- 2 files changed, 17 insertions(+), 16 deletions(-) rename test/functional/apps/home/{_sample_data.js => _sample_data.ts} (94%) diff --git a/test/functional/apps/home/_sample_data.js b/test/functional/apps/home/_sample_data.ts similarity index 94% rename from test/functional/apps/home/_sample_data.js rename to test/functional/apps/home/_sample_data.ts index 4aa862a4a0384..8088b5a0f9da9 100644 --- a/test/functional/apps/home/_sample_data.js +++ b/test/functional/apps/home/_sample_data.ts @@ -19,8 +19,9 @@ import expect from '@kbn/expect'; import moment from 'moment'; +import { FtrProviderContext } from '../../ftr_provider_context'; -export default function({ getService, getPageObjects }) { +export default function({ getService, getPageObjects }: FtrProviderContext) { const retry = getService('retry'); const find = getService('find'); const log = getService('log'); @@ -76,9 +77,8 @@ export default function({ getService, getPageObjects }) { expect(isInstalled).to.be(true); }); - // FLAKY: https://github.com/elastic/kibana/issues/40670 - describe.skip('dashboard', () => { - afterEach(async () => { + describe('dashboard', () => { + beforeEach(async () => { await PageObjects.common.navigateToUrl('home', 'tutorial_directory/sampleData'); await PageObjects.header.waitUntilLoadingHasFinished(); }); @@ -99,7 +99,6 @@ export default function({ getService, getPageObjects }) { await PageObjects.home.launchSampleDataSet('flights'); await PageObjects.header.waitUntilLoadingHasFinished(); await renderable.waitForRender(); - log.debug('Checking pie charts rendered'); await pieChart.expectPieSliceCount(4); log.debug('Checking area, bar and heatmap charts rendered'); @@ -142,6 +141,11 @@ export default function({ getService, getPageObjects }) { // needs to be in describe block so it is run after 'dashboard describe block' describe('uninstall', () => { + beforeEach(async () => { + await PageObjects.common.navigateToUrl('home', 'tutorial_directory/sampleData'); + await PageObjects.header.waitUntilLoadingHasFinished(); + }); + it('should uninstall flights sample data set', async () => { await PageObjects.home.removeSampleDataSet('flights'); const isInstalled = await PageObjects.home.isSampleDataSetInstalled('flights'); diff --git a/test/functional/page_objects/home_page.ts b/test/functional/page_objects/home_page.ts index cf9eb4332c3e1..a641fbda023c3 100644 --- a/test/functional/page_objects/home_page.ts +++ b/test/functional/page_objects/home_page.ts @@ -22,7 +22,6 @@ import { FtrProviderContext } from '../ftr_provider_context'; export function HomePageProvider({ getService }: FtrProviderContext) { const testSubjects = getService('testSubjects'); const retry = getService('retry'); - const find = getService('find'); class HomePage { async clickSynopsis(title: string) { @@ -38,12 +37,15 @@ export function HomePageProvider({ getService }: FtrProviderContext) { } async isSampleDataSetInstalled(id: string) { - return await testSubjects.exists(`removeSampleDataSet${id}`); + return !(await testSubjects.exists(`addSampleDataSet${id}`)); } async addSampleDataSet(id: string) { - await testSubjects.click(`addSampleDataSet${id}`); - await this._waitForSampleDataLoadingAction(id); + const isInstalled = await this.isSampleDataSetInstalled(id); + if (!isInstalled) { + await testSubjects.click(`addSampleDataSet${id}`); + await this._waitForSampleDataLoadingAction(id); + } } async removeSampleDataSet(id: string) { @@ -62,13 +64,8 @@ export function HomePageProvider({ getService }: FtrProviderContext) { } async launchSampleDataSet(id: string) { - if (await find.existsByCssSelector(`#sampleDataLinks${id}`)) { - // omits cloud test failures - await find.clickByCssSelectorWhenNotDisabled(`#sampleDataLinks${id}`); - await find.clickByCssSelector('.euiContextMenuItem:nth-of-type(1)'); - } else { - await testSubjects.click(`launchSampleDataSet${id}`); - } + await this.addSampleDataSet(id); + await testSubjects.click(`launchSampleDataSet${id}`); } async loadSavedObjects() { From 2927373f8bd33af8fb59c76c03675402f1e78ec8 Mon Sep 17 00:00:00 2001 From: Phillip Burch Date: Tue, 14 Jan 2020 08:46:49 -0600 Subject: [PATCH 092/139] Add aria labels to fields (#54510) Co-authored-by: Elastic Machine --- .../public/components/metrics_explorer/aggregation.tsx | 9 ++++++--- .../public/components/metrics_explorer/group_by.tsx | 3 +++ .../public/components/metrics_explorer/kuery_bar.tsx | 9 ++++++--- .../infra/public/components/metrics_explorer/metrics.tsx | 1 + 4 files changed, 16 insertions(+), 6 deletions(-) diff --git a/x-pack/legacy/plugins/infra/public/components/metrics_explorer/aggregation.tsx b/x-pack/legacy/plugins/infra/public/components/metrics_explorer/aggregation.tsx index 3550cfc9e03ee..2abc03d6ea9b9 100644 --- a/x-pack/legacy/plugins/infra/public/components/metrics_explorer/aggregation.tsx +++ b/x-pack/legacy/plugins/infra/public/components/metrics_explorer/aggregation.tsx @@ -52,11 +52,14 @@ export const MetricsExplorerAggregationPicker = ({ options, onChange }: Props) = [onChange] ); + const placeholder = i18n.translate('xpack.infra.metricsExplorer.aggregationSelectLabel', { + defaultMessage: 'Select an aggregation', + }); + return ( ({ diff --git a/x-pack/legacy/plugins/infra/public/components/metrics_explorer/group_by.tsx b/x-pack/legacy/plugins/infra/public/components/metrics_explorer/group_by.tsx index 505966e62e45f..750894fd0188b 100644 --- a/x-pack/legacy/plugins/infra/public/components/metrics_explorer/group_by.tsx +++ b/x-pack/legacy/plugins/infra/public/components/metrics_explorer/group_by.tsx @@ -44,6 +44,9 @@ export const MetricsExplorerGroupBy = ({ options, onChange, fields }: Props) => placeholder={i18n.translate('xpack.infra.metricsExplorer.groupByLabel', { defaultMessage: 'Everything', })} + aria-label={i18n.translate('xpack.infra.metricsExplorer.groupByAriaLabel', { + defaultMessage: 'Graph per', + })} fullWidth singleSelection={true} selectedOptions={(options.groupBy && [{ label: options.groupBy }]) || []} diff --git a/x-pack/legacy/plugins/infra/public/components/metrics_explorer/kuery_bar.tsx b/x-pack/legacy/plugins/infra/public/components/metrics_explorer/kuery_bar.tsx index f1957c1fa91a7..7114217920998 100644 --- a/x-pack/legacy/plugins/infra/public/components/metrics_explorer/kuery_bar.tsx +++ b/x-pack/legacy/plugins/infra/public/components/metrics_explorer/kuery_bar.tsx @@ -48,18 +48,21 @@ export const MetricsExplorerKueryBar = ({ derivedIndexPattern, onSubmit, value } fields: derivedIndexPattern.fields.filter(field => isDisplayable(field)), }; + const placeholder = i18n.translate('xpack.infra.homePage.toolbar.kqlSearchFieldPlaceholder', { + defaultMessage: 'Search for infrastructure data… (e.g. host.name:host-1)', + }); + return ( {({ isLoadingSuggestions, loadSuggestions, suggestions }) => ( diff --git a/x-pack/legacy/plugins/infra/public/components/metrics_explorer/metrics.tsx b/x-pack/legacy/plugins/infra/public/components/metrics_explorer/metrics.tsx index 7a8b22467ccd8..0010fce7efa49 100644 --- a/x-pack/legacy/plugins/infra/public/components/metrics_explorer/metrics.tsx +++ b/x-pack/legacy/plugins/infra/public/components/metrics_explorer/metrics.tsx @@ -71,6 +71,7 @@ export const MetricsExplorerMetrics = ({ options, onChange, fields, autoFocus = return ( Date: Tue, 14 Jan 2020 17:03:58 +0200 Subject: [PATCH 093/139] [i18n] integrate translation files ja and zh (#54722) --- .../translations/translations/ja-JP.json | 19913 +++++++-------- .../translations/translations/zh-CN.json | 19989 ++++++++-------- 2 files changed, 20487 insertions(+), 19415 deletions(-) diff --git a/x-pack/plugins/translations/translations/ja-JP.json b/x-pack/plugins/translations/translations/ja-JP.json index 5661020ba6fa6..ca49aea3ee885 100644 --- a/x-pack/plugins/translations/translations/ja-JP.json +++ b/x-pack/plugins/translations/translations/ja-JP.json @@ -84,13 +84,13 @@ "common.ui.aggTypes.aggregateWithLabel": "アグリゲーション:", "common.ui.aggTypes.aggregateWithTooltip": "複数ヒットまたは複数値のフィールドを 1 つのメトリックにまとめる方法を選択します。", "common.ui.aggTypes.buckets.dateHistogramLabel": "{intervalDescription}ごとの {fieldName}", - "common.ui.aggTypes.buckets.dateHistogramTitle": "Date Histogram", + "common.ui.aggTypes.buckets.dateHistogramTitle": "日付ヒストグラム", "common.ui.aggTypes.buckets.dateRangeTitle": "日付範囲", "common.ui.aggTypes.buckets.filtersTitle": "フィルター", "common.ui.aggTypes.buckets.filterTitle": "フィルター", "common.ui.aggTypes.buckets.geohashGridTitle": "ジオハッシュ", "common.ui.aggTypes.buckets.geotileGridTitle": "ジオタイル", - "common.ui.aggTypes.buckets.histogramTitle": "Histogram", + "common.ui.aggTypes.buckets.histogramTitle": "ヒストグラム", "common.ui.aggTypes.buckets.intervalOptions.autoDisplayName": "自動", "common.ui.aggTypes.buckets.intervalOptions.dailyDisplayName": "日ごと", "common.ui.aggTypes.buckets.intervalOptions.hourlyDisplayName": "1 時間ごと", @@ -102,12 +102,13 @@ "common.ui.aggTypes.buckets.intervalOptions.yearlyDisplayName": "1 年ごと", "common.ui.aggTypes.buckets.ipRangeLabel": "{fieldName} IP 範囲", "common.ui.aggTypes.buckets.ipRangeTitle": "IPv4 範囲", + "common.ui.aggTypes.buckets.ranges.rangesFormatMessage": "{gte} {from} と {lt} {to}", "common.ui.aggTypes.buckets.rangesLabel": "{fieldName} の範囲", "common.ui.aggTypes.buckets.rangeTitle": "範囲", "common.ui.aggTypes.buckets.significantTerms.excludeLabel": "除外", "common.ui.aggTypes.buckets.significantTerms.includeLabel": "含める", "common.ui.aggTypes.buckets.significantTermsLabel": "{fieldName} のトップ {size} の珍しいアイテム", - "common.ui.aggTypes.buckets.significantTermsTitle": "Significant Terms", + "common.ui.aggTypes.buckets.significantTermsTitle": "重要な用語", "common.ui.aggTypes.buckets.terms.excludeLabel": "除外", "common.ui.aggTypes.buckets.terms.includeLabel": "含める", "common.ui.aggTypes.buckets.terms.missingBucketLabel": "欠測値", @@ -121,9 +122,10 @@ "common.ui.aggTypes.customMetricLabel": "カスタムメトリック", "common.ui.aggTypes.dateRanges.acceptedDateFormatsLinkText": "対応データフォーマット", "common.ui.aggTypes.dateRanges.addRangeButtonLabel": "範囲を追加", + "common.ui.aggTypes.dateRanges.errorMessage": "各範囲は1つ以上の有効な日付にしてください。", "common.ui.aggTypes.dateRanges.fromColumnLabel": "From", + "common.ui.aggTypes.dateRanges.removeRangeButtonAriaLabel": "{from}から{to}の範囲を削除", "common.ui.aggTypes.dateRanges.toColumnLabel": "To", - "common.ui.aggTypes.definiteMetricLabel": "メトリック: {metric}", "common.ui.aggTypes.dropPartialBucketsLabel": "不完全なバケットをドロップ", "common.ui.aggTypes.dropPartialBucketsTooltip": "時間範囲外にわたるバケットを削除してヒストグラムが不完全なバケットで開始・終了しないようにします。", "common.ui.aggTypes.extendedBounds.errorMessage": "最低値は最大値以下でなければなりません。", @@ -193,8 +195,8 @@ "common.ui.aggTypes.metrics.percentiles.valuePropsLabel": "{label} の {percentile} パーセンタイル", "common.ui.aggTypes.metrics.percentilesLabel": "{field} のパーセンタイル", "common.ui.aggTypes.metrics.percentilesTitle": "パーセンタイル", - "common.ui.aggTypes.metrics.serialDiffLabel": "serial diff", - "common.ui.aggTypes.metrics.serialDiffTitle": "Serial Diff", + "common.ui.aggTypes.metrics.serialDiffLabel": "差分の推移", + "common.ui.aggTypes.metrics.serialDiffTitle": "差分の推移", "common.ui.aggTypes.metrics.siblingPipelineAggregationsSubtypeTitle": "シブリングパイプラインアグリゲーション", "common.ui.aggTypes.metrics.standardDeviation.keyDetailsLabel": "{fieldDisplayName} の標準偏差", "common.ui.aggTypes.metrics.standardDeviation.lowerKeyDetailsTitle": "下の{label}", @@ -246,8 +248,12 @@ "common.ui.aggTypes.precisionLabel": "精度", "common.ui.aggTypes.ranges.addRangeButtonLabel": "範囲を追加", "common.ui.aggTypes.ranges.fromLabel": "開始値:", + "common.ui.aggTypes.ranges.greaterThanOrEqualPrepend": "≥", + "common.ui.aggTypes.ranges.lessThanPrepend": "<", "common.ui.aggTypes.ranges.removeRangeButtonAriaLabel": "{from} から {to} の範囲を削除", "common.ui.aggTypes.ranges.toLabel": "To", + "common.ui.aggTypes.scaleMetricsLabel": "メトリック値のスケーリング (廃止)", + "common.ui.aggTypes.scaleMetricsTooltip": "これを有効にすると、手動最低間隔を選択し、広い間隔が使用された場合、カウントと合計メトリックが手動で選択された間隔にスケーリングされます。", "common.ui.aggTypes.showEmptyBucketsLabel": "空のバケットを表示", "common.ui.aggTypes.showEmptyBucketsTooltip": "結果のあるバケットだけでなくすべてのバケットを表示します", "common.ui.aggTypes.sizeLabel": "サイズ", @@ -261,10 +267,14 @@ "common.ui.aggTypes.timeInterval.scaledHelpText": "現在 {bucketDescription} にスケーリングされています", "common.ui.aggTypes.timeInterval.selectIntervalPlaceholder": "間隔を選択", "common.ui.aggTypes.timeInterval.selectOptionHelpText": "オプションを選択するかカスタム値を作成します。例30s、20m、24h、2d、1w、1M", + "common.ui.chrome.bigUrlWarningNotificationMessage": "{advancedSettingsLink}で{storeInSessionStorageParam}オプションを有効にするか、オンスクリーンビジュアルを簡素化してください。", + "common.ui.chrome.bigUrlWarningNotificationMessage.advancedSettingsLinkText": "高度な設定", + "common.ui.chrome.bigUrlWarningNotificationTitle": "URLが大きく、Kibanaの動作が停止する可能性があります", "common.ui.directives.fieldNameIcons.booleanAriaLabel": "ブールフィールド", "common.ui.directives.fieldNameIcons.conflictFieldAriaLabel": "矛盾フィールド", "common.ui.directives.fieldNameIcons.dateFieldAriaLabel": "日付フィールド", "common.ui.directives.fieldNameIcons.geoPointFieldAriaLabel": "地理ポイント", + "common.ui.directives.fieldNameIcons.geoShapeFieldAriaLabel": "地理情報図形", "common.ui.directives.fieldNameIcons.ipAddressFieldAriaLabel": "IP アドレスフィールド", "common.ui.directives.fieldNameIcons.murmur3FieldAriaLabel": "Murmur3 フィールド", "common.ui.directives.fieldNameIcons.numberFieldAriaLabel": "数値フィールド", @@ -395,6 +405,7 @@ "common.ui.fieldEditor.syntaxHeader": "構文", "common.ui.fieldEditor.truncate.lengthLabel": "フィールドの長さ", "common.ui.fieldEditor.typeLabel": "タイプ", + "common.ui.fieldEditor.url.heightLabel": "高さ", "common.ui.fieldEditor.url.labelTemplateHelpText": "ラベルテンプレートのヘルプ", "common.ui.fieldEditor.url.labelTemplateLabel": "ラベルテンプレート", "common.ui.fieldEditor.url.offLabel": "オフ", @@ -403,6 +414,7 @@ "common.ui.fieldEditor.url.template.helpLinkText": "URL テンプレートのヘルプ", "common.ui.fieldEditor.url.typeLabel": "タイプ", "common.ui.fieldEditor.url.urlTemplateLabel": "URL テンプレート", + "common.ui.fieldEditor.url.widthLabel": "幅", "common.ui.fieldEditor.urlTemplate.examplesHeader": "例", "common.ui.fieldEditor.urlTemplate.inputHeader": "インプット", "common.ui.fieldEditor.urlTemplate.outputHeader": "アウトプット", @@ -467,17 +479,27 @@ "common.ui.vis.aggConfig.percentageOfLabel": "{label} のパーセンテージ", "common.ui.vis.defaultEditor.aggSelect.aggregationLabel": "集約", "common.ui.vis.defaultEditor.aggSelect.helpLinkLabel": "{aggTitle} のヘルプ", + "common.ui.vis.defaultEditor.aggSelect.noCompatibleAggsDescription": "インデックスパターン{indexPatternTitle}には集約可能なフィールドが含まれていません。", "common.ui.vis.defaultEditor.aggSelect.selectAggPlaceholder": "集約を選択してください", "common.ui.vis.defaultEditor.aggSelect.subAggregationLabel": "サブ集約", + "common.ui.vis.defaultEditor.controls.columnsLabel": "フィールド", + "common.ui.vis.defaultEditor.controls.dotSizeRatioHelpText": "最小の点から最大の点までの半径の比率を変更します。", + "common.ui.vis.defaultEditor.controls.dotSizeRatioLabel": "点サイズ率", + "common.ui.vis.defaultEditor.controls.rowsLabel": "行", + "common.ui.vis.defaultEditor.controls.splitByLegend": "行または列でチャートを分割します。", "common.ui.vis.defaultFeedbackMessage": "フィードバックがありますか?{link} で問題を報告してください。", "common.ui.vis.editors.advancedToggle.advancedLinkLabel": "高度な設定", "common.ui.vis.editors.agg.disableAggButtonTooltip": "集約を無効にする", "common.ui.vis.editors.agg.enableAggButtonTooltip": "集約を有効にする", + "common.ui.vis.editors.agg.errorsAriaLabel": "集約にエラーがあります", "common.ui.vis.editors.agg.modifyPriorityButtonTooltip": "ドラッグして優先順位を変更します", "common.ui.vis.editors.agg.removeDimensionButtonTooltip": "ディメンションを削除", "common.ui.vis.editors.agg.toggleEditorButtonAriaLabel": "{schema} エディターを切り替える", + "common.ui.vis.editors.aggAdd.addButtonLabel": "追加", "common.ui.vis.editors.aggAdd.addGroupButtonLabel": "{groupNameLabel} を追加", "common.ui.vis.editors.aggAdd.addSubGroupButtonLabel": "サブ {groupNameLabel} を追加", + "common.ui.vis.editors.aggAdd.bucketLabel": "バケット", + "common.ui.vis.editors.aggAdd.metricLabel": "メトリック", "common.ui.vis.editors.aggGroups.bucketsText": "バケット", "common.ui.vis.editors.aggGroups.metricsText": "メトリック", "common.ui.vis.editors.aggParams.errors.aggWrongRunOrderErrorMessage": "「{schema}」集約は他のバケットの前に実行する必要があります!", @@ -489,13 +511,14 @@ "common.ui.vis.editors.sidebar.autoApplyChangesTooltip": "変更を自動適用", "common.ui.vis.editors.sidebar.discardChangesAriaLabel": "ビジュアライゼーションをリセット", "common.ui.vis.editors.sidebar.discardChangesTooltip": "変更を破棄", + "common.ui.vis.editors.sidebar.errorButtonAriaLabel": "ハイライトされたフィールドのエラーを解決する必要があります。", + "common.ui.vis.editors.sidebar.errorButtonTooltip": "ハイライトされたフィールドのエラーを解決する必要があります。", "common.ui.vis.editors.sidebar.tabs.dataLabel": "データ", "common.ui.vis.editors.sidebar.tabs.optionsLabel": "オプション", "common.ui.vis.kibanaMap.leaflet.fitDataBoundsAriaLabel": "データバウンドを合わせる", "common.ui.vis.kibanaMap.zoomWarning": "ズームレベルが最大に達しました。完全にズームインするには、Elasticsearch と Kibana の {defaultDistribution} にアップグレードしてください。{ems} でより多くのズームレベルが利用できます。または、独自のマップサーバーを構成できます。詳細は { wms } または { configSettings} をご覧ください。", "common.ui.vis.visTypes.legend.filterForValueButtonAriaLabel": "値 {legendDataLabel} でフィルタリング", "common.ui.vis.visTypes.legend.filterOutValueButtonAriaLabel": "値 {legendDataLabel} を除外", - "common.ui.vis.visTypes.legend.filterOptionsLegend": "{legendDataLabel}, フィルターオプション", "common.ui.vis.visTypes.legend.loadingLabel": "読み込み中…", "common.ui.vis.visTypes.legend.setColorScreenReaderDescription": "値 {legendDataLabel} の色を設定", "common.ui.vis.visTypes.legend.toggleLegendButtonAriaLabel": "凡例を切り替える", @@ -507,368 +530,72 @@ "common.ui.vislib.colormaps.greysText": "グレー", "common.ui.vislib.colormaps.redsText": "赤", "common.ui.vislib.colormaps.yellowToRedText": "黄色から赤", - "common.ui.visualize.queryGeohashBounds.unableToGetBoundErrorTitle": "バウンドを取得できませんでした", - "common.ui.directives.fieldNameIcons.geoShapeFieldAriaLabel": "地理情報図形", - "common.ui.vis.editors.agg.errorsAriaLabel": "集約にエラーがあります", "common.ui.vislib.heatmap.maxBucketsText": "定義された数列が多すぎます ({nr}).構成されている最高値は {max} です。", - "common.ui.aggTypes.ranges.greaterThanOrEqualPrepend": "≥", - "common.ui.aggTypes.ranges.lessThanPrepend": "<", - "common.ui.aggTypes.scaleMetricsLabel": "メトリック値のスケーリング (廃止)", - "common.ui.aggTypes.scaleMetricsTooltip": "これを有効にすると、手動最低間隔を選択し、広い間隔が使用された場合、カウントと合計メトリックが手動で選択された間隔にスケーリングされます。", - "common.ui.aggTypes.buckets.ranges.rangesFormatMessage": "{gte} {from} と {lt} {to}", - "management.connectDataDisplayName": "データに接続", - "management.displayName": "管理", - "management.nav.menu": "管理メニュー", - "management.editIndexPattern.createIndex.defaultButtonDescription": "すべてのデータに完全集約を実行", - "management.editIndexPattern.createIndex.defaultButtonText": "標準インデックスパターン", - "management.editIndexPattern.createIndex.defaultTypeName": "インデックスパターン", - "timelion.savedObjectFinder.addNewItemButtonLabel": "新規 {item} を追加", - "timelion.savedObjectFinder.manageItemsButtonLabel": "{items} の管理", - "timelion.savedObjectFinder.noMatchesFoundDescription": "一致する {items} が見つかりません。", - "timelion.savedObjectFinder.pageItemsFromHitCountDescription": "{hitCount} 件中 {pageFirstItem}-{pageLastItem} 件目", - "timelion.savedObjectFinder.sortByButtonLabeAscendingScreenReaderOnly": "昇順", - "timelion.savedObjectFinder.sortByButtonLabeDescendingScreenReaderOnly": "降順", - "timelion.savedObjectFinder.sortByButtonLabel": "名前", - "timelion.savedObjectFinder.sortByButtonLabelScreenReaderOnly": "並べ替え基準", - "timelion.badge.readOnly.text": "読み込み専用", - "timelion.badge.readOnly.tooltip": "Timelion シートを保存できません", - "timelion.breadcrumbs.create": "作成", - "timelion.breadcrumbs.root": "Timelion", - "timelion.cells.actions.fullscreenAriaLabel": "全画面チャート", - "timelion.cells.actions.fullscreenTooltip": "全画面", - "timelion.cells.actions.removeAriaLabel": "リモートスタート", - "timelion.cells.actions.removeTooltip": "削除", - "timelion.cells.actions.reorderAriaLabel": "ドラッグして並べ替え", - "timelion.cells.actions.reorderTooltip": "ドラッグして並べ替え", - "timelion.chart.seriesList.noSchemaWarning": "次のパネルタイプは存在しません: {renderType}", - "timelion.expressionInputAriaLabel": "Timelion 式", - "timelion.expressionInputPlaceholder": "{esQuery} でのクエリを試してみてください。", - "timelion.expressionSuggestions.arg.infoTitle": "情報", - "timelion.expressionSuggestions.arg.listTitle": "引数:", - "timelion.expressionSuggestions.arg.nameTitle": "引数名", - "timelion.expressionSuggestions.arg.typesTitle": "対応タイプ", - "timelion.expressionSuggestions.func.description.chainableText": "{help} (連鎖可能)", - "timelion.expressionSuggestions.func.description.dataSourceText": "{help} (データソース)", - "timelion.fitFunctions.carry.downSampleErrorMessage": "ダウンサンプルには「carry」フィットメソドを使用せず、「scale」または「average」を使用してください", - "timelion.fullscreen.exitAriaLabel": "全画面を終了", - "timelion.fullscreen.exitTooltip": "全画面を終了", - "timelion.function.help": "Timelion のビジュアライゼーションです。", - "timelion.help.configuration.firstTimeConfigurationLinkText": "初回構成", - "timelion.help.configuration.notValid.advancedSettingsPathText": "管理 / Kibana / 高度な設定", - "timelion.help.configuration.notValid.notValidSettingsErrorMessage": "Elasticsearch の設定を確認できませんでした: {reason}。高度な設定を確認して再試行してください。({count})", - "timelion.help.configuration.notValid.paragraph1": "Logstash を使用している場合、Timelion でのログデータの探索開始に何も構成する必要はありません。他のインデックスを検索するには、{advancedSettingsPath} に移動してインデックスと一致するよう {esDefaultIndex} と {esTimefield} を設定します。", - "timelion.help.configuration.notValid.paragraph2": "他の Timelion 設定もあります。今のところ他の設定は気にしなくて大丈夫です。後程、必要に応じていつでも設定できることがわかります。", - "timelion.help.configuration.notValid.validateButtonLabel": "構成を検証", - "timelion.help.configuration.notValidTitle": "初回構成", - "timelion.help.configuration.valid.advancedSettingsPathText": "管理/Kibana/高度な設定", - "timelion.help.configuration.valid.intervalIsAutoText": "準備完了です!", - "timelion.help.configuration.valid.intervals.content.intervalIsNotAutoText": "Timelion が適切な間隔を選択できるよう、{auto} に設定します。", - "timelion.help.configuration.valid.intervalsTextPart1": "インプットバーの右にある間隔設定は、サンプリングの頻度をコントロールできます。現在 {interval} に設定されています。", - "timelion.help.configuration.valid.intervalsTextPart2": "Timelion が選択された時間範囲と間隔の組み合わせによりデータポイントが多くなりすぎると判断した場合、エラーが発生します。{advancedSettingsPath} の {maxBuckets} を構成することでこの制限を調整できます。", - "timelion.help.configuration.valid.intervalsTitle": "間隔", - "timelion.help.configuration.valid.paragraph1Part1": "デフォルトのインデックスと時間フィールドを検証し、すべて問題なさそうです。{statsMin} から {statsMax} までのデータが見つかりました。恐らく準備完了です。何か問題がある場合は、", - "timelion.help.configuration.valid.paragraph1Part2": "で Elasticsearch データソースの構成に関する詳細をご覧ください。", - "timelion.help.configuration.valid.paragraph2": "既にチャートが 1 つ表示されていますが、興味深いデータを得るにはいくつか調整が必要な可能性があります。", - "timelion.help.configuration.valid.paragraph3": "これで、一定期間のデータポイントの数を示す折れ線グラフが表示されるはずです。", - "timelion.help.configuration.valid.timeRangeText": "Kibana ツールバーのタイムピッカーで可視化するデータを含む期間を選択します。上記のすべてまたは一部の時間範囲を含む時間範囲を選択するようにしてください。", - "timelion.help.configuration.valid.timeRangeTitle": "時間範囲", - "timelion.help.configuration.validTitle": "良いお知らせです。Elasticsearch が正しく構成されました!", - "timelion.help.dataTransforming.functionReferenceLinkText": "機能リファレンス", - "timelion.help.dataTransforming.paragraph1": "基本を覚えたところで、Timelion の実力を発揮させましょう。エータのサブセットが、一定期間における全体の何パーセントを表しているか見てみましょう。例えば、Web トラフィックの何パーセントが米国からのものでしょう?", - "timelion.help.dataTransforming.paragraph2": "まず初めに、米国を含むすべてのイベントを見つけます: {esUsQuery}。", - "timelion.help.dataTransforming.paragraph3": "次に、全体に対する米国のイベントの比率を割り出します。{us} を全体で割るには、{divide} 関数を使用します: {divideDataQuery}。", - "timelion.help.dataTransforming.paragraph4": "まぁまぁですが、これでは 0 から 1 までの値になってしまいます。パーセンテージに変換するには、100 を掛けます: {multiplyDataQuery}。", - "timelion.help.dataTransforming.paragraph5": "これでトラフィックの何パーセントが米国からのものなのか分かり、一定期間内にどのように変化したのか見ることができます!Timelion には、{sum}、{subtract}、{multiply}、{divide} などのいくつもの演算機能が搭載されています。これらの多くが数列や数字を扱えます。また、{movingaverage}、{abs}、{derivative} といった他の便利な変換機能もあります。", - "timelion.help.dataTransforming.paragraph6Part1": "構文を学んだところで、", - "timelion.help.dataTransforming.paragraph6Part2": "で、Timelion で利用できるすべての機能の使い方をご覧ください。Kibana ツールバーの \\{ドキュメント\\} をクリックしていつでもリファレンスを参照することができます。このチュートリアルに戻るには、リファレンスの上にある \\{チュートリアル\\} リンクをクリックします。", - "timelion.help.dataTransformingTitle": "データの変換: お楽しみの始まりです!", - "timelion.help.dontShowHelpButtonLabel": "今後表示しない", - "timelion.help.expressions.examples.customStylingDescription": "{descriptionTitle}初めの数列を赤くし、2 つ目の数列に 1 ピクセル幅のバーを使用します。", - "timelion.help.expressions.examples.customStylingDescriptionTitle": "カスタムスタイリング。", - "timelion.help.expressions.examples.groupedExpressionsDescription": "{descriptionTitle}式のグループを関数に連結させることもできます。ここでは両方の数列が線ではなく点で表示されています。", - "timelion.help.expressions.examples.groupedExpressionsDescriptionTitle": "式のグループ化。", - "timelion.help.expressions.examples.namedArgumentsDescription": "{descriptionTitle}引数の指定順序を覚える必要はありません。名前付き引数を使えば、式の読み書きが楽になります。", - "timelion.help.expressions.examples.namedArgumentsDescriptionTitle": "名前付き引数。", - "timelion.help.expressions.examples.twoExpressionsDescription": "{descriptionTitle}同じチャートに 2 つの式が使えます。", - "timelion.help.expressions.examples.twoExpressionsDescriptionTitle": "2 倍の楽しみ。", - "timelion.help.expressions.functionReferenceLinkText": "関数リファレンス", - "timelion.help.expressions.paragraph1": "それぞれの式はデータソース関数で始まります。ここから、新しい関数をデータソースに追加して変換や強化ができます。", - "timelion.help.expressions.paragraph2": "ところで、ここから先はデータの持ち主が一番よくご存知なのではないでしょうか。サンプルクエリをより有意義なものと自由に置き換えてみてください。", - "timelion.help.expressions.paragraph3": "Kibana ツールバーの {strongAdd} をクリックして、他のチャートをいくつか追加してみみましょう。そして、チャートを選択して次の式の内の 1 つをコピーし、インプットバーに貼り付けて、Enter を押します。リセットして繰り返し、他の式を試してみましょう。", - "timelion.help.expressions.paragraph4": "Timelion は、チャートの見た目をカスタマイズするための他のビュー変換機能も搭載しています。完全なリストは次のリソースをご覧ください", - "timelion.help.expressions.strongAddText": "追加", - "timelion.help.expressionsTitle": "式を使って式を定義", - "timelion.help.functions.absHelpText": "数列リストの各値の絶対値を返します", - "timelion.help.functions.aggregate.args.functionHelpText": "{functions} の 1 つ", - "timelion.help.functions.aggregateHelpText": "数列のすべての点の処理結果に基づく線を作成します。利用可能な関数: {functions}", - "timelion.help.functions.bars.args.stackHelpText": "バーがスタックした場合はデフォルトで true にする", - "timelion.help.functions.bars.args.widthHelpText": "バーの幅 (ピクセル)", - "timelion.help.functions.barsHelpText": "seriesList をバーとして表示", - "timelion.help.functions.color.args.colorHelpText": "ヘックスとしての数列の色です。例: #c6c6c6 はかわいいライトグレー。複数の色を指定し、複数数列がある場合、グラデーションになります。例: 「#00B1CC:#00FF94:#FF3A39:#CC1A6F」", - "timelion.help.functions.colorHelpText": "数列の色を変更します", - "timelion.help.functions.common.args.fitHelpText": "ターゲットの期間と間隔に数列を合わせるためのアルゴリズムです。利用可能: {fitFunctions}", - "timelion.help.functions.common.args.offsetHelpText": "日付表現による数列の取得をオフセットします。例: 1 か月前からイベントを作成する -1M tは現在のように表示されます。「 timerange」によって、チャートの全体的な時間範囲に関連した数列をオフセットします。例: 「timerange:-2」は過去に対する全体的なチャート時間範囲の 2 倍をオフセットします。", - "timelion.help.functions.condition.args.elseHelpText": "比較が false の場合に点が設定される値です。ここで seriesList を引き渡した場合、初めの数列が使用されます。", - "timelion.help.functions.condition.args.ifHelpText": "点が比較される値です。ここで seriesList を引き渡した場合、初めの数列が使用されます。", - "timelion.help.functions.condition.args.operator.suggestions.eqHelpText": "equal", - "timelion.help.functions.condition.args.operator.suggestions.gteHelpText": "超過", - "timelion.help.functions.condition.args.operator.suggestions.gtHelpText": "以上", - "timelion.help.functions.condition.args.operator.suggestions.lteHelpText": "未満", - "timelion.help.functions.condition.args.operator.suggestions.ltHelpText": "以下", - "timelion.help.functions.condition.args.operator.suggestions.neHelpText": "not equal", - "timelion.help.functions.condition.args.operatorHelpText": "比較に使用する比較演算子、有効な演算子は eq (=)、ne (≠), lt (<), lte (≦), gt (>), gte (≧)", - "timelion.help.functions.condition.args.thenHelpText": "比較が true の場合に点が設定される値です。ここで seriesList を引き渡した場合、初めの数列が使用されます。", - "timelion.help.functions.conditionHelpText": "演算子を使って各点を数字、または別の数列の同じ点と比較し、true の場合値を結果の値に設定し、オプションとして else が使用されます。", - "timelion.help.functions.cusum.args.baseHelpText": "開始の数字です。基本的に、数列の初めにこの数字が追加されます", - "timelion.help.functions.cusumHelpText": "ベースから始め、数列の累積和を返します。", - "timelion.help.functions.derivativeHelpText": "一定期間の値の変化をプロットします。", - "timelion.help.functions.divide.args.divisorHelpText": "割る数字または数列です。複数数列を含む seriesList はラベルに適用されます。", - "timelion.help.functions.divideHelpText": "seriesList の 1 つまたは複数の数列の値をインプット seriesList の各数列のそれぞれの配置に割けます。", - "timelion.help.functions.es.args.indexHelpText": "クエリを実行するインデックスで、ワイルドカードが使えます。「metrics」、「split」、「timefield」引数のスクリプトフィールドのフィールド名のインデックスパターン名とフィールド名の入力候補を提供します。", - "timelion.help.functions.es.args.intervalHelpText": "**これは使用しないでください**。fit 関数のデバッグは楽しいですが、間隔ピッカーを使用すべきです。", - "timelion.help.functions.es.args.kibanaHelpText": "Kibana ダッシュボードでフィルターを適用します。Kibana ダッシュボードの使用時にのみ適用されます。", - "timelion.help.functions.es.args.metricHelpText": "Elasticsearch メトリック集約: avg、sum、min、max、percentiles、または基数、後ろにフィールドを付けます。例: 「sum:bytes」、「percentiles:bytes:95,99,99.9」、「count」", - "timelion.help.functions.es.args.qHelpText": "Lucene クエリ文字列の構文のクエリ", - "timelion.help.functions.es.args.splitHelpText": "分割する Elasticsearch フィールドと制限です。例: トップ 10 のホスト名を割り出す「{hostnameSplitArg}」", - "timelion.help.functions.es.args.timefieldHelpText": "X 軸にフィールドタイプ「date」を使用", - "timelion.help.functions.esHelpText": "Elasticsearch インスタンスからデータを取得します", - "timelion.help.functions.firstHelpText": "これは単純に input seriesList を返す内部機能です。この機能は使わないでください", - "timelion.help.functions.fit.args.modeHelpText": "数列をターゲットに合わせるためのアルゴリズムです。{fitFunctions} の 1 つ", - "timelion.help.functions.fitHelpText": "定義された fit 関数を使用して空値を入力します", - "timelion.help.functions.graphite.args.metricHelpText": "取得する Graphite メトリック、例: {metricExample}", - "timelion.help.functions.graphiteHelpText": "[実験的] Graphite からデータを取得します。Kibana の高度な設定で Graphite サーバーを構成します", - "timelion.help.functions.hide.args.hideHelpText": "数列の表示と非表示を切り替えます", - "timelion.help.functions.hideHelpText": "デフォルトで数列を非表示にします", - "timelion.help.functions.holt.args.alphaHelpText": "\n 0 から 1 の平滑化加重です。\n アルファを上げると新しい数列がオリジナルにさらに近くなります。\n 下げると数列がスムーズになります", - "timelion.help.functions.holt.args.betaHelpText": "\n 0 から 1 の傾向加重です。\n ベータを上げると線の上下の動きが長くなります。\n 下げると新しい傾向をより早く反映するようになります", - "timelion.help.functions.holt.args.gammaHelpText": "0 から 1 のシーズン加重です。データが波のようになっていますか?\n この数字を上げると、最近のシーズンの重要性が高まり、波形の動きを速くします。\n 下げると新しいシーズンの重要性が下がり、過去がより重要視されます。", - "timelion.help.functions.holt.args.sampleHelpText": "\n シーズン数列の「予測」を開始する前にサンプリングするシーズンの数です。\n (gamma でのみ有効、デフォルト: all)", - "timelion.help.functions.holt.args.seasonHelpText": "シーズンの長さです、例: パターンが毎週繰り返される場合は 1w。(gamma でのみ有効)", - "timelion.help.functions.holtHelpText": "\n 数列の始めをサンプリングし、\n いくつかのオプションパラメーターを使用して何が起こるか予測します。基本的に、この機能は未来を予測するのではなく、\n 過去のデータに基づき現在何が起きているべきかを予測します。\n この情報は異常検知に役立ちます。null には予測値が入力されます。", - "timelion.help.functions.label.args.labelHelpText": "数列の凡例値です。文字列で $1、$2 などを使用して、正規表現の捕捉グループに合わせることができます。", - "timelion.help.functions.label.args.regexHelpText": "捕捉グループをサポートする正規表現です", - "timelion.help.functions.labelHelpText": "数列のラベルを変更します。%s で既存のラベルを参照します", - "timelion.help.functions.legend.args.columnsHelpText": "凡例を分ける列の数です", - "timelion.help.functions.legend.args.position.suggestions.falseHelpText": "凡例を無効にします", - "timelion.help.functions.legend.args.position.suggestions.neHelpText": "北東の角に凡例を配置します", - "timelion.help.functions.legend.args.position.suggestions.nwHelpText": "北西の角に凡例を配置します", - "timelion.help.functions.legend.args.position.suggestions.seHelpText": "南東の角に凡例を配置します", - "timelion.help.functions.legend.args.position.suggestions.swHelpText": "南西の角に凡例を配置します", - "timelion.help.functions.legend.args.positionHelpText": "凡例を配置する角: nw、ne、se、または sw。false で凡例を無効にすることもできます", - "timelion.help.functions.legend.args.showTimeHelpText": "グラフにカーソルを合わせた時、凡例の時間値を表示します。デフォルト: true", - "timelion.help.functions.legend.args.timeFormatHelpText": "moment.js フォーマットパターンです。デフォルト: {defaultTimeFormat}", - "timelion.help.functions.legendHelpText": "プロットの凡例の位置とスタイルを設定します", - "timelion.help.functions.lines.args.fillHelpText": "0 と 10 の間の数字です。エリアチャートの作成に使用します。", - "timelion.help.functions.lines.args.showHelpText": "線の表示と非表示を切り替えます", - "timelion.help.functions.lines.args.stackHelpText": "線をスタックします。よく誤解を招きます。この機能を使用する際は塗りつぶしを使うようにしましょう。", - "timelion.help.functions.lines.args.stepsHelpText": "線をステップとして表示します。つまり、点の間に中間値を挿入しません。", - "timelion.help.functions.lines.args.widthHelpText": "線の太さです", - "timelion.help.functions.linesHelpText": "seriesList を線として表示します", - "timelion.help.functions.log.args.baseHelpText": "対数のベースを設定します、デフォルトは 10 です", - "timelion.help.functions.logHelpText": "数列リストの各値の対数値を返します (デフォルトのベース:10)", - "timelion.help.functions.max.args.valueHelpText": "点を既存の値と引き渡された値のどちらか高い方に設定します。seriesList を引き渡す場合、数列がちょうど 1 つでなければなりません。", - "timelion.help.functions.maxHelpText": "インプット seriesList の各数列のそれぞれの配置の seriesList の 1 つまたは複数の数列の最高値です", - "timelion.help.functions.min.args.valueHelpText": "点を既存の値と引き渡された値のどちらか低い方に設定します。seriesList を引き渡す場合、数列がちょうど 1 つでなければなりません。", - "timelion.help.functions.minHelpText": "インプット seriesList の各数列のそれぞれの配置の seriesList の 1 つまたは複数の数列の最低値です", - "timelion.help.functions.movingaverage.args.positionHelpText": "結果時間に比較した平均点の配置です。{validPositions} の 1 つ", - "timelion.help.functions.movingaverage.args.windowHelpText": "平均を出す点の数、または日付計算式 (例: 1d、1M) です。日付計算式が指定された場合、この機能は現在選択された間隔でできるだけ近づけます。日付計算式が間隔で均等に分けられない場合、結果に異常が出る場合があります。", - "timelion.help.functions.movingaverageHelpText": "特定期間の移動平均を計算します。ばらばらの数列を滑らかにするのに有効です。", - "timelion.help.functions.movingstd.args.positionHelpText": "結果時間に比較した期間スライスの配置です。オプションは {positions} です。デフォルト: {defaultPosition}", - "timelion.help.functions.movingstd.args.windowHelpText": "標準偏差を計算する点の数です。", - "timelion.help.functions.movingstdHelpText": "特定期間の移動標準偏差を計算します。ネイティブ two-pass アルゴリズムを使用します。非常に長い数列や、非常に大きな数字を含む数列では、四捨五入による誤差がより明らかになる可能性があります。", - "timelion.help.functions.multiply.args.multiplierHelpText": "掛ける数字または数列です。複数数列を含む seriesList はラベルに適用されます。", - "timelion.help.functions.multiplyHelpText": "seriesList の 1 つまたは複数の数列の値をインプット seriesList の各数列のそれぞれの配置に掛けます。", - "timelion.help.functions.points.args.fillColorHelpText": "点を塗りつぶす色です。", - "timelion.help.functions.points.args.fillHelpText": "塗りつぶしの透明度を表す 0 から 10 までの数字です", - "timelion.help.functions.points.args.radiusHelpText": "点のサイズです", - "timelion.help.functions.points.args.showHelpText": "点の表示・非表示です", - "timelion.help.functions.points.args.symbolHelpText": "点のシンボルです。{validSymbols} の 1 つ", - "timelion.help.functions.points.args.weightHelpText": "点の周りの太さです", - "timelion.help.functions.pointsHelpText": "数列を点として表示します", - "timelion.help.functions.precision.args.precisionHelpText": "各値を四捨五入する桁数です", - "timelion.help.functions.precisionHelpText": "値の小数点以下の四捨五入する桁数です", - "timelion.help.functions.props.args.globalHelpText": "各数列に対し、seriesList にプロップを設定します", - "timelion.help.functions.propsHelpText": "数列に任意のプロパティを設定するため、自己責任で行ってください。例: {example}", - "timelion.help.functions.quandl.args.codeHelpText": "プロットする Quandl コードです。これらは quandl.com に掲載されています。", - "timelion.help.functions.quandl.args.positionHelpText": "Quandl ソースによっては、複数数列を返すものがあります。どれを使用しますか?1 ベースインデックス", - "timelion.help.functions.quandlHelpText": "\n [実験的]\n Quandl コードで quandl.com からデータを取得します。{quandlKeyField} を Kibana の空いている API キーに設定します。\n 高度な設定です。API は、キーなしでは非常に低いレート制限があります。", - "timelion.help.functions.range.args.maxHelpText": "新しい最高値です", - "timelion.help.functions.range.args.minHelpText": "新しい最低値です", - "timelion.help.functions.rangeHelpText": "同じシェイプを維持しつつ数列の最高値と最低値を変更します", - "timelion.help.functions.scaleInterval.args.intervalHelpText": "新しい間隔の日付計算表記です。例: 1 秒 = 1s。1m、5m、1M、1w、1y など。", - "timelion.help.functions.scaleIntervalHelpText": "変更すると、値 (通常合計またはカウント) が新しい間隔にスケーリングされます。例: 毎秒のレート", - "timelion.help.functions.static.args.labelHelpText": "数列のラベルを簡単に設定する方法です。.label() 関数を使用することもできます。", - "timelion.help.functions.static.args.valueHelpText": "表示する単一の値です。複数の値が引き渡された場合、指定された時間範囲に均等に挿入されます。", - "timelion.help.functions.staticHelpText": "チャートに 1 つの値を挿入します", - "timelion.help.functions.subtract.args.termHelpText": "インプットから引く数字または数列です。複数数列を含む seriesList はラベルに適用されます。", - "timelion.help.functions.subtractHelpText": "seriesList の 1 つまたは複数の数列の値をインプット seriesList の各数列のそれぞれの配置から引きます。", - "timelion.help.functions.sum.args.termHelpText": "インプット数列に足す数字または数列です。複数数列を含む seriesList はラベルに適用されます。", - "timelion.help.functions.sumHelpText": "seriesList の 1 つまたは複数の数列の値をインプット seriesList の各数列のそれぞれの配置に足します。", - "timelion.help.functions.title.args.titleHelpText": "プロットのタイトルです。", - "timelion.help.functions.titleHelpText": "プロットの上部にタイトルを追加します。複数の seriesList がコールされた場合、最後のコールが使用されます。", - "timelion.help.functions.trend.args.endHelpText": "始めまたは終わりからの計算を修了する場所です。例えば、-10 の場合終わりから 10 点目で計算が終了し、+15 の場合始めから 15 点目で終了します。デフォルト:0", - "timelion.help.functions.trend.args.modeHelpText": "傾向線の生成に使用するアルゴリズムです。{validRegressions} の 1 つ", - "timelion.help.functions.trend.args.startHelpText": "始めまたは終わりからの計算を開始する場所です。例えば、-10 の場合終わりから 10 点目から計算を開始し、+15 の場合始めから 15 点目から開始します。デフォルト:0", - "timelion.help.functions.trendHelpText": "指定された回帰アルゴリズムで傾向線を描きます", - "timelion.help.functions.trim.args.endHelpText": "数列の終わりから切り取るバケットです。デフォルト:1", - "timelion.help.functions.trim.args.startHelpText": "数列の始めから切り取るバケットです。デフォルト:1", - "timelion.help.functions.trimHelpText": "「部分的バケットの問題」に合わせて、数列の始めか終わりの N 個のバケットを無効化するように設定します。", - "timelion.help.functions.worldbank.args.codeHelpText": "Worldbank API パスです。これは通常ドメインの後ろからクエリ文字列までのすべてです。例: {apiPathExample}。", - "timelion.help.functions.worldbankHelpText": "\n [experimental]\n 数列のパスを使用して {worldbankUrl} からデータを取得します。\n Worldbank は主に年間データを提供し、現在の年のデータがないことがよくあります。\n 最近の期間範囲のデータが取得できない場合は、{offsetQuery} をお試しください。", - "timelion.help.functions.worldbankIndicators.args.countryHelpText": "Worldbank の国 ID です。通常は国の 2 文字のコートです", - "timelion.help.functions.worldbankIndicators.args.indicatorHelpText": "使用するインジケーターコードです。{worldbankUrl} で調べる必要があります。多くが分かりずらいものです。例えば、人口は {indicatorExample} です。", - "timelion.help.functions.worldbankIndicatorsHelpText": "\n [experimental]\n 国名とインジケーターを使って {worldbankUrl} からデータを取得します。Worldbank は\n 主に年間データを提供し、現在の年のデータがないことがよくあります。最近の期間のデータが取得できない場合は、{offsetQuery} をお試しください\n 時間範囲", - "timelion.help.functions.yaxis.args.colorHelpText": "軸ラベルの色です", - "timelion.help.functions.yaxis.args.labelHelpText": "軸のラベルです", - "timelion.help.functions.yaxis.args.maxHelpText": "最高値", - "timelion.help.functions.yaxis.args.minHelpText": "最低値", - "timelion.help.functions.yaxis.args.positionHelpText": "左から右", - "timelion.help.functions.yaxis.args.tickDecimalsHelpText": "y 軸とティックラベルの小数点以下の桁数です。", - "timelion.help.functions.yaxis.args.unitsHelpText": "Y 軸のラベルのフォーマットに使用する機能です。{formatters} の 1 つ", - "timelion.help.functions.yaxis.args.yaxisHelpText": "この数列をプロットする数字の Y 軸です。例: 2 本目の Y 軸は .yaxis(2) になります。", - "timelion.help.functions.yaxisHelpText": "様々な Y 軸のオプションを構成します。恐らく最も重要なのは、N 本目 (例: 2 本目) の Y 軸を追加する機能です。", - "timelion.help.mainPage.functionReference.detailsTable.acceptedTypesColumnLabel": "対応タイプ", - "timelion.help.mainPage.functionReference.detailsTable.argumentNameColumnLabel": "引数名", - "timelion.help.mainPage.functionReference.detailsTable.informationColumnLabel": "情報", - "timelion.help.mainPage.functionReference.gettingStartedText": "関数をクリックすると詳細が表示されます。初心者の方ですか?", - "timelion.help.mainPage.functionReference.noArgumentsFunctionErrorMessage": "この関数には引数を使用できません。簡単でしょう?", - "timelion.help.mainPage.functionReference.welcomePageLinkText": "チュートリアルをご覧ください", - "timelion.help.mainPage.functionReferenceTitle": "関数リファレンス", - "timelion.help.mainPage.keyboardTips.autoComplete.downArrowDescription": "自動入力メニューに焦点を切り替えます。矢印でさらに用語を選択します", - "timelion.help.mainPage.keyboardTips.autoComplete.downArrowLabel": "下矢印", - "timelion.help.mainPage.keyboardTips.autoComplete.enterTabDescription": "現在の選択項目または自動入力メニューで最も使用されている用語を選択します", - "timelion.help.mainPage.keyboardTips.autoComplete.escDescription": "自動入力メニューを閉じます", - "timelion.help.mainPage.keyboardTips.autoCompleteTitle": "自動入力が有効な場合", - "timelion.help.mainPage.keyboardTips.generalEditing.submitRequestText": "リクエストを送信します", - "timelion.help.mainPage.keyboardTips.generalEditingTitle": "一般編集", - "timelion.help.mainPage.keyboardTipsTitle": "キーボードのヒント", - "timelion.help.mainPageTitle": "ヘルプ", - "timelion.help.nextPageButtonLabel": "次へ", - "timelion.help.previousPageButtonLabel": "前へ", - "timelion.help.querying.countMetricAggregationLinkText": "Elasticsearch メトリック集約", - "timelion.help.querying.countTextPart1": "イベントをカウントするのも良いですが、Elasticsearch のデータソースは単独の値を返す", - "timelion.help.querying.countTextPart2": "もサポートしています。最も便利なものには {min}、{max}、{avg}、{sum}、{cardinality} などがあります。{srcIp}フィールドのユニークカウントを求めたいとしましょう。{cardinality} メトリックを使うだけです: {esCardinalityQuery}{bytes}フィールドの平均を求めるには、{avg} メトリックが使えます: {esAvgQuery}", - "timelion.help.querying.countTitle": "カウントを超えて", - "timelion.help.querying.esAsteriskQueryDescriptionText": "Elasticsearch、デフォルトインデックスのすべてを計算", - "timelion.help.querying.esIndexQueryDescriptionText": "* を logstash-* インデックスの q (クエリ) として使用します", - "timelion.help.querying.luceneQueryLinkText": "Lucene クエリ文字列", - "timelion.help.querying.paragraph1": "Elasticsearch データソースが利用可能であることを確認済みなので、クエリの送信ができます。手始めに、インプットバーに {esPattern} と入力し Enter を押してみましょう。", - "timelion.help.querying.paragraph2Part1": "{esAsteriskQueryDescription} が返されます。サブセットを把握したい場合は、{htmlQuery} で {html} に一致するイベントをカウントしたり、{bobQuery} で {user} フィールドに {bob} を含み、{bytes} フィールドが 100 より大きな値のイベントを検索したりできます。このクエリはシングルクォートで囲まれています。スペースを含むためです。いずれかの", - "timelion.help.querying.paragraph2Part2": "を {esQuery} 関数の初めの引数として入力することができます。", - "timelion.help.querying.passingArgumentsText": "Timelion には一般的な操作を簡単に行えるよう、いくつものショートカットがあります。スペースや特殊文字を含まないシンプルな引数用のものがその一つで、クォートを使う必要はありません。また、多くの関数にデフォルトがあります。例えば、{esEmptyQuery} と {esStarQuery} の動作は同じです。引数には名前も付いているため、特定の順序で指定する必要はありません。例えば、{esLogstashQuery} と入力して Elasticsearch データソースに {esIndexQueryDescription} させることができます。", - "timelion.help.querying.passingArgumentsTitle": "引数の受け渡し", - "timelion.help.queryingTitle": "Elasticsearch データソースにクエリを実行中", - "timelion.help.unknownErrorMessage": "不明なエラー", - "timelion.help.welcome.content.emphasizedEverythingText": "すべて", - "timelion.help.welcome.content.functionReferenceLinkText": "関数リファレンスに移動", - "timelion.help.welcome.content.paragraph1": "Timelion は時系列に関する {emphasizedEverything} を司る、全知全能のツールです。データストアから提供された時系列データは、Timelion にお任せください。Timelion は複数データソースのデータセットを、覚えやすい式構文で比較、結合、整理できます。このチュートリアルは Elasticsearch が中心となりますが、ここで学んだことは Timelion がサポートするすべてのデータソースに適用できます。", - "timelion.help.welcome.content.paragraph2": "準備はいいですか?{strongNext} をクリックしてください。チュートリアルをスキップしてドキュメントを表示しますか?", - "timelion.help.welcome.content.strongNextText": "次へ", - "timelion.help.welcomeTitle": "{strongTimelionLabel} へようこそ!", - "timelion.intervals.customIntervalAriaLabel": "カスタム間隔", - "timelion.intervals.selectIntervalAriaLabel": "間隔を選択", - "timelion.noFunctionErrorMessage": "そのような関数はありません: {name}", - "timelion.panels.noRenderFunctionErrorMessage": "パネルにはレンダリング関数が必要です", - "timelion.panels.timechart.unknownIntervalErrorMessage": "不明な間隔", - "timelion.registerFeatureDescription": "時系列データを分析して結果を可視化するには、式言語を使用してください。", - "timelion.requestHandlerErrorTitle": "Timelion リクエストエラー", - "timelion.saveExpression.successNotificationText": "保存された式「{title}」", - "timelion.saveSheet.successNotificationText": "保存されたシート「{title}」", - "timelion.search.submitAriaLabel": "検索", - "timelion.searchErrorTitle": "Timelion リクエストエラー", - "timelion.serverSideErrors.argumentsOverflowErrorMessage": "{functionName} に引き渡された引数が多すぎます", - "timelion.serverSideErrors.bucketsOverflowErrorMessage": "バケットの最高数を超過: {maxBuckets} 個中 {bucketCount} 個が使用できます。より広い間隔または短い期間を選択してください", - "timelion.serverSideErrors.colorFunction.colorNotProvidedErrorMessage": "色が指定されていません", - "timelion.serverSideErrors.conditionFunction.unknownOperatorErrorMessage": "不明な演算子", - "timelion.serverSideErrors.conditionFunction.wrongArgTypeErrorMessage": "数字または seriesList でなければなりません", - "timelion.serverSideErrors.esFunction.indexNotFoundErrorMessage": "Elasticsearch インデックス {index} が見つかりません", - "timelion.serverSideErrors.holtFunction.missingParamsErrorMessage": "シーズンの長さとサンプルサイズ >= 2 を指定する必要があります", - "timelion.serverSideErrors.holtFunction.notEnoughPointsErrorMessage": "二重指数平滑化を使用するには最低 2 つの点が必要です", - "timelion.serverSideErrors.movingaverageFunction.notValidPositionErrorMessage": "有効な配置: {validPositions}", - "timelion.serverSideErrors.movingstdFunction.notValidPositionErrorMessage": "有効な配置: {validPositions}", - "timelion.serverSideErrors.pointsFunction.notValidSymbolErrorMessage": "有効なシンボル: {validSymbols}", - "timelion.serverSideErrors.quandlFunction.unsupportedIntervalErrorMessage": "quandl() でサポートされていない間隔: {interval}. quandl() でサポートされている間隔: {intervals}", - "timelion.serverSideErrors.sheetParseErrorMessage": "予想: 文字 {column} で {expectedDescription}。", - "timelion.serverSideErrors.unknownArgumentErrorMessage": "{functionName} への不明な引数: {argumentName}", - "timelion.serverSideErrors.unknownArgumentTypeErrorMessage": "引数タイプがサポートされていません: {argument}", - "timelion.serverSideErrors.worldbankFunction.noDataErrorMessage": "Worldbank へのリクエストは成功しましたが、{code} のデータがありませんでした", - "timelion.serverSideErrors.wrongFunctionArgumentTypeErrorMessage": "{functionName} ({argumentName}) は {requiredTypes} の内の 1 つでなければなりません。{actualType} を入手", - "timelion.serverSideErrors.yaxisFunction.notSupportedUnitTypeErrorMessage": "{units} はサポートされているユニットタイプではありません。.", - "timelion.serverSideErrors.yaxisFunction.notValidCurrencyFormatErrorMessage": "通貨は 3 文字のコードでなければなりません", - "timelion.timelionDescription": "関数式で時系列チャートを作成します。", - "timelion.topNavMenu.addChartButtonAriaLabel": "チャートを追加", - "timelion.topNavMenu.addChartButtonLabel": "追加", - "timelion.topNavMenu.delete.modal.confirmButtonLabel": "削除", - "timelion.topNavMenu.delete.modal.successNotificationText": "「{title}」が削除されました", - "timelion.topNavMenu.delete.modal.warningText": "削除されたシートは復元できません。", - "timelion.topNavMenu.delete.modalTitle": "Timelion シート「{title}」を削除しますか?", - "timelion.topNavMenu.deleteSheetButtonAriaLabel": "現在のシートを削除", - "timelion.topNavMenu.deleteSheetButtonLabel": "削除", - "timelion.topNavMenu.helpButtonAriaLabel": "ヘルプ", - "timelion.topNavMenu.helpButtonLabel": "ヘルプ", - "timelion.topNavMenu.newSheetButtonAriaLabel": "新規シート", - "timelion.topNavMenu.newSheetButtonLabel": "新規", - "timelion.topNavMenu.openSheetButtonAriaLabel": "シートを開く", - "timelion.topNavMenu.openSheetButtonLabel": "開く", - "timelion.topNavMenu.openSheetTitle": "シートを開く", - "timelion.topNavMenu.options.columnsCountLabel": "列 (列カウントは 12 できっかりと割れる必要があります)", - "timelion.topNavMenu.options.rowsCountLabel": "行 (これは現在のウィンドウの縦の長さに基づく目標値です)。", - "timelion.topNavMenu.optionsButtonAriaLabel": "オプション", - "timelion.topNavMenu.optionsButtonLabel": "オプション", - "timelion.topNavMenu.save.saveAsDashboardPanel.inputPlaceholder": "このパネルに名前を付ける", - "timelion.topNavMenu.save.saveAsDashboardPanel.selectedExpressionLabel": "現在選択されている式", - "timelion.topNavMenu.save.saveAsDashboardPanel.submitButtonLabel": "保存", - "timelion.topNavMenu.save.saveAsDashboardPanelDescription": "Kibana ダッシュボードにチャートの追加が必要ですか?できます!このオプションは、現在選択されている式を、他のオブジェクトの追加と同じように Kibana ダッシュボードに追加可能なパネルとして保存します。他のパネルへのリファレンスが使用されている場合、リファレンスの表現を直接保存する表現にコピーして、リファレンスを削除する必要があります。他の表現式を保存するよう選択すrには、チャートをクリックします。", - "timelion.topNavMenu.save.saveAsDashboardPanelLabel": "式に名前を付けて保存", - "timelion.topNavMenu.save.saveAsDashboardPanelTitle": "現在の式を Kibana ダッシュボードのパネルとして保存", - "timelion.topNavMenu.save.saveEntireSheet.inputAriaLabel": "名前", - "timelion.topNavMenu.save.saveEntireSheet.inputPlaceholder": "このシートに名前を付ける…", - "timelion.topNavMenu.save.saveEntireSheet.submitButtonLabel": "保存", - "timelion.topNavMenu.save.saveEntireSheetDescription": "Timelion 式を主に Timelion アプリで使用し、Kibana のダッシュボードに Timelion のチャートを追加する必要がない場合は、このオプションを使用します。他のパネルへのリファレンスを使用する場合もこのオプションを使用します。", - "timelion.topNavMenu.save.saveEntireSheetLabel": "シートに名前を付けて保存", - "timelion.topNavMenu.save.saveEntireSheetTitle": "Timelion シート全体の保存", - "timelion.topNavMenu.saveSheetButtonAriaLabel": "シートを保存", - "timelion.topNavMenu.saveSheetButtonLabel": "保存", - "timelion.topNavMenu.sheetOptionsTitle": "シートオプション", - "timelion.topNavMenu.statsDescription": "クエリ時間 {queryTime}ms / 処理時間 {processingTime}ms", - "timelion.uiSettings.defaultColumnsDescription": "デフォルトの Timelion シートの列数です", - "timelion.uiSettings.defaultColumnsLabel": "デフォルトの列", - "timelion.uiSettings.defaultIndexDescription": "{esParam} で検索するデフォルトの Elasticsearch インデックスです", - "timelion.uiSettings.defaultIndexLabel": "デフォルトのインデックス", - "timelion.uiSettings.defaultRowsDescription": "デフォルトの Timelion シートの行数です", - "timelion.uiSettings.defaultRowsLabel": "デフォルトの行", - "timelion.uiSettings.experimentalLabel": "実験的", - "timelion.uiSettings.graphiteURLDescription": "{experimentalLabel}Graphite ホストの URL です", - "timelion.uiSettings.graphiteURLLabel": "Graphite URL", - "timelion.uiSettings.maximumBucketsDescription": "1 つのデータソースが返せるバケットの最大数です", - "timelion.uiSettings.maximumBucketsLabel": "バケットの最大数", - "timelion.uiSettings.minimumIntervalDescription": "「auto」を使用時に計算される最小の間隔です", - "timelion.uiSettings.minimumIntervalLabel": "最低間隔", - "timelion.uiSettings.quandlKeyDescription": "{experimentalLabel} www.quandl.com からの API キーです", - "timelion.uiSettings.quandlKeyLabel": "Quandl キー", - "timelion.uiSettings.showTutorialDescription": "Timelion アプリの起動時にデフォルトでチュートリアルを表示しますか?", - "timelion.uiSettings.showTutorialLabel": "チュートリアルを表示", - "timelion.uiSettings.targetBucketsDescription": "自動間隔の使用時に目標となるバケット数です。", - "timelion.uiSettings.targetBucketsLabel": "目標バケット数", - "timelion.uiSettings.timeFieldDescription": "{esParam} の使用時にタイムスタンプを含むデフォルトのフィールドです", - "timelion.uiSettings.timeFieldLabel": "時間フィールド", - "timelion.vis.expressionLabel": "Timelion 式", - "timelion.vis.intervalLabel": "間隔", - "timelion.help.functions.notAllowedGraphiteUrl": "この Graphite URL は kibana.yml ファイルで構成されていません。\n 「'timelion.graphiteUrls」で kibana.yml ファイルの Graphite サーバーリストを構成して\n Kibana の高度な設定で選択してください", - "timelion.emptyExpressionErrorMessage": "Timelion エラー式が入力されていません", - "core.ui.overlays.banner.attentionTitle": "注意", - "core.ui.overlays.banner.closeButtonLabel": "閉じる", - "core.ui.chrome.headerGlobalNav.goHomePageIconAriaLabel": "ホームページに移動", - "core.ui.chrome.headerGlobalNav.helpMenuButtonAriaLabel": "ヘルプメニュー", - "core.ui.chrome.headerGlobalNav.helpMenuTitle": "ヘルプ", - "core.ui.chrome.headerGlobalNav.helpMenuVersion": "v {version}", - "core.ui.chrome.sideGlobalNav.viewRecentItemsFlyoutTitle": "最近のアイテム", - "core.ui.chrome.sideGlobalNav.viewRecentItemsLabel": "最近閲覧", - "core.ui.recentLinks.linkItem.screenReaderLabel": "{recentlyAccessedItemLinklabel}、タイプ: {pageType}", - "core.ui.legacyBrowserMessage": "この Kibana インストレーションは、現在ご使用のブラウザが満たしていない厳格なセキュリティ要件が有効になっています。", - "core.ui.legacyBrowserTitle": "ブラウザをアップグレードしてください", - "core.ui.welcomeErrorMessage": "Kibana が正常に読み込まれませんでした。詳細はサーバーアウトプットを確認してください。", - "core.ui.welcomeMessage": "Kibana を読み込み中", + "common.ui.visualize.queryGeohashBounds.unableToGetBoundErrorTitle": "バウンドを取得できませんでした", + "console.autocomplete.addMethodMetaText": "メソド", + "console.consoleDisplayName": "コンソール", + "console.consoleMenu.copyAsCurlMessage": "リクエストが URL としてコピーされました", + "console.helpPage.keyboardCommands.autoIndentDescription": "現在のリクエストを自動インデントします", + "console.helpPage.keyboardCommands.closeAutoCompleteMenuDescription": "自動入力メニューを閉じます", + "console.helpPage.keyboardCommands.collapseAllScopesDescription": "現在のスコープを除きすべてのスコープを最小表示します。シフトを追加して拡張します。", + "console.helpPage.keyboardCommands.collapseExpandCurrentScopeDescription": "現在のスコープを最小/拡張表示します。", + "console.helpPage.keyboardCommands.jumpToPreviousNextRequestDescription": "前/次のリクエストの開始または終了に移動します。", + "console.helpPage.keyboardCommands.openAutoCompleteDescription": "自動入力を開きます (未入力時を含む)", + "console.helpPage.keyboardCommands.openDocumentationDescription": "現在のリクエストのドキュメントを開きます", + "console.helpPage.keyboardCommands.selectCurrentlySelectedInAutoCompleteMenuDescription": "現在の選択項目または自動入力メニューで最も使用されている用語を選択します", + "console.helpPage.keyboardCommands.submitRequestDescription": "リクエストを送信します", + "console.helpPage.keyboardCommands.switchFocusToAutoCompleteMenuDescription": "自動入力メニューに焦点を切り替えます。矢印でさらに用語を選択します", + "console.helpPage.keyboardCommandsTitle": "キーボードコマンド", + "console.helpPage.pageTitle": "ヘルプ", + "console.helpPage.requestFormatDescription": "ホワイトエディターに 1 つまたは複数のリクエストを入力できます。コンソールはコンパクトなフォーマットのリクエストを理解できます。", + "console.helpPage.requestFormatTitle": "リクエストフォーマット", + "console.historyPage.applyHistoryButtonLabel": "適用", + "console.historyPage.clearHistoryButtonLabel": "消去", + "console.historyPage.closehistoryButtonLabel": "閉じる", + "console.historyPage.itemOfRequestListAriaLabel": "リクエスト: {historyItem}", + "console.historyPage.noHistoryTextMessage": "履歴がありません", + "console.historyPage.pageTitle": "履歴", + "console.historyPage.requestListAriaLabel": "リクエストの送信履歴", + "console.requestOptions.autoIndentButtonLabel": "自動インデント", + "console.requestOptions.copyAsUrlButtonLabel": "cURL としてコピー", + "console.requestOptions.openDocumentationButtonLabel": "ドキュメントを開く", + "console.requestOptionsButtonAriaLabel": "リクエストオプション", + "console.sendRequestButtonTooltip": "クリックしてリクエストを送信します", + "console.settingsPage.autocompleteLabel": "自動入力", + "console.settingsPage.cancelButtonLabel": "キャンセル", + "console.settingsPage.fieldsLabelText": "フィールド", + "console.settingsPage.fontSizeLabel": "フォントサイズ", + "console.settingsPage.indicesAndAliasesLabelText": "インデックスとエイリアス", + "console.settingsPage.jsonSyntaxLabel": "JSON構文", + "console.settingsPage.pageTitle": "設定", + "console.settingsPage.pollingLabelText": "自動入力候補を自動的に更新", + "console.settingsPage.refreshButtonLabel": "自動入力候補の更新", + "console.settingsPage.refreshingDataDescription": "コンソールは、Elasticsearchをクエリして自動入力候補を更新します。クラスターが大きい場合や、ネットワークの制限がある場合には、自動更新で問題が発生する可能性があります。", + "console.settingsPage.refreshingDataLabel": "自動入力候補を更新しています", + "console.settingsPage.saveButtonLabel": "保存", + "console.settingsPage.templatesLabelText": "テンプレート", + "console.settingsPage.tripleQuotesMessage": "出力ウィンドウでは三重引用符を使用してください", + "console.settingsPage.wrapLongLinesLabelText": "長い行を改行", + "console.topNav.helpTabDescription": "ヘルプ", + "console.topNav.helpTabLabel": "ヘルプ", + "console.topNav.historyTabDescription": "履歴", + "console.topNav.historyTabLabel": "履歴", + "console.topNav.settingsTabDescription": "設定", + "console.topNav.settingsTabLabel": "設定", + "console.welcomePage.closeButtonLabel": "始めましょう", + "console.welcomePage.pageTitle": "コンソールへようこそ", + "console.welcomePage.quickIntroDescription": "コンソール UI は、エディターペイン (左) と応答ペイン (右) の 2 つのペインに分かれています。エディターでリクエストを入力し、Elasticsearch に送信します。結果が右側の応答ペインに表示されます。", + "console.welcomePage.quickIntroTitle": "UI の簡単な説明", + "console.welcomePage.quickTips.cUrlFormatForRequestsDescription": "cURL フォーマットのリクエストを張り付けると、Console 構文に変換されます。", + "console.welcomePage.quickTips.keyboardShortcutsDescription": "ヘルプボタンでキーボードショートカットが学べます。便利な情報が揃っています!", + "console.welcomePage.quickTips.resizeEditorDescription": "間の区切りをドラッグすることで、エディターとアウトプットペインのサイズを変更できます。", + "console.welcomePage.quickTips.submitRequestDescription": "緑の三角形のボタンをクリックして ES にリクエストを送信します。", + "console.welcomePage.quickTips.useWrenchMenuDescription": "レンチメニューで他の便利な機能が使えます。", + "console.welcomePage.quickTipsTitle": "今のうちにいくつか簡単なコツをお教えします", + "console.welcomePage.supportedRequestFormatDescription": "リクエストの入力中、コンソールが候補を提案するので、Enter/Tabを押して確定できます。これらの候補はリクエストの構造、およびインデックス、タイプに基づくものです。", + "console.welcomePage.supportedRequestFormatTitle": "コンソールは cURL と同様に、コンパクトなフォーマットのリクエストを理解できます。", + "core.application.appNotFound.pageDescription": "この URL にアプリケーションが見つかりませんでした。前の画面に戻るか、メニューからアプリを選択してみてください。", + "core.application.appNotFound.title": "アプリケーションが見つかりません", "core.chrome.legacyBrowserWarning": "ご使用のブラウザが Kibana のセキュリティ要件を満たしていません。", "core.euiBasicTable.selectAllRows": "すべての行を選択", "core.euiBasicTable.selectThisRow": "この行を選択", @@ -916,8 +643,14 @@ "core.euiStepNumber.hasErrors": "エラーがあります", "core.euiStepNumber.hasWarnings": "警告があります", "core.euiStepNumber.isComplete": "完了", + "core.euiSuperDatePicker.showDatesButtonLabel": "日付を表示", "core.euiSuperSelect.screenReaderAnnouncement": "{optionsCount} 件のアイテムのフォームセレクターを使用中で、1 つのオプションを選択する必要があります。上下の矢印キーで移動するか、Esc キーで閉じます。", "core.euiSuperSelectControl.selectAnOption": "オプションの選択: {selectedValue} を選択済み", + "core.euiSuperUpdateButton.cannotUpdateTooltip": "アップデートできません", + "core.euiSuperUpdateButton.clickToApplyTooltip": "クリックして適用", + "core.euiSuperUpdateButton.refreshButtonLabel": "更新", + "core.euiSuperUpdateButton.updateButtonLabel": "更新", + "core.euiSuperUpdateButton.updatingButtonLabel": "更新中", "core.euiTablePagination.rowsPerPage": "ページごとの行数", "core.euiTablePagination.rowsPerPageOption": "{rowsPerPage} 行", "core.euiTableSortMobile.sorting": "並べ替え", @@ -931,141 +664,23 @@ "core.notifications.errorToast.closeModal": "閉じる", "core.notifications.unableUpdateUISettingNotificationMessageTitle": "UI 設定を更新できません", "core.toasts.errorToast.seeFullError": "完全なエラーを表示", - "core.euiSuperDatePicker.showDatesButtonLabel": "日付を表示", - "core.euiSuperUpdateButton.cannotUpdateTooltip": "アップデートできません", - "core.euiSuperUpdateButton.clickToApplyTooltip": "クリックして適用", - "core.euiSuperUpdateButton.refreshButtonLabel": "更新", - "core.euiSuperUpdateButton.updateButtonLabel": "更新", - "core.euiSuperUpdateButton.updatingButtonLabel": "更新中", - "core.application.appNotFound.pageDescription": "この URL にアプリケーションが見つかりませんでした。前の画面に戻るか、メニューからアプリを選択してみてください。", - "core.application.appNotFound.title": "アプリケーションが見つかりません", - "kibana-react.tableListView.listing.deleteButtonMessage": "{itemCount} 件の {entityName} を削除", - "kibana-react.tableListView.listing.deleteConfirmModalDescription": "削除された {entityNamePlural} は復元できません。", - "kibana-react.tableListView.listing.deleteSelectedItemsConfirmModal.cancelButtonLabel": "キャンセル", - "kibana-react.tableListView.listing.deleteSelectedItemsConfirmModal.confirmButtonLabel": "削除", - "kibana-react.tableListView.listing.deleteSelectedItemsConfirmModal.confirmButtonLabelDeleting": "削除中", - "kibana-react.tableListView.listing.listingLimitExceeded.advancedSettingsLinkText": "高度な設定", - "kibana-react.tableListView.listing.listingLimitExceededDescription": "{totalItems} 件の {entityNamePlural} がありますが、{listingLimitText} の設定により {listingLimitValue} 件までしか下の表に表示できません。この設定は {advancedSettingsLink} で変更できます。", - "kibana-react.tableListView.listing.listingLimitExceededTitle": "リスティング制限超過", - "kibana-react.tableListView.listing.noAvailableItemsMessage": "利用可能な {entityNamePlural} がありません。", - "kibana-react.tableListView.listing.noMatchedItemsMessage": "検索条件に一致する {entityNamePlural} がありません。", - "kibana-react.tableListView.listing.table.actionTitle": "アクション", - "kibana-react.tableListView.listing.table.editActionDescription": "編集", - "kibana-react.tableListView.listing.table.editActionName": "編集", - "kibana-react.tableListView.listing.unableToDeleteDangerMessage": "{entityName} を削除できません", - "kibana-react.exitFullScreenButton.exitFullScreenModeButtonAriaLabel": "全画面モードを終了", - "kibana-react.exitFullScreenButton.exitFullScreenModeButtonLabel": "全画面を終了", - "kibana-react.exitFullScreenButton.fullScreenModeDescription": "ESC キーで全画面モードを終了します。", - "kibana-react.savedObjects.finder.filterButtonLabel": "タイプ", - "kibana-react.savedObjects.finder.searchPlaceholder": "検索...", - "kibana-react.savedObjects.finder.sortAsc": "昇順", - "kibana-react.savedObjects.finder.sortAuto": "ベストマッチ", - "kibana-react.savedObjects.finder.sortButtonLabel": "並べ替え", - "kibana-react.savedObjects.finder.sortDesc": "降順", - "kibana-react.savedObjects.saveModal.cancelButtonLabel": "キャンセル", - "kibana-react.savedObjects.saveModal.descriptionLabel": "説明", - "kibana-react.savedObjects.saveModal.duplicateTitleDescription": "{confirmSaveLabel} をクリックすると、既存の {objectType} が上書きされます。", - "kibana-react.savedObjects.saveModal.duplicateTitleLabel": "「{title}」というタイトルの {objectType} が既に存在します", - "kibana-react.savedObjects.saveModal.saveAsNewLabel": "新規 {objectType} として保存", - "kibana-react.savedObjects.saveModal.saveButtonLabel": "保存", - "kibana-react.savedObjects.saveModal.saveTitle": "{objectType} を保存", - "kibana-react.savedObjects.saveModal.titleLabel": "タイトル", - "kibana_utils.stateManagement.stateHash.unableToRestoreUrlErrorMessage": "URL を完全に復元できません。共有機能を使用していることを確認してください。", - "kibana_utils.stateManagement.stateHash.unableToStoreHistoryInSessionErrorMessage": "セッションがいっぱいで安全に削除できるアイテムが見つからないため、Kibana は履歴アイテムを保存できません。\n\nこれは大抵新規タブに移動することで解決されますが、より大きな問題が原因である可能性もあります。このメッセージが定期的に表示される場合は、{gitHubIssuesUrl} で問題を報告してください。", - "inspector.closeButton": "インスペクターを閉じる", - "inspector.reqTimestampDescription": "リクエストの開始が記録された時刻です", - "inspector.reqTimestampKey": "リクエストのタイムスタンプ", - "inspector.title": "インスペクター", - "inspector.view": "{viewName} を表示", - "inspector.data.dataDescriptionTooltip": "ビジュアライゼーションの元のデータを表示", - "inspector.data.dataTitle": "データ", - "inspector.data.downloadCSVButtonLabel": "CSV をダウンロード", - "inspector.data.downloadCSVToggleButtonLabel": "CSV をダウンロード", - "inspector.data.filterForValueButtonAriaLabel": "値でフィルタリング", - "inspector.data.filterForValueButtonTooltip": "値でフィルタリング", - "inspector.data.filterOutValueButtonAriaLabel": "値を除外", - "inspector.data.filterOutValueButtonTooltip": "値を除外", - "inspector.data.formattedCSVButtonLabel": "フォーマット済み CSV", - "inspector.data.formattedCSVButtonTooltip": "データを表形式でダウンロード", - "inspector.data.gatheringDataLabel": "データを収集中", - "inspector.data.noDataAvailableDescription": "エレメントがデータを提供しませんでした。", - "inspector.data.noDataAvailableTitle": "利用可能なデータがありません", - "inspector.data.rawCSVButtonLabel": "CSV", - "inspector.data.rawCSVButtonTooltip": "日付をタイムスタンプとしてなど、提供されたデータをそのままダウンロードします", - "inspector.requests.descriptionRowIconAriaLabel": "説明", - "inspector.requests.failedLabel": " (失敗)", - "inspector.requests.noRequestsLoggedDescription.elementHasNotLoggedAnyRequestsText": "エレメントが (まだ) リクエストを記録していません。", - "inspector.requests.noRequestsLoggedDescription.whatDoesItUsuallyMeanText": "これは通常、データを取得する必要がないか、エレメントがまだデータの取得を開始していないことを意味します。", - "inspector.requests.noRequestsLoggedTitle": "リクエストが記録されていません", - "inspector.requests.requestFailedTooltipTitle": "リクエストに失敗しました", - "inspector.requests.requestInProgressAriaLabel": "リクエスト進行中", - "inspector.requests.requestLabel": "リクエスト", - "inspector.requests.requestsDescriptionTooltip": "データを収集したリクエストを表示します", - "inspector.requests.requestsTitle": "リクエスト", - "inspector.requests.requestSucceededTooltipTitle": "リクエスト成功", - "inspector.requests.requestTabLabel": "リクエスト", - "inspector.requests.requestTimeLabel": "{requestTime}ms", - "inspector.requests.requestTooltipDescription": "リクエストの合計所要時間です。", - "inspector.requests.requestWasMadeDescription": "{requestsCount, plural, one {# リクエストが} other {# リクエストが} } 行われました{failedRequests}", - "inspector.requests.requestWasMadeDescription.requestHadFailureText": "、{failedCount} 件に失敗がありました", - "inspector.requests.responseTabLabel": "応答", - "inspector.requests.statisticsTabLabel": "統計", - "console.autocomplete.addMethodMetaText": "メソド", - "console.consoleDisplayName": "コンソール", - "console.devToolsDescription": "cURL をスキップしこの JSON インスタンスを使って、データに直接アクセスします。", - "console.devToolsTitle": "コンソール", - "console.helpPage.keyboardCommands.autoIndentDescription": "現在のリクエストを自動インデントします", - "console.helpPage.keyboardCommands.closeAutoCompleteMenuDescription": "自動入力メニューを閉じます", - "console.helpPage.keyboardCommands.collapseAllScopesDescription": "現在のスコープを除きすべてのスコープを最小表示します。シフトを追加して拡張します。", - "console.helpPage.keyboardCommands.collapseExpandCurrentScopeDescription": "現在のスコープを最小/拡張表示します。", - "console.helpPage.keyboardCommands.jumpToPreviousNextRequestDescription": "前/次のリクエストの開始または終了に移動します。", - "console.helpPage.keyboardCommands.openAutoCompleteDescription": "自動入力を開きます (未入力時を含む)", - "console.helpPage.keyboardCommands.openDocumentationDescription": "現在のリクエストのドキュメントを開きます", - "console.helpPage.keyboardCommands.selectCurrentlySelectedInAutoCompleteMenuDescription": "現在の選択項目または自動入力メニューで最も使用されている用語を選択します", - "console.helpPage.keyboardCommands.submitRequestDescription": "リクエストを送信します", - "console.helpPage.keyboardCommands.switchFocusToAutoCompleteMenuDescription": "自動入力メニューに焦点を切り替えます。矢印でさらに用語を選択します", - "console.helpPage.keyboardCommandsTitle": "キーボードコマンド", - "console.helpPage.pageTitle": "ヘルプ", - "console.helpPage.requestFormatDescription": "ホワイトエディターに 1 つまたは複数のリクエストを入力できます。コンソールはコンパクトなフォーマットのリクエストを理解できます。", - "console.helpPage.requestFormatTitle": "リクエストフォーマット", - "console.historyPage.applyHistoryButtonLabel": "適用", - "console.historyPage.clearHistoryButtonLabel": "消去", - "console.historyPage.itemOfRequestListAriaLabel": "リクエスト: {historyItem}", - "console.historyPage.noHistoryTextMessage": "履歴がありません", - "console.historyPage.pageTitle": "履歴", - "console.historyPage.requestListAriaLabel": "リクエストの送信履歴", - "console.requestOptions.autoIndentButtonLabel": "自動インデント", - "console.requestOptions.copyAsUrlButtonLabel": "cURL としてコピー", - "console.requestOptions.openDocumentationButtonLabel": "ドキュメントを開く", - "console.requestOptionsButtonAriaLabel": "リクエストオプション", - "console.sendRequestButtonTooltip": "クリックしてリクエストを送信します", - "console.settingsPage.autocompleteLabel": "自動入力", - "console.settingsPage.cancelButtonLabel": "キャンセル", - "console.settingsPage.fieldsLabelText": "フィールド", - "console.settingsPage.fontSizeLabel": "フォントサイズ", - "console.settingsPage.indicesAndAliasesLabelText": "インデックスとエイリアス", - "console.settingsPage.pageTitle": "設定", - "console.settingsPage.saveButtonLabel": "保存", - "console.settingsPage.templatesLabelText": "テンプレート", - "console.settingsPage.wrapLongLinesLabelText": "長い行を改行", - "console.topNav.helpTabDescription": "ヘルプ", - "console.topNav.helpTabLabel": "ヘルプ", - "console.topNav.historyTabDescription": "履歴", - "console.topNav.historyTabLabel": "履歴", - "console.topNav.settingsTabDescription": "設定", - "console.topNav.settingsTabLabel": "設定", - "console.welcomePage.closeButtonLabel": "始めましょう", - "console.welcomePage.pageTitle": "コンソールへようこそ", - "console.welcomePage.quickIntroDescription": "コンソール UI は、エディターペイン (左) と応答ペイン (右) の 2 つのペインに分かれています。エディターでリクエストを入力し、Elasticsearch に送信します。結果が右側の応答ペインに表示されます。", - "console.welcomePage.quickIntroTitle": "UI の簡単な説明", - "console.welcomePage.quickTips.cUrlFormatForRequestsDescription": "cURL フォーマットのリクエストを張り付けると、Console 構文に変換されます。", - "console.welcomePage.quickTips.keyboardShortcutsDescription": "ヘルプボタンでキーボードショートカットが学べます。便利な情報が揃っています!", - "console.welcomePage.quickTips.resizeEditorDescription": "間の区切りをドラッグすることで、エディターとアウトプットペインのサイズを変更できます。", - "console.welcomePage.quickTips.submitRequestDescription": "緑の三角形のボタンをクリックして ES にリクエストを送信します。", - "console.welcomePage.quickTips.useWrenchMenuDescription": "レンチメニューで他の便利な機能が使えます。", - "console.welcomePage.quickTipsTitle": "今のうちにいくつか簡単なコツをお教えします", - "console.welcomePage.supportedRequestFormatTitle": "コンソールは cURL と同様に、コンパクトなフォーマットのリクエストを理解できます。", - "console.consoleMenu.copyAsCurlMessage": "リクエストが URL としてコピーされました", + "core.ui.chrome.headerGlobalNav.goHomePageIconAriaLabel": "ホームページに移動", + "core.ui.chrome.headerGlobalNav.helpMenuAskElasticTitle": "Elasticに確認する", + "core.ui.chrome.headerGlobalNav.helpMenuButtonAriaLabel": "ヘルプメニュー", + "core.ui.chrome.headerGlobalNav.helpMenuGiveFeedbackTitle": "フィードバックを作成する", + "core.ui.chrome.headerGlobalNav.helpMenuKibanaDocumentationTitle": "Kibanaドキュメント", + "core.ui.chrome.headerGlobalNav.helpMenuOpenGitHubIssueTitle": "GitHubで問題を開く", + "core.ui.chrome.headerGlobalNav.helpMenuTitle": "ヘルプ", + "core.ui.chrome.headerGlobalNav.helpMenuVersion": "v {version}", + "core.ui.chrome.sideGlobalNav.viewRecentItemsFlyoutTitle": "最近のアイテム", + "core.ui.chrome.sideGlobalNav.viewRecentItemsLabel": "最近閲覧", + "core.ui.overlays.banner.attentionTitle": "注意", + "core.ui.overlays.banner.closeButtonLabel": "閉じる", + "core.ui.recentLinks.linkItem.screenReaderLabel": "{recentlyAccessedItemLinklabel}、タイプ: {pageType}", + "dashboardEmbeddableContainer.actions.toggleExpandPanelMenuItem.expandedDisplayName": "最小化", + "dashboardEmbeddableContainer.actions.toggleExpandPanelMenuItem.notExpandedDisplayName": "全画面", + "dashboardEmbeddableContainer.dashboardGrid.toast.unableToLoadDashboardDangerMessage": "ダッシュボードが読み込めません。", + "dashboardEmbeddableContainer.factory.displayName": "ダッシュボード", "data.filter.applyFilters.popupHeader": "適用するフィルターの選択", "data.filter.applyFiltersPopup.cancelButtonLabel": "キャンセル", "data.filter.applyFiltersPopup.saveButtonLabel": "適用", @@ -1080,6 +695,7 @@ "data.filter.filterBar.filterItemBadgeIconAriaLabel": "削除", "data.filter.filterBar.includeFilterButtonLabel": "結果を含める", "data.filter.filterBar.indexPatternSelectPlaceholder": "インデックスパターンの選択", + "data.filter.filterBar.moreFilterActionsMessage": "フィルター:{innerText}。他のフィルターアクションを使用するには選択してください。", "data.filter.filterBar.negatedFilterPrefix": "NOT ", "data.filter.filterBar.pinFilterButtonLabel": "すべてのアプリにピン付け", "data.filter.filterBar.pinnedFilterPrefix": "ピン付け済み", @@ -1093,7 +709,7 @@ "data.filter.filterEditor.editFilterValuesButtonLabel": "フィルター値を編集", "data.filter.filterEditor.editQueryDslButtonLabel": "クエリ DSL として編集", "data.filter.filterEditor.existsOperatorOptionLabel": "存在する", - "data.filter.filterEditor.falseOptionLabel": "false", + "data.filter.filterEditor.falseOptionLabel": "False", "data.filter.filterEditor.fieldSelectLabel": "フィールド", "data.filter.filterEditor.fieldSelectPlaceholder": "フィールドを選択", "data.filter.filterEditor.indexPatternSelectLabel": "インデックスパターン", @@ -1104,10 +720,14 @@ "data.filter.filterEditor.isOneOfOperatorOptionLabel": "is one of", "data.filter.filterEditor.isOperatorOptionLabel": "が", "data.filter.filterEditor.operatorSelectLabel": "演算子", + "data.filter.filterEditor.operatorSelectPlaceholderSelect": "選択してください", + "data.filter.filterEditor.operatorSelectPlaceholderWaiting": "待機中", + "data.filter.filterEditor.queryDslLabel": "Elasticsearch クエリ DSL", "data.filter.filterEditor.rangeEndInputPlaceholder": "範囲の終了値", + "data.filter.filterEditor.rangeInputLabel": "範囲", "data.filter.filterEditor.rangeStartInputPlaceholder": "範囲の開始値", "data.filter.filterEditor.saveButtonLabel": "保存", - "data.filter.filterEditor.trueOptionLabel": "true", + "data.filter.filterEditor.trueOptionLabel": "True", "data.filter.filterEditor.valueInputLabel": "値", "data.filter.filterEditor.valueInputPlaceholder": "値を入力", "data.filter.filterEditor.valueSelectPlaceholder": "値を選択", @@ -1126,22 +746,26 @@ "data.indexPatterns.unableWriteLabel": "インデックスパターンを書き込めません!このインデックスパターンへの最新の変更を取得するには、ページを更新してください。", "data.indexPatterns.unknownFieldErrorMessage": "インデックスパターン「{title}」のフィールド「{name}」が不明なフィールドタイプを使用しています。", "data.indexPatterns.unknownFieldHeader": "不明なフィールドタイプ {type}", + "data.parseEsInterval.invalidEsCalendarIntervalErrorMessage": "無効なカレンダー間隔:{interval}、1よりも大きな値が必要です", + "data.parseEsInterval.invalidEsIntervalFormatErrorMessage": "無効な間隔フォーマット:{interval}", + "data.query.queryBar.comboboxAriaLabel": "{pageType} ページの検索とフィルタリング", "data.query.queryBar.kqlFullLanguageName": "Kibana クエリ言語", "data.query.queryBar.kqlLanguageName": "KQL", "data.query.queryBar.kqlOffLabel": "オフ", "data.query.queryBar.kqlOnLabel": "オン", "data.query.queryBar.luceneLanguageName": "Lucene", "data.query.queryBar.luceneSyntaxWarningMessage": "Lucene クエリ構文を使用しているようですが、Kibana クエリ言語 (KQL) が選択されています。KQL ドキュメント {link} を確認してください。", + "data.query.queryBar.luceneSyntaxWarningOptOutText": "今後表示しない", "data.query.queryBar.luceneSyntaxWarningTitle": "Lucene 構文警告", + "data.query.queryBar.searchInputAriaLabel": "{pageType} ページの検索とフィルタリングを行うには入力を開始してください", "data.query.queryBar.searchInputPlaceholder": "検索", "data.query.queryBar.syntaxOptionsDescription": "{docsLink} (KQL) は、シンプルなクエリ構文とスクリプトフィールドのサポートを提供します。また、KQL はベーシックライセンス以上をご利用の場合、自動入力も提供します。KQL をオフにすると、Kibana は Lucene を使用します。", "data.query.queryBar.syntaxOptionsDescription.docsLinkText": "こちら", "data.query.queryBar.syntaxOptionsTitle": "構文オプション", - "data.filter.filterEditor.queryDslLabel": "Elasticsearch クエリ DSL", - "data.query.queryBar.luceneSyntaxWarningOptOutText": "今後表示しない", "data.search.searchBar.savedQueryDescriptionLabelText": "説明", "data.search.searchBar.savedQueryDescriptionText": "再度使用するクエリテキストとフィルターを保存します。", "data.search.searchBar.savedQueryForm.titleConflictText": "タイトルが既に保存されているクエリに使用されています", + "data.search.searchBar.savedQueryForm.titleMissingText": "名前が必要です", "data.search.searchBar.savedQueryForm.whitespaceErrorText": "タイトルの始めと終わりにはスペースを使用できません", "data.search.searchBar.savedQueryFormCancelButtonText": "キャンセル", "data.search.searchBar.savedQueryFormSaveButtonText": "保存", @@ -1158,6 +782,7 @@ "data.search.searchBar.savedQueryPopoverConfirmDeletionConfirmButtonText": "削除", "data.search.searchBar.savedQueryPopoverConfirmDeletionTitle": "「{savedQueryName}」を削除しますか?", "data.search.searchBar.savedQueryPopoverDeleteButtonAriaLabel": "保存されたクエリ {savedQueryName} を削除", + "data.search.searchBar.savedQueryPopoverSaveAsNewButtonAriaLabel": "新規保存クエリを保存", "data.search.searchBar.savedQueryPopoverSaveAsNewButtonText": "新規保存", "data.search.searchBar.savedQueryPopoverSaveButtonAriaLabel": "新規保存クエリを保存", "data.search.searchBar.savedQueryPopoverSaveButtonText": "現在のクエリを保存", @@ -1167,60 +792,10 @@ "data.search.searchBar.savedQueryPopoverSavedQueryListItemDescriptionAriaLabel": "{savedQueryName} の説明", "data.search.searchBar.savedQueryPopoverSavedQueryListItemSelectedButtonAriaLabel": "選択されたクエリボタン {savedQueryName} を保存しました。変更を破棄するには押してください。", "data.search.searchBar.savedQueryPopoverTitleText": "保存されたクエリ", - "data.search.searchSource.fetch.shardsFailedModal.close": "閉じる", - "data.search.searchSource.fetch.shardsFailedModal.copyToClipboard": "応答をクリップボードにコピー", - "data.search.searchSource.fetch.shardsFailedModal.failureHeader": "{failureName} で {failureDetails}", - "data.search.searchSource.fetch.shardsFailedModal.showDetails": "詳細を表示", - "data.search.searchSource.fetch.shardsFailedModal.tabHeaderRequest": "リクエスト", - "data.search.searchSource.fetch.shardsFailedModal.tabHeaderResponse": "応答", - "data.search.searchSource.fetch.shardsFailedModal.tabHeaderShardFailures": "シャードエラー", - "data.search.searchSource.fetch.shardsFailedModal.tableColIndex": "インデックス", - "data.search.searchSource.fetch.shardsFailedModal.tableColNode": "ノード", - "data.search.searchSource.fetch.shardsFailedModal.tableColReason": "理由", - "data.search.searchSource.fetch.shardsFailedModal.tableColShard": "シャード", - "data.search.searchSource.fetch.shardsFailedModal.tableRowCollapse": "{rowDescription} を折りたたむ", - "data.search.searchSource.fetch.shardsFailedModal.tableRowExpand": "{rowDescription} を展開する", - "data.search.searchSource.fetch.shardsFailedNotificationDescription": "表示されているデータは不完全か誤りの可能性があります。", - "data.search.searchSource.fetch.requestTimedOutNotificationMessage": "リクエストがタイムアウトしたため、データが不完全な可能性があります", - "data.search.searchSource.fetch.shardsFailedNotificationMessage": "{shardsTotal} 件中 {shardsFailed} 件のシャードでエラーが発生しました", - "data.search.searchSource.hitsDescription": "クエリにより返されたドキュメントの数です。", - "data.search.searchSource.hitsLabel": "ヒット数", - "data.search.searchSource.hitsTotalDescription": "クエリに一致するドキュメントの数です。", - "data.search.searchSource.hitsTotalLabel": "ヒット数 (合計)", - "data.search.searchSource.indexPatternDescription": "Elasticsearch インデックスに接続したインデックスパターンです。", - "data.search.searchSource.indexPatternIdDescription": "{kibanaIndexPattern} インデックス内の ID です。", - "data.search.searchSource.indexPatternIdLabel": "インデックスパターン ID", - "data.search.searchSource.indexPatternLabel": "インデックスパターン", - "data.search.searchSource.noSearchStrategyRegisteredErrorMessageDescription": "検索リクエストの検索方法が見つかりませんでした", - "data.search.searchSource.noSearchStrategyRegisteredErrorMessageTitle": "検索方法が登録されていません", - "data.search.searchSource.queryTimeDescription": "クエリの処理の所要時間です。リクエストの送信やブラウザでのパースの時間は含まれません。", - "data.search.searchSource.queryTimeLabel": "クエリ時間", - "data.search.searchSource.queryTimeValue": "{queryTime}ms", - "data.search.searchSource.requestTimeDescription": "ブラウザから Elasticsearch にリクエストが送信され返されるまでの所要時間です。リクエストがキューで待機していた時間は含まれません。", - "data.search.searchSource.requestTimeLabel": "リクエスト時間", - "data.search.searchSource.requestTimeValue": "{requestTime}ms", - "data.filter.filterEditor.operatorSelectPlaceholderSelect": "選択してください", - "data.filter.filterEditor.operatorSelectPlaceholderWaiting": "待機中", - "data.filter.filterEditor.rangeInputLabel": "範囲", - "data.query.queryBar.comboboxAriaLabel": "{pageType} ページの検索とフィルタリング", - "data.search.searchBar.savedQueryForm.titleMissingText": "名前が必要です", - "data.query.queryBar.searchInputAriaLabel": "{pageType} ページの検索とフィルタリングを行うには入力を開始してください", - "data.search.searchBar.savedQueryPopoverSaveAsNewButtonAriaLabel": "新規保存クエリを保存", - "data.functions.esaggs.help": "AggConfig 集約を実行します", - "data.functions.esaggs.inspector.dataRequest.description": "このリクエストは Elasticsearch にクエリし、ビジュアライゼーション用のデータを取得します。", - "data.functions.esaggs.inspector.dataRequest.title": "データ", - "data.common.esQuery.kql.errors.endOfInputText": "インプットの終わり", - "data.common.esQuery.kql.errors.fieldNameText": "フィールド名", - "data.common.esQuery.kql.errors.literalText": "文字通り", - "data.common.esQuery.kql.errors.syntaxError": "{expectedList} が予測されましたが {foundInput} が検出されました。", - "data.common.esQuery.kql.errors.valueText": "値", - "data.common.esQuery.kql.errors.whitespaceText": "ホワイトスペース", - "devTools.badge.readOnly.text": "読み込み専用", - "devTools.badge.readOnly.tooltip": "を保存できませんでした", - "devTools.k7BreadcrumbsDevToolsLabel": "開発ツール", "embeddableApi.actions.applyFilterActionTitle": "現在のビューにフィルターを適用", "embeddableApi.addPanel.createNewDefaultOption": "新規作成...", "embeddableApi.addPanel.displayName": "パネルの追加", + "embeddableApi.addPanel.noMatchingObjectsMessage": "一致するオブジェクトが見つかりませんでした。", "embeddableApi.addPanel.savedObjectAddedToContainerSuccessMessageTitle": "{savedObjectName} が追加されました", "embeddableApi.addPanel.Title": "パネルの追加", "embeddableApi.customizePanel.action.displayName": "パネルをカスタマイズ", @@ -1235,16 +810,69 @@ "embeddableApi.customizeTitle.optionsMenuForm.resetCustomDashboardButtonLabel": "タイトルをリセット", "embeddableApi.errors.embeddableFactoryNotFound": "{type} を読み込めません。Elasticsearch と Kibana のデフォルトのディストリビューションを適切なライセンスでアップグレードしてください。", "embeddableApi.errors.paneldoesNotExist": "パネルが見つかりません", + "embeddableApi.panel.dashboardPanelAriaLabel": "ダッシュボードパネル", "embeddableApi.panel.editPanel.displayName": "{value} を編集", + "embeddableApi.panel.enhancedDashboardPanelAriaLabel": "ダッシュボードパネル: {title}", "embeddableApi.panel.inspectPanel.displayName": "検査", "embeddableApi.panel.optionsMenu.panelOptionsButtonAriaLabel": "パネルオプション", + "embeddableApi.panel.optionsMenu.panelOptionsButtonEnhancedAriaLabel": "{title} のパネルオプション", "embeddableApi.panel.removePanel.displayName": "ダッシュボードから削除", "embeddableApi.samples.contactCard.displayName": "連絡先カード", "embeddableApi.samples.filterableContainer.displayName": "フィルター可能なダッシュボード", "embeddableApi.samples.filterableEmbeddable.displayName": "フィルター可能", - "embeddableApi.panel.enhancedDashboardPanelAriaLabel": "ダッシュボードパネル: {title}", - "embeddableApi.panel.optionsMenu.panelOptionsButtonEnhancedAriaLabel": "{title} のパネルオプション", - "embeddableApi.panel.dashboardPanelAriaLabel": "ダッシュボードパネル", + "esUi.cronEditor.cronDaily.fieldHour.textAtLabel": "に", + "esUi.cronEditor.cronDaily.fieldTimeLabel": "時間", + "esUi.cronEditor.cronDaily.hourSelectLabel": "時間", + "esUi.cronEditor.cronDaily.minuteSelectLabel": "分", + "esUi.cronEditor.cronHourly.fieldMinute.textAtLabel": "に", + "esUi.cronEditor.cronHourly.fieldTimeLabel": "分", + "esUi.cronEditor.cronMonthly.fieldDateLabel": "日付", + "esUi.cronEditor.cronMonthly.fieldHour.textAtLabel": "に", + "esUi.cronEditor.cronMonthly.fieldTimeLabel": "時間", + "esUi.cronEditor.cronMonthly.hourSelectLabel": "時間", + "esUi.cronEditor.cronMonthly.minuteSelectLabel": "分", + "esUi.cronEditor.cronMonthly.textOnTheLabel": "に", + "esUi.cronEditor.cronWeekly.fieldDateLabel": "日", + "esUi.cronEditor.cronWeekly.fieldHour.textAtLabel": "に", + "esUi.cronEditor.cronWeekly.fieldTimeLabel": "時間", + "esUi.cronEditor.cronWeekly.hourSelectLabel": "時間", + "esUi.cronEditor.cronWeekly.minuteSelectLabel": "分", + "esUi.cronEditor.cronWeekly.textOnLabel": "オン", + "esUi.cronEditor.cronYearly.fieldDate.textOnTheLabel": "に", + "esUi.cronEditor.cronYearly.fieldDateLabel": "日付", + "esUi.cronEditor.cronYearly.fieldHour.textAtLabel": "に", + "esUi.cronEditor.cronYearly.fieldMonth.textInLabel": "に", + "esUi.cronEditor.cronYearly.fieldMonthLabel": "月", + "esUi.cronEditor.cronYearly.fieldTimeLabel": "時間", + "esUi.cronEditor.cronYearly.hourSelectLabel": "時間", + "esUi.cronEditor.cronYearly.minuteSelectLabel": "分", + "esUi.cronEditor.day.friday": "金曜日", + "esUi.cronEditor.day.monday": "月曜日", + "esUi.cronEditor.day.saturday": "土曜日", + "esUi.cronEditor.day.sunday": "日曜日", + "esUi.cronEditor.day.thursday": "木曜日", + "esUi.cronEditor.day.tuesday": "火曜日", + "esUi.cronEditor.day.wednesday": "水曜日", + "esUi.cronEditor.fieldFrequencyLabel": "頻度", + "esUi.cronEditor.month.april": "4 月", + "esUi.cronEditor.month.august": "8 月", + "esUi.cronEditor.month.december": "12 月", + "esUi.cronEditor.month.february": "2 月", + "esUi.cronEditor.month.january": "1 月", + "esUi.cronEditor.month.july": "7 月", + "esUi.cronEditor.month.june": "6 月", + "esUi.cronEditor.month.march": "3 月", + "esUi.cronEditor.month.may": "5 月", + "esUi.cronEditor.month.november": "11 月", + "esUi.cronEditor.month.october": "10 月", + "esUi.cronEditor.month.september": "9 月", + "esUi.cronEditor.textEveryLabel": "毎", + "esUi.forms.comboBoxField.placeHolderText": "入力してエンターキーを押してください", + "esUi.forms.fieldValidation.indexNameInvalidCharactersError": "インデックス名に無効な{characterListLength, plural, one {文字} other {文字}} { characterList } が含まれています。", + "esUi.forms.fieldValidation.indexNameSpacesError": "インデックス名にはスペースを使用できません。", + "esUi.forms.fieldValidation.indexNameStartsWithDotError": "インデックス名の始めにピリオド (.) は使用できません。", + "esUi.forms.fieldValidation.indexPatternInvalidCharactersError": "インデックスパターンに無効な{characterListLength, plural, one {文字} other {文字}} { characterList } が含まれています。", + "esUi.forms.fieldValidation.indexPatternSpacesError": "インデックスパターンにはスペースを使用できません。", "inputControl.control.noIndexPatternTooltip": "index-pattern id が見つかりませんでした: {indexPatternId}.", "inputControl.control.notInitializedTooltip": "コントロールが初期化されていません", "inputControl.control.noValuesDisableTooltip": "「{indexPatternName}」インデックスパターンでいずれのドキュメントにも存在しない「{fieldName}」フィールドがフィルターの対象になっています。異なるフィールドを選択するか、このフィールドに値が入力されているドキュメントをインデックスしてください。", @@ -1286,28 +914,55 @@ "inputControl.vis.inputControlVis.applyChangesButtonLabel": "変更を適用", "inputControl.vis.inputControlVis.cancelChangesButtonLabel": "変更をキャンセル", "inputControl.vis.inputControlVis.clearFormButtonLabel": "用語を消去", + "inputControl.vis.listControl.partialResultsWarningMessage": "リクエストに長くかかり過ぎているため、用語リストが不完全な可能性があります。完全な結果を得るには、kibana.yml の自動完了設定を調整してください。", "inputControl.vis.listControl.selectPlaceholder": "選択してください…", "inputControl.vis.listControl.selectTextPlaceholder": "選択してください…", - "inputControl.vis.listControl.partialResultsWarningMessage": "リクエストに長くかかり過ぎているため、用語リストが不完全な可能性があります。完全な結果を得るには、kibana.yml の自動完了設定を調整してください。", - "visualizations.function.visDimension.accessor.help": "使用するデータセット内の列 (列インデックスまたは列名)", - "visualizations.function.visDimension.error.accessor": "入力された列名は無効です。", - "visualizations.function.visDimension.help": "visConfig ディメンションオブジェクトを生成します", - "expressions.functions.kibana_context.help": "Kibana グローバルコンテキストを更新します", - "expressions.functions.kibana.help": "Kibana グローバルコンテキストを取得します", - "expressions.functions.font.args.alignHelpText": "水平テキスト配置", - "expressions.functions.font.args.colorHelpText": "文字の色です。", - "expressions.functions.font.args.italicHelpText": "テキストを斜体にしますか?", - "expressions.functions.font.args.lHeightHelpText": "ピクセル単位の行の高さです。", - "expressions.functions.font.args.sizeHelpText": "ピクセル単位のフォントサイズです。", - "expressions.functions.font.args.underlineHelpText": "テキストに下線を引きますか?", - "expressions.functions.font.args.weightHelpText": "フォントの重量です。例: {list} または {end}。", - "expressions.functions.fontHelpText": "フォントスタイルを作成します。", + "inspector.closeButton": "インスペクターを閉じる", + "inspector.data.dataDescriptionTooltip": "ビジュアライゼーションの元のデータを表示", + "inspector.data.dataTitle": "データ", + "inspector.data.downloadCSVButtonLabel": "CSV をダウンロード", + "inspector.data.downloadCSVToggleButtonLabel": "CSV をダウンロード", + "inspector.data.filterForValueButtonAriaLabel": "値でフィルタリング", + "inspector.data.filterForValueButtonTooltip": "値でフィルタリング", + "inspector.data.filterOutValueButtonAriaLabel": "値を除外", + "inspector.data.filterOutValueButtonTooltip": "値を除外", + "inspector.data.formattedCSVButtonLabel": "フォーマット済み CSV", + "inspector.data.formattedCSVButtonTooltip": "データを表形式でダウンロード", + "inspector.data.gatheringDataLabel": "データを収集中", + "inspector.data.noDataAvailableDescription": "エレメントがデータを提供しませんでした。", + "inspector.data.noDataAvailableTitle": "利用可能なデータがありません", + "inspector.data.rawCSVButtonLabel": "CSV", + "inspector.data.rawCSVButtonTooltip": "日付をタイムスタンプとしてなど、提供されたデータをそのままダウンロードします", + "inspector.reqTimestampDescription": "リクエストの開始が記録された時刻です", + "inspector.reqTimestampKey": "リクエストのタイムスタンプ", + "inspector.requests.descriptionRowIconAriaLabel": "説明", + "inspector.requests.failedLabel": " (失敗)", + "inspector.requests.noRequestsLoggedDescription.elementHasNotLoggedAnyRequestsText": "エレメントが (まだ) リクエストを記録していません。", + "inspector.requests.noRequestsLoggedDescription.whatDoesItUsuallyMeanText": "これは通常、データを取得する必要がないか、エレメントがまだデータの取得を開始していないことを意味します。", + "inspector.requests.noRequestsLoggedTitle": "リクエストが記録されていません", + "inspector.requests.requestFailedTooltipTitle": "リクエストに失敗しました", + "inspector.requests.requestInProgressAriaLabel": "リクエスト進行中", + "inspector.requests.requestLabel": "リクエスト", + "inspector.requests.requestsDescriptionTooltip": "データを収集したリクエストを表示します", + "inspector.requests.requestsTitle": "リクエスト", + "inspector.requests.requestSucceededTooltipTitle": "リクエスト成功", + "inspector.requests.requestTabLabel": "リクエスト", + "inspector.requests.requestTimeLabel": "{requestTime}ms", + "inspector.requests.requestTooltipDescription": "リクエストの合計所要時間です。", + "inspector.requests.requestWasMadeDescription": "{requestsCount, plural, one {# リクエストが} other {# リクエストが} } 行われました{failedRequests}", + "inspector.requests.requestWasMadeDescription.requestHadFailureText": "、{failedCount} 件に失敗がありました", + "inspector.requests.responseTabLabel": "応答", + "inspector.requests.statisticsTabLabel": "統計", + "inspector.title": "インスペクター", + "inspector.view": "{viewName} を表示", "kbn.advancedSettings.context.defaultSizeText": "コンテキストビューに表示される周りのエントリーの数", "kbn.advancedSettings.context.defaultSizeTitle": "コンテキストサイズ", "kbn.advancedSettings.context.sizeStepText": "コンテキストサイズを増減させる際の最低単位です", "kbn.advancedSettings.context.sizeStepTitle": "コンテキストサイズのステップ", "kbn.advancedSettings.context.tieBreakerFieldsText": "同じタイムスタンプ値のドキュメントを区別するためのコンマ区切りのフィールドのリストです。このリストから、現在のインデックスパターンに含まれ並べ替え可能な初めのフィールドが使用されます。", "kbn.advancedSettings.context.tieBreakerFieldsTitle": "タイブレーカーフィールド", + "kbn.advancedSettings.courier.batchSearchesText": "無効の場合、ダッシュボードパネルは個々に読み込まれ、検索リクエストはユーザーが移動するか\n クエリを更新すると停止します。有効の場合、ダッシュボードパネルはすべてのデータが読み込まれると同時に読み込まれ、\n 検索は停止しません。", + "kbn.advancedSettings.courier.batchSearchesTitle": "同時検索のバッチ処理", "kbn.advancedSettings.courier.customRequestPreference.requestPreferenceLinkText": "リクエスト設定", "kbn.advancedSettings.courier.customRequestPreferenceText": "{setRequestReferenceSetting} が {customSettingValue} に設定されている時に使用される {requestPreferenceLink} です。", "kbn.advancedSettings.courier.customRequestPreferenceTitle": "カスタムリクエスト設定", @@ -1343,12 +998,17 @@ "kbn.advancedSettings.defaultColumnsTitle": "デフォルトの列", "kbn.advancedSettings.defaultIndexText": "インデックスが設定されていない時にアクセスするインデックスです", "kbn.advancedSettings.defaultIndexTitle": "デフォルトのインデックス", + "kbn.advancedSettings.defaultRoute.defaultRouteText": "この設定は、Kibana 起動時のデフォルトのルートを設定します。この設定で、Kibana 起動時のランディングページを変更できます。ルートはスラッシュ (\"/\") で始まる必要があります。", + "kbn.advancedSettings.defaultRoute.defaultRouteTitle": "デフォルトのルート", + "kbn.advancedSettings.defaultRoute.defaultRouteValidationMessage": "ルートはスラッシュ (\"/\") で始まる必要があります。", "kbn.advancedSettings.disableAnimationsText": "Kibana UI の不要なアニメーションをオフにします。変更を適用するにはページを更新してください。", "kbn.advancedSettings.disableAnimationsTitle": "アニメーションを無効にする", "kbn.advancedSettings.discover.aggsTermsSizeText": "「可視化」ボタンをクリックした際に、フィールドドロップダウンやディスカバリサイドバーに可視化される用語の数を設定します。", "kbn.advancedSettings.discover.aggsTermsSizeTitle": "用語数", "kbn.advancedSettings.discover.sampleSizeText": "表に表示する行数です", "kbn.advancedSettings.discover.sampleSizeTitle": "行数", + "kbn.advancedSettings.discover.searchOnPageLoadText": "ディスカバリの最初の読み込み時に検索を実行するかを制御します。この設定は、保存された検索の読み込み時には影響しません。", + "kbn.advancedSettings.discover.searchOnPageLoadTitle": "ページの読み込み時の検索", "kbn.advancedSettings.discover.sortDefaultOrderText": "ディスカバリアプリのインデックスパターンに基づく時刻のデフォルトの並べ替え方向をコントロールします。", "kbn.advancedSettings.discover.sortDefaultOrderTitle": "デフォルトの並べ替え方向", "kbn.advancedSettings.discover.sortOrderAsc": "昇順", @@ -1448,6 +1108,8 @@ "kbn.advancedSettings.visualization.colorMappingTitle": "カラーマッピング", "kbn.advancedSettings.visualization.dimmingOpacityText": "チャートの別のエレメントが選択された時に暗くなるチャート項目の透明度です。この数字が小さければ小さいほど、ハイライトされたエレメントが目立ちます。0 と 1 の間の数字で設定します。", "kbn.advancedSettings.visualization.dimmingOpacityTitle": "減光透明度", + "kbn.advancedSettings.visualization.heatmap.maxBucketsText": "1 つのデータソースが返せるバケットの最大数です。値が大きいとブラウザのレンダリング速度が下がる可能性があります。", + "kbn.advancedSettings.visualization.heatmap.maxBucketsTitle": "ヒートマップの最大バケット数", "kbn.advancedSettings.visualization.loadingDelayText": "クエリの際にビジュアライゼーションを暗くするまでの時間です", "kbn.advancedSettings.visualization.loadingDelayTitle": "読み込み遅延", "kbn.advancedSettings.visualization.showRegionMapWarningsText": "用語がマップの形に合わない場合に地域マップに警告を表示するかどうかです。", @@ -1764,10 +1426,17 @@ "kbn.context.breadcrumb": "{indexPatternTitle}#{docId} のコンテキスト", "kbn.context.failedToLoadAnchorDocumentDescription": "別ののドキュメントの読み込みに失敗しました", "kbn.context.failedToLoadAnchorDocumentErrorDescription": "別のドキュメントの読み込みに失敗しました。", + "kbn.context.loadButtonLabel": "読み込み", "kbn.context.loadingDescription": "読み込み中…", + "kbn.context.newerDocumentsAriaLabel": "新しいドキュメントの数", "kbn.context.newerDocumentsDescription": "新しいドキュメント", + "kbn.context.newerDocumentsWarning": "アンカーよりも新しいドキュメントは {docCount} 件しか見つかりませんでした。", + "kbn.context.newerDocumentsWarningZero": "アンカーよりも新しいドキュメントは見つかりませんでした。", "kbn.context.noSearchableTiebreakerFieldDescription": "インデックスパターン {indexPatternId} で検索可能なタイブレーカーフィールドが見つかりませんでした。高度な設定 {tieBreakerFields} tを変更してこのインデックスパターンの有効なフィールドを含めてください。", + "kbn.context.olderDocumentsAriaLabel": "古いドキュメントの数", "kbn.context.olderDocumentsDescription": "古いドキュメント", + "kbn.context.olderDocumentsWarning": "アンカーよりも古いドキュメントは {docCount} 件しか見つかりませんでした。", + "kbn.context.olderDocumentsWarningZero": "アンカーよりも古いドキュメントは見つかりませんでした。", "kbn.context.reloadPageDescription.discoverLinkText": "ディスカバリ", "kbn.context.reloadPageDescription.reloadOrVisitTextMessage": "再読み込みするか", "kbn.context.reloadPageDescription.selectValidAnchorDocumentTextMessage": "にアクセスして有効な別のドキュメントを選択してください。", @@ -1801,6 +1470,8 @@ "kbn.dashboard.listing.table.entityName": "ダッシュボード", "kbn.dashboard.listing.table.entityNamePlural": "ダッシュボード", "kbn.dashboard.listing.table.titleColumnName": "タイトル", + "kbn.dashboard.panel.invalidData": "URLの無効なデータ", + "kbn.dashboard.panel.unableToMigratePanelDataForSixOneZeroErrorMessage": "「6.1.0」のダッシュボードの互換性のため、パネルデータを移行できませんでした。パネルには想定された列または行フィールドがありません", "kbn.dashboard.panel.unableToMigratePanelDataForSixThreeZeroErrorMessage": "「6.3.0」のダッシュボードの互換性のため、パネルデータを移行できませんでした。パネルに必要なフィールドがありません: {key}", "kbn.dashboard.savedDashboard.newDashboardTitle": "新規ダッシュボード", "kbn.dashboard.savedDashboardsTitle": "ダッシュボード", @@ -1850,25 +1521,6 @@ "kbn.discover.discoverDescription": "ドキュメントにクエリをかけたりフィルターを適用することで、データをインタラクティブに閲覧できます。", "kbn.discover.discoverTitle": "ディスカバー", "kbn.discover.documentsAriaLabel": "ドキュメント", - "kbn.discover.docViews.table.fieldNamesBeginningWithUnderscoreUnsupportedTooltip": "{underscoreSign} で始まるフィールド名はサポートされていません", - "kbn.discover.docViews.table.filterForFieldPresentButtonAriaLabel": "現在のフィールドのフィルター", - "kbn.discover.docViews.table.filterForFieldPresentButtonTooltip": "現在のフィールドのフィルター", - "kbn.discover.docViews.table.filterForValueButtonAriaLabel": "値でフィルタリング", - "kbn.discover.docViews.table.filterForValueButtonTooltip": "値でフィルタリング", - "kbn.discover.docViews.table.filterOutValueButtonAriaLabel": "値を除外", - "kbn.discover.docViews.table.filterOutValueButtonTooltip": "値を除外します", - "kbn.discover.docViews.table.noCachedMappingForThisFieldTooltip": "このフィールドのキャッシュされたマッピングがありません。管理 > インデックスパターンページからフィールドリストを更新してください", - "kbn.discover.docViews.table.tableTitle": "表", - "kbn.discover.docViews.table.toggleColumnInTableButtonAriaLabel": "表の列を切り替える", - "kbn.discover.docViews.table.toggleColumnInTableButtonTooltip": "表の列を切り替える", - "kbn.discover.docViews.table.unableToFilterForPresenceOfMetaFieldsTooltip": "メタフィールドの有無でフィルタリングできません", - "kbn.discover.docViews.table.unableToFilterForPresenceOfScriptedFieldsTooltip": "スクリプトフィールドの有無でフィルタリングできません", - "kbn.discover.docViews.table.unindexedFieldsCanNotBeSearchedTooltip": "インデックスされていないフィールドは検索できません", - "kbn.discover.docViews.json.codeEditorAriaLabel": "Elasticsearch ドキュメントの JSON ビューのみを読み込む", - "kbn.discover.docViews.json.jsonTitle": "JSON", - "kbn.discover.docViews.table.fieldNamesBeginningWithUnderscoreUnsupportedAriaLabel": "警告", - "kbn.discover.docViews.table.noCachedMappingForThisFieldAriaLabel": "警告", - "kbn.discover.docViews.table.toggleFieldDetails": "フィールド詳細を切り替える", "kbn.discover.errorLoadingData": "データの読み込み中にエラーが発生", "kbn.discover.fetchError.howToAddressErrorDescription": "このエラーは、{scriptedFields} タブにある {managementLink} の {fetchErrorScript} フィールドを編集することで解決できます。", "kbn.discover.fetchError.managmentLinkText": "管理 > インデックスパターン", @@ -1888,6 +1540,7 @@ "kbn.discover.fieldChooser.fieldCalculator.analysisIsNotAvailableForGeoFieldsErrorMessage": "ジオフィールドは分析できません。", "kbn.discover.fieldChooser.fieldCalculator.analysisIsNotAvailableForObjectFieldsErrorMessage": "オブジェクトフィールドは分析できません。", "kbn.discover.fieldChooser.fieldCalculator.fieldIsNotPresentInDocumentsErrorMessage": "このフィールドは Elasticsearch マッピングに表示されますが、ドキュメントテーブルの {hitsLength} 件のドキュメントには含まれません。可視化や検索は可能な場合があります。", + "kbn.discover.fieldChooser.fieldFilterFacetButtonLabel": "フィルタリングされたフィールド", "kbn.discover.fieldChooser.filter.aggregatableLabel": "集約可能", "kbn.discover.fieldChooser.filter.availableFieldsTitle": "利用可能なフィールド", "kbn.discover.fieldChooser.filter.hideMissingFieldsLabel": "未入力のフィールドを非表示", @@ -1896,8 +1549,10 @@ "kbn.discover.fieldChooser.filter.searchableLabel": "検索可能", "kbn.discover.fieldChooser.filter.selectedFieldsTitle": "スクリプトフィールド", "kbn.discover.fieldChooser.filter.typeLabel": "タイプ", + "kbn.discover.fieldChooser.searchPlaceHolder": "検索フィールド", "kbn.discover.fieldChooser.toggleFieldFilterButtonHideAriaLabel": "フィールド設定を非表示", "kbn.discover.fieldChooser.toggleFieldFilterButtonShowAriaLabel": "フィールド設定を表示", + "kbn.discover.histogram.partialData.bucketTooltipText": "選択された時間範囲にはこのバケット全体は含まれていませんが、一部データが含まれている可能性があります。", "kbn.discover.histogramOfFoundDocumentsAriaLabel": "発見されたドキュメントのヒストグラム", "kbn.discover.hitsPluralTitle": "{hits, plural, one {ヒット} other {ヒット}}", "kbn.discover.howToChangeTheTimeTooltip": "時刻を変更するには、ナビゲーションバーのカレンダーアイコンをクリックします", @@ -1910,6 +1565,7 @@ "kbn.discover.localMenu.openInspectorForSearchDescription": "検索用にインスペクターを開きます", "kbn.discover.localMenu.openSavedSearchDescription": "保存された検索を開きます", "kbn.discover.localMenu.openTitle": "開く", + "kbn.discover.localMenu.saveSaveSearchDescription": "ビジュアライゼーションとダッシュボードで使用できるようにディスカバリの検索を保存します", "kbn.discover.localMenu.saveSearchDescription": "検索を保存します", "kbn.discover.localMenu.saveTitle": "保存", "kbn.discover.localMenu.shareSearchDescription": "検索を共有します", @@ -1933,6 +1589,7 @@ "kbn.discover.notifications.notSavedSearchTitle": "検索「{savedSearchTitle}」は保存されませんでした。", "kbn.discover.notifications.savedSearchTitle": "検索「{savedSearchTitle}」が保存されました。", "kbn.discover.painlessError.painlessScriptedFieldErrorMessage": "Painless スクリプトのフィールド「{script}」のエラー.", + "kbn.discover.reloadSavedSearchButton": "検索をリセット", "kbn.discover.rootBreadcrumb": "ディスカバリ", "kbn.discover.savedSearch.savedObjectName": "保存された検索", "kbn.discover.scaledToDescription": "{bucketIntervalDescription} にスケーリング済み", @@ -1943,13 +1600,21 @@ "kbn.discover.topNav.openSearchPanel.manageSearchesButtonLabel": "検索の管理", "kbn.discover.topNav.openSearchPanel.noSearchesFoundDescription": "一致する検索が見つかりませんでした。", "kbn.discover.topNav.openSearchPanel.openSearchTitle": "検索を開く", + "kbn.discover.uninitializedRefreshButtonText": "データを更新", + "kbn.discover.uninitializedText": "クエリを作成、フィルターを追加、または [更新] をクリックして、現在のクエリの結果を取得します。", + "kbn.discover.uninitializedTitle": "検索開始", "kbn.discover.valueIsNotConfiguredIndexPatternIDWarningTitle": "{stateVal} は設定されたインデックスパターン ID ではありません", "kbn.discoverTitle": "ディスカバリ", + "kbn.doc.couldNotFindDocumentsDescription": "その ID に一致するドキュメントがありません。", "kbn.doc.failedToExecuteQueryDescription": "クエリの実行に失敗しました", "kbn.doc.failedToLocateDocumentDescription": "ドキュメントが見つかりませんでした", + "kbn.doc.failedToLocateIndexPattern": "ID {indexPatternId} に一致するインデックスパターンがありません", "kbn.doc.loadingDescription": "読み込み中…", + "kbn.doc.somethingWentWrongDescription": "{indexName} が欠けています。", + "kbn.doc.somethingWentWrongDescriptionAddon": "インデックスが存在することを確認してください。", "kbn.docTable.limitedSearchResultLabel": "{resultCount} 件の結果に制限。検索結果の絞り込み。", "kbn.docTable.noResultsTitle": "結果が見つかりませんでした", + "kbn.docTable.pagerControl.pagesCountLabel": "{startItem}–{endItem} of {totalItems}", "kbn.docTable.tableHeader.moveColumnLeftButtonAriaLabel": "{columnName} 列を左に移動", "kbn.docTable.tableHeader.moveColumnLeftButtonTooltip": "列を左に移動", "kbn.docTable.tableHeader.moveColumnRightButtonAriaLabel": "{columnName} 列を右に移動", @@ -1958,6 +1623,7 @@ "kbn.docTable.tableHeader.removeColumnButtonTooltip": "列の削除", "kbn.docTable.tableHeader.sortByColumnAscendingAriaLabel": "{columnName} を昇順に並べ替える", "kbn.docTable.tableHeader.sortByColumnDescendingAriaLabel": "{columnName} を降順に並べ替える", + "kbn.docTable.tableHeader.sortByColumnUnsortedAriaLabel": "{columnName} で並べ替えを止める", "kbn.docTable.tableRow.detailHeading": "拡張ドキュメント", "kbn.docTable.tableRow.filterForValueButtonAriaLabel": "値でフィルタリング", "kbn.docTable.tableRow.filterForValueButtonTooltip": "値でフィルタリング", @@ -1969,6 +1635,8 @@ "kbn.embeddable.errorTitle": "データの取得中にエラーが発生", "kbn.embeddable.inspectorRequestDataTitle": "データ", "kbn.embeddable.inspectorRequestDescription": "このリクエストは Elasticsearch にクエリをかけ、検索データを取得します。", + "kbn.embeddable.search.displayName": "検索", + "kbn.embeddable.visualizations.displayName": "ビジュアライゼーション", "kbn.home.addData.addDataToKibanaDescription": "これらのソリューションで、データを作成済みのダッシュボードと監視システムへとすぐに変えることができます。", "kbn.home.addData.addDataToKibanaTitle": "Kibana にデータを追加", "kbn.home.addData.apm.addApmButtonLabel": "APM を追加", @@ -1982,12 +1650,21 @@ "kbn.home.addData.metrics.nameTitle": "メトリック", "kbn.home.addData.sampleDataLink": "データセットと Kibana ダッシュボードを読み込む", "kbn.home.addData.sampleDataTitle": "サンプルデータの追加", + "kbn.home.addData.siem.addSiemEventsButtonLabel": "セキュリティイベントを追加", + "kbn.home.addData.siem.nameDescription": "即利用可能なビジュアライゼーションで、セキュリティイベントをまとめてインタラクティブな調査を可能にします。", + "kbn.home.addData.siem.nameTitle": "SIEM", "kbn.home.addData.uploadFileLink": "CSV、NDJSON、またはログファイルをインポート", "kbn.home.addData.uploadFileTitle": "ログファイルからデータをアップロード", "kbn.home.addData.yourDataLink": "Elasticsearch インデックスに接続", "kbn.home.addData.yourDataTitle": "Elasticsearch データの使用", "kbn.home.breadcrumbs.addDataTitle": "データの投入", "kbn.home.breadcrumbs.homeTitle": "ホーム", + "kbn.home.dataManagementDisableCollection": "収集を停止するには、", + "kbn.home.dataManagementDisableCollectionLink": "ここで使用状況データを無効にします。", + "kbn.home.dataManagementDisclaimerPrivacy": "使用状況データがどのように製品とサービスの管理と改善につながるのかに関する詳細については ", + "kbn.home.dataManagementDisclaimerPrivacyLink": "プライバシーポリシーをご覧ください。", + "kbn.home.dataManagementEnableCollection": " 収集を開始するには、", + "kbn.home.dataManagementEnableCollectionLink": "ここで使用状況データを有効にします。", "kbn.home.directories.manage.nameTitle": "Elastic Stack の管理", "kbn.home.directories.notFound.description": "お探しのものが見つかりませんでしたか?", "kbn.home.directories.notFound.viewFullButtonLabel": "Kibana プラグインの完全なディレクトリを表示", @@ -2052,9 +1729,11 @@ "kbn.home.tutorial.tabs.loggingTitle": "ログ", "kbn.home.tutorial.tabs.metricsTitle": "メトリック", "kbn.home.tutorial.tabs.sampleDataTitle": "サンプルデータ", + "kbn.home.tutorial.tabs.siemTitle": "SIEM", "kbn.home.tutorial.unexpectedStatusCheckStateErrorDescription": "予期せぬステータス確認ステータス {statusCheckState}", "kbn.home.tutorial.unhandledInstructionTypeErrorDescription": "予期せぬ指示タイプ {visibleInstructions}", "kbn.home.welcomeDescription": "Elastic Stack への開かれた窓", + "kbn.home.welcomeHomePageHeader": "Kibana ホーム", "kbn.home.welcomeTitle": "Kibana へようこそ", "kbn.management.advancedSettings.badge.readOnly.text": "読み込み専用", "kbn.management.advancedSettings.badge.readOnly.tooltip": "高度な設定を保存できません", @@ -2242,6 +1921,7 @@ "kbn.management.objects.objectsTable.deleteSavedObjectsConfirmModalTitle": "保存されたオブジェクトの削除", "kbn.management.objects.objectsTable.export.dangerNotification": "エクスポートを生成できません", "kbn.management.objects.objectsTable.export.successNotification": "ファイルはバックグラウンドでダウンロード中です", + "kbn.management.objects.objectsTable.export.successWithMissingRefsNotification": "ファイルはバックグラウンドでダウンロード中です。一部の関連オブジェクトが見つかりませんでした。足りないオブジェクトの一覧は、エクスポートされたファイルの最後の行をご覧ください。", "kbn.management.objects.objectsTable.exportObjectsConfirmModal.cancelButtonLabel": "キャンセル", "kbn.management.objects.objectsTable.exportObjectsConfirmModal.exportAllButtonLabel": "すべてエクスポート:", "kbn.management.objects.objectsTable.exportObjectsConfirmModal.exportOptionsLabel": "オプション", @@ -2357,6 +2037,7 @@ "kbn.management.settings.categoryNames.notificationsLabel": "通知", "kbn.management.settings.categoryNames.reportingLabel": "レポート", "kbn.management.settings.categoryNames.searchLabel": "検索", + "kbn.management.settings.categoryNames.siemLabel": "SIEM", "kbn.management.settings.categoryNames.timelionLabel": "Timelion", "kbn.management.settings.categoryNames.visualizationsLabel": "ビジュアライゼーション", "kbn.management.settings.categorySearchLabel": "カテゴリー", @@ -2371,6 +2052,7 @@ "kbn.management.settings.field.defaultValueTypeJsonText": "デフォルト: {value}", "kbn.management.settings.field.helpText": "この設定は Kibana サーバーにより上書きされ、変更することはできません。", "kbn.management.settings.field.imageChangeErrorMessage": "画像を保存できませんでした", + "kbn.management.settings.field.imageTooLargeErrorMessage": "画像が大きすぎます。最大サイズは {maxSizeDescription} です", "kbn.management.settings.field.offLabel": "オフ", "kbn.management.settings.field.onLabel": "オン", "kbn.management.settings.field.requiresPageReloadToastButtonLabel": "ページを再読み込み", @@ -2430,12 +2112,14 @@ "kbn.server.tutorials.apm.dotNetClient.configureApplication.textPost": "「IConfiguration」インスタンスを渡すのはオプションで、これにより、エージェントはこの「IConfiguration」インスタンス (例: 「appsettings.json」ファイル) から構成を読み込みます。", "kbn.server.tutorials.apm.dotNetClient.configureApplication.textPre": "「Elastic.Apm.NetCoreAll」パッケージの ASP.NET Core の場合、「Startup.cs」ファイル内の「Configure」メソドの「UseElasticApm」メソドを呼び出します。", "kbn.server.tutorials.apm.dotNetClient.configureApplication.title": "エージェントをアプリケーションに追加", + "kbn.server.tutorials.apm.dotNetClient.download.textPre": "[NuGet]({allNuGetPackagesLink}) から .NET アプリケーションにエージェントパッケージを追加してください。用途の異なる複数の NuGet パッケージがあります。\n\nEntity Framework Core の ASP.NET Core アプリケーションの場合は、[Elastic.Apm.NetCoreAll]({netCoreAllApmPackageLink}) パッケージをダウンロードしてください。このパッケージは、自動的にすべてのエージェントコンポーネントをアプリケーションに追加します。\n\n 依存性を最低限に抑えたい場合、ASP.NET Core の監視のみに [Elastic.Apm.AspNetCore]({aspNetCorePackageLink}) パッケージ、または Entity Framework Core の監視のみに [Elastic.Apm.EfCore]({efCorePackageLink}) パッケージを使用することができます。\n\n 手動インストルメンテーションのみにパブリック Agent API を使用する場合は、[Elastic.Apm]({elasticApmPackageLink}) パッケージを使用してください。", "kbn.server.tutorials.apm.dotNetClient.download.title": "APM エージェントのダウンロード", "kbn.server.tutorials.apm.downloadServer.title": "APM Server をダウンロードして展開します", "kbn.server.tutorials.apm.downloadServerRpm": "32 ビットパッケージをお探しですか?[ダウンロードページ]({downloadPageLink}) をご覧ください。", "kbn.server.tutorials.apm.downloadServerTitle": "32 ビットパッケージをお探しですか?[ダウンロードページ]({downloadPageLink}) をご覧ください。", "kbn.server.tutorials.apm.editConfig.textPre": "Elastic Stack の X-Pack セキュアバージョンをご使用の場合、「apm-server.yml」構成ファイルで認証情報を指定する必要があります。", "kbn.server.tutorials.apm.editConfig.title": "構成の変更", + "kbn.server.tutorials.apm.elasticCloud.textPre": "APM サーバーを有効にするには、[the Elastic Cloud console](https://cloud.elastic.co/deployments?q={cloudId}) に移動し、展開設定で APM を有効にします。有効にした後、このページを更新してください。", "kbn.server.tutorials.apm.elasticCloudInstructions.title": "APM エージェント", "kbn.server.tutorials.apm.flaskClient.configure.commands.allowedCharactersComment": "a-z、A-Z、0-9、-、_、スペース", "kbn.server.tutorials.apm.flaskClient.configure.commands.configureElasticApmComment": "またはアプリケーションの設定で ELASTIC_APM を使用するよう構成します。", @@ -2467,9 +2151,6 @@ "kbn.server.tutorials.apm.javaClient.startApplication.textPost": "構成オプションと高度な用途に関しては、[ドキュメンテーション]({documentationLink}) をご覧ください。", "kbn.server.tutorials.apm.javaClient.startApplication.textPre": "「-javaagent」フラグを追加してエージェントをシステムプロパティで構成します。\n\n * 必要なサービス名を設定します (使用可能な文字は a-z、A-Z、0-9、-、_、スペースです)\n * カスタム APM Server URL を設定します (デフォルト: {customApmServerUrl})\n * アプリケーションのベースパッケージを設定します", "kbn.server.tutorials.apm.javaClient.startApplication.title": "javaagent フラグのアプリケーションの起動", - "kbn.server.tutorials.apm.jsClient.installDependency.commands.setCustomApmServerUrlComment": "カスタム APM Server URL (デフォルト: {defaultApmServerUrl})", - "kbn.server.tutorials.apm.jsClient.installDependency.commands.setRequiredServiceNameComment": "必要なサービス名を設定します (使用可能な文字は a-z、A-Z、0-9、-、_、スペースです)", - "kbn.server.tutorials.apm.jsClient.installDependency.commands.setServiceVersionComment": "サーバーバージョンを設定します (ソースマップ機能に必要)", "kbn.server.tutorials.apm.jsClient.enableRealUserMonitoring.textPre": "[ドキュメンテーション({documentationLink}) をご覧ください。", "kbn.server.tutorials.apm.jsClient.enableRealUserMonitoring.title": "APM Server の Real User 監視エージェントを有効にする", "kbn.server.tutorials.apm.nodeClient.configure.commands.addThisToTheFileTopComment": "アプリに読み込まれたファイルの一番上にこれを追加します", @@ -2540,6 +2221,10 @@ "kbn.server.tutorials.couchbaseMetrics.longDescription": "「couchbase」Metricbeat モジュールは、Couchbase から内部メトリックを取得します。 [詳細]({learnMoreLink})。", "kbn.server.tutorials.couchbaseMetrics.nameTitle": "Couchbase メトリック", "kbn.server.tutorials.couchbaseMetrics.shortDescription": "Couchbase から内部メトリックを取得します。", + "kbn.server.tutorials.couchdbMetrics.artifacts.dashboards.linkLabel": "CouchDB メトリックダッシュボード", + "kbn.server.tutorials.couchdbMetrics.longDescription": "「couchdb」Metricbeat モジュールが、CouchDB から監視メトリックを取得します。[詳細] ({learnMoreLink})。", + "kbn.server.tutorials.couchdbMetrics.nameTitle": "CouchDB メトリック", + "kbn.server.tutorials.couchdbMetrics.shortDescription": "CouchdB サーバーから監視メトリックを取得します。", "kbn.server.tutorials.dockerMetrics.artifacts.dashboards.linkLabel": "Docker メトリックダッシュボード", "kbn.server.tutorials.dockerMetrics.longDescription": "「docker」 Metricbeat モジュールは、Docker サーバーからメトリックを取得します。[詳細]({learnMoreLink})。", "kbn.server.tutorials.dockerMetrics.nameTitle": "Docker メトリック", @@ -2762,6 +2447,8 @@ "kbn.visualize.linkedToSearch.unlinkButtonTooltip": "保存された検索からリンクを解除するにはダブルクリックします", "kbn.visualize.linkedToSearch.unlinkSuccessNotificationText": "保存された検索「{searchTitle}」からリンクが解除されました", "kbn.visualize.linkedToSearchInfoText": "保存された検索にリンクされています", + "kbn.visualize.listing.betaTitle": "ベータ", + "kbn.visualize.listing.betaTooltip": "このビジュアライゼーションはベータ段階で、変更される可能性があります。デザインとコードはオフィシャル GA 機能よりも完成度が低く、現状のまま保証なしで提供されています。ベータ機能にはオフィシャル GA 機能の SLA が適用されません", "kbn.visualize.listing.breadcrumb": "可視化", "kbn.visualize.listing.createNew.createButtonLabel": "新規ビジュアライゼーションを追加", "kbn.visualize.listing.createNew.description": "データに基づき異なるビジュアライゼーションを作成できます。", @@ -2774,6 +2461,8 @@ "kbn.visualize.listing.table.listTitle": "ビジュアライゼーション", "kbn.visualize.listing.table.titleColumnName": "タイトル", "kbn.visualize.listing.table.typeColumnName": "タイプ", + "kbn.visualize.newVisWizard.betaDescription": "このビジュアライゼーションはベータ段階で、変更される可能性があります。デザインとコードはオフィシャル GA 機能よりも完成度が低く、現状のまま保証なしで提供されています。ベータ機能にはオフィシャル GA 機能の SLA が適用されません", + "kbn.visualize.newVisWizard.betaTitle": "ベータ", "kbn.visualize.newVisWizard.chooseSourceTitle": "ソースの選択", "kbn.visualize.newVisWizard.experimentalDescription": "このビジュアライゼーションは実験的なものです。デザインと導入は安定したビジュアライゼーションよりも完成度が低く、変更される可能性があります。", "kbn.visualize.newVisWizard.experimentalTitle": "実験的", @@ -2788,6 +2477,9 @@ "kbn.visualize.newVisWizard.searchSelection.savedObjectType.search": "保存された検索", "kbn.visualize.newVisWizard.selectVisType": "ビジュアライゼーションのタイプを選択してください", "kbn.visualize.newVisWizard.title": "新規ビジュアライゼーション", + "kbn.visualize.newVisWizard.visTypeAliasDescription": "Visualize外でKibanaアプリケーションを開きます。", + "kbn.visualize.newVisWizard.visTypeAliasTitle": "Kibanaアプリケーション", + "kbn.visualize.pageHeading": "{chartName} {chartType} ビジュアライゼーション", "kbn.visualize.saveDialog.saveAndAddToDashboardButtonLabel": "保存してダッシュボードに追加", "kbn.visualize.savedObjectName": "ビジュアライゼーション", "kbn.visualize.topNavMenu.openInspectorButtonAriaLabel": "ビジュアライゼーションのインスペクターを開く", @@ -2804,80 +2496,68 @@ "kbn.visualize.wizard.step1Breadcrumb": "作成", "kbn.visualize.wizard.step2Breadcrumb": "作成", "kbn.visualizeTitle": "可視化", - "kbn.advancedSettings.discover.searchOnPageLoadText": "ディスカバリの最初の読み込み時に検索を実行するかを制御します。この設定は、保存された検索の読み込み時には影響しません。", - "kbn.advancedSettings.discover.searchOnPageLoadTitle": "ページの読み込み時の検索", - "kbn.advancedSettings.visualization.heatmap.maxBucketsText": "1 つのデータソースが返せるバケットの最大数です。値が大きいとブラウザのレンダリング速度が下がる可能性があります。", - "kbn.advancedSettings.visualization.heatmap.maxBucketsTitle": "ヒートマップの最大バケット数", - "kbn.discover.localMenu.saveSaveSearchDescription": "ビジュアライゼーションとダッシュボードで使用できるようにディスカバリの検索を保存します", - "kbn.discover.uninitializedRefreshButtonText": "データを更新", - "kbn.discover.uninitializedText": "クエリを作成、フィルターを追加、または [更新] をクリックして、現在のクエリの結果を取得します。", - "kbn.discover.uninitializedTitle": "検索開始", - "kbn.docTable.tableHeader.sortByColumnUnsortedAriaLabel": "{columnName} で並べ替えを止める", - "kbn.embeddable.search.displayName": "検索", - "kbn.embeddable.visualizations.displayName": "ビジュアライゼーション", - "kbn.home.addData.siem.addSiemEventsButtonLabel": "セキュリティイベントを追加", - "kbn.home.addData.siem.nameDescription": "即利用可能なビジュアライゼーションで、セキュリティイベントをまとめてインタラクティブな調査を可能にします。", - "kbn.home.addData.siem.nameTitle": "SIEM", - "kbn.home.tutorial.tabs.siemTitle": "SIEM", - "kbn.home.welcomeHomePageHeader": "Kibana ホーム", - "kbn.discover.reloadSavedSearchButton": "検索をリセット", - "kbn.server.tutorials.apm.dotNetClient.download.textPre": "[NuGet]({allNuGetPackagesLink}) から .NET アプリケーションにエージェントパッケージを追加してください。用途の異なる複数の NuGet パッケージがあります。\n\nEntity Framework Core の ASP.NET Core アプリケーションの場合は、[Elastic.Apm.NetCoreAll]({netCoreAllApmPackageLink}) パッケージをダウンロードしてください。このパッケージは、自動的にすべてのエージェントコンポーネントをアプリケーションに追加します。\n\n 依存性を最低限に抑えたい場合、ASP.NET Core の監視のみに [Elastic.Apm.AspNetCore]({aspNetCorePackageLink}) パッケージ、または Entity Framework Core の監視のみに [Elastic.Apm.EfCore]({efCorePackageLink}) パッケージを使用することができます。\n\n 手動インストルメンテーションのみにパブリック Agent API を使用する場合は、[Elastic.Apm]({elasticApmPackageLink}) パッケージを使用してください。", - "kbn.server.tutorials.apm.elasticCloud.textPre": "APM サーバーを有効にするには、[the Elastic Cloud console](https://cloud.elastic.co/deployments?q={cloudId}) に移動し、展開設定で APM を有効にします。有効にした後、このページを更新してください。", - "kbn.advancedSettings.defaultRoute.defaultRouteText": "この設定は、Kibana 起動時のデフォルトのルートを設定します。この設定で、Kibana 起動時のランディングページを変更できます。ルートはスラッシュ (\"/\") で始まる必要があります。", - "kbn.advancedSettings.defaultRoute.defaultRouteTitle": "デフォルトのルート", - "kbn.advancedSettings.defaultRoute.defaultRouteValidationMessage": "ルートはスラッシュ (\"/\") で始まる必要があります。", - "kbn.context.loadButtonLabel": "読み込み", - "kbn.context.newerDocumentsAriaLabel": "新しいドキュメントの数", - "kbn.context.newerDocumentsWarning": "アンカーよりも新しいドキュメントは {docCount} 件しか見つかりませんでした。", - "kbn.context.newerDocumentsWarningZero": "アンカーよりも新しいドキュメントは見つかりませんでした。", - "kbn.context.olderDocumentsAriaLabel": "古いドキュメントの数", - "kbn.context.olderDocumentsWarning": "アンカーよりも古いドキュメントは {docCount} 件しか見つかりませんでした。", - "kbn.context.olderDocumentsWarningZero": "アンカーよりも古いドキュメントは見つかりませんでした。", - "kbn.discover.fieldChooser.fieldFilterFacetButtonLabel": "フィルタリングされたフィールド", - "kbn.discover.fieldChooser.searchPlaceHolder": "検索フィールド", - "kbn.discover.histogram.partialData.bucketTooltipText": "選択された時間範囲にはこのバケット全体は含まれていませんが、一部データが含まれている可能性があります。", - "kbn.doc.failedToLocateIndexPattern": "ID {indexPatternId} に一致するインデックスパターンがありません", - "kbn.doc.somethingWentWrongDescriptionAddon": "インデックスが存在することを確認してください。", - "kbn.management.objects.objectsTable.export.successWithMissingRefsNotification": "ファイルはバックグラウンドでダウンロード中です。一部の関連オブジェクトが見つかりませんでした。足りないオブジェクトの一覧は、エクスポートされたファイルの最後の行をご覧ください。", - "kbn.management.settings.categoryNames.siemLabel": "SIEM", - "kbn.management.settings.field.imageTooLargeErrorMessage": "画像が大きすぎます。最大サイズは {maxSizeDescription} です", - "kbn.server.tutorials.couchdbMetrics.artifacts.dashboards.linkLabel": "CouchDB メトリックダッシュボード", - "kbn.server.tutorials.couchdbMetrics.longDescription": "「couchdb」Metricbeat モジュールが、CouchDB から監視メトリックを取得します。[詳細] ({learnMoreLink})。", - "kbn.server.tutorials.couchdbMetrics.nameTitle": "CouchDB メトリック", - "kbn.server.tutorials.couchdbMetrics.shortDescription": "CouchdB サーバーから監視メトリックを取得します。", - "kbn.visualize.listing.betaTitle": "ベータ", - "kbn.visualize.listing.betaTooltip": "このビジュアライゼーションはベータ段階で、変更される可能性があります。デザインとコードはオフィシャル GA 機能よりも完成度が低く、現状のまま保証なしで提供されています。ベータ機能にはオフィシャル GA 機能の SLA が適用されません", - "kbn.visualize.newVisWizard.betaDescription": "このビジュアライゼーションはベータ段階で、変更される可能性があります。デザインとコードはオフィシャル GA 機能よりも完成度が低く、現状のまま保証なしで提供されています。ベータ機能にはオフィシャル GA 機能の SLA が適用されません", - "kbn.visualize.newVisWizard.betaTitle": "ベータ", - "kbn.visualize.pageHeading": "{chartName} {chartType} ビジュアライゼーション", - "kbn.advancedSettings.courier.batchSearchesText": "無効の場合、ダッシュボードパネルは個々に読み込まれ、検索リクエストはユーザーが移動するか\n クエリを更新すると停止します。有効の場合、ダッシュボードパネルはすべてのデータが読み込まれると同時に読み込まれ、\n 検索は停止しません。", - "kbn.doc.couldNotFindDocumentsDescription": "その ID に一致するドキュメントがありません。", - "kbn.doc.somethingWentWrongDescription": "{indexName} が欠けています。", "kbnVislibVisTypes.area.areaDescription": "折れ線グラフの下の数量を強調します。", "kbnVislibVisTypes.area.areaTitle": "エリア", + "kbnVislibVisTypes.area.countText": "カウント", "kbnVislibVisTypes.area.groupTitle": "系列を分割", "kbnVislibVisTypes.area.metricsTitle": "Y 軸", "kbnVislibVisTypes.area.radiusTitle": "点のサイズ", "kbnVislibVisTypes.area.segmentTitle": "X 軸", "kbnVislibVisTypes.area.splitTitle": "チャートを分割", - "kbnVislibVisTypes.controls.gaugeOptions.alignmentLabel": "アラインメント", - "kbnVislibVisTypes.controls.gaugeOptions.displayWarningsLabel": "警告を表示", - "kbnVislibVisTypes.controls.gaugeOptions.rangesTitle": "範囲", - "kbnVislibVisTypes.controls.gaugeOptions.styleTitle": "スタイル", - "kbnVislibVisTypes.controls.heatmapOptions.colorLabel": "色", - "kbnVislibVisTypes.controls.heatmapOptions.colorsNumberLabel": "色の数", - "kbnVislibVisTypes.controls.heatmapOptions.overwriteAutomaticColorLabel": "自動からーを上書きする", - "kbnVislibVisTypes.controls.heatmapOptions.rotateLabel": "回転", - "kbnVislibVisTypes.controls.heatmapOptions.showLabelsTitle": "ラベルを表示", - "kbnVislibVisTypes.controls.pointSeries.categoryAxis.filterLabelsLabel": "フィルターラベル", - "kbnVislibVisTypes.controls.pointSeries.categoryAxis.labelsTitle": "ラベル", - "kbnVislibVisTypes.controls.pointSeries.categoryAxis.positionLabel": "配置", - "kbnVislibVisTypes.controls.pointSeries.categoryAxis.showLabel": "表示", - "kbnVislibVisTypes.controls.pointSeries.categoryAxis.showLabelsLabel": "ラベルを表示", + "kbnVislibVisTypes.area.tabs.metricsAxesTitle": "メトリックと軸", + "kbnVislibVisTypes.area.tabs.panelSettingsTitle": "パネル設定", + "kbnVislibVisTypes.axisModes.normalText": "標準", + "kbnVislibVisTypes.axisModes.percentageText": "パーセンテージ", + "kbnVislibVisTypes.axisModes.silhouetteText": "シルエット", + "kbnVislibVisTypes.axisModes.wiggleText": "振動", + "kbnVislibVisTypes.categoryAxis.rotate.angledText": "傾斜", + "kbnVislibVisTypes.categoryAxis.rotate.horizontalText": "横", + "kbnVislibVisTypes.categoryAxis.rotate.verticalText": "縦", + "kbnVislibVisTypes.chartModes.normalText": "標準", + "kbnVislibVisTypes.chartModes.stackedText": "スタック", + "kbnVislibVisTypes.chartTypes.areaText": "エリア", + "kbnVislibVisTypes.chartTypes.barText": "バー", + "kbnVislibVisTypes.chartTypes.lineText": "折れ線", + "kbnVislibVisTypes.controls.colorRanges.errorText": "各範囲は前の範囲よりも大きくなければなりません。", + "kbnVislibVisTypes.controls.colorSchema.colorSchemaLabel": "カラー図表", + "kbnVislibVisTypes.controls.colorSchema.howToChangeColorsDescription": "それぞれの色は凡例で変更できます。", + "kbnVislibVisTypes.controls.colorSchema.resetColorsButtonLabel": "色をリセット", + "kbnVislibVisTypes.controls.colorSchema.reverseColorSchemaLabel": "図表を反転", + "kbnVislibVisTypes.controls.gaugeOptions.alignmentLabel": "アラインメント", + "kbnVislibVisTypes.controls.gaugeOptions.autoExtendRangeLabel": "範囲を自動拡張", + "kbnVislibVisTypes.controls.gaugeOptions.displayWarningsLabel": "警告を表示", + "kbnVislibVisTypes.controls.gaugeOptions.extendRangeTooltip": "範囲をデータの最高値に広げます。", + "kbnVislibVisTypes.controls.gaugeOptions.gaugeTypeLabel": "ゲージタイプ", + "kbnVislibVisTypes.controls.gaugeOptions.labelsTitle": "ラベル", + "kbnVislibVisTypes.controls.gaugeOptions.percentageModeLabel": "パーセンテージモード", + "kbnVislibVisTypes.controls.gaugeOptions.rangesTitle": "範囲", + "kbnVislibVisTypes.controls.gaugeOptions.showLabelsLabel": "ラベルを表示", + "kbnVislibVisTypes.controls.gaugeOptions.showLegendLabel": "凡例を表示", + "kbnVislibVisTypes.controls.gaugeOptions.showScaleLabel": "縮尺を表示", + "kbnVislibVisTypes.controls.gaugeOptions.styleTitle": "スタイル", + "kbnVislibVisTypes.controls.gaugeOptions.subTextLabel": "サブラベル", + "kbnVislibVisTypes.controls.gaugeOptions.switchWarningsTooltip": "警告のオン・オフを切り替えます。オンにすると、すべてのラベルを表示できない際に警告が表示されます。", + "kbnVislibVisTypes.controls.heatmapOptions.colorLabel": "色", + "kbnVislibVisTypes.controls.heatmapOptions.colorScaleLabel": "カラースケール", + "kbnVislibVisTypes.controls.heatmapOptions.colorsNumberLabel": "色の数", + "kbnVislibVisTypes.controls.heatmapOptions.labelsTitle": "ラベル", + "kbnVislibVisTypes.controls.heatmapOptions.overwriteAutomaticColorLabel": "自動からーを上書きする", + "kbnVislibVisTypes.controls.heatmapOptions.percentageModeLabel": "パーセンテージモード", + "kbnVislibVisTypes.controls.heatmapOptions.rotateLabel": "回転", + "kbnVislibVisTypes.controls.heatmapOptions.scaleToDataBoundsLabel": "データバウンドに合わせる", + "kbnVislibVisTypes.controls.heatmapOptions.showLabelsTitle": "ラベルを表示", + "kbnVislibVisTypes.controls.heatmapOptions.useCustomRangesLabel": "カスタム範囲を使用", + "kbnVislibVisTypes.controls.pointSeries.categoryAxis.alignLabel": "配置", + "kbnVislibVisTypes.controls.pointSeries.categoryAxis.filterLabelsLabel": "フィルターラベル", + "kbnVislibVisTypes.controls.pointSeries.categoryAxis.labelsTitle": "ラベル", + "kbnVislibVisTypes.controls.pointSeries.categoryAxis.positionLabel": "配置", + "kbnVislibVisTypes.controls.pointSeries.categoryAxis.showLabel": "表示", + "kbnVislibVisTypes.controls.pointSeries.categoryAxis.showLabelsLabel": "ラベルを表示", "kbnVislibVisTypes.controls.pointSeries.categoryAxis.xAxisTitle": "X 軸", "kbnVislibVisTypes.controls.pointSeries.gridAxis.dontShowLabel": "非表示", "kbnVislibVisTypes.controls.pointSeries.gridAxis.gridText": "グリッド", "kbnVislibVisTypes.controls.pointSeries.gridAxis.xAxisLinesLabel": "X 軸線を表示", + "kbnVislibVisTypes.controls.pointSeries.gridAxis.yAxisLinesDisabledTooltip": "ヒストグラムに X 軸線は表示できません。", "kbnVislibVisTypes.controls.pointSeries.gridAxis.yAxisLinesLabel": "Y 軸線を表示", "kbnVislibVisTypes.controls.pointSeries.series.chartTypeLabel": "チャートタイプ", "kbnVislibVisTypes.controls.pointSeries.series.lineModeLabel": "線のモード", @@ -2885,23 +2565,53 @@ "kbnVislibVisTypes.controls.pointSeries.series.metricsTitle": "メトリック", "kbnVislibVisTypes.controls.pointSeries.series.modeLabel": "モード", "kbnVislibVisTypes.controls.pointSeries.series.newAxisLabel": "新規軸…", + "kbnVislibVisTypes.controls.pointSeries.series.showDotsLabel": "点を表示", "kbnVislibVisTypes.controls.pointSeries.series.showLineLabel": "線を表示", "kbnVislibVisTypes.controls.pointSeries.series.valueAxisLabel": "値軸", + "kbnVislibVisTypes.controls.pointSeries.seriesAccordionAriaLabel": "{agg} オプションを切り替える", + "kbnVislibVisTypes.controls.pointSeries.valueAxes.addButtonTooltip": "Y 軸を追加します", + "kbnVislibVisTypes.controls.pointSeries.valueAxes.customExtentsLabel": "カスタム範囲", "kbnVislibVisTypes.controls.pointSeries.valueAxes.maxLabel": "最高", + "kbnVislibVisTypes.controls.pointSeries.valueAxes.minErrorMessage": "最低値は最高値よりも低く設定する必要があります", "kbnVislibVisTypes.controls.pointSeries.valueAxes.minLabel": "最低", "kbnVislibVisTypes.controls.pointSeries.valueAxes.minNeededScaleText": "ログスケールが選択されている場合、最低値は 0 よりも大きいものである必要があります", "kbnVislibVisTypes.controls.pointSeries.valueAxes.modeLabel": "モード", "kbnVislibVisTypes.controls.pointSeries.valueAxes.positionLabel": "配置", + "kbnVislibVisTypes.controls.pointSeries.valueAxes.removeButtonTooltip": "Y 軸を削除します", + "kbnVislibVisTypes.controls.pointSeries.valueAxes.scaleToDataBounds.boundsMargin": "境界マージン", + "kbnVislibVisTypes.controls.pointSeries.valueAxes.scaleToDataBounds.minNeededBoundsMargin": "境界マージンは 0 以上でなければなりません", "kbnVislibVisTypes.controls.pointSeries.valueAxes.scaleToDataBoundsLabel": "データバウンドに合わせる", "kbnVislibVisTypes.controls.pointSeries.valueAxes.scaleTypeLabel": "スケールタイプ", "kbnVislibVisTypes.controls.pointSeries.valueAxes.setAxisExtentsLabel": "軸の範囲の設定", "kbnVislibVisTypes.controls.pointSeries.valueAxes.showLabel": "表示", "kbnVislibVisTypes.controls.pointSeries.valueAxes.titleLabel": "タイトル", + "kbnVislibVisTypes.controls.pointSeries.valueAxes.toggleCustomExtendsAriaLabel": "カスタム範囲を切り替える", + "kbnVislibVisTypes.controls.pointSeries.valueAxes.toggleOptionsAriaLabel": "{axisName} オプションを切り替える", "kbnVislibVisTypes.controls.pointSeries.valueAxes.yAxisTitle": "Y 軸", + "kbnVislibVisTypes.controls.rangeErrorMessage": "値は {min} と {max} の間でなければなりません", + "kbnVislibVisTypes.controls.truncateLabel": "切り捨て", + "kbnVislibVisTypes.controls.vislibBasicOptions.legendPositionLabel": "凡例の配置", + "kbnVislibVisTypes.controls.vislibBasicOptions.showTooltipLabel": "ツールヒントを表示", + "kbnVislibVisTypes.editors.heatmap.basicSettingsTitle": "基本設定", + "kbnVislibVisTypes.editors.heatmap.heatmapSettingsTitle": "ヒートマップ設定", + "kbnVislibVisTypes.editors.heatmap.highlightLabel": "ハイライト範囲", + "kbnVislibVisTypes.editors.heatmap.highlightLabelTooltip": "チャートのカーソルを当てた部分と凡例の対応するラベルをハイライトします。", "kbnVislibVisTypes.editors.pie.donutLabel": "ドーナッツ", + "kbnVislibVisTypes.editors.pie.labelsSettingsTitle": "ラベル設定", + "kbnVislibVisTypes.editors.pie.pieSettingsTitle": "パイ設定", + "kbnVislibVisTypes.editors.pie.showLabelsLabel": "ラベルを表示", + "kbnVislibVisTypes.editors.pie.showTopLevelOnlyLabel": "トップレベルのみ表示", + "kbnVislibVisTypes.editors.pie.showValuesLabel": "値を表示", "kbnVislibVisTypes.editors.pointSeries.currentTimeMarkerLabel": "現在時刻マーカー", "kbnVislibVisTypes.editors.pointSeries.orderBucketsBySumLabel": "バケットを合計で並べ替え", "kbnVislibVisTypes.editors.pointSeries.settingsTitle": "設定", + "kbnVislibVisTypes.editors.pointSeries.showLabels": "チャートに値を表示", + "kbnVislibVisTypes.editors.pointSeries.thresholdLine.colorLabel": "ラインカラー", + "kbnVislibVisTypes.editors.pointSeries.thresholdLine.showLabel": "しきい線を表示", + "kbnVislibVisTypes.editors.pointSeries.thresholdLine.styleLabel": "ラインスタイル", + "kbnVislibVisTypes.editors.pointSeries.thresholdLine.valueLabel": "しきい値", + "kbnVislibVisTypes.editors.pointSeries.thresholdLine.widthLabel": "線の幅", + "kbnVislibVisTypes.editors.pointSeries.thresholdLineSettingsTitle": "しきい線", "kbnVislibVisTypes.functions.pie.help": "パイビジュアライゼーション", "kbnVislibVisTypes.functions.vislib.help": "Vislib ビジュアライゼーション", "kbnVislibVisTypes.gauge.alignmentAutomaticTitle": "自動", @@ -2909,6 +2619,8 @@ "kbnVislibVisTypes.gauge.alignmentVerticalTitle": "縦", "kbnVislibVisTypes.gauge.gaugeDescription": "ゲージはメトリックのステータスを示します。メトリックの値としきい値との関連性を示すのに使用します。", "kbnVislibVisTypes.gauge.gaugeTitle": "ゲージ", + "kbnVislibVisTypes.gauge.gaugeTypes.arcText": "弧形", + "kbnVislibVisTypes.gauge.gaugeTypes.circleText": "円", "kbnVislibVisTypes.gauge.groupTitle": "グループを分割", "kbnVislibVisTypes.gauge.metricTitle": "メトリック", "kbnVislibVisTypes.goal.goalDescription": "ゴールチャートは、最終目標にどれだけ近いかを示します。", @@ -2935,6 +2647,13 @@ "kbnVislibVisTypes.horizontalBar.radiusTitle": "点のサイズ", "kbnVislibVisTypes.horizontalBar.segmentTitle": "X 軸", "kbnVislibVisTypes.horizontalBar.splitTitle": "チャートを分割", + "kbnVislibVisTypes.interpolationModes.smoothedText": "スムーズ", + "kbnVislibVisTypes.interpolationModes.steppedText": "ステップ", + "kbnVislibVisTypes.interpolationModes.straightText": "直線", + "kbnVislibVisTypes.legendPositions.bottomText": "一番下", + "kbnVislibVisTypes.legendPositions.leftText": "左", + "kbnVislibVisTypes.legendPositions.rightText": "右", + "kbnVislibVisTypes.legendPositions.topText": "一番上", "kbnVislibVisTypes.line.groupTitle": "系列を分割", "kbnVislibVisTypes.line.lineDescription": "トレンドを強調します。", "kbnVislibVisTypes.line.lineTitle": "折れ線", @@ -2947,114 +2666,34 @@ "kbnVislibVisTypes.pie.pieTitle": "パイ", "kbnVislibVisTypes.pie.segmentTitle": "スライスの分割", "kbnVislibVisTypes.pie.splitTitle": "チャートを分割", - "kbnVislibVisTypes.controls.gaugeOptions.extendRangeTooltip": "範囲をデータの最高値に広げます。", - "kbnVislibVisTypes.controls.gaugeOptions.labelsTitle": "ラベル", - "kbnVislibVisTypes.controls.gaugeOptions.switchWarningsTooltip": "警告のオン・オフを切り替えます。オンにすると、すべてのラベルを表示できない際に警告が表示されます。", - "kbnVislibVisTypes.controls.pointSeries.gridAxis.yAxisLinesDisabledTooltip": "ヒストグラムに X 軸線は表示できません。", - "kbnVislibVisTypes.controls.rangeErrorMessage": "値は {min} と {max} の間でなければなりません", - "kbnVislibVisTypes.controls.truncateLabel": "切り捨て", - "kbnVislibVisTypes.editors.pointSeries.thresholdLine.valueLabel": "しきい値", - "kbnVislibVisTypes.editors.pointSeries.thresholdLine.widthLabel": "線の幅", - "kbnVislibVisTypes.gauge.gaugeTypes.arcText": "弧形", - "kbnVislibVisTypes.gauge.gaugeTypes.circleText": "円", - "kbnVislibVisTypes.legendPositions.bottomText": "一番下", - "kbnVislibVisTypes.legendPositions.leftText": "左", - "kbnVislibVisTypes.legendPositions.rightText": "右", - "kbnVislibVisTypes.legendPositions.topText": "一番上", - "kbnVislibVisTypes.controls.gaugeOptions.autoExtendRangeLabel": "範囲を自動拡張", - "kbnVislibVisTypes.controls.gaugeOptions.gaugeTypeLabel": "ゲージタイプ", - "kbnVislibVisTypes.controls.gaugeOptions.percentageModeLabel": "パーセンテージモード", - "kbnVislibVisTypes.controls.gaugeOptions.showLabelsLabel": "ラベルを表示", - "kbnVislibVisTypes.controls.gaugeOptions.showLegendLabel": "凡例を表示", - "kbnVislibVisTypes.controls.gaugeOptions.showScaleLabel": "縮尺を表示", - "kbnVislibVisTypes.controls.gaugeOptions.subTextLabel": "サブラベル", - "kbnVislibVisTypes.controls.vislibBasicOptions.legendPositionLabel": "凡例の配置", - "kbnVislibVisTypes.controls.vislibBasicOptions.showTooltipLabel": "ツールヒントを表示", - "kbnVislibVisTypes.editors.pie.labelsSettingsTitle": "ラベル設定", - "kbnVislibVisTypes.editors.pie.pieSettingsTitle": "パイ設定", - "kbnVislibVisTypes.editors.pie.showLabelsLabel": "ラベルを表示", - "kbnVislibVisTypes.editors.pie.showTopLevelOnlyLabel": "トップレベルのみ表示", - "kbnVislibVisTypes.editors.pie.showValuesLabel": "値を表示", - "kbnVislibVisTypes.area.countText": "カウント", - "kbnVislibVisTypes.area.tabs.metricsAxesTitle": "メトリックと軸", - "kbnVislibVisTypes.area.tabs.panelSettingsTitle": "パネル設定", - "kbnVislibVisTypes.axisModes.normalText": "標準", - "kbnVislibVisTypes.axisModes.percentageText": "パーセンテージ", - "kbnVislibVisTypes.axisModes.silhouetteText": "シルエット", - "kbnVislibVisTypes.axisModes.wiggleText": "振動", - "kbnVislibVisTypes.categoryAxis.rotate.angledText": "傾斜", - "kbnVislibVisTypes.categoryAxis.rotate.horizontalText": "横", - "kbnVislibVisTypes.categoryAxis.rotate.verticalText": "縦", - "kbnVislibVisTypes.chartModes.normalText": "標準", - "kbnVislibVisTypes.chartModes.stackedText": "スタック", - "kbnVislibVisTypes.chartTypes.areaText": "エリア", - "kbnVislibVisTypes.chartTypes.barText": "バー", - "kbnVislibVisTypes.chartTypes.lineText": "折れ線", - "kbnVislibVisTypes.controls.colorRanges.errorText": "各範囲は前の範囲よりも大きくなければなりません。", - "kbnVislibVisTypes.controls.colorSchema.colorSchemaLabel": "カラー図表", - "kbnVislibVisTypes.controls.colorSchema.howToChangeColorsDescription": "それぞれの色は凡例で変更できます。", - "kbnVislibVisTypes.controls.colorSchema.resetColorsButtonLabel": "色をリセット", - "kbnVislibVisTypes.controls.colorSchema.reverseColorSchemaLabel": "図表を反転", - "kbnVislibVisTypes.controls.heatmapOptions.labelsTitle": "ラベル", - "kbnVislibVisTypes.controls.heatmapOptions.useCustomRangesLabel": "カスタム範囲を使用", - "kbnVislibVisTypes.controls.pointSeries.categoryAxis.alignLabel": "配置", - "kbnVislibVisTypes.controls.pointSeries.series.showDotsLabel": "点を表示", - "kbnVislibVisTypes.controls.pointSeries.seriesAccordionAriaLabel": "{agg} オプションを切り替える", - "kbnVislibVisTypes.controls.pointSeries.valueAxes.addButtonTooltip": "Y 軸を追加します", - "kbnVislibVisTypes.controls.pointSeries.valueAxes.customExtentsLabel": "カスタム範囲", - "kbnVislibVisTypes.controls.pointSeries.valueAxes.minErrorMessage": "最低値は最高値よりも低く設定する必要があります", - "kbnVislibVisTypes.controls.pointSeries.valueAxes.removeButtonTooltip": "Y 軸を削除します", - "kbnVislibVisTypes.controls.pointSeries.valueAxes.toggleCustomExtendsAriaLabel": "カスタム範囲を切り替える", - "kbnVislibVisTypes.controls.pointSeries.valueAxes.toggleOptionsAriaLabel": "{axisName} オプションを切り替える", - "kbnVislibVisTypes.editors.heatmap.highlightLabelTooltip": "チャートのカーソルを当てた部分と凡例の対応するラベルをハイライトします。", - "kbnVislibVisTypes.editors.pointSeries.thresholdLine.colorLabel": "ラインカラー", - "kbnVislibVisTypes.editors.pointSeries.thresholdLine.showLabel": "しきい線を表示", - "kbnVislibVisTypes.editors.pointSeries.thresholdLine.styleLabel": "ラインスタイル", - "kbnVislibVisTypes.editors.pointSeries.thresholdLineSettingsTitle": "しきい線", - "kbnVislibVisTypes.interpolationModes.smoothedText": "スムーズ", - "kbnVislibVisTypes.interpolationModes.steppedText": "ステップ", - "kbnVislibVisTypes.interpolationModes.straightText": "直線", "kbnVislibVisTypes.scaleTypes.linearText": "直線", "kbnVislibVisTypes.scaleTypes.logText": "ログ", "kbnVislibVisTypes.scaleTypes.squareRootText": "平方根", "kbnVislibVisTypes.thresholdLine.style.dashedText": "鎖線", "kbnVislibVisTypes.thresholdLine.style.dotdashedText": "点線", "kbnVislibVisTypes.thresholdLine.style.fullText": "完全", - "kbnVislibVisTypes.controls.heatmapOptions.colorScaleLabel": "カラースケール", - "kbnVislibVisTypes.controls.heatmapOptions.percentageModeLabel": "パーセンテージモード", - "kbnVislibVisTypes.controls.heatmapOptions.scaleToDataBoundsLabel": "データバウンドに合わせる", - "kbnVislibVisTypes.controls.pointSeries.valueAxes.scaleToDataBounds.boundsMargin": "境界マージン", - "kbnVislibVisTypes.controls.pointSeries.valueAxes.scaleToDataBounds.minNeededBoundsMargin": "境界マージンは 0 以上でなければなりません", - "kbnVislibVisTypes.editors.heatmap.basicSettingsTitle": "基本設定", - "kbnVislibVisTypes.editors.heatmap.heatmapSettingsTitle": "ヒートマップ設定", - "kbnVislibVisTypes.editors.heatmap.highlightLabel": "ハイライト範囲", - "visTypeMetric.colorModes.backgroundOptionLabel": "背景", - "visTypeMetric.colorModes.labelsOptionLabel": "ラベル", - "visTypeMetric.colorModes.noneOptionLabel": "なし", - "visTypeMetric.function.help": "メトリックビジュアライゼーション", - "visTypeMetric.metricDescription": "計算結果を単独の数字として表示します。", - "visTypeMetric.metricTitle": "メトリック", - "visTypeMetric.params.rangesTitle": "範囲", - "visTypeMetric.params.style.styleTitle": "スタイル", - "visTypeMetric.schemas.metricTitle": "メトリック", - "visTypeMetric.schemas.splitGroupTitle": "グループを分割", - "visTypeMetric.function.bgFill.help": "html 16 進数コード (#123456)、html 色 (red、blue)、または rgba 値 (rgba(255,255,255,1))。", - "visTypeMetric.function.bucket.help": "バケットディメンションの構成です。", - "visTypeMetric.function.colorMode.help": "色を変更するメトリックの部分", - "visTypeMetric.function.colorRange.help": "別の色が適用される値のグループを指定する範囲オブジェクト。", - "visTypeMetric.function.colorScheme.help": "使用する配色", - "visTypeMetric.function.font.help": "フォント設定です。", - "visTypeMetric.function.invertColors.help": "色範囲を反転します", - "visTypeMetric.function.metric.help": "メトリックディメンションの構成です。", - "visTypeMetric.function.percentage.help": "パーセンテージモードでメトリックを表示します。colorRange を設定する必要があります。", - "visTypeMetric.function.showLabels.help": "メトリック値の下にラベルを表示します。", - "visTypeMetric.function.subText.help": "メトリックの下に表示するカスタムテキスト", - "visTypeMetric.function.useRanges.help": "有効な色範囲です。", - "visTypeMetric.params.settingsTitle": "設定", - "visTypeMetric.params.showTitleLabel": "タイトルを表示", - "visTypeMetric.params.color.useForLabel": "使用する色", - "visTypeMetric.params.percentageModeLabel": "パーセンテージモード", - "visTypeMetric.params.style.fontSizeLabel": "ポイント単位のメトリックフォントサイズ", + "kibana-react.exitFullScreenButton.exitFullScreenModeButtonLabel": "全画面を終了", + "kibana-react.exitFullScreenButton.fullScreenModeDescription": "ESC キーで全画面モードを終了します。", + "kibana-react.savedObjects.finder.filterButtonLabel": "タイプ", + "kibana-react.savedObjects.finder.searchPlaceholder": "検索...", + "kibana-react.savedObjects.finder.sortAsc": "昇順", + "kibana-react.savedObjects.finder.sortAuto": "ベストマッチ", + "kibana-react.savedObjects.finder.sortButtonLabel": "並べ替え", + "kibana-react.savedObjects.finder.sortDesc": "降順", + "kibana-react.savedObjects.saveModal.cancelButtonLabel": "キャンセル", + "kibana-react.savedObjects.saveModal.descriptionLabel": "説明", + "kibana-react.savedObjects.saveModal.duplicateTitleDescription": "{confirmSaveLabel} をクリックすると、既存の {objectType} が上書きされます。", + "kibana-react.savedObjects.saveModal.duplicateTitleLabel": "「{title}」というタイトルの {objectType} が既に存在します", + "kibana-react.savedObjects.saveModal.saveAsNewLabel": "新規 {objectType} として保存", + "kibana-react.savedObjects.saveModal.saveButtonLabel": "保存", + "kibana-react.savedObjects.saveModal.saveTitle": "{objectType} を保存", + "kibana-react.savedObjects.saveModal.titleLabel": "タイトル", + "newsfeed.emptyPrompt.noNewsText": "Kibanaインスタンスがインターネットにアクセスできない場合、管理者にこの機能を無効にするように依頼してください。そうでない場合は、ニュースを取り込み続けます。", + "newsfeed.emptyPrompt.noNewsTitle": "ニュースがない場合", + "newsfeed.flyoutList.closeButtonLabel": "閉じる", + "newsfeed.flyoutList.versionTextLabel": "{version}", + "newsfeed.flyoutList.whatsNewTitle": "新機能", + "newsfeed.loadingPrompt.gettingNewsText": "最新ニュースを取得しています...", "regionMap.choroplethLayer.downloadingVectorData404ErrorMessage": "{name} の取得時にサーバーから「404」が返されます。指定された場所にファイルが存在することを確認してください。", "regionMap.choroplethLayer.downloadingVectorDataErrorMessage": "{name} ファイルをダウンロードできません。サーバーの CORS 構成で、このホストの Kibana アプリケーションからのリクエストが許可されていることを確認してください。", "regionMap.choroplethLayer.downloadingVectorDataErrorMessageTitle": "ベクトルデータのダウンロード中にエラーが発生しました", @@ -3064,8 +2703,11 @@ "regionMap.mapVis.regionMapEditorConfig.schemas.metricTitle": "値", "regionMap.mapVis.regionMapEditorConfig.schemas.segmentTitle": "フィールドのシェイプ", "regionMap.mapVis.regionMapTitle": "地域マップ", + "regionMap.visParams.colorSchemaLabel": "カラー図表", "regionMap.visParams.displayWarningsLabel": "警告を表示", "regionMap.visParams.joinFieldLabel": "フィールドを結合", + "regionMap.visParams.layerSettingsTitle": "レイヤー設定", + "regionMap.visParams.outlineWeightLabel": "境界の太さ", "regionMap.visParams.previewOnEMSLinkText": "EMS でプレビュー", "regionMap.visParams.previewOnEMSLinkTitle": "Elastic Maps Service で {selectedLayerName} をプレビュー", "regionMap.visParams.showAllShapesLabel": "すべてのシェイプを表示", @@ -3075,84 +2717,12 @@ "regionMap.visParams.vectorMapLabel": "ベクトルマップ", "regionMap.visualization.unableToShowMismatchesWarningText": "次の各用語がシェイプの結合フィールドのシェイプと一致することを確認してください: {mismatches}", "regionMap.visualization.unableToShowMismatchesWarningTitle": "{mismatchesLength} {oneMismatch, plural, one { 件の結果} other { 件の結果}}をマップに表示できません", - "regionMap.visParams.colorSchemaLabel": "カラー図表", - "regionMap.visParams.layerSettingsTitle": "レイヤー設定", - "regionMap.visParams.outlineWeightLabel": "境界の太さ", - "home.sampleData.ecommerceSpec.averageSalesPerRegionTitle": "[e コマース] 地域ごとの平均売上", - "home.sampleData.ecommerceSpec.averageSalesPriceTitle": "[e コマース] 平均販売価格", - "home.sampleData.ecommerceSpec.averageSoldQuantityTitle": "[e コマース] 平均販売数", - "home.sampleData.ecommerceSpec.controlsTitle": "[e コマース] コントロール", - "home.sampleData.ecommerceSpec.markdownTitle": "[e コマース] マークダウン", - "home.sampleData.ecommerceSpec.ordersTitle": "[e コマース] 注文", - "home.sampleData.ecommerceSpec.promotionTrackingTitle": "[e コマース] プロモーショントラッキング", - "home.sampleData.ecommerceSpec.revenueDashboardDescription": "サンプルの e コマースの注文と収益を分析します", - "home.sampleData.ecommerceSpec.revenueDashboardTitle": "[e コマース] 収益ダッシュボード", - "home.sampleData.ecommerceSpec.salesByCategoryTitle": "[e コマース] カテゴリーごとの売上", - "home.sampleData.ecommerceSpec.salesByGenderTitle": "[e コマース] 性別ごとの売上", - "home.sampleData.ecommerceSpec.soldProductsPerDayTitle": "[e コマース] 1 日の販売製品", - "home.sampleData.ecommerceSpec.topSellingProductsTitle": "[e コマース] トップセラー製品", - "home.sampleData.ecommerceSpec.totalRevenueTitle": "[e コマース] 合計収益", - "home.sampleData.ecommerceSpecDescription": "e コマースの注文をトラッキングするサンプルデータ、ビジュアライゼーション、ダッシュボードです。", - "home.sampleData.ecommerceSpecTitle": "サンプル e コマース注文", - "home.sampleData.flightsSpec.airlineCarrierTitle": "[フライト] 航空会社", - "home.sampleData.flightsSpec.airportConnectionsTitle": "[フライト] 空港乗り継ぎ (空港にカーソルを合わせてください)", - "home.sampleData.flightsSpec.averageTicketPriceTitle": "[フライト] 平均運賃", - "home.sampleData.flightsSpec.controlsTitle": "[フライト] コントロール", - "home.sampleData.flightsSpec.delayBucketsTitle": "[フライト] 遅延バケット", - "home.sampleData.flightsSpec.delaysAndCancellationsTitle": "[フライト] 遅延・欠航", - "home.sampleData.flightsSpec.delayTypeTitle": "[フライト] 遅延タイプ", - "home.sampleData.flightsSpec.destinationWeatherTitle": "[フライト] 目的地の天候", - "home.sampleData.flightsSpec.flightCancellationsTitle": "[フライト] フライト欠航", - "home.sampleData.flightsSpec.flightCountAndAverageTicketPriceTitle": "[フライト] カウントと平均運賃", - "home.sampleData.flightsSpec.flightDelaysTitle": "[フライト] フライトの遅延", - "home.sampleData.flightsSpec.flightLogTitle": "[フライト] 飛行記録", - "home.sampleData.flightsSpec.globalFlightDashboardDescription": "ES-Air、Logstash Airways、Kibana Airlines、JetBeats のサンプル飛行データを分析します", - "home.sampleData.flightsSpec.globalFlightDashboardTitle": "[フライト] グローバルフライトダッシュボード", - "home.sampleData.flightsSpec.markdownInstructionsTitle": "[フライト] マークダウンの指示", - "home.sampleData.flightsSpec.originCountryTicketPricesTitle": "[フライト] 出発国の運賃", - "home.sampleData.flightsSpec.originCountryTitle": "[Flights] 出発国と到着国の比較", - "home.sampleData.flightsSpec.totalFlightCancellationsTitle": "[フライト] フライト欠航合計", - "home.sampleData.flightsSpec.totalFlightDelaysTitle": "[フライト] フライト遅延合計", - "home.sampleData.flightsSpec.totalFlightsTitle": "[フライト] フライト合計", - "home.sampleData.flightsSpecDescription": "飛行ルートを監視するサンプルデータ、ビジュアライゼーション、ダッシュボードです。", - "home.sampleData.flightsSpecTitle": "サンプル飛行データ", - "home.sampleData.logsSpec.fileTypeScatterPlotTitle": "[ログ] ファイルタイプ散布図", - "home.sampleData.logsSpec.goalsTitle": "[ログ] 目標", - "home.sampleData.logsSpec.heatmapTitle": "[ログ] ヒートマップ", - "home.sampleData.logsSpec.hostVisitsBytesTableTitle": "[ログ] ホスト、訪問数、バイト表", - "home.sampleData.logsSpec.inputControlsTitle": "[ログ] インプットコントロール", - "home.sampleData.logsSpec.markdownInstructionsTitle": "[ログ] マークダウンの指示", - "home.sampleData.logsSpec.responseCodesOverTimeTitle": "[ログ] 一定期間の応答コードと注釈", - "home.sampleData.logsSpec.sourceAndDestinationSankeyChartTitle": "[ログ] ソースと行先のサンキーダイアグラム", - "home.sampleData.logsSpec.uniqueVisitorsByCountryTitle": "[ログ] 国ごとのユニークビジター", - "home.sampleData.logsSpec.uniqueVisitorsTitle": "[ログ] ユニークビジターと平均バイトの比較", - "home.sampleData.logsSpec.visitorOSTitle": "[ログ] OS 別のビジター", - "home.sampleData.logsSpec.webTrafficDescription": "Elastic Web サイトのサンプル Webトラフィックログデータを分析します", - "home.sampleData.logsSpec.webTrafficTitle": "[ログ] Web トラフィック", - "home.sampleData.logsSpecDescription": "Web ログを監視するサンプルデータ、ビジュアライゼーション、ダッシュボードです。", - "home.sampleData.logsSpecTitle": "サンプル Web ログ", "server.stats.notReadyMessage": "まだ統計が準備できていません。後程再試行してください", "server.status.disabledTitle": "無効", "server.status.greenTitle": "緑", "server.status.redTitle": "赤", "server.status.uninitializedTitle": "アンインストールしました", "server.status.yellowTitle": "黄色", - "share.contextMenu.embedCodeLabel": "埋め込みコード", - "share.contextMenu.embedCodePanelTitle": "埋め込みコード", - "share.contextMenu.permalinkPanelTitle": "パーマリンク", - "share.contextMenu.permalinksLabel": "パーマリンク", - "share.contextMenuTitle": "この {objectType} を共有", - "share.urlPanel.canNotShareAsSavedObjectHelpText": "{objectType} が保存されるまで保存されたオブジェクトを共有することはできません。", - "share.urlPanel.copyIframeCodeButtonLabel": "iFrame コードをコピー", - "share.urlPanel.copyLinkButtonLabel": "リンクをコピー", - "share.urlPanel.generateLinkAsLabel": "名前を付けてリンクを生成", - "share.urlPanel.savedObjectDescription": "この URL を共有することで、他のユーザーがこの {objectType} の最も最近保存されたバージョンを読み込めるようになります。", - "share.urlPanel.savedObjectLabel": "保存されたオブジェクト", - "share.urlPanel.shortUrlHelpText": "互換性が最も高くなるよう、短いスナップショット URL を共有することをお勧めします。Internet Explorer は URL の長さに制限があり、一部の wiki やマークアップパーサーは長い完全なスナップショット URL に対応していませんが、短い URL は正常に動作するはずです。", - "share.urlPanel.shortUrlLabel": "短い URL", - "share.urlPanel.snapshotDescription": "スナップショット URL には、{objectType} の現在の状態がエンコードされています。保存された {objectType} への編集内容はこの URL には反映されません。.", - "share.urlPanel.snapshotLabel": "スナップショット", - "share.urlPanel.unableCreateShortUrlErrorMessage": "短い URL を作成できません。エラー: {errorMessage}", "statusPage.loadStatus.serverIsDownErrorMessage": "サーバーステータスのリクエストに失敗しました。サーバーがダウンしている可能性があります。", "statusPage.loadStatus.serverStatusCodeErrorMessage": "サーバーステータスのリクエストに失敗しました。ステータスコード: {responseStatus}", "statusPage.metricsTiles.columns.heapTotalHeader": "ヒープ合計", @@ -3168,63 +2738,54 @@ "statusPage.statusApp.statusTitle": "プラグインステータス", "statusPage.statusTable.columns.idHeader": "ID", "statusPage.statusTable.columns.statusHeader": "ステータス", - "visTypeTable.aggTable.exportLabel": "エクスポート:", - "visTypeTable.aggTable.formattedLabel": "フォーマット済み", - "visTypeTable.aggTable.rawLabel": "生", - "visTypeTable.directives.tableCellFilter.filterForValueTooltip": "値でフィルタリング", - "visTypeTable.directives.tableCellFilter.filterOutValueTooltip": "値を除外", - "visTypeTable.function.help": "表ビジュアライゼーション", - "visTypeTable.params.showMetricsLabel": "すべてのバケット/レベルのメトリックを表示", - "visTypeTable.params.showPartialRowsLabel": "部分的な行を表示", - "visTypeTable.params.showPartialRowsTip": "部分データのある行を表示。表示されていなくてもすべてのバケット/レベルのメトリックが計算されます。", - "visTypeTable.params.showTotalLabel": "合計を表示", - "visTypeTable.params.totalFunctionLabel": "合計機能", - "visTypeTable.tableVisDescription": "テーブルに値を表示します。", - "visTypeTable.tableVisEditorConfig.schemas.bucketTitle": "行を分割", - "visTypeTable.tableVisEditorConfig.schemas.metricTitle": "メトリック", - "visTypeTable.tableVisEditorConfig.schemas.splitTitle": "テーブルを分割", - "visTypeTable.tableVisTitle": "データテーブル", - "visTypeTable.vis.noResultsFoundTitle": "結果が見つかりませんでした", - "visTypeTable.params.PercentageColLabel": "パーセンテージ列", - "visTypeTable.params.percentageTableColumnName": "{title} パーセント", - "visTypeTable.params.defaultPercentageCol": "非表示", - "visTypeTable.totalAggregations.averageText": "平均", - "visTypeTable.totalAggregations.countText": "カウント", - "visTypeTable.totalAggregations.maxText": "最高", - "visTypeTable.totalAggregations.minText": "最低", - "visTypeTable.totalAggregations.sumText": "合計", - "visTypeTable.params.perPageLabel": "ページごとの行数", - "visTypeTagCloud.feedbackMessage.tooSmallContainerDescription": "コンテナーが小さすぎてクラウド全体を表示できません。タグが切り取られたか省略されている可能性があります。", - "visTypeTagCloud.feedbackMessage.truncatedTagsDescription": "描写時間が長くなるのを防ぐため、タグの数が切り捨てられています。", - "visTypeTagCloud.function.bucket.help": "バケットディメンションの構成です。", - "visTypeTagCloud.function.help": "タグクラウドのビジュアライゼーションです。", - "visTypeTagCloud.function.metric.help": "メトリックディメンションの構成です。", - "visTypeTagCloud.function.orientation.help": "タグクラウド内の単語の方向です。", - "visTypeTagCloud.function.scale.help": "単語のフォントサイズを決定するスケールです", - "visTypeTagCloud.vis.schemas.metricTitle": "タグサイズ", - "visTypeTagCloud.vis.schemas.segmentTitle": "タグ", - "visTypeTagCloud.vis.tagCloudDescription": "重要度に基づき大きさを変えた単語のグループ表示です。", - "visTypeTagCloud.vis.tagCloudTitle": "タグクラウド", - "visTypeTagCloud.visParams.orientationsLabel": "方向", - "visTypeTagCloud.vis.editorConfig.orientations.multipleText": "複数", - "visTypeTagCloud.vis.editorConfig.orientations.rightAngledText": "直角", - "visTypeTagCloud.vis.editorConfig.orientations.singleText": "単一", - "visTypeTagCloud.vis.editorConfig.scales.linearText": "直線", - "visTypeTagCloud.vis.editorConfig.scales.logText": "ログ", - "visTypeTagCloud.vis.editorConfig.scales.squareRootText": "平方根", - "visTypeTagCloud.visParams.fontSizeLabel": "フォントサイズ範囲 (ピクセル)", - "visTypeTagCloud.visParams.showLabelToggleLabel": "ラベルを表示", - "visTypeTagCloud.visParams.textScaleLabel": "テキストスケール", + "telemetry.callout.appliesSettingTitle": "この設定は {allOfKibanaText} に適用されます", + "telemetry.callout.appliesSettingTitle.allOfKibanaText": "Kibana のすべて", + "telemetry.callout.clusterStatisticsDescription": "これは収集される基本的なクラスター統計の例です。インデックス、シャード、ノードの数が含まれます。監視がオンになっているかどうかなどのハイレベルの使用統計も含まれます。", + "telemetry.callout.clusterStatisticsTitle": "クラスター統計", + "telemetry.callout.errorLoadingClusterStatisticsDescription": "クラスター統計の取得中に予期せぬエラーが発生しました。Elasticsearch、Kibana、またはネットワークのエラーが原因の可能性があります。Kibana を確認し、ページを再読み込みして再試行してください。", + "telemetry.callout.errorLoadingClusterStatisticsTitle": "クラスター統計の読み込みエラー", + "telemetry.callout.errorUnprivilegedUserDescription": "暗号化されていないクラスター統計を表示するアクセス権がありません。", + "telemetry.callout.errorUnprivilegedUserTitle": "クラスター統計の表示エラー", + "telemetry.optInErrorToastText": "使用状況統計設定の設定中にエラーが発生しました。", + "telemetry.optInErrorToastTitle": "エラー", + "telemetry.optInNoticeSeenErrorTitle": "エラー", + "telemetry.optInNoticeSeenErrorToastText": "通知の消去中にエラーが発生しました", + "telemetry.readOurUsageDataPrivacyStatementLinkText": "使用データのプライバシーステートメントをお読みください", + "telemetry.seeExampleOfWhatWeCollectLinkText": "収集されるデータの例を見る", + "telemetry.telemetryBannerDescription": "Elastic Stackの改善にご協力ください使用状況データの収集は現在無効です。使用状況データの収集を有効にすると、製品とサービスを管理して改善することができます。詳細については、{privacyStatementLink}をご覧ください。", + "telemetry.telemetryConfigDescription": "基本的な機能の利用状況に関する統計情報を提供して、Elastic Stack の改善にご協力ください。このデータは Elastic 社外と共有されません。", + "telemetry.telemetryConfigTitle": "遠隔測定オプトイン", + "telemetry.telemetryErrorNotificationMessageDescription.tryAgainText": "Kibana と Elasticsearch が現在も実行中であることを確認し、再試行してください。", + "telemetry.telemetryErrorNotificationMessageDescription.unableToSaveTelemetryPreferenceText": "遠隔測定設定を保存できません。", + "telemetry.telemetryErrorNotificationMessageTitle": "遠隔測定エラー", + "telemetry.telemetryOptedInDisableUsage": "ここで使用状況データを無効にする", + "telemetry.telemetryOptedInDismissMessage": "閉じる", + "telemetry.telemetryOptedInNoticeDescription": "使用状況データがどのように製品とサービスの管理と改善につながるのかに関する詳細については、{privacyStatementLink}をご覧ください。収集を停止するには、{disableLink}。", + "telemetry.telemetryOptedInPrivacyStatement": "プライバシーポリシー", + "telemetry.usageDataTitle": "使用データ", + "telemetry.welcomeBanner.disableButtonLabel": "無効にする", + "telemetry.welcomeBanner.enableButtonLabel": "有効にする", + "telemetry.welcomeBanner.telemetryConfigDetailsDescription.telemetryPrivacyStatementLinkText": "遠隔測定に関するプライバシーステートメント", + "telemetry.welcomeBanner.title": "Elastic Stack の改善にご協力ください", "tileMap.baseMapsVisualization.childShouldImplementMethodErrorMessage": "子は data-update に対応できるようこのメソドを導入する必要があります", "tileMap.function.help": "タイルマップのビジュアライゼーションです", "tileMap.geohashLayer.mapTitle": "{mapType} マップタイプが認識されません", "tileMap.tooltipFormatter.latitudeLabel": "緯度", "tileMap.tooltipFormatter.longitudeLabel": "経度", + "tileMap.vis.editorConfig.legendPositions.bottomLeftText": "左下", + "tileMap.vis.editorConfig.legendPositions.bottomRightText": "右下", + "tileMap.vis.editorConfig.legendPositions.topLeftText": "左上", + "tileMap.vis.editorConfig.legendPositions.topRightText": "右上", + "tileMap.vis.editorConfig.mapTypes.heatmapText": "ヒートマップ", + "tileMap.vis.editorConfig.mapTypes.scaledCircleMarkersText": "スケーリングされた円マーカー", + "tileMap.vis.editorConfig.mapTypes.shadedCircleMarkersText": "影付き円マーカー", + "tileMap.vis.editorConfig.mapTypes.shadedGeohashGridText": "影付きジオハッシュグリッド", "tileMap.vis.map.editorConfig.schemas.geoCoordinatesTitle": "座標", "tileMap.vis.map.editorConfig.schemas.metricTitle": "値", "tileMap.vis.mapDescription": "マップ上に緯度と経度の座標を表示します。", "tileMap.vis.mapTitle": "座標マップ", "tileMap.visParams.clusterSizeLabel": "クラスターサイズ", + "tileMap.visParams.colorSchemaLabel": "カラー図表", "tileMap.visParams.desaturateTilesLabel": "タイルを不飽和化", "tileMap.visParams.mapTypeLabel": "マップタイプ", "tileMap.visParams.reduceVibrancyOfTileColorsTip": "色の鮮明度を下げます。この機能は Internet Explorer ではバージョンにかかわらず利用できません。", @@ -3233,8800 +2794,432 @@ "tileMap.wmsOptions.imageFormatToUseTip": "通常画像/png または画像/jpeg です。サーバーが透明レイヤーを返す場合は png を使用します。", "tileMap.wmsOptions.layersLabel": "レイヤー", "tileMap.wmsOptions.listOfLayersToUseTip": "使用するレイヤーのコンマ区切りのリストです。", + "tileMap.wmsOptions.mapLoadFailDescription": "このパラメーターが正しくないと、マップが正常に読み込まれません。", "tileMap.wmsOptions.urlOfWMSWebServiceTip": "WMS web サービスの URL です。", "tileMap.wmsOptions.useWMSCompliantMapTileServerTip": "WMS 対応のマップタイルサーバーを使用します。上級者向けです。", "tileMap.wmsOptions.versionOfWMSserverSupportsTip": "サーバーがサポートしている WMS のバージョンです。", "tileMap.wmsOptions.wmsAttributionLabel": "WMS 属性", - "tileMap.wmsOptions.wmsMapServerLabel": "WMS マップサーバー", - "tileMap.wmsOptions.wmsServerSupportedStylesListTip": "WMS サーバーがサポートしている使用スタイルのコンマ区切りのリストです。大抵は空白のままです。", - "tileMap.vis.editorConfig.legendPositions.bottomLeftText": "左下", - "tileMap.vis.editorConfig.legendPositions.bottomRightText": "右下", - "tileMap.vis.editorConfig.legendPositions.topLeftText": "左上", - "tileMap.vis.editorConfig.legendPositions.topRightText": "右上", - "tileMap.vis.editorConfig.mapTypes.heatmapText": "ヒートマップ", - "tileMap.vis.editorConfig.mapTypes.scaledCircleMarkersText": "スケーリングされた円マーカー", - "tileMap.vis.editorConfig.mapTypes.shadedCircleMarkersText": "影付き円マーカー", - "tileMap.vis.editorConfig.mapTypes.shadedGeohashGridText": "影付きジオハッシュグリッド", - "tileMap.visParams.colorSchemaLabel": "カラー図表", - "tileMap.wmsOptions.mapLoadFailDescription": "このパラメーターが正しくないと、マップが正常に読み込まれません。", "tileMap.wmsOptions.wmsDescription": "WMS は、マップイメージサービスの {wmsLink} です。", "tileMap.wmsOptions.wmsFormatLabel": "WMS フォーマット", "tileMap.wmsOptions.wmsLayersLabel": "WMS レイヤー", "tileMap.wmsOptions.wmsLinkText": "OGC スタンダード", + "tileMap.wmsOptions.wmsMapServerLabel": "WMS マップサーバー", + "tileMap.wmsOptions.wmsServerSupportedStylesListTip": "WMS サーバーがサポートしている使用スタイルのコンマ区切りのリストです。大抵は空白のままです。", "tileMap.wmsOptions.wmsStylesLabel": "WMS スタイル", "tileMap.wmsOptions.wmsUrlLabel": "WMS URL", "tileMap.wmsOptions.wmsVersionLabel": "WMS バージョン", - "visTypeVega.editor.formatError": "仕様のフォーマット中にエラーが発生", - "visTypeVega.editor.reformatAsHJSONButtonLabel": "HJSON に変換", - "visTypeVega.editor.reformatAsJSONButtonLabel": "JSON に変換しコメントを削除", - "visTypeVega.editor.vegaEditorOptionsButtonAriaLabel": "Vega エディターオプション", - "visTypeVega.editor.vegaHelpButtonAriaLabel": "Vega ヘルプ", - "visTypeVega.emsFileParser.emsFileNameDoesNotExistErrorMessage": "{emsfile} {emsfileName} が存在しません", - "visTypeVega.emsFileParser.missingNameOfFileErrorMessage": "{dataUrlParamValue} の {dataUrlParam} には {nameParam} パラメーター (ファイル名) が必要です", - "visTypeVega.esQueryParser.autointervalValueTypeErrorMessage": "{autointerval} は文字 {trueValue} または数字である必要があります", - "visTypeVega.esQueryParser.dataUrlMustNotHaveLegacyAndBodyQueryValuesAtTheSameTimeErrorMessage": "{dataUrlParam} はレガシー {legacyContext} と {bodyQueryConfigName} の値を同時に含めることができません。", - "visTypeVega.esQueryParser.dataUrlMustNotHaveLegacyContextTogetherWithContextOrTimefieldErrorMessage": "{dataUrlParam} は {legacyContext} と同時に {context} または {timefield} を含めることができません", - "visTypeVega.esQueryParser.legacyContextCanBeTrueErrorMessage": "レガシー {legacyContext} は {trueValue} (時間範囲ピッカーを無視)、または時間フィールドの名前のどちらかです。例: {timestampParam}", - "visTypeVega.esQueryParser.legacyUrlShouldChangeToWarningMessage": "レガシー {urlParam}: {legacyUrl} を {result} に変更する必要があります", - "visTypeVega.esQueryParser.shiftMustValueTypeErrorMessage": "{shiftParam} は数値でなければなりません", - "visTypeVega.esQueryParser.timefilterValueErrorMessage": "{timefilter} のプロパティは {trueValue}、{minValue}、または {maxValue} に設定する必要があります", - "visTypeVega.esQueryParser.unknownUnitValueErrorMessage": "不明な {unitParamName} 値。[{unitParamValues}] の内の 1 つでなければなりません", - "visTypeVega.esQueryParser.urlBodyValueTypeErrorMessage": "{configName} はオブジェクトでなければなりません", - "visTypeVega.esQueryParser.urlContextAndUrlTimefieldMustNotBeUsedErrorMessage": "{urlContext} と {timefield} は {queryParam} が設定されている場合使用できません", - "visTypeVega.function.help": "Vega ビジュアライゼーション", - "visTypeVega.mapView.mapStyleNotFoundWarningMessage": "{mapStyleParam} が見つかりませんでした", - "visTypeVega.mapView.minZoomAndMaxZoomHaveBeenSwappedWarningMessage": "{minZoomPropertyName} と {maxZoomPropertyName} が交換されました", - "visTypeVega.mapView.resettingPropertyToMaxValueWarningMessage": "{name} を {max} にリセットしています", - "visTypeVega.mapView.resettingPropertyToMinValueWarningMessage": "{name} を {min} にリセットしています", - "visTypeVega.type.vegaDescription": "Vega と Vega-Lite を使用してカスタムビジュアライゼーションを作成します。", - "visTypeVega.urlParser.dataUrlRequiresUrlParameterInFormErrorMessage": "{dataUrlParam} には「{formLink}」の形で {urlParam} パラメーターが必要です", - "visTypeVega.urlParser.urlShouldHaveQuerySubObjectWarningMessage": "{urlObject} を使用するには {subObjectName} サブオブジェクトが必要です", - "visTypeVega.vegaParser.baseView.externalUrlsAreNotEnabledErrorMessage": "外部 URL が無効です。{enableExternalUrls} を {kibanaConfigFileName} に追加します", - "visTypeVega.vegaParser.baseView.functionIsNotDefinedForGraphErrorMessage": "このグラフには {funcName} が定義されていません", - "visTypeVega.vegaParser.baseView.timeValuesTypeErrorMessage": "時間フィルターの設定エラー: 両方の時間の値は相対的または絶対的な日付である必要があります。 {start}、{end}", - "visTypeVega.vegaParser.centerOnMarkConfigValueTypeErrorMessage": "{configName} は {trueValue}、{falseValue}、または数字でなければなりません", - "visTypeVega.vegaParser.dataExceedsSomeParamsUseTimesLimitErrorMessage": "データには {urlParam}、{valuesParam}、 {sourceParam} の内複数を含めることができません", - "visTypeVega.vegaParser.hostConfigIsDeprecatedWarningMessage": "{deprecatedConfigName} は廃止されました。代わりに {newConfigName} を使用してください。", - "visTypeVega.vegaParser.hostConfigValueTypeErrorMessage": "{configName} が含まれている場合、オブジェクトでなければなりません", - "visTypeVega.vegaParser.inputSpecDoesNotSpecifySchemaWarningMessage": "インプット仕様で {schemaParam} が指定されていないため、デフォルトで {defaultSchema} になります", - "visTypeVega.vegaParser.invalidVegaSpecErrorMessage": "無効な Vega 仕様", - "visTypeVega.vegaParser.kibanaConfigValueTypeErrorMessage": "{configName} が含まれている場合、オブジェクトでなければなりません", - "visTypeVega.vegaParser.mapStyleValueTypeWarningMessage": "{mapStyleConfigName} は {mapStyleConfigFirstAllowedValue} か {mapStyleConfigSecondAllowedValue} のどちらかです", - "visTypeVega.vegaParser.maxBoundsValueTypeWarningMessage": "{maxBoundsConfigName} は 4 つの数字の配列でなければなりません", - "visTypeVega.vegaParser.notSupportedUrlTypeErrorMessage": "{urlObject} はサポートされていません", - "visTypeVega.vegaParser.notValidLibraryVersionForInputSpecWarningMessage": "インプット仕様に {schemaLibrary} {schemaVersion} が使用されていますが、現在のバージョンの {schemaLibrary} は {libraryVersion} です。’", - "visTypeVega.vegaParser.paddingConfigValueTypeErrorMessage": "{configName} は数字でなければなりません", - "visTypeVega.vegaParser.someKibanaConfigurationIsNoValidWarningMessage": "{configName} は有効ではありません", - "visTypeVega.vegaParser.someKibanaParamValueTypeWarningMessage": "{configName} はブール値でなければなりません", - "visTypeVega.vegaParser.unexpectedValueForPositionConfigurationErrorMessage": "{configurationName} 構成に予期せぬ値が使用されています", - "visTypeVega.vegaParser.unrecognizedControlsLocationValueErrorMessage": "認識されない {controlsLocationParam} 値[{locToDirMap}] のいずれかである必要があります", - "visTypeVega.vegaParser.unrecognizedDirValueErrorMessage": "認識されない {dirParam} 値[{expectedValues}] のいずれかである必要があります", - "visTypeVega.vegaParser.VLCompilerShouldHaveGeneratedSingleProtectionObjectErrorMessage": "内部エラー:Vega-Lite コンパイラーがシングルプロジェクションオブジェクトを生成したはずです", - "visTypeVega.vegaParser.widthAndHeightParamsAreIgnoredWithAutosizeFitWarningMessage": "{widthParam} と {heightParam} パラメーターは {autosizeParam} で無視されます", - "visTypeVega.visualization.indexNotFoundErrorMessage": "インデックス {index} が見つかりません", - "visTypeVega.visualization.renderErrorTitle": "Vega エラー", - "visTypeVega.visualization.unableToFindDefaultIndexErrorMessage": "デフォルトのインデックスが見つかりません", - "visTypeVega.visualization.unableToRenderWithoutDataWarningMessage": "データなしにはレンダリングできません", - "xpack.apm.agentMetrics.java.heapMemoryChartTitle": "ヒープ領域", - "xpack.apm.agentMetrics.java.heapMemorySeriesCommitted": "平均実行割当", - "xpack.apm.agentMetrics.java.heapMemorySeriesMax": "平均制限", - "xpack.apm.agentMetrics.java.heapMemorySeriesUsed": "平均使用", - "xpack.apm.agentMetrics.java.nonHeapMemoryChartTitle": "ヒープ領域以外", - "xpack.apm.agentMetrics.java.nonHeapMemorySeriesCommitted": "平均実行割当", - "xpack.apm.agentMetrics.java.nonHeapMemorySeriesUsed": "平均使用", - "xpack.apm.agentMetrics.java.threadCount": "平均カウント", - "xpack.apm.agentMetrics.java.threadCountChartTitle": "スレッド数", - "xpack.apm.agentMetrics.java.threadCountMax": "最高カウント", - "xpack.apm.apmDescription": "アプリケーション内から自動的に詳細なパフォーマンスメトリックやエラーを集めます。", - "xpack.apm.apmForESDescription": "Elastic Stack 用の APM", - "xpack.apm.breadcrumb.errorsTitle": "エラー", - "xpack.apm.breadcrumb.metricsTitle": "メトリック", - "xpack.apm.breadcrumb.servicesTitle": "サービス", - "xpack.apm.breadcrumb.tracesTitle": "トレース", - "xpack.apm.breadcrumb.transactionsTitle": "トランザクション", - "xpack.apm.chart.cpuSeries.processAverageLabel": "プロセス平均", - "xpack.apm.chart.cpuSeries.processMaxLabel": "プロセス最大", - "xpack.apm.chart.cpuSeries.systemAverageLabel": "システム平均", - "xpack.apm.chart.cpuSeries.systemMaxLabel": "システム最大", - "xpack.apm.chart.memorySeries.systemAverageLabel": "平均", - "xpack.apm.chart.memorySeries.systemMaxLabel": "最高", - "xpack.apm.emptyMessage.noDataFoundDescription": "別の時間範囲を試すか検索フィルターをリセットしてください。", - "xpack.apm.emptyMessage.noDataFoundLabel": "データが見つかりません。", - "xpack.apm.errorGroupDetails.culpritLabel": "原因", - "xpack.apm.errorGroupDetails.errorGroupTitle": "エラーグループ {errorGroupId}", - "xpack.apm.errorGroupDetails.errorOccurrenceTitle": "エラーのオカレンス", - "xpack.apm.errorGroupDetails.exceptionMessageLabel": "例外メッセージ", - "xpack.apm.errorGroupDetails.logMessageLabel": "ログメッセージ", - "xpack.apm.errorGroupDetails.noErrorsLabel": "エラーが見つかりませんでした", - "xpack.apm.errorGroupDetails.occurrencesChartLabel": "オカレンス", - "xpack.apm.errorGroupDetails.occurrencesLongLabel": "{occCount} 件", - "xpack.apm.errorGroupDetails.occurrencesShortLabel": "{occCount} 件", - "xpack.apm.errorGroupDetails.unhandledLabel": "未対応", - "xpack.apm.errorGroupDetails.viewOccurrencesInDiscoverButtonLabel": "ディスカバリで {occurrencesCount} 件の{occurrencesCount, plural, one {ドキュメント} other {ドキュメント}}を表示。", - "xpack.apm.errorsTable.errorMessageAndCulpritColumnLabel": "エラーメッセージと原因", - "xpack.apm.errorsTable.groupIdColumnLabel": "グループ ID", - "xpack.apm.errorsTable.latestOccurrenceColumnLabel": "最近のオカレンス", - "xpack.apm.errorsTable.noErrorsLabel": "エラーが見つかりませんでした", - "xpack.apm.errorsTable.occurrencesColumnLabel": "オカレンス", - "xpack.apm.errorsTable.unhandledLabel": "未対応", - "xpack.apm.featureRegistry.apmFeatureName": "APM", - "xpack.apm.filter.environment.allLabel": "すべて", - "xpack.apm.filter.environment.label": "環境", - "xpack.apm.filter.environment.notDefinedLabel": "未定義", - "xpack.apm.filter.environment.selectEnvironmentLabel": "環境を選択", - "xpack.apm.formatters.microsTimeUnitLabel": "マイクロ秒", - "xpack.apm.formatters.millisTimeUnitLabel": "ミリ秒", - "xpack.apm.formatters.requestsPerMinLabel": "1分あたりリクエスト数", - "xpack.apm.formatters.secondsTimeUnitLabel": "秒", - "xpack.apm.formatters.minutesTimeUnitLabel": "最低", - "xpack.apm.formatters.hoursTimeUnitLabel": "h", - "xpack.apm.formatters.transactionsPerMinLabel": "1分あたりトランザクション数", - "xpack.apm.header.badge.readOnly.text": "読み込み専用", - "xpack.apm.header.badge.readOnly.tooltip": "を保存できませんでした", - "xpack.apm.helpMenu.upgradeAssistantLink": "アップグレードアシスタント", - "xpack.apm.home.servicesTabLabel": "サービス", - "xpack.apm.home.tracesTabLabel": "トレース", - "xpack.apm.invalidLicense.licenseManagementLink": "ライセンスを更新", - "xpack.apm.invalidLicense.message": "現在ご使用のライセンスが期限切れか有効でなくなったため、APM UI を利用できません。", - "xpack.apm.invalidLicense.title": "無効なライセンス", - "xpack.apm.metadataTable.section.agentLabel": "エージェント", - "xpack.apm.metadataTable.section.containerLabel": "コンテナー", - "xpack.apm.metadataTable.section.customLabel": "カスタム", - "xpack.apm.metadataTable.section.hostLabel": "ホスト", - "xpack.apm.metadataTable.section.httpLabel": "HTTP", - "xpack.apm.metadataTable.section.labelsLabel": "ラベル", - "xpack.apm.metadataTable.section.processLabel": "プロセス", - "xpack.apm.metadataTable.section.serviceLabel": "サービス", - "xpack.apm.metadataTable.section.urlLabel": "URL", - "xpack.apm.metadataTable.section.userLabel": "ユーザー", - "xpack.apm.metrics.plot.noDataLabel": "この時間範囲のデータがありません。", - "xpack.apm.metrics.transactionChart.machineLearningLabel": "機械学習:", - "xpack.apm.metrics.transactionChart.machineLearningTooltip": "平均期間の周りのストリームには予測バウンドが表示されます。異常スコアが >= 75 の場合、注釈が表示されます。", - "xpack.apm.metrics.transactionChart.pageLoadTimesLabel": "ページ読み込み時間", - "xpack.apm.metrics.transactionChart.requestsPerMinuteLabel": "1 分あたりのリクエスト", - "xpack.apm.metrics.transactionChart.routeChangeTimesLabel": "ルート変更時間", - "xpack.apm.metrics.transactionChart.transactionDurationLabel": "トランザクション時間", - "xpack.apm.metrics.transactionChart.transactionsPerMinuteLabel": "1 分あたりのトランザクション数", - "xpack.apm.notAvailableLabel": "N/A", - "xpack.apm.propertiesTable.agentFeature.noDataAvailableLabel": "利用可能なデータがありません", - "xpack.apm.propertiesTable.tabs.exceptionStacktraceLabel": "例外のスタックトレース", - "xpack.apm.propertiesTable.tabs.logStacktraceLabel": "ログのスタックトレース", - "xpack.apm.propertiesTable.tabs.metadataLabel": "メタデータ", - "xpack.apm.propertiesTable.tabs.timelineLabel": "タイムライン", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.callout.jobExistsDescription": "現在 {serviceName} ({transactionType}) の実行中のジョブがあります。", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.callout.jobExistsDescription.viewJobLinkText": "既存のジョブを表示", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.callout.jobExistsTitle": "ジョブが既に存在します", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.createMLJobDescription": "ここでは、{serviceName} 数列内の APM トランザクションの期間の異常スコアを計算する機械学習ジョブを作成できます。有効にすると、{transactionDurationGraphText} が予測バウンドを表示し、異常スコアが >=75 の場合グラフに注釈が追加されます。", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.createMLJobDescription.transactionDurationGraphText": "トランザクション時間のグラフ", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.createNewJobButtonLabel": "新規ジョブを作成", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.enableAnomalyDetectionTitle": "異常検知を有効にする", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.jobCreatedNotificationText": "現在 {serviceName} ({transactionType}) の分析を実行中です。応答時間グラフに結果が追加されるまで少し時間がかかる場合があります。", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.jobCreatedNotificationText.viewJobLinkText": "ジョブを表示", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.jobCreatedNotificationTitle": "ジョブが作成されました", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.jobCreationFailedNotificationText": "現在のライセンスでは機械学習ジョブの作成が許可されていないか、ジョブが既に存在する可能性があります。", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.jobCreationFailedNotificationTitle": "ジョブの作成に失敗", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.manageMLJobDescription": "ジョブはそれぞれのサービス + トランザクションタイプの組み合わせに対して作成できます。ジョブの作成後、{mlJobsPageLink} で管理と詳細の確認ができます。", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.manageMLJobDescription.mlJobsPageLinkText": "機械学習ジョブの管理ページ", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.manageMLJobDescription.noteText": "注:ジョブが結果の計算を開始するまでに少し時間がかかる場合があります。", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.selectTransactionTypeLabel": "このジョブのトランザクションタイプを選択してください", - "xpack.apm.serviceDetails.enableErrorReportsPanel.actionsDescription": "レポートはメールで送信するか Slack チャンネルに投稿できます。各レポートにはオカランス別のトップ 10 のエラーが含まれます。", - "xpack.apm.serviceDetails.enableErrorReportsPanel.actionsTitle": "アクション", - "xpack.apm.serviceDetails.enableErrorReportsPanel.conditionTitle": "コンディション", - "xpack.apm.serviceDetails.enableErrorReportsPanel.createWatchButtonLabel": "ウォッチを作成", - "xpack.apm.serviceDetails.enableErrorReportsPanel.dailyReportHelpText": "デイリーレポートは {dailyTimeFormatted} / {dailyTime12HourFormatted} に送信されます。", - "xpack.apm.serviceDetails.enableErrorReportsPanel.dailyReportRadioButtonLabel": "デイリーレポート", - "xpack.apm.serviceDetails.enableErrorReportsPanel.emailSubjectText": "{serviceName} にしきい値を超えたエラーグループがあります", - "xpack.apm.serviceDetails.enableErrorReportsPanel.emailTemplateText": "{serviceName} サービスに {timeRange}{br}{br}{errorGroupsBuckets}{br}{errorLogMessage}{br}{errorCulprit}N/A{slashErrorCulprit}{br}{docCountParam} オカレンス {br}{slashErrorGroupsBucket} 内で {threshold} 件のオカレンスを超えるエラーグループがあります", - "xpack.apm.serviceDetails.enableErrorReportsPanel.enableErrorReportsTitle": "エラーレポートを有効にする", - "xpack.apm.serviceDetails.enableErrorReportsPanel.formDescription": "このフォームは、このサービスでのエラーのオカレンスを通知するウォッチの作成をアシストします。Watcher の書斎は、{documentationLink} をご覧ください。", - "xpack.apm.serviceDetails.enableErrorReportsPanel.formDescription.documentationLinkText": "ドキュメンテーション", - "xpack.apm.serviceDetails.enableErrorReportsPanel.intervalHelpText": "レポートの間隔。", - "xpack.apm.serviceDetails.enableErrorReportsPanel.intervalRadioButtonLabel": "間隔", - "xpack.apm.serviceDetails.enableErrorReportsPanel.intervalUnit.hrsLabel": "時間", - "xpack.apm.serviceDetails.enableErrorReportsPanel.intervalUnit.minsLabel": "分", - "xpack.apm.serviceDetails.enableErrorReportsPanel.occurrencesThresholdHelpText": "エラーグループがレポートに含まれるしきい値です。", - "xpack.apm.serviceDetails.enableErrorReportsPanel.occurrencesThresholdLabel": "エラーグループごとのオカレンスのしきい値", - "xpack.apm.serviceDetails.enableErrorReportsPanel.recipientsHelpText": "メールを構成していない場合は、{documentationLink} をご覧ください。", - "xpack.apm.serviceDetails.enableErrorReportsPanel.recipientsHelpText.documentationLinkText": "ドキュメンテーション", - "xpack.apm.serviceDetails.enableErrorReportsPanel.recipientsLabel": "受信者 (コンマ区切り)", - "xpack.apm.serviceDetails.enableErrorReportsPanel.sendEmailLabel": "メールを送信", - "xpack.apm.serviceDetails.enableErrorReportsPanel.sendSlackNotificationLabel": "Slack 通知を送信", - "xpack.apm.serviceDetails.enableErrorReportsPanel.slackTemplateText": "{serviceName} サービスに {timeRange} 以内に {threshold} 件のオカレンスを超えるエラーグループがあります。\n{errorGroupsBuckets}\n{errorLogMessage}\n{errorCulprit}N/A{slashErrorCulprit}\n{docCountParam} 件のオカレンス\n{slashErrorGroupsBucket}", - "xpack.apm.serviceDetails.enableErrorReportsPanel.slackWebhookURLHelpText": "Slack webhook の取得方法は、{documentationLink} をご覧ください。", - "xpack.apm.serviceDetails.enableErrorReportsPanel.slackWebhookURLHelpText.documentationLinkText": "ドキュメンテーション", - "xpack.apm.serviceDetails.enableErrorReportsPanel.slackWebhookURLLabel": "Slack Webhook URL", - "xpack.apm.serviceDetails.enableErrorReportsPanel.triggerScheduleDescription": "しきい値を超えた際のレポートの間隔を選択してください。", - "xpack.apm.serviceDetails.enableErrorReportsPanel.triggerScheduleTitle": "トリガースケジュール", - "xpack.apm.serviceDetails.enableErrorReportsPanel.triggerText": "この値はトリガーセクションで変更する必要があります。", - "xpack.apm.serviceDetails.enableErrorReportsPanel.watchCreatedNotificationText": "ウォッチの準備が完了し、{serviceName} のエラーレポートが送信されます。", - "xpack.apm.serviceDetails.enableErrorReportsPanel.watchCreatedNotificationText.viewWatchLinkText": "ウォッチを表示", - "xpack.apm.serviceDetails.enableErrorReportsPanel.watchCreatedNotificationTitle": "新規ウォッチが作成されました!", - "xpack.apm.serviceDetails.enableErrorReportsPanel.watchCreationFailedNotificationText": "ユーザーにウォッチ作成のパーミッションがあることを確認してください。", - "xpack.apm.serviceDetails.enableErrorReportsPanel.watchCreationFailedNotificationTitle": "ウォッチの作成に失敗", - "xpack.apm.serviceDetails.errorsTabLabel": "エラー", - "xpack.apm.serviceDetails.integrationsMenu.enableMLAnomalyDetectionButtonLabel": "ML 異常検知を有効にする", - "xpack.apm.serviceDetails.integrationsMenu.enableMLAnomalyDetectionButtonTooltip": "このサービスの機械学習ジョブをセットアップします", - "xpack.apm.serviceDetails.integrationsMenu.enableWatcherErrorReportsButtonLabel": "ウォッチエラーレポートを有効にする", - "xpack.apm.serviceDetails.integrationsMenu.integrationsButtonLabel": "統合", - "xpack.apm.serviceDetails.integrationsMenu.viewWatchesButtonLabel": "既存のウォッチを表示", - "xpack.apm.serviceDetails.metrics.cpuUsageChartTitle": "CPU 使用状況", - "xpack.apm.serviceDetails.metrics.errorOccurrencesChartTitle": "エラーのオカレンス", - "xpack.apm.serviceDetails.metrics.memoryUsageChartTitle": "システムメモリー使用状況", - "xpack.apm.serviceDetails.metricsTabLabel": "メトリック", - "xpack.apm.serviceDetails.transactionsTabLabel": "トランザクション", - "xpack.apm.serviceOverview.toastText": "現在 Elastic Stack 7.0+ を実行中で、以前のバージョン 6.x からの互換性のないデータを検知しました。このデータを APM で表示するには、移行が必要です。詳細: ", - "xpack.apm.serviceOverview.toastTitle": "選択された時間範囲内にレガシーデータが検知されました。", - "xpack.apm.serviceOverview.upgradeAssistantLink": "アップグレードアシスタント", - "xpack.apm.servicesTable.7xOldDataMessage": "また、移行が必要な古いデータがある可能性もあります。", - "xpack.apm.servicesTable.7xUpgradeServerMessage": "pre-7.x バージョンからのアップグレードですか?次のアップグレードも完了していることを確認してください:\n APM サーバーインスタンスを 7.0 以降に。", - "xpack.apm.servicesTable.agentColumnLabel": "エージェント", - "xpack.apm.servicesTable.avgResponseTimeColumnLabel": "平均応答時間", - "xpack.apm.servicesTable.environmentColumnLabel": "環境", - "xpack.apm.servicesTable.environmentCount": "{environmentCount, plural, one {1 個の環境} other {# 個の環境}}", - "xpack.apm.servicesTable.errorsPerMinuteColumnLabel": "1 分あたりのエラー", - "xpack.apm.servicesTable.errorsPerMinuteUnitLabel": "エラー", - "xpack.apm.servicesTable.nameColumnLabel": "名前", - "xpack.apm.servicesTable.noServicesLabel": "APM サービスがインストールされていないようです。追加しましょう!", - "xpack.apm.servicesTable.notFoundLabel": "サービスが見つかりません", - "xpack.apm.servicesTable.transactionsPerMinuteColumnLabel": "1 分あたりのトランザクション", - "xpack.apm.servicesTable.transactionsPerMinuteUnitLabel": "1分あたりトランザクション数", - "xpack.apm.servicesTable.UpgradeAssistantLink": "Kibana アップグレードアシスタントで詳細をご覧ください", - "xpack.apm.setupInstructionsButtonLabel": "セットアップの手順", - "xpack.apm.stacktraceTab.localVariablesToogleButtonLabel": "ローカル変数", - "xpack.apm.stacktraceTab.noStacktraceAvailableLabel": "利用可能なスタックトレースがありません", - "xpack.apm.toggleHeight.showLessButtonLabel": "表示する行数を減らす", - "xpack.apm.toggleHeight.showMoreButtonLabel": "表示する行数を増やす", - "xpack.apm.tracesTable.avgResponseTimeColumnLabel": "平均応答時間", - "xpack.apm.tracesTable.impactColumnLabel": "インパクト", - "xpack.apm.tracesTable.nameColumnLabel": "名前", - "xpack.apm.tracesTable.notFoundLabel": "このクエリのトレースが見つかりません", - "xpack.apm.tracesTable.originatingServiceColumnLabel": "発生元サービス", - "xpack.apm.tracesTable.tracesPerMinuteColumnLabel": "1 分あたりのトレース", - "xpack.apm.tracesTable.tracesPerMinuteUnitLabel": "tpm", - "xpack.apm.transactionActionMenu.actionsButtonLabel": "アクション", - "xpack.apm.transactionActionMenu.actionsLabel": "アクション", - "xpack.apm.transactionActionMenu.showContainerLogsLinkLabel": "コンテナーログを表示", - "xpack.apm.transactionActionMenu.showContainerMetricsLinkLabel": "コンテナーメトリックを表示", - "xpack.apm.transactionActionMenu.showHostLogsLinkLabel": "ホストログを表示", - "xpack.apm.transactionActionMenu.showHostMetricsLinkLabel": "ホストメトリックを表示", - "xpack.apm.transactionActionMenu.showPodLogsLinkLabel": "ポッドログを表示", - "xpack.apm.transactionActionMenu.showPodMetricsLinkLabel": "ポッドメトリックを表示", - "xpack.apm.transactionActionMenu.showTraceLogsLinkLabel": "トレースログを表示", - "xpack.apm.transactionActionMenu.viewInUptime": "監視ステータスを表示", - "xpack.apm.transactionActionMenu.viewSampleDocumentLinkLabel": "サンプルドキュメントを表示", - "xpack.apm.transactionDetails.errorsOverviewLinkTooltip": "{errorCount, plural, one {1 件の関連エラーを表示} other {# 件の関連エラーを表示}}", - "xpack.apm.transactionDetails.notFoundLabel": "トランザクションが見つかりませんでした。", - "xpack.apm.transactionDetails.noTraceParentButtonTooltip": "トレースの親が見つかりませんでした", - "xpack.apm.transactionDetails.resultLabel": "結果", - "xpack.apm.transactionDetails.serviceLabel": "サービス", - "xpack.apm.transactionDetails.servicesTitle": "サービス", - "xpack.apm.transactionDetails.spanFlyout.databaseStatementTitle": "データベースステートメント", - "xpack.apm.transactionDetails.spanFlyout.nameLabel": "名前", - "xpack.apm.transactionDetails.spanFlyout.spanDetailsTitle": "スパン詳細", - "xpack.apm.transactionDetails.spanFlyout.spanType.navigationTimingLabel": "ナビゲーションタイミング", - "xpack.apm.transactionDetails.spanFlyout.stackTraceTabLabel": "スタックトレース", - "xpack.apm.transactionDetails.spanFlyout.viewSpanInDiscoverButtonLabel": "ディスカバリでスパンを表示", - "xpack.apm.transactionDetails.transactionLabel": "トランザクション", - "xpack.apm.transactionDetails.transactionsDurationDistributionChart.noSampleTooltip": "このバケットに利用可能なサンプルがありません", - "xpack.apm.transactionDetails.transactionsDurationDistributionChart.requestTypeUnitLongLabel": "{transCount, plural, =0 {# request} 1 {# 件のリクエスト} other {# 件のリクエスト}}", - "xpack.apm.transactionDetails.transactionsDurationDistributionChart.transactionTypeUnitLongLabel": "{transCount, plural, =0 {# transaction} 1 {# 件のトランザクション} other {# 件のトランザクション}}", - "xpack.apm.transactionDetails.transactionsDurationDistributionChart.unitShortLabel": "{transCount} {transType, select, request {件のリクエスト} other {件のトランザクション}}", - "xpack.apm.transactionDetails.transactionsDurationDistributionChartTitle": "トラザクション時間の分布", - "xpack.apm.transactionDetails.transactionsDurationDistributionChartTooltip.samplingDescription": "各バケットはサンプルトランザクションを示します。利用可能なサンプルがない場合、恐らくエージェントの構成で設定されたサンプリング制限が原因です。", - "xpack.apm.transactionDetails.transactionsDurationDistributionChartTooltip.samplingLabel": "サンプリング", - "xpack.apm.transactionDetails.transFlyout.callout.agentDroppedSpansMessage": "このトランザクションを報告した APM エージェントが、構成に基づき {dropped} 個以上のスパンをドロップしました。", - "xpack.apm.transactionDetails.transFlyout.callout.learnMoreAboutDroppedSpansLinkText": "ドロップされたスパンの詳細。", - "xpack.apm.transactionDetails.transFlyout.transactionDetailsTitle": "トランザクションの詳細", - "xpack.apm.transactionDetails.viewFullTraceButtonLabel": "完全なトレースを表示", - "xpack.apm.transactionDetails.viewingFullTraceButtonTooltip": "現在完全なトレースが表示されています", - "xpack.apm.transactions.chart.95thPercentileLabel": "95 パーセンタイル", - "xpack.apm.transactions.chart.99thPercentileLabel": "99 パーセンタイル", - "xpack.apm.transactions.chart.anomalyBoundariesLabel": "異常境界", - "xpack.apm.transactions.chart.anomalyScoreLabel": "異常スコア", - "xpack.apm.transactions.chart.averageLabel": "平均", - "xpack.apm.transactionsTable.95thPercentileColumnLabel": "95 パーセンタイル", - "xpack.apm.transactionsTable.avgDurationColumnLabel": "平均期間", - "xpack.apm.transactionsTable.impactColumnLabel": "インパクト", - "xpack.apm.transactionsTable.nameColumnLabel": "名前", - "xpack.apm.transactionsTable.transactionsPerMinuteColumnLabel": "1 分あたりのトランザクション", - "xpack.apm.transactionsTable.transactionsPerMinuteUnitLabel": "tpm", - "xpack.apm.applyFilter": "{title} フィルターを適用", - "xpack.apm.applyOptions": "オプションを適用", - "xpack.apm.clearFilters": "フィルターを消去", - "xpack.apm.datePicker.last15MinutesLabel": "過去 15 分間", - "xpack.apm.datePicker.last1HourLabel": "過去 1 時間", - "xpack.apm.datePicker.last1YearLabel": "過去 1 年間", - "xpack.apm.datePicker.last24HoursLabel": "過去 24 時間", - "xpack.apm.datePicker.last30DaysLabel": "過去 30 日間", - "xpack.apm.datePicker.last30MinutesLabel": "過去 30 分間", - "xpack.apm.datePicker.last7DaysLabel": "過去 7 日間", - "xpack.apm.datePicker.last90DaysLabel": "過去 90 日間", - "xpack.apm.error.prompt.body": "詳細はブラウザの開発者コンソールをご確認ください。", - "xpack.apm.error.prompt.title": "申し訳ございませんが、エラーが発生しました :(", - "xpack.apm.fetcher.error.status": "エラー", - "xpack.apm.fetcher.error.title": "リソースの取得中にエラーが発生しました", - "xpack.apm.fetcher.error.url": "URL", - "xpack.apm.localFilters.titles.agentName": "エージェント名", - "xpack.apm.localFilters.titles.containerId": "コンテナー ID", - "xpack.apm.localFilters.titles.host": "ホスト", - "xpack.apm.localFilters.titles.podName": "ポッド", - "xpack.apm.localFilters.titles.transactionResult": "トランザクション結果", - "xpack.apm.localFilters.titles.transactionType": "トランザクションタイプ", - "xpack.apm.localFiltersTitle": "各種フィルター", - "xpack.apm.metrics.durationByCountryMap.avgPageLoadByCountryLabel": "国ごとの平均ページ読み込み時間の分布", - "xpack.apm.metrics.durationByCountryMap.RegionMapChart.ToolTip.avgPageLoadDuration": "平均ページ読み込み時間:", - "xpack.apm.metrics.durationByCountryMap.RegionMapChart.ToolTip.countPageLoads": "{docCount} ページの読み込み", - "xpack.apm.settings.agentConf.configTable.editButtonDescription": "この構成を編集します", - "xpack.apm.settings.agentConf.configTable.editButtonLabel": "編集", - "xpack.apm.settings.agentConf.configTable.emptyPromptText": "変更しましょう。直接 Kibana からエージェント構成を微調整できます。再展開する必要はありません。まず、最初の構成を作成します。", - "xpack.apm.settings.agentConf.configTable.emptyPromptTitle": "構成が見つかりません。", - "xpack.apm.settings.agentConf.configTable.environmentColumnLabel": "サービス環境", - "xpack.apm.settings.agentConf.configTable.lastUpdatedColumnLabel": "最終更新", - "xpack.apm.settings.agentConf.configTable.sampleRateColumnLabel": "サンプルレート", - "xpack.apm.settings.agentConf.configTable.serviceNameColumnLabel": "サービス名", - "xpack.apm.settings.agentConf.configurationsPanelTitle": "構成", - "xpack.apm.settings.agentConf.createConfigButtonLabel": "構成の作成", - "xpack.apm.transactionDetails.traceNotFound": "選択されたトレースが見つかりません", - "xpack.apm.transactionDetails.traceSampleTitle": "トレースのサンプル", - "xpack.apm.transactionsTable.notFoundLabel": "トランザクションが見つかりませんでした。", - "xpack.apm.waterfall.exceedsMax": "このトレースの項目数は表示されている範囲を超えています", - "xpack.apm.agentMetrics.java.gcRate": "GC レート", - "xpack.apm.agentMetrics.java.gcRateChartTitle": "1 分ごとのごみ収集レート", - "xpack.apm.agentMetrics.java.gcTime": "GC 時間", - "xpack.apm.agentMetrics.java.gcTimeChartTitle": "1 分ごとのごみ収集の時間", - "xpack.apm.breadcrumb.nodesTitle": "JVM", - "xpack.apm.breadcrumb.serviceMapTitle": "サービスマップ", - "xpack.apm.errorGroupDetails.relatedTransactionSample": "関連トランザクションサンプル", - "xpack.apm.home.serviceMapTabLabel": "サービスマップ", - "xpack.apm.jvmsTable.cpuColumnLabel": "CPU 平均", - "xpack.apm.jvmsTable.explainServiceNodeNameMissing": "これらのメトリックが所属する JVM を特定できませんでした。7.5 よりも古い APM Server を実行していることが原因である可能性が高いです。この問題は APM Server 7.5 以降にアップグレードすることで解決されます。", - "xpack.apm.jvmsTable.heapMemoryColumnLabel": "ヒープ領域の平均", - "xpack.apm.jvmsTable.nameColumnLabel": "名前", - "xpack.apm.jvmsTable.nameExplanation": "JVM 名はデフォルトでコンピューター ID (該当する場合) またはホスト名ですが、エージェントの「'service_node_name」で手動で構成することもできます。", - "xpack.apm.jvmsTable.noJvmsLabel": "JVM が見つかりませんでした", - "xpack.apm.jvmsTable.nonHeapMemoryColumnLabel": "非ヒープ領域の平均", - "xpack.apm.jvmsTable.threadCountColumnLabel": "最大スレッド数", - "xpack.apm.metadataTable.section.errorLabel": "エラー", - "xpack.apm.metadataTable.section.pageLabel": "ページ", - "xpack.apm.metadataTable.section.spanLabel": "スパン", - "xpack.apm.metadataTable.section.traceLabel": "トレース", - "xpack.apm.metadataTable.section.transactionLabel": "トランザクション", - "xpack.apm.metadataTable.section.userAgentLabel": "ユーザーエージェント", - "xpack.apm.percentOfParent": "({parentType, select, transaction { 件中 {value} 件のトランザクション} トレース {trace} })", - "xpack.apm.serviceDetails.nodesTabLabel": "JVM", - "xpack.apm.serviceMap.fullscreen": "全画面", - "xpack.apm.serviceMap.zoomIn": "ズームイン", - "xpack.apm.serviceMap.zoomOut": "ズームアウト", - "xpack.apm.serviceNodeMetrics.containerId": "コンテナー ID", - "xpack.apm.serviceNodeMetrics.host": "ホスト", - "xpack.apm.serviceNodeMetrics.unidentifiedServiceNodesWarningDocumentationLink": "APM Server のドキュメンテーション", - "xpack.apm.serviceNodeMetrics.unidentifiedServiceNodesWarningText": "これらのメトリックが所属する JVM を特定できませんでした。7.5 よりも古い APM Server を実行していることが原因である可能性が高いです。この問題は APM Server 7.5 以降にアップグレードすることで解決されます。アップグレードに関する詳細は、{link} をご覧ください。代わりに Kibana クエリバーを使ってホスト名、コンテナー ID、またはその他フィールドでフィルタリングすることもできます。", - "xpack.apm.serviceNodeMetrics.unidentifiedServiceNodesWarningTitle": "JVM を特定できませんでした", - "xpack.apm.serviceNodeNameMissing": "(空)", - "xpack.apm.settings.agentConf.allOptionLabel": "すべて", - "xpack.apm.settings.agentConf.cancelButtonLabel": "キャンセル", - "xpack.apm.settings.agentConf.configTable.appliedTooltipMessage": "1 つまたは複数のエージェントにより適用されました。", - "xpack.apm.settings.agentConf.configTable.captureBodyColumnLabel": "キャプチャ本文", - "xpack.apm.settings.agentConf.configTable.configTable.failurePromptText": "エージェントの構成一覧を取得できませんでした。ユーザーに十分なパーミッションがない可能性があります。", - "xpack.apm.settings.agentConf.configTable.createConfigButtonLabel": "構成の作成", - "xpack.apm.settings.agentConf.configTable.notAppliedTooltipMessage": "まだエージェントにより適用されていません", - "xpack.apm.settings.agentConf.configTable.transactionMaxSpansColumnLabel": "トランザクションの最大範囲", - "xpack.apm.settings.agentConf.createConfigTitle": "構成の作成", - "xpack.apm.settings.agentConf.editConfigTitle": "構成の編集", - "xpack.apm.settings.agentConf.flyout.deleteSection.buttonLabel": "削除", - "xpack.apm.settings.agentConf.flyout.deleteSection.deleteConfigFailedText": "{serviceName} の構成を削除中にエラーが発生しました。エラー「{errorMessage}」", - "xpack.apm.settings.agentConf.flyout.deleteSection.deleteConfigFailedTitle": "構成を削除できませんでした", - "xpack.apm.settings.agentConf.flyout.deleteSection.deleteConfigSucceededText": "「{serviceName}」の構成が正常に削除されました。エージェントに反映されるまでに少し時間がかかります。", - "xpack.apm.settings.agentConf.flyout.deleteSection.deleteConfigSucceededTitle": "構成が削除されました", - "xpack.apm.settings.agentConf.flyOut.serviceSection.alreadyConfiguredOption": "既に構成済み", - "xpack.apm.settings.agentConf.flyOut.serviceSection.selectPlaceholder": "選択してください", - "xpack.apm.settings.agentConf.flyOut.serviceSection.serviceEnvironmentSelectHelpText": "構成ごとに 1 つの環境のみがサポートされます。", - "xpack.apm.settings.agentConf.flyOut.serviceSection.serviceEnvironmentSelectLabel": "環境", - "xpack.apm.settings.agentConf.flyOut.serviceSection.serviceNameSelectHelpText": "構成するサービスを選択してください。", - "xpack.apm.settings.agentConf.flyOut.serviceSection.serviceNameSelectLabel": "名前", - "xpack.apm.settings.agentConf.flyOut.serviceSection.title": "サービス", - "xpack.apm.settings.agentConf.flyOut.settingsSection.captureBodyInputHelpText": "HTTP リクエストのトランザクションの場合、エージェントはリクエスト本文 (POST 変数など) をキャプチャすることができます。デフォルトは「off」です。", - "xpack.apm.settings.agentConf.flyOut.settingsSection.captureBodyInputLabel": "本文をキャプチャ", - "xpack.apm.settings.agentConf.flyOut.settingsSection.captureBodyInputPlaceholderText": "オプションを選択", - "xpack.apm.settings.agentConf.flyOut.settingsSection.sampleRateConfigurationInputErrorText": "サンプルレートは 0.000 ~ 1 の範囲でなければなりません", - "xpack.apm.settings.agentConf.flyOut.settingsSection.sampleRateConfigurationInputHelpText": "0.000 ~ 1.0 の範囲のレートを選択してください。デフォルトは 1.0 (トレースの 100%) です。", - "xpack.apm.settings.agentConf.flyOut.settingsSection.sampleRateConfigurationInputLabel": "トランザクションのサンプルレート", - "xpack.apm.settings.agentConf.flyOut.settingsSection.sampleRateConfigurationInputPlaceholderText": "サンプルレートを設定", - "xpack.apm.settings.agentConf.flyOut.settingsSection.title": "オプション", - "xpack.apm.settings.agentConf.flyOut.settingsSection.transactionMaxSpansConfigInputErrorText": "0 と 32000 の間でなければなりません", - "xpack.apm.settings.agentConf.flyOut.settingsSection.transactionMaxSpansConfigInputHelpText": "トランザクションごとに記録される範囲を制限します。デフォルトは 500 です。", - "xpack.apm.settings.agentConf.flyOut.settingsSection.transactionMaxSpansConfigInputLabel": "トランザクションの最大範囲", - "xpack.apm.settings.agentConf.flyOut.settingsSection.transactionMaxSpansConfigInputPlaceholderText": "トランザクションの最大範囲を設定", - "xpack.apm.settings.agentConf.saveConfig.failed.text": "「{serviceName}」の構成を保存中にエラーが発生しました。エラー「{errorMessage}」", - "xpack.apm.settings.agentConf.saveConfig.failed.title": "構成を保存できませんでした", - "xpack.apm.settings.agentConf.saveConfig.succeeded.text": "「{serviceName}」の構成が保存されました。エージェントに反映されるまでに少し時間がかかります。", - "xpack.apm.settings.agentConf.saveConfig.succeeded.title": "構成が保存されました", - "xpack.apm.settings.agentConf.saveConfigurationButtonLabel": "保存", - "xpack.apm.tracesTable.impactColumnDescription": "ご利用のサービスで最も頻繁に使用されていて、最も遅いエンドポイントです。相対的平均時間に 1 分ごとのトランザクション数をかけて計算されます。", - "xpack.apm.transactionBreakdown.noData": "この時間範囲のデータがありません。", - "xpack.apm.transactionDetails.errorCount": "{errorCount, number} {errorCount, plural, one {件のエラー} other {件のエラー}}", - "xpack.apm.transactionDetails.requestMethodLabel": "リクエストメソッド", - "xpack.apm.transactionDetails.spanFlyout.spanAction": "アクション", - "xpack.apm.transactionDetails.spanFlyout.spanSubtype": "サブタイプ", - "xpack.apm.transactionDetails.spanFlyout.spanType": "タイプ", - "xpack.apm.transactionDetails.statusCode": "ステータスコード", - "xpack.apm.transactionDetails.userAgentAndVersionLabel": "ユーザーエージェントとバージョン", - "xpack.apm.transactionDurationLabel": "期間", - "xpack.apm.transactionsTable.impactColumnDescription": "ご利用のサービスで最も頻繁に使用されていて、最も遅いエンドポイントです。相対的平均時間に 1 分ごとのトランザクション数をかけて計算されます。", - "xpack.beatsManagement.beat.actionSectionTypeLabel": "タイプ: {beatType}。", - "xpack.beatsManagement.beat.actionSectionVersionLabel": "バージョン: {beatVersion}", - "xpack.beatsManagement.beat.beatNameAndIdTitle": "ビート: {nameOrNoName} (ID: {id})", - "xpack.beatsManagement.beat.beatNotFoundErrorMessage": "ビートが見つかりません", - "xpack.beatsManagement.beat.beatNotFoundErrorTitle": "ビートが見つかりません", - "xpack.beatsManagement.beat.beatNotFoundMessage": "ビートが見つかりません", - "xpack.beatsManagement.beat.configTabLabel": "構成", - "xpack.beatsManagement.beat.configurationTagsTabLabel": "構成タグ", - "xpack.beatsManagement.beat.detailsConfigurationDescription": "1 つのタグに風数構成を適用することができます。これらの構成は必要に応じて同じタイプを繰り返したり、タイプを組み合わせることができます。例えば、3 つの Metricbeat 構成と同時に 1 つのインプットと Filebeat 構成を使用することができます。", - "xpack.beatsManagement.beat.detailsConfigurationTitle": "構成", - "xpack.beatsManagement.beat.lastConfigUpdateMessage": "前回の構成の更新: {lastUpdateTime}。", - "xpack.beatsManagement.beat.loadingTitle": "読み込み中", - "xpack.beatsManagement.beatConfigurations.descriptionColumnName": "説明", - "xpack.beatsManagement.beatConfigurations.moduleColumnName": "モジュール", - "xpack.beatsManagement.beatConfigurations.tagColumnName": "タグ", - "xpack.beatsManagement.beatConfigurations.typeColumnName": "タイプ", - "xpack.beatsManagement.beats.addedNotificationDescription": "タグ {tag} を {assignmentsLength, plural, one { ビート {beatName}} other {# ビート}}に追加しました。", - "xpack.beatsManagement.beats.addedNotificationTitle": "{assignmentsLength, plural, one {タグ } other {タグ}} が追加されました", - "xpack.beatsManagement.beats.beatDisenrolledNotificationDescription": "ID {firstBeatId} のビートの登録が解除されました。", - "xpack.beatsManagement.beats.beatDisenrolledNotificationTitle": "{firstBeatNameOrId} の登録解除", - "xpack.beatsManagement.beats.configurationTagsTabTitle": "構成タグ", - "xpack.beatsManagement.beats.disenrolledBeatsNotificationTitle": "{beatsLength} 個のビートの登録解除", - "xpack.beatsManagement.beats.enrollBeatsButtonLabel": "ビートを登録", - "xpack.beatsManagement.beats.enrolledBeatsTabTitle": "登録済みのビート", - "xpack.beatsManagement.beats.enrollNewBeatsTitle": "新規ビートの登録", - "xpack.beatsManagement.beats.installBeatsLearningButtonLabel": "ビートのインストール方法", - "xpack.beatsManagement.beats.removedNotificationDescription": "{assignmentsLength, plural, one {beat {beatName}} other {# beats}}からタグ{tag}が削除されました。", - "xpack.beatsManagement.beats.removedNotificationTitle": "{assignmentsLength, plural, one {Tag} other {Tags}} が削除されました", - "xpack.beatsManagement.beatsListAssignmentOptions.setTagsButtonLabel": "タグを設定", - "xpack.beatsManagement.beatsListAssignmentOptions.unenrollBeatsWarninigMessage": "選択されたビートは今後集中管理を使用しません", - "xpack.beatsManagement.beatsListAssignmentOptions.unenrollBeatsWarninigTitle": "選択されたビートの登録を解除しますか?", - "xpack.beatsManagement.beatsListAssignmentOptions.unenrollButtonLabel": "選択項目の登録を解除", - "xpack.beatsManagement.beatsTable.beatNameTitle": "ビート名", - "xpack.beatsManagement.beatsTable.configErrorStatusLabel": "構成エラー", - "xpack.beatsManagement.beatsTable.configStatus.errorTooltip": "このビートにエラーがあります。このホストのログを確認してください。", - "xpack.beatsManagement.beatsTable.configStatus.noConnectionTooltip": "このビートは 10 分以上 Kibana に接続していません", - "xpack.beatsManagement.beatsTable.configStatus.notStartedLabel": "未開始", - "xpack.beatsManagement.beatsTable.configStatus.notStartedTooltip": "このビートはまだ開始していません。", - "xpack.beatsManagement.beatsTable.configStatus.offlineLabel": "オフライン", - "xpack.beatsManagement.beatsTable.configStatus.okLabel": "OK", - "xpack.beatsManagement.beatsTable.configStatus.okTooltip": "最新の構成にビートが適用されました", - "xpack.beatsManagement.beatsTable.configStatus.progressTooltip": "このビートは現在 CM から構成を再読み込み中です。", - "xpack.beatsManagement.beatsTable.configStatus.runningTooltip": "このビートは問題なく動作中です。", - "xpack.beatsManagement.beatsTable.configStatus.startingTooltip": "このビートは開始中です。", - "xpack.beatsManagement.beatsTable.configStatusTitle": "構成ステータス", - "xpack.beatsManagement.beatsTable.disenrollSelectedLabel": "選択項目の登録を解除", - "xpack.beatsManagement.beatsTable.failedStatusLabel": "エラー", - "xpack.beatsManagement.beatsTable.runningStatusLabel": "実行中", - "xpack.beatsManagement.beatsTable.startingStatusLabel": "開始中", - "xpack.beatsManagement.beatsTable.stoppedStatusLabel": "停止中", - "xpack.beatsManagement.beatsTable.tagsTitle": "タグ", - "xpack.beatsManagement.beatsTable.typeLabel": "タイプ", - "xpack.beatsManagement.beatsTable.typeTitle": "タイプ", - "xpack.beatsManagement.beatsTable.updatingStatusLabel": "更新中", - "xpack.beatsManagement.beatTagsTable.addTagLabel": "タグを追加", - "xpack.beatsManagement.beatTagsTable.lastUpdateTitle": "最終更新", - "xpack.beatsManagement.beatTagsTable.removeSelectedLabel": "選択項目を削除", - "xpack.beatsManagement.beatTagsTable.tagNameTitle": "タグ名", - "xpack.beatsManagement.breadcrumb.beatDetails": "{beatId} のビート詳細", - "xpack.beatsManagement.breadcrumb.beatTags": "{beatId} のビートタグ", - "xpack.beatsManagement.breadcrumb.configurationTags": "構成タグ", - "xpack.beatsManagement.breadcrumb.enrolledBeats": "登録済みのビート", - "xpack.beatsManagement.centralManagementLinkLabel": "集中管理", - "xpack.beatsManagement.centralManagementSectionLabel": "Beats", - "xpack.beatsManagement.config.other.error": "有効な YAML フォーマットを使用してください", - "xpack.beatsManagement.config.otherConfigDescription": "YAML フォーマットで Filebeat インプットの他の設定を指定します", - "xpack.beatsManagement.config.otherConfigLabel": "他の構成", - "xpack.beatsManagement.confirmModal.cancelButtonLabel": "キャンセル", - "xpack.beatsManagement.confirmModal.confirmButtonLabel": "確認", - "xpack.beatsManagement.confirmModal.confirmWarningTitle": "確認", - "xpack.beatsManagement.createTag.errorSavingTagTitle": "タグの保存中にエラーが発生", - "xpack.beatsManagement.createTag.saveAndContinueButtonLabel": "保存して続行", - "xpack.beatsManagement.disabledSecurityDescription": "ビートの集中管理を使用するには、Kibana と Elasticsearch でセキュリティを有効にする必要があります。", - "xpack.beatsManagement.disabledSecurityTitle": "セキュリティが有効ではありません", - "xpack.beatsManagement.enrollBeat.assignTagToBeatInvalidURLNoTagFoundTitle": "無効な URL、createdTag が見つかりません", - "xpack.beatsManagement.enrollBeat.assignTagToBeatInvalidURLNoTokenFountTitle": "無効な URL、enrollmentToken が見つかりません", - "xpack.beatsManagement.enrollBeat.assignTagToBeatNotEnrolledProperlyTitle": "エラー:ビートを正常に登録できません", - "xpack.beatsManagement.enrollBeat.beatEnrolledTitle": "このビートは現在集中管理に登録されています:", - "xpack.beatsManagement.enrollBeat.beatsCentralManagementDescription": "一か所で構成を集中管理できます。", - "xpack.beatsManagement.enrollBeat.beatTypeColumnName": "ビートタイプ", - "xpack.beatsManagement.enrollBeat.beatTypeTitle": "ビートタイプ:", - "xpack.beatsManagement.enrollBeat.copyButtonLabel": "コマンドをコピー", - "xpack.beatsManagement.enrollBeat.createTagStepLabel": "タグを作成", - "xpack.beatsManagement.enrollBeat.enrollBeatButtonLabel": "ビートを登録", - "xpack.beatsManagement.enrollBeat.enrollBeatStepLabel": "ビートを登録", - "xpack.beatsManagement.enrollBeat.finishStepLabel": "終了", - "xpack.beatsManagement.enrollBeat.firstBeatEnrollingDoneButtonLabel": "完了", - "xpack.beatsManagement.enrollBeat.getStartedBeatsCentralManagementTitle": "ビートの集中管理を開始", - "xpack.beatsManagement.enrollBeat.hostnameColumnName": "ホスト名", - "xpack.beatsManagement.enrollBeat.nextStepDescription": "ビートを起動して構成エラーを確認し、「完了」をクリックしてください。", - "xpack.beatsManagement.enrollBeat.nextStepTitle": "ビートが登録されました。次のステップ", - "xpack.beatsManagement.enrollBeat.platformTitle": "プラットフォーム:", - "xpack.beatsManagement.enrollBeat.versionColumnName": "バージョン", - "xpack.beatsManagement.enrollBeat.waitingBeatTypeToEnrollTitle": "{beatType} の登録待ち…", - "xpack.beatsManagement.enrollBeat.yourBeatTypeHostTitle": "{beatType} がインストールされているホストでは次を実行:", - "xpack.beatsManagement.filebeatInputConfig.otherConfigDescription": "YAML フォーマットで Filebeat インプットの他の設定を指定します", - "xpack.beatsManagement.filebeatInputConfig.otherConfigErrorMessage": "有効な YAML フォーマットを使用してください", - "xpack.beatsManagement.filebeatInputConfig.otherConfigLabel": "他の構成", - "xpack.beatsManagement.filebeatInputConfig.pathsDescription": "それぞれのパスを別々の行に入力します", - "xpack.beatsManagement.filebeatInputConfig.pathsErrorMessage": "1 行につき 1 つのパスを入力してください", - "xpack.beatsManagement.filebeatInputConfig.pathsLabel": "パス", - "xpack.beatsManagement.filebeatModuleConfig.moduleDescription": "YAML フォーマットで Filebeat モジュールの他の設定を指定します", - "xpack.beatsManagement.filebeatModuleConfig.moduleErrorMessage": "モジュールを選択してください。", - "xpack.beatsManagement.filebeatModuleConfig.moduleLabel": "モジュール", - "xpack.beatsManagement.filebeatModuleConfig.otherConfigErrorMessage": "有効な YAML フォーマットを使用してください", - "xpack.beatsManagement.filebeatModuleConfig.otherConfigLabel": "他の構成", - "xpack.beatsManagement.invalidLicenseDescription": "現在のライセンスは期限切れです。登録されたビートは引き続き動作しますが、ビート管理 UI にアクセスするには有効なライセンスが必要です。", - "xpack.beatsManagement.invalidLicenseTitle": "ライセンスの期限切れ", - "xpack.beatsManagement.management.breadcrumb": "管理", - "xpack.beatsManagement.metricbeatModuleConfig.hostsDescription": "それぞれのパスを別々の行に入力します", - "xpack.beatsManagement.metricbeatModuleConfig.hostsErrorMessage": "1 行につき 1 つのファイルホストを入力してください", - "xpack.beatsManagement.metricbeatModuleConfig.hostsLabel": "すべてのホスト", - "xpack.beatsManagement.metricbeatModuleConfig.moduleErrorMessage": "モジュールを選択してください。", - "xpack.beatsManagement.metricbeatModuleConfig.moduleLabel": "モジュール", - "xpack.beatsManagement.metricbeatModuleConfig.otherConfigDescription": "YAML フォーマットで Metricbeat モジュールの他の設定を指定します", - "xpack.beatsManagement.metricbeatModuleConfig.otherConfigErrorMessage": "有効な YAML フォーマットを使用してください", - "xpack.beatsManagement.metricbeatModuleConfig.otherConfigLabel": "他の構成", - "xpack.beatsManagement.metricbeatModuleConfig.periodErrorMessage": "無効な期間、10 秒は「10s」というフォーマットを使用してください", - "xpack.beatsManagement.metricbeatModuleConfig.periodLabel": "期間", - "xpack.beatsManagement.noAccess.accessDeniedDescription": "ビート集中管理へのアクセス権がありません。ビート集中管理を使用するには、{beatsAdminRole} ロールから権限が必要です。", - "xpack.beatsManagement.noAccess.accessDeniedTitle": "アクセスが拒否されました", - "xpack.beatsManagement.noContentFoundErrorMessage": "コンテンツがありません", - "xpack.beatsManagement.outputConfig.hostsErrorMessage": "1 行につき 1 つのファイルホストを入力してください", - "xpack.beatsManagement.outputConfig.hostsLabel": "すべてのホスト", - "xpack.beatsManagement.outputConfig.outputTypeErrorMessage": "アウトプットタイプを選択してください", - "xpack.beatsManagement.outputConfig.outputTypeLabel": "アウトプットタイプ", - "xpack.beatsManagement.outputConfig.passwordErrorMessage": "処理不能なパスワードです", - "xpack.beatsManagement.outputConfig.passwordLabel": "パスワード", - "xpack.beatsManagement.outputConfig.usernameErrorMessage": "処理不能なユーザー名です", - "xpack.beatsManagement.outputConfig.usernameLabel": "ユーザー名", - "xpack.beatsManagement.overview.betaBadgeText": "ベータ", - "xpack.beatsManagement.table.filterResultsPlaceholder": "フィルター結果", - "xpack.beatsManagement.table.selectOptionLabel": "オプションを選択してください", - "xpack.beatsManagement.table.selectThisBeatTooltip": "このビートを選択します", - "xpack.beatsManagement.tag.addConfigurationButtonLabel": "構成ブロックを追加", - "xpack.beatsManagement.tag.beatsAssignedToTagTitle": "このタグが付いたビート", - "xpack.beatsManagement.tag.cancelButtonLabel": "キャンセル", - "xpack.beatsManagement.tag.createTagTitle": "タグの作成", - "xpack.beatsManagement.tag.saveButtonLabel": "保存", - "xpack.beatsManagement.tag.tagColorLabel": "タグの色", - "xpack.beatsManagement.tag.tagConfigurationsDescription": "タグには異なるタイプのビートの構成ブロックが使用できます。例えば、1 つのタグに 2 つの Metricbeat 構成ブロックと 1 つの Filebeat インプット構成ブロックを使用することができます。", - "xpack.beatsManagement.tag.tagConfigurationsTitle": "構成ブロック", - "xpack.beatsManagement.tag.tagDetailsDescription": "タグとは、1 つまたは複数のビートに適用できる構成ブロックのグループです。", - "xpack.beatsManagement.tag.tagDetailsTitle": "タグの詳細", - "xpack.beatsManagement.tag.tagName.validationErrorMessage": "タグ名には文字、数字、ハイフンのみが使用できます。", - "xpack.beatsManagement.tag.tagNameLabel": "タグ名", - "xpack.beatsManagement.tag.tagNamePlaceholder": "タグ名 (必須)", - "xpack.beatsManagement.tag.updateTagTitle": "タグ {tagId} を更新", - "xpack.beatsManagement.tagConfig.addConfigurationTitle\"": "構成ブロックを追加", - "xpack.beatsManagement.tagConfig.closeButtonLabel": "閉じる", - "xpack.beatsManagement.tagConfig.configurationTypeText": "{configType}‘構成", - "xpack.beatsManagement.tagConfig.descriptionLabel": "説明", - "xpack.beatsManagement.tagConfig.descriptionPlaceholder": "説明 (オプション)", - "xpack.beatsManagement.tagConfig.editConfigurationTitle": "構成ブロックの編集", - "xpack.beatsManagement.tagConfig.filebeatInputLabel": "Filebeat インプット", - "xpack.beatsManagement.tagConfig.filebeatModuleLabel": "Filebeat モジュール", - "xpack.beatsManagement.tagConfig.invalidSchema": "エラー:この構成は無効です。Beats でサポートされておらず、削除する必要があります", - "xpack.beatsManagement.tagConfig.metricbeatModuleLabel": "Metricbeat モジュール", - "xpack.beatsManagement.tagConfig.outputLabel": "アウトプット", - "xpack.beatsManagement.tagConfig.saveButtonLabel": "保存", - "xpack.beatsManagement.tagConfig.typeLabel": "タイプ", - "xpack.beatsManagement.tagConfig.viewConfigurationTitle\"": "構成ブロックの表示", - "xpack.beatsManagement.tagConfigAssignmentOptions.removeTagsButtonLabel": "タグを削除", - "xpack.beatsManagement.tagConfigAssignmentOptions.removeTagsWarninigMessage": "選択されたビートからタグを削除しますか?", - "xpack.beatsManagement.tagConfigAssignmentOptions.removeTagsWarninigTitle": "タグを削除", - "xpack.beatsManagement.tagListAssignmentOptions.removeTagsButtonLabel": "選択項目を削除", - "xpack.beatsManagement.tagListAssignmentOptions.removeTagsWarninigTitle": "タグを削除", - "xpack.beatsManagement.tagListAssignmentOptions.removeTagWarninigMessage": "タグを削除しますか?", - "xpack.beatsManagement.tags.addTagButtonLabel": "タグを追加", - "xpack.beatsManagement.tags.someTagsMightBeAssignedToBeatsTitle": "これらのタグのいくつかはビートに割り当てられている可能性があります。削除するタグが現在割り当てられていないことを確認してください", - "xpack.beatsManagement.tagsTable.lastUpdateTitle": "最終更新", - "xpack.beatsManagement.tagsTable.removeSelectedLabel": "選択項目を削除", - "xpack.beatsManagement.tagsTable.tagNameTitle": "タグ名", - "xpack.beatsManagement.tagTable.actions.removeButtonAriaLabel": "削除", - "xpack.beatsManagement.tagTable.actions.removeTooltip": "タグからこの構成を削除します", - "xpack.beatsManagement.tagTable.actionsColumnName": "アクション", - "xpack.beatsManagement.tagTable.descriptionColumnName": "説明", - "xpack.beatsManagement.tagTable.moduleColumn.notAvailibaleLabel": "N/A", - "xpack.beatsManagement.tagTable.moduleColumnName": "モジュール", - "xpack.beatsManagement.tagTable.typeColumnName": "タイプ", - "xpack.beatsManagement.walkthrough.initial.betaBadgeText": "ベータ", - "xpack.canvas.badge.readOnly.text": "読み込み専用", - "xpack.canvas.elements.areaChartDisplayName": "面グラフ", - "xpack.canvas.elements.areaChartHelpText": "塗りつぶされた折れ線グラフ", - "xpack.canvas.elements.bubbleChartDisplayName": "バブルチャート", - "xpack.canvas.elements.bubbleChartHelpText": "カスタマイズ可能なバブルチャートです", - "xpack.canvas.elements.debugDisplayName": "デバッグ", - "xpack.canvas.elements.debugHelpText": "エレメントの構成をダンプします", - "xpack.canvas.elements.donutChartDisplayName": "ドーナッツチャート", - "xpack.canvas.elements.donutChartHelpText": "カスタマイズ可能なドーナッツチャートです", - "xpack.canvas.elements.dropdownFilterDisplayName": "ドロップダウンフィルター", - "xpack.canvas.elements.dropdownFilterHelpText": "「exactly」フィルターの値を選択できるドロップダウンです", - "xpack.canvas.elements.horizontalBarChartDisplayName": "水平棒グラフ", - "xpack.canvas.elements.horizontalBarChartHelpText": "カスタマイズ可能な水平棒グラフです", - "xpack.canvas.elements.horizontalProgressBarDisplayName": "水平プログレスバー", - "xpack.canvas.elements.horizontalProgressBarHelpText": "水平バーに進捗状況を表示します", - "xpack.canvas.elements.horizontalProgressPillDisplayName": "水平プログレスピル", - "xpack.canvas.elements.horizontalProgressPillHelpText": "水平ピルに進捗状況を表示します", - "xpack.canvas.elements.imageDisplayName": "画像", - "xpack.canvas.elements.imageHelpText": "静止画", - "xpack.canvas.elements.lineChartDisplayName": "折れ線グラフ", - "xpack.canvas.elements.lineChartHelpText": "カスタマイズ可能な折れ線グラフです", - "xpack.canvas.elements.markdownDisplayName": "マークダウン", - "xpack.canvas.elements.markdownHelpText": "マークダウンからマークアップします", - "xpack.canvas.elements.metricDisplayName": "メトリック", - "xpack.canvas.elements.metricHelpText": "ラベル付きの数字です", - "xpack.canvas.elements.pieDisplayName": "円グラフ", - "xpack.canvas.elements.pieHelpText": "円グラフ", - "xpack.canvas.elements.plotDisplayName": "座標プロット", - "xpack.canvas.elements.plotHelpText": "折れ線、棒、点の組み合わせです", - "xpack.canvas.elements.progressGaugeDisplayName": "進捗ゲージ", - "xpack.canvas.elements.progressGaugeHelpText": "進捗状況をゲージで表示します", - "xpack.canvas.elements.progressSemicircleDisplayName": "進捗半円", - "xpack.canvas.elements.progressSemicircleHelpText": "進捗状況を半円で表示します", - "xpack.canvas.elements.progressWheelDisplayName": "進捗ホイール", - "xpack.canvas.elements.progressWheelHelpText": "進捗状況をホイールで表示します", - "xpack.canvas.elements.repeatImageDisplayName": "画像の繰り返し", - "xpack.canvas.elements.repeatImageHelpText": "画像を N 回繰り返します", - "xpack.canvas.elements.revealImageDisplayName": "画像の部分表示", - "xpack.canvas.elements.revealImageHelpText": "画像のパーセンテージを表示します", - "xpack.canvas.elements.shapeDisplayName": "図形", - "xpack.canvas.elements.shapeHelpText": "カスタマイズ可能な図形です", - "xpack.canvas.elements.tableDisplayName": "データテーブル", - "xpack.canvas.elements.tableHelpText": "データをチューブ形式で表示する、スクロール可能なグリッドです", - "xpack.canvas.elements.tiltedPieDisplayName": "傾き円グラフ", - "xpack.canvas.elements.tiltedPieHelpText": "カスタマイズ可能な傾き円グラフです", - "xpack.canvas.elements.timeFilterDisplayName": "時間フィルター", - "xpack.canvas.elements.timeFilterHelpText": "期間を設定します", - "xpack.canvas.elements.verticalBarChartDisplayName": "垂直棒グラフ", - "xpack.canvas.elements.verticalBarChartHelpText": "カスタマイズ可能な垂直棒グラフです", - "xpack.canvas.elements.verticalProgressBarDisplayName": "垂直プログレスバー", - "xpack.canvas.elements.verticalProgressBarHelpText": "進捗状況を垂直のバーで表示します", - "xpack.canvas.elements.verticalProgressPillDisplayName": "垂直プログレスピル", - "xpack.canvas.elements.verticalProgressPillHelpText": "進捗状況を垂直のピルで表示します", - "xpack.canvas.functions.alterColumn.args.columnHelpText": "変更する列の名前です。", - "xpack.canvas.functions.alterColumn.args.nameHelpText": "変更後の列名です。名前を変更しない場合は未入力のままにします。", - "xpack.canvas.functions.alterColumn.args.typeHelpText": "列の変換語のタイプです。タイプを変更しない場合は未入力のままにします。", - "xpack.canvas.functions.alterColumn.cannotConvertTypeErrorMessage": "「{type}」に変換できません", - "xpack.canvas.functions.alterColumn.columnNotFoundErrorMessage": "列が見つかりません: 「{column}」", - "xpack.canvas.functions.as.args.nameHelpText": "列に付ける名前です", - "xpack.canvas.functions.axisConfig.args.showHelpText": "軸ラベルを表示しますか?", - "xpack.canvas.functions.axisConfig.args.tickSizeHelpText": "目盛り間の増加量です。「数字」軸のみで使用されます", - "xpack.canvas.functions.axisConfig.invalidMaxPositionErrorMessage": "無効なデータ文字列: 「{max}」。「max」は数字、ms での日付、または ISO8601 データ文字列出なければなりません", - "xpack.canvas.functions.axisConfig.invalidMinDateStringErrorMessage": "無効なデータ文字列: 「{min}」。「min」は数字、ms での日付、または ISO8601 データ文字列出なければなりません", - "xpack.canvas.functions.axisConfig.invalidPositionErrorMessage": "無効なポジション: 「{position}」", - "xpack.canvas.functions.case.args.thenHelpText": "条件が満たされた際に戻る値です。", - "xpack.canvas.functions.compare.args.opHelpText": "比較で使用する演算子です: {eq} (equal to)、{gt} (greater than)、{gte} (greater than or equal to)、{lt} (less than)、{lte} (less than or equal to)、{ne} または {neq} (not equal to)", - "xpack.canvas.functions.compare.invalidCompareOperatorErrorMessage": "無効な比較演算子: 「{op}」。{ops} を使用してください", - "xpack.canvas.functions.containerStyle.args.borderRadiusHelpText": "角を丸くする際に使用されるピクセル数です。", - "xpack.canvas.functions.containerStyle.args.opacityHelpText": "0 から 1 までの数字で、エレメントの透明度を示します。", - "xpack.canvas.functions.containerStyle.args.paddingHelpText": "ピクセル単位のコンテンツの境界からの距離です。", - "xpack.canvas.functions.containerStyle.invalidBackgroundImageErrorMessage": "無効な背景画像。アセットまたは URL を入力してください。", - "xpack.canvas.functions.csv.args.delimeterHelpText": "データの区切り文字です。", - "xpack.canvas.functions.csv.args.newlineHelpText": "行の区切り文字です。", - "xpack.canvas.functions.csv.invalidInputCSVErrorMessage": "インプット CSV の解析中にエラーが発生しました。", - "xpack.canvas.functions.date.invalidDateInputErrorMessage": "無効な日付インプット: {date}", - "xpack.canvas.functions.dateHelpText": "現在時刻、または指定された文字列から解析された時刻を、新紀元からのミリ秒で返します。", - "xpack.canvas.functions.demodata.args.typeHelpText": "使用するデモデータセットの名前です。", - "xpack.canvas.functions.demodata.invalidDataSetErrorMessage": "無効なデータセット: 「{arg}」。「{ci}」または「{shirts}」を使用してください", - "xpack.canvas.functions.demodataHelpText": "プロジェクト {ci} の回数とユーザー名、国、実行フェーズを含む模擬データセットです。", - "xpack.canvas.functions.dropdownControl.args.filterColumnHelpText": "フィルタリングする列またはフィールドです。", - "xpack.canvas.functions.dropdownControl.args.filterGroupHelpText": "フィルターのグループ名です。", - "xpack.canvas.functions.dropdownControl.args.valueColumnHelpText": "ドロップダウンコントロールの固有値を抽出する元の列またはフィールドです。", - "xpack.canvas.functions.dropdownControlHelpText": "ドロップダウンフィルターのコントロールエレメントを構成します。", - "xpack.canvas.functions.escount.args.indexHelpText": "インデックスまたはインデックスパターンです。例: {example}。", - "xpack.canvas.functions.esdocs.args.countHelpText": "取得するドキュメント数です。パフォーマンスを向上させるには、小さなデータセットを使用します。", - "xpack.canvas.functions.esdocs.args.fieldsHelpText": "フィールドのコンマ区切りのリストです。パフォーマンスを向上させるには、フィールドの数を減らします。", - "xpack.canvas.functions.esdocs.args.indexHelpText": "インデックスまたはインデックスパターンです。例: {example}。", - "xpack.canvas.functions.esdocs.args.metaFieldsHelpText": "メタフィールドのコンマ区切りのリストです。例: {example}。", - "xpack.canvas.functions.esdocs.args.sortHelpText": "{directions} フォーマットの並べ替え方向です。例: {example1} または {example2}。", - "xpack.canvas.functions.essql.args.countHelpText": "取得するドキュメント数です。パフォーマンスを向上させるには、小さなデータセットを使用します。", - "xpack.canvas.functions.exactly.args.columnHelpText": "フィルタリングする列またはフィールドです。", - "xpack.canvas.functions.exactly.args.valueHelpText": "ホワイトスペースと大文字・小文字を含め、正確に一致させる値です。", - "xpack.canvas.functions.exactlyHelpText": "特定の列をピッタリと正確な値に一致させるフィルターを作成します。", - "xpack.canvas.functions.getCell.args.rowHelpText": "行番号で、0 から開始します。", - "xpack.canvas.functions.getCell.columnNotFoundErrorMessage": "列が見つかりません: 「{column}」", - "xpack.canvas.functions.getCell.rowNotFoundErrorMessage": "行が見つかりません: 「{row}」", - "xpack.canvas.functions.ifHelpText": "条件付きロジックを実行します", - "xpack.canvas.functions.image.args.modeHelpText": "{contain} はサイズに合わせて拡大・縮小して画像全体を表示し、{cover} はコンテナーを画像で埋め、必要に応じて両端や下をクロップします。{stretch} は画像の高さと幅をコンテナーの 100% になるよう変更します", - "xpack.canvas.functions.image.invalidImageModeErrorMessage": "「mode」は「{contain}」、「{cover}」、または「{stretch}」でなければなりません", - "xpack.canvas.functions.mapColumn.args.nameHelpText": "結果の列の名前です。", - "xpack.canvas.functions.math.emptyDatatableErrorMessage": "空のデータベース", - "xpack.canvas.functions.math.emptyExpressionErrorMessage": "空の表現", - "xpack.canvas.functions.math.executionFailedErrorMessage": "数式の実行に失敗しました。列名を確認してください", - "xpack.canvas.functions.math.tooManyResultsErrorMessage": "表現は 1 つの数字を返す必要があります。表現を {mean} または {sum} で囲んでみてください", - "xpack.canvas.functions.metric.args.labelHelpText": "メトリックを説明するテキストです。", - "xpack.canvas.functions.metricHelpText": "ラベルの上に数字を表示します。", - "xpack.canvas.functions.palette.args.gradientHelpText": "サポートされている場合グラデーションパレットを作成しますか?", - "xpack.canvas.functions.palette.args.reverseHelpText": "パレットを反転させますか?", - "xpack.canvas.functions.paletteHelpText": "カラーパレットを作成します。", - "xpack.canvas.functions.pie.args.holeHelpText": "円グラフに穴をあけます、0~100 で円グラフの半径のパーセンテージを指定します。", - "xpack.canvas.functions.pie.args.labelRadiusHelpText": "ラベルの円の半径として使用する、コンテナーの面積のパーセンテージです。", - "xpack.canvas.functions.pie.args.labelsHelpText": "円グラフのラベルを表示しますか?", - "xpack.canvas.functions.pie.args.radiusHelpText": "利用可能なスペースのパーセンテージで示された円グラフの半径です (0 から 1 の間)。半径を自動的に設定するには {auto} を使用します。", - "xpack.canvas.functions.pie.args.seriesStyleHelpText": "特定の数列のスタイルです", - "xpack.canvas.functions.pie.args.tiltHelpText": "「1」 が完全に垂直、「0」が完全に水平を表す傾きのパーセンテージです。", - "xpack.canvas.functions.pieHelpText": "円グラフのエレメントを構成します。", - "xpack.canvas.functions.plot.args.defaultStyleHelpText": "すべての数列に使用するデフォルトのスタイルです。", - "xpack.canvas.functions.plot.args.seriesStyleHelpText": "特定の数列のスタイルです", - "xpack.canvas.functions.ply.columnNotFoundErrorMessage": "列が見つかりません: 「{by}」", - "xpack.canvas.functions.ply.rowCountMismatchErrorMessage": "すべての表現が同じ行数を返す必要があります。", - "xpack.canvas.functions.pointseries.args.colorHelpText": "マークの色を決めるのに使用する表現です。", - "xpack.canvas.functions.pointseries.args.sizeHelpText": "マークのサイズです。サポートされているエレメントのみに適用されます。", - "xpack.canvas.functions.pointseries.args.textHelpText": "マークに表示するテキストです。サポートされているエレメントのみに適用されます。", - "xpack.canvas.functions.pointseries.args.xHelpText": "X 軸の値です。", - "xpack.canvas.functions.pointseries.args.yHelpText": "Y 軸の値です。", - "xpack.canvas.functions.pointseries.unwrappedExpressionErrorMessage": "表現は {fn} などの関数で囲む必要があります", - "xpack.canvas.functions.progress.args.barColorHelpText": "背景バーの色です。", - "xpack.canvas.functions.progress.args.barWeightHelpText": "背景バーの太さです。", - "xpack.canvas.functions.progress.args.maxHelpText": "進捗エレメントの最高値です。", - "xpack.canvas.functions.progress.args.shapeHelpText": "{list} または {end} を選択します。", - "xpack.canvas.functions.progress.args.valueColorHelpText": "進捗バーの色です。", - "xpack.canvas.functions.progress.args.valueWeightHelpText": "進捗バーの太さです。", - "xpack.canvas.functions.progress.invalidMaxValueErrorMessage": "無効な {arg} 値: 「{max, number}」。「{arg}」は 0 より大きい必要があります", - "xpack.canvas.functions.progress.invalidValueErrorMessage": "無効な値: 「{value, number}」。値は 0 と {max, number} の間でなければなりません", - "xpack.canvas.functions.progressHelpText": "進捗エレメントを構成します。", - "xpack.canvas.functions.render.args.containerStyleHelpText": "背景、境界、透明度を含む、コンテナーのスタイルです。", - "xpack.canvas.functions.repeatImage.args.maxHelpText": "画像が繰り返される最高回数です。", - "xpack.canvas.functions.repeatImage.args.sizeHelpText": "画像の高さまたは幅のピクセル単位での最高値です。画像が縦長の場合、この関数は高さを制限します。", - "xpack.canvas.functions.repeatImageHelpText": "繰り返し画像エレメントを構成します。", - "xpack.canvas.functions.replace.args.flagsHelpText": "フラグを指定します。{url} を参照。", - "xpack.canvas.functions.replace.args.replacementHelpText": "文字列の一致する部分の代わりです。キャプチャグループはノードによってアクセス可能です。例: {example}。", - "xpack.canvas.functions.replaceImageHelpText": "正規表現で文字列の一部を置き換えます。", - "xpack.canvas.functions.revealImage.invalidPercentErrorMessage": "無効な値: 「{percent}」.パーセンテージは 0 と 1 の間でなければなりません ", - "xpack.canvas.functions.revealImageHelpText": "画像表示エレメントを構成します。", - "xpack.canvas.functions.seriesStyle.args.barsHelpText": "バーの幅です。", - "xpack.canvas.functions.seriesStyle.args.colorHelpText": "ラインカラーです。", - "xpack.canvas.functions.seriesStyle.args.fillHelpText": "点を埋めますか?", - "xpack.canvas.functions.seriesStyle.args.horizontalBarsHelpText": "グラフの棒の方向を水平に設定します。", - "xpack.canvas.functions.seriesStyle.args.labelHelpText": "スタイルを適用する数列の名前です。", - "xpack.canvas.functions.seriesStyle.args.linesHelpText": "線の幅です。", - "xpack.canvas.functions.seriesStyle.args.pointsHelpText": "線上の点のサイズです", - "xpack.canvas.functions.shape.args.borderWidthHelpText": "境界の太さです。", - "xpack.canvas.functions.shape.args.shapeHelpText": "図形を選択します。", - "xpack.canvas.functions.shapeHelpText": "図形を作成します。", - "xpack.canvas.functions.sortHelpText": "データ表を指定された列で並べ替えます。", - "xpack.canvas.functions.staticColumn.args.nameHelpText": "新しい列の名前です。", - "xpack.canvas.functions.table.args.showHeaderHelpText": "各列のタイトルと共にヘッダー行を表示するかしないかです。", - "xpack.canvas.functions.timefilter.args.columnHelpText": "フィルタリングする列またはフィールドです。", - "xpack.canvas.functions.timefilter.invalidStringErrorMessage": "無効な日付/時刻文字列: 「{str}」", - "xpack.canvas.functions.timefilterControl.args.columnHelpText": "フィルタリングする列またはフィールドです。", - "xpack.canvas.functions.timefilterControl.args.compactHelpText": "時間フィルターを、ポップオーバーを実行するボタンとして表示します。", - "xpack.canvas.appDescription": "データを完璧に美しく表現します。", - "xpack.canvas.functions.exactly.args.filterGroupHelpText": "フィルターのグループ名です。", - "xpack.canvas.functions.metric.args.metricFormatHelpText": "{NUMERALJS} 文字列のフォーマットです。例: {example1} または {example2}。{url} を参照。", - "xpack.canvas.functions.timefilter.args.filterGroupHelpText": "フィルターのグループ名です。", - "xpack.canvas.functions.all.args.conditionHelpText": "確認する条件です。", - "xpack.canvas.functions.allHelpText": "すべての条件が満たされている場合、{BOOLEAN_TRUE} が返されます。{anyFn} もご参照ください。", - "xpack.canvas.functions.alterColumnHelpText": "{list}、{end} などのコアタイプを変換し、列名を変更します。{mapColumnFn} および {staticColumnFn} もご参照ください。", - "xpack.canvas.functions.any.args.conditionHelpText": "確認する条件です。", - "xpack.canvas.functions.anyHelpText": "少なくとも 1 つの条件が満たされている場合、{BOOLEAN_TRUE} が返されます。{all_fn} もご参照ください。", - "xpack.canvas.functions.asHelpText": "単一の値で {DATATABLE} を作成します。{getCellFn} もご参照ください。", - "xpack.canvas.functions.axisConfig.args.maxHelpText": "軸に表示する最高値です。数字または新世紀からのミリ秒単位の日付、もしくは {ISO8601} 文字列でなければなりません。", - "xpack.canvas.functions.axisConfig.args.minHelpText": "軸に表示する最低値です。数字または新世紀からのミリ秒単位の日付、もしくは {ISO8601} 文字列でなければなりません。", - "xpack.canvas.functions.axisConfig.args.positionHelpText": "軸ラベルの配置です。例: {list} または {end}。", - "xpack.canvas.functions.axisConfigHelpText": "ビジュアライゼーションの軸を構成します。{plotFn} でのみ使用されます。", - "xpack.canvas.functions.case.args.ifHelpText": "この値は、条件が満たされているかを示し、通常部分式を使用します。両方が入力された場合、{IF_ARG} 引数が {WHEN_ARG} 引数を上書きします。", - "xpack.canvas.functions.case.args.whenHelpText": "等しいかを確認するために {CONTEXT} と比較される値です。{IF_ARG} 引数も指定されている場合、{WHEN_ARG} 引数は無視されます。", - "xpack.canvas.functions.caseHelpText": "{switchFn} 関数に渡すため、条件と結果を含めて {case} を作成します。", - "xpack.canvas.functions.clearHelpText": "{CONTEXT} を消去し、{TYPE_NULL} を返します。", - "xpack.canvas.functions.columns.args.excludeHelpText": "{DATATABLE} から削除する列名のコンマ区切りのリストです。", - "xpack.canvas.functions.columns.args.includeHelpText": "{DATATABLE} にキープする列名のコンマ区切りのリストです。", - "xpack.canvas.functions.columnsHelpText": "{DATATABLE} に列を含める、または除外します。両方の引数が指定されている場合、まず初めに除外された列が削除されます。", - "xpack.canvas.functions.compare.args.toHelpText": "{CONTEXT} と比較される値です。", - "xpack.canvas.functions.compareHelpText": "{CONTEXT} を指定された値と比較し、{BOOLEAN_TRUE} または {BOOLEAN_FALSE} を決定します。通常「{ifFn}」または「{caseFn}」と組み合わせて使用されます。{examples} などの基本タイプにのみ使用できます。「{eqFn}」、「{gtFn}」、「{gteFn}」、「{ltFn}」、「{lteFn}」、「{neqFn}」もご参照ください", - "xpack.canvas.functions.containerStyle.args.backgroundColorHelpText": "有効な {CSS} 背景色。", - "xpack.canvas.functions.containerStyle.args.backgroundImageHelpText": "有効な {CSS} 背景画像。", - "xpack.canvas.functions.containerStyle.args.backgroundRepeatHelpText": "有効な {CSS} 背景繰り返し。", - "xpack.canvas.functions.containerStyle.args.backgroundSizeHelpText": "有効な {CSS} 背景サイズ。", - "xpack.canvas.functions.containerStyle.args.borderHelpText": "有効な {CSS} 境界。", - "xpack.canvas.functions.containerStyle.args.overflowHelpText": "有効な {CSS} オーバーフロー。", - "xpack.canvas.functions.containerStyleHelpText": "背景、境界、透明度を含む、エレメントのコンテナーのスタイリングに使用されるオブジェクトを使用します。", - "xpack.canvas.functions.contextHelpText": "渡したものをすべて返します。これは、{CONTEXT} を部分式としての関数の引数として使用する際に有効です。", - "xpack.canvas.functions.csv.args.dataHelpText": "使用する {CSV} データです。", - "xpack.canvas.functions.csvHelpText": "{CSV} インプットから {DATATABLE} を作成します。", - "xpack.canvas.functions.date.args.formatHelpText": "指定された日付文字列の解析に使用される {MOMENTJS} フォーマットです。{url} を参照。", - "xpack.canvas.functions.date.args.valueHelpText": "新紀元からのミリ秒に解析するオプションの日付文字列です。日付文字列には、有効な {JS} {date} インプット、または {formatArg} 引数を使用して解析する文字列のどちらかが使用できます。{ISO8601} 文字列を使用するか、フォーマットを提供する必要があります。", - "xpack.canvas.functions.do.args.fnHelpText": "実行する部分式です。この機能は単に元の {CONTEXT} を戻すだけなので、これらの部分式の戻り値はルートパイプラインでは利用できません。", - "xpack.canvas.functions.doHelpText": "複数部分式を実行し、元の {CONTEXT} を戻します。元の {CONTEXT} を変更することなく、アクションまたは副作用を起こす関数の実行に使用します。", - "xpack.canvas.functions.eq.args.valueHelpText": "{CONTEXT} と比較される値です。", - "xpack.canvas.functions.eqHelpText": "{CONTEXT} が引数と等しいかを戻します。", - "xpack.canvas.functions.escount.args.queryHelpText": "{LUCENE} クエリ文字列です。", - "xpack.canvas.functions.escountHelpText": "{ELASTICSEARCH} にクエリを実行して、指定されたクエリに一致するヒット数を求めます。", - "xpack.canvas.functions.esdocs.args.queryHelpText": "{LUCENE} クエリ文字列です。", - "xpack.canvas.functions.esdocsHelpText": "{ELASTICSEARCH} にクエリをかけて生ドキュメントを探します。特に多くの行を必要とする場合、希望のフィールドを指定してください。", - "xpack.canvas.functions.essql.args.queryHelpText": "{ELASTICSEARCH} {SQL} クエリです。", - "xpack.canvas.functions.essql.args.timezoneHelpText": "日付操作の際に使用するタイムゾーンです。有効な {ISO8601} フォーマットと {UTC} は両方を相殺します。", - "xpack.canvas.functions.essqlHelpText": "{ELASTICSEARCH} {SQL} を使用して {ELASTICSEARCH} にクエリを実行します。", - "xpack.canvas.functions.filterrows.args.fnHelpText": "{DATATABLE} の各行に渡す表現式です。表現式は {TYPE_BOOLEAN} に戻ります。{BOOLEAN_TRUE} 値は行を維持し、{BOOLEAN_FALSE} 値は行を削除します。", - "xpack.canvas.functions.filterrowsHelpText": "{DATATABLE} の行を部分式の戻り値に基づきフィルタリングします。", - "xpack.canvas.functions.formatdate.args.formatHelpText": "{MOMENTJS} フォーマットです。例: {example}。{url} を参照。", - "xpack.canvas.functions.formatdateHelpText": "{MOMENTJS} を使って {ISO8601} 日付文字列、または新世紀からのミリ秒での日付をフォーマットします。{url} を参照。", - "xpack.canvas.functions.formatnumber.args.formatHelpText": "{NUMERALJS} 文字列のフォーマットです。例: {example1} または {example2}。{url} を参照。", - "xpack.canvas.functions.formatnumberHelpText": "{NUMERALJS} を使って数字をフォーマットされた数字文字列にフォーマットします。{url} を参照。", - "xpack.canvas.functions.getCell.args.columnHelpText": "値を取得する元の列の名前です。この値は入力されていないと、初めの列から取得されます。", - "xpack.canvas.functions.getCellHelpText": "{DATATABLE} から単一のセルを取得します。", - "xpack.canvas.functions.gt.args.valueHelpText": "{CONTEXT} と比較される値です。", - "xpack.canvas.functions.gte.args.valueHelpText": "{CONTEXT} と比較される値です。", - "xpack.canvas.functions.gteHelpText": "{CONTEXT} が引数以上かを戻します。", - "xpack.canvas.functions.gtHelpText": "{CONTEXT} が引数よりも大きいかを戻します。", - "xpack.canvas.functions.head.args.countHelpText": "{DATATABLE} の初めから取得する行数です。", - "xpack.canvas.functions.headHelpText": "{DATATABLE} から初めの {n} 行を取得します。{tailFn} もご参照ください", - "xpack.canvas.functions.if.args.conditionHelpText": "{BOOLEAN_TRUE} または {BOOLEAN_FALSE} で、条件が満たされているかを示し、通常部分式から戻されます。指定されていない場合、元の {CONTEXT} が戻されます。", - "xpack.canvas.functions.if.args.elseHelpText": "条件が {BOOLEAN_FALSE} の場合の戻り値です。指定されておらず、条件が満たされていない場合は、元の {CONTEXT} が戻されます。", - "xpack.canvas.functions.if.args.thenHelpText": "条件が {BOOLEAN_TRUE} の場合の戻り値です。指定されておらず、条件が満たされている場合は、元の {CONTEXT} が戻されます。", - "xpack.canvas.functions.image.args.dataurlHelpText": "画像の {https} {URL} または {BASE64} データ {URL} です。", - "xpack.canvas.functions.imageHelpText": "画像を表示します。画像アセットを {BASE64} データ {URL} として提供するか、部分式で渡します。", - "xpack.canvas.functions.joinRows.args.columnHelpText": "値を結合する元になる列", - "xpack.canvas.functions.joinRows.args.distinctHelpText": "重複する値を削除しますか?", - "xpack.canvas.functions.joinRows.args.quoteHelpText": "値を囲む引用文字", - "xpack.canvas.functions.joinRows.args.separatorHelpText": "行の値の間で使用する区切り文字", - "xpack.canvas.functions.locationHelpText": "ブラウザの {geolocationAPI} を使用して現在位置を取得します。パフォーマンスに違いはありますが、比較的正確です。{url} を参照。", - "xpack.canvas.functions.lt.args.valueHelpText": "{CONTEXT} と比較される値です。", - "xpack.canvas.functions.lte.args.valueHelpText": "{CONTEXT} と比較される値です。", - "xpack.canvas.functions.lteHelpText": "{CONTEXT} が引数以下かを戻します。", - "xpack.canvas.functions.ltHelpText": "{CONTEXT} が引数よりも小さいかを戻します。", - "xpack.canvas.functions.mapColumn.args.expressionHelpText": "単一行 {DATATABLE} として各行に渡される {CANVAS} 表現です。", - "xpack.canvas.functions.mapColumnHelpText": "他の列の結果として計算された列を追加します。引数が提供された場合のみ変更が加えられます。{mapColumnFn} と {staticColumnFn} もご参照ください。", - "xpack.canvas.functions.markdown.args.contentHelpText": "{MARKDOWN} を含むテキストの文字列です。連結させるには、{stringFn} 関数を複数回渡します。", - "xpack.canvas.functions.markdown.args.fontHelpText": "コンテンツの {CSS} フォントプロパティです。例: {fontFamily} または {fontWeight}。", - "xpack.canvas.functions.markdownHelpText": "{MARKDOWN} テキストをレンダリングするエレメントを追加します。ヒント:単一の数字、メトリック、テキストの段落には {markdownFn} 関数を使います。", - "xpack.canvas.functions.math.args.expressionHelpText": "評価された {TINYMATH} 表現です。{TINYMATH_URL} をご覧ください。", - "xpack.canvas.functions.mathHelpText": "数字または {DATATABLE} を {CONTEXT} として使用して {TINYMATH} 数式を解釈します。{DATATABLE} 列は列名で表示されます。{CONTEXT} が数字の場合は、{value} と表示されます。", - "xpack.canvas.functions.metric.args.labelFontHelpText": "ラベルの {CSS} フォントプロパティです。例: {FONT_FAMILY} または {FONT_WEIGHT}。", - "xpack.canvas.functions.metric.args.metricFontHelpText": "メトリックの {CSS} フォントプロパティです。例: {FONT_FAMILY} または {FONT_WEIGHT}。", - "xpack.canvas.functions.neq.args.valueHelpText": "{CONTEXT} と比較される値です。", - "xpack.canvas.functions.neqHelpText": "{CONTEXT} が引数と等しくないかを戻します。", - "xpack.canvas.functions.palette.args.colorHelpText": "パレットの色です。{html} カラー名、{hex}、{hsl}、{hsla}、{rgb}、または {rgba} を受け付けます。", - "xpack.canvas.functions.pie.args.fontHelpText": "表の {CSS} フォントプロパティです。例: {FONT_FAMILY} または {FONT_WEIGHT}。", - "xpack.canvas.functions.pie.args.legendHelpText": "凡例の配置です。例: {positions}、または {BOOLEAN_FALSE}。{BOOLEAN_FALSE} の場合、凡例は非表示になります。", - "xpack.canvas.functions.pie.args.paletteHelpText": "この円グラフに使用されている色を説明する {palette} オブジェクトです。{paletteFn} をご覧ください。", - "xpack.canvas.functions.plot.args.fontHelpText": "表の {CSS} フォントプロパティです。例: {FONT_FAMILY} または {FONT_WEIGHT}。", - "xpack.canvas.functions.plot.args.legendHelpText": "凡例の配置です。例: {positions}、または {BOOLEAN_FALSE}。{BOOLEAN_FALSE} の場合、凡例は非表示になります。", - "xpack.canvas.functions.plot.args.paletteHelpText": "このチャートに使用される色を説明する {palette} オブジェクトです。{paletteFn} をご覧ください。", - "xpack.canvas.functions.plot.args.xaxisHelpText": "軸の構成です。{BOOLEAN_FALSE} の場合、軸は非表示になります。", - "xpack.canvas.functions.plot.args.yaxisHelpText": "軸の構成です。{BOOLEAN_FALSE} の場合、軸は非表示になります。", - "xpack.canvas.functions.plotHelpText": "チャートのエレメントを構成します", - "xpack.canvas.functions.ply.args.byHelpText": "{DATATABLE} を細分する列です。", - "xpack.canvas.functions.ply.args.expressionHelpText": "それぞれの結果の {DATATABLE} を渡す先の表現です。アドバイス:表現は {DATATABLE} を返す必要があります。直定数を {DATATABLE} にするには {asFn} を使用します。複数表現が同じ行数を戻す必要があります。異なる行数を戻す必要がある場合は、{plyFn} の別のインスタンスにパイピングします。複数表現が同じ名前の行を戻した場合、最後の行が優先されます。", - "xpack.canvas.functions.plyHelpText": "{DATATABLE} を指定された列の固有値で細分し、表現にその結果となる表を渡し、各表現のアウトプットを結合します。", - "xpack.canvas.functions.pointseriesHelpText": "{DATATABLE} を点の配列モデルに変換します。現在 {TINYMATH} 表現でディメンションのメジャーを区別します。{TINYMATH_URL} をご覧ください。引数に {TINYMATH} 表現が入力された場合、その引数をメジャーとして使用し、そうでない場合はディメンションになります。ディメンションを組み合わせて固有のキーを作成します。その後メジャーはそれらのキーで、指定された {TINYMATH} 関数を使用して複製されます。", - "xpack.canvas.functions.progress.args.fontHelpText": "ラベルの {CSS} フォントプロパティです。例: {FONT_FAMILY} または {FONT_WEIGHT}。", - "xpack.canvas.functions.progress.args.labelHelpText": "ラベルの表示・非表示を切り替えるには、{BOOLEAN_TRUE} または {BOOLEAN_FALSE} を使用します。また、ラベルとして表示する文字列を入力することもできます。", - "xpack.canvas.functions.render.args.asHelpText": "レンダリングに使用するエレメントタイプです。代わりに {plotFn} や {shapeFn} などの特殊な関数を使用するほうがいいでしょう。", - "xpack.canvas.functions.render.args.cssHelpText": "このエレメントの対象となるカスタム {CSS} のブロックです。", - "xpack.canvas.functions.renderHelpText": "{CONTEXT} を特定のエレメントとしてレンダリングし、背景と境界のスタイルなどのエレメントレベルのオプションを設定します。", - "xpack.canvas.functions.repeatImage.args.emptyImageHelpText": "{CONTEXT} と {maxArg} パラメーターの間をこの画像で埋めます。画像アセットは {BASE64} データ {URL} として提供するか、部分式で渡します。", - "xpack.canvas.functions.repeatImage.args.imageHelpText": "繰り返す画像です。画像アセットを {BASE64} データ {URL} として提供するか、部分式で渡します。", - "xpack.canvas.functions.replace.args.patternHelpText": "{JS} 正規表現のテキストまたはパターンです。例: {example}。ここではキャプチャグループを使用できます。", - "xpack.canvas.functions.revealImage.args.emptyImageHelpText": "表示される背景画像です。画像アセットは {BASE64} データ {URL} として提供するか、部分式で渡します。", - "xpack.canvas.functions.revealImage.args.imageHelpText": "表示する画像です。画像アセットを {BASE64} データ {URL} として提供するか、部分式で渡します。", - "xpack.canvas.functions.revealImage.args.originHelpText": "画像で埋め始める位置です。例: {list} または {end}。", - "xpack.canvas.functions.rounddate.args.formatHelpText": "バケットに使用する {MOMENTJS} フォーマットです。たとえば、{example} はそれぞれの日付を月単位に繰り上げ・繰り下げします。{url} を参照。", - "xpack.canvas.functions.rounddateHelpText": "新世紀からのミリ秒の繰り上げ・繰り下げに {MOMENTJS} を使用し、新世紀からのミリ秒を戻します。", - "xpack.canvas.functions.rowCountHelpText": "行数を戻します。{plyFn} と組み合わせて、固有の列値の数、または固有の列値の組み合わせを求めます。", - "xpack.canvas.functions.seriesStyle.args.stackHelpText": "数列をスタックするかを指定します。数字はスタック ID です。同じスタック ID の数列は一緒にスタックされます。", - "xpack.canvas.functions.seriesStyleHelpText": "チャートの数列のプロパティの説明に使用されるオブジェクトを作成します。グラフ関数内では {plotFn} または {pieFn} のような {seriesStyleFn} を使用します。", - "xpack.canvas.functions.shape.args.borderHelpText": "図形の外郭の {SVG} カラーです。", - "xpack.canvas.functions.shape.args.fillHelpText": "図形を塗りつぶす {SVG} カラーです。", - "xpack.canvas.functions.shape.args.maintainAspectHelpText": "図形の元の横縦比を維持しますか?", - "xpack.canvas.functions.sort.args.byHelpText": "並べ替えの基準となる列です。指定されていない場合、「{DATATABLE}」は初めの列で並べられます。", - "xpack.canvas.functions.sort.args.reverseHelpText": "並び順を反転させます。指定されていない場合、「{DATATABLE}」は昇順で並べられます。", - "xpack.canvas.functions.staticColumn.args.valueHelpText": "新しい列の各行に挿入する値です。ヒント: 部分式を使用して他の列を静的値にロールアップします。", - "xpack.canvas.functions.staticColumnHelpText": "すべての行に同じ静的値の列を追加します。{alterColumnFn} および {mapColumnFn} もご参照ください。", - "xpack.canvas.functions.string.args.valueHelpText": "1 つの文字列に結合する値です。必要な場所にスペースを入れてください。", - "xpack.canvas.functions.stringHelpText": "すべての引数を 1 つの文字列に連結させます。", - "xpack.canvas.functions.switch.args.caseHelpText": "確認する条件です", - "xpack.canvas.functions.switch.args.defaultHelpText": "条件が一切満たされていないときに戻される値です。指定されておらず、条件が一切満たされている場合は、元の {CONTEXT} が戻されます。", - "xpack.canvas.functions.switchHelpText": "複数条件の条件付きロジックを実行します。{case} を作成し {switchFn} 関数に渡す {caseFn} もご覧ください。", - "xpack.canvas.functions.table.args.fontHelpText": "表のコンテンツの {CSS} フォントプロパティです。例: {FONT_FAMILY} または {FONT_WEIGHT}。", - "xpack.canvas.functions.table.args.paginateHelpText": "ページ付けのコントロールを表示しますか?{BOOLEAN_FALSE} の場合、初めのページだけが表示されます。", - "xpack.canvas.functions.table.args.perPageHelpText": "各ページに表示される行数です。", - "xpack.canvas.functions.tableHelpText": "表エレメントを構成します", - "xpack.canvas.functions.tail.args.countHelpText": "{DATATABLE} の終わりから取得する行数です。", - "xpack.canvas.functions.tailHelpText": "{DATATABLE} の終わりから N 行を取得します。{headFn} もご参照ください。", - "xpack.canvas.functions.timefilter.args.fromHelpText": "範囲の始まりです。{ISO8601} または {ELASTICSEARCH} {DATEMATH} のフォーマットを使用します", - "xpack.canvas.functions.timefilter.args.toHelpText": "範囲の終わりです。{ISO8601} または {ELASTICSEARCH} {DATEMATH} のフォーマットを使用します", - "xpack.canvas.functions.timefilterControlHelpText": "時間フィルターのコントロールエレメントを構成します。", - "xpack.canvas.functions.timefilterHelpText": "ソースのクエリ用の時間フィルターを作成します。", - "xpack.canvas.functions.urlparam.args.defaultHelpText": "{URL} パラメーターが指定されていないときに戻される文字列です。", - "xpack.canvas.functions.urlparam.args.paramHelpText": "取得する {URL} ハッシュパラメーターです。", - "xpack.canvas.functions.urlparamHelpText": "表現で使用する {URL} パラメーターを取得します。{urlparamFn} 関数は常に {TYPE_STRING} を戻します。たとえば、値 {value} を {URL} {example} のパラメーター {myVar} から取得できます)。", - "xpack.canvas.app.loadErrorMessage": "メッセージ: {error}", - "xpack.canvas.app.loadErrorTitle": "Canvas の読み込みに失敗", - "xpack.canvas.app.loadingMessage": "Canvas を読み込み中", - "xpack.canvas.argAddPopover.addAriaLabel": "引数を追加", - "xpack.canvas.argFormAdvancedFailure.applyButtonLabel": "適用", - "xpack.canvas.argFormAdvancedFailure.resetButtonLabel": "リセット", - "xpack.canvas.argFormAdvancedFailure.rowErrorMessage": "無効な表現", - "xpack.canvas.argFormArgSimpleForm.removeAriaLabel": "削除", - "xpack.canvas.argFormArgSimpleForm.requiredTooltip": "この引数は必須です。数値を入力してください。", - "xpack.canvas.argFormPendingArgValue.loadingMessage": "読み込み中", - "xpack.canvas.argFormSimpleFailure.failureTooltip": "この引数のインターフェースが値を解析できなかったため、フォールバックインプットが使用されています", - "xpack.canvas.asset.copyAssetTooltip": "ID をクリップボードにコピー", - "xpack.canvas.asset.createImageTooltip": "画像エレメントを作成", - "xpack.canvas.asset.deleteAssetTooltip": "削除", - "xpack.canvas.asset.downloadAssetTooltip": "ダウンロード", - "xpack.canvas.asset.thumbnailAltText": "アセットのサムネイル", - "xpack.canvas.assetManager.confirmModalButtonLabel": "削除", - "xpack.canvas.assetManager.confirmModalDetail": "このアセットを削除してよろしいですか?", - "xpack.canvas.assetManager.confirmModalTitle": "アセットの削除", - "xpack.canvas.assetManager.manageButtonLabel": "アセットの管理", - "xpack.canvas.assetModal.emptyAssetsDescription": "アセットをインポートして開始します", - "xpack.canvas.assetModal.filePickerPromptText": "画像を選択するかドラッグ &amp; ドロップしてください", - "xpack.canvas.assetModal.loadingText": "画像をアップロード中", - "xpack.canvas.assetModal.modalCloseButtonLabel": "閉じる", - "xpack.canvas.assetModal.modalDescription": "以下はこのワークパッドの画像アセットです。現在使用中のアセットは現時点で特定できません。スペースを取り戻すには、アセットを削除してください。", - "xpack.canvas.assetModal.modalTitle": "ワークパッドアセットの管理", - "xpack.canvas.assetModal.spacedUsedText": "{percentageUsed}% のスペースを使用中", - "xpack.canvas.assetpicker.assetAltText": "アセットのサムネイル", - "xpack.canvas.colorManager.addAriaLabel": "色を追加", - "xpack.canvas.colorManager.codePlaceholder": "カラーコード", - "xpack.canvas.colorManager.removeAriaLabel": "色を削除", - "xpack.canvas.customElementModal.cancelButtonLabel": "キャンセル", - "xpack.canvas.customElementModal.descriptionInputLabel": "説明", - "xpack.canvas.customElementModal.elementPreviewTitle": "エレメントのプレビュー", - "xpack.canvas.customElementModal.imageFilePickerPlaceholder": "画像を選択するかドラッグ &amp; ドロップしてください", - "xpack.canvas.customElementModal.imageInputDescription": "エレメントのスクリーンショットを作成してここにアップロードします。保存後に行うこともできます。", - "xpack.canvas.customElementModal.imageInputLabel": "サムネイル画像", - "xpack.canvas.customElementModal.nameInputLabel": "名前", - "xpack.canvas.customElementModal.remainingCharactersDescription": "残り {numberOfRemainingCharacter} 文字", - "xpack.canvas.customElementModal.saveButtonLabel": "保存", - "xpack.canvas.datasourceDatasourceComponent.changeButtonLabel": "データソースを変更", - "xpack.canvas.datasourceDatasourceComponent.previewButtonLabel": "プレビュー", - "xpack.canvas.datasourceDatasourceComponent.saveButtonLabel": "保存", - "xpack.canvas.datasourceDatasourcePreview.emptyFirstLineDescription": "検索条件に一致するドキュメントが見つかりませんでした。", - "xpack.canvas.datasourceDatasourcePreview.emptySecondLineDescription": "データソース設定を確認して再試行してください。", - "xpack.canvas.datasourceDatasourcePreview.emptyTitle": "ドキュメントが見つかりませんでした", - "xpack.canvas.datasourceDatasourcePreview.modalDescription": "このデータを使用するには、サイドバーの {saveLabel} をクリックしてください。", - "xpack.canvas.datasourceDatasourcePreview.modalTitle": "データソースのプレビュー", - "xpack.canvas.datasourceNoDatasource.panelDescription": "このエレメントにはデータソースが添付されていません。これは通常、エレメントが画像または他の不動アセットであることが原因です。その場合、表現が正しい形式であることを確認することをお勧めします。", - "xpack.canvas.datasourceNoDatasource.panelTitle": "データソースなし", - "xpack.canvas.elementConfig.failedLabel": "失敗", - "xpack.canvas.elementConfig.loadedLabel": "読み込み済み", - "xpack.canvas.elementConfig.progressLabel": "進捗", - "xpack.canvas.elementConfig.title": "エレメント", - "xpack.canvas.elementConfig.totalLabel": "合計", - "xpack.canvas.elementControls.deleteAriaLabel": "エレメントを削除", - "xpack.canvas.elementControls.deleteToolTip": "削除", - "xpack.canvas.elementControls.editAriaLabel": "エレメントを編集", - "xpack.canvas.elementControls.editToolTip": "編集", - "xpack.canvas.elementSettings.dataTabLabel": "データ", - "xpack.canvas.elementSettings.displayTabLabel": "表示", - "xpack.canvas.elementTypes.addNewElementDescription": "ワークパッドのエレメントをグループ化して保存し、新規エレメントを作成します", - "xpack.canvas.elementTypes.addNewElementTitle": "新規エレメントの作成", - "xpack.canvas.elementTypes.cancelButtonLabel": "キャンセル", - "xpack.canvas.elementTypes.deleteButtonLabel": "削除", - "xpack.canvas.elementTypes.deleteElementDescription": "このエレメントを削除してよろしいですか?", - "xpack.canvas.elementTypes.deleteElementTitle": "エレメント「{elementName}」を削除しますか?", - "xpack.canvas.elementTypes.editElementTitle": "エレメントを編集", - "xpack.canvas.elementTypes.elementsTitle": "エレメント", - "xpack.canvas.elementTypes.findElementPlaceholder": "エレメントを検索", - "xpack.canvas.elementTypes.myElementsTitle": "マイエレメント", - "xpack.canvas.embedObject.noMatchingObjectsMessage": "一致するオブジェクトが見つかりませんでした。", - "xpack.canvas.embedObject.titleText": "オブジェクトの埋め込み", - "xpack.canvas.error.actionsElements.invaludArgIndexErrorMessage": "無効な引数インデックス: {index}", - "xpack.canvas.error.downloadWorkpad.downloadFailureErrorMessage": "ワークパッドをダウンロードできませんでした", - "xpack.canvas.error.downloadWorkpad.downloadRenderedWorkpadFailureErrorMessage": "レンダリングされたワークパッドをダウンロードできませんでした", - "xpack.canvas.error.downloadWorkpad.downloadRuntimeFailureErrorMessage": "共有可能なランタイムをダウンロードできませんでした", - "xpack.canvas.error.downloadWorkpad.downloadZippedRuntimeFailureErrorMessage": "ZIP ファイルをダウンロードできませんでした", - "xpack.canvas.error.esPersist.saveFailureTitle": "変更を Elasticsearch に保存できませんでした", - "xpack.canvas.error.esPersist.tooLargeErrorMessage": "サーバーからワークパッドデータが大きすぎるという返答が返されました。これは通常、アップロードされた画像アセットが Kibana またはプロキシに大きすぎることを意味します。アセットマネージャーでいくつかのアセットを削除してみてください。", - "xpack.canvas.error.esPersist.updateFailureTitle": "ワークパッドを更新できませんでした", - "xpack.canvas.error.esService.defaultIndexFetchErrorMessage": "デフォルトのインデックスを取得できませんでした", - "xpack.canvas.error.esService.fieldsFetchErrorMessage": "「{index}」の Elasticsearch フィールドを取得できませんでした", - "xpack.canvas.error.esService.indicesFetchErrorMessage": "Elasticsearch インデックスを取得できませんでした", - "xpack.canvas.error.RenderWithFn.renderErrorMessage": "「{functionName}」フィールドをレンダリング中", - "xpack.canvas.error.repeatImage.missingMaxArgument": "{emptyImageArgument} を提供する場合、{maxArgument} の設定が必要です。", - "xpack.canvas.error.workpadLoader.cloneFailureErrorMessage": "ワークパッドのクローンを作成できませんでした", - "xpack.canvas.error.workpadLoader.deleteFailureErrorMessage": "すべてのワークパッドを削除できませんでした", - "xpack.canvas.error.workpadLoader.findFailureErrorMessage": "ワークパッドが見つかりませんでした", - "xpack.canvas.error.workpadLoader.uploadFailureErrorMessage": "ワークパッドをアップロードできませんでした", - "xpack.canvas.error.workpadRoutes.createFailureErrorMessage": "ワークパッドを作成できませんでした", - "xpack.canvas.error.workpadRoutes.loadFailureErrorMessage": "ID でワークパッドを読み込めませんでした", - "xpack.canvas.error.workpadUpload.acceptJSONOnlyErrorMessage": "{JSON} 個のファイルしか受け付けられませんでした", - "xpack.canvas.error.workpadUpload.fileUploadFailureWithoutFileNameErrorMessage": "ファイルをアップロードできませんでした", - "xpack.canvas.error.workpadUpload.missingPropertiesErrorMessage": "{CANVAS} ワークパッドに必要なプロパティの一部が欠けています。 {JSON} ファイルを編集して正しいプロパティ値を入力し、再試行してください。", - "xpack.canvas.errorComponent.description": "表現が失敗し次のメッセージが返されました:", - "xpack.canvas.errorComponent.title": "おっと!表現が失敗しました", - "xpack.canvas.errors.workpadUpload.fileUploadFileWithFileNameErrorMessage": "「{fileName}」をアップロードできませんでした", - "xpack.canvas.expression.cancelButtonLabel": "キャンセル", - "xpack.canvas.expression.closeButtonLabel": "閉じる", - "xpack.canvas.expression.learnLinkText": "表現構文の詳細", - "xpack.canvas.expression.maximizeButtonLabel": "エディターを最大化", - "xpack.canvas.expression.minimizeButtonLabel": "エディターを最小化", - "xpack.canvas.expression.runButtonLabel": "実行", - "xpack.canvas.expression.runTooltip": "表現を実行", - "xpack.canvas.expressionElementNotSelected.closeButtonLabel": "閉じる", - "xpack.canvas.expressionElementNotSelected.selectDescription": "表現インプットを表示するエレメントを選択します", - "xpack.canvas.expressionInput.argReferenceAliasesDetail": "{BOLD_MD_TOKEN}Aliases{BOLD_MD_TOKEN}: {aliases}", - "xpack.canvas.expressionInput.argReferenceDefaultDetail": "{BOLD_MD_TOKEN}Default{BOLD_MD_TOKEN}: {defaultVal}", - "xpack.canvas.expressionInput.argReferenceRequiredDetail": "{BOLD_MD_TOKEN}Required{BOLD_MD_TOKEN}: {required}", - "xpack.canvas.expressionInput.argReferenceTypesDetail": "{BOLD_MD_TOKEN}Types{BOLD_MD_TOKEN}: {types}", - "xpack.canvas.expressionInput.functionReferenceAccepts": "{BOLD_MD_TOKEN}Accepts{BOLD_MD_TOKEN}: {acceptTypes}", - "xpack.canvas.expressionInput.functionReferenceReturns": "{BOLD_MD_TOKEN}Returns{BOLD_MD_TOKEN}: {returnType}", - "xpack.canvas.expressionTypes.argTypes.colorDisplayName": "色", - "xpack.canvas.expressionTypes.argTypes.colorHelp": "カラーピッカー", - "xpack.canvas.expressionTypes.argTypes.containerStyle.appearanceTitle": "見た目", - "xpack.canvas.expressionTypes.argTypes.containerStyle.borderTitle": "境界", - "xpack.canvas.expressionTypes.argTypes.containerStyle.colorLabel": "色", - "xpack.canvas.expressionTypes.argTypes.containerStyle.opacityLabel": "レイヤーの透明度", - "xpack.canvas.expressionTypes.argTypes.containerStyle.overflowHiddenDropDown": "非表示", - "xpack.canvas.expressionTypes.argTypes.containerStyle.overflowLabel": "オーバーフロー", - "xpack.canvas.expressionTypes.argTypes.containerStyle.overflowVisibleDropDown": "表示", - "xpack.canvas.expressionTypes.argTypes.containerStyle.paddingLabel": "パッド", - "xpack.canvas.expressionTypes.argTypes.containerStyle.radiusLabel": "半径", - "xpack.canvas.expressionTypes.argTypes.containerStyle.styleLabel": "スタイル", - "xpack.canvas.expressionTypes.argTypes.containerStyle.thicknessLabel": "太さ", - "xpack.canvas.expressionTypes.argTypes.containerStyleLabel": "エレメントコンテナーの見た目の調整", - "xpack.canvas.expressionTypes.argTypes.containerStyleTitle": "コンテナースタイル", - "xpack.canvas.expressionTypes.argTypes.fontHelpLabel": "フォント、サイズ、色を設定します", - "xpack.canvas.expressionTypes.argTypes.fontTitle": "テキスト設定", - "xpack.canvas.expressionTypes.argTypes.seriesStyle.barLabel": "バー", - "xpack.canvas.expressionTypes.argTypes.seriesStyle.colorLabel": "色", - "xpack.canvas.expressionTypes.argTypes.seriesStyle.lineLabel": "折れ線", - "xpack.canvas.expressionTypes.argTypes.seriesStyle.noneDropDown": "なし", - "xpack.canvas.expressionTypes.argTypes.seriesStyle.noSeriesTooltip": "データにスタイリングする数列がありません。カラーディメンションを追加してください", - "xpack.canvas.expressionTypes.argTypes.seriesStyle.pointLabel": "ポイント", - "xpack.canvas.expressionTypes.argTypes.seriesStyle.removeAriaLabel": "数列カラーを削除", - "xpack.canvas.expressionTypes.argTypes.seriesStyle.selectSeriesDropDown": "数列を選択します", - "xpack.canvas.expressionTypes.argTypes.seriesStyle.seriesIdentifierLabel": "数列識別子", - "xpack.canvas.expressionTypes.argTypes.seriesStyle.styleLabel": "スタイル", - "xpack.canvas.expressionTypes.argTypes.seriesStyleLabel": "選択された名前付きの数列のスタイルを設定", - "xpack.canvas.expressionTypes.argTypes.seriesStyleTitle": "数列スタイル", - "xpack.canvas.expressionTypes.datasources.esdocs.ascendingDropDown": "昇順", - "xpack.canvas.expressionTypes.datasources.esdocs.descendingDropDown": "降順", - "xpack.canvas.expressionTypes.datasources.esdocs.fieldsLabel": "抽出するフィールドです。Kibana スクリプトフィールドは現在利用できません", - "xpack.canvas.expressionTypes.datasources.esdocs.fieldsTitle": "フィールド", - "xpack.canvas.expressionTypes.datasources.esdocs.fieldsWarningLabel": "このデータソースは、10 個以下のフィールドで最も高い性能を発揮します", - "xpack.canvas.expressionTypes.datasources.esdocs.indexLabel": "インデックス名を入力するか、インデックスパターンを選択してください", - "xpack.canvas.expressionTypes.datasources.esdocs.indexTitle": "インデックス", - "xpack.canvas.expressionTypes.datasources.esdocs.queryLabel": "{lucene} クエリ文字列の構文", - "xpack.canvas.expressionTypes.datasources.esdocs.queryTitle": "クエリ", - "xpack.canvas.expressionTypes.datasources.esdocs.sortFieldLabel": "ドキュメントソートフィールド", - "xpack.canvas.expressionTypes.datasources.esdocs.sortFieldTitle": "ソートフィールド", - "xpack.canvas.expressionTypes.datasources.esdocs.sortOrderLabel": "ドキュメントの並べ替え順", - "xpack.canvas.expressionTypes.datasources.esdocs.sortOrderTitle": "並べ替え順", - "xpack.canvas.expressionTypes.datasources.esdocs.warningTitle": "ご注意ください", - "xpack.canvas.expressionTypes.datasources.esdocsLabel": "Elasticsearch から未加工のドキュメントを読み込みます", - "xpack.canvas.expressionTypes.datasources.esdocsTitle": "Elasticsearch 未加工ドキュメント", - "xpack.canvas.functionForm.contextError": "エラー: {errorMessage}", - "xpack.canvas.functionForm.functionUnknown.unknownArgumentTypeError": "未知の表現タイプ「{expressionType}」", - "xpack.canvas.functions.asset.args.id": "読み込むアセットの ID です。", - "xpack.canvas.functions.asset.invalidAssetId": "ID「{assetId}」でアセットを取得できませんでした", - "xpack.canvas.functions.assetHelpText": "引数値を提供するために、Canvas ワークパッドアセットオブジェクトを取得します。通常画像です。", - "xpack.canvas.functions.filters.args.group": "使用するフィルターグループの名前です。", - "xpack.canvas.functions.filters.args.ungrouped": "フィルターグループに属するフィルターを除外しますか?", - "xpack.canvas.functions.filtersHelpText": "ワークパッドのエレメントフィルターを他 (通常データソース) で使用できるように集約します。", - "xpack.canvas.functions.savedMapHelpText": "保存されたマップオブジェクトの埋め込み可能なオブジェクトを返します", - "xpack.canvas.functions.savedSearchHelpText": "保存検索オブジェクトの埋め込み可能なオブジェクトを返します", - "xpack.canvas.functions.savedVisualizationHelpText": "保存されたビジュアライゼーションオブジェクトの埋め込み可能なオブジェクトを返します", - "xpack.canvas.functions.timelion.args.from": "時間範囲の始めの {ELASTICSEARCH} {DATEMATH} 文字列です。", - "xpack.canvas.functions.timelion.args.interval": "時系列のバケット間隔です。", - "xpack.canvas.functions.timelion.args.query": "Timelion クエリ", - "xpack.canvas.functions.timelion.args.timezone": "時間範囲のタイムゾーンです。{MOMENTJS_TIMEZONE_URL} をご覧ください。", - "xpack.canvas.functions.timelion.args.to": "時間範囲の終わりの {ELASTICSEARCH} {DATEMATH} 文字列です。", - "xpack.canvas.functions.timelionHelpText": "多くのソースから単独または複数の時系列を抽出するために、Timelion を使用します。", - "xpack.canvas.functions.to.args.type": "表現言語の既知のデータ型です。", - "xpack.canvas.functions.to.missingType": "型キャストを指定する必要があります", - "xpack.canvas.functions.toHelpText": "{CONTEXT} の型を指定された型に明確にキャストします。", - "xpack.canvas.groupSettings.multipleElementsActionsDescription": "個々の設定を編集するには、これらのエレメントの選択を解除し、 ({gKey}) を押してグループ化するか、この選択をワークパッド全体で再利用できるように新規エレメントとして保存します。", - "xpack.canvas.groupSettings.multipleElementsDescription": "現在複数エレメントが選択されています。", - "xpack.canvas.groupSettings.saveGroupDescription": "ワークパッド全体で再利用できるように、このグループを新規エレメントとして保存します。", - "xpack.canvas.groupSettings.ungroupDescription": "個々のエレメントの設定を編集できるように、({uKey}) のグループを解除します。", - "xpack.canvas.helpMenu.description": "{CANVAS} に関する情報", - "xpack.canvas.helpMenu.documentationLinkLabel": "{CANVAS} ドキュメント", - "xpack.canvas.helpMenu.keyboardShortcutsLinkLabel": "キーボードショートカット", - "xpack.canvas.keyboardShortcuts.bringFowardShortcutHelpText": "表面に移動", - "xpack.canvas.keyboardShortcuts.bringToFrontShortcutHelpText": "前に移動", - "xpack.canvas.keyboardShortcuts.cloneShortcutHelpText": "クローンを作成", - "xpack.canvas.keyboardShortcuts.copyShortcutHelpText": "コピー", - "xpack.canvas.keyboardShortcuts.cutShortcutHelpText": "切り取り", - "xpack.canvas.keyboardShortcuts.deleteShortcutHelpText": "削除", - "xpack.canvas.keyboardShortcuts.editingShortcutHelpText": "編集モードを切り替えます", - "xpack.canvas.keyboardShortcuts.fullscreenExitShortcutHelpText": "プレゼンテーションモードを終了します", - "xpack.canvas.keyboardShortcuts.fullscreenShortcutHelpText": "プレゼンテーションモードを開始します", - "xpack.canvas.keyboardShortcuts.gridShortcutHelpText": "グリッドを表示します", - "xpack.canvas.keyboardShortcuts.groupShortcutHelpText": "グループ", - "xpack.canvas.keyboardShortcuts.ignoreSnapShortcutHelpText": "スナップせずに移動、サイズ変更、回転します", - "xpack.canvas.keyboardShortcuts.multiselectShortcutHelpText": "複数エレメントを選択します", - "xpack.canvas.keyboardShortcuts.namespace.editorDisplayName": "エディターコントロール", - "xpack.canvas.keyboardShortcuts.namespace.elementDisplayName": "エレメントコントロール", - "xpack.canvas.keyboardShortcuts.namespace.expressionDisplayName": "表現コントロール", - "xpack.canvas.keyboardShortcuts.namespace.presentationDisplayName": "プレゼンテーションコントロール", - "xpack.canvas.keyboardShortcuts.nextShortcutHelpText": "次のページに移動します", - "xpack.canvas.keyboardShortcuts.nudgeDownShortcutHelpText": "{ELEMENT_NUDGE_OFFSET}px 下に移動させます", - "xpack.canvas.keyboardShortcuts.nudgeLeftShortcutHelpText": "{ELEMENT_NUDGE_OFFSET}px 左に移動させます", - "xpack.canvas.keyboardShortcuts.nudgeRightShortcutHelpText": "{ELEMENT_NUDGE_OFFSET}px 右に移動させます", - "xpack.canvas.keyboardShortcuts.nudgeUpShortcutHelpText": "{ELEMENT_NUDGE_OFFSET}px 上に移動させます", - "xpack.canvas.keyboardShortcuts.pageCycleToggleShortcutHelpText": "ページ周期を切り替えます", - "xpack.canvas.keyboardShortcuts.pasteShortcutHelpText": "貼り付け", - "xpack.canvas.keyboardShortcuts.prevShortcutHelpText": "前のページに移動します", - "xpack.canvas.keyboardShortcuts.redoShortcutHelpText": "最後の操作をやり直します", - "xpack.canvas.keyboardShortcuts.resizeFromCenterShortcutHelpText": "中央からサイズ変更します", - "xpack.canvas.keyboardShortcuts.runShortcutHelpText": "表現全体を実行します", - "xpack.canvas.keyboardShortcuts.selectBehindShortcutHelpText": "下のエレメントを選択します", - "xpack.canvas.keyboardShortcuts.sendBackwardShortcutHelpText": "後方に送ります", - "xpack.canvas.keyboardShortcuts.sendToBackShortcutHelpText": "後ろに送ります", - "xpack.canvas.keyboardShortcuts.shiftDownShortcutHelpText": "{ELEMENT_SHIFT_OFFSET}px 下に移動させます", - "xpack.canvas.keyboardShortcuts.shiftLeftShortcutHelpText": "{ELEMENT_SHIFT_OFFSET}px 左に移動させます", - "xpack.canvas.keyboardShortcuts.shiftRightShortcutHelpText": "{ELEMENT_SHIFT_OFFSET}px 右に移動させます", - "xpack.canvas.keyboardShortcuts.shiftUpShortcutHelpText": "{ELEMENT_SHIFT_OFFSET}px 上に移動させます", - "xpack.canvas.keyboardShortcuts.ShortcutHelpText": "ワークパッドを更新します", - "xpack.canvas.keyboardShortcuts.undoShortcutHelpText": "最後の操作を元に戻します", - "xpack.canvas.keyboardShortcuts.ungroupShortcutHelpText": "グループ解除", - "xpack.canvas.keyboardShortcuts.zoomInShortcutHelpText": "ズームイン", - "xpack.canvas.keyboardShortcuts.zoomOutShortcutHelpText": "ズームアウト", - "xpack.canvas.keyboardShortcuts.zoomResetShortcutHelpText": "ズームを 100% にリセットします", - "xpack.canvas.keyboardShortcutsDoc.flyout.closeButtonAriaLabel": "キーボードショートカットリファレンスを作成", - "xpack.canvas.keyboardShortcutsDoc.flyoutHeaderTitle": "キーボードショートカット", - "xpack.canvas.keyboardShortcutsDoc.shortcutListSeparator": "または", - "xpack.canvas.link.errorMessage": "リンクエラー: {message}", - "xpack.canvas.pageConfig.backgroundColorDescription": "HEX、RGB、また HTML 色名が使用できます", - "xpack.canvas.pageConfig.backgroundColorLabel": "背景色", - "xpack.canvas.pageConfig.title": "ページ", - "xpack.canvas.pageConfig.transitionLabel": "トランジション", - "xpack.canvas.pageConfig.transitionPreviewLabel": "プレビュー", - "xpack.canvas.pageConfig.transitions.noneDropDownOptionLabel": "なし", - "xpack.canvas.pageManager.pageNumberAriaLabel": "ページ {pageNumber} を読み込む", - "xpack.canvas.pagePreviewPageControls.clonePageAriaLabel": "ページのクローンを作成", - "xpack.canvas.pagePreviewPageControls.clonePageTooltip": "クローンを作成", - "xpack.canvas.pagePreviewPageControls.deletePageAriaLabel": "ページを削除", - "xpack.canvas.pagePreviewPageControls.deletePageTooltip": "削除", - "xpack.canvas.renderer.advancedFilter.applyButtonLabel": "適用", - "xpack.canvas.renderer.advancedFilter.displayName": "高度なフィルター", - "xpack.canvas.renderer.advancedFilter.helpDescription": "Canvas フィルター表現をレンダリングします。", - "xpack.canvas.renderer.advancedFilter.inputPlaceholder": "フィルター表現を入力", - "xpack.canvas.renderer.debug.displayName": "デバッグ", - "xpack.canvas.renderer.debug.helpDescription": "デバッグアウトプットをフォーマットされた {JSON} としてレンダリングします", - "xpack.canvas.renderer.dropdownFilter.displayName": "ドロップダウンフィルター", - "xpack.canvas.renderer.dropdownFilter.helpDescription": "「{exactly}」フィルターの値を選択できるドロップダウンです", - "xpack.canvas.renderer.dropdownFilter.matchAllOptionLabel": "すべて", - "xpack.canvas.renderer.embeddable.displayName": "埋め込み可能", - "xpack.canvas.renderer.embeddable.helpDescription": "Kibana の他の部分から埋め込み可能な保存済みオブジェクトをレンダリングします", - "xpack.canvas.renderer.error.displayName": "エラー情報", - "xpack.canvas.renderer.error.helpDescription": "エラーデータをユーザーにわかるようにレンダリングします", - "xpack.canvas.renderer.image.displayName": "画像", - "xpack.canvas.renderer.image.helpDescription": "画像をレンダリングします", - "xpack.canvas.renderer.markdown.displayName": "マークダウン", - "xpack.canvas.renderer.markdown.helpDescription": "{MARKDOWN} インプットで {HTML} をレンダリングします", - "xpack.canvas.renderer.metric.displayName": "メトリック", - "xpack.canvas.renderer.metric.helpDescription": "ラベルの上に数字をレンダリングします", - "xpack.canvas.renderer.pie.displayName": "円グラフ", - "xpack.canvas.renderer.pie.helpDescription": "データから円グラフをレンダリングします", - "xpack.canvas.renderer.plot.displayName": "座標プロット", - "xpack.canvas.renderer.plot.helpDescription": "データから XY プロットをレンダリングします", - "xpack.canvas.renderer.progress.displayName": "進捗インジケーター", - "xpack.canvas.renderer.progress.helpDescription": "エレメントのパーセンテージを示す進捗インジケーターをレンダリングします", - "xpack.canvas.renderer.repeatImage.displayName": "画像の繰り返し", - "xpack.canvas.renderer.repeatImage.helpDescription": "画像を指定回数繰り返し表示します", - "xpack.canvas.renderer.revealImage.displayName": "画像の部分表示", - "xpack.canvas.renderer.revealImage.helpDescription": "カスタムゲージスタイルチャートを作成するため、画像のパーセンテージを表示します", - "xpack.canvas.renderer.shape.displayName": "図形", - "xpack.canvas.renderer.shape.helpDescription": "基本的な図形をレンダリングします", - "xpack.canvas.renderer.table.displayName": "データテーブル", - "xpack.canvas.renderer.table.helpDescription": "表形式データを {HTML} としてレンダリングします", - "xpack.canvas.renderer.text.displayName": "プレインテキスト", - "xpack.canvas.renderer.text.helpDescription": "アウトプットをプレインテキストとしてレンダリングします", - "xpack.canvas.renderer.timeFilter.displayName": "時間フィルター", - "xpack.canvas.renderer.timeFilter.helpDescription": "時間枠を設定してデータをフィルタリングします", - "xpack.canvas.shareWebsiteFlyout.description": "外部 Web サイトでこのワークパッドの不動バージョンを共有するには、これらの手順に従ってください。現在のワークパッドのビジュアルスナップショットになり、ライブデータにはアクセスできません。", - "xpack.canvas.shareWebsiteFlyout.flyoutCalloutDescription": "共有するには、このワークパッド、{CANVAS} シェアラブルワークパッドランタイム、サンプル {HTML} ファイルを含む {link} を使用します。", - "xpack.canvas.shareWebsiteFlyout.flyoutTitle": "Web サイトで共有", - "xpack.canvas.shareWebsiteFlyout.runtimeStep.description": "共有可能なワークパッドをレンダリングするには、{CANVAS} シェアラブルワークパッドランタイムも含める必要があります。Web サイトに既にランタイムが含まれている場合、この手順をスキップすることができます。", - "xpack.canvas.shareWebsiteFlyout.runtimeStep.downloadLabel": "ダウンロードランタイム", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.addSnippetsTitle": "スナップショットを Web サイトに追加", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.autoplayParameterDescription": "ワークパッドのページ間で’ランタイムを自動的に移動させますか?", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.callRuntimeLabel": "ランタイムを呼び出す", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.description": "ワークパッドは {HTML} プレースホルダーでサイトの {HTML} 内に配置されますランタイムのパラメーターはインラインに含まれます。全パラメーターの一覧は以下をご覧ください。1 ページに複数のワークパッドを含めることができます。", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.downloadRuntimeTitle": "ダウンロードランタイム", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.downloadWorkpadTitle": "ワークパッドのダウンロード", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.heightParameterDescription": "ワークパッドの高さです。デフォルトはワークパッドの高さです。", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.includeRuntimeLabel": "ランタイムを含める", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.intervalParameterDescription": "時間フォーマットでのページが進む間隔です (例: {twoSeconds}、{oneMinute})", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.pageParameterDescription": "表示するページです。デフォルトはワークパッドに指定されたページになります。", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.parametersDescription": "シェアラブルワークパッドを構成するインラインパラメーターが多数あります。", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.parametersLabel": "パラメーター", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.placeholderLabel": "プレースホルダー", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.requiredLabel": "必要", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.shareableParameterDescription": "シェアラブルのタイプです。この場合、{CANVAS} ワークパッドです。", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.toolbarParameterDescription": "ツールバーを非表示にしますか?", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.urlParameterDescription": "シェアラブルワークパッド {JSON} ファイルの {URL} です。", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.widthParameterDescription": "ワークパッドの幅です。デフォルトはワークパッドの幅です。", - "xpack.canvas.shareWebsiteFlyout.workpadStep.description": "ワークパッドは別のサイトで共有できるように 1 つの {JSON} ファイルとしてエクスポートされます。", - "xpack.canvas.shareWebsiteFlyout.workpadStep.downloadLabel": "ワークパッドのダウンロード", - "xpack.canvas.shareWebsiteFlyout.zipDownloadLinkLabel": "サンプル {ZIP} ファイルをダウンロード", - "xpack.canvas.sidebarContent.groupedElementSidebarTitle": "グループ化されたエレメント", - "xpack.canvas.sidebarContent.multiElementSidebarTitle": "複数エレメント", - "xpack.canvas.sidebarContent.singleElementSidebarTitle": "選択されたエレメント", - "xpack.canvas.sidebarHeader.alignmentMenuItemLabel": "アラインメント", - "xpack.canvas.sidebarHeader.bottomAlignMenuItemLabel": "一番下", - "xpack.canvas.sidebarHeader.bringForwardArialLabel": "エレメントを 1 つ上のレイヤーに移動", - "xpack.canvas.sidebarHeader.bringToFrontArialLabel": "エレメントを一番上のレイヤーに移動", - "xpack.canvas.sidebarHeader.centerAlignMenuItemLabel": "中央", - "xpack.canvas.sidebarHeader.contextMenuAriaLabel": "エレメントオプション", - "xpack.canvas.sidebarHeader.createElementModalTitle": "新規エレメントの作成", - "xpack.canvas.sidebarHeader.distributionMenutItemLabel": "分布", - "xpack.canvas.sidebarHeader.groupMenuItemLabel": "グループ", - "xpack.canvas.sidebarHeader.horizontalDistributionMenutItemLabel": "横", - "xpack.canvas.sidebarHeader.leftAlignMenuItemLabel": "左", - "xpack.canvas.sidebarHeader.middleAlignMenuItemLabel": "真ん中", - "xpack.canvas.sidebarHeader.orderMenuItemLabel": "順序", - "xpack.canvas.sidebarHeader.rightAlignMenuItemLabel": "右", - "xpack.canvas.sidebarHeader.savedElementMenuItemLabel": "新規エレメントとして保存", - "xpack.canvas.sidebarHeader.sendBackwardArialLabel": "エレメントを 1 つ下のレイヤーに移動", - "xpack.canvas.sidebarHeader.sendToBackArialLabel": "エレメントを一番下のレイヤーに移動", - "xpack.canvas.sidebarHeader.topAlignMenuItemLabel": "一番上", - "xpack.canvas.sidebarHeader.ungroupMenuItemLabel": "グループ解除", - "xpack.canvas.sidebarHeader.verticalDistributionMenutItemLabel": "縦", - "xpack.canvas.tags.chartTag": "チャート", - "xpack.canvas.tags.filterTag": "フィルター", - "xpack.canvas.tags.graphicTag": "グラフィック", - "xpack.canvas.tags.presentationTag": "プレゼンテーション", - "xpack.canvas.tags.proportionTag": "比率", - "xpack.canvas.tags.reportTag": "レポート", - "xpack.canvas.tags.textTag": "テキスト", - "xpack.canvas.templates.darkHelp": "ダークカラーテーマのプレゼンテーションデッキです", - "xpack.canvas.templates.darkName": "ダーク", - "xpack.canvas.templates.lightHelp": "ライトカラーテーマのプレゼンテーションデッキです", - "xpack.canvas.templates.lightName": "ライト", - "xpack.canvas.templates.pitchHelp": "大きな写真でブランディングされたプレゼンテーションです", - "xpack.canvas.templates.pitchName": "ピッチ", - "xpack.canvas.templates.statusHelp": "ライブチャート付きのドキュメント式のレポートです", - "xpack.canvas.templates.statusName": "ステータス", - "xpack.canvas.templates.summaryDisplayName": "まとめ", - "xpack.canvas.templates.summaryHelp": "ライブチャート付きのインフォグラフィック式のレポートです", - "xpack.canvas.textStylePicker.alignCenterOption": "中央に合わせる", - "xpack.canvas.textStylePicker.alignLeftOption": "左に合わせる", - "xpack.canvas.textStylePicker.alignRightOption": "右に合わせる", - "xpack.canvas.textStylePicker.styleBoldOption": "太字", - "xpack.canvas.textStylePicker.styleItalicOption": "斜体", - "xpack.canvas.textStylePicker.styleUnderlineOption": "下線", - "xpack.canvas.timePicker.applyButtonLabel": "適用", - "xpack.canvas.toolbar.editorButtonLabel": "表現エディター", - "xpack.canvas.toolbar.nextPageAriaLabel": "次のページ", - "xpack.canvas.toolbar.pageButtonLabel": "ページ {pageNum}{rest}", - "xpack.canvas.toolbar.previousPageAriaLabel": "前のページ", - "xpack.canvas.toolbar.workpadManagerCloseButtonLabel": "閉じる", - "xpack.canvas.toolbarTray.closeTrayAriaLabel": "トレイのクローンを作成", - "xpack.canvas.transitions.fade.displayName": "フェード", - "xpack.canvas.transitions.fade.help": "ページからページへフェードします", - "xpack.canvas.transitions.rotate.displayName": "回転", - "xpack.canvas.transitions.rotate.help": "ページからページへ回転します", - "xpack.canvas.transitions.slide.displayName": "スライド", - "xpack.canvas.transitions.slide.help": "ページからページへスライドします", - "xpack.canvas.transitions.zoom.displayName": "ズーム:", - "xpack.canvas.transitions.zoom.help": "ページからページへズームします", - "xpack.canvas.uis.arguments.axisConfig.position.options.bottomDropDown": "一番下", - "xpack.canvas.uis.arguments.axisConfig.position.options.leftDropDown": "左", - "xpack.canvas.uis.arguments.axisConfig.position.options.rightDropDown": "右", - "xpack.canvas.uis.arguments.axisConfig.position.options.topDropDown": "トップ", - "xpack.canvas.uis.arguments.axisConfig.positionLabel": "配置", - "xpack.canvas.uis.arguments.axisConfigLabel": "ビジュアライゼーションの軸の構成", - "xpack.canvas.uis.arguments.axisConfigTitle": "軸の構成", - "xpack.canvas.uis.arguments.dataColumn.options.averageDropDown": "平均", - "xpack.canvas.uis.arguments.dataColumn.options.countDropDown": "カウント", - "xpack.canvas.uis.arguments.dataColumn.options.firstDropDown": "最初", - "xpack.canvas.uis.arguments.dataColumn.options.lastDropDown": "最後", - "xpack.canvas.uis.arguments.dataColumn.options.maxDropDown": "最高", - "xpack.canvas.uis.arguments.dataColumn.options.medianDropDown": "中央", - "xpack.canvas.uis.arguments.dataColumn.options.minDropDown": "最低", - "xpack.canvas.uis.arguments.dataColumn.options.sumDropDown": "合計", - "xpack.canvas.uis.arguments.dataColumn.options.uniqueDropDown": "固有", - "xpack.canvas.uis.arguments.dataColumn.options.valueDropDown": "値", - "xpack.canvas.uis.arguments.dataColumnLabel": "データ列を選択", - "xpack.canvas.uis.arguments.dataColumnTitle": "列", - "xpack.canvas.uis.arguments.dateFormatLabel": "{momentJS} フォーマットを選択または入力", - "xpack.canvas.uis.arguments.dateFormatTitle": "データフォーマット", - "xpack.canvas.uis.arguments.filterGroup.createNewGroupLinkText": "新規グループを作成", - "xpack.canvas.uis.arguments.filterGroupLabel": "フィルターグループを作成または入力", - "xpack.canvas.uis.arguments.filterGroupTitle": "フィルターグループ", - "xpack.canvas.uis.arguments.imageUpload.fileUploadPromptLabel": "画像を選択するかドラッグ &amp; ドロップしてください", - "xpack.canvas.uis.arguments.imageUpload.imageUploadingLabel": "画像をアップロード中", - "xpack.canvas.uis.arguments.imageUpload.urlFieldPlaceholder": "画像 {url}", - "xpack.canvas.uis.arguments.imageUpload.urlTypes.assetDropDown": "アセット", - "xpack.canvas.uis.arguments.imageUpload.urlTypes.fileDropDown": "インポート", - "xpack.canvas.uis.arguments.imageUpload.urlTypes.linkDropDown": "リンク", - "xpack.canvas.uis.arguments.imageUploadLabel": "画像を選択またはアップロード", - "xpack.canvas.uis.arguments.imageUploadTitle": "画像がアップロードされました", - "xpack.canvas.uis.arguments.numberFormat.format.bytesDropDown": "バイト", - "xpack.canvas.uis.arguments.numberFormat.format.currencyDropDown": "通貨", - "xpack.canvas.uis.arguments.numberFormat.format.durationDropDown": "期間", - "xpack.canvas.uis.arguments.numberFormat.format.numberDropDown": "数字", - "xpack.canvas.uis.arguments.numberFormat.format.percentDropDown": "パーセント", - "xpack.canvas.uis.arguments.numberFormatLabel": "有効な {numeralJS} フォーマットを選択または入力", - "xpack.canvas.uis.arguments.numberFormatTitle": "数字フォーマット", - "xpack.canvas.uis.arguments.numberLabel": "数字を入力", - "xpack.canvas.uis.arguments.numberTitle": "数字", - "xpack.canvas.uis.arguments.paletteLabel": "カラーパレットを選択", - "xpack.canvas.uis.arguments.paletteTitle": "カラーパレット", - "xpack.canvas.uis.arguments.percentageLabel": "パーセンテージのスライダー ", - "xpack.canvas.uis.arguments.percentageTitle": "パーセンテージ", - "xpack.canvas.uis.arguments.rangeLabel": "範囲内の値のスライダー", - "xpack.canvas.uis.arguments.rangeTitle": "範囲", - "xpack.canvas.uis.arguments.selectLabel": "ドロップダウンの複数オプションから選択", - "xpack.canvas.uis.arguments.selectTitle": "選択してください", - "xpack.canvas.uis.arguments.shapeLabel": "図形ピッカー", - "xpack.canvas.uis.arguments.shapeTitle": "図形", - "xpack.canvas.uis.arguments.stringLabel": "短い文字列を入力", - "xpack.canvas.uis.arguments.stringTitle": "文字列", - "xpack.canvas.uis.arguments.textareaLabel": "長い文字列を入力", - "xpack.canvas.uis.arguments.textareaTitle": "テキストエリア", - "xpack.canvas.uis.arguments.toggleLabel": "true/false トグルスイッチ", - "xpack.canvas.uis.arguments.toggleTitle": "切り替え", - "xpack.canvas.uis.dataSources.demoData.headingTitle": "デモデータを使用中です", - "xpack.canvas.uis.dataSources.demoDataLabel": "ユーザー名、価格、プロジェクト、国、フェーズを含む模擬データセット", - "xpack.canvas.uis.dataSources.demoDataTitle": "デモデータ", - "xpack.canvas.uis.dataSources.essqlLabel": "{elasticsearch} {sql} でデータ表を取得します", - "xpack.canvas.uis.dataSources.essqlTitle": "{elasticsearch} {sql}", - "xpack.canvas.uis.dataSources.timelion.intervalTitle": "間隔", - "xpack.canvas.uis.dataSources.timelion.queryLabel": "{lucene} クエリ文字列の構文", - "xpack.canvas.uis.dataSources.timelion.queryTitle": "クエリ", - "xpack.canvas.uis.dataSources.timelion.tips.functions": "{functionExample} などの一部 {timelion} 関数は {canvas} データ表に変換できません。データ操作に関する機能は正常に動作するはずです。", - "xpack.canvas.uis.dataSources.timelion.tips.time": "{timelion} には時間範囲が必要です。ページのどこかに時間フィルターを追加するか、コードエディターで時間フィルターを渡す必要があります。", - "xpack.canvas.uis.dataSources.timelionLabel": "{timelion} 構文で時系列を取得します", - "xpack.canvas.uis.models.math.args.valueLabel": "データソースから値を抽出する際に使用する関数と列", - "xpack.canvas.uis.models.math.args.valueTitle": "値", - "xpack.canvas.uis.models.mathTitle": "メジャー", - "xpack.canvas.uis.models.pointSeries.args.colorLabel": "マークまたは数列の色を決定します", - "xpack.canvas.uis.models.pointSeries.args.colorTitle": "色", - "xpack.canvas.uis.models.pointSeries.args.sizeLabel": "マークのサイズを決定します", - "xpack.canvas.uis.models.pointSeries.args.sizeTitle": "サイズ", - "xpack.canvas.uis.models.pointSeries.args.textLabel": "テキストをマークとして、またはマークの周りに使用するように設定", - "xpack.canvas.uis.models.pointSeries.args.textTitle": "テキスト", - "xpack.canvas.uis.models.pointSeries.args.xaxisLabel": "水平軸の周りのデータです。通常は数字、文字列、または日付です。", - "xpack.canvas.uis.models.pointSeries.args.xaxisTitle": "X 軸", - "xpack.canvas.uis.models.pointSeries.args.yaxisLabel": "垂直軸の周りのデータです。通常は数字です。", - "xpack.canvas.uis.models.pointSeries.args.yaxisTitle": "Y 軸", - "xpack.canvas.uis.models.pointSeriesTitle": "ディメンションとメジャー", - "xpack.canvas.uis.transforms.formatDate.args.formatTitle": "フォーマット", - "xpack.canvas.uis.transforms.formatDateTitle": "データフォーマット", - "xpack.canvas.uis.transforms.formatNumber.args.formatTitle": "フォーマット", - "xpack.canvas.uis.transforms.formatNumberTitle": "数字フォーマット", - "xpack.canvas.uis.transforms.roundDate.args.formatLabel": "日付の繰り上げ・繰り下げに使用する {momentJs} フォーマットを選択または入力", - "xpack.canvas.uis.transforms.roundDate.args.formatTitle": "フォーマット", - "xpack.canvas.uis.transforms.roundDateTitle": "日付の繰り上げ・繰り下げ", - "xpack.canvas.uis.transforms.sort.args.reverseToggleSwitch": "降順", - "xpack.canvas.uis.transforms.sort.args.sortFieldTitle": "ソートフィールド", - "xpack.canvas.uis.transforms.sortTitle": "データベースの並べ替え", - "xpack.canvas.uis.views.dropdownControl.args.filterColumnLabel": "ドロップダウンで選択された値を適用する列", - "xpack.canvas.uis.views.dropdownControl.args.filterColumnTitle": "フィルター列", - "xpack.canvas.uis.views.dropdownControl.args.filterGroupLabel": "選択されたグループ名をエレメントのフィルター関数に適用してこのフィルターをターゲットにする", - "xpack.canvas.uis.views.dropdownControl.args.filterGroupTitle": "フィルターグループ", - "xpack.canvas.uis.views.dropdownControl.args.valueColumnLabel": "ドロップダウンに表示する値を抽出する列", - "xpack.canvas.uis.views.dropdownControl.args.valueColumnTitle": "値列", - "xpack.canvas.uis.views.dropdownControlTitle": "ドロップダウンフィルター", - "xpack.canvas.uis.views.getCellLabel": "最初の行と列を使用", - "xpack.canvas.uis.views.getCellTitle": "ドロップダウンフィルター", - "xpack.canvas.uis.views.image.args.mode.containDropDown": "Contain", - "xpack.canvas.uis.views.image.args.mode.coverDropDown": "Cover", - "xpack.canvas.uis.views.image.args.mode.stretchDropDown": "Stretch", - "xpack.canvas.uis.views.image.args.modeLabel": "注:ストレッチ塗りつぶしはベクター画像には使用できない場合があります", - "xpack.canvas.uis.views.image.args.modeTitle": "塗りつぶしモード", - "xpack.canvas.uis.views.imageTitle": "画像", - "xpack.canvas.uis.views.markdown.args.contentLabel": "{markdown} フォーマットのテキスト", - "xpack.canvas.uis.views.markdown.args.contentTitle": "{markdown} コンテンツ", - "xpack.canvas.uis.views.markdownLabel": "{markdown} を使用してマークアップを生成", - "xpack.canvas.uis.views.markdownTitle": "{markdown}", - "xpack.canvas.uis.views.metric.args.labelArgLabel": "メトリックを説明します", - "xpack.canvas.uis.views.metric.args.labelArgTitle": "ラベル", - "xpack.canvas.uis.views.metric.args.labelFontLabel": "フォント、配置、色", - "xpack.canvas.uis.views.metric.args.labelFontTitle": "ラベルテキスト設定", - "xpack.canvas.uis.views.metric.args.metricFontLabel": "フォント、配置、色", - "xpack.canvas.uis.views.metric.args.metricFontTitle": "メトリックテキスト設定", - "xpack.canvas.uis.views.metric.args.metricFormatLabel": "フォント、配置、色", - "xpack.canvas.uis.views.metric.args.metricFormatTitle": "メトリックのフォーマット", - "xpack.canvas.uis.views.metricTitle": "メトリック", - "xpack.canvas.uis.views.numberArgTitle": "数字", - "xpack.canvas.uis.views.pie.args.holeLabel": "穴の半径", - "xpack.canvas.uis.views.pie.args.holeTitle": "内半径", - "xpack.canvas.uis.views.pie.args.labelRadiusLabel": "円グラフの中心からラベルまでの距離です", - "xpack.canvas.uis.views.pie.args.labelRadiusTitle": "ラベル半径", - "xpack.canvas.uis.views.pie.args.labelsTitle": "ラベル", - "xpack.canvas.uis.views.pie.args.labelsToggleSwitch": "ラベルの表示・非表示", - "xpack.canvas.uis.views.pie.args.legendLabel": "凡例の無効化・配置", - "xpack.canvas.uis.views.pie.args.legendTitle": "凡例の配置", - "xpack.canvas.uis.views.pie.args.radiusLabel": "円グラフの半径", - "xpack.canvas.uis.views.pie.args.radiusTitle": "半径", - "xpack.canvas.uis.views.pie.args.tiltLabel": "100 が完全に垂直、0 が完全に水平を表す傾きのパーセンテージです", - "xpack.canvas.uis.views.pie.args.tiltTitle": "傾斜角度", - "xpack.canvas.uis.views.pieTitle": "チャートスタイル", - "xpack.canvas.uis.views.plot.args.defaultStyleLabel": "上書きされない限りすべての数列にデフォルトで使用されるスタイルを設定します", - "xpack.canvas.uis.views.plot.args.defaultStyleTitle": "デフォルトのスタイル", - "xpack.canvas.uis.views.plot.args.legendLabel": "凡例の無効化・配置", - "xpack.canvas.uis.views.plot.args.legendTitle": "凡例の配置", - "xpack.canvas.uis.views.plot.args.xaxisLabel": "X 軸の構成・無効化", - "xpack.canvas.uis.views.plot.args.xaxisTitle": "X 軸", - "xpack.canvas.uis.views.plot.args.yaxisLabel": "Y 軸の構成・無効化", - "xpack.canvas.uis.views.plot.args.yaxisTitle": "Y 軸", - "xpack.canvas.uis.views.plotTitle": "チャートスタイル", - "xpack.canvas.uis.views.progress.args.barColorLabel": "HEX、RGB、または HTML カラーネームが使用できます", - "xpack.canvas.uis.views.progress.args.barColorTitle": "背景色", - "xpack.canvas.uis.views.progress.args.barWeightLabel": "背景バーの太さです", - "xpack.canvas.uis.views.progress.args.barWeightTitle": "背景重量", - "xpack.canvas.uis.views.progress.args.fontLabel": "ラベルのフォント設定です。技術的には他のスタイルを追加することもできます", - "xpack.canvas.uis.views.progress.args.fontTitle": "ラベル設定", - "xpack.canvas.uis.views.progress.args.labelArgLabel": "{true}/{false} でラベルの表示/非表示を設定するか、ラベルとして表示する文字列を指定します", - "xpack.canvas.uis.views.progress.args.labelArgTitle": "ラベル", - "xpack.canvas.uis.views.progress.args.maxLabel": "進捗エレメントの最高値です", - "xpack.canvas.uis.views.progress.args.maxTitle": "最高値", - "xpack.canvas.uis.views.progress.args.shapeLabel": "進捗インジケーターの形", - "xpack.canvas.uis.views.progress.args.shapeTitle": "図形", - "xpack.canvas.uis.views.progress.args.valueColorLabel": "{hex}、{rgb}、または {html} カラーネームが使用できます", - "xpack.canvas.uis.views.progress.args.valueColorTitle": "進捗の色", - "xpack.canvas.uis.views.progress.args.valueWeightLabel": "進捗バーの太さです", - "xpack.canvas.uis.views.progress.args.valueWeightTitle": "進捗の重量", - "xpack.canvas.uis.views.progressTitle": "進捗", - "xpack.canvas.uis.views.render.args.css.applyButtonLabel": "スタイルシートを適用", - "xpack.canvas.uis.views.render.args.cssLabel": "エレメントに合わせた {css} スタイルシート", - "xpack.canvas.uis.views.renderLabel": "エレメントの周りのコンテナーの設定です", - "xpack.canvas.uis.views.renderTitle": "エレメントスタイル", - "xpack.canvas.uis.views.repeatImage.args.emptyImageLabel": "値と最高値の間を埋める画像です", - "xpack.canvas.uis.views.repeatImage.args.emptyImageTitle": "空の部分の画像", - "xpack.canvas.uis.views.repeatImage.args.imageLabel": "繰り返す画像です", - "xpack.canvas.uis.views.repeatImage.args.imageTitle": "画像", - "xpack.canvas.uis.views.repeatImage.args.maxLabel": "画像を繰り返す最高回数", - "xpack.canvas.uis.views.repeatImage.args.maxTitle": "最高カウント", - "xpack.canvas.uis.views.repeatImage.args.sizeLabel": "画像寸法の最大値です。例: 画像が縦長の場合、高さになります", - "xpack.canvas.uis.views.repeatImage.args.sizeTitle": "画像サイズ", - "xpack.canvas.uis.views.repeatImageTitle": "繰り返しの画像", - "xpack.canvas.uis.views.revealImage.args.emptyImageLabel": "背景画像です。例: 空のグラス", - "xpack.canvas.uis.views.revealImage.args.emptyImageTitle": "背景画像", - "xpack.canvas.uis.views.revealImage.args.imageLabel": "関数インプットで徐々に表示される画像です。例: いっぱいのグラス", - "xpack.canvas.uis.views.revealImage.args.imageTitle": "画像", - "xpack.canvas.uis.views.revealImage.args.origin.bottomDropDown": "一番下", - "xpack.canvas.uis.views.revealImage.args.origin.leftDropDown": "左", - "xpack.canvas.uis.views.revealImage.args.origin.rightDropDown": "右", - "xpack.canvas.uis.views.revealImage.args.origin.topDropDown": "一番上", - "xpack.canvas.uis.views.revealImage.args.originLabel": "徐々に表示を開始する方向", - "xpack.canvas.uis.views.revealImage.args.originTitle": "徐々に表示を開始する場所", - "xpack.canvas.uis.views.revealImageTitle": "画像を徐々に表示", - "xpack.canvas.uis.views.shape.args.borderLabel": "HEX、RGB、または HTML カラーネームが使用できます", - "xpack.canvas.uis.views.shape.args.borderTitle": "境界", - "xpack.canvas.uis.views.shape.args.borderWidthLabel": "境界線の幅", - "xpack.canvas.uis.views.shape.args.borderWidthTitle": "境界線の幅", - "xpack.canvas.uis.views.shape.args.fillLabel": "HEX、RGB、または HTML カラーネームが使用できます", - "xpack.canvas.uis.views.shape.args.fillTitle": "塗りつぶし", - "xpack.canvas.uis.views.shape.args.maintainAspectTitle": "アスペクト比を維持", - "xpack.canvas.uis.views.shape.args.shapeTitle": "図形を選択", - "xpack.canvas.uis.views.shapeTitle": "図形", - "xpack.canvas.uis.views.table.args.paginateLabel": "ページ付けコントロールの表示・非表示を切り替えます。無効の場合、初めのページのみが表示されます", - "xpack.canvas.uis.views.table.args.paginateTitle": "ページ付け", - "xpack.canvas.uis.views.table.args.perPageLabel": "各表ページに表示される行数です", - "xpack.canvas.uis.views.table.args.perPageTitle": "ページごとの行数", - "xpack.canvas.uis.views.table.args.showHeaderLabel": "各列のタイトルを含むヘッダー列の表示・非表示を切り替えます", - "xpack.canvas.uis.views.table.args.showHeaderTitle": "ヘッダー", - "xpack.canvas.uis.views.tableLabel": "表エレメントのスタイルを設定します", - "xpack.canvas.uis.views.tableTitle": "表スタイル", - "xpack.canvas.uis.views.timefilter.args.columnConfirmButtonLabel": "設定", - "xpack.canvas.uis.views.timefilter.args.columnLabel": "選択された時間が適用される列です", - "xpack.canvas.uis.views.timefilter.args.columnTitle": "列", - "xpack.canvas.uis.views.timefilter.args.filterGroupLabel": "選択されたグループ名をエレメントのフィルター関数に適用してこのフィルターをターゲットにする", - "xpack.canvas.uis.views.timefilter.args.filterGroupTitle": "フィルターグループ名", - "xpack.canvas.uis.views.timefilterTitle": "時間フィルター", - "xpack.canvas.units.quickRange.dayBeforeYesterday": "一昨日", - "xpack.canvas.units.quickRange.last12Hours": "過去 12 時間", - "xpack.canvas.units.quickRange.last15Minutes": "過去 15 分間", - "xpack.canvas.units.quickRange.last1Hour": "過去 1 時間", - "xpack.canvas.units.quickRange.last1Year": "過去 1 年間", - "xpack.canvas.units.quickRange.last24Hours": "過去 24 時間", - "xpack.canvas.units.quickRange.last2Weeks": "過去 2 週間", - "xpack.canvas.units.quickRange.last2Years": "過去 2 年間", - "xpack.canvas.units.quickRange.last30Days": "過去 30 日間", - "xpack.canvas.units.quickRange.last30Minutes": "過去 30 分間", - "xpack.canvas.units.quickRange.last4Hours": "過去 4 時間", - "xpack.canvas.units.quickRange.last5Years": "過去 5 年間", - "xpack.canvas.units.quickRange.last60Days": "過去 60 日間", - "xpack.canvas.units.quickRange.last6Months": "過去 6 か月間", - "xpack.canvas.units.quickRange.last7Days": "過去 7 日間", - "xpack.canvas.units.quickRange.last90Days": "過去 90 日間", - "xpack.canvas.units.quickRange.monthToDate": "月初めから今日まで", - "xpack.canvas.units.quickRange.previousMonth": "先月", - "xpack.canvas.units.quickRange.previousWeek": "先週", - "xpack.canvas.units.quickRange.previousYear": "昨年", - "xpack.canvas.units.quickRange.theDaySoFar": "本日現在まで", - "xpack.canvas.units.quickRange.thisDayLastWeek": "先週のこの曜日", - "xpack.canvas.units.quickRange.thisMonth": "今月", - "xpack.canvas.units.quickRange.thisWeek": "今週", - "xpack.canvas.units.quickRange.thisYear": "今年", - "xpack.canvas.units.quickRange.today": "今日", - "xpack.canvas.units.quickRange.weekToDate": "週初めから今日まで", - "xpack.canvas.units.quickRange.yearToDate": "年度の頭から今日まで", - "xpack.canvas.units.quickRange.yesterday": "昨日", - "xpack.canvas.units.time.days": "{days, plural, one {# 日} other {# 日}}", - "xpack.canvas.units.time.hours": "{hours, plural, one {# 時間} other {# 時間}}", - "xpack.canvas.units.time.minutes": "{minutes, plural, one {# 分} other {# 分}}", - "xpack.canvas.units.time.seconds": "{seconds, plural, one {# 秒} other {# 秒}}", - "xpack.canvas.workpadConfig.applyStylesheetButtonLabel": "スタイルシートを適用", - "xpack.canvas.workpadConfig.globalCSSLabel": "グローバル CSS オーバーライド", - "xpack.canvas.workpadConfig.globalCSSTooltip": "このワークパッドのすべてのページにスタイルを適用します", - "xpack.canvas.workpadConfig.heightLabel": "高さ", - "xpack.canvas.workpadConfig.nameLabel": "名前", - "xpack.canvas.workpadConfig.pageSizeBadgeAriaLabel": "ページサイズを事前設定: {sizeName}", - "xpack.canvas.workpadConfig.pageSizeBadgeOnClickAriaLabel": "ページサイズを {sizeName} に設定", - "xpack.canvas.workpadConfig.swapDimensionsAriaLabel": "ページの幅と高さを入れ替えます", - "xpack.canvas.workpadConfig.swapDimensionsTooltip": "ページの幅と高さを入れ替える", - "xpack.canvas.workpadConfig.title": "ワークパッド", - "xpack.canvas.workpadConfig.USLetterButtonLabel": "US レター", - "xpack.canvas.workpadConfig.widthLabel": "幅", - "xpack.canvas.workpadCreate.createButtonLabel": "ワークパッドを作成", - "xpack.canvas.workpadHeader.addElementButtonLabel": "エレメントを追加", - "xpack.canvas.workpadHeader.addElementModalCloseButtonLabel": "閉じる", - "xpack.canvas.workpadHeader.cycleIntervalDaysText": "{days} {days, plural, one {日} other {日}}ごと", - "xpack.canvas.workpadHeader.cycleIntervalHoursText": "{hours} {hours, plural, one {時間} other {時間}}ごと", - "xpack.canvas.workpadHeader.cycleIntervalMinutesText": "{minutes} {minutes, plural, one {分} other {分}}ごと", - "xpack.canvas.workpadHeader.cycleIntervalSecondsText": "{seconds} {seconds, plural, one {秒} other {秒}}ごと", - "xpack.canvas.workpadHeader.embedObjectButtonLabel": "オブジェクトを埋め込む", - "xpack.canvas.workpadHeader.fullscreenButtonAriaLabel": "全画面表示", - "xpack.canvas.workpadHeader.fullscreenTooltip": "全画面モードを開始します", - "xpack.canvas.workpadHeader.hideEditControlTooltip": "編集コントロールを非表示にします", - "xpack.canvas.workpadHeader.noWritePermissionTooltip": "このワークパッドを編集するパーミッションがありません", - "xpack.canvas.workpadHeader.showEditControlTooltip": "編集コントロールを表示します", - "xpack.canvas.workpadHeaderAutoRefreshControls.disableTooltip": "自動更新を無効にします", - "xpack.canvas.workpadHeaderAutoRefreshControls.intervalFormLabel": "自動更新間隔を変更します", - "xpack.canvas.workpadHeaderAutoRefreshControls.refreshListDurationManualText": "手動で", - "xpack.canvas.workpadHeaderAutoRefreshControls.refreshListTitle": "エレメントを更新", - "xpack.canvas.workpadHeaderControlSettings.settingsTooltip": "設定をコントロールします", - "xpack.canvas.workpadHeaderCustomInterval.confirmButtonLabel": "設定", - "xpack.canvas.workpadHeaderCustomInterval.formDescription": "{secondsExample}、{minutesExample}、{hoursExample} のような短い表記を使用します", - "xpack.canvas.workpadHeaderCustomInterval.formLabel": "カスタム間隔を設定", - "xpack.canvas.workpadHeaderKioskControl.controlTitle": "全画面ページのサイクル", - "xpack.canvas.workpadHeaderKioskControl.cycleFormLabel": "サイクル間隔を変更", - "xpack.canvas.workpadHeaderKioskControl.cycleToggleSwitch": "スライドを自動的にサイクル", - "xpack.canvas.workpadHeaderRefreshControlSettings.refreshAriaLabel": "エレメントを更新", - "xpack.canvas.workpadHeaderRefreshControlSettings.refreshTooltip": "データを更新", - "xpack.canvas.workpadHeaderWorkpadExport.copyPDFMessage": "{PDF} 生成 {URL} がクリップボードにコピーされました。", - "xpack.canvas.workpadHeaderWorkpadExport.copyReportingConfigMessage": "レポート構成がクリップボードにコピーされました", - "xpack.canvas.workpadHeaderWorkpadExport.copyShareConfigMessage": "共有マークアップがクリップボードにコピーされました", - "xpack.canvas.workpadHeaderWorkpadExport.exportPDFErrorMessage": "「{workpadName}」の {PDF} の作成に失敗しました", - "xpack.canvas.workpadHeaderWorkpadExport.exportPDFMessage": "{PDF} をエクスポート中です。管理で進捗を確認できます。", - "xpack.canvas.workpadHeaderWorkpadExport.exportPDFTitle": "ワークパッド「{workpadName}」の {PDF} エクスポート", - "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelCopyAriaLabel": "この {URL} を使用してスクリプトから、または Watcher で {PDF} を生成することもできます。{URL} をクリップボードにコピーするにはエンターキーを押してください。", - "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelCopyButtonLabel": "{POST} {URL} をコピー", - "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelCopyDescription": "{POST} {URL} をコピーして {KIBANA} 外または ウォッチャー から生成することもできます。", - "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelDisabledDescription": "PDF へのエクスポートは無効になっています。Chromium ブラウザを使用するにはレポートの構成が必要です。これを {fileName} ファイルに追加します。", - "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelGenerateButtonLabel": "{PDF} を生成", - "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelGenerateDescription": "ワークパッドのサイズによって、{PDF} の生成には数分かかる場合があります。", - "xpack.canvas.workpadHeaderWorkpadExport.shareDownloadJSONTitle": "{JSON} をダウンロード", - "xpack.canvas.workpadHeaderWorkpadExport.shareDownloadPDFTitle": "{PDF} レポート", - "xpack.canvas.workpadHeaderWorkpadExport.shareWebsiteErrorTitle": "「{workpadName}」の {ZIP} ファイルの作成に失敗しました。ワークパッドが大きすぎる可能性があります。ファイルを別々にダウンロードする必要があります。", - "xpack.canvas.workpadHeaderWorkpadExport.shareWebsiteTitle": "Web サイトで共有", - "xpack.canvas.workpadHeaderWorkpadExport.shareWorkpadMessage": "このワークパッドを共有", - "xpack.canvas.workpadHeaderWorkpadExport.unknownExportErrorMessage": "未知のエクスポートタイプ: {type}", - "xpack.canvas.workpadHeaderWorkpadExport.unsupportedRendererWarning": "このワークパッドには {CANVAS} シェアラブルワークパッドランタイムがサポートしていないレンダリング関数が含まれています。これらのエレメントはレンダリングされません:", - "xpack.canvas.workpadHeaderWorkpadZoom.zoomControlsAriaLabel": "ズームコントロール", - "xpack.canvas.workpadHeaderWorkpadZoom.zoomControlsTooltip": "ズームコントロール", - "xpack.canvas.workpadHeaderWorkpadZoom.zoomFitToWindowText": "ウィンドウに合わせる", - "xpack.canvas.workpadHeaderWorkpadZoom.zoomInText": "ズームイン", - "xpack.canvas.workpadHeaderWorkpadZoom.zoomOutText": "ズームアウト", - "xpack.canvas.workpadHeaderWorkpadZoom.zoomPanelTitle": "ズーム:", - "xpack.canvas.workpadHeaderWorkpadZoom.zoomPrecentageValue": "リセット", - "xpack.canvas.workpadHeaderWorkpadZoom.zoomResetText": "{scalePercentage}%", - "xpack.canvas.workpadLoader.clonedWorkpadName": "{workpadName} のコピー", - "xpack.canvas.workpadLoader.cloneTooltip": "ワークパッドのクローンを作成します", - "xpack.canvas.workpadLoader.createWorkpadLoadingDescription": "ワークパッドを作成中...", - "xpack.canvas.workpadLoader.deleteButtonAriaLabel": "{numberOfWorkpads} 件のワークパッドを削除", - "xpack.canvas.workpadLoader.deleteButtonLabel": "({numberOfWorkpads}) 件を削除", - "xpack.canvas.workpadLoader.deleteModalConfirmButtonLabel": "削除", - "xpack.canvas.workpadLoader.deleteModalDescription": "削除されたワークパッドは復元できません。", - "xpack.canvas.workpadLoader.deleteMultipleWorkpadsModalTitle": "{numberOfWorkpads} 件のワークパッドを削除しますか?", - "xpack.canvas.workpadLoader.deleteSingleWorkpadModalTitle": "ワークパッド「{workpadName}」を削除しますか?", - "xpack.canvas.workpadLoader.emptyPromptGettingStartedDescription": "新規ワークパッドを作成、テンプレートで開始、またはワークパッド {JSON} ファイルをここにドロップしてインポートします。", - "xpack.canvas.workpadLoader.emptyPromptNewUserDescription": "{CANVAS} は初めてですか?", - "xpack.canvas.workpadLoader.emptyPromptTitle": "初の’ワークパッドを追加しましょう", - "xpack.canvas.workpadLoader.exportButtonAriaLabel": "{numberOfWorkpads} 件のワークパッドをエクスポート", - "xpack.canvas.workpadLoader.exportButtonLabel": "({numberOfWorkpads}) 件をエクスポート:", - "xpack.canvas.workpadLoader.exportTooltip": "ワークパッドをエクスポート", - "xpack.canvas.workpadLoader.fetchLoadingDescription": "ワークパッドを取得中...", - "xpack.canvas.workpadLoader.filePickerPlaceholder": "ワークパッド {JSON} ファイルをインポート", - "xpack.canvas.workpadLoader.loadWorkpadArialLabel": "ワークパッド「{workpadName}」を読み込む", - "xpack.canvas.workpadLoader.noPermissionToCloneToolTip": "ワークパッドのクローンを作成するパーミッションがありません", - "xpack.canvas.workpadLoader.noPermissionToCreateToolTip": "ワークパッドを作成するパーミッションがありません", - "xpack.canvas.workpadLoader.noPermissionToDeleteToolTip": "ワークパッドを削除するパーミッションがありません", - "xpack.canvas.workpadLoader.noPermissionToUploadToolTip": "ワークパッドを更新するパーミッションがありません", - "xpack.canvas.workpadLoader.sampleDataLinkLabel": "初の’ワークパッドを追加しましょう", - "xpack.canvas.workpadLoader.table.createdColumnTitle": "作成済み", - "xpack.canvas.workpadLoader.table.nameColumnTitle": "ワークパッド名", - "xpack.canvas.workpadLoader.table.updatedColumnTitle": "更新しました", - "xpack.canvas.workpadManager.modalTitle": "{CANVAS} ワークパッド", - "xpack.canvas.workpadManager.myWorkpadsTabLabel": "マイワークパッド", - "xpack.canvas.workpadManager.workpadTemplatesTabLabel": "テンプレート", - "xpack.canvas.workpadSearch.searchPlaceholder": "ワークパッドを検索", - "xpack.canvas.workpadTemplate.cloneTemplateLinkAriaLabel": "ワークパッドテンプレート「{templateName}」のクローンを作成", - "xpack.canvas.workpadTemplate.searchPlaceholder": "テンプレートを検索", - "xpack.canvas.workpadTemplates.table.descriptionColumnTitle": "説明", - "xpack.canvas.workpadTemplates.table.nameColumnTitle": "テンプレート名", - "xpack.canvas.workpadTemplates.table.tagsColumnTitle": "タグ", - "xpack.canvas.badge.readOnly.tooltip": "{canvas} ワークパッドを保存できません", - "xpack.crossClusterReplication.addAutoFollowPatternButtonLabel": "自動フォローパターンを作成", - "xpack.crossClusterReplication.addBreadcrumbTitle": "追加", - "xpack.crossClusterReplication.addFollowerButtonLabel": "フォロワーインデックスを作成", - "xpack.crossClusterReplication.app.checkPermissionsFatalErrorTitle": "クラスター横断レプリケーションアプリ", - "xpack.crossClusterReplication.app.deniedPermissionDescription": "クラスター横断レプリケーションを使用するには、{clusterPrivilegesCount, plural, one {次のクラスター特権} other {次のクラスター特権}}が必要です: {clusterPrivileges}。", - "xpack.crossClusterReplication.app.deniedPermissionTitle": "クラスター特権が足りません", - "xpack.crossClusterReplication.app.permissionCheckErrorTitle": "パーミッションの確認中にエラーが発生", - "xpack.crossClusterReplication.app.permissionCheckTitle": "パーミッションを確認中…", - "xpack.crossClusterReplication.appTitle": "クラスター横断レプリケーション", - "xpack.crossClusterReplication.autoFollowPattern.addAction.successNotificationTitle": "自動フォローパターン「{name}」が追加されました", - "xpack.crossClusterReplication.autoFollowPattern.addTitle": "自動フォローパターンの追加", - "xpack.crossClusterReplication.autoFollowPattern.editTitle": "自動フォローパターンの編集", - "xpack.crossClusterReplication.autoFollowPattern.leaderIndexPatternValidation.illegalCharacters": "インデックスパターンから{characterListLength, plural, one {} other {}} {characterList} を削除してください。", - "xpack.crossClusterReplication.autoFollowPattern.leaderIndexPatternValidation.isEmpty": "リーダーインデックスパターンが最低 1 つ必要です。", - "xpack.crossClusterReplication.autoFollowPattern.leaderIndexPatternValidation.noEmptySpace": "インデックスパターンにスペースは使用できません。", - "xpack.crossClusterReplication.autoFollowPattern.nameValidation.errorComma": "名前にコンマは使用できません。", - "xpack.crossClusterReplication.autoFollowPattern.nameValidation.errorEmptyName": "名前が必要です。", - "xpack.crossClusterReplication.autoFollowPattern.nameValidation.errorSpace": "名前にスペースは使用できません。", - "xpack.crossClusterReplication.autoFollowPattern.nameValidation.errorUnderscore": "名前の頭にアンダーラインは使用できません。", - "xpack.crossClusterReplication.autoFollowPattern.prefixValidation.beginsWithPeriod": "接頭辞はピリオドで始めることはできません。", - "xpack.crossClusterReplication.autoFollowPattern.prefixValidation.illegalCharacters": "接頭辞から{characterListLength, plural, one {} other {}} {characterList} を削除してください。", - "xpack.crossClusterReplication.autoFollowPattern.prefixValidation.noEmptySpace": "接頭辞にスペースは使用できません。", - "xpack.crossClusterReplication.autoFollowPattern.removeAction.errorMultipleNotificationTitle": "{count} 自動フォローパターンの削除中にエラーが発生", - "xpack.crossClusterReplication.autoFollowPattern.removeAction.errorSingleNotificationTitle": "「「{name}」自動フォローパターンの削除中にエラーが発生", - "xpack.crossClusterReplication.autoFollowPattern.removeAction.successMultipleNotificationTitle": "{count} 自動フォローパターンが削除されました", - "xpack.crossClusterReplication.autoFollowPattern.removeAction.successSingleNotificationTitle": "「{name}」 自動フォローパターンが削除されました", - "xpack.crossClusterReplication.autoFollowPattern.suffixValidation.illegalCharacters": "接尾辞から{characterListLength, plural, one {} other {}} {characterList} 削除してください。", - "xpack.crossClusterReplication.autoFollowPattern.suffixValidation.noEmptySpace": "接尾辞にスペースは使用できません。", - "xpack.crossClusterReplication.autoFollowPattern.updateAction.successNotificationTitle": "自動フォローパターン「{name}」が更新されました", - "xpack.crossClusterReplication.autoFollowPatternCreateForm.loadingRemoteClustersMessage": "リモートクラスターを読み込み中…", - "xpack.crossClusterReplication.autoFollowPatternCreateForm.saveButtonLabel": "作成", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.closeButtonLabel": "閉じる", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.deleteButtonLabel": "削除", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.editButtonLabel": "編集", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.leaderPatternsLabel": "リーダーパターン", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.notFoundLabel": "自動フォローパターンが見つかりません", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.prefixEmptyValue": "接頭辞がありません", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.prefixLabel": "接頭辞", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.recentErrorsTitle": "最近のエラー", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.remoteClusterLabel": "リモートクラスター", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.statusTitle": "設定", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.suffixEmptyValue": "接尾辞がありません", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.suffixLabel": "接尾辞", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.viewIndicesLink": "インデックス管理でフォロワーインデックスを表示", - "xpack.crossClusterReplication.autoFollowPatternEditForm.loadingErrorMessage": "自動フォローパターン「{name}」は存在しません。", - "xpack.crossClusterReplication.autoFollowPatternEditForm.loadingErrorTitle": "自動フォローパターンの読み込み中にエラーが発生", - "xpack.crossClusterReplication.autoFollowPatternEditForm.loadingRemoteClustersMessage": "リモートクラスターを読み込み中…", - "xpack.crossClusterReplication.autoFollowPatternEditForm.loadingTitle": "自動フォローパターンを読み込み中…", - "xpack.crossClusterReplication.autoFollowPatternEditForm.saveButtonLabel": "更新", - "xpack.crossClusterReplication.autoFollowPatternEditForm.viewAutoFollowPatternsButtonLabel": "自動フォローパターンを表示", - "xpack.crossClusterReplication.autoFollowPatternForm.actions.savingText": "保存中", - "xpack.crossClusterReplication.autoFollowPatternForm.autoFollowPattern.fieldPrefixLabel": "接頭辞", - "xpack.crossClusterReplication.autoFollowPatternForm.autoFollowPattern.fieldSuffixLabel": "接尾辞", - "xpack.crossClusterReplication.autoFollowPatternForm.autoFollowPatternName.fieldNameLabel": "名前", - "xpack.crossClusterReplication.autoFollowPatternForm.cancelButtonLabel": "キャンセル", - "xpack.crossClusterReplication.autoFollowPatternForm.currentRemoteClusterNotConnectedCallOutDescription": "これはリモートクラスターを編集することで解決できます。", - "xpack.crossClusterReplication.autoFollowPatternForm.currentRemoteClusterNotConnectedCallOutTitle": "リモートクラスター「{name}」が接続されていないため、自動フォローパターンを編集できません", - "xpack.crossClusterReplication.autoFollowPatternForm.currentRemoteClusterNotFoundCallOutDescription": "この自動フォローパターンを編集するには、「{name}」というリモートクラスターの追加が必要です。", - "xpack.crossClusterReplication.autoFollowPatternForm.emptyRemoteClustersCallOutDescription": "自動フォローパターンはリモートクラスターのインデックスを捕捉します。", - "xpack.crossClusterReplication.autoFollowPatternForm.fieldFollowerIndicesHelpLabel": "スペースと {characterList} は使用できません。", - "xpack.crossClusterReplication.autoFollowPatternForm.fieldLeaderIndexPatternsHelpLabel": "スペースと {characterList} は使用できません。", - "xpack.crossClusterReplication.autoFollowPatternForm.fieldLeaderIndexPatternsLabel": "インデックスパターン", - "xpack.crossClusterReplication.autoFollowPatternForm.fieldLeaderIndexPatternsPlaceholder": "入力してエンターキーを押してください", - "xpack.crossClusterReplication.autoFollowPatternForm.indicesPreviewDescription": "上の設定は次のようなインデックス名を生成します:", - "xpack.crossClusterReplication.autoFollowPatternForm.indicesPreviewTitle": "インデックス名の例", - "xpack.crossClusterReplication.autoFollowPatternForm.leaderIndexPatternError.duplicateMessage": "リーダーインデックスパターンの複製はできません。", - "xpack.crossClusterReplication.autoFollowPatternForm.savingErrorTitle": "自動フォローパターンを作成できません", - "xpack.crossClusterReplication.autoFollowPatternForm.sectionAutoFollowPatternDescription": "カスタム接頭辞や接尾辞はフォロワーインデックス名に適用され、複製されたインデックスを見分けやすくします。デフォルトで、フォロワーインデックスにはリーダーインデックスと同じ名前が付きます。", - "xpack.crossClusterReplication.autoFollowPatternForm.sectionAutoFollowPatternNameDescription": "自動フォローパターンの固有の名前です。", - "xpack.crossClusterReplication.autoFollowPatternForm.sectionAutoFollowPatternNameTitle": "名前", - "xpack.crossClusterReplication.autoFollowPatternForm.sectionAutoFollowPatternTitle": "フォロワーインデックス (オプション)", - "xpack.crossClusterReplication.autoFollowPatternForm.sectionLeaderIndexPatternsDescription1": "リモートクラスターから複製するインデックスを識別する 1 つまたは複数のインデックスパターンです。これらのパターンと一致する新しいインデックスが作成される際、ローカルクラスターでフォロワーインデックスに複製されます。", - "xpack.crossClusterReplication.autoFollowPatternForm.sectionLeaderIndexPatternsDescription2": "{note} 既に存在するインデックスは複製されません。", - "xpack.crossClusterReplication.autoFollowPatternForm.sectionLeaderIndexPatternsDescription2.noteLabel": "注:", - "xpack.crossClusterReplication.autoFollowPatternForm.sectionLeaderIndexPatternsTitle": "リーダーインデックス", - "xpack.crossClusterReplication.autoFollowPatternForm.sectionRemoteClusterDescription": "リーダーインデックスに複製する元のリモートクラスター。", - "xpack.crossClusterReplication.autoFollowPatternForm.sectionRemoteClusterTitle": "リモートクラスター", - "xpack.crossClusterReplication.autoFollowPatternForm.validationErrorTitle": "続行する前にエラーを修正してください", - "xpack.crossClusterReplication.autoFollowPatternList.addAutoFollowPatternButtonLabel": "新規自動フォローパターンを作成", - "xpack.crossClusterReplication.autoFollowPatternList.autoFollowPatternsDescription": "自動フォローパターンは、リモートクラスターからリーダーインデックスを複製し、ローカルクラスターでフォロワーインデックスにコピーします。", - "xpack.crossClusterReplication.autoFollowPatternList.autoFollowPatternsTitle": "自動フォローパターン", - "xpack.crossClusterReplication.autoFollowPatternList.crossClusterReplicationTitle": "クラスター横断レプリケーション", - "xpack.crossClusterReplication.autoFollowPatternList.emptyPromptDescription": "自動フォローパターンを使用して自動的にリモートクラスターからインデックスを複製します。", - "xpack.crossClusterReplication.autoFollowPatternList.emptyPromptTitle": "初めの自動フォローパターンの作成", - "xpack.crossClusterReplication.autoFollowPatternList.followerIndicesTitle": "フォロワーインデックス", - "xpack.crossClusterReplication.autoFollowPatternList.loadingErrorTitle": "自動フォローパターンの読み込み中にエラーが発生", - "xpack.crossClusterReplication.autoFollowPatternList.loadingTitle": "自動フォローパターンを読み込み中…", - "xpack.crossClusterReplication.autoFollowPatternList.noPermissionText": "自動フォローパターンの表示または追加パーミッションがありません。", - "xpack.crossClusterReplication.autoFollowPatternList.permissionErrorTitle": "パーミッションエラー", - "xpack.crossClusterReplication.autoFollowPatternList.table.actionDeleteDescription": "自動フォローパターンを削除", - "xpack.crossClusterReplication.autoFollowPatternList.table.actionEditDescription": "自動フォローパターンの編集", - "xpack.crossClusterReplication.autoFollowPatternList.table.actionsColumnTitle": "アクション", - "xpack.crossClusterReplication.autoFollowPatternList.table.clusterColumnTitle": "リモートクラスター", - "xpack.crossClusterReplication.autoFollowPatternList.table.leaderPatternsColumnTitle": "リーダーパターン", - "xpack.crossClusterReplication.autoFollowPatternList.table.nameColumnTitle": "名前", - "xpack.crossClusterReplication.autoFollowPatternList.table.prefixColumnTitle": "フォロワーインデックスの接頭辞", - "xpack.crossClusterReplication.autoFollowPatternList.table.suffixColumnTitle": "フォロワーインデックスの接尾辞", - "xpack.crossClusterReplication.checkLicense.errorExpiredMessage": "{licenseType} ライセンスが期限切れのため {pluginName} を使用できません", - "xpack.crossClusterReplication.checkLicense.errorUnavailableMessage": "現在ライセンス情報が利用できないため {pluginName} を使用できません。", - "xpack.crossClusterReplication.checkLicense.errorUnsupportedMessage": "ご使用の {licenseType} ライセンスは {pluginName} をサポートしていません。ライセンスをアップグレードしてください。", - "xpack.crossClusterReplication.deleteAutoFollowPattern.confirmModal.cancelButtonText": "キャンセル", - "xpack.crossClusterReplication.deleteAutoFollowPattern.confirmModal.confirmButtonText": "削除", - "xpack.crossClusterReplication.deleteAutoFollowPattern.confirmModal.deleteMultipleTitle": "{count} 個の自動フォローパターンを削除しますか?", - "xpack.crossClusterReplication.deleteAutoFollowPattern.confirmModal.deleteSingleTitle": "自動フォローパターン「{name}」を削除しますか?", - "xpack.crossClusterReplication.deleteAutoFollowPattern.confirmModal.multipleDeletionDescription": "これらの自動フォローパターンを削除しようとしています:", - "xpack.crossClusterReplication.deleteAutoFollowPatternButtonLabel": "自動フォロー{total, plural, one {パターン} other {パターン}}を削除", - "xpack.crossClusterReplication.editBreadcrumbTitle": "編集", - "xpack.crossClusterReplication.followerIndex.addAction.successNotificationTitle": "フォロワーインデックス「{name}」が追加されました", - "xpack.crossClusterReplication.followerIndex.addTitle": "フォロワーインデックスの追加", - "xpack.crossClusterReplication.followerIndex.advancedSettingsForm.showSwitchLabel": "高度な設定をカスタマイズ", - "xpack.crossClusterReplication.followerIndex.contextMenu.buttonLabel": "フォロワー{followerIndicesLength, plural, one {インデックス} other {インデックス}}の管理", - "xpack.crossClusterReplication.followerIndex.contextMenu.editLabel": "フォロワーインデックスを編集", - "xpack.crossClusterReplication.followerIndex.contextMenu.pauseLabel": "複製を中止", - "xpack.crossClusterReplication.followerIndex.contextMenu.resumeLabel": "複製を再開", - "xpack.crossClusterReplication.followerIndex.contextMenu.title": "フォロワー{followerIndicesLength, plural, one {インデックス} other {インデックス}}オプション", - "xpack.crossClusterReplication.followerIndex.contextMenu.unfollowLabel": "不明なリーダー{followerIndicesLength, plural, one {インデックス} other {インデックス}}", - "xpack.crossClusterReplication.followerIndex.editTitle": "フォロワーインデックスを編集します", - "xpack.crossClusterReplication.followerIndex.indexNameValidation.noEmptySpace": "名前にスペースは使用できません。", - "xpack.crossClusterReplication.followerIndex.leaderIndexValidation.noEmptySpace": "リーダーインデックスではスペースを使用できません。", - "xpack.crossClusterReplication.followerIndex.pauseAction.errorMultipleNotificationTitle": "{count} 件のフォロワーインデックスのパース中にエラーが発生", - "xpack.crossClusterReplication.followerIndex.pauseAction.errorSingleNotificationTitle": "フォロワーインデックス「{name}」のパース中にエラーが発生", - "xpack.crossClusterReplication.followerIndex.pauseAction.successMultipleNotificationTitle": "{count} 件のフォロワーインデックスがパースされました", - "xpack.crossClusterReplication.followerIndex.pauseAction.successSingleNotificationTitle": "フォロワーインデックス「{name}」がパースされました", - "xpack.crossClusterReplication.followerIndex.resumeAction.errorMultipleNotificationTitle": "{count} 件のフォロワーインデックスの再開中にエラーが発生", - "xpack.crossClusterReplication.followerIndex.resumeAction.errorSingleNotificationTitle": "フォロワーインデックス「{name}」の再開中にエラーが発生", - "xpack.crossClusterReplication.followerIndex.resumeAction.successMultipleNotificationTitle": "{count} 件のフォロワーインデックスが再開されました", - "xpack.crossClusterReplication.followerIndex.resumeAction.successSingleNotificationTitle": "フォロワーインデックス「{name}」が再開されました", - "xpack.crossClusterReplication.followerIndex.unfollowAction.errorMultipleNotificationTitle": "{count} 件のフォロワーインデックスの、リーダーインデックスのフォロー解除中にエラーが発生", - "xpack.crossClusterReplication.followerIndex.unfollowAction.errorSingleNotificationTitle": "フォロワーインデックス「{name}」の、リーダーインデックスのフォロー解除中にエラーが発生", - "xpack.crossClusterReplication.followerIndex.unfollowAction.notOpenWarningMultipleNotificationTitle": "{count} 件のインデックスを再度開けませんでした", - "xpack.crossClusterReplication.followerIndex.unfollowAction.notOpenWarningSingleNotificationTitle": "インデックス「{name}」を再度開けませんでした", - "xpack.crossClusterReplication.followerIndex.unfollowAction.successMultipleNotificationTitle": "{count} 件のフォロワーインデックスの、リーダーインデックスのフォローが解除されました", - "xpack.crossClusterReplication.followerIndex.unfollowAction.successSingleNotificationTitle": "フォロワーインデックス「{name}」の、リーダーインデックスのフォローが解除されました", - "xpack.crossClusterReplication.followerIndex.updateAction.successNotificationTitle": "フォロワーインデックス「{name}」が更新されました", - "xpack.crossClusterReplication.followerIndexCreateForm.loadingRemoteClustersMessage": "リモートクラスターを読み込み中…", - "xpack.crossClusterReplication.followerIndexCreateForm.saveButtonLabel": "作成", - "xpack.crossClusterReplication.followerIndexDetailPanel.activeStatus": "アクティブ", - "xpack.crossClusterReplication.followerIndexDetailPanel.closeButtonLabel": "閉じる", - "xpack.crossClusterReplication.followerIndexDetailPanel.leaderIndexLabel": "リーダーインデックス", - "xpack.crossClusterReplication.followerIndexDetailPanel.loadingLabel": "フォロワーインデックスを読み込み中…", - "xpack.crossClusterReplication.followerIndexDetailPanel.manageButtonLabel": "管理", - "xpack.crossClusterReplication.followerIndexDetailPanel.notFoundLabel": "フォロワーインデックスが見つかりません", - "xpack.crossClusterReplication.followerIndexDetailPanel.pausedFollowerCalloutTitle": "パースされたフォロワーインデックスに設定またはシャード統計がありません。", - "xpack.crossClusterReplication.followerIndexDetailPanel.pausedStatus": "一時停止中", - "xpack.crossClusterReplication.followerIndexDetailPanel.remoteClusterLabel": "リモートクラスター", - "xpack.crossClusterReplication.followerIndexDetailPanel.settingsTitle": "設定", - "xpack.crossClusterReplication.followerIndexDetailPanel.shardStatsTitle": "シャード {id} の統計", - "xpack.crossClusterReplication.followerIndexDetailPanel.statusLabel": "ステータス", - "xpack.crossClusterReplication.followerIndexDetailPanel.viewIndexLink": "インデックス管理で表示", - "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.cancelButtonText": "キャンセル", - "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.confirmAndResumeButtonText": "更新して再開", - "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.confirmButtonText": "更新", - "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.description": "フォロワーインデックスが一時停止し、再開しました。更新に失敗した場合、手動で複製を再開してみてください。", - "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.resumeDescription": "フォロワーインデックスを更新すると、リーダーインデックスの複製が再開されます。", - "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.title": "フォロワーインデックス「{id}」を更新しますか?", - "xpack.crossClusterReplication.followerIndexEditForm.loadingErrorMessage": "フォロワーインデックス「{name}」は存在しません。", - "xpack.crossClusterReplication.followerIndexEditForm.loadingErrorTitle": "フォロワーインデックスを読み込み中にエラーが発生", - "xpack.crossClusterReplication.followerIndexEditForm.loadingFollowerIndexTitle": "フォロワーインデックスを読み込み中…", - "xpack.crossClusterReplication.followerIndexEditForm.loadingRemoteClustersMessage": "リモートクラスターを読み込み中…", - "xpack.crossClusterReplication.followerIndexEditForm.saveButtonLabel": "更新", - "xpack.crossClusterReplication.followerIndexEditForm.viewFollowerIndicesButtonLabel": "フォロワーインデックスを表示", - "xpack.crossClusterReplication.followerIndexForm.actions.savingText": "保存中", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.byteUnitsHelpText": "値の例:10b、1024kb、1mb、5gb、2tb、1pb。{link}", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.byteUnitsHelpTextLinkMessage": "続きを読む", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingReadRequestsDescription": "リモートクラスターからの未了の読み込みリクエストの最高数です。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingReadRequestsLabel": "未了読み込みリクエストの最高数", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingReadRequestsTitle": "未了読み込みリクエストの最高数", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingWriteRequestsDescription": "フォロワーの未了の書き込みリクエストの最高数です", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingWriteRequestsLabel": "未了書き込みリクエストの最高数", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingWriteRequestsTitle": "未了書き込みリクエストの最高数", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestOperationCountDescription": "リモートクラスターからの読み込みごとのプーリングオペレーションの最高数です。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestOperationCountLabel": "読み込みリクエストオペレーションの最高数", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestOperationCountTitle": "読み込みリクエストオペレーションの最高数", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestSizeDescription": "リモートクラスターからプーリングされるオペレーションのバッチの読み込みごとのバイト単位の最大サイズです。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestSizeLabel": "最大読み込みリクエストサイズ", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestSizeTitle": "最大読み込みリクエストサイズ", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxRetryDelayDescription": "例外で失敗したオペレーションを再試行するまでの最長待ち時間です。再試行の際には指数バックオフの手段が取られます。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxRetryDelayLabel": "最長再試行遅延", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxRetryDelayTitle": "最長再試行遅延", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferCountDescription": "書き込み待ちにできるオペレーションの最高数です。この制限数に達すると、キューのオペレーション数が制限未満になるまで、リモートクラスターからの読み込みが延期されます。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferCountLabel": "最大書き込みバッファー数", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferCountTitle": "最大書き込みバッファー数", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferSizeDescription": "書き込み待ちにできるオペレーションの最高合計バイト数です。この制限数に達すると、キューのオペレーションの合計バイト数が制限未満になるまで、リモートクラスターからの読み込みが延期されます。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferSizeLabel": "最大書き込みバッファーサイズ", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferSizeTitle": "最大書き込みバッファーサイズ", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestOperationCountDescription": "フォロワーに実行される一斉書き込みリクエストごとのオペレーションの最高数です。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestOperationCountLabel": "書き込みリクエストオペレーションの最高数", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestOperationCountTitle": "書き込みリクエストオペレーションの最高数", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestSizeDescription": "フォロワーに実行される一斉書き込みリクエストごとのオペレーションの最高合計バイト数です。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestSizeLabel": "書き込みリクエストの最大サイズ", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestSizeTitle": "書き込みリクエストの最大サイズ", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.readPollTimeoutDescription": "フォロワーインデックスがリーダーインデックスと同期される際のリモートクラスターの新規オペレーションの最長待ち時間です。タイムアウトになった場合、統計を更新できるようオペレーションのポーリングがフォロワーに返され、フォロワーが直ちにリーダーから再度読み込みを試みます。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.readPollTimeoutLabel": "読み込みポーリングタイムアウト", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.readPollTimeoutTitle": "読み込みポーリングタイムアウト", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.timeUnitsHelpText": "値の例:2d、24h、20m、30s、500ms、10000micros、80000nanos。{link}", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.timeUnitsHelpTextLinkMessage": "続きを読む", - "xpack.crossClusterReplication.followerIndexForm.advancedSettingsDescription": "高度な設定は、複製のレートを管理します。これらの設定をカスタマイズするか、デフォルトの値を使用できます。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettingsTitle": "高度な設定 (任意)", - "xpack.crossClusterReplication.followerIndexForm.cancelButtonLabel": "キャンセル", - "xpack.crossClusterReplication.followerIndexForm.currentRemoteClusterNotConnectedCallOutDescription": "これはリモートクラスターを編集することで解決できます。", - "xpack.crossClusterReplication.followerIndexForm.currentRemoteClusterNotConnectedCallOutTitle": "リモートクラスター「{name}」が接続されていないため、フォロワーインデックスを編集できません", - "xpack.crossClusterReplication.followerIndexForm.currentRemoteClusterNotFoundCallOutDescription": "このフォロワーインデックスを編集するには、「{name}」というリモートクラスターの追加が必要です。", - "xpack.crossClusterReplication.followerIndexForm.emptyRemoteClustersCallOutDescription": "複製にはリモートクラスターのリーダーインデックスが必要です。", - "xpack.crossClusterReplication.followerIndexForm.errors.leaderIndexIllegalCharactersMessage": "リーダーインデックスから {characterList} を削除してください。", - "xpack.crossClusterReplication.followerIndexForm.errors.leaderIndexMissingMessage": "リーダーインデックスが必要です。", - "xpack.crossClusterReplication.followerIndexForm.errors.nameBeginsWithPeriodMessage": "名前はピリオドで始めることはできません。", - "xpack.crossClusterReplication.followerIndexForm.errors.nameIllegalCharactersMessage": "名前から {characterList} を削除してください。", - "xpack.crossClusterReplication.followerIndexForm.errors.nameMissingMessage": "名前が必要です。", - "xpack.crossClusterReplication.followerIndexForm.indexAlreadyExistError": "同じ名前のインデックスが既に存在します。", - "xpack.crossClusterReplication.followerIndexForm.indexNameHelpLabel": "スペースと {characterList} は使用できません。", - "xpack.crossClusterReplication.followerIndexForm.indexNameValidatingLabel": "利用可能か確認中…", - "xpack.crossClusterReplication.followerIndexForm.indexNameValidationFatalErrorTitle": "フォロワーインデックスフォームのインデックス名の検証", - "xpack.crossClusterReplication.followerIndexForm.leaderIndexNotFoundError": "リーダーインデックス「{leaderIndex}」は存在しません。", - "xpack.crossClusterReplication.followerIndexForm.resetFieldButtonLabel": "デフォルトにリセット", - "xpack.crossClusterReplication.followerIndexForm.savingErrorTitle": "フォロワーインデックスを作成できません", - "xpack.crossClusterReplication.followerIndexForm.sectionFollowerIndexNameDescription": "インデックスの固有の名前です。", - "xpack.crossClusterReplication.followerIndexForm.sectionFollowerIndexNameTitle": "フォロワーインデックス", - "xpack.crossClusterReplication.followerIndexForm.sectionLeaderIndexDescription": "フォロワーインデックスに複製するリモートクラスターのインデックスです。", - "xpack.crossClusterReplication.followerIndexForm.sectionLeaderIndexDescription2": "{note} リーダーインデックスが既に存在している必要があります。", - "xpack.crossClusterReplication.followerIndexForm.sectionLeaderIndexDescription2.noteLabel": "注:", - "xpack.crossClusterReplication.followerIndexForm.sectionLeaderIndexTitle": "リーダーインデックス", - "xpack.crossClusterReplication.followerIndexForm.sectionRemoteClusterDescription": "複製するインデックスを含むクラスターです。", - "xpack.crossClusterReplication.followerIndexForm.sectionRemoteClusterTitle": "リモートクラスター", - "xpack.crossClusterReplication.followerIndexForm.validationErrorTitle": "続行する前にエラーを修正してください。", - "xpack.crossClusterReplication.followerIndexList.addFollowerButtonLabel": "フォロワーインデックスを作成", - "xpack.crossClusterReplication.followerIndexList.emptyPromptDescription": "フォロワーインデックスを使用してリモートクラスターのリーダーインデックスを複製します。", - "xpack.crossClusterReplication.followerIndexList.emptyPromptTitle": "最初のフォロワーインデックスの作成", - "xpack.crossClusterReplication.followerIndexList.followerIndicesDescription": "フォロワーインデックスはリモートクラスターのリーダーインデックスを複製します。", - "xpack.crossClusterReplication.followerIndexList.loadingErrorTitle": "フォロワーインデックスを読み込み中にエラーが発生", - "xpack.crossClusterReplication.followerIndexList.loadingTitle": "フォロワーインデックスを読み込み中…", - "xpack.crossClusterReplication.followerIndexList.noPermissionText": "フォロワーインデックスの表示または追加パーミッションがありません。", - "xpack.crossClusterReplication.followerIndexList.permissionErrorTitle": "パーミッションエラー", - "xpack.crossClusterReplication.followerIndexList.table.actionEditDescription": "フォロワーインデックスを編集します", - "xpack.crossClusterReplication.followerIndexList.table.actionPauseDescription": "複製を中止", - "xpack.crossClusterReplication.followerIndexList.table.actionResumeDescription": "複製を再開", - "xpack.crossClusterReplication.followerIndexList.table.actionsColumnTitle": "アクション", - "xpack.crossClusterReplication.followerIndexList.table.actionUnfollowDescription": "不明なリーダーインデックス", - "xpack.crossClusterReplication.followerIndexList.table.clusterColumnTitle": "リモートクラスター", - "xpack.crossClusterReplication.followerIndexList.table.leaderIndexColumnTitle": "リーダーインデックス", - "xpack.crossClusterReplication.followerIndexList.table.nameColumnTitle": "名前", - "xpack.crossClusterReplication.followerIndexList.table.statusColumn.activeLabel": "アクティブ", - "xpack.crossClusterReplication.followerIndexList.table.statusColumn.pausedLabel": "一時停止中", - "xpack.crossClusterReplication.followerIndexList.table.statusColumnTitle": "ステータス", - "xpack.crossClusterReplication.homeBreadcrumbTitle": "クラスター横断レプリケーション", - "xpack.crossClusterReplication.indexMgmtBadge.followerLabel": "フォロワー", - "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.cancelButtonText": "キャンセル", - "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.confirmButtonText": "複製を中止", - "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.multiplePauseDescription": "これらのフォロワーインデックスの複製が一時停止されます:", - "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.multiplePauseDescriptionWithSettingWarning": "フォロワーインデックスへの複製を一時停止することで、高度な設定のカスタマイズが消去されます。", - "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.pauseMultipleTitle": "{count} 件のフォロワーインデックスへの複製を一時停止しますか?", - "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.pauseSingleTitle": "フォロワーインデックス 「{name}」 への複製を一時停止しますか?", - "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.singlePauseDescriptionWithSettingWarning": "このフォロワーインデックスへの複製を一時停止することで、高度な設定のカスタマイズが消去されます。", - "xpack.crossClusterReplication.readDocsAutoFollowPatternButtonLabel": "自動フォローパターンドキュメント", - "xpack.crossClusterReplication.readDocsFollowerIndexButtonLabel": "フォロワーインデックスドキュメント", - "xpack.crossClusterReplication.remoteClustersFormField.addRemoteClusterButtonLabel": "リモートクラスターを追加", - "xpack.crossClusterReplication.remoteClustersFormField.currentRemoteClusterNotConnectedCallOutDescription": "リモートクラスターを編集するか、接続されているクラスターを選択します。", - "xpack.crossClusterReplication.remoteClustersFormField.currentRemoteClusterNotConnectedCallOutTitle": "リモートクラスター「{name}」が接続されていません", - "xpack.crossClusterReplication.remoteClustersFormField.emptyRemoteClustersCallOutDescription": "フォロワーインデックスを作成するには最低 1 つのリモートクラスターが必要です。", - "xpack.crossClusterReplication.remoteClustersFormField.emptyRemoteClustersCallOutTitle": "リモートクラスターがありません", - "xpack.crossClusterReplication.remoteClustersFormField.fieldClusterLabel": "リモートクラスター", - "xpack.crossClusterReplication.remoteClustersFormField.invalidRemoteClusterError": "無効なリモートクラスター", - "xpack.crossClusterReplication.remoteClustersFormField.remoteClusterDropdownNotConnected": "{name} (未接続)", - "xpack.crossClusterReplication.remoteClustersFormField.remoteClusterNotFoundTitle": "リモートクラスター「{name}」が見つかりませんでした", - "xpack.crossClusterReplication.remoteClustersFormField.validRemoteClusterRequired": "接続されたリモートクラスターが必要です。", - "xpack.crossClusterReplication.remoteClustersFormField.viewRemoteClusterButtonLabel": "リモートクラスターを編集", - "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.cancelButtonText": "キャンセル", - "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.confirmButtonText": "複製を再開", - "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.multipleResumeDescription": "これらのフォロワーインデックスの複製が再開されます:", - "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.multipleResumeDescriptionWithSettingWarning": "複製はデフォルトの高度な設定で再開されます。", - "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.resumeMultipleTitle": "{count} 件のフォロワーインデックスへの複製を再開しますか?", - "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.resumeSingleTitle": "フォロワーインデックス「{name}」への複製を再開しますか?", - "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.singleResumeDescription": "複製はデフォルトの高度な設定で再開されます。カスタマイズされた高度な設定を使用するには、{editLink}。", - "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.singleResumeEditLink": "フォロワーインデックスを編集", - "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.cancelButtonText": "キャンセル", - "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.confirmButtonText": "不明なリーダー", - "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.multipleUnfollowDescription": "フォロワーインデックスは標準のインデックスに変換されます。今後クラスター横断レプリケーションには表示されませんが、インデックス管理で管理できます。この操作は元に戻すことができません。", - "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.singleUnfollowDescription": "フォロワーインデックスは標準のインデックスに変換されます。今後クラスター横断レプリケーションには表示されませんが、インデックス管理で管理できます。この操作は元に戻すことができません。", - "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.unfollowMultipleTitle": "{count} 件のリーダーインデックスのフォローを解除しますか?", - "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.unfollowSingleTitle": "「{name}」のリーダーインデックスのフォローを解除しますか?", - "xpack.crossClusterReplication.autoFollowPatternForm.hideRequestButtonLabel": "リクエストを非表示", - "xpack.crossClusterReplication.autoFollowPatternForm.requestFlyout.closeButtonLabel": "閉じる", - "xpack.crossClusterReplication.autoFollowPatternForm.requestFlyout.createDescriptionText": "この Elasticsearch リクエストは、この自動フォローパターンを作成します。", - "xpack.crossClusterReplication.autoFollowPatternForm.requestFlyout.editDescriptionText": "この Elasticsearch リクエストは、この自動フォローパターンを更新します。", - "xpack.crossClusterReplication.autoFollowPatternForm.requestFlyout.namedTitle": "「{name}」のリクエスト", - "xpack.crossClusterReplication.autoFollowPatternForm.requestFlyout.unnamedTitle": "リクエスト", - "xpack.crossClusterReplication.autoFollowPatternFormm.showRequestButtonLabel": "リクエストを表示", - "xpack.crossClusterReplication.followerIndexForm.hideRequestButtonLabel": "リクエストを非表示", - "xpack.crossClusterReplication.followerIndexForm.requestFlyout.closeButtonLabel": "閉じる", - "xpack.crossClusterReplication.followerIndexForm.requestFlyout.descriptionText": "この Elasticsearch リクエストは、このフォロワーインデックスを作成します。", - "xpack.crossClusterReplication.followerIndexForm.requestFlyout.title": "リクエスト", - "xpack.crossClusterReplication.followerIndexForm.showRequestButtonLabel": "リクエストを表示", - "xpack.dashboardMode.dashboardViewer.dashboardDescription": "ダッシュボードビューアー", - "xpack.dashboardMode.dashboardViewer.dashboardTitle": "ダッシュボード", - "xpack.dashboardMode.dashboardViewerDescription": "ダッシュボードを表示", - "xpack.dashboardMode.dashboardViewerTitle": "ダッシュボードビューアー", - "xpack.dashboardMode.uiSettings.dashboardsOnlyRolesDescription": "ダッシュボード表示専用モードのロールです", - "xpack.dashboardMode.uiSettings.dashboardsOnlyRolesTitle": "ダッシュボード専用ロール", - "xpack.graph.badge.readOnly.text": "読み込み専用", - "xpack.graph.badge.readOnly.tooltip": "Graph ワークスペースを保存できません", - "xpack.graph.exploreGraph.timedOutWarningText": "閲覧がタイムアウトしました", - "xpack.graph.featureRegistry.graphFeatureName": "Graph", - "xpack.graph.home.breadcrumb": "Graph", - "xpack.graph.missingWorkspaceErrorMessage": "ワークスペースがありません", - "xpack.graph.outlinkEncoders.esqPlainDescription": "標準 URL エンコードの JSON", - "xpack.graph.outlinkEncoders.esqPlainTitle": "Elasticsearch クエリ (プレインエンコード)", - "xpack.graph.outlinkEncoders.esqRisonDescription": "Rison エンコードの JSON、minimum_should_match=2、ほとんどの Kibana URL に対応", - "xpack.graph.outlinkEncoders.esqRisonLooseDescription": "Rison エンコードの JSON、minimum_should_match=1、ほとんどの Kibana URL に対応", - "xpack.graph.outlinkEncoders.esqRisonLooseTitle": "Elasticsearch OR クエリ (Rison エンコード)", - "xpack.graph.outlinkEncoders.esqRisonTitle": "Elasticsearch AND クエリ (Rison エンコード)", - "xpack.graph.outlinkEncoders.esqSimilarRisonDescription": "Rison エンコードの JSON、欠けているドキュメントを検索するための「これに似ているがこれではない」といったタイプのクエリです", - "xpack.graph.outlinkEncoders.esqSimilarRisonTitle": "Elasticsearch more like this クエリ (Rison エンコード)", - "xpack.graph.outlinkEncoders.textLuceneDescription": "選択された Lucene 特殊文字エンコードを含む頂点ラベルのテキストです", - "xpack.graph.outlinkEncoders.textLuceneTitle": "Lucene エスケープテキスト", - "xpack.graph.outlinkEncoders.textPlainDescription": "選択されたパス URL エンコード文字列としての頂点ラベル のテキストです", - "xpack.graph.outlinkEncoders.textPlainTitle": "プレインテキスト", - "xpack.graph.pluginDescription": "Elasticsearch データの関連性のある関係を浮上させ分析します。", - "xpack.graph.savedWorkspace.workspaceNameTitle": "新規グラフワークスペース", - "xpack.graph.savedWorkspaces.graphWorkspaceLabel": "グラフワークスペース", - "xpack.graph.savedWorkspaces.graphWorkspacesLabel": "グラフワークスペース", - "xpack.graph.saveWorkspace.successNotification.noDataSavedText": "構成が保存されましたが、データは保存されませんでした", - "xpack.graph.saveWorkspace.successNotificationTitle": "「{workspaceTitle}」が保存されました", - "xpack.graph.serverSideErrors.unavailableGraphErrorMessage": "グラフを利用できません", - "xpack.graph.serverSideErrors.unavailableLicenseInformationErrorMessage": "グラフを利用できません。現在ライセンス情報が利用できません。", - "xpack.graph.settings.advancedSettings.certaintyInputHelpText": "関連用語が登録される前に証拠として必要なドキュメントの最低数です", - "xpack.graph.settings.advancedSettings.certaintyInputLabel": "確実性", - "xpack.graph.settings.advancedSettings.diversityFieldInputHelpText1": "ドキュメントのサンプルが 1 種類に偏らないように、バイアスの原因の認識に役立つフィールドを選択してください。", - "xpack.graph.settings.advancedSettings.diversityFieldInputHelpText2": "1 つの用語のフィールドを選択しないと、検索がエラーで拒否されます", - "xpack.graph.settings.advancedSettings.diversityFieldInputLabel": "多様性フィールド", - "xpack.graph.settings.advancedSettings.diversityFieldInputOptionLabel": "[多様化なし)", - "xpack.graph.settings.advancedSettings.maxValuesInputHelpText": "同じ値を含めることのできるサンプルのドキュメントの最大数です", - "xpack.graph.settings.advancedSettings.maxValuesInputHelpText.fieldText": "フィールド", - "xpack.graph.settings.advancedSettings.maxValuesInputLabel": "フィールドごとの最大ドキュメント数", - "xpack.graph.settings.advancedSettings.sampleSizeInputHelpText": "用語は最も関連性の高いドキュメントのサンプルから認識されます。サンプルは大きければ良いというものではありません。動作が遅くなり関連性が低くなる可能性があります。", - "xpack.graph.settings.advancedSettings.sampleSizeInputLabel": "サンプルサイズ", - "xpack.graph.settings.advancedSettings.significantLinksCheckboxHelpText": "ただ利用頻度が高いだけでなく「重要」な用語を認識します", - "xpack.graph.settings.advancedSettings.significantLinksCheckboxLabel": "重要なリンク", - "xpack.graph.settings.advancedSettings.timeoutInputHelpText": "リクエストが実行可能なミリ秒単位での最長時間です", - "xpack.graph.settings.advancedSettings.timeoutInputLabel": "タイムアウト (ms)", - "xpack.graph.settings.advancedSettingsTitle": "高度な設定", - "xpack.graph.settings.blacklist.blacklistHelpText": "これらの用語は現在ワークスペースに再度表示されないようブラックリストに登録されています", - "xpack.graph.settings.blacklist.clearButtonLabel": "消去", - "xpack.graph.settings.blacklistTitle": "ブラックリスト", - "xpack.graph.settings.drillDowns.defaultUrlTemplateTitle": "生ドキュメント", - "xpack.graph.settings.drillDowns.invalidUrlWarningText": "URL には {placeholder} 文字列を含める必要があります。", - "xpack.graph.settings.drillDowns.kibanaUrlWarningText": "これは Kibana URL のようです。テンプレートに変換しますか?", - "xpack.graph.settings.drillDowns.resetButtonLabel": "リセット", - "xpack.graph.settings.drillDowns.toolbarIconPickerLabel": "ツールバーアイコン", - "xpack.graph.settings.drillDowns.urlDescriptionInputLabel": "タイトル", - "xpack.graph.settings.drillDowns.urlDescriptionInputPlaceholder": "Google で検索", - "xpack.graph.settings.drillDowns.urlEncoderInputLabel": "URL パラメータータイプ", - "xpack.graph.settings.drillDowns.urlInputHelpText": "選択された頂点用語が挿入された場所に {gquery} でテンプレート URL を定義してください", - "xpack.graph.settings.drillDowns.urlInputLabel": "URL", - "xpack.graph.settings.drillDownsTitle": "ドリルダウン", - "xpack.graph.sidebar.displayLabelHelpText": "この頂点の票を変更", - "xpack.graph.sidebar.displayLabelLabel": "ラベルを表示", - "xpack.graph.sidebar.drillDowns.noDrillDownsHelpText": "設定メニューからドリルダウンを構成します", - "xpack.graph.sidebar.drillDownsTitle": "ドリルダウン", - "xpack.graph.sidebar.groupButtonLabel": "グループ", - "xpack.graph.sidebar.groupButtonTooltip": "現在選択された項目を {latestSelectionLabel} にグループ分けします", - "xpack.graph.sidebar.linkSummary.bothTermsCountTooltip": "{count} 件のドキュメントに両方の用語があります", - "xpack.graph.sidebar.linkSummary.leftTermCountTooltip": "{count} 件のドキュメントに {term} があります", - "xpack.graph.sidebar.linkSummary.mergeTerm1ToTerm2ButtonTooltip": "{term1} を {term2} に結合します", - "xpack.graph.sidebar.linkSummary.mergeTerm2ToTerm1ButtonTooltip": "{term2} を {term1} に結合します", - "xpack.graph.sidebar.linkSummary.rightTermCountTooltip": "{count} 件のドキュメントに {term} があります", - "xpack.graph.sidebar.linkSummaryTitle": "リンクの概要", - "xpack.graph.sidebar.selections.invertSelectionButtonLabel": "反転", - "xpack.graph.sidebar.selections.invertSelectionButtonTooltip": "選択を反転させます", - "xpack.graph.sidebar.selections.noSelectionsHelpText": "選択項目がありません。頂点をクリックして追加します。", - "xpack.graph.sidebar.selections.selectAllButtonLabel": "すべて", - "xpack.graph.sidebar.selections.selectAllButtonTooltip": "すべて選択", - "xpack.graph.sidebar.selections.selectNeighboursButtonLabel": "リンク", - "xpack.graph.sidebar.selections.selectNeighboursButtonTooltip": "隣を選択します", - "xpack.graph.sidebar.selections.selectNoneButtonLabel": "なし", - "xpack.graph.sidebar.selections.selectNoneButtonTooltip": "どれも選択しません", - "xpack.graph.sidebar.selectionsTitle": "選択項目", - "xpack.graph.sidebar.styleVerticesTitle": "スタイルが選択された頂点", - "xpack.graph.sidebar.topMenu.addLinksButtonTooltip": "既存の用語の間にリンクを追加します", - "xpack.graph.sidebar.topMenu.blacklistButtonTooltip": "選択項目がワークスペースに戻らないようブラックリストに追加します", - "xpack.graph.sidebar.topMenu.customStyleButtonTooltip": "選択された頂点のカスタムスタイル", - "xpack.graph.sidebar.topMenu.drillDownButtonTooltip": "ドリルダウン", - "xpack.graph.sidebar.topMenu.expandSelectionButtonTooltip": "選択項目を拡張", - "xpack.graph.sidebar.topMenu.pauseLayoutButtonTooltip": "レイアウトを一時停止", - "xpack.graph.sidebar.topMenu.redoButtonTooltip": "やり直す", - "xpack.graph.sidebar.topMenu.removeVerticesButtonTooltip": "ワークスペースから頂点を削除", - "xpack.graph.sidebar.topMenu.runLayoutButtonTooltip": "レイアウトを実行", - "xpack.graph.sidebar.topMenu.undoButtonTooltip": "元に戻す", - "xpack.graph.sidebar.ungroupButtonLabel": "グループ解除", - "xpack.graph.sidebar.ungroupButtonTooltip": "{latestSelectionLabel} のグループを解除", - "xpack.graph.topNavMenu.newWorkspaceAriaLabel": "新規ワークスペース", - "xpack.graph.topNavMenu.newWorkspaceLabel": "新規", - "xpack.graph.topNavMenu.newWorkspaceTooltip": "新規ワークスペースを作成します", - "xpack.graph.topNavMenu.save.descriptionInputLabel": "説明", - "xpack.graph.topNavMenu.save.saveConfigurationOnlyText": "このワークスペースのデータは消去され、構成のみが保存されます", - "xpack.graph.topNavMenu.save.saveConfigurationOnlyWarning": "このワークスペースのデータは消去され、構成のみが保存されます", - "xpack.graph.topNavMenu.save.saveGraphContentCheckboxLabel": "Graph コンテンツを保存", - "xpack.graph.topNavMenu.saveWorkspace.disabledTooltip": "現在の保存ポリシーでは、保存されたワークスペースへの変更が許可されていません", - "xpack.graph.topNavMenu.saveWorkspace.enabledAriaLabel": "ワークスペースを保存", - "xpack.graph.topNavMenu.saveWorkspace.enabledLabel": "保存", - "xpack.graph.topNavMenu.saveWorkspace.enabledTooltip": "このワークスペースを保存します", - "xpack.graph.topNavMenu.settingsAriaLabel": "設定", - "xpack.graph.topNavMenu.settingsLabel": "設定", - "xpack.graph.errorToastTitle": "Graph エラー", - "xpack.graph.bar.exploreLabel": "Graph", - "xpack.graph.bar.pickFieldsLabel": "フィールドを追加", - "xpack.graph.bar.pickSourceLabel": "データソースを選択", - "xpack.graph.bar.pickSourceTooltip": "グラフの関係性を開始するデータソースを選択します。", - "xpack.graph.bar.searchFieldPlaceholder": "データを検索してグラフに追加", - "xpack.graph.blacklist.noEntriesDescription": "ブロックされた用語がありません。頂点を選択して、右側のコントロールパネルの {stopSign} をクリックしてブロックします。ブロックされた用語に一致するドキュメントは今後表示されず、関係性が非表示になります。", - "xpack.graph.blacklist.removeButtonAriaLabel": "削除", - "xpack.graph.clearWorkspace.modalTitle": "保存されていない変更", - "xpack.graph.drilldowns.description": "ドリルダウンで他のアプリケーションにリンクします。選択された頂点が URL の一部になります。", - "xpack.graph.fieldManager.cancelLabel": "キャンセル", - "xpack.graph.fieldManager.colorLabel": "色", - "xpack.graph.fieldManager.deleteFieldLabel": "フィールドの選択を解除しました", - "xpack.graph.fieldManager.deleteFieldTooltipContent": "このフィールドの新規頂点は検出されなくなります。 既存の頂点はグラフに残されます。", - "xpack.graph.fieldManager.disabledFieldBadgeDescription": "無効なフィールド {field}:構成するにはクリックしてください。Shift+クリックで有効にします。", - "xpack.graph.fieldManager.disableFieldLabel": "フィールドを無効にする", - "xpack.graph.fieldManager.disableFieldTooltipContent": "このフィールドの頂点の検出をオフにします。フィールドを Shift+クリックしても無効にできます。", - "xpack.graph.fieldManager.enableFieldLabel": "フィールドを有効にする", - "xpack.graph.fieldManager.enableFieldTooltipContent": "このフィールドの頂点の検出をオンにします。フィールドを Shift+クリックしても有効にできます。", - "xpack.graph.fieldManager.fieldBadgeDescription": "フィールド {field}:構成するにはクリックしてください。Shift+クリックで無効にします", - "xpack.graph.fieldManager.fieldLabel": "フィールド", - "xpack.graph.fieldManager.fieldSearchPlaceholder": "フィルタリング条件:", - "xpack.graph.fieldManager.iconLabel": "アイコン", - "xpack.graph.fieldManager.maxTermsPerHopDescription": "各検索ステップで返されるアイテムの最大数をコントロールします。", - "xpack.graph.fieldManager.maxTermsPerHopLabel": "ホップごとの用語数", - "xpack.graph.fieldManager.settingsFormTitle": "編集", - "xpack.graph.fieldManager.settingsLabel": "設定の変更", - "xpack.graph.fieldManager.updateLabel": "変更を保存", - "xpack.graph.fillWorkspaceError": "トップアイテムの取得に失敗しました: {message}", - "xpack.graph.guidancePanel.datasourceItem.indexPatternButtonLabel": "データソースを選択", - "xpack.graph.guidancePanel.fieldsItem.fieldsButtonLabel": "フィールドを追加。", - "xpack.graph.guidancePanel.nodesItem.description": "閲覧を始めるには、検索バーにクエリを入力してください。どこから始めていいかわかりませんか?{topTerms}。", - "xpack.graph.guidancePanel.nodesItem.topTermsButtonLabel": "トップアイテムをグラフ化", - "xpack.graph.guidancePanel.title": "グラフ作成の 3 つのステップ", - "xpack.graph.icon.areaChart": "面グラフ", - "xpack.graph.icon.at": "に", - "xpack.graph.icon.automobile": "自動車", - "xpack.graph.icon.bank": "銀行", - "xpack.graph.icon.barChart": "棒グラフ", - "xpack.graph.icon.bolt": "ボルト", - "xpack.graph.icon.cube": "キューブ", - "xpack.graph.icon.desktop": "デスクトップ", - "xpack.graph.icon.exclamation": "感嘆符", - "xpack.graph.icon.externalLink": "外部リンク", - "xpack.graph.icon.eye": "目", - "xpack.graph.icon.file": "開いているファイル", - "xpack.graph.icon.fileText": "ファイル", - "xpack.graph.icon.flag": "旗", - "xpack.graph.icon.folderOpen": "開いているフォルダ", - "xpack.graph.icon.font": "フォント", - "xpack.graph.icon.globe": "球", - "xpack.graph.icon.google": "Google", - "xpack.graph.icon.heart": "ハート", - "xpack.graph.icon.home": "ホーム", - "xpack.graph.icon.industry": "業界", - "xpack.graph.icon.info": "情報", - "xpack.graph.icon.key": "キー", - "xpack.graph.icon.lineChart": "折れ線グラフ", - "xpack.graph.icon.list": "一覧", - "xpack.graph.icon.mapMarker": "マップマーカー", - "xpack.graph.icon.music": "音楽", - "xpack.graph.icon.phone": "電話", - "xpack.graph.icon.pieChart": "円グラフ", - "xpack.graph.icon.plane": "飛行機", - "xpack.graph.icon.question": "質問", - "xpack.graph.icon.shareAlt": "alt を共有", - "xpack.graph.icon.table": "表", - "xpack.graph.icon.tachometer": "タコメーター", - "xpack.graph.icon.user": "ユーザー", - "xpack.graph.icon.users": "ユーザー", - "xpack.graph.inspect.requestTabTitle": "リクエスト", - "xpack.graph.inspect.responseTabTitle": "応答", - "xpack.graph.inspect.title": "検査", - "xpack.graph.leaveWorkspace.confirmButtonLabel": "それでも移動", - "xpack.graph.leaveWorkspace.confirmText": "今移動すると、保存されていない変更が失われます。", - "xpack.graph.leaveWorkspace.modalTitle": "保存されていない変更", - "xpack.graph.listing.createNewGraph.combineDataViewFromKibanaAppDescription": "Elasticsearch インデックスのパターンと関係性を検出します。", - "xpack.graph.listing.createNewGraph.createButtonLabel": "グラフを作成", - "xpack.graph.listing.createNewGraph.newToKibanaDescription": "Kibana は初めてですか?{sampleDataInstallLink} で始めましょう。", - "xpack.graph.listing.createNewGraph.sampleDataInstallLinkText": "サンプルデータ", - "xpack.graph.listing.createNewGraph.title": "初めてのグラフを作成してみましょう。", - "xpack.graph.listing.graphsTitle": "グラフ", - "xpack.graph.listing.noDataSource.newToKibanaDescription": "Kibana は初めてですか?{sampleDataInstallLink} も使用できます。", - "xpack.graph.listing.noDataSource.sampleDataInstallLinkText": "サンプルデータ", - "xpack.graph.listing.noItemsMessage": "グラフがないようです。", - "xpack.graph.listing.table.descriptionColumnName": "説明", - "xpack.graph.listing.table.entityName": "グラフ", - "xpack.graph.listing.table.entityNamePlural": "グラフ", - "xpack.graph.listing.table.titleColumnName": "タイトル", - "xpack.graph.newGraphTitle": "保存されていないグラフ", - "xpack.graph.outlinkEncoders.kqlLooseDescription": "KQL クエリ、ディスカバリ、可視化、ダッシュボードに対応", - "xpack.graph.outlinkEncoders.kqlLooseTitle": "KQL OR クエリ", - "xpack.graph.outlinkEncoders.kqlTitle": "KQL AND クエリ", - "xpack.graph.saveWorkspace.savingErrorMessage": "ワークスペースの保存に失敗しました: {message}", - "xpack.graph.settings.advancedSettings.timeoutUnit": "ms", - "xpack.graph.settings.closeLabel": "閉じる", - "xpack.graph.settings.drillDowns.cancelButtonLabel": "キャンセル", - "xpack.graph.settings.drillDowns.kibanaUrlWarningConvertOptionLinkText": "変換する。", - "xpack.graph.settings.drillDowns.newSaveButtonLabel": "ドリルダウンを保存", - "xpack.graph.settings.drillDowns.removeButtonLabel": "削除", - "xpack.graph.settings.drillDowns.updateSaveButtonLabel": "ドリルダウンを更新", - "xpack.graph.settings.title": "設定", - "xpack.graph.sourceModal.notFoundLabel": "データソースが見つかりませんでした。", - "xpack.graph.sourceModal.savedObjectType.indexPattern": "インデックスパターン", - "xpack.graph.sourceModal.title": "データソースを選択", - "xpack.graph.templates.addLabel": "新規ドリルダウン", - "xpack.graph.templates.newTemplateFormLabel": "ドリルダウンを追加", - "xpack.graph.topNavMenu.inspectAriaLabel": "検査", - "xpack.graph.topNavMenu.inspectLabel": "検査", - "xpack.graph.topNavMenu.save.objectType": "グラフ", - "xpack.graph.clearWorkspace.confirmButtonLabel": "データソースを変更", - "xpack.graph.clearWorkspace.confirmText": "データソースを変更すると、現在のフィールドと頂点がリセットされます。", - "xpack.graph.loadWorkspace.missingIndexPatternErrorMessage": "インデックスパターンが見つかりませんでした", - "xpack.graph.noDataSourceNotificationMessageText": "データソースが見つかりませんでした。{managementIndexPatternsLink} に移動して Elasticsearch インデックスのインデックスパターンを作成してください。", - "xpack.grokDebugger.customPatterns.callOutTitle": "1 行に付き 1 つのカスタムパターンを入力してください例:", - "xpack.grokDebugger.customPatternsButtonLabel": "カスタムパターン", - "xpack.grokDebugger.displayName": "Grok デバッガー", - "xpack.grokDebugger.grokPatternLabel": "Grok パターン", - "xpack.grokDebugger.licenseHasExpiredMessage": "{licenseType} ライセンスが期限切れのため {grokLogParsingTool} デバッガーを使用できません", - "xpack.grokDebugger.patternsErrorMessage": "提供された {grokLogParsingTool} パターンがインプットのデータと一致していません", - "xpack.grokDebugger.registryProviderDescription": "{grokLogParsingTool} パターンを、投入時にデータ変換用にシミュレートしデバッグします。", - "xpack.grokDebugger.registryProviderTitle": "{grokLogParsingTool} デバッガー", - "xpack.grokDebugger.sampleDataLabel": "サンプルデータ", - "xpack.grokDebugger.simulateButtonLabel": "シミュレート", - "xpack.grokDebugger.structuredDataLabel": "構造化データ", - "xpack.grokDebugger.unavailableLicenseInformationMessage": "現在ライセンス情報が利用できないため {grokLogParsingTool} デバッガーを使用できません。", - "xpack.idxMgmt.appTitle": "インデックス管理", - "xpack.idxMgmt.badgeAriaLabel": "{label}。これをフィルタリングするよう選択。", - "xpack.idxMgmt.clearCacheIndicesAction.successMessage": "キャッシュ [{indexNames}] が削除されました:", - "xpack.idxMgmt.closeIndicesAction.successfullyClosedIndicesMessage": "[{indexNames}] がクローズされました", - "xpack.idxMgmt.deleteIndicesAction.successfullyDeletedIndicesMessage": "[{indexNames}] が削除されました", - "xpack.idxMgmt.detailPanel.manageContextMenuLabel": "管理", - "xpack.idxMgmt.detailPanel.missingIndexMessage": "このインデックスは存在しません。実行中のジョブや別のシステムにより削除された可能性があります。", - "xpack.idxMgmt.detailPanel.missingIndexTitle": "インデックスがありません", - "xpack.idxMgmt.detailPanel.tabEditSettingsLabel": "設定の変更", - "xpack.idxMgmt.detailPanel.tabMappingLabel": "マッピング", - "xpack.idxMgmt.detailPanel.tabSettingsLabel": "設定", - "xpack.idxMgmt.detailPanel.tabStatsLabel": "統計", - "xpack.idxMgmt.detailPanel.tabSummaryLabel": "まとめ", - "xpack.idxMgmt.editIndexSettingsAction.successfullySavedSettingsForIndicesMessage": "{indexName} の設定が保存されました", - "xpack.idxMgmt.editSettingsJSON.saveJSONButtonLabel": "保存", - "xpack.idxMgmt.editSettingsJSON.saveJSONDescription": "変更して JSON を保存します", - "xpack.idxMgmt.editSettingsJSON.settingsReferenceLinkText": "設定レファレンス", - "xpack.idxMgmt.flushIndicesAction.successfullyFlushedIndicesMessage": "[{indexNames}] がフラッシュされました", - "xpack.idxMgmt.forceMergeIndicesAction.successfullyForceMergedIndicesMessage": "[{indexNames}] が強制結合されました", - "xpack.idxMgmt.freezeIndicesAction.successfullyFrozeIndicesMessage": "[{indexNames}] が凍結されました", - "xpack.idxMgmt.frozenBadgeLabel": "凍結", - "xpack.idxMgmt.indexActionsMenu.clearIndexCacheLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }のキャッシュを消去", - "xpack.idxMgmt.indexActionsMenu.closeIndexLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }を閉じる", - "xpack.idxMgmt.indexActionsMenu.deleteIndex.confirmModal.cancelButtonText": "キャンセル", - "xpack.idxMgmt.indexActionsMenu.deleteIndex.confirmModal.modalTitle": "{selectedIndexCount, plural, one {インデックス} other {インデックス} } の削除の確認", - "xpack.idxMgmt.indexActionsMenu.deleteIndex.deleteDescription": "{selectedIndexCount, plural, one {このインデックス} other {これらのインデックス} }を削除しようとしています:", - "xpack.idxMgmt.indexActionsMenu.deleteIndex.deleteWarningDescription": "この操作は元に戻すことができません。適切なバックアップがあることを確認してください。", - "xpack.idxMgmt.indexActionsMenu.deleteIndex.proceedWithCautionCallOutTitle": "十分ご注意ください!", - "xpack.idxMgmt.indexActionsMenu.deleteIndexLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }を削除", - "xpack.idxMgmt.indexActionsMenu.editIndexSettingsLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }の設定を編集", - "xpack.idxMgmt.indexActionsMenu.flushIndexLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }をフラッシュ", - "xpack.idxMgmt.indexActionsMenu.forceMerge.confirmModal.cancelButtonText": "キャンセル", - "xpack.idxMgmt.indexActionsMenu.forceMerge.confirmModal.confirmButtonText": "強制結合", - "xpack.idxMgmt.indexActionsMenu.forceMerge.confirmModal.modalTitle": "強制結合", - "xpack.idxMgmt.indexActionsMenu.forceMerge.forceMergeDescription": "{selectedIndexCount, plural, one {このインデックス} other {これらのインデックス} }を強制結合しようとしています:", - "xpack.idxMgmt.indexActionsMenu.forceMerge.forceMergeSegmentsHelpText": "セグメントがこの数以下になるまでインデックスのセグメントを結合します。デフォルトは 1 です。", - "xpack.idxMgmt.indexActionsMenu.forceMerge.forceMergeWarningDescription": " 大きなインデックスや読み取り専用ではないインデックスの強制結合は、適切に実行 (読み取り専用ではないインデックスに対して実行) されないと、クラスターでパフォーマンスや安定性の問題を引き起こす可能性があります。", - "xpack.idxMgmt.indexActionsMenu.forceMerge.maximumNumberOfSegmentsFormRowLabel": "シャードごとの最大セグメント数", - "xpack.idxMgmt.indexActionsMenu.forceMerge.proceedWithCautionCallOutTitle": "十分ご注意ください!", - "xpack.idxMgmt.indexActionsMenu.forceMergeIndexLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }を強制結合", - "xpack.idxMgmt.indexActionsMenu.freezeEntity.confirmModal.cancelButtonText": "キャンセル", - "xpack.idxMgmt.indexActionsMenu.freezeEntity.freezeEntityWarningDescription": " 凍結されたインデックスはクラスターにほとんどオーバーヘッドがなく、書き込みオペレーションがブロックされます。凍結されたインデックスは検索できますが、クエリが遅くなります。", - "xpack.idxMgmt.indexActionsMenu.freezeEntity.proceedWithCautionCallOutTitle": "十分ご注意ください", - "xpack.idxMgmt.indexActionsMenu.freezeIndexLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }を凍結", - "xpack.idxMgmt.indexActionsMenu.manageButtonAriaLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }オプション", - "xpack.idxMgmt.indexActionsMenu.manageButtonLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス}}の管理", - "xpack.idxMgmt.indexActionsMenu.openIndexLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }を開く", - "xpack.idxMgmt.indexActionsMenu.panelTitle": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }オプション", - "xpack.idxMgmt.indexActionsMenu.refreshIndexLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }を更新", - "xpack.idxMgmt.indexActionsMenu.segmentsNumberErrorMessage": "セグメント数は 0 より大きい値である必要があります。", - "xpack.idxMgmt.indexActionsMenu.showIndexMappingLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }のマッピングを表示", - "xpack.idxMgmt.indexActionsMenu.showIndexSettingsLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }の設定を表示", - "xpack.idxMgmt.indexActionsMenu.showIndexStatsLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }の統計を表示", - "xpack.idxMgmt.indexActionsMenu.unfreezeIndexLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }の凍結を解除", - "xpack.idxMgmt.indexStatusLabels.clearingCacheStatusLabel": "キャッシュを消去中...", - "xpack.idxMgmt.indexStatusLabels.closedStatusLabel": "クローズ済み", - "xpack.idxMgmt.indexStatusLabels.closingStatusLabel": "クローズ中...", - "xpack.idxMgmt.indexStatusLabels.flushingStatusLabel": "フラッシュ中...", - "xpack.idxMgmt.indexStatusLabels.forcingMergeStatusLabel": "強制結合中...", - "xpack.idxMgmt.indexStatusLabels.mergingStatusLabel": "結合中...", - "xpack.idxMgmt.indexStatusLabels.openingStatusLabel": "開いています...", - "xpack.idxMgmt.indexStatusLabels.refreshingStatusLabel": "更新中...", - "xpack.idxMgmt.indexTable.headers.documentsHeader": "ドキュメント数", - "xpack.idxMgmt.indexTable.headers.healthHeader": "ヘルス", - "xpack.idxMgmt.indexTable.headers.nameHeader": "名前", - "xpack.idxMgmt.indexTable.headers.primaryHeader": "プライマリ", - "xpack.idxMgmt.indexTable.headers.replicaHeader": "複製", - "xpack.idxMgmt.indexTable.headers.statusHeader": "ステータス", - "xpack.idxMgmt.indexTable.headers.storageSizeHeader": "ストレージサイズ", - "xpack.idxMgmt.indexTable.invalidSearchErrorMessage": "無効な検索: {errorMessage}", - "xpack.idxMgmt.indexTable.reloadIndicesButton": "インデックスを再読み込み", - "xpack.idxMgmt.indexTable.serverErrorTitle": "インデックスの読み込み中にエラーが発生", - "xpack.idxMgmt.indexTable.systemIndicesSearchIndicesAriaLabel": "インデックスの検索", - "xpack.idxMgmt.indexTable.systemIndicesSearchInputPlaceholder": "検索", - "xpack.idxMgmt.indexTable.systemIndicesSwitchLabel": "システムインデックスを含める", - "xpack.idxMgmt.noMatch.noIndicesDescription": "表示するインデックスがありません", - "xpack.idxMgmt.openIndicesAction.successfullyOpenedIndicesMessage": "[{indexNames}] が開かれました", - "xpack.idxMgmt.pageErrorForbidden.title": "インデックス管理を使用するパーミッションがありません", - "xpack.idxMgmt.refreshIndicesAction.successfullyRefreshedIndicesMessage": "[{indexNames}] が更新されました", - "xpack.idxMgmt.reloadIndicesAction.indicesPageRefreshFailureMessage": "現在のインデックスページの更新に失敗しました。", - "xpack.idxMgmt.summary.headers.aliases": "エイリアス", - "xpack.idxMgmt.summary.headers.deletedDocumentsHeader": "ドキュメントが削除されました", - "xpack.idxMgmt.summary.headers.documentsHeader": "ドキュメント数", - "xpack.idxMgmt.summary.headers.healthHeader": "ヘルス", - "xpack.idxMgmt.summary.headers.primaryHeader": "プライマリ", - "xpack.idxMgmt.summary.headers.primaryStorageSizeHeader": "プライマリストレージサイズ", - "xpack.idxMgmt.summary.headers.replicaHeader": "複製", - "xpack.idxMgmt.summary.headers.statusHeader": "ステータス", - "xpack.idxMgmt.summary.headers.storageSizeHeader": "ストレージサイズ", - "xpack.idxMgmt.summary.summaryTitle": "一般", - "xpack.idxMgmt.unfreezeIndicesAction.successfullyUnfrozeIndicesMessage": "[{indexNames}] の凍結が解除されました", - "xpack.idxMgmt.updateIndexSettingsAction.settingsSuccessUpdateMessage": "インデックス {indexName} の設定が更新されました", - "xpack.idxMgmt.breadcrumb.cloneTemplateLabel": "テンプレートのクローンを作成", - "xpack.idxMgmt.breadcrumb.createTemplateLabel": "テンプレートを作成", - "xpack.idxMgmt.breadcrumb.editTemplateLabel": "テンプレートを編集", - "xpack.idxMgmt.breadcrumb.homeLabel": "インデックス管理", - "xpack.idxMgmt.breadcrumb.templatesLabel": "テンプレート", - "xpack.idxMgmt.createRoute.duplicateTemplateIdErrorMessage": "「{name}」という名前のテンプレートが既に存在します。", - "xpack.idxMgmt.createTemplate.cloneTemplatePageTitle": "テンプレート「{name}」のクローンの作成", - "xpack.idxMgmt.createTemplate.createTemplatePageTitle": "テンプレートを作成", - "xpack.idxMgmt.deleteTemplatesModal.cancelButtonLabel": "キャンセル", - "xpack.idxMgmt.deleteTemplatesModal.confirmButtonLabel": "{numTemplatesToDelete, plural, one {テンプレート} other {テンプレート} }を削除", - "xpack.idxMgmt.deleteTemplatesModal.confirmDeleteCheckboxLabel": "システムテンプレートを削除することの重大な影響を理解しています", - "xpack.idxMgmt.deleteTemplatesModal.deleteDescription": "{numTemplatesToDelete, plural, one {このテンプレート} other {これらのテンプレート} }を削除しようとしています:", - "xpack.idxMgmt.deleteTemplatesModal.errorNotificationMessageText": "テンプレート「{name}」の削除中にエラーが発生", - "xpack.idxMgmt.deleteTemplatesModal.modalTitleText": "{numTemplatesToDelete, plural, one {テンプレート} other {テンプレート}}の削除", - "xpack.idxMgmt.deleteTemplatesModal.multipleErrorsNotificationMessageText": "{count} 個のテンプレートの削除中にエラーが発生", - "xpack.idxMgmt.deleteTemplatesModal.proceedWithCautionCallOutDescription": "システムテンプレートは内部オペレーションに不可欠です。このテンプレートを削除すると、復元することはできません。", - "xpack.idxMgmt.deleteTemplatesModal.proceedWithCautionCallOutTitle": "システムテンプレートを削除することで、Kibana に重大な障害が生じる可能性があります", - "xpack.idxMgmt.deleteTemplatesModal.successDeleteMultipleNotificationMessageText": "{numSuccesses, plural, one {テンプレート} other {テンプレート}}を削除しました", - "xpack.idxMgmt.deleteTemplatesModal.successDeleteSingleNotificationMessageText": "テンプレート「{templateName}」を削除しました", - "xpack.idxMgmt.deleteTemplatesModal.systemTemplateLabel": "システムテンプレート", - "xpack.idxMgmt.editTemplate.editTemplatePageTitle": "テンプレート「{name}」を編集", - "xpack.idxMgmt.home.appTitle": "インデックス管理", - "xpack.idxMgmt.home.idxMgmtDescription": "Elasticsearch インデックスを個々に、または一斉に更新します", - "xpack.idxMgmt.home.idxMgmtDocsLinkText": "インデックス管理ドキュメント", - "xpack.idxMgmt.home.indexTemplatesDescription": "テンプレートを使用して設定、マッピング、エイリアスをインデックスに自動的に適用します。", - "xpack.idxMgmt.home.indexTemplatesTabTitle": "インデックステンプレート", - "xpack.idxMgmt.home.indicesTabTitle": "インデックス", - "xpack.idxMgmt.indexTemplatesList.emptyPrompt.noIndexTemplatesTitle": "まだテンプレートがありません", - "xpack.idxMgmt.indexTemplatesList.loadingIndexTemplatesDescription": "テンプレートを読み込み中…", - "xpack.idxMgmt.indexTemplatesList.loadingIndexTemplatesErrorMessage": "テンプレートの読み込み中にエラーが発生", - "xpack.idxMgmt.indexTemplatesTable.systemIndexTemplatesSwitchLabel": "システムテンプレートを含める", - "xpack.idxMgmt.mappingsEditor.formatError": "JSON フォーマットエラー", - "xpack.idxMgmt.mappingsEditor.mappingsEditorAriaLabel": "インデックスマッピングエディター", - "xpack.idxMgmt.templateCreate.loadingTemplateToCloneDescription": "クローンを作成するテンプレートを読み込み中…", - "xpack.idxMgmt.templateCreate.loadingTemplateToCloneErrorMessage": "クローンを作成するテンプレートを読み込み中にエラーが発生", - "xpack.idxMgmt.templateDetails.aliasesTab.noAliasesTitle": "エイリアスが定義されていません。", - "xpack.idxMgmt.templateDetails.aliasesTabTitle": "エイリアス", - "xpack.idxMgmt.templateDetails.cloneButtonLabel": "クローンを作成", - "xpack.idxMgmt.templateDetails.closeButtonLabel": "閉じる", - "xpack.idxMgmt.templateDetails.deleteButtonLabel": "削除", - "xpack.idxMgmt.templateDetails.editButtonLabel": "編集", - "xpack.idxMgmt.templateDetails.loadingIndexTemplateDescription": "テンプレートを読み込み中…", - "xpack.idxMgmt.templateDetails.loadingIndexTemplateErrorMessage": "テンプレートの読み込み中にエラーが発生", - "xpack.idxMgmt.templateDetails.manageButtonLabel": "管理", - "xpack.idxMgmt.templateDetails.manageContextMenuPanelTitle": "テンプレートオプション", - "xpack.idxMgmt.templateDetails.managedTemplateInfoDescription": "マネージドテンプレートは内部オペレーションに不可欠です。", - "xpack.idxMgmt.templateDetails.managedTemplateInfoTitle": "マネジドテンプレートの編集は許可されていません。", - "xpack.idxMgmt.templateDetails.mappingsTab.noMappingsTitle": "マッピングが定義されていません。", - "xpack.idxMgmt.templateDetails.mappingsTabTitle": "マッピング", - "xpack.idxMgmt.templateDetails.settingsTab.noSettingsTitle": "設定が定義されていません。", - "xpack.idxMgmt.templateDetails.settingsTabTitle": "設定", - "xpack.idxMgmt.templateDetails.summaryTab.ilmPolicyDescriptionListTitle": "ILM ポリシー", - "xpack.idxMgmt.templateDetails.summaryTab.indexPatternsDescriptionListTitle": "インデックス{numIndexPatterns, plural, one {パターン} other {パターン}}", - "xpack.idxMgmt.templateDetails.summaryTab.noneDescriptionText": "なし", - "xpack.idxMgmt.templateDetails.summaryTab.orderDescriptionListTitle": "順序", - "xpack.idxMgmt.templateDetails.summaryTab.versionDescriptionListTitle": "バージョン", - "xpack.idxMgmt.templateDetails.summaryTabTitle": "まとめ", - "xpack.idxMgmt.templateEdit.loadingIndexTemplateDescription": "テンプレートを読み込み中…", - "xpack.idxMgmt.templateEdit.loadingIndexTemplateErrorMessage": "テンプレートの読み込み中にエラーが発生", - "xpack.idxMgmt.templateEdit.managedTemplateWarningDescription": "管理されているテンプレートは内部オペレーションに不可欠です。", - "xpack.idxMgmt.templateEdit.managedTemplateWarningTitle": "マネジドテンプレートの編集は許可されていません。", - "xpack.idxMgmt.templateEdit.systemTemplateWarningDescription": "システムテンプレートは内部オペレーションに不可欠です。", - "xpack.idxMgmt.templateEdit.systemTemplateWarningTitle": "システムテンプレートを編集することで、Kibana に重大な障害が生じる可能性があります", - "xpack.idxMgmt.templateForm.backButtonLabel": "戻る", - "xpack.idxMgmt.templateForm.createButtonLabel": "テンプレートを作成", - "xpack.idxMgmt.templateForm.nextButtonLabel": "次へ", - "xpack.idxMgmt.templateForm.saveButtonLabel": "テンプレートを保存", - "xpack.idxMgmt.templateForm.saveTemplateError": "テンプレートを作成できません", - "xpack.idxMgmt.templateForm.savingButtonLabel": "保存中…", - "xpack.idxMgmt.templateForm.stepAliases.aliasesDescription": "エイリアスをセットアップして、インデックスに関連付けてください。", - "xpack.idxMgmt.templateForm.stepAliases.aliasesEditorHelpText": "JSON フォーマットを使用: {code}", - "xpack.idxMgmt.templateForm.stepAliases.docsButtonLabel": "インデックステンプレートドキュメント", - "xpack.idxMgmt.templateForm.stepAliases.fieldAliasesAriaLabel": "エイリアスコードエディター", - "xpack.idxMgmt.templateForm.stepAliases.fieldAliasesLabel": "エイリアス", - "xpack.idxMgmt.templateForm.stepAliases.stepTitle": "エイリアス (任意)", - "xpack.idxMgmt.templateForm.stepLogistics.docsButtonLabel": "インデックステンプレートドキュメント", - "xpack.idxMgmt.templateForm.stepLogistics.fieldIndexPatternsHelpText": "スペースと {invalidCharactersList} は使用できません。", - "xpack.idxMgmt.templateForm.stepLogistics.fieldIndexPatternsLabel": "インデックスパターン", - "xpack.idxMgmt.templateForm.stepLogistics.fieldNameLabel": "名前", - "xpack.idxMgmt.templateForm.stepLogistics.fieldOrderLabel": "その他 (任意)", - "xpack.idxMgmt.templateForm.stepLogistics.fieldVersionLabel": "バージョン (任意)", - "xpack.idxMgmt.templateForm.stepLogistics.indexPatternsDescription": "テンプレートに適用するインデックスパターンです。", - "xpack.idxMgmt.templateForm.stepLogistics.indexPatternsTitle": "インデックスパターン", - "xpack.idxMgmt.templateForm.stepLogistics.nameDescription": "このテンプレートの固有の識別子です。", - "xpack.idxMgmt.templateForm.stepLogistics.nameTitle": "名前", - "xpack.idxMgmt.templateForm.stepLogistics.orderDescription": "複数テンプレートがインデックスと一致した場合の結合順序です。", - "xpack.idxMgmt.templateForm.stepLogistics.orderTitle": "結合順序", - "xpack.idxMgmt.templateForm.stepLogistics.stepTitle": "ロジスティクス", - "xpack.idxMgmt.templateForm.stepLogistics.versionDescription": "テンプレートを外部管理システムで識別するための番号です。", - "xpack.idxMgmt.templateForm.stepLogistics.versionTitle": "バージョン", - "xpack.idxMgmt.templateForm.stepMappings.docsButtonLabel": "マッピングドキュメント", - "xpack.idxMgmt.templateForm.stepMappings.fieldMappingsAriaLabel": "マッピングエディター", - "xpack.idxMgmt.templateForm.stepMappings.fieldMappingsLabel": "マッピング", - "xpack.idxMgmt.templateForm.stepMappings.mappingsDescription": "ドキュメントの保存とインデックス方法を定義します。", - "xpack.idxMgmt.templateForm.stepMappings.mappingsEditorHelpText": "JSON フォーマットを使用: {code}", - "xpack.idxMgmt.templateForm.stepMappings.stepTitle": "マッピング (任意)", - "xpack.idxMgmt.templateForm.stepReview.requestTab.descriptionText": "このリクエストは次のインデックステンプレートを作成します。", - "xpack.idxMgmt.templateForm.stepReview.requestTabTitle": "リクエスト", - "xpack.idxMgmt.templateForm.stepReview.stepTitle": "「{templateName}」の詳細の確認", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.aliasesLabel": "エイリアス", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.indexPatternsLabel": "インデックス{numIndexPatterns, plural, one {パターン} other {パターン}}", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.indexPatternsWarningDescription": "作成するすべての新規インデックスにこのテンプレートが使用されます。", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.indexPatternsWarningLinkText": "インデックスパターンの編集。", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.indexPatternsWarningTitle": "このテンプレートはワイルドカード (*) をインデックスパターンとして使用します。", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.mappingLabel": "マッピング", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.noDescriptionText": "いいえ", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.noneDescriptionText": "なし", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.orderLabel": "順序", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.settingsLabel": "インデックス設定", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.versionLabel": "バージョン", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.yesDescriptionText": "はい", - "xpack.idxMgmt.templateForm.stepReview.summaryTabTitle": "まとめ", - "xpack.idxMgmt.templateForm.steps.aliasesStepName": "エイリアス", - "xpack.idxMgmt.templateForm.steps.logisticsStepName": "ロジスティクス", - "xpack.idxMgmt.templateForm.steps.mappingsStepName": "マッピング", - "xpack.idxMgmt.templateForm.steps.settingsStepName": "インデックス設定", - "xpack.idxMgmt.templateForm.steps.summaryStepName": "テンプレートのレビュー", - "xpack.idxMgmt.templateForm.stepSettings.docsButtonLabel": "インデックス設定ドキュメント", - "xpack.idxMgmt.templateForm.stepSettings.fieldIndexSettingsAriaLabel": "インデックス設定エディター", - "xpack.idxMgmt.templateForm.stepSettings.fieldIndexSettingsLabel": "インデックス設定", - "xpack.idxMgmt.templateForm.stepSettings.settingsDescription": "インデックスの動作を定義します。", - "xpack.idxMgmt.templateForm.stepSettings.settingsEditorHelpText": "JSON フォーマットを使用: {code}", - "xpack.idxMgmt.templateForm.stepSettings.stepTitle": "インデックス設定 (任意)", - "xpack.idxMgmt.templateList.table.actionCloneDescription": "このテンプレートのクローンを作成します", - "xpack.idxMgmt.templateList.table.actionCloneTitle": "クローンを作成", - "xpack.idxMgmt.templateList.table.actionColumnTitle": "アクション", - "xpack.idxMgmt.templateList.table.actionDeleteDecription": "このテンプレートを削除します", - "xpack.idxMgmt.templateList.table.actionDeleteText": "削除", - "xpack.idxMgmt.templateList.table.actionEditDecription": "このテンプレートを編集します", - "xpack.idxMgmt.templateList.table.actionEditText": "編集", - "xpack.idxMgmt.templateList.table.aliasesColumnTitle": "エイリアス", - "xpack.idxMgmt.templateList.table.createTemplatesButtonLabel": "テンプレートを作成", - "xpack.idxMgmt.templateList.table.deleteManagedTemplateTooltip": "管理されているテンプレートは削除できません。", - "xpack.idxMgmt.templateList.table.deleteTemplatesButtonLabel": "{count, plural, one {テンプレート} other {テンプレート} }を削除", - "xpack.idxMgmt.templateList.table.ilmPolicyColumnDescription": "インデックスライフサイクルポリシー「{policyName}」", - "xpack.idxMgmt.templateList.table.ilmPolicyColumnTitle": "ILM ポリシー", - "xpack.idxMgmt.templateList.table.indexPatternsColumnTitle": "インデックスパターン", - "xpack.idxMgmt.templateList.table.mappingsColumnTitle": "マッピング", - "xpack.idxMgmt.templateList.table.nameColumnTitle": "名前", - "xpack.idxMgmt.templateList.table.noIndexTemplatesMessage": "テンプレートが見つかりませんでした", - "xpack.idxMgmt.templateList.table.orderColumnTitle": "順序", - "xpack.idxMgmt.templateList.table.reloadTemplatesButtonLabel": "再読み込み", - "xpack.idxMgmt.templateList.table.settingsColumnTitle": "設定", - "xpack.idxMgmt.templateValidation.indexPatternsRequiredError": "インデックスパターンが最低 1 つ必要です。", - "xpack.idxMgmt.templateValidation.templateNameInvalidaCharacterError": "テンプレート名に「{invalidChar}」は使用できません", - "xpack.idxMgmt.templateValidation.templateNamePeriodError": "テンプレート名はピリオドで始めることはできません。", - "xpack.idxMgmt.templateValidation.templateNameRequiredError": "テンプレート名が必要です。", - "xpack.idxMgmt.templateValidation.templateNameSpacesError": "テンプレート名にスペースは使用できません。", - "xpack.idxMgmt.templateValidation.templateNameUnderscoreError": "テンプレート名はアンダーラインで始めることはできません。", - "xpack.idxMgmt.indexTable.captionText": "以下は {total} 列中 {count, plural, one {# 列} other {# 列}} を含むインデックス表です。", - "xpack.idxMgmt.indexTable.selectAllIndicesAriaLabel": "すべての行を選択", - "xpack.idxMgmt.indexTable.selectIndexAriaLabel": "この行を選択", - "xpack.idxMgmt.validators.string.invalidJSONError": "無効な JSON フォーマット。", - "xpack.idxMgmt.indexActionsMenu.closeIndex.systemIndexLabel": "システムインデックス", - "xpack.idxMgmt.indexActionsMenu.deleteIndex.proceedWithCautionCallOutDescription": "システムインデックスは内部オペレーションに不可欠です。システムインデックスを削除すると、復元することはできません。適切なバックアップがあることを確認してください。", - "xpack.idxMgmt.indexActionsMenu.deleteIndex.systemIndexLabel": "システムインデックス", - "xpack.indexLifecycleMgmt.activePhaseMessage": "アクティブ", - "xpack.indexLifecycleMgmt.addLifecyclePolicyActionButtonLabel": "ライフサイクルポリシーを追加", - "xpack.indexLifecycleMgmt.appTitle": "インデックスライフサイクルポリシー", - "xpack.indexLifecycleMgmt.checkLicense.errorExpiredMessage": "{licenseType} ライセンスが期限切れのため {pluginName} を使用できません。", - "xpack.indexLifecycleMgmt.checkLicense.errorUnavailableMessage": "現在ライセンス情報が利用できないため {pluginName} を使用できません。", - "xpack.indexLifecycleMgmt.checkLicense.errorUnsupportedMessage": "ご使用の {licenseType} ライセンスは {pluginName} をサポートしていません。ライセンスをアップグレードしてください。", - "xpack.indexLifecycleMgmt.coldPhase.freezeIndexLabel": "インデックスを凍結", - "xpack.indexLifecycleMgmt.coldPhase.numberOfReplicasLabel": "複製の数", - "xpack.indexLifecycleMgmt.coldPhase.replicaCountHelpText": "デフォルトで、複製の数は同じままになります。", - "xpack.indexLifecycleMgmt.confirmDelete.cancelButton": "キャンセル", - "xpack.indexLifecycleMgmt.confirmDelete.deleteButton": "削除", - "xpack.indexLifecycleMgmt.confirmDelete.errorMessage": "ポリシー {policyName} の削除中にエラーが発生しました", - "xpack.indexLifecycleMgmt.confirmDelete.successMessage": "ポリシー {policyName} が削除されました", - "xpack.indexLifecycleMgmt.confirmDelete.title": "ポリシー「{name}」が削除されました", - "xpack.indexLifecycleMgmt.confirmDelete.undoneWarning": "削除されたポリシーは復元できません。", - "xpack.indexLifecycleMgmt.editPolicy.cancelButton": "キャンセル", - "xpack.indexLifecycleMgmt.editPolicy.coldPhase.activateWarmPhaseSwitchLabel": "コールドフェーズを有効にする", - "xpack.indexLifecycleMgmt.editPolicy.coldPhase.coldPhaseDescriptionText": "インデックスへのクエリの頻度を減らすことで、大幅に性能が低いハードウェアにシャードを割り当てることができます。クエリが遅いため、複製の数を減らすことができます。", - "xpack.indexLifecycleMgmt.editPolicy.coldPhase.coldPhaseLabel": "コールドフェーズ", - "xpack.indexLifecycleMgmt.editPolicy.coldPhase.freezeIndexExplanationText": "凍結されたインデックスはクラスターにほとんどオーバーヘッドがなく、書き込みオペレーションがブロックされます。凍結されたインデックスは検索できますが、クエリが遅くなります。", - "xpack.indexLifecycleMgmt.editPolicy.coldPhase.freezeText": "凍結", - "xpack.indexLifecycleMgmt.editPolicy.createdMessage": "作成されました", - "xpack.indexLifecycleMgmt.editPolicy.createPolicyMessage": "インデックスライフサイクルポリシーを作成します", - "xpack.indexLifecycleMgmt.editPolicy.creationDaysOptionLabel": "インデックスの作成からの経過日数", - "xpack.indexLifecycleMgmt.editPolicy.creationHoursOptionLabel": "インデックスの作成からの経過時間数", - "xpack.indexLifecycleMgmt.editPolicy.deletePhase.activateWarmPhaseSwitchLabel": "削除フェーズを有効にする", - "xpack.indexLifecycleMgmt.editPolicy.deletePhase.deletePhaseDescriptionText": "今後インデックスは必要ありません。 いつ安全に削除できるかを定義できます。", - "xpack.indexLifecycleMgmt.editPolicy.deletePhase.deletePhaseLabel": "削除フェーズ", - "xpack.indexLifecycleMgmt.editPolicy.differentPolicyNameRequiredError": "ポリシー名は異なるものである必要があります。", - "xpack.indexLifecycleMgmt.editPolicy.editingExistingPolicyExplanationMessage": "すべての変更はこのポリシーに関連付けられているインデックスに影響を及ぼします。代わりに、これらの変更を新規ポリシーに保存することもできます。", - "xpack.indexLifecycleMgmt.editPolicy.editingExistingPolicyMessage": "既存のポリシーを編集しています", - "xpack.indexLifecycleMgmt.editPolicy.editPolicyMessage": "インデックスライフサイクルポリシー {originalPolicyName} を編集します", - "xpack.indexLifecycleMgmt.editPolicy.formErrorsMessage": "このページのエラーを修正してください。", - "xpack.indexLifecycleMgmt.editPolicy.hotPhase.hotPhaseDescriptionMessage": "このフェーズは必須です。アクティブにクエリを実行しインデックスに書き込んでいます。 更新を高速化するため、大きくなりすぎたり古くなりすぎたりした際にインデックスをロールオーバーできます。", - "xpack.indexLifecycleMgmt.editPolicy.hotPhase.hotPhaseLabel": "ホットフェーズ", - "xpack.indexLifecycleMgmt.editPolicy.hotPhase.learnAboutRolloverLinkText": "ロールオーバーの詳細をご覧ください", - "xpack.indexLifecycleMgmt.editPolicy.hotPhase.rolloverDescriptionMessage": "ロールオーバーにより作成された新規インデックスは、インデックスエイリアスに追加され、書き込みインデックスとして指定されます。", - "xpack.indexLifecycleMgmt.editPolicy.indexPriorityText": "インデックスの優先順位", - "xpack.indexLifecycleMgmt.editPolicy.learnAboutIndexLifecycleManagementLinkText": "インデックスライフサイクルの詳細をご覧ください。", - "xpack.indexLifecycleMgmt.editPolicy.learnAboutIndexTemplatesLink": "インデックステンプレートの詳細をご覧ください", - "xpack.indexLifecycleMgmt.editPolicy.learnAboutShardAllocationLink": "シャード割り当ての詳細をご覧ください", - "xpack.indexLifecycleMgmt.editPolicy.learnAboutTimingText": "タイミングの詳細をご覧ください", - "xpack.indexLifecycleMgmt.editPolicy.lifecyclePolicyDescriptionText": "インデックスへのアクティブな書き込みから削除までの、インデックスライフサイクルの 4 つのフェーズを自動化するには、インデックスポリシーを使用します。", - "xpack.indexLifecycleMgmt.editPolicy.loadPolicyErrorMessage": "ポリシーの読み込み中にエラーが発生しました", - "xpack.indexLifecycleMgmt.editPolicy.maximumAgeMissingError": "最高年齢が必要です。", - "xpack.indexLifecycleMgmt.editPolicy.maximumDocumentsMissingError": "最高ドキュメント数が必要です。", - "xpack.indexLifecycleMgmt.editPolicy.maximumIndexSizeMissingError": "最大インデックスサイズが必要です。", - "xpack.indexLifecycleMgmt.editPolicy.nameLabel": "名前", - "xpack.indexLifecycleMgmt.editPolicy.nodeAllocationLabel": "シャードの割当をコントロールするノード属性を選択", - "xpack.indexLifecycleMgmt.editPolicy.nodeAttributesMissingDescription": "ノード属性なしではシャードの割り当てをコントロールできません。", - "xpack.indexLifecycleMgmt.editPolicy.nodeAttributesMissingLabel": "elasticsearch.yml でノード属性が構成されていません", - "xpack.indexLifecycleMgmt.editPolicy.nodeDetailErrorMessage": "ノード属性の詳細の読み込み中にエラーが発生しました", - "xpack.indexLifecycleMgmt.editPolicy.nodeInfoErrorMessage": "ノード属性の情報の読み込み中にエラーが発生しました", - "xpack.indexLifecycleMgmt.editPolicy.numberRequiredError": "数字が必要です。", - "xpack.indexLifecycleMgmt.editPolicy.phaseCold.minimumAgeLabel": "コールドフェーズのタイミング", - "xpack.indexLifecycleMgmt.editPolicy.phaseCold.minimumAgeUnitsAriaLabel": "コールドフェーズのタイミングの単位", - "xpack.indexLifecycleMgmt.editPolicy.phaseDelete.minimumAgeLabel": "削除フェーズのタイミング", - "xpack.indexLifecycleMgmt.editPolicy.phaseDelete.minimumAgeUnitsAriaLabel": "削除フェーズのタイミングの単位", - "xpack.indexLifecycleMgmt.editPolicy.phaseErrorMessage": "エラーを修正してください", - "xpack.indexLifecycleMgmt.editPolicy.phaseWarm.minimumAgeLabel": "ウォームフェーズのタイミング", - "xpack.indexLifecycleMgmt.editPolicy.phaseWarm.minimumAgeUnitsAriaLabel": "ウォームフェーズのタイミングの単位", - "xpack.indexLifecycleMgmt.editPolicy.policyNameAlreadyUsedError": "このポリシー名は既に使用されています。", - "xpack.indexLifecycleMgmt.editPolicy.policyNameContainsCommaError": "ポリシー名にはコンマを使用できません。", - "xpack.indexLifecycleMgmt.editPolicy.policyNameContainsSpaceError": "ポリシー名にはスペースを使用できません。", - "xpack.indexLifecycleMgmt.editPolicy.policyNameLabel": "ポリシー名", - "xpack.indexLifecycleMgmt.editPolicy.policyNameRequiredError": "ポリシー名が必要です。", - "xpack.indexLifecycleMgmt.editPolicy.policyNameStartsWithUnderscoreError": "ポリシー名の頭にアンダーラインを使用することはできません。", - "xpack.indexLifecycleMgmt.editPolicy.policyNameTooLongError": "ポリシー名は 255 バイト未満である必要があります。", - "xpack.indexLifecycleMgmt.editPolicy.positiveNumberAboveZeroRequiredError": "0 よりも大きい数字のみ使用できます。", - "xpack.indexLifecycleMgmt.editPolicy.positiveNumberRequiredError": "プラスの数字のみ使用できます。", - "xpack.indexLifecycleMgmt.editPolicy.rolloverDaysOptionLabel": "ロールオーバーからの経過日数", - "xpack.indexLifecycleMgmt.editPolicy.rolloverHoursOptionLabel": "ロールオーバーからの経過時間数", - "xpack.indexLifecycleMgmt.editPolicy.saveAsNewButton": "新規ポリシーとして保存します", - "xpack.indexLifecycleMgmt.editPolicy.saveAsNewPolicyMessage": "新規ポリシーとして保存します", - "xpack.indexLifecycleMgmt.editPolicy.saveButton": "ポリシーを保存", - "xpack.indexLifecycleMgmt.editPolicy.saveErrorMessage": "ライフサイクルポリシー {lifecycleName} の保存中にエラーが発生しました", - "xpack.indexLifecycleMgmt.editPolicy.successfulSaveMessage": "ライフサイクルポリシー「{lifecycleName}」を {verb}", - "xpack.indexLifecycleMgmt.editPolicy.updatedMessage": "更新しました", - "xpack.indexLifecycleMgmt.editPolicy.validPolicyNameMessage": "ポリシー名の頭にアンダーラインを使用することはできず、括弧やスペースを含めることもできません。", - "xpack.indexLifecycleMgmt.editPolicy.viewNodeDetailsButton": "この構成に関連付けられているインデックスのリストを表示", - "xpack.indexLifecycleMgmt.editPolicy.warmPhase.activateWarmPhaseSwitchLabel": "ウォームフェーズを有効にする", - "xpack.indexLifecycleMgmt.editPolicy.warmPhase.forceMergeDataExplanationText": "小さなファイルを結合して削除されたファイルを消去することで、シャードのセグメント数を減らします。", - "xpack.indexLifecycleMgmt.editPolicy.warmPhase.forceMergeDataText": "強制結合", - "xpack.indexLifecycleMgmt.editPolicy.warmPhase.indexPriorityExplanationText": "ノードの再起動後にインデックスを復元する優先順位を設定します。優先順位の高いインデックスは優先順位の低いインデックスよりも先に復元されます。", - "xpack.indexLifecycleMgmt.editPolicy.warmPhase.shrinkIndexExplanationText": "インデックス情報をプライマリシャードの少ない新規インデックスに縮小します。", - "xpack.indexLifecycleMgmt.editPolicy.warmPhase.shrinkText": "縮小", - "xpack.indexLifecycleMgmt.editPolicy.warmPhase.warmPhaseDescriptionMessage": "まだインデックスにクエリを実行中ですが、読み取り専用です。性能の低いハードウェアにシャードを割り当てることができます。検索を高速化するために、シャードの数を減らしセグメントを結合することができます。", - "xpack.indexLifecycleMgmt.editPolicy.warmPhase.warmPhaseLabel": "ウォームフェーズ", - "xpack.indexLifecycleMgmt.hotPhase.daysLabel": "日", - "xpack.indexLifecycleMgmt.hotPhase.enableRolloverLabel": "ロールオーバーを有効にする", - "xpack.indexLifecycleMgmt.hotPhase.gigabytesLabel": "ギガバイト", - "xpack.indexLifecycleMgmt.hotPhase.hoursLabel": "時間", - "xpack.indexLifecycleMgmt.hotPhase.maximumAgeLabel": "最高年齢", - "xpack.indexLifecycleMgmt.hotPhase.maximumAgeUnitsAriaLabel": "最高年齢の単位", - "xpack.indexLifecycleMgmt.hotPhase.maximumDocumentsLabel": "最高ドキュメント数", - "xpack.indexLifecycleMgmt.hotPhase.maximumIndexSizeLabel": "最大インデックスサイズ", - "xpack.indexLifecycleMgmt.hotPhase.maximumIndexSizeUnitsAriaLabel": "最大インデックスサイズの単位", - "xpack.indexLifecycleMgmt.hotPhase.megabytesLabel": "メガバイト", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.actionStatusTitle": "アクションステータス", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.headers.currentActionHeader": "現在のステータス", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.headers.currentActionTimeHeader": "現在のアクション時間", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.headers.currentPhaseHeader": "現在のフェーズ", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.headers.failedStepHeader": "失敗したステップ", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.headers.lifecyclePolicyHeader": "ライフサイクルポリシー", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.phaseDefinitionTitle": "フェーズ検知", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.showPhaseDefinitionButton": "フェーズ検知を表示", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.stackTraceButton": "スタックトレース", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.summaryErrorMessage": "インデックスライフサイクルエラー", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.summaryTitle": "インデックスライフサイクル管理", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.addPolicyButtonText": "ポリシーを追加", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.addPolicyToIndexError": "インデックスへのポリシーの追加中にエラーが発生しました", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.addPolicyToIndexSuccess": "インデックス {indexName} にポリシー {policyName} が追加されました。", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.cancelButtonText": "キャンセル", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.chooseAliasLabel": "インデックスロールオーバーエイリアス", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.chooseAliasMessage": "エイリアスを選択してください", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.choosePolicyLabel": "ライフサイクルポリシー", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.choosePolicyMessage": "ライフサイクルポリシーを選択してください", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.defineLifecyclePolicyLinkText": "ライフサイクルポリシーを追加", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.indexHasNoAliasesWarningMessage": "ポリシー {policyName} はロールオーバーするよう構成されていますが、インデックス {indexName} にデータがありません。ロールオーバーにはデータが必要です。", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.indexHasNoAliasesWarningTitle": "インデックスにエイリアスがありません", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.loadPolicyError": "ポリシーリストの読み込み中にエラーが発生しました", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.modalTitle": "「{indexName}」にライフサイクルポリシーを追加", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.noPoliciesWarningTitle": "インデックスライフサイクルポリシーが定義されていません", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.noPolicySelectedErrorMessage": "ポリシーの選択が必要です。", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyToTemplateConfirmModal.indexHasNoAliasesWarningMessage": "このインデックステンプレートには既にポリシー {existingPolicyName} が適用されています。このポリシーを追加するとこの構成が上書きされます。", - "xpack.indexLifecycleMgmt.indexManagementTable.removeLifecyclePolicyConfirmModal.cancelButtonText": "キャンセル", - "xpack.indexLifecycleMgmt.indexManagementTable.removeLifecyclePolicyConfirmModal.removePolicyButtonText": "ポリシーを削除", - "xpack.indexLifecycleMgmt.indexManagementTable.removeLifecyclePolicyConfirmModal.removePolicyToIndexError": "ポリシーの削除中にエラーが発生しました", - "xpack.indexLifecycleMgmt.indexMgmtBanner.errorMessage": "{ numIndicesWithLifecycleErrors, number}\n {numIndicesWithLifecycleErrors, plural, one {インデックスに} other {インデックスに} }\n インデックスライフサイクルエラー", - "xpack.indexLifecycleMgmt.indexMgmtBanner.filterLabel": "エラーを表示", - "xpack.indexLifecycleMgmt.indexMgmtFilter.lifecycleStatusLabel": "ライフサイクルステータス", - "xpack.indexLifecycleMgmt.indexMgmtFilter.managedLabel": "管理中", - "xpack.indexLifecycleMgmt.indexMgmtFilter.unmanagedLabel": "管理対象外", - "xpack.indexLifecycleMgmt.indexPriorityLabel": "インデックスの優先順位", - "xpack.indexLifecycleMgmt.learnMore": "その他のリソース", - "xpack.indexLifecycleMgmt.nodeAttrDetails.hostField": "ホスト", - "xpack.indexLifecycleMgmt.nodeAttrDetails.idField": "ID", - "xpack.indexLifecycleMgmt.nodeAttrDetails.nameField": "名前", - "xpack.indexLifecycleMgmt.nodeAttrDetails.title": "属性 {selectedNodeAttrs} を含むノード", - "xpack.indexLifecycleMgmt.noMatch.noPolicicesDescription": "表示するポリシーがありません", - "xpack.indexLifecycleMgmt.optionalMessage": " (オプション)", - "xpack.indexLifecycleMgmt.policyTable.actionsButtonText": "アクション", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.cancelButton": "キャンセル", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.chooseTemplateLabel": "インデックステンプレート", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.chooseTemplateMessage": "インデックステンプレートを選択してください", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.confirmButton": "ポリシーを追加", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.errorMessage": "インデックステンプレート {templateName} へのポリシー {policyName} の追加中にエラーが発生しました", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.explanationText": "これにより、インデックステンプレートと一致するすべてのインデックスにライフサイクルポリシーが適用されます。", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.noTemplateSelectedErrorMessage": "インデックステンプレートの選択が必要です。", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.rolloverAliasLabel": "ロールオーバーインデックスのエイリアス", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.successMessage": "インデックステンプレート {templateName} にポリシー {policyName} を追加しました", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.templateHasPolicyWarningTitle": "テンプレートに既にポリシーがあります", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.title": "インデックステンプレートにポリシー「{name}」 を追加", - "xpack.indexLifecycleMgmt.policyTable.addPolicyToTemplateButtonText": "インデックステンプレートにポリシーを追加", - "xpack.indexLifecycleMgmt.policyTable.deletedPoliciesText": "{numSelected} 件の{numSelected, plural, one {ポリシー} other {ポリシー}}が削除されました", - "xpack.indexLifecycleMgmt.policyTable.deletePolicyButtonDisabledTooltip": "インデックスが使用中のポリシーは削除できません", - "xpack.indexLifecycleMgmt.policyTable.deletePolicyButtonText": "ポリシーを削除", - "xpack.indexLifecycleMgmt.policyTable.emptyPrompt.createButtonLabel": "ポリシーを作成", - "xpack.indexLifecycleMgmt.policyTable.emptyPromptDescription": " ライフサイクルポリシーは、インデックスが古くなるにつれ管理しやすくなります。", - "xpack.indexLifecycleMgmt.policyTable.emptyPromptTitle": "初めのインデックスライフサイクルポリシーの作成", - "xpack.indexLifecycleMgmt.policyTable.headers.linkedIndicesHeader": "リンクされたインデクス", - "xpack.indexLifecycleMgmt.policyTable.headers.modifiedDateHeader": "変更日", - "xpack.indexLifecycleMgmt.policyTable.headers.nameHeader": "名前", - "xpack.indexLifecycleMgmt.policyTable.headers.versionHeader": "バージョン", - "xpack.indexLifecycleMgmt.policyTable.policyActionsMenu.panelTitle": "ポリシーオプション", - "xpack.indexLifecycleMgmt.policyTable.sectionDescription": "インデックスが古くなるにつれ管理します。 インデックスのライフサイクルにおける進捗のタイミングと方法を自動化するポリシーを設定します。", - "xpack.indexLifecycleMgmt.policyTable.sectionHeading": "インデックスライフサイクルポリシー", - "xpack.indexLifecycleMgmt.policyTable.systempoliciesSearchInputAriaLabel": "検索ポリシー", - "xpack.indexLifecycleMgmt.policyTable.systempoliciesSearchInputPlaceholder": "検索", - "xpack.indexLifecycleMgmt.policyTable.viewIndicesButtonText": "ポリシーにリンクされたインデックスを表示", - "xpack.indexLifecycleMgmt.removeIndexLifecycleActionButtonLabel": "ライフサイクルポリシーを削除", - "xpack.indexLifecycleMgmt.retryIndexLifecycleAction.retriedLifecycleMessage": "ライフサイクルのステップを再試行します {indexNames}", - "xpack.indexLifecycleMgmt.retryIndexLifecycleActionButtonLabel": "ライフサイクルのステップを再試行", - "xpack.indexLifecycleMgmt.warmPhase.forceMergeDataLabel": "データを強制結合", - "xpack.indexLifecycleMgmt.warmPhase.moveToWarmPhaseOnRolloverLabel": "ロールオーバー時にウォームフェーズに変更", - "xpack.indexLifecycleMgmt.warmPhase.numberOfPrimaryShardsLabel": "プライマリシャードの数", - "xpack.indexLifecycleMgmt.warmPhase.numberOfReplicasLabel": "レプリカの数", - "xpack.indexLifecycleMgmt.warmPhase.numberOfSegmentsLabel": "セグメントの数", - "xpack.indexLifecycleMgmt.warmPhase.replicaCountHelpText": "デフォルトで、レプリカの数は同じままになります。", - "xpack.indexLifecycleMgmt.warmPhase.shrinkIndexLabel": "インデックスを縮小", - "xpack.indexLifecycleMgmt.editPolicy.hidePolicyJsonButto": "リクエストを非表示", - "xpack.indexLifecycleMgmt.editPolicy.showPolicyJsonButto": "リクエストを表示", - "xpack.indexLifecycleMgmt.policyJsonFlyout.closeButtonLabel": "閉じる", - "xpack.indexLifecycleMgmt.policyJsonFlyout.descriptionText": "この Elasticsearch リクエストは、このインデックスライフサイクルポリシーを作成または更新します。", - "xpack.indexLifecycleMgmt.policyJsonFlyout.namedTitle": "「{policyName}」のリクエスト", - "xpack.indexLifecycleMgmt.policyJsonFlyout.unnamedTitle": "リクエスト", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.showPhaseDefinitionDescriptionTitle": "フェーズ検知", - "xpack.indexLifecycleMgmt.policyTable.captionText": "以下は {total} 列中 {count, plural, one {# 列} other {# 列}} を含むインデックスライフサイクルポリシー表です。", - "xpack.infra.chartSection.missingMetricDataText": "データが欠けています", - "xpack.infra.chartSection.notEnoughDataPointsToRenderText": "チャートのレンダリングに必要なデータポイントが足りません。時間範囲を広げてみてください。", - "xpack.infra.configureSourceActionLabel": "ソース構成を変更", - "xpack.infra.errorPage.errorOccurredTitle": "エラーが発生しました", - "xpack.infra.errorPage.tryAgainButtonLabel": "再試行", - "xpack.infra.errorPage.tryAgainDescription ": "戻るボタンをクリックして再試行してください。", - "xpack.infra.errorPage.unexpectedErrorTitle": "おっと!", - "xpack.infra.featureRegistry.linkInfrastructureTitle": "メトリック", - "xpack.infra.featureRegistry.linkLogsTitle": "ログ", - "xpack.infra.groupByDisplayNames.availabilityZone": "アベイラビリティゾーン", - "xpack.infra.groupByDisplayNames.hostName": "ホスト", - "xpack.infra.groupByDisplayNames.kubernetesNamespace": "ネームスペース", - "xpack.infra.groupByDisplayNames.kubernetesNodeName": "ノード", - "xpack.infra.groupByDisplayNames.machineType": "マシンタイプ", - "xpack.infra.groupByDisplayNames.projectID": "プロジェクト ID", - "xpack.infra.groupByDisplayNames.provider": "クラウドプロバイダー", - "xpack.infra.groupByDisplayNames.serviceType": "サービスタイプ", - "xpack.infra.header.badge.readOnly.text": "読み込み専用", - "xpack.infra.header.badge.readOnly.tooltip": "ソース構成を変更できません", - "xpack.infra.header.infrastructureTitle": "メトリック", - "xpack.infra.homePage.documentTitle": "メトリック", - "xpack.infra.homePage.inventoryTabTitle": "インベントリ", - "xpack.infra.homePage.metricsExplorerTabTitle": "メトリックエクスプローラー", - "xpack.infra.homePage.noMetricsIndicesDescription": "追加しましょう!", - "xpack.infra.homePage.noMetricsIndicesInstructionsActionLabel": "セットアップの手順を表示", - "xpack.infra.homePage.noMetricsIndicesTitle": "メトリックインデックスがないようです。", - "xpack.infra.homePage.toolbar.kqlSearchFieldPlaceholder": "インフラストラクチャーデータを検索… (例: host.name:host-1)", - "xpack.infra.infrastructureDescription": "インフラストラクチャーを閲覧します", - "xpack.infra.infrastructureMetricsExplorerPage.documentTitle": "{previousTitle} | メトリックエクスプローラー", - "xpack.infra.infrastructureSnapshotPage.documentTitle": "{previousTitle} | インベントリ", - "xpack.infra.infrastructureTitle": "メトリック", - "xpack.infra.kibanaMetrics.invalidInfraMetricErrorMessage": "{id} は有効な InfraMetric ではありません", - "xpack.infra.kibanaMetrics.nodeDoesNotExistErrorMessage": "{nodeId} が存在しません。", - "xpack.infra.legendControls.applyButton": "適用", - "xpack.infra.legendControls.buttonLabel": "凡例を校正", - "xpack.infra.legendControls.errorMessage": "最低値は最高値よりも低く設定する必要があります", - "xpack.infra.legendControls.maxLabel": "最高", - "xpack.infra.legendControls.minLabel": "最低", - "xpack.infra.legendControls.switchLabel": "自動計算範囲", - "xpack.infra.linkInfrastructureDescription": "インフラストラクチャーを閲覧します", - "xpack.infra.linkInfrastructureTitle": "メトリック", - "xpack.infra.linkLogsDescription": "ログを閲覧します", - "xpack.infra.linkLogsTitle": "ログ", - "xpack.infra.linkTo.hostWithIp.error": "IP アドレス「{hostIp}」でホストが見つかりません.", - "xpack.infra.linkTo.hostWithIp.loading": "IP アドレス「{hostIp}」のホストを読み込み中", - "xpack.infra.logEntryActionsMenu.buttonLabel": "アクション", - "xpack.infra.logEntryActionsMenu.uptimeActionLabel": "監視ステータスを表示", - "xpack.infra.logEntryItemView.viewDetailsToolTip": "詳細を表示", - "xpack.infra.logFlyout.fieldColumnLabel": "フィールド", - "xpack.infra.logFlyout.filterAriaLabel": "フィルター", - "xpack.infra.logFlyout.flyoutTitle": "ログイベントドキュメントの詳細", - "xpack.infra.logFlyout.loadingMessage": "イベントを読み込み中", - "xpack.infra.logFlyout.setFilterTooltip": "フィルターでイベントを表示", - "xpack.infra.logFlyout.valueColumnLabel": "値", - "xpack.infra.logs.customizeLogs.customizeButtonLabel": "カスタマイズ", - "xpack.infra.logs.customizeLogs.lineWrappingFormRowLabel": "改行", - "xpack.infra.logs.customizeLogs.minimapScaleFormRowLabel": "ミニマップスケール", - "xpack.infra.logs.customizeLogs.textSizeFormRowLabel": "テキストサイズ", - "xpack.infra.logs.customizeLogs.textSizeRadioGroup": "{textScale, select, small {小さい} 中くらい {Medium} 大きい {Large} その他の {{textScale}} }", - "xpack.infra.logs.customizeLogs.wrapLongLinesSwitchLabel": "長い行を改行", - "xpack.infra.logs.emptyView.checkForNewDataButtonLabel": "新規データを確認", - "xpack.infra.logs.emptyView.noLogMessageDescription": "フィルターを調整してみてください。", - "xpack.infra.logs.emptyView.noLogMessageTitle": "表示するログメッセージがありません。", - "xpack.infra.logs.lastStreamingUpdateText": " 最終更新 {lastUpdateTime}", - "xpack.infra.logs.loadAgainButtonLabel": "再読み込み", - "xpack.infra.logs.loadingAdditionalEntriesText": "追加エントリーを読み込み中", - "xpack.infra.logs.noAdditionalEntriesFoundText": "追加エントリーが見つかりません", - "xpack.infra.logs.scrollableLogTextStreamView.loadingEntriesLabel": "エントリーを読み込み中", - "xpack.infra.logs.search.nextButtonLabel": "次へ", - "xpack.infra.logs.search.previousButtonLabel": "前へ", - "xpack.infra.logs.search.searchInLogsAriaLabel": "検索", - "xpack.infra.logs.search.searchInLogsPlaceholder": "検索", - "xpack.infra.logs.searchResultTooltip": "{bucketCount, plural, one {# 件のハイライトされたエントリー} other {# 件のハイライトされたエントリー}}", - "xpack.infra.logs.startStreamingButtonLabel": "ライブストリーム", - "xpack.infra.logs.stopStreamingButtonLabel": "ストリーム停止", - "xpack.infra.logs.streamingDescription": "新しいエントリーをストリーム中...", - "xpack.infra.logs.streamingNewEntriesText": "新しいエントリーをストリーム中", - "xpack.infra.logsPage.noLoggingIndicesDescription": "追加しましょう!", - "xpack.infra.logsPage.noLoggingIndicesInstructionsActionLabel": "セットアップの手順を表示", - "xpack.infra.logsPage.noLoggingIndicesTitle": "ログインデックスがないようです。", - "xpack.infra.logsPage.toolbar.kqlSearchFieldPlaceholder": "ログエントリーを検索中… (例: host.name:host-1)", - "xpack.infra.mapLogs.oneDayLabel": "1 日", - "xpack.infra.mapLogs.oneHourLabel": "1 時間", - "xpack.infra.mapLogs.oneMinuteLabel": "1 分", - "xpack.infra.mapLogs.oneMonthLabel": "1 か月", - "xpack.infra.mapLogs.oneWeekLabel": "1 週間", - "xpack.infra.mapLogs.oneYearLabel": "1 年", - "xpack.infra.metricDetailPage.containerMetricsLayout.cpuUsageSection.sectionLabel": "CPU 使用状況", - "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoBytesSection.readRateSeriesLabel": "読み取り", - "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoBytesSection.sectionLabel": "ディスク IO (バイト)", - "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoBytesSection.writeRateSeriesLabel": "書き込み", - "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoOpsSection.readRateSeriesLabel": "読み取り", - "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoOpsSection.sectionLabel": "ディスク IO (Ops)", - "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoOpsSection.writeRateSeriesLabel": "書き込み", - "xpack.infra.metricDetailPage.containerMetricsLayout.layoutLabel": "コンテナー", - "xpack.infra.metricDetailPage.containerMetricsLayout.memoryUsageSection.sectionLabel": "メモリー使用状況", - "xpack.infra.metricDetailPage.containerMetricsLayout.networkTrafficSection.networkRxRateSeriesLabel": "入", - "xpack.infra.metricDetailPage.containerMetricsLayout.networkTrafficSection.networkTxRateSeriesLabel": "出", - "xpack.infra.metricDetailPage.containerMetricsLayout.networkTrafficSection.sectionLabel": "ネットワークトラフィック", - "xpack.infra.metricDetailPage.containerMetricsLayout.overviewSection.cpuUsageSeriesLabel": "CPU 使用状況", - "xpack.infra.metricDetailPage.containerMetricsLayout.overviewSection.inboundRXSeriesLabel": "受信 (RX)", - "xpack.infra.metricDetailPage.containerMetricsLayout.overviewSection.memoryUsageSeriesLabel": "メモリー使用状況", - "xpack.infra.metricDetailPage.containerMetricsLayout.overviewSection.outboundTXSeriesLabel": "送信 (TX)", - "xpack.infra.metricDetailPage.containerMetricsLayout.overviewSection.sectionLabel": "概要", - "xpack.infra.metricDetailPage.documentTitle": "インフラストラクチャー | メトリック | {name}", - "xpack.infra.metricDetailPage.documentTitleError": "{previousTitle} | おっと", - "xpack.infra.metricDetailPage.hostMetricsLayout.cpuUsageSection.sectionLabel": "CPU 使用状況", - "xpack.infra.metricDetailPage.hostMetricsLayout.layoutLabel": "ホスト", - "xpack.infra.metricDetailPage.hostMetricsLayout.loadSection.fifteenMinuteSeriesLabel": "15m", - "xpack.infra.metricDetailPage.hostMetricsLayout.loadSection.fiveMinuteSeriesLabel": "5分", - "xpack.infra.metricDetailPage.hostMetricsLayout.loadSection.oneMinuteSeriesLabel": "1m", - "xpack.infra.metricDetailPage.hostMetricsLayout.loadSection.sectionLabel": "読み込み", - "xpack.infra.metricDetailPage.hostMetricsLayout.memoryUsageSection.sectionLabel": "メモリー使用状況", - "xpack.infra.metricDetailPage.hostMetricsLayout.networkTrafficSection.networkRxRateSeriesLabel": "入", - "xpack.infra.metricDetailPage.hostMetricsLayout.networkTrafficSection.networkTxRateSeriesLabel": "出", - "xpack.infra.metricDetailPage.hostMetricsLayout.networkTrafficSection.sectionLabel": "ネットワークトラフィック", - "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.cpuUsageSeriesLabel": "CPU 使用状況", - "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.inboundRXSeriesLabel": "受信 (RX)", - "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.loadSeriesLabel": "読み込み (5m)", - "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.memoryCapacitySeriesLabel": "メモリー使用状況", - "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.outboundTXSeriesLabel": "送信 (TX)", - "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.sectionLabel": "概要", - "xpack.infra.metricDetailPage.kubernetesMetricsLayout.nodeCpuCapacitySection.sectionLabel": "ノード CPU 処理能力", - "xpack.infra.metricDetailPage.kubernetesMetricsLayout.nodeDiskCapacitySection.sectionLabel": "ノードディスク容量", - "xpack.infra.metricDetailPage.kubernetesMetricsLayout.nodeMemoryCapacitySection.sectionLabel": "ノードメモリー容量", - "xpack.infra.metricDetailPage.kubernetesMetricsLayout.nodePodCapacitySection.sectionLabel": "ノードポッド容量", - "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.cpuUsageSeriesLabel": "CPU 処理能力", - "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.diskCapacitySeriesLabel": "ディスク容量", - "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.loadSeriesLabel": "読み込み (5m)", - "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.memoryUsageSeriesLabel": "メモリー容量", - "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.podCapacitySeriesLabel": "ポッド容量", - "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.sectionLabel": "概要", - "xpack.infra.metricDetailPage.nginxMetricsLayout.activeConnectionsSection.sectionLabel": "アクティブな接続", - "xpack.infra.metricDetailPage.nginxMetricsLayout.hitsSection.sectionLabel": "ヒット", - "xpack.infra.metricDetailPage.nginxMetricsLayout.requestRateSection.sectionLabel": "リクエストレート", - "xpack.infra.metricDetailPage.nginxMetricsLayout.requestsPerConnectionsSection.reqsPerConnSeriesLabel": "接続あたりのリクエスト数", - "xpack.infra.metricDetailPage.nginxMetricsLayout.requestsPerConnectionsSection.sectionLabel": "接続あたりのリクエスト数", - "xpack.infra.metricDetailPage.podMetricsLayout.cpuUsageSection.sectionLabel": "CPU 使用状況", - "xpack.infra.metricDetailPage.podMetricsLayout.layoutLabel": "ポッド", - "xpack.infra.metricDetailPage.podMetricsLayout.memoryUsageSection.sectionLabel": "メモリー使用状況", - "xpack.infra.metricDetailPage.podMetricsLayout.networkTrafficSection.networkRxRateSeriesLabel": "入", - "xpack.infra.metricDetailPage.podMetricsLayout.networkTrafficSection.networkTxRateSeriesLabel": "出", - "xpack.infra.metricDetailPage.podMetricsLayout.networkTrafficSection.sectionLabel": "ネットワークトラフィック", - "xpack.infra.metricDetailPage.podMetricsLayout.overviewSection.cpuUsageSeriesLabel": "CPU 使用状況", - "xpack.infra.metricDetailPage.podMetricsLayout.overviewSection.inboundRXSeriesLabel": "受信 (RX)", - "xpack.infra.metricDetailPage.podMetricsLayout.overviewSection.memoryUsageSeriesLabel": "メモリー使用状況", - "xpack.infra.metricDetailPage.podMetricsLayout.overviewSection.outboundTXSeriesLabel": "送信 (TX)", - "xpack.infra.metricDetailPage.podMetricsLayout.overviewSection.sectionLabel": "概要", - "xpack.infra.metrics.emptyViewDescription": "期間またはフィルターを調整してみてください。", - "xpack.infra.metrics.emptyViewTitle": "表示するデータがありません。", - "xpack.infra.metrics.invalidNodeErrorDescription": "構成をよく確認してください", - "xpack.infra.metrics.invalidNodeErrorTitle": "{nodeName} がメトリックデータを収集していないようです", - "xpack.infra.metrics.loadingNodeDataText": "データを読み込み中", - "xpack.infra.metrics.refetchButtonLabel": "新規データを確認", - "xpack.infra.metricsExplorer.actionsLabel.aria": "{grouping} のアクション", - "xpack.infra.metricsExplorer.actionsLabel.button": "アクション", - "xpack.infra.metricsExplorer.aggregationLabel": "/", - "xpack.infra.metricsExplorer.aggregationLables.avg": "平均", - "xpack.infra.metricsExplorer.aggregationLables.cardinality": "基数", - "xpack.infra.metricsExplorer.aggregationLables.count": "ドキュメントカウント", - "xpack.infra.metricsExplorer.aggregationLables.max": "最高", - "xpack.infra.metricsExplorer.aggregationLables.min": "最低", - "xpack.infra.metricsExplorer.aggregationLables.rate": "レート", - "xpack.infra.metricsExplorer.aggregationSelectLabel": "集約を選択してください", - "xpack.infra.metricsExplorer.emptyChart.body": "チャートをレンダリングできません。", - "xpack.infra.metricsExplorer.emptyChart.title": "チャートデータがありません", - "xpack.infra.metricsExplorer.errorMessage": "「{message}」によりリクエストは実行されませんでした", - "xpack.infra.metricsExplorer.filterByLabel": "フィルターを追加します", - "xpack.infra.metricsExplorer.footerPaginationMessage": "「{groupBy}」でグループ化された{total}件中{length}件のチャートを表示しています。", - "xpack.infra.metricsExplorer.groupByLabel": "すべて", - "xpack.infra.metricsExplorer.groupByToolbarLabel": "graph/", - "xpack.infra.metricsExplorer.loadingCharts": "チャートを読み込み中", - "xpack.infra.metricsExplorer.loadMoreChartsButton": "さらにチャートを読み込む", - "xpack.infra.metricsExplorer.metricComboBoxPlaceholder": "プロットするメトリックを選択してください", - "xpack.infra.metricsExplorer.noDataBodyText": "設定で時間、フィルター、またはグループを調整してみてください。", - "xpack.infra.metricsExplorer.noDataRefetchText": "新規データを確認", - "xpack.infra.metricsExplorer.noDataTitle": "表示するデータがありません。", - "xpack.infra.metricsExplorer.noMetrics.body": "上でメトリックを選択してください。", - "xpack.infra.metricsExplorer.noMetrics.title": "不足しているメトリック", - "xpack.infra.metricsExplorer.openInTSVB": "ビジュアライザーで開く", - "xpack.infra.metricsExplorer.viewNodeDetail": "{name} のメトリックを表示", - "xpack.infra.node.ariaLabel": "{nodeName}、クリックしてメニューを開きます", - "xpack.infra.nodeContextMenu.viewLogsName": "ログを表示", - "xpack.infra.nodeContextMenu.viewMetricsName": "メトリックを表示", - "xpack.infra.nodesToWaffleMap.groupsWithGroups.allName": "すべて", - "xpack.infra.nodesToWaffleMap.groupsWithNodes.allName": "すべて", - "xpack.infra.notFoundPage.noContentFoundErrorTitle": "コンテンツがありません", - "xpack.infra.redirectToNodeLogs.loadingNodeLogsMessage": "{nodeType} ログを読み込み中", - "xpack.infra.registerFeatures.infraOpsDescription": "共通のサーバー、コンテナー、サービスのインフラストラクチャーメトリックとログを閲覧します。", - "xpack.infra.registerFeatures.infraOpsTitle": "メトリック", - "xpack.infra.registerFeatures.logsDescription": "ログをリアルタイムでストリーするか、コンソール式の UI で履歴ビューをスクロールします。", - "xpack.infra.registerFeatures.logsTitle": "ログ", - "xpack.infra.sourceConfiguration.addLogColumnButtonLabel": "列を追加", - "xpack.infra.sourceConfiguration.containerFieldLabel": "コンテナー ID", - "xpack.infra.sourceConfiguration.fieldEmptyErrorMessage": "このフィールドは未入力のままにできません。", - "xpack.infra.sourceConfiguration.fieldLogColumnTitle": "フィールド", - "xpack.infra.sourceConfiguration.fieldsSectionTitle": "フィールド", - "xpack.infra.sourceConfiguration.hostFieldDescription": "推奨値は {defaultValue} です", - "xpack.infra.sourceConfiguration.hostFieldLabel": "ホスト名", - "xpack.infra.sourceConfiguration.indicesSectionTitle": "インデックス", - "xpack.infra.sourceConfiguration.logColumnListEmptyErrorMessage": "ログ列リストは未入力のままにできません。", - "xpack.infra.sourceConfiguration.logColumnsSectionTitle": "ログ列", - "xpack.infra.sourceConfiguration.logIndicesLabel": "ログインデックス", - "xpack.infra.sourceConfiguration.messageLogColumnDescription": "このシステムフィールドは、ドキュメントフィールドから取得されたログエントリーメッセージを表示します。", - "xpack.infra.sourceConfiguration.metricIndicesLabel": "メトリックインデックス", - "xpack.infra.sourceConfiguration.nameLabel": "名前", - "xpack.infra.sourceConfiguration.nameSectionTitle": "名前", - "xpack.infra.sourceConfiguration.noLogColumnsDescription": "上のボタンでこのリストに列を追加します。", - "xpack.infra.sourceConfiguration.noLogColumnsTitle": "列がありません", - "xpack.infra.sourceConfiguration.podFieldLabel": "ポッド ID", - "xpack.infra.sourceConfiguration.systemColumnBadgeLabel": "システム", - "xpack.infra.sourceConfiguration.tiebreakerFieldLabel": "タイブレーカー", - "xpack.infra.sourceConfiguration.timestampFieldLabel": "タイムスタンプ", - "xpack.infra.sourceConfiguration.timestampLogColumnDescription": "このシステムフィールドは、{timestampSetting} フィールド設定から判断されたログエントリーの時刻を表示します。", - "xpack.infra.sourceErrorPage.failedToLoadDataSourcesMessage": "データソースの読み込みに失敗しました。", - "xpack.infra.sourceLoadingPage.loadingDataSourcesMessage": "データソースを読み込み中", - "xpack.infra.tableView.columnName.avg": "平均", - "xpack.infra.tableView.columnName.last1m": "過去 1m", - "xpack.infra.tableView.columnName.max": "最高", - "xpack.infra.tableView.columnName.name": "名前", - "xpack.infra.viewSwitcher.lenged": "表とマップビューを切り替えます", - "xpack.infra.viewSwitcher.mapViewLabel": "マップビュー", - "xpack.infra.viewSwitcher.tableViewLabel": "表ビュー", - "xpack.infra.waffle.checkNewDataButtonLabel": "新規データを確認", - "xpack.infra.waffle.customGroupByDropdownPlacehoder": "1 つ選択してください", - "xpack.infra.waffle.customGroupByFieldLabel": "フィールド", - "xpack.infra.waffle.customGroupByHelpText": "これは用語集約に使用されるフィールドです。", - "xpack.infra.waffle.customGroupByOptionName": "カスタムフィールド", - "xpack.infra.waffle.customGroupByPanelTitle": "カスタムフィールドでグループ分け", - "xpack.infra.waffle.groupByAllTitle": "すべて", - "xpack.infra.waffle.groupByButtonLabel": "グループ分けの条件:", - "xpack.infra.waffle.loadingDataText": "データを読み込み中", - "xpack.infra.waffle.metricButtonLabel": "メトリック: {selectedMetric}", - "xpack.infra.waffle.metricOptions.cpuUsageText": "CPU 使用状況", - "xpack.infra.waffle.metricOptions.hostLogRateText": "ログレート", - "xpack.infra.waffle.metricOptions.inboundTrafficText": "受信トラフィック", - "xpack.infra.waffle.metricOptions.loadText": "読み込み", - "xpack.infra.waffle.metricOptions.memoryUsageText": "メモリー使用状況", - "xpack.infra.waffle.metricOptions.outboundTrafficText": "送信トラフィック", - "xpack.infra.waffle.noDataDescription": "期間またはフィルターを調整してみてください。", - "xpack.infra.waffle.noDataTitle": "表示するデータがありません。", - "xpack.infra.waffle.selectTwoGroupingsTitle": "最大 2 つのグループ分けを選択してください", - "xpack.infra.waffle.unableToSelectGroupErrorMessage": "{nodeType} のオプションでグループを選択できません", - "xpack.infra.waffle.unableToSelectMetricErrorTitle": "メトリックのオプションまたは値を選択できません", - "xpack.infra.waffleTime.autoRefreshButtonLabel": "自動更新", - "xpack.infra.waffleTime.stopRefreshingButtonLabel": "更新中止", - "xpack.infra.analysisSetup.analysisSetupDescription": "機械学習を使用して自動的に異常ログレートカウントを検出します。", - "xpack.infra.analysisSetup.analysisSetupTitle": "機械学習分析を有効にする", - "xpack.infra.analysisSetup.createMlJobButton": "ML ジョブを作成", - "xpack.infra.analysisSetup.endTimeDefaultDescription": "永久", - "xpack.infra.analysisSetup.endTimeLabel": "終了時刻", - "xpack.infra.analysisSetup.startTimeDefaultDescription": "ログインデックスの開始地点です。", - "xpack.infra.analysisSetup.startTimeLabel": "開始時刻", - "xpack.infra.analysisSetup.timeRangeDescription": "デフォルトで、機械学習は 4 週間以内のログインデックスのログメッセージを分析し、永久に継続します。別の開始日、終了日、または両方を指定できます。", - "xpack.infra.analysisSetup.timeRangeTitle": "時間範囲の選択", - "xpack.infra.chartSection.missingMetricDataBody": "このチャートはデータが欠けています。", - "xpack.infra.chartSection.notEnoughDataPointsToRenderTitle": "データが不十分です", - "xpack.infra.header.logsTitle": "ログ", - "xpack.infra.homePage.settingsTabTitle": "設定", - "xpack.infra.kibanaMetrics.cloudIdMissingErrorMessage": "{metricId} のモデルには cloudId が必要ですが、{nodeId} に cloudId が指定されていません。", - "xpack.infra.logs.analysis.logRateSectionLineSeriesName": "15 分ごとのログエントリー (平均)", - "xpack.infra.logs.analysis.logRateSectionLoadingAriaLabel": "ログレートの結果を読み込み中", - "xpack.infra.logs.analysis.logRateSectionNoDataBody": "時間範囲を調整する必要があるかもしれません。", - "xpack.infra.logs.analysis.logRateSectionNoDataTitle": "表示するデータがありません。", - "xpack.infra.logs.analysis.logRateSectionTitle": "ログレート", - "xpack.infra.logs.analysisPage.loadingMessage": "分析ジョブのステータスを確認中…", - "xpack.infra.logs.analysisPage.unavailable.mlAppLink": "機械学習アプリ", - "xpack.infra.logs.highlights.goToNextHighlightButtonLabel": "次のハイライトにスキップ", - "xpack.infra.logs.highlights.goToPreviousHighlightButtonLabel": "前のハイライトにスキップ", - "xpack.infra.logs.index.settingsTabTitle": "設定", - "xpack.infra.logs.index.streamTabTitle": "ストリーム", - "xpack.infra.logs.streamPage.documentTitle": "{previousTitle} | ストリーム", - "xpack.infra.logsPage.toolbar.kqlSearchFieldAriaLabel": "ログエントリーを検索", - "xpack.infra.metricDetailPage.awsMetricsLayout.cpuUtilSection.percentSeriesLabel": "パーセント", - "xpack.infra.metricDetailPage.awsMetricsLayout.cpuUtilSection.sectionLabel": "CPU 使用状況", - "xpack.infra.metricDetailPage.awsMetricsLayout.diskioBytesSection.readsSeriesLabel": "読み取り", - "xpack.infra.metricDetailPage.awsMetricsLayout.diskioBytesSection.sectionLabel": "ディスク I/O バイト", - "xpack.infra.metricDetailPage.awsMetricsLayout.diskioBytesSection.writesSeriesLabel": "書き込み", - "xpack.infra.metricDetailPage.awsMetricsLayout.diskioOperationsSection.readsSeriesLabel": "読み取り", - "xpack.infra.metricDetailPage.awsMetricsLayout.diskioOperationsSection.sectionLabel": "ディスク I/O オペレーション", - "xpack.infra.metricDetailPage.awsMetricsLayout.diskioOperationsSection.writesSeriesLabel": "書き込み", - "xpack.infra.metricDetailPage.awsMetricsLayout.networkBytesSection.rxSeriesLabel": "次に含まれる:", - "xpack.infra.metricDetailPage.awsMetricsLayout.networkBytesSection.sectionLabel": "ネットワークトラフィック", - "xpack.infra.metricDetailPage.awsMetricsLayout.networkBytesSection.txSeriesLabel": "出", - "xpack.infra.metricDetailPage.awsMetricsLayout.networkPacketsSection.packetsInSeriesLabel": "次に含まれる:", - "xpack.infra.metricDetailPage.awsMetricsLayout.networkPacketsSection.packetsOutSeriesLabel": "出", - "xpack.infra.metricDetailPage.awsMetricsLayout.networkPacketsSection.sectionLabel": "ネットワークパケット (平均)", - "xpack.infra.metricDetailPage.awsMetricsLayout.overviewSection.cpuUtilizationSeriesLabel": "CPU 使用状況", - "xpack.infra.metricDetailPage.awsMetricsLayout.overviewSection.networkPacketsInLabel": "パケット (受信)", - "xpack.infra.metricDetailPage.awsMetricsLayout.overviewSection.networkPacketsOutLabel": "パケット (送信)", - "xpack.infra.metricDetailPage.awsMetricsLayout.overviewSection.sectionLabel": "概要", - "xpack.infra.metricDetailPage.awsMetricsLayout.overviewSection.statusCheckFailedLabel": "ステータス確認失敗", - "xpack.infra.metricsExplorer.chartOptions.areaLabel": "エリア", - "xpack.infra.metricsExplorer.chartOptions.autoLabel": "自動 (最低 ~ 最高)", - "xpack.infra.metricsExplorer.chartOptions.fromZeroLabel": "ゼロから (0 ~ 最高)", - "xpack.infra.metricsExplorer.chartOptions.lineLabel": "折れ線", - "xpack.infra.metricsExplorer.chartOptions.stackLabel": "スタックシリーズ", - "xpack.infra.metricsExplorer.chartOptions.stackSwitchLabel": "スタック", - "xpack.infra.metricsExplorer.chartOptions.typeLabel": "チャートスタイル", - "xpack.infra.metricsExplorer.chartOptions.yAxisDomainLabel": "Y 軸ドメイン", - "xpack.infra.metricsExplorer.customizeChartOptions": "カスタマイズ", - "xpack.infra.sourceConfiguration.applySettingsButtonLabel": "申し込む", - "xpack.infra.sourceConfiguration.containerFieldRecommendedValue": "推奨値は {defaultValue} です", - "xpack.infra.sourceConfiguration.discardSettingsButtonLabel": "破棄", - "xpack.infra.sourceConfiguration.hostNameFieldDescription": "ホストの識別に使用されるフィールドです", - "xpack.infra.sourceConfiguration.hostNameFieldLabel": "ホスト名", - "xpack.infra.sourceConfiguration.logIndicesRecommendedValue": "推奨値は {defaultValue} です", - "xpack.infra.sourceConfiguration.logIndicesTitle": "ログインデックス", - "xpack.infra.sourceConfiguration.metricIndicesRecommendedValue": "推奨値は {defaultValue} です", - "xpack.infra.sourceConfiguration.metricIndicesTitle": "メトリックインデックス", - "xpack.infra.sourceConfiguration.nameDescription": "ソース構成を説明する名前です", - "xpack.infra.sourceConfiguration.podFieldRecommendedValue": "推奨値は {defaultValue} です", - "xpack.infra.sourceConfiguration.tiebreakerFieldRecommendedValue": "推奨値は {defaultValue} です", - "xpack.infra.sourceConfiguration.timestampFieldRecommendedValue": "推奨値は {defaultValue} です", - "xpack.infra.sourceConfiguration.unsavedFormPrompt": "終了してよろしいですか?変更内容は失われます", - "xpack.infra.useHTTPRequest.error.status": "エラー", - "xpack.infra.useHTTPRequest.error.title": "リソースの取得中にエラーが発生しました", - "xpack.infra.useHTTPRequest.error.url": "URL", - "xpack.infra.sourceConfiguration.containerFieldDescription": "Docker コンテナーの識別に使用されるフィールドです", - "xpack.infra.sourceConfiguration.logIndicesDescription": "ログデータを含む一致するインデックスのインデックスパターンです", - "xpack.infra.sourceConfiguration.metricIndicesDescription": "Metricbeat データを含む一致するインデックスのインデックスパターンです", - "xpack.infra.sourceConfiguration.podFieldDescription": "Kubernetes ポッドの識別に使用されるフィールドです", - "xpack.infra.sourceConfiguration.removeLogColumnButtonLabel": "{columnDescription} 列を削除", - "xpack.infra.sourceConfiguration.tiebreakerFieldDescription": "同じタイムスタンプの 2 つのエントリーを識別するのに使用されるフィールドです", - "xpack.infra.sourceConfiguration.timestampFieldDescription": "ログエントリーの並べ替えに使用されるタイムスタンプです", - "xpack.infra.analysisSetup.deleteAnalysisResultsWarning": "これにより以前検出された異常が削除されます。", - "xpack.infra.analysisSetup.recreateMlJobButton": "ML ジョブを再作成", - "xpack.infra.analysisSetup.steps.setupProcess.loadingText": "ML ジョブを作成中…", - "xpack.infra.analysisSetup.steps.setupProcess.successText": "ML ジョブが正常に設定されました", - "xpack.infra.analysisSetup.steps.setupProcess.tryAgainButton": "再試行", - "xpack.infra.analysisSetup.steps.setupProcess.viewResultsButton": "結果を表示", - "xpack.infra.logs.analysis.analyzeInMlButtonLabel": "ML で分析", - "xpack.infra.logs.analysis.anomaliesExpandedRowNumberOfLogEntriesDescription": "ログエントリーの数です", - "xpack.infra.logs.analysis.anomaliesSectionLineSeriesName": "15 分ごとのログエントリー (平均)", - "xpack.infra.logs.analysis.anomaliesSectionLoadingAriaLabel": "異常を読み込み中", - "xpack.infra.logs.analysis.anomaliesSectionTitle": "異常", - "xpack.infra.logs.analysis.anomaliesTableCollapseLabel": "縮小", - "xpack.infra.logs.analysis.anomaliesTableExpandLabel": "拡張", - "xpack.infra.logs.analysis.anomaliesTableMaxAnomalyScoreColumnName": "最高異常スコア", - "xpack.infra.logs.analysis.anomaliesTablePartitionColumnName": "パーティション", - "xpack.infra.logs.analysis.anomalySectionNoAnomaliesTitle": "異常が検出されませんでした。", - "xpack.infra.logs.analysis.anomalySectionNoDataBody": "時間範囲を調整する必要があるかもしれません。", - "xpack.infra.logs.analysis.anomalySectionNoDataTitle": "表示するデータがありません。", - "xpack.infra.logs.analysis.jobConfigurationOutdatedCalloutMessage": "異なるソース構成を使用して ML ジョブが作成されました。現在の構成を適用するにはジョブを再作成してください。これにより以前検出された異常が削除されます。", - "xpack.infra.logs.analysis.jobConfigurationOutdatedCalloutTitle": "古い ML ジョブ構成", - "xpack.infra.logs.analysis.jobDefinitionOutdatedCalloutMessage": "ML ジョブの新しいバージョンが利用可能です。新しいバージョンをデプロイするにはジョブを再作成してください。これにより以前検出された異常が削除されます。", - "xpack.infra.logs.analysis.jobDefinitionOutdatedCalloutTitle": "古い ML ジョブ定義", - "xpack.infra.logs.analysis.jobStoppedCalloutMessage": "ML ジョブが手動またはリソース不足により停止しました。新しいログエントリーはジョブが再起動するまで処理されません。", - "xpack.infra.logs.analysis.jobStoppedCalloutTitle": "ML ジョブが停止しました", - "xpack.infra.logs.analysis.logRateResultsToolbarText": "{startTime} から {endTime} までの {numberOfLogs} 件のログエントリーを分析しました", - "xpack.infra.logs.analysis.logRateSectionBucketSpanLabel": "バケットスパン:", - "xpack.infra.logs.analysis.logRateSectionBucketSpanValue": "15 分", - "xpack.infra.logs.analysis.overallAnomaliesNumberOfLogEntriesDescription": "ログエントリーの数です", - "xpack.infra.logs.analysis.overallAnomaliesTopAnomalyScoreDescription": "最高異常スコア", - "xpack.infra.logs.analysis.overallAnomalyChartMaxScoresLabel": "最高異常スコア", - "xpack.infra.logs.analysis.partitionMaxAnomalyScoreAnnotationLabel": "最高異常スコア: {maxAnomalyScore}", - "xpack.infra.logs.analysis.recreateJobButtonLabel": "ML ジョブを再作成", - "xpack.infra.logs.jumpToTailText": "最も新しいエントリーに移動", - "xpack.infra.metricsExplorer.chartOptions.barLabel": "バー", - "xpack.infra.nodeDetails.labels.availabilityZone": "アベイラビリティゾーン", - "xpack.infra.nodeDetails.labels.cloudProvider": "クラウドプロバイダー", - "xpack.infra.nodeDetails.labels.containerized": "コンテナー化", - "xpack.infra.nodeDetails.labels.hostname": "ホスト名", - "xpack.infra.nodeDetails.labels.instanceId": "インスタンス ID", - "xpack.infra.nodeDetails.labels.instanceName": "インスタンス名", - "xpack.infra.nodeDetails.labels.kernelVersion": "カーネルバージョン", - "xpack.infra.nodeDetails.labels.machineType": "マシンタイプ", - "xpack.infra.nodeDetails.labels.operatinSystem": "オペレーティングシステム", - "xpack.infra.nodeDetails.labels.projectId": "プロジェクト ID", - "xpack.infra.nodeDetails.labels.showMoreDetails": "他の詳細を表示", - "xpack.infra.nodeDetails.no": "いいえ", - "xpack.infra.nodeDetails.yes": "はい", - "xpack.infra.openView.actionNames.deleteConfirmation": "ビューを削除しますか?", - "xpack.infra.openView.cancelButton": "キャンセル", - "xpack.infra.openView.columnNames.actions": "アクション", - "xpack.infra.openView.columnNames.name": "名前", - "xpack.infra.openView.flyoutHeader": "ビューを読み込む", - "xpack.infra.sampleDataLinkLabel": "ログ", - "xpack.infra.savedView.defaultViewName": "デフォルト", - "xpack.infra.savedView.errorOnCreate.title": "ビューの保存中にエラーが発生しました。", - "xpack.infra.savedView.findError.title": "ビューの読み込み中にエラーが発生しました。", - "xpack.infra.waffle.inventoryButtonLabel": "ビュー: {selectedText}", - "xpack.infra.waffle.metricOptions.countText": "カウント", - "xpack.infra.waffle.savedView.createHeader": "ビューを保存", - "xpack.infra.waffle.savedViews.cancel": "キャンセル", - "xpack.infra.waffle.savedViews.cancelButton": "キャンセル", - "xpack.infra.waffle.savedViews.includeTimeFilterLabel": "ビューに時刻を保存", - "xpack.infra.waffle.savedViews.includeTimeHelpText": "ビューが読み込まれるごとに現在選択された時刻の時間フィルターが変更されます。", - "xpack.infra.waffle.savedViews.loadViewsLabel": "読み込み", - "xpack.infra.waffle.savedViews.saveButton": "保存", - "xpack.infra.waffle.savedViews.saveViewLabel": "保存", - "xpack.infra.waffle.savedViews.viewNamePlaceholder": "名前", - "xpack.kueryAutocomplete.andOperatorDescription": "{bothArguments}がtrueであることを条件とする", - "xpack.kueryAutocomplete.andOperatorDescription.bothArgumentsText": "両方の引数", - "xpack.kueryAutocomplete.equalOperatorDescription": "一部の値に{equals}", - "xpack.kueryAutocomplete.equalOperatorDescription.equalsText": "一致する", - "xpack.kueryAutocomplete.existOperatorDescription": "いずれかの形式中に{exists}", - "xpack.kueryAutocomplete.existOperatorDescription.existsText": "存在する", - "xpack.kueryAutocomplete.filterResultsDescription": "{fieldName}を含む結果をフィルタリング", - "xpack.kueryAutocomplete.greaterThanOperatorDescription": "が一部の値{greaterThan}", - "xpack.kueryAutocomplete.greaterThanOperatorDescription.greaterThanText": "より大きい", - "xpack.kueryAutocomplete.greaterThanOrEqualOperatorDescription": "が一部の値{greaterThanOrEqualTo}", - "xpack.kueryAutocomplete.greaterThanOrEqualOperatorDescription.greaterThanOrEqualToText": "よりも大きいまたは等しい", - "xpack.kueryAutocomplete.lessThanOperatorDescription": "が一部の値{lessThan}", - "xpack.kueryAutocomplete.lessThanOperatorDescription.lessThanText": "より小さい", - "xpack.kueryAutocomplete.lessThanOrEqualOperatorDescription": "が一部の値{lessThanOrEqualTo}", - "xpack.kueryAutocomplete.lessThanOrEqualOperatorDescription.lessThanOrEqualToText": "より小さいまたは等しい", - "xpack.kueryAutocomplete.orOperatorDescription": "{oneOrMoreArguments}がtrueであることを条件とする", - "xpack.kueryAutocomplete.orOperatorDescription.oneOrMoreArgumentsText": "1つ以上の引数", - "xpack.licenseMgmt.dashboard.breadcrumb": "ライセンス管理", - "xpack.licenseMgmt.licenseDashboard.addLicense.updateLicenseButtonLabel": "ライセンスを更新", - "xpack.licenseMgmt.licenseDashboard.addLicense.updateLicenseTitle": "ライセンスの更新", - "xpack.licenseMgmt.licenseDashboard.addLicense.useAvailableLicenseDescription": "既に新しいライセンスがある場合は、今すぐアップロードしてください。", - "xpack.licenseMgmt.licenseDashboard.licenseStatus.activeLicenseStatusDescription": "ライセンスは {expiryDate} に期限切れになります", - "xpack.licenseMgmt.licenseDashboard.licenseStatus.activeLicenseStatusText": "アクティブ", - "xpack.licenseMgmt.licenseDashboard.licenseStatus.activeLicenseStatusTitle": "ご使用の {typeTitleCase} ライセンスは {status} です", - "xpack.licenseMgmt.licenseDashboard.licenseStatus.expiredLicenseStatusDescription": "ご使用のライセンスは {expiryDate} に期限切れになりました", - "xpack.licenseMgmt.licenseDashboard.licenseStatus.expiredLicenseStatusTitle": "ご使用の {typeTitleCase} ライセンスは期限切れです", - "xpack.licenseMgmt.licenseDashboard.licenseStatus.inactiveLicenseStatusText": "非アクティブ", - "xpack.licenseMgmt.licenseDashboard.licenseStatus.permanentActiveLicenseStatusDescription": "ご使用のライセンスには有効期限がありません。", - "xpack.licenseMgmt.licenseDashboard.requestTrialExtension.extendTrialButtonLabel": "トライアルを延長", - "xpack.licenseMgmt.licenseDashboard.requestTrialExtension.extendYourTrialTitle": "トライアルの延長", - "xpack.licenseMgmt.licenseDashboard.requestTrialExtension.howToContinueUsingPluginsDescription": "機械学習、高度なセキュリティ、その他の素晴らしい {platinumLicenseFeaturesLinkText} の使用を続けるには、今すぐ延長をお申し込みください。", - "xpack.licenseMgmt.licenseDashboard.requestTrialExtension.platinumLicenseFeaturesLinkText": "プラチナ機能", - "xpack.licenseMgmt.licenseDashboard.revertToBasic.acknowledgeModal.revertToBasicButtonLabel": "ベーシックに戻す", - "xpack.licenseMgmt.licenseDashboard.revertToBasic.acknowledgeModalTitle": "ベーシックライセンスに戻す", - "xpack.licenseMgmt.licenseDashboard.revertToBasic.confirmModal.cancelButtonLabel": "キャンセル", - "xpack.licenseMgmt.licenseDashboard.revertToBasic.confirmModal.confirmButtonLabel": "確認", - "xpack.licenseMgmt.licenseDashboard.revertToBasic.confirmModalTitle": "ベーシックライセンスに戻す確認", - "xpack.licenseMgmt.licenseDashboard.revertToBasic.platinumLicenseFeaturesLinkText": "プラチナ機能", - "xpack.licenseMgmt.licenseDashboard.revertToBasic.revertToFreeFeaturesDescription": "無料の機能に戻すと、セキュリティ、機械学習、その他 {platinumLicenseFeaturesLinkText} が利用できなくなります。", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModal.cancelButtonLabel": "キャンセル", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModal.startTrialButtonLabel": "トライアルを開始", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription": "このトライアルは、Elastic Stack の {platinumLicenseFeaturesLinkText} のフルセットが使えます。次の機能に直ちにアクセスできるようになります:", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.alertingFeatureTitle": "アラート", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.dataBaseConnectivityFeatureTitle": "{sqlDataBase} の {jdbcStandard} および {odbcStandard} 接続", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.graphCapabilitiesFeatureTitle": "グラフ機能", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.mashingLearningFeatureTitle": "機械学習", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.platinumLicenseFeaturesLinkText": "プラチナ機能", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.securityDocumentationLinkText": "ドキュメンテーション", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.securityFeaturesConfigurationDescription": "認証 ({authenticationTypeList})、フィールドとドキュメントレベルのセキュリティ、監査などの高度なセキュリティ機能には構成が必要です。手順は {securityDocumentationLinkText} をご覧ください。", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.termsAndConditionsDescription": "このトライアルを開始することで、これらの {termsAndConditionsLinkText} が適用されることに同意したものとみなされます。", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.termsAndConditionsLinkText": "諸条件", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalTitle": "30 日間の無料トライアルの開始", - "xpack.licenseMgmt.licenseDashboard.startTrial.platinumFeaturesExperienceDescription": "機械学習、高度なセキュリティ、その他 {platinumLicenseFeaturesLinkText} をご体験ください。", - "xpack.licenseMgmt.licenseDashboard.startTrial.platinumLicenseFeaturesLinkText": "プラチナ機能", - "xpack.licenseMgmt.licenseDashboard.startTrial.startTrialButtonLabel": "トライアルを開始", - "xpack.licenseMgmt.licenseDashboard.startTrialTitle": "30 日間のトライアルの開始", - "xpack.licenseMgmt.managementSectionDisplayName": "ライセンス管理", - "xpack.licenseMgmt.replacingCurrentLicenseWithBasicLicenseWarningMessage": "{currentLicenseType} ライセンスからベーシックライセンスにすると、一部機能が使えなくなります。下の機能のリストをご確認ください。", - "xpack.licenseMgmt.telemetryOptIn.customersHelpSupportDescription": "Elastic Support のサービス改善にご協力ください", - "xpack.licenseMgmt.telemetryOptIn.exampleLinkText": "例", - "xpack.licenseMgmt.telemetryOptIn.featureUsageWarningMessage": "この機能は定期的に基本的な機能利用に関する統計情報を送信します。この情報は Elastic 社外には共有されません。{exampleLink} をご覧いただくか、{telemetryPrivacyStatementLink} をお読みください。この機能はいつでも無効にできます。", - "xpack.licenseMgmt.telemetryOptIn.readMoreLinkText": "続きを読む", - "xpack.licenseMgmt.telemetryOptIn.sendBasicFeatureStatisticsLabel": "定期的に基本的な機能利用に関する統計情報を Elastic に送信します。{popover}", - "xpack.licenseMgmt.telemetryOptIn.telemetryPrivacyStatementLinkText": "遠隔測定に関するプライバシーステートメント", - "xpack.licenseMgmt.upload.breadcrumb": "アップロード", - "xpack.licenseMgmt.uploadLicense.cancelButtonLabel": "キャンセル", - "xpack.licenseMgmt.uploadLicense.checkLicenseFileErrorMessage": "{genericUploadError} ライセンスファイルを確認してください。", - "xpack.licenseMgmt.uploadLicense.confirmModal.cancelButtonLabel": "キャンセル", - "xpack.licenseMgmt.uploadLicense.confirmModal.confirmButtonLabel": "確認", - "xpack.licenseMgmt.uploadLicense.confirmModalTitle": "ライセンスのアップロードの確認", - "xpack.licenseMgmt.uploadLicense.expiredLicenseErrorMessage": "提供されたライセンスは期限切れです。", - "xpack.licenseMgmt.uploadLicense.genericUploadErrorMessage": "ライセンスのアップロード中にエラーが発生しました:", - "xpack.licenseMgmt.uploadLicense.invalidLicenseErrorMessage": "提供されたライセンスはこの製品に有効ではありません。", - "xpack.licenseMgmt.uploadLicense.licenseFileNotSelectedErrorMessage": "ライセンスファイルの選択が必要です。", - "xpack.licenseMgmt.uploadLicense.licenseKeyTypeDescription": "ライセンスキーは署名付きの JSON ファイルです。", - "xpack.licenseMgmt.uploadLicense.problemWithUploadedLicenseDescription": "{currentLicenseType} ライセンスから {newLicenseType} ライセンスにすると、一部機能が使えなくなります。下の機能のリストをご確認ください。", - "xpack.licenseMgmt.uploadLicense.replacingCurrentLicenseWarningMessage": "ライセンスを更新することにより、現在の {currentLicenseType} ライセンスが置き換えられます。", - "xpack.licenseMgmt.uploadLicense.selectLicenseFileDescription": "ライセンスファイルを選択するかドラッグしてください", - "xpack.licenseMgmt.uploadLicense.unknownErrorErrorMessage": "不明なエラー。", - "xpack.licenseMgmt.uploadLicense.uploadButtonLabel": "アップロード", - "xpack.licenseMgmt.uploadLicense.uploadingButtonLabel": "アップロード中…", - "xpack.licenseMgmt.uploadLicense.uploadLicenseTitle": "ライセンスのアップロード", - "xpack.logstash.addRoleAlert.grantAdditionalPrivilegesDescription": "Kibana の管理で、Kibana ユーザーに {role} ロールを割り当ててください。", - "xpack.logstash.addRoleAlert.grantAdditionalPrivilegesTitle": "追加権限の授与。", - "xpack.logstash.alertCallOut.howToSeeAdditionalPipelinesDescription": "追加パイプラインを表示させる方法", - "xpack.logstash.confirmDeleteModal.cancelButtonLabel": "キャンセル", - "xpack.logstash.confirmDeleteModal.deletedPipelineConfirmButtonLabel": "パイプラインを削除", - "xpack.logstash.confirmDeleteModal.deletedPipelinesConfirmButtonLabel": "{numPipelinesSelected} パイプラインを削除", - "xpack.logstash.confirmDeleteModal.deletedPipelinesTitle": "{numPipelinesSelected} パイプラインを削除", - "xpack.logstash.confirmDeleteModal.deletedPipelinesWarningMessage": "削除されたパイプラインは復元できません。", - "xpack.logstash.confirmDeleteModal.deletedPipelineTitle": "パイプライン「{id}」の削除", - "xpack.logstash.confirmDeleteModal.deletedPipelineWarningMessage": "削除されたパイプラインは復元できません。", - "xpack.logstash.confirmDeletePipelineModal.cancelButtonText": "キャンセル", - "xpack.logstash.confirmDeletePipelineModal.confirmButtonText": "パイプラインを削除", - "xpack.logstash.confirmDeletePipelineModal.deletePipelineTitle": "パイプライン「{id}」の削除", - "xpack.logstash.couldNotLoadPipelineErrorNotification": "パイプラインを読み込めませんでした。エラー「{errStatusText}」。", - "xpack.logstash.deletePipelineModalMessage": "削除されたパイプラインは復元できません。", - "xpack.logstash.enableMonitoringAlert.enableMonitoringDescription": "{configFileName} ファイルで、{monitoringConfigParam} と {monitoringUiConfigParam} を {trueValue} に設定します。", - "xpack.logstash.enableMonitoringAlert.enableMonitoringTitle": "監視を有効にする。", - "xpack.logstash.homeFeature.logstashPipelinesDescription": "データ投入パイプラインの作成、削除、更新、クローンの作成を行います。", - "xpack.logstash.homeFeature.logstashPipelinesTitle": "Logstash パイプライン", - "xpack.logstash.idFormatErrorMessage": "パイプライン ID は文字またはアンダーラインで始まる必要があり、文字、アンダーライン、ハイフン、数字のみ使用できます", - "xpack.logstash.insufficientUserPermissionsDescription": "Logstash パイプラインの管理に必要なユーザーパーミッションがありません", - "xpack.logstash.kibanaManagementPipelinesTitle": "Kibana の管理で作成されたパイプラインだけがここに表示されます", - "xpack.logstash.managementSection.createPipelineTitle": "パイプラインの作成", - "xpack.logstash.managementSection.editPipelineTitle": "パイプラインの編集", - "xpack.logstash.managementSection.enableSecurityDescription": "Logstash パイプライン管理機能を使用するには、セキュリティを有効にする必要があります。elasticsearch.yml で xpack.security.enabled: true に設定してください。", - "xpack.logstash.managementSection.licenseDoesNotSupportDescription": "ご使用の {licenseType} ライセンスは Logstash パイプライン管理をサポートしていません。ライセンスをアップグレードしてください。", - "xpack.logstash.managementSection.notPossibleToManagePipelinesMessage": "現在ライセンス情報が利用できないため Logstash パイプラインを使用できません。", - "xpack.logstash.managementSection.pipelineCrudOperationsNotAllowedDescription": "ご使用の {licenseType} ライセンスは期限切れのため、Logstash パイプラインの編集、作成、削除ができません。", - "xpack.logstash.managementSection.pipelinesTitle": "パイプライン", - "xpack.logstash.manualUpgradeButtonLabel": "再試行", - "xpack.logstash.newPipelineMessage": "パイプラインを追加する前に、構成をアップグレードする必要があります。", - "xpack.logstash.notManualUpgradeButtonLabel": "アップグレード", - "xpack.logstash.notManualUpgradeTitle": "アップグレードの時がやってきました!", - "xpack.logstash.notNewPipelineMessage": "このパイプラインを編集する前に、構成をアップグレードする必要があります。", - "xpack.logstash.pipelineBatchDelayTooltip": "パイプラインイベントバッチを作成する際、それぞれのイベントでパイプラインワーカーにサイズの小さなバッチを送る前に何ミリ秒間待つかです。\n\nデフォルト値:50ms", - "xpack.logstash.pipelineBatchSizeTooltip": "フィルターとアウトプットをを実行する前に各ワーカースレッドがインプットから収集するイベントの最低数です。基本的にバッチサイズが大きくなるほど効率が上がりますが、メモリーオーバーヘッドも大きくなります。このオプションを効率的に使用するには、LS_HEAP_SIZE 変数を設定して JVM のヒープサイズを増やす必要があるかもしれません。\n\nデフォルト値:125", - "xpack.logstash.pipelineEditor.cancelButtonLabel": "キャンセル", - "xpack.logstash.pipelineEditor.clonePipelineTitle": "「{id}」のクローンの作成", - "xpack.logstash.pipelineEditor.createAndDeployButtonLabel": "作成して導入", - "xpack.logstash.pipelineEditor.createPipelineTitle": "パイプラインの作成", - "xpack.logstash.pipelineEditor.deletePipelineButtonLabel": "パイプラインを削除", - "xpack.logstash.pipelineEditor.descriptionFormRowLabel": "説明", - "xpack.logstash.pipelineEditor.editPipelineTitle": "パイプライン「{id}」の編集", - "xpack.logstash.pipelineEditor.errorHandlerToastTitle": "パイプラインエラー", - "xpack.logstash.pipelineEditor.pipelineBatchDelayFormRowLabel": "パイプラインバッチの遅延", - "xpack.logstash.pipelineEditor.pipelineBatchSizeFormRowLabel": "パイプラインバッチのサイズ", - "xpack.logstash.pipelineEditor.pipelineFormRowLabel": "パイプライン", - "xpack.logstash.pipelineEditor.pipelineIdFormRowLabel": "パイプライン ID", - "xpack.logstash.pipelineEditor.pipelineSuccessfullyDeletedMessage": "「{id}」が削除されました", - "xpack.logstash.pipelineEditor.pipelineSuccessfullySavedMessage": "「{id}」が保存されました", - "xpack.logstash.pipelineEditor.pipelineWorkersFormRowLabel": "パイプラインワーカー", - "xpack.logstash.pipelineEditor.queueCheckpointWritesFormRowLabel": "キューチェックポイントの書き込み", - "xpack.logstash.pipelineEditor.queueMaxBytesFormRowLabel": "キューの最大バイト数", - "xpack.logstash.pipelineEditor.queueTypeFormRowLabel": "キュータイプ", - "xpack.logstash.pipelineIdRequiredMessage": "パイプライン ID が必要です", - "xpack.logstash.pipelineList.couldNotDeletePipelinesNotification": "{numErrors, plural, one {# パイプライン} other {# パイプライン}}の削除に失敗しました", - "xpack.logstash.pipelineList.head": "パイプライン", - "xpack.logstash.pipelineList.noPermissionToManageDescription": "管理者にお問い合わせください。", - "xpack.logstash.pipelineList.noPermissionToManageTitle": "Logstash パイプラインを変更するパーミッションがありません。", - "xpack.logstash.pipelineList.noPipelinesDescription": "パイプラインが定義されていません。", - "xpack.logstash.pipelineList.noPipelinesTitle": "パイプラインがありません", - "xpack.logstash.pipelineList.pipelineLoadingErrorNotification": "パイプラインを読み込めませんでした。エラー「{errStatusText}」。", - "xpack.logstash.pipelineList.pipelinesCouldNotBeDeletedDescription": "しかし {numErrors, plural, one {# パイプライン} other {# パイプライン}}を削除できませんでした。", - "xpack.logstash.pipelineList.pipelinesLoadingErrorDescription": "パイプラインの読み込み中にエラーが発生しました。", - "xpack.logstash.pipelineList.pipelinesLoadingErrorTitle": "エラー", - "xpack.logstash.pipelineList.pipelinesLoadingMessage": "パイプラインを読み込み中…", - "xpack.logstash.pipelineList.pipelinesSuccessfullyDeletedNotification": "「{id}」が削除されました", - "xpack.logstash.pipelineList.subhead": "Logstash イベントの処理を管理して結果を表示", - "xpack.logstash.pipelineList.successfullyDeletedPipelinesNotification": "{numPipelinesSelected, plural, one {# 本中} other {# 本中}}{numSuccesses} 本のパイプラインが削除されました", - "xpack.logstash.pipelineNotCentrallyManagedTooltip": "このパイプラインは集中構成管理で作成されませんでした。ここで管理または編集できません。", - "xpack.logstash.pipelines.createBreadcrumb": "作成", - "xpack.logstash.pipelines.listBreadcrumb": "パイプライン", - "xpack.logstash.pipelinesTable.cloneButtonLabel": "クローンを作成", - "xpack.logstash.pipelinesTable.createPipelineButtonLabel": "パイプラインの作成", - "xpack.logstash.pipelinesTable.deleteButtonLabel": "削除", - "xpack.logstash.pipelinesTable.descriptionColumnLabel": "説明", - "xpack.logstash.pipelinesTable.filterByIdLabel": "ID でフィルタリング", - "xpack.logstash.pipelinesTable.idColumnLabel": "Id", - "xpack.logstash.pipelinesTable.lastModifiedColumnLabel": "最終更新:", - "xpack.logstash.pipelinesTable.modifiedByColumnLabel": "変更者:", - "xpack.logstash.pipelinesTable.selectablePipelineMessage": "パイプライン「{id}」を選択します", - "xpack.logstash.queueCheckpointWritesTooltip": "永続キューが有効な場合にチェックポイントを強制する前に書き込むイベントの最大数です。無制限にするには 0 を指定します。\n\nデフォルト値:1024", - "xpack.logstash.queueMaxBytesTooltip": "バイト単位でのキューの合計容量です。ディスクドライブの容量がここで指定する値よりも大きいことを確認してください。\n\nデフォルト値:1024mb (1g)", - "xpack.logstash.queueTypes.memoryLabel": "メモリー", - "xpack.logstash.queueTypes.persistedLabel": "永続", - "xpack.logstash.queueTypeTooltip": "イベントのバッファーに使用する内部キューモデルです。レガシーインメモリ―ベースのキュー、または現存のディスクベースの ACK キューに使用するメモリーを指定します\n\nデフォルト値: メモリー", - "xpack.logstash.units.bytesLabel": "バイト", - "xpack.logstash.units.gigabytesLabel": "ギガバイト", - "xpack.logstash.units.kilobytesLabel": "キロバイト", - "xpack.logstash.units.megabytesLabel": "メガバイト", - "xpack.logstash.units.petabytesLabel": "ペタバイト", - "xpack.logstash.units.terabytesLabel": "テラバイト", - "xpack.logstash.upgradeFailedTitle": "アップグレード失敗", - "xpack.logstash.upgradeFailureActions.goBackButtonLabel": "戻る", - "xpack.logstash.upstreamPipelineArgumentMustContainAnIdPropertyErrorMessage": "upstreamPipeline 引数には id プロパティを含める必要があります", - "xpack.logstash.workersTooltip": "パイプラインのフィルターとアウトプットステージを同時に実行するワーカーの数です。イベントが詰まってしまう場合や CPU が飽和状態ではない場合は、マシンの処理能力をより有効に活用するため、この数字を上げてみてください。\n\nデフォルト値:ホストの CPU コア数です", - "xpack.maps.addLayerPanel.changeDataSourceButtonLabel": "データソースを変更", - "xpack.maps.addLayerPanel.chooseDataSourceTitle": "データソースの選択", - "xpack.maps.appDescription": "マップアプリケーション", - "xpack.maps.appTitle": "Maps", - "xpack.maps.badge.readOnly.text": "読み込み専用", - "xpack.maps.badge.readOnly.tooltip": "マップを保存できませんで", - "xpack.maps.esSearch.featureCountMsg": "{count} 件のドキュメントが見つかりました。", - "xpack.maps.esSearch.resultsTrimmedMsg": "結果は初めの {count} 件のドキュメントに制限されています。", - "xpack.maps.esSearch.topHitsEntitiesCountMsg": "{entityCount} 件のエントリーを発見.", - "xpack.maps.feature.appDescription": "Elasticsearch と Elastic Maps Service の地理空間データを閲覧します", - "xpack.maps.featureRegistry.mapsFeatureName": "Maps", - "xpack.maps.geoGrid.resolutionLabel": "グリッド解像度", - "xpack.maps.heatmap.colorRampLabel": "色の範囲", - "xpack.maps.heatmapLegend.coldLabel": "コールド", - "xpack.maps.heatmapLegend.hotLabel": "ホット", - "xpack.maps.inspector.centerLatLabel": "中央緯度", - "xpack.maps.inspector.centerLonLabel": "中央経度", - "xpack.maps.inspector.mapboxStyleTitle": "マップボックススタイル", - "xpack.maps.inspector.mapDetailsTitle": "マップの詳細", - "xpack.maps.inspector.mapDetailsViewHelpText": "マップステータスを表示します", - "xpack.maps.inspector.mapDetailsViewTitle": "マップの詳細", - "xpack.maps.inspector.zoomLabel": "ズーム:", - "xpack.maps.layer.layerHiddenTooltip": "レイヤーが非表示になっています。", - "xpack.maps.layer.loadWarningAriaLabel": "警告を読み込む", - "xpack.maps.layer.zoomFeedbackTooltip": "レイヤーはズームレベル {minZoom} から {maxZoom} の間で表示されます。", - "xpack.maps.layerControl.addLayerButtonLabel": "レイヤーを追加", - "xpack.maps.layerControl.closeLayerTOCButtonAriaLabel": "レイヤーパネルを畳む", - "xpack.maps.layerControl.layersTitle": "レイヤー", - "xpack.maps.layerControl.openLayerTOCButtonAriaLabel": "レイヤーパネルを拡張", - "xpack.maps.layerControl.tocEntry.editButtonAriaLabel": "レイヤーを編集", - "xpack.maps.layerControl.tocEntry.editButtonTitle": "レイヤーを編集", - "xpack.maps.layerControl.tocEntry.grabButtonAriaLabel": "レイヤーの並べ替え", - "xpack.maps.layerControl.tocEntry.grabButtonTitle": "レイヤーの並べ替え", - "xpack.maps.layerControl.tocEntry.hideDetailsButtonAriaLabel": "レイヤー詳細を非表示", - "xpack.maps.layerControl.tocEntry.hideDetailsButtonTitle": "レイヤー詳細を非表示", - "xpack.maps.layerControl.tocEntry.showDetailsButtonAriaLabel": "レイヤー詳細を表示", - "xpack.maps.layerControl.tocEntry.showDetailsButtonTitle": "レイヤー詳細を表示", - "xpack.maps.layerPanel.filterEditor.addFilterButtonLabel": "フィルターを追加します", - "xpack.maps.layerPanel.filterEditor.editFilterButtonLabel": "フィルターを編集", - "xpack.maps.layerPanel.filterEditor.emptyState.description": "フィルターを追加してレイヤーデータを絞ります。", - "xpack.maps.layerPanel.filterEditor.queryBarSubmitButtonLabel": "フィルターを設定", - "xpack.maps.layerPanel.filterEditor.title": "フィルター", - "xpack.maps.layerPanel.fitToBoundsAriaLabel": "境界に合わせる", - "xpack.maps.layerPanel.fitToBoundsButtonLabel": "合わせる", - "xpack.maps.layerPanel.footer.cancelButtonLabel": "キャンセル", - "xpack.maps.layerPanel.footer.closeButtonLabel": "閉じる", - "xpack.maps.layerPanel.footer.removeLayerButtonLabel": "レイヤーを削除", - "xpack.maps.layerPanel.footer.saveAndCloseButtonLabel": "保存して閉じる", - "xpack.maps.layerPanel.join.deleteJoinAriaLabel": "ジョブを削除", - "xpack.maps.layerPanel.join.deleteJoinTitle": "ジョブの削除", - "xpack.maps.layerPanel.join.noIndexPatternErrorMessage": "インデックスパターン {indexPatternId} が見つかりません", - "xpack.maps.layerPanel.joinEditor.addJoinAriaLabel": "結合を追加", - "xpack.maps.layerPanel.joinEditor.addJoinButtonLabel": "結合を追加", - "xpack.maps.layerPanel.joinEditor.termJoinsTitle": "用語結合", - "xpack.maps.layerPanel.joinExpression.joinPopoverTitle": "結合", - "xpack.maps.layerPanel.joinExpression.leftFieldLabel": "左のフィールド", - "xpack.maps.layerPanel.joinExpression.leftSourceLabel": "左のソース", - "xpack.maps.layerPanel.joinExpression.rightFieldLabel": "右のフィールド", - "xpack.maps.layerPanel.joinExpression.rightSourceLabel": "右のソース", - "xpack.maps.layerPanel.joinExpression.selectFieldPlaceholder": "フィールドを選択", - "xpack.maps.layerPanel.joinExpression.selectIndexPatternPlaceholder": "インデックスパターンを選択", - "xpack.maps.layerPanel.joinExpression.selectPlaceholder": "-- 選択 --", - "xpack.maps.layerPanel.layerSettingsTitle": "レイヤー設定", - "xpack.maps.layerPanel.metricsExpression.joinMustBeSetErrorMessage": "JOIN の設定が必要です", - "xpack.maps.layerPanel.metricsExpression.metricsPopoverTitle": "メトリック", - "xpack.maps.layerPanel.metricsExpression.useMetricsDescription": "{metricsLength, plural, one {してメトリックを使用します} other {してメトリックを使用します}}", - "xpack.maps.layerPanel.settingsPanel.layerNameLabel": "名前", - "xpack.maps.layerPanel.settingsPanel.layerTransparencyLabel": "レイヤーの透明度", - "xpack.maps.layerPanel.settingsPanel.unableToLoadTitle": "レイヤーを読み込めません", - "xpack.maps.layerPanel.settingsPanel.visibleZoomLabel": "レイヤー表示のズーム範囲", - "xpack.maps.layerPanel.sourceDetailsLabel": "ソースの詳細", - "xpack.maps.layerPanel.styleSettingsTitle": "レイヤースタイル", - "xpack.maps.layerTocActions.cloneLayerTitle": "レイヤーおクローンを作成", - "xpack.maps.layerTocActions.editLayerTitle": "レイヤーを編集", - "xpack.maps.layerTocActions.fitToDataTitle": "データに合わせる", - "xpack.maps.layerTocActions.hideLayerTitle": "レイヤーの非表示", - "xpack.maps.layerTocActions.layerActionsTitle": "レイヤー操作", - "xpack.maps.layerTocActions.noFitSupportTooltip": "レイヤーが「データに合わせる」をサポートしていません", - "xpack.maps.layerTocActions.showLayerTitle": "レイヤーの表示", - "xpack.maps.map.initializeErrorTitle": "マップを初期化できません", - "xpack.maps.mapController.fullScreenButtonLabel": "全画面", - "xpack.maps.mapController.fullScreenDescription": "全画面", - "xpack.maps.mapController.mapsBreadcrumbLabel": "マップ", - "xpack.maps.mapController.openInspectorButtonLabel": "検査", - "xpack.maps.mapController.openInspectorDescription": "インスペクターを開きます", - "xpack.maps.mapController.saveErrorMessage": "「{title}」の保存中にエラーが発生しました", - "xpack.maps.mapController.saveMapButtonLabel": "保存", - "xpack.maps.mapController.saveMapDescription": "マップを保存", - "xpack.maps.mapController.saveSuccessMessage": "「{title}」が保存されました", - "xpack.maps.mapListing.advancedSettingsLinkText": "高度な設定", - "xpack.maps.mapListing.cancelTitle": "キャンセル", - "xpack.maps.mapListing.createMapButtonLabel": "マップを作成", - "xpack.maps.mapListing.deleteSelectedButtonLabel": "選択項目を削除", - "xpack.maps.mapListing.deleteSelectedItemsTitle": "選択項目を削除しますか?", - "xpack.maps.mapListing.deleteTitle": "削除", - "xpack.maps.mapListing.deleteWarning": "削除されたアイテムは復元できません。", - "xpack.maps.mapListing.descriptionFieldTitle": "説明", - "xpack.maps.mapListing.limitExceededTitle": "リスティング制限超過", - "xpack.maps.mapListing.limitHelpDescription": "{totalItems} 個のアイテムがありますが、listingLimit の設定により {listingLimit} 個までしか下の表に表示できません。この設定は次の場所で変更できます ", - "xpack.maps.mapListing.listingTableTitle": "マップ", - "xpack.maps.mapListing.noItemsDescription": "マップがないようです。作成ボタンをクリックして作成してください。", - "xpack.maps.mapListing.noMatchDescription": "検索に一致するアイテムがありません。", - "xpack.maps.mapListing.searchAriaLabel": "フィルターアイテム", - "xpack.maps.mapListing.searchPlaceholder": "検索…", - "xpack.maps.mapListing.titleFieldTitle": "タイトル", - "xpack.maps.mapListing.unableToDeleteToastTitle": "マップを削除できません", - "xpack.maps.mapSavedObjectLabel": "マップ", - "xpack.maps.metricsEditor.addMetricButtonLabel": "メトリックを追加", - "xpack.maps.metricsEditor.deleteMetricAriaLabel": "メトリックを削除", - "xpack.maps.metricsEditor.deleteMetricButtonLabel": "メトリックを削除", - "xpack.maps.metricsEditor.selectFieldPlaceholder": "フィールドを選択", - "xpack.maps.metricSelect.averageDropDownOptionLabel": "平均", - "xpack.maps.metricSelect.countDropDownOptionLabel": "カウント", - "xpack.maps.metricSelect.maxDropDownOptionLabel": "最高", - "xpack.maps.metricSelect.minDropDownOptionLabel": "最低", - "xpack.maps.metricSelect.selectAggregationPlaceholder": "集約を選択", - "xpack.maps.metricSelect.sumDropDownOptionLabel": "合計", - "xpack.maps.noIndexPattern.doThisLinkTextDescription": "インデックスパターンを作成します", - "xpack.maps.noIndexPattern.doThisPrefixDescription": "次のことが必要です ", - "xpack.maps.noIndexPattern.doThisSuffixDescription": " 地理空間フィールドを含む", - "xpack.maps.noIndexPattern.getStartedLinkText": "サンプルデータセットで始めましょう。", - "xpack.maps.noIndexPattern.hintDescription": "地理空間データセットがありませんか?", - "xpack.maps.noIndexPattern.messageTitle": "地理空間フィールドを含むインデックスパターンが見つかりませんでした", - "xpack.maps.sampleData.ecommerceSpec.mapsTitle": "[e コマース] 国別の注文", - "xpack.maps.sampleData.flightaSpec.logsTitle": "[ログ ] 合計リクエスト数とバイト数", - "xpack.maps.sampleData.flightaSpec.mapsTitle": "[フライト] 出発地と目的地の飛行時間", - "xpack.maps.sampleDataLinkLabel": "マップ", - "xpack.maps.source.dataSourceLabel": "データソース", - "xpack.maps.source.ems_xyzDescription": "XYZ 座標を含む URL からのマップタイルです", - "xpack.maps.source.ems_xyzTitle": "URL からのタイルマップサービス", - "xpack.maps.source.ems.disabledDescription": "Elastic Maps Service へのアクセスが無効になっています。システム管理者に問い合わせるか、kibana.yml で「map.includeElasticMapsService」を設定してください。", - "xpack.maps.source.ems.noAccessDescription": "Kibana が Elastic Maps Service にアクセスできません。システム管理者にお問い合わせください", - "xpack.maps.source.emsFile.layerLabel": "レイヤー", - "xpack.maps.source.emsFile.selectPlaceholder": "EMS ベクターシェイプを選択", - "xpack.maps.source.emsFile.unableToFindIdErrorMessage": "ID {id} の EMS ベクターシェイプが見つかりません", - "xpack.maps.source.emsFileDescription": "Elastic Maps Service の行政区画のベクターシェイプ", - "xpack.maps.source.emsFileTitle": "ベクターシェイプ", - "xpack.maps.source.emsTile.errorMessage": "ID {id} の EMS タイル構成が見つかりません", - "xpack.maps.source.emsTile.label": "タイルサービス", - "xpack.maps.source.emsTile.serviceId": "タイルサービス", - "xpack.maps.source.emsTileDescription": "Elastic Maps Service のマップタイル", - "xpack.maps.source.emsTileTitle": "タイル", - "xpack.maps.source.esGeoGrid.geofieldLabel": "地理空間フィールド", - "xpack.maps.source.esGeoGrid.geofieldPlaceholder": "ジオフィールドを選択", - "xpack.maps.source.esGeoGrid.gridRectangleDropdownOption": "グリッド四角", - "xpack.maps.source.esGeoGrid.heatmapDropdownOption": "ヒートマップ", - "xpack.maps.source.esGeoGrid.indexPatternLabel": "インデックスパターン", - "xpack.maps.source.esGeoGrid.indexPatternPlaceholder": "インデックスパターンを選択", - "xpack.maps.source.esGeoGrid.pointsDropdownOption": "点", - "xpack.maps.source.esGeoGrid.showAsLabel": "表示形式", - "xpack.maps.source.esGeoGrid.showAsPlaceholder": "1 つのオプションを選択", - "xpack.maps.source.esGrid.coarseDropdownOption": "粗い", - "xpack.maps.source.esGrid.fineDropdownOption": "細かい", - "xpack.maps.source.esGrid.finestDropdownOption": "最も細かい", - "xpack.maps.source.esGrid.geospatialFieldLabel": "地理空間フィールド", - "xpack.maps.source.esGrid.indexPatternLabel": "インデックスパターン", - "xpack.maps.source.esGrid.inspectorDescription": "Elasticsearch ジオグリッド集約リクエスト", - "xpack.maps.source.esGrid.noIndexPatternErrorMessage": "インデックスパターン {id} が見つかりません", - "xpack.maps.source.esGrid.resolutionParamErrorMessage": "グリッド解像度パラメーターが認識されません: {resolution}", - "xpack.maps.source.esGrid.showasFieldLabel": "表示形式", - "xpack.maps.source.esGridDescription": "それぞれのグリッド付きセルのメトリックでグリッドにグループ分けされた地理空間データです。", - "xpack.maps.source.esGridTitle": "グリッド集約", - "xpack.maps.source.esJoin.joinDescription": "{description} の Elasticsearch 用語集約リクエストです", - "xpack.maps.source.esJoin.joinLeftDescription": "{leftSourceName}:{leftFieldName} を次と結合:", - "xpack.maps.source.esJoin.joinMetricsDescription": "メトリック {metrics} の", - "xpack.maps.source.esSearch.convertToGeoJsonErrorMsg": "検索への応答を geoJson 機能コレクションに変換できません。エラー: {errorMsg}", - "xpack.maps.source.esSearch.disableFilterByMapBoundsExplainMsg": "インデックス「{indexPatternTitle}」はドキュメント数が少なく、ダイナミックフィルターが必要ありません。", - "xpack.maps.source.esSearch.disableFilterByMapBoundsTitle": "ダイナミックデータフィルターは無効です", - "xpack.maps.source.esSearch.disableFilterByMapBoundsTurnOnMsg": "ドキュメント数が増えると思われる場合はダイナミックフィルターをオンにしてください。", - "xpack.maps.source.esSearch.extentFilterLabel": "マップの表示範囲でデータを動的にフィルタリング", - "xpack.maps.source.esSearch.geofieldLabel": "地理空間フィールド", - "xpack.maps.source.esSearch.geoFieldLabel": "地理空間フィールド", - "xpack.maps.source.esSearch.geoFieldTypeLabel": "地理空間フィールドタイプ", - "xpack.maps.source.esSearch.indexPatternLabel": "インデックスパターン", - "xpack.maps.source.esSearch.loadErrorMessage": "インデックスパターン {id} が見つかりません", - "xpack.maps.source.esSearch.loadTooltipPropertiesErrorMsg": "ドキュメントが見つかりません。_id: {docId}", - "xpack.maps.source.esSearch.selectIndexPatternPlaceholder": "インデックスパターンを選択", - "xpack.maps.source.esSearch.selectLabel": "ジオフィールドを選択", - "xpack.maps.source.esSearch.topHitsSizeLabel": "エンティティごとのドキュメント数", - "xpack.maps.source.esSearch.topHitsSplitFieldLabel": "エンティティ", - "xpack.maps.source.esSearch.topHitsSplitFieldSelectPlaceholder": "エンティティフィールドを選択", - "xpack.maps.source.esSearch.useTopHitsLabel": "エンティティによる最も最近のドキュメントを表示", - "xpack.maps.source.esSearchDescription": "Kibana インデックスパターンの地理空間データ", - "xpack.maps.source.esSearchTitle": "ドキュメント", - "xpack.maps.source.esSource.noGeoFieldErrorMessage": "インデックスパターン {indexPatternTitle} には現在ジオフィールド {geoField} が含まれていません", - "xpack.maps.source.esSource.noIndexPatternErrorMessage": "ID {indexPatternId} のインデックスパターンが見つかりません", - "xpack.maps.source.esSource.requestFailedErrorMessage": "Elasticsearch 検索リクエストに失敗。エラー: {message}", - "xpack.maps.source.kbnRegionMap.noConfigErrorMessage": "{name} の map.regionmap 構成が見つかりません", - "xpack.maps.source.kbnRegionMap.noLayerAvailableHelptext": "ベクターレイヤーが利用できません。システム管理者に、kibana.yml で「map.regionmap」を設定するよう依頼してください。", - "xpack.maps.source.kbnRegionMap.vectorLayerLabel": "ベクターレイヤー", - "xpack.maps.source.kbnRegionMapDescription": "kibana.yml で構成された静的ファイルのベクターシェイプです", - "xpack.maps.source.kbnRegionMapTitle": "カスタムベクターシェイプ", - "xpack.maps.source.kbnTMS.kbnTMS.urlLabel": "タイルマップ URL", - "xpack.maps.source.kbnTMS.noConfigErrorMessage": "kibana.yml に map.tilemap.url 構成が見つかりません", - "xpack.maps.source.kbnTMS.noLayerAvailableHelptext": "タイルマップレイヤーが利用できません。システム管理者に、kibana.yml で「map.tilemap.url」を設定するよう依頼してください。", - "xpack.maps.source.kbnTMS.urlLabel": "タイルマップ URL", - "xpack.maps.source.kbnTMSDescription": "kibana.yml で構成されたマップタイルです", - "xpack.maps.source.kbnTMSTitle": "カスタムタイルマップサービス", - "xpack.maps.source.urlLabel": "URL", - "xpack.maps.source.vetorSource.formatErrorMessage": "URL からベクターシェイプを取得できません: {format}", - "xpack.maps.source.vetorSource.requestFailedErrorMessage": "URL からベクターシェイプを取得できません: {fetchUrl}", - "xpack.maps.source.wms.getCapabilitiesButtonText": "負荷容量", - "xpack.maps.source.wms.getCapabilitiesErrorCalloutTitle": "サービスメタデータを読み込めません", - "xpack.maps.source.wms.layersHelpText": "レイヤー名のコンマ区切りのリストを使用します", - "xpack.maps.source.wms.layersLabel": "レイヤー", - "xpack.maps.source.wms.stylesHelpText": "スタイル名のコンマ区切りのリストを使用します", - "xpack.maps.source.wms.stylesLabel": "スタイル", - "xpack.maps.source.wms.urlLabel": "URL", - "xpack.maps.source.wmsDescription": "OGC スタンダード WMS のマップ", - "xpack.maps.source.wmsTitle": "ウェブマップサービス", - "xpack.maps.style.heatmap.displayNameLabel": "ヒートマップスタイル", - "xpack.maps.style.heatmap.resolutionStyleErrorMessage": "解像度パラメーターが認識されません: {resolution}", - "xpack.maps.styles.vector.borderColorLabel": "境界線の色", - "xpack.maps.styles.vector.borderWidthLabel": "境界線の幅", - "xpack.maps.styles.vector.fillColorLabel": "塗りつぶす色", - "xpack.maps.styles.vector.selectFieldPlaceholder": "フィールドを選択", - "xpack.maps.styles.vector.symbolSizeLabel": "シンボルのサイズ", - "xpack.maps.toolbarOverlay.drawBoundsLabel": "境界を描いてデータをフィルタリング", - "xpack.maps.toolbarOverlay.drawShapeLabel": "シェイプを描いてデータをフィルタリング", - "xpack.maps.toolbarOverlay.tools.toolbarTitle": "ツール", - "xpack.maps.tooltip.closeAriaLabel": "ツールヒントを閉じる", - "xpack.maps.tooltip.filterOnPropertyAriaLabel": "プロパティのフィルター", - "xpack.maps.tooltip.filterOnPropertyTitle": "プロパティのフィルター", - "xpack.maps.tooltip.loadingMsg": "読み込み中", - "xpack.maps.tooltip.unableToLoadContentTitle": "ツールヒントのコンテンツを読み込めません", - "xpack.maps.validatedRange.rangeErrorMessage": "{min} と {max} の間でなければなりません", - "xpack.maps.vector.symbolAs.circleLabel": "円", - "xpack.maps.vector.symbolAs.IconLabel": "アイコン", - "xpack.maps.vector.symbolLabel": "マーク", - "xpack.maps.vectorLayer.noResultsFoundTooltip": "結果が見つかりませんでした。", - "xpack.maps.vectorStyleEditor.featureTypeButtonGroupLegend": "ベクター機能ボタングループ", - "xpack.maps.vectorStyleEditor.lineLabel": "行", - "xpack.maps.vectorStyleEditor.pointLabel": "ポイント", - "xpack.maps.vectorStyleEditor.polygonLabel": "多角形", - "xpack.maps.viewControl.latLabel": "緯度:", - "xpack.maps.viewControl.lonLabel": "経度:", - "xpack.maps.common.esSpatialRelation.containsLabel": "contains", - "xpack.maps.common.esSpatialRelation.disjointLabel": "disjoint", - "xpack.maps.common.esSpatialRelation.intersectsLabel": "intersects", - "xpack.maps.common.esSpatialRelation.withinLabel": "within", - "xpack.maps.drawTooltip.boundsInstructions": "クリックして四角形を開始します。もう一度クリックして終了します。", - "xpack.maps.drawTooltip.polygonInstructions": "クリックして頂点を追加します。ダブルクリックして終了します。", - "xpack.maps.embeddableDisplayName": "マップ", - "xpack.maps.es_geo_utils.convert.unsupportedGeometryTypeErrorMessage": "{geometryType} ジオメトリから Geojson に変換できません。サポートされていません", - "xpack.maps.es_geo_utils.shapeFilter.geoPointRelationLabel": "次に含まれる:", - "xpack.maps.es_geo_utils.unsupportedFieldTypeErrorMessage": "サポートされていないフィールドタイプ、期待値: {expectedTypes}、提供された値: {fieldType}", - "xpack.maps.es_geo_utils.unsupportedGeometryTypeErrorMessage": "サポートされていないジオメトリタイプ、期待値: {expectedTypes}、提供された値: {geometryType}", - "xpack.maps.es_geo_utils.wkt.invalidWKTErrorMessage": "{wkt} を Geojson に変換できません。有効な WKT が必要です。", - "xpack.maps.geometryFilterForm.geoFieldLabel": "フィルタリングされたフィールド", - "xpack.maps.geometryFilterForm.geometryLabelLabel": "ジオメトリラベル", - "xpack.maps.geometryFilterForm.relationLabel": "空間関係", - "xpack.maps.layer.isUsingSearchMsg": "検索バーにより絞られた結果", - "xpack.maps.mapController.unsavedChangesWarning": "保存されていない変更は保存されない可能性があります", - "xpack.maps.mapEmbeddableFactory.invalidLayerList": "不正な形式のレイヤーリストによりマップを読み込めません", - "xpack.maps.mapEmbeddableFactory.invalidSavedObject": "不正な形式の保存済みオブジェクトによりマップを読み込めません", - "xpack.maps.setViewControl.goToButtonLabel": "移動:", - "xpack.maps.setViewControl.latitudeLabel": "緯度", - "xpack.maps.setViewControl.longitudeLabel": "経度", - "xpack.maps.setViewControl.submitButtonLabel": "Go", - "xpack.maps.setViewControl.zoomLabel": "ズーム:", - "xpack.maps.source.emsTile.autoLabel": "Kibana テーマに基づき自動選択", - "xpack.maps.source.emsTile.isAutoSelectLabel": "Kibana テーマに基づき自動選択", - "xpack.maps.source.geojsonFileDescription": "GeoJSON ファイルをアップデートして Elasticsearch にインデックス", - "xpack.maps.source.geojsonFileTitle": "GeoJSON ベクトルファイルのアップロード", - "xpack.maps.source.pewPew.destGeoFieldLabel": "送信先", - "xpack.maps.source.pewPew.destGeoFieldPlaceholder": "デスティネーション地理情報フィールドを選択", - "xpack.maps.source.pewPew.indexPatternLabel": "インデックスパターン", - "xpack.maps.source.pewPew.indexPatternPlaceholder": "インデックスパターンを選択", - "xpack.maps.source.pewPew.inspectorDescription": "ソースとデスティネーションの接続リクエスト", - "xpack.maps.source.pewPew.metricsLabel": "メトリック", - "xpack.maps.source.pewPew.noIndexPatternErrorMessage": "インデックスパターン {id} が見つかりません", - "xpack.maps.source.pewPew.noSourceAndDestDetails": "選択されたインデックスパターンにはソースとデスティネーションのフィールドが含まれていません。", - "xpack.maps.source.pewPew.sourceGeoFieldLabel": "送信元", - "xpack.maps.source.pewPew.sourceGeoFieldPlaceholder": "ソース地理情報フィールドを選択", - "xpack.maps.source.pewPewDescription": "ソースとデスティネーションの間の集約データパスです。", - "xpack.maps.source.pewPewTitle": "ソースとデスティネーションの接続", - "xpack.maps.source.wms.attributionLink": "属性テキストにはリンクが必要です", - "xpack.maps.source.wms.attributionText": "属性 URL にはテキストが必要です", - "xpack.maps.style.customColorRampLabel": "カスタマカラーランプ", - "xpack.maps.toolbarOverlay.drawBounds.initialGeometryLabel": "境界", - "xpack.maps.toolbarOverlay.drawShape.initialGeometryLabel": "図形", - "xpack.maps.tooltip.geometryFilterForm.createFilterButtonLabel": "フィルターを作成", - "xpack.maps.tooltip.pageNumerText": "{pageNumber} / {total}", - "xpack.maps.tooltip.showGeometryFilterViewLinkLabel": "ジオメトリでフィルタリング", - "xpack.maps.tooltip.toolsControl.cancelDrawButtonLabel": "キャンセル", - "xpack.maps.xyztmssource.attributionLink": "属性テキストにはリンクが必要です", - "xpack.maps.xyztmssource.attributionText": "属性 URL にはテキストが必要です", - "xpack.maps.layerPanel.settingsPanel.percentageLabel": "%", - "xpack.maps.layerPanel.settingsPanel.visibleZoom": "ズームレベル", - "xpack.maps.source.esSearch.sortFieldSelectPlaceholder": "ソートフィールドを選択", - "xpack.maps.toolbarOverlay.drawBoundsLabelShort": "境界を描く", - "xpack.maps.toolbarOverlay.drawShapeLabelShort": "図形を描く", - "xpack.maps.tooltipSelector.addLabelWithCount": "{count} を追加", - "xpack.maps.tooltipSelector.addLabelWithoutCount": "追加", - "xpack.maps.tooltipSelector.grabButtonAriaLabel": "プロパティを並べ替える", - "xpack.maps.tooltipSelector.grabButtonTitle": "プロパティを並べ替える", - "xpack.maps.tooltipSelector.togglePopoverLabel": "追加", - "xpack.maps.tooltipSelector.trashButtonAriaLabel": "プロパティを削除", - "xpack.maps.tooltipSelector.trashButtonTitle": "プロパティを削除", - "xpack.maps.vector.dualSize.unitLabel": "px", - "xpack.maps.vector.size.unitLabel": "px", - "xpack.ml.annotationsTable.actionsColumnName": "アクション", - "xpack.ml.annotationsTable.annotationColumnName": "注釈", - "xpack.ml.annotationsTable.annotationsNotCreatedTitle": "このジョブには注釈が作成されていません", - "xpack.ml.annotationsTable.editAnnotationsTooltip": "注釈を編集します", - "xpack.ml.annotationsTable.editAnnotationsTooltipAriaLabel": "注釈を編集します", - "xpack.ml.annotationsTable.fromColumnName": "開始値:", - "xpack.ml.annotationsTable.howToCreateAnnotationDescription": "注釈を作成するには、{linkToSingleMetricView} を開きます", - "xpack.ml.annotationsTable.howToCreateAnnotationDescription.singleMetricViewerLinkText": "シングルメトリックビューアー", - "xpack.ml.annotationsTable.jobConfigurationNotSupportedInSingleMetricViewerAriaLabel": "シングルメトリックビューアーでジョブ構成がサポートされていません", - "xpack.ml.annotationsTable.jobConfigurationNotSupportedInSingleMetricViewerTooltip": "シングルメトリックビューアーでジョブ構成がサポートされていません", - "xpack.ml.annotationsTable.jobIdColumnName": "ジョブ ID", - "xpack.ml.annotationsTable.labelColumnName": "ラベル", - "xpack.ml.annotationsTable.lastModifiedByColumnName": "最終更新者", - "xpack.ml.annotationsTable.lastModifiedDateColumnName": "最終更新日", - "xpack.ml.annotationsTable.openInSingleMetricViewerAriaLabel": "シングルメトリックビューアーで開く", - "xpack.ml.annotationsTable.openInSingleMetricViewerTooltip": "シングルメトリックビューアーで開く", - "xpack.ml.annotationsTable.toColumnName": "To", - "xpack.ml.anomaliesTable.actionsColumnName": "アクション", - "xpack.ml.anomaliesTable.actualSortColumnName": "実際", - "xpack.ml.anomaliesTable.anomalyDetails.actualTitle": "実際", - "xpack.ml.anomaliesTable.anomalyDetails.anomalyDescriptionListMoreLinkText": "他 {othersCount} 件", - "xpack.ml.anomaliesTable.anomalyDetails.anomalyDescriptionShowLessLinkText": "縮小表示", - "xpack.ml.anomaliesTable.anomalyDetails.anomalyDetailsTitle": "異常の詳細", - "xpack.ml.anomaliesTable.anomalyDetails.anomalyInLabel": "{anomalyDetector} の {anomalySeverity} の異常", - "xpack.ml.anomaliesTable.anomalyDetails.anomalyTimeRangeLabel": "{anomalyTime} から {anomalyEndTime}", - "xpack.ml.anomaliesTable.anomalyDetails.categoryExamplesTitle": "カテゴリーの例", - "xpack.ml.anomaliesTable.anomalyDetails.causeValuesDescription": "{causeEntityValue} (実際値 {actualValue}、通常値 {typicalValue}、確率 {probabilityValue})", - "xpack.ml.anomaliesTable.anomalyDetails.causeValuesTitle": "{causeEntityName} の値", - "xpack.ml.anomaliesTable.anomalyDetails.descriptionTitle": "説明", - "xpack.ml.anomaliesTable.anomalyDetails.detailsOnHighestSeverityAnomalyTitle": "深刻度が高い異常の詳細", - "xpack.ml.anomaliesTable.anomalyDetails.detailsTitle": "詳細", - "xpack.ml.anomaliesTable.anomalyDetails.detectedInLabel": " {sourcePartitionFieldName} {sourcePartitionFieldValue} で検知", - "xpack.ml.anomaliesTable.anomalyDetails.examplesTitle": "例", - "xpack.ml.anomaliesTable.anomalyDetails.fieldNameTitle": "fieldName", - "xpack.ml.anomaliesTable.anomalyDetails.foundForLabel": " {anomalyEntityName} {anomalyEntityValue} で発見", - "xpack.ml.anomaliesTable.anomalyDetails.functionTitle": "関数", - "xpack.ml.anomaliesTable.anomalyDetails.influencersTitle": "影響", - "xpack.ml.anomaliesTable.anomalyDetails.interimResultLabel": "中間結果", - "xpack.ml.anomaliesTable.anomalyDetails.jobIdTitle": "ジョブ ID", - "xpack.ml.anomaliesTable.anomalyDetails.multiBucketImpactTitle": "複数バケットの影響", - "xpack.ml.anomaliesTable.anomalyDetails.multivariateDescription": "{sourceByFieldName} で多変量相関が見つかりました; {sourceByFieldValue} は {sourceCorrelatedByFieldValue} のため異例とみなされます", - "xpack.ml.anomaliesTable.anomalyDetails.probabilityTitle": "確率", - "xpack.ml.anomaliesTable.anomalyDetails.regexDescriptionAriaLabel": "説明", - "xpack.ml.anomaliesTable.anomalyDetails.regexDescriptionTooltip": "カテゴリーが一致する値を検索するのに使用される正規表現です ({maxChars} 文字の制限で切り捨てられている可能性があります)", - "xpack.ml.anomaliesTable.anomalyDetails.regexTitle": "正規表現", - "xpack.ml.anomaliesTable.anomalyDetails.termsDescriptionAriaLabel": "説明", - "xpack.ml.anomaliesTable.anomalyDetails.termsDescriptionTooltip": "カテゴリーの値で一致している共通のトークンのスペース区切りのリストです (({maxChars} 文字の制限で切り捨てられている可能性があります)", - "xpack.ml.anomaliesTable.anomalyDetails.termsTitle": "用語", - "xpack.ml.anomaliesTable.anomalyDetails.timeTitle": "時間", - "xpack.ml.anomaliesTable.anomalyDetails.typicalTitle": "通常", - "xpack.ml.anomaliesTable.categoryExamplesColumnName": "カテゴリーの例", - "xpack.ml.anomaliesTable.detectorCell.rulesConfiguredTooltip": "この検知器にはルールが構成されています", - "xpack.ml.anomaliesTable.detectorColumnName": "検知器", - "xpack.ml.anomaliesTable.entityCell.addFilterAriaLabel": "フィルターを追加", - "xpack.ml.anomaliesTable.entityCell.addFilterTooltip": "フィルターを追加します", - "xpack.ml.anomaliesTable.entityCell.removeFilterAriaLabel": "フィルターを削除", - "xpack.ml.anomaliesTable.entityCell.removeFilterTooltip": "フィルターを削除します", - "xpack.ml.anomaliesTable.entityValueColumnName": "検索条件:", - "xpack.ml.anomaliesTable.hideDetailsAriaLabel": "詳細を非表示", - "xpack.ml.anomaliesTable.influencersCell.addFilterAriaLabel": "フィルターを追加します", - "xpack.ml.anomaliesTable.influencersCell.addFilterTooltip": "フィルターを追加します", - "xpack.ml.anomaliesTable.influencersCell.moreInfluencersLinkText": "他 {othersCount} 件", - "xpack.ml.anomaliesTable.influencersCell.removeFilterAriaLabel": "フィルターを削除します", - "xpack.ml.anomaliesTable.influencersCell.removeFilterTooltip": "フィルターを削除します", - "xpack.ml.anomaliesTable.influencersCell.showLessInfluencersLinkText": "縮小表示", - "xpack.ml.anomaliesTable.influencersColumnName": "影響元", - "xpack.ml.anomaliesTable.jobIdColumnName": "ジョブ ID", - "xpack.ml.anomaliesTable.linksMenu.configureRulesLabel": "ルールを構成", - "xpack.ml.anomaliesTable.linksMenu.loadingDetailsErrorMessage": "カテゴリー ID {categoryId} の詳細の読み込み中にエラーが発生したため例を表示できません", - "xpack.ml.anomaliesTable.linksMenu.noMappingCouldBeFoundErrorMessage": "カテゴリー分けフィールド {categorizationFieldName} のマッピングが見つからなかったため、ML カテゴリー {categoryId} のドキュメントの例を表示できません", - "xpack.ml.anomaliesTable.linksMenu.selectActionAriaLabel": "{time} の異常のアクションを選択", - "xpack.ml.anomaliesTable.linksMenu.unableToOpenLinkErrorMessage": "カテゴリー ID {categoryId} の詳細の読み込み中にエラーが発生したためリンクを開けません", - "xpack.ml.anomaliesTable.linksMenu.unableToViewExamplesErrorMessage": "ジョブ ID {jobId} の詳細が見つからなかったため例を表示できません", - "xpack.ml.anomaliesTable.linksMenu.viewExamplesLabel": "例を表示", - "xpack.ml.anomaliesTable.linksMenu.viewSeriesLabel": "数列を表示", - "xpack.ml.anomaliesTable.metricDescriptionSortColumnName": "説明", - "xpack.ml.anomaliesTable.noMatchingAnomaliesFoundTitle": "一致する注釈が見つかりません", - "xpack.ml.anomaliesTable.severityColumnName": "深刻度", - "xpack.ml.anomaliesTable.showDetailsAriaLabel": "詳細を表示", - "xpack.ml.anomaliesTable.timeColumnName": "時間", - "xpack.ml.anomaliesTable.typicalSortColumnName": "通常", - "xpack.ml.anomalyExplorerPageLabel": "異常エクスプローラー", - "xpack.ml.anomalyUtils.multiBucketImpact.highLabel": "高", - "xpack.ml.anomalyUtils.multiBucketImpact.lowLabel": "低", - "xpack.ml.anomalyUtils.multiBucketImpact.mediumLabel": "中", - "xpack.ml.anomalyUtils.multiBucketImpact.noneLabel": "なし", - "xpack.ml.anomalyUtils.severity.criticalLabel": "致命的", - "xpack.ml.anomalyUtils.severity.majorLabel": "メジャー", - "xpack.ml.anomalyUtils.severity.minorLabel": "マイナー", - "xpack.ml.anomalyUtils.severity.unknownLabel": "不明", - "xpack.ml.anomalyUtils.severity.warningLabel": "警告", - "xpack.ml.anomalyUtils.severityWithLow.lowLabel": "低", - "xpack.ml.calendarsEdit.calendarForm.allowedCharactersDescription": "アルファベットの小文字 (a-z と 0-9)、ハイフンまたはアンダーラインを使用し、最初と最後を英数字にする必要があります", - "xpack.ml.calendarsEdit.calendarForm.calendarIdLabel": "カレンダー ID", - "xpack.ml.calendarsEdit.calendarForm.calendarTitle": "カレンダー {calendarId}", - "xpack.ml.calendarsEdit.calendarForm.cancelButtonLabel": "キャンセル", - "xpack.ml.calendarsEdit.calendarForm.createCalendarTitle": "新規カレンダーの作成", - "xpack.ml.calendarsEdit.calendarForm.descriptionLabel": "説明", - "xpack.ml.calendarsEdit.calendarForm.eventsLabel": "イベント", - "xpack.ml.calendarsEdit.calendarForm.groupsLabel": "グループ", - "xpack.ml.calendarsEdit.calendarForm.jobsLabel": "ジョブ", - "xpack.ml.calendarsEdit.calendarForm.saveButtonLabel": "保存", - "xpack.ml.calendarsEdit.calendarForm.savingButtonLabel": "保存中…", - "xpack.ml.calendarsEdit.canNotCreateCalendarWithExistingIdErrorMessag": "ID [{formCalendarId}] は既に存在するため、この ID でカレンダーを作成できません。", - "xpack.ml.calendarsEdit.errorWithCreatingCalendarErrorMessage": "カレンダー {calendarId} の作成中にエラーが発生しました", - "xpack.ml.calendarsEdit.errorWithFetchingJobSummariesErrorMessage": "ジョブ概要の取得中にエラーが発生しました: {err}", - "xpack.ml.calendarsEdit.errorWithLoadingCalendarFromDataErrorMessage": "データからカレンダーを読み込み中にエラーが発生しました。ページを更新してみてください。", - "xpack.ml.calendarsEdit.errorWithLoadingCalendarsErrorMessage": "カレンダーの読み込み中にエラーが発生しました: {err}", - "xpack.ml.calendarsEdit.errorWithLoadingGroupsErrorMessage": "グループの読み込み中にエラーが発生しました: {err}", - "xpack.ml.calendarsEdit.errorWithUpdatingCalendarErrorMessage": "カレンダー {calendarId} の保存中にエラーが発生しました。ページを更新してみてください。", - "xpack.ml.calendarsEdit.eventsTable.cancelButtonLabel": "キャンセル", - "xpack.ml.calendarsEdit.eventsTable.deleteButtonLabel": "削除", - "xpack.ml.calendarsEdit.eventsTable.descriptionColumnName": "説明", - "xpack.ml.calendarsEdit.eventsTable.endColumnName": "終了", - "xpack.ml.calendarsEdit.eventsTable.importButtonLabel": "インポート", - "xpack.ml.calendarsEdit.eventsTable.importEventsButtonLabel": "イベントをインポート", - "xpack.ml.calendarsEdit.eventsTable.importEventsDescription": "ICS ファイルからイベントをインポートします。", - "xpack.ml.calendarsEdit.eventsTable.importEventsTitle": "イベントのインポート", - "xpack.ml.calendarsEdit.eventsTable.newEventButtonLabel": "新規イベント", - "xpack.ml.calendarsEdit.eventsTable.startColumnName": "開始", - "xpack.ml.calendarsEdit.importedEvents.eventsToImportTitle": "インポートするイベント: {eventsCount}", - "xpack.ml.calendarsEdit.importedEvents.includePastEventsLabel": "過去のイベントを含める", - "xpack.ml.calendarsEdit.importedEvents.recurringEventsNotSupportedDescription": "定期イベントはサポートされていません。初めのイベントのみがインポートされます。", - "xpack.ml.calendarsEdit.importModal.couldNotParseICSFileErrorMessage": "ICS ファイルをパースできませんでした。", - "xpack.ml.calendarsEdit.importModal.selectOrDragAndDropFilePromptText": "ファイルを選択するかドラッグ & ドロップしてください", - "xpack.ml.calendarsEdit.newEventModal.addButtonLabel": "追加", - "xpack.ml.calendarsEdit.newEventModal.cancelButtonLabel": "キャンセル", - "xpack.ml.calendarsEdit.newEventModal.createNewEventTitle": "新規イベントの作成", - "xpack.ml.calendarsEdit.newEventModal.descriptionLabel": "説明", - "xpack.ml.calendarsEdit.newEventModal.endDateAriaLabel": "終了日", - "xpack.ml.calendarsEdit.newEventModal.fromLabel": "開始:", - "xpack.ml.calendarsEdit.newEventModal.startDateAriaLabel": "開始日", - "xpack.ml.calendarsEdit.newEventModal.toLabel": "終了:", - "xpack.ml.calendarsList.deleteCalendars.calendarsLabel": "{calendarsToDeleteCount} 件のカレンダー", - "xpack.ml.calendarsList.deleteCalendars.deletingCalendarErrorMessage": "カレンダー {calendarId} の削除中にエラーが発生しました: {errorMessage}", - "xpack.ml.calendarsList.deleteCalendars.deletingCalendarsNotificationMessage": "{messageId} を削除中", - "xpack.ml.calendarsList.deleteCalendars.deletingCalendarSuccessNotificationMessage": "{messageId} が選択されました", - "xpack.ml.calendarsList.deleteCalendarsModal.cancelButtonLabel": "キャンセル", - "xpack.ml.calendarsList.deleteCalendarsModal.deleteButtonLabel": "削除", - "xpack.ml.calendarsList.deleteCalendarsModal.deleteCalendarsDescription": "{calendarsCount, plural, one {このカレンダー} other {これらのカレンダー}}を削除しますか?{calendarsList}", - "xpack.ml.calendarsList.deleteCalendarsModal.deleteCalendarTitle": "カレンダーの削除", - "xpack.ml.calendarsList.errorWithLoadingListOfCalendarsErrorMessage": "カレンダーのリストの読み込み中にエラーが発生しました。", - "xpack.ml.calendarsList.table.deleteButtonLabel": "削除", - "xpack.ml.calendarsList.table.eventsColumnName": "イベント", - "xpack.ml.calendarsList.table.eventsCountLabel": "{eventsLength, plural, one {# イベント} other {# イベント}}", - "xpack.ml.calendarsList.table.idColumnName": "ID", - "xpack.ml.calendarsList.table.jobsColumnName": "ジョブ", - "xpack.ml.calendarsList.table.newButtonLabel": "新規", - "xpack.ml.checkLicense.licenseHasExpiredMessage": "{licenseTypeName} 機械学習ライセンスが期限切れになりました。", - "xpack.ml.checkLicense.licenseInformationNotAvailableThisTimeMessage": "現在ライセンス情報が利用できないため機械学習を使用できません。", - "xpack.ml.checkLicense.mlIsUnavailableMessage": "機械学習が利用できません", - "xpack.ml.controls.checkboxShowCharts.showChartsCheckboxLabel": "チャートを表示", - "xpack.ml.controls.selectInterval.autoLabel": "自動", - "xpack.ml.controls.selectInterval.dayLabel": "1 日", - "xpack.ml.controls.selectInterval.hourLabel": "1 時間", - "xpack.ml.controls.selectInterval.showAllLabel": "すべて表示", - "xpack.ml.controls.selectSeverity.criticalLabel": "致命的", - "xpack.ml.controls.selectSeverity.majorLabel": "メジャー", - "xpack.ml.controls.selectSeverity.minorLabel": "マイナー", - "xpack.ml.controls.selectSeverity.scoreDetailsDescription": "スコア {value} 以上", - "xpack.ml.controls.selectSeverity.warningLabel": "警告", - "xpack.ml.customUrlEditor.discoverLabel": "ディスカバリ", - "xpack.ml.customUrlEditor.kibanaDashboardLabel": "Kibana ダッシュボード", - "xpack.ml.customUrlEditor.otherLabel": "その他", - "xpack.ml.customUrlEditorList.deleteCustomUrlAriaLabel": "カスタム URL を削除", - "xpack.ml.customUrlEditorList.deleteCustomUrlTooltip": "カスタム URL を削除します", - "xpack.ml.customUrlEditorList.invalidTimeRangeFormatErrorMessage": "無効なフォーマット", - "xpack.ml.customUrlEditorList.labelIsNotUniqueErrorMessage": "固有のラベルが供給されました", - "xpack.ml.customUrlEditorList.labelLabel": "ラベル", - "xpack.ml.customUrlEditorList.obtainingUrlToTestConfigurationErrorMessage": "構成をテストするための URL の取得中にエラーが発生しました", - "xpack.ml.customUrlEditorList.testCustomUrlAriaLabel": "カスタム URL をテスト", - "xpack.ml.customUrlEditorList.testCustomUrlTooltip": "カスタム URL をテストします", - "xpack.ml.customUrlEditorList.timeRangeLabel": "時間範囲", - "xpack.ml.customUrlEditorList.urlLabel": "URL", - "xpack.ml.customUrlsEditor.createNewCustomUrlTitle": "新規カスタム URL の作成", - "xpack.ml.customUrlsEditor.dashboardNameLabel": "ダッシュボード名", - "xpack.ml.customUrlsEditor.indexPatternLabel": "インデックスパターン", - "xpack.ml.customUrlsEditor.intervalLabel": "間隔", - "xpack.ml.customUrlsEditor.invalidLabelErrorMessage": "固有のラベルが供給されました", - "xpack.ml.customUrlsEditor.labelLabel": "ラベル", - "xpack.ml.customUrlsEditor.linkToLabel": "リンク先", - "xpack.ml.customUrlsEditor.queryEntitiesLabel": "エントリーをクエリ", - "xpack.ml.customUrlsEditor.selectEntitiesPlaceholder": "エントリーを選択", - "xpack.ml.customUrlsEditor.timeRangeLabel": "時間範囲", - "xpack.ml.customUrlsEditor.urlLabel": "URL", - "xpack.ml.customUrlsList.invalidIntervalFormatErrorMessage": "無効な間隔のフォーマット", - "xpack.ml.datavisualizer.selector.dataVisualizerDescription": "機械学習データビジュアライザーツールは、ログファイルのメトリックとフィールド、または既存の Elasticsearch インデックスを分析し、データの理解を助けます。", - "xpack.ml.datavisualizer.selector.dataVisualizerTitle": "データビジュアライザー", - "xpack.ml.datavisualizer.selector.experimentalBadgeLabel": "実験的", - "xpack.ml.datavisualizer.selector.experimentalBadgeTooltipLabel": "実験的機能。フィードバックをお待ちしています。", - "xpack.ml.datavisualizer.selector.importDataDescription": "ログファイルからデータをインポートします。最大 100 MB のファイルをアップロードできます。", - "xpack.ml.datavisualizer.selector.importDataTitle": "データのインポート", - "xpack.ml.datavisualizer.selector.selectIndexButtonLabel": "インデックスを選択", - "xpack.ml.datavisualizer.selector.selectIndexPatternDescription": "既存の Elasticsearch インデックスのデータを可視化します。", - "xpack.ml.datavisualizer.selector.selectIndexPatternTitle": "インデックスパターンの選択", - "xpack.ml.datavisualizer.selector.startTrialButtonLabel": "トライアルを開始", - "xpack.ml.datavisualizer.selector.startTrialTitle": "トライアルを開始", - "xpack.ml.datavisualizer.selector.uploadFileButtonLabel": "ファイルをアップロード", - "xpack.ml.dataVisualizerPageLabel": "データビジュアライザー", - "xpack.ml.explorer.annotationsTitle": "注釈", - "xpack.ml.explorer.anomaliesTitle": "異常", - "xpack.ml.explorer.anomalyTimelineTitle": "異常のタイムライン", - "xpack.ml.explorer.charts.detectorLabel": "「{fieldName}」で分割された {detectorLabel}{br} Y 軸イベントの分布", - "xpack.ml.explorer.charts.infoTooltip.aggregationIntervalTitle": "集約間隔", - "xpack.ml.explorer.charts.infoTooltip.chartEventDistributionDescription": "グレーの点は、{byFieldValuesParam} のサンプルの一定期間のオカレンスのおおよその分布を示しており、より頻繁なイベントタイプが上に、頻繁ではないものが下に表示されます。", - "xpack.ml.explorer.charts.infoTooltip.chartFunctionTitle": "チャート関数", - "xpack.ml.explorer.charts.infoTooltip.chartPopulationDistributionDescription": "グレーの点は、{overFieldValuesParam} のサンプルの一定期間の値のおおよその分布を示しています。", - "xpack.ml.explorer.charts.infoTooltip.jobIdTitle": "ジョブ ID", - "xpack.ml.explorer.charts.openInSingleMetricViewerButtonLabel": "シングルメトリックビューアーで開く", - "xpack.ml.explorer.charts.tooManyBucketsDescription": "この選択は、表示するバケット数が多すぎます。ダッシュボードは短い時間範囲で表示するのが最適です。", - "xpack.ml.explorer.charts.viewLabel": "表示", - "xpack.ml.explorer.createNewJobLinkText": "新規ジョブを作成", - "xpack.ml.explorer.fetchingSuggestionsErrorMessage": "提案の取得中にエラーが発生しました", - "xpack.ml.explorer.intervalLabel": "間隔", - "xpack.ml.explorer.invalidKuerySyntaxErrorMessage": "無効な Kuery 構文", - "xpack.ml.explorer.invalidKuerySyntaxErrorMessageFromTable": "クエリバーに無効な構文。インプットは有効な Kibana クエリ言語 (KQL) でなければなりません", - "xpack.ml.explorer.jobIdLabel": "ジョブ ID", - "xpack.ml.explorer.jobScoreAcrossAllInfluencersLabel": "(すべての影響因子のジョブスコア)", - "xpack.ml.explorer.kueryBar.filterPlaceholder": "影響因子フィールドでフィルタリング… ({queryExample})", - "xpack.ml.explorer.limitLabel": "制限", - "xpack.ml.explorer.loadingLabel": "読み込み中", - "xpack.ml.explorer.noConfiguredInfluencersTooltip": "選択されたジョブに影響因子が構成されていないため、トップインフルエンスリストは非表示になっています。", - "xpack.ml.explorer.noInfluencersFoundTitle": "{viewBySwimlaneFieldName}影響因子が見つかりません", - "xpack.ml.explorer.noInfluencersFoundTitleFilterMessage": "指定されたフィルターの {viewBySwimlaneFieldName} 影響因子が見つかりません", - "xpack.ml.explorer.noJobsFoundLabel": "ジョブが見つかりません", - "xpack.ml.explorer.noResultsFoundLabel": "結果が見つかりませんでした", - "xpack.ml.explorer.overallLabel": "全体", - "xpack.ml.explorer.overallSwimlaneUnfilteredLabel": "{label} (フィルタリングなし)", - "xpack.ml.explorer.severityThresholdLabel": "深刻度のしきい値", - "xpack.ml.explorer.sortedByMaxAnomalyScoreForTimeFormattedLabel": "({viewByLoadedForTimeFormatted} の最高異常スコアで分類)", - "xpack.ml.explorer.sortedByMaxAnomalyScoreLabel": "(最高異常スコアで分類)", - "xpack.ml.explorer.topInfuencersTitle": "トップ影響因子", - "xpack.ml.explorer.tryWideningTimeSelectionLabel": "時間範囲を広げるか、さらに過去に遡ってみてください", - "xpack.ml.explorer.viewByLabel": "表示方式", - "xpack.ml.feature.reserved.description": "ユーザーアクセスを許可するには、machine_learning_user か machine_learning_admin ロールのどちらかを割り当てる必要があります。", - "xpack.ml.featureRegistry.mlFeatureName": "機械学習", - "xpack.ml.fieldDataCard.cardBoolean.valuesLabel": "値", - "xpack.ml.fieldDataCard.cardDocumentCount.calculatedOverAllDocumentsLabel": "全ドキュメントで計算", - "xpack.ml.fieldDataCard.cardIp.topValuesLabel": "トップの値", - "xpack.ml.fieldDataCard.cardKeyword.topValuesLabel": "トップの値", - "xpack.ml.fieldDataCard.cardNumber.details.distributionOfValuesLabel": "値の分布", - "xpack.ml.fieldDataCard.cardNumber.details.topValuesLabel": "トップの値", - "xpack.ml.fieldDataCard.cardNumber.maxLabel": "最高", - "xpack.ml.fieldDataCard.cardNumber.medianLabel": "中間", - "xpack.ml.fieldDataCard.cardNumber.minLabel": "最低", - "xpack.ml.fieldDataCard.cardOther.cardTypeLabel": "{cardType} タイプ", - "xpack.ml.fieldDataCard.cardText.fieldMayBePopulatedDescription": "たとえば、ドキュメントマッピングで {copyToParam} パラメーターを使ったり、{includesParam} と {excludesParam} パラメーターを使用してインデックスした後に {sourceParam} フィールドから切り取ったりして入力される場合があります。", - "xpack.ml.fieldDataCard.loadingLabel": "読み込み中", - "xpack.ml.fieldTitleBar.documentCountLabel": "ドキュメントカウント", - "xpack.ml.fieldTypeIcon.booleanTypeAriaLabel": "ブールタイプ", - "xpack.ml.fieldTypeIcon.dateTypeAriaLabel": "日付タイプ", - "xpack.ml.fieldTypeIcon.fieldTypeTooltip": "{type} タイプ", - "xpack.ml.fieldTypeIcon.geoPointTypeAriaLabel": "{geoPointParam} タイプ", - "xpack.ml.fieldTypeIcon.ipTypeAriaLabel": "IP タイプ", - "xpack.ml.fieldTypeIcon.keywordTypeAriaLabel": "キーワードタイプ", - "xpack.ml.fieldTypeIcon.numberTypeAriaLabel": "数字タイプ", - "xpack.ml.fieldTypeIcon.textTypeAriaLabel": "テキストタイプ", - "xpack.ml.fieldTypeIcon.unknownTypeAriaLabel": "不明なタイプ", - "xpack.ml.fileDatavisualizer.aboutPanel.analyzingDataTitle": "データを分析中", - "xpack.ml.fileDatavisualizer.aboutPanel.selectOrDragAndDropFileDescription": "ファイルを選択するかドラッグ & ドロップしてください", - "xpack.ml.fileDatavisualizer.advancedImportSettings.createIndexPatternLabel": "インデックスパターンを作成", - "xpack.ml.fileDatavisualizer.advancedImportSettings.indexNameAriaLabel": "インデックス名、必須フィールド", - "xpack.ml.fileDatavisualizer.advancedImportSettings.indexNameLabel": "インデックス名", - "xpack.ml.fileDatavisualizer.advancedImportSettings.indexNamePlaceholder": "インデックス名", - "xpack.ml.fileDatavisualizer.advancedImportSettings.indexPatternNameLabel": "インデックスパターン名", - "xpack.ml.fileDatavisualizer.advancedImportSettings.indexSettingsLabel": "インデックス設定", - "xpack.ml.fileDatavisualizer.advancedImportSettings.ingestPipelineLabel": "パイプラインを投入", - "xpack.ml.fileDatavisualizer.advancedImportSettings.mappingsLabel": "マッピング", - "xpack.ml.fileDatavisualizer.analysisSummary.analyzedLinesNumberTitle": "分析した行数", - "xpack.ml.fileDatavisualizer.analysisSummary.delimiterTitle": "区切り記号", - "xpack.ml.fileDatavisualizer.analysisSummary.formatTitle": "フォーマット", - "xpack.ml.fileDatavisualizer.analysisSummary.grokPatternTitle": "Grok パターン", - "xpack.ml.fileDatavisualizer.analysisSummary.hasHeaderRowTitle": "ヘッダー行があります", - "xpack.ml.fileDatavisualizer.analysisSummary.summaryTitle": "概要", - "xpack.ml.fileDatavisualizer.analysisSummary.timeFieldTitle": "時間フィールド", - "xpack.ml.fileDatavisualizer.analysisSummary.timeFormatTitle": "時間 {timestampFormats, plural, zero {format} one {format} other {formats}}", - "xpack.ml.fileDatavisualizer.bottomBar.backButtonLabel": "戻る", - "xpack.ml.fileDatavisualizer.bottomBar.cancelButtonLabel": "キャンセル", - "xpack.ml.fileDatavisualizer.bottomBar.readMode.cancelButtonLabel": "キャンセル", - "xpack.ml.fileDatavisualizer.bottomBar.readMode.importButtonLabel": "インポート", - "xpack.ml.fileDatavisualizer.editFlyout.applyOverrideSettingsButtonLabel": "適用", - "xpack.ml.fileDatavisualizer.editFlyout.closeOverrideSettingsButtonLabel": "閉じる", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.customDelimiterFormRowLabel": "カスタム区切り記号", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.customTimestampFormatErrorMessage": "タイムスタンプのフォーマットは、これらの Java 日付/時刻フォーマットの組み合わせでなければなりません:\n yy, yyyy, M, MM, MMM, MMMM, d, dd, EEE, EEEE, H, HH, h, mm, ss, S through SSSSSSSSS, a, XX, XXX, zzz", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.customTimestampFormatFormRowLabel": "カスタムタイムスタンプフォーマット", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.dataFormatFormRowLabel": "データフォーマット", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.delimiterFormRowLabel": "区切り記号", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.editFieldNamesTitle": "フィールド名の編集", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.grokPatternFormRowLabel": "Grok パターン", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.hasHeaderRowLabel": "ヘッダー行があります", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.linesToSampleErrorMessage": "値は {min} よりも大きく {max} 以下でなければなりません", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.linesToSampleFormRowLabel": "サンプルする行数", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.quoteCharacterFormRowLabel": "引用符", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.timeFieldFormRowLabel": "時間フィールド", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampEmptyValidationErrorMessage": "タイムスタンプフォーマットにタイムフォーマット文字グループがありません {timestampFormat}", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampFormatFormRowLabel": "タイムスタンプフォーマット", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampFormatHelpText": "対応フォーマットの詳細をご覧ください", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampLetterSValidationErrorMessage": "{format} の文字 { length, plural, one { {lg} } other { グループ {lg} } } は、ss と {sep} からの区切りで始まっていないため、サポートされていません", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampLetterValidationErrorMessage": "{format} の文字 { length, plural, one { {lg} } other { グループ {lg} } } はサポートされていません", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampQuestionMarkValidationErrorMessage": "タイムスタンプフォーマット {timestampFormat} は、疑問符 ({fieldPlaceholder}) が含まれているためサポートされていません", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.trimFieldsLabel": "フィールドを切り抜く", - "xpack.ml.fileDatavisualizer.editFlyout.overrideSettingsTitle": "上書き設定", - "xpack.ml.fileDatavisualizer.experimentalBadge.experimentalLabel": "実験的", - "xpack.ml.fileDatavisualizer.fieldStatsCard.distinctCountDescription": "{fieldCardinality} 個の特徴的な {fieldCardinality, plural, zero {value} one {value} other {values}}", - "xpack.ml.fileDatavisualizer.fieldStatsCard.documentsCountDescription": "{fieldCount, plural, zero {# document} one {# document} other {# documents}} ({fieldPercent}%)", - "xpack.ml.fileDatavisualizer.fieldStatsCard.maxTitle": "最高", - "xpack.ml.fileDatavisualizer.fieldStatsCard.medianTitle": "中間", - "xpack.ml.fileDatavisualizer.fieldStatsCard.minTitle": "最低", - "xpack.ml.fileDatavisualizer.fieldStatsCard.noFieldInformationAvailableDescription": "フィールド情報がありません", - "xpack.ml.fileDatavisualizer.fieldStatsCard.topStatsValuesDescription": "トップの値", - "xpack.ml.fileDatavisualizer.fileContents.fileContentsTitle": "ファイルコンテンツ", - "xpack.ml.fileDatavisualizer.fileContents.firstLinesDescription": "初めの {numberOfLines, plural, zero {# 行} 1 {# 行} other {# 行}}", - "xpack.ml.fileDatavisualizer.fileDatavisualizerView.xmlNotCurrentlySupportedErrorMessage": "XML は現在サポートされていません", - "xpack.ml.fileDatavisualizer.fileErrorCallouts.fileCouldNotBeReadTitle": "ファイルを読み込めませんでした", - "xpack.ml.fileDatavisualizer.fileErrorCallouts.fileSizeExceedsAllowedSizeByDiffFormatErrorMessage": "アップロードするよう選択されたファイルのサイズが {diffFormatted} に許可された最大サイズの {maxFileSizeFormatted} を超えています", - "xpack.ml.fileDatavisualizer.fileErrorCallouts.fileSizeExceedsAllowedSizeErrorMessage": "アップロードするよう選択されたファイルのサイズは {fileSizeFormatted} で、許可された最大サイズの {maxFileSizeFormatted} を超えています。", - "xpack.ml.fileDatavisualizer.fileErrorCallouts.fileSizeTooLargeTitle": "ファイルサイズが大きすぎます。", - "xpack.ml.fileDatavisualizer.fileErrorCallouts.revertingToPreviousSettingsDescription": "以前の設定に戻しています。", - "xpack.ml.fileDatavisualizer.importErrors.checkingPermissionErrorMessage": "パーミッションエラーをインポートします", - "xpack.ml.fileDatavisualizer.importErrors.creatingIndexErrorMessage": "インデックスの作成中にエラーが発生しました", - "xpack.ml.fileDatavisualizer.importErrors.creatingIndexPatternErrorMessage": "インデックスパターンの作成中にエラーが発生しました", - "xpack.ml.fileDatavisualizer.importErrors.creatingIngestPipelineErrorMessage": "投入パイプラインの作成中にエラーが発生しました", - "xpack.ml.fileDatavisualizer.importErrors.defaultErrorMessage": "エラー", - "xpack.ml.fileDatavisualizer.importErrors.moreButtonLabel": "もっと", - "xpack.ml.fileDatavisualizer.importErrors.parsingJSONErrorMessage": "JSON のパース中にエラーが発生しました", - "xpack.ml.fileDatavisualizer.importErrors.readingFileErrorMessage": "ファイルの読み込み中にエラーが発生しました", - "xpack.ml.fileDatavisualizer.importErrors.unknownErrorMessage": "不明なエラー", - "xpack.ml.fileDatavisualizer.importErrors.uploadingDataErrorMessage": "データのアップロード中にエラーが発生しました", - "xpack.ml.fileDatavisualizer.importProgress.createIndexPatternTitle": "インデックスパターンの作成", - "xpack.ml.fileDatavisualizer.importProgress.createIndexTitle": "インデックスの作成", - "xpack.ml.fileDatavisualizer.importProgress.createIngestPipelineTitle": "投入パイプラインの作成", - "xpack.ml.fileDatavisualizer.importProgress.creatingIndexPatternDescription": "インデックスパターンを作成中です", - "xpack.ml.fileDatavisualizer.importProgress.creatingIndexPatternTitle": "インデックスパターンを作成中", - "xpack.ml.fileDatavisualizer.importProgress.creatingIndexTitle": "インデックスを作成中", - "xpack.ml.fileDatavisualizer.importProgress.creatingIngestPipelineTitle": "投入パイプラインを作成中", - "xpack.ml.fileDatavisualizer.importProgress.dataUploadedTitle": "データがアップロードされました", - "xpack.ml.fileDatavisualizer.importProgress.fileProcessedTitle": "ファイルが処理されました", - "xpack.ml.fileDatavisualizer.importProgress.indexCreatedTitle": "インデックスが作成されました", - "xpack.ml.fileDatavisualizer.importProgress.indexPatternCreatedTitle": "インデックスパターンが作成されました", - "xpack.ml.fileDatavisualizer.importProgress.ingestPipelineCreatedTitle": "投入パイプラインが作成されました", - "xpack.ml.fileDatavisualizer.importProgress.processFileTitle": "ファイルの処理", - "xpack.ml.fileDatavisualizer.importProgress.processingFileTitle": "ファイルを処理中", - "xpack.ml.fileDatavisualizer.importProgress.processingImportedFileDescription": "インポートするファイルを処理中", - "xpack.ml.fileDatavisualizer.importProgress.stepTwoCreatingIndexDescription": "インデックスを作成中です", - "xpack.ml.fileDatavisualizer.importProgress.stepTwoCreatingIndexIngestPipelineDescription": "インデックスと投入パイプラインを作成中です", - "xpack.ml.fileDatavisualizer.importProgress.uploadDataTitle": "データのアップロード", - "xpack.ml.fileDatavisualizer.importProgress.uploadingDataDescription": "データをアップロード中です", - "xpack.ml.fileDatavisualizer.importProgress.uploadingDataTitle": "データをアップロード中", - "xpack.ml.fileDatavisualizer.importSettings.advancedTabName": "高度な設定", - "xpack.ml.fileDatavisualizer.importSettings.simpleTabName": "シンプル", - "xpack.ml.fileDatavisualizer.importSummary.documentsCouldNotBeImportedDescription": "{docCount} 件中 {importFailuresLength} 件のドキュメントをインポートできません。行が Grok パターンと一致していないことが原因の可能性があります。", - "xpack.ml.fileDatavisualizer.importSummary.documentsCouldNotBeImportedTitle": "ドキュメントの一部をインポートできませんでした。", - "xpack.ml.fileDatavisualizer.importSummary.documentsIngestedTitle": "ドキュメントが投入されました", - "xpack.ml.fileDatavisualizer.importSummary.failedDocumentsButtonLabel": "失敗したドキュメント", - "xpack.ml.fileDatavisualizer.importSummary.failedDocumentsTitle": "失敗したドキュメント", - "xpack.ml.fileDatavisualizer.importSummary.importCompleteTitle": "インポート完了", - "xpack.ml.fileDatavisualizer.importSummary.indexPatternTitle": "インデックスパターン", - "xpack.ml.fileDatavisualizer.importSummary.indexTitle": "インデックス", - "xpack.ml.fileDatavisualizer.importSummary.ingestPipelineTitle": "パイプラインを投入", - "xpack.ml.fileDatavisualizer.importView.experimentalFeatureTooltip": "実験的機能。フィードバックをお待ちしています。", - "xpack.ml.fileDatavisualizer.importView.importButtonLabel": "インポート", - "xpack.ml.fileDatavisualizer.importView.importDataTitle": "データのインポート", - "xpack.ml.fileDatavisualizer.importView.importPermissionError": "インデックス {index} にデータを作成またはインポートするパーミッションがありません。", - "xpack.ml.fileDatavisualizer.importView.indexNameAlreadyExistsErrorMessage": "インデックス名が既に存在します", - "xpack.ml.fileDatavisualizer.importView.indexNameContainsIllegalCharactersErrorMessage": "インデックス名に許可されていない文字が含まれています", - "xpack.ml.fileDatavisualizer.importView.indexPatternDoesNotMatchIndexNameErrorMessage": "インデックスパターンがインデックス名と一致しません", - "xpack.ml.fileDatavisualizer.importView.indexPatternNameAlreadyExistsErrorMessage": "インデックスパターン名が既に存在します", - "xpack.ml.fileDatavisualizer.importView.noIdOrIndexSuppliedErrorMessage": "ID またはインデックスが提供されていません", - "xpack.ml.fileDatavisualizer.importView.parseMappingsError": "マッピングのパース中にエラーが発生しました:", - "xpack.ml.fileDatavisualizer.importView.parsePipelineError": "投入パイプラインのパース中にエラーが発生しました:", - "xpack.ml.fileDatavisualizer.importView.parseSettingsError": "設定のパース中にエラーが発生しました:", - "xpack.ml.fileDatavisualizer.importView.resetButtonLabel": "リセット", - "xpack.ml.fileDatavisualizer.resultsLinks.createNewMLJobTitle": "新規 ML ジョブの作成", - "xpack.ml.fileDatavisualizer.resultsLinks.indexManagementTitle": "インデックス管理", - "xpack.ml.fileDatavisualizer.resultsLinks.indexPatternManagementTitle": "インデックスパターン管理", - "xpack.ml.fileDatavisualizer.resultsLinks.openInDataVisualizerTitle": "データビジュアライザーを開く", - "xpack.ml.fileDatavisualizer.resultsLinks.viewIndexInDiscoverTitle": "インデックスをディスカバリで表示", - "xpack.ml.fileDatavisualizer.resultsView.fileStatsTabName": "ファイル統計", - "xpack.ml.fileDatavisualizer.resultsView.overrideSettingsButtonLabel": "上書き設定", - "xpack.ml.fileDatavisualizer.simpleImportSettings.createIndexPatternLabel": "インデックスパターンを作成", - "xpack.ml.fileDatavisualizer.simpleImportSettings.indexNameAriaLabel": "インデックス名、必須フィールド", - "xpack.ml.fileDatavisualizer.simpleImportSettings.indexNameFormRowLabel": "インデックス名", - "xpack.ml.fileDatavisualizer.simpleImportSettings.indexNamePlaceholder": "インデックス名", - "xpack.ml.fileDatavisualizer.welcomeContent.delimitedTextFilesDescription": "CSV や TSV などの区切られたテキストファイル", - "xpack.ml.fileDatavisualizer.welcomeContent.experimentalFeatureDescription": "これは実験的な機能です。フィードバックがありますか?{githubLink} で問題を報告してください。", - "xpack.ml.fileDatavisualizer.welcomeContent.experimentalFeatureTooltip": "実験的機能。フィードバックをお待ちしています。", - "xpack.ml.fileDatavisualizer.welcomeContent.logFilesWithCommonFormatDescription": "タイムスタンプの一般的フォーマットのログファイル", - "xpack.ml.fileDatavisualizer.welcomeContent.newlineDelimitedJsonDescription": "改行区切りの JSON", - "xpack.ml.fileDatavisualizer.welcomeContent.supportedFileFormatDescription": "ファイルデータビジュアライザーはこれらのファイル形式をサポートしています:", - "xpack.ml.fileDatavisualizer.welcomeContent.uploadedFilesAllowedSizeDescription": "最大 100 MB のファイルをアップロードできます。", - "xpack.ml.fileDatavisualizer.welcomeContent.visualizeDataFromLogFileDescription": "ファイルデータビジュアライザーは、ログファイルのフィールドとメトリックの理解に役立ちます。ファイルをアップロードして、データを分析し、 Elasticsearch インデックスにインポートするか選択できます。", - "xpack.ml.fileDatavisualizer.welcomeContent.visualizeDataFromLogFileTitle": "ログファイルのデータを可視化 {experimentalBadge}", - "xpack.ml.formatters.metricChangeDescription.actualSameAsTypicalDescription": "実際値が通常値と同じ", - "xpack.ml.formatters.metricChangeDescription.moreThan100xHigherDescription": "100x よりも高い", - "xpack.ml.formatters.metricChangeDescription.moreThan100xLowerDescription": "100x よりも低い", - "xpack.ml.formatters.metricChangeDescription.moreThanOneAndFiveHundredthsxHigherDescription": "{factor}x 高い", - "xpack.ml.formatters.metricChangeDescription.moreThanOneAndFiveHundredthsxLowerDescription": "{factor}x 低い", - "xpack.ml.formatters.metricChangeDescription.moreThanOneAndHalfxHigherDescription": "{factor}x 高い", - "xpack.ml.formatters.metricChangeDescription.moreThanOneAndHalfxLowerDescription": "{factor}x 低い", - "xpack.ml.formatters.metricChangeDescription.unexpectedNonZeroValueDescription": "予期せぬ 0 以外の値", - "xpack.ml.formatters.metricChangeDescription.unexpectedZeroValueDescription": "予期せぬ 0 の値", - "xpack.ml.formatters.metricChangeDescription.unusuallyHighDescription": "異常に高い", - "xpack.ml.formatters.metricChangeDescription.unusuallyLowDescription": "異常に低い", - "xpack.ml.formatters.metricChangeDescription.unusualValuesDescription": "異常な値", - "xpack.ml.fullTimeRangeSelector.errorSettingTimeRangeNotification": "時間範囲の設定中にエラーが発生しました。", - "xpack.ml.fullTimeRangeSelector.useFullDataButtonLabel": "完全な {indexPatternTitle} データを使用", - "xpack.ml.indexPatternNotBasedOnTimeSeriesNotificationDescription": "異常検知は時間ベースのインデックスでのみ実行されます", - "xpack.ml.indexPatternNotBasedOnTimeSeriesNotificationTitle": "インデックスパターン {indexPatternTitle} は時系列に基づくものではありません", - "xpack.ml.influencersList.maxAnomalyScoreTooltipDescription": "最高異常スコア: {maxScoreLabel}", - "xpack.ml.influencersList.noInfluencersFoundTitle": "影響因子が見つかりません", - "xpack.ml.influencersList.totalAnomalyScoreTooltipDescription": "合計異常スコア: {totalScoreLabel}", - "xpack.ml.itemsGrid.itemsCountLabel": "{pageSize} 個の項目", - "xpack.ml.itemsGrid.itemsPerPageButtonLabel": "ページごとの項目数: {itemsPerPage}", - "xpack.ml.itemsGrid.noItemsAddedTitle": "項目が追加されていません", - "xpack.ml.itemsGrid.noMatchingItemsTitle": "一致する項目が見つかりません。", - "xpack.ml.jobsBreadcrumbs.advancedConfigurationLabel": "高度な構成", - "xpack.ml.jobsBreadcrumbs.multiMetricLabel": "マルチメトリック", - "xpack.ml.jobsBreadcrumbs.populationLabel": "集団", - "xpack.ml.jobsBreadcrumbs.selectIndexOrSearchLabel": "インデックスまたは検索を選択", - "xpack.ml.jobsBreadcrumbs.singleMetricLabel": "シングルメトリック", - "xpack.ml.jobSelect.noJobsSelectedWarningMessage": "ジョブが選択されていません。初めのジョブを自動選択します", - "xpack.ml.jobSelect.requestedJobsDoesNotExistWarningMessage": "リクエストされました\n{invalidIdsLength, plural, one {job {invalidIds} does not exist} other {jobs {invalidIds} do not exist}}", - "xpack.ml.jobSelectList.groupTimeRangeLabel": "{fromString} ~ {toString}", - "xpack.ml.jobSelector.applyFlyoutButton": "適用", - "xpack.ml.jobSelector.applyTimerangeSwitchLabel": "時間範囲を適用", - "xpack.ml.jobSelector.clearAllFlyoutButton": "すべて消去", - "xpack.ml.jobSelector.closeFlyoutButton": "閉じる", - "xpack.ml.jobSelector.customTable.searchBarPlaceholder": "検索…", - "xpack.ml.jobSelector.customTable.selectAllCheckboxLabel": "すべて選択", - "xpack.ml.jobSelector.filterBar.groupLabel": "グループ", - "xpack.ml.jobSelector.filterBar.invalidSearchErrorMessage": "無効な検索: {errorMessage}", - "xpack.ml.jobSelector.filterBar.jobGroupTitle": "({jobsCount, plural, one {# ジョブ} other {# 件のジョブ}})", - "xpack.ml.jobSelector.flyoutTitle": "ジョブの選択", - "xpack.ml.jobSelector.groupsTab": "グループ", - "xpack.ml.jobSelector.hideBarBadges": "を非表示", - "xpack.ml.jobSelector.hideFlyoutBadges": "を非表示", - "xpack.ml.jobSelector.jobFetchErrorMessage": "ジョブの取得中にエラーが発生しました。更新して再試行してください。", - "xpack.ml.jobSelector.jobSelectionButton": "他のジョブを選択", - "xpack.ml.jobSelector.jobsTab": "ジョブ", - "xpack.ml.jobSelector.jobTimeRangeLabel": "{fromString} ~ {toString}", - "xpack.ml.jobSelector.selectedGroupJobs": "({jobsCount, plural, one {# ジョブ} other {# 件のジョブ}})", - "xpack.ml.jobSelector.showBarBadges": "その他 {overFlow} 件", - "xpack.ml.jobSelector.showFlyoutBadges": "その他 {overFlow} 件", - "xpack.ml.jobService.activeDatafeedsLabel": "アクティブなデータフィード", - "xpack.ml.jobService.activeMLNodesLabel": "アクティブな ML ノード", - "xpack.ml.jobService.closedJobsLabel": "ジョブを作成", - "xpack.ml.jobService.couldNotStartDatafeedErrorMessage": "{jobId} のデータフィードを開始できませんでした", - "xpack.ml.jobService.couldNotStopDatafeedErrorMessage": "{jobId} のデータフィードを停止できませんでした", - "xpack.ml.jobService.couldNotUpdateDatafeedErrorMessage": "データフィードを更新できませんでした: {datafeedId}", - "xpack.ml.jobService.couldNotUpdateJobErrorMessage": "ジョブを更新できませんでした: {jobId}", - "xpack.ml.jobService.datafeedsListCouldNotBeRetrievedErrorMessage": "データフィードリストを取得できませんでした", - "xpack.ml.jobService.failedJobsLabel": "失敗したジョブ", - "xpack.ml.jobService.jobsListCouldNotBeRetrievedErrorMessage": "ジョブリストを取得できませんでした", - "xpack.ml.jobService.jobValidationErrorMessage": "ジョブ検証エラー: {errorMessage}", - "xpack.ml.jobService.openJobsLabel": "ジョブを開く", - "xpack.ml.jobService.requestMayHaveTimedOutErrorMessage": "リクエストがタイムアウトし、まだバックグラウンドで実行中の可能性があります。", - "xpack.ml.jobService.totalJobsLabel": "合計ジョブ数", - "xpack.ml.jobsList.actionExecuteSuccessfullyNotificationMessage": "{successesJobsCount, plural, one{{successJob}} other{# 件のジョブ}} {actionTextPT}成功", - "xpack.ml.jobsList.actionFailedNotificationMessage": "{failureId} が {actionText} に失敗しました", - "xpack.ml.jobsList.actionsLabel": "アクション", - "xpack.ml.jobsList.cloneJobErrorMessage": "{jobId} のクローンを作成できませんでした。ジョブが見つかりませんでした", - "xpack.ml.jobsList.closeActionStatusText": "閉じる", - "xpack.ml.jobsList.closedActionStatusText": "クローズ済み", - "xpack.ml.jobsList.closeJobErrorMessage": "ジョブをクローズできませんでした", - "xpack.ml.jobsList.collapseJobDetailsAriaLabel": "{itemId} の詳細を非表示", - "xpack.ml.jobsList.createNewJobButtonLabel": "新規ジョブを作成", - "xpack.ml.jobsList.createWatchFlyout.closeButtonLabel": "閉じる", - "xpack.ml.jobsList.createWatchFlyout.editWatchButtonLabel": "ウォッチを編集", - "xpack.ml.jobsList.createWatchFlyout.pageTitle": "{jobId} のウォッチを作成", - "xpack.ml.jobsList.createWatchFlyout.saveButtonLabel": "保存", - "xpack.ml.jobsList.createWatchFlyout.watchCreatedSuccessfullyNotificationMessage": "ウォッチ {id} が作成されました", - "xpack.ml.jobsList.createWatchFlyout.watchNotSavedErrorNotificationMessage": "ウォッチを保存できませんでした", - "xpack.ml.jobsList.datafeedStateLabel": "データフィード状態", - "xpack.ml.jobsList.deleteActionStatusText": "削除", - "xpack.ml.jobsList.deletedActionStatusText": "削除されました", - "xpack.ml.jobsList.deleteJobErrorMessage": "ジョブの削除に失敗しました", - "xpack.ml.jobsList.deleteJobModal.cancelButtonLabel": "キャンセル", - "xpack.ml.jobsList.deleteJobModal.closeButtonLabel": "閉じる", - "xpack.ml.jobsList.deleteJobModal.deleteButtonLabel": "削除", - "xpack.ml.jobsList.deleteJobModal.deleteJobsDescription": "{jobsCount, plural, one {このジョブ} other {これらのジョブ}}を削除してよろしいですか?", - "xpack.ml.jobsList.deleteJobModal.deleteJobsTitle": "{jobsCount, plural, one {{jobId}} other {# 件のジョブ}}を削除", - "xpack.ml.jobsList.deleteJobModal.deleteMultipleJobsDescription": "{jobsCount, plural, one {ジョブ} other {複数ジョブ}}の削除には時間がかかる場合があります。{jobsCount, plural, one {} other {}}バックグラウンドで削除され、ジョブリストからすぐに消えない場合があります", - "xpack.ml.jobsList.deleteJobModal.deletingJobsStatusLabel": "ジョブを削除中", - "xpack.ml.jobsList.descriptionLabel": "説明", - "xpack.ml.jobsList.editJobFlyout.changesNotSavedNotificationMessage": "{jobId} への変更を保存できませんでした", - "xpack.ml.jobsList.editJobFlyout.changesSavedNotificationMessage": "{jobId} への変更が保存されました", - "xpack.ml.jobsList.editJobFlyout.closeButtonLabel": "閉じる", - "xpack.ml.jobsList.editJobFlyout.customUrls.addButtonLabel": "追加", - "xpack.ml.jobsList.editJobFlyout.customUrls.addCustomUrlButtonLabel": "カスタム URL を追加", - "xpack.ml.jobsList.editJobFlyout.customUrls.addNewUrlErrorNotificationMessage": "提供された設定から新規カスタム URL を作成中にエラーが発生しました", - "xpack.ml.jobsList.editJobFlyout.customUrls.buildUrlErrorNotificationMessage": "提供された設定からテスト用のカスタム URL を作成中にエラーが発生しました", - "xpack.ml.jobsList.editJobFlyout.customUrls.closeEditorAriaLabel": "カスタム URL エディターを閉じる", - "xpack.ml.jobsList.editJobFlyout.customUrls.getTestUrlErrorNotificationMessage": "構成をテストするための URL の取得中にエラーが発生しました", - "xpack.ml.jobsList.editJobFlyout.customUrls.loadIndexPatternsErrorNotificationMessage": "保存されたインデックスパターンのリストの読み込み中にエラーが発生しました", - "xpack.ml.jobsList.editJobFlyout.customUrls.loadSavedDashboardsErrorNotificationMessage": "保存された Kibana ダッシュボードのリストの読み込み中にエラーが発生しました", - "xpack.ml.jobsList.editJobFlyout.customUrls.testButtonLabel": "テスト", - "xpack.ml.jobsList.editJobFlyout.customUrlsTitle": "カスタム URL", - "xpack.ml.jobsList.editJobFlyout.datafeed.frequencyLabel": "頻度", - "xpack.ml.jobsList.editJobFlyout.datafeed.queryDelayLabel": "クエリの遅延", - "xpack.ml.jobsList.editJobFlyout.datafeed.queryLabel": "クエリ", - "xpack.ml.jobsList.editJobFlyout.datafeed.scrollSizeLabel": "スクロールサイズ", - "xpack.ml.jobsList.editJobFlyout.datafeedTitle": "データフィード", - "xpack.ml.jobsList.editJobFlyout.detectorsTitle": "検知器", - "xpack.ml.jobsList.editJobFlyout.groupsAndJobsHasSameIdErrorMessage": "この ID のジョブが既に存在します。グループとジョブは同じ ID を共有できません。", - "xpack.ml.jobsList.editJobFlyout.jobDetails.jobDescriptionLabel": "ジョブの説明", - "xpack.ml.jobsList.editJobFlyout.jobDetails.jobGroupsLabel": "ジョブグループ", - "xpack.ml.jobsList.editJobFlyout.jobDetails.jobGroupsPlaceholder": "ジョブを選択または作成", - "xpack.ml.jobsList.editJobFlyout.jobDetails.modelMemoryLimitLabel": "モデルメモリー制限", - "xpack.ml.jobsList.editJobFlyout.jobDetailsTitle": "ジョブの詳細", - "xpack.ml.jobsList.editJobFlyout.pageTitle": "{jobId} の編集", - "xpack.ml.jobsList.editJobFlyout.saveButtonLabel": "保存", - "xpack.ml.jobsList.expandJobDetailsAriaLabel": "{itemId} の詳細を表示", - "xpack.ml.jobsList.idLabel": "ID", - "xpack.ml.jobsList.jobDetails.analysisConfigTitle": "分析の構成", - "xpack.ml.jobsList.jobDetails.analysisLimitsTitle": "分析制限", - "xpack.ml.jobsList.jobDetails.calendarsTitle": "カレンダー", - "xpack.ml.jobsList.jobDetails.countsTitle": "カウント", - "xpack.ml.jobsList.jobDetails.customUrlsTitle": "カスタム URL", - "xpack.ml.jobsList.jobDetails.dataDescriptionTitle": "データの説明", - "xpack.ml.jobsList.jobDetails.datafeedTitle": "データフィード", - "xpack.ml.jobsList.jobDetails.detectorsTitle": "検知器", - "xpack.ml.jobsList.jobDetails.forecastsTable.createdLabel": "作成済み", - "xpack.ml.jobsList.jobDetails.forecastsTable.expiresLabel": "有効期限", - "xpack.ml.jobsList.jobDetails.forecastsTable.fromLabel": "開始:", - "xpack.ml.jobsList.jobDetails.forecastsTable.loadingErrorMessage": "このジョブに実行された予測のリストの読み込み中にエラーが発生しました", - "xpack.ml.jobsList.jobDetails.forecastsTable.memorySizeLabel": "メモリーサイズ", - "xpack.ml.jobsList.jobDetails.forecastsTable.messagesLabel": "メッセージ", - "xpack.ml.jobsList.jobDetails.forecastsTable.msTimeUnitLabel": "{ms} ms", - "xpack.ml.jobsList.jobDetails.forecastsTable.noForecastsDescription": "予測を実行するには、{singleMetricViewerLink} を開きます", - "xpack.ml.jobsList.jobDetails.forecastsTable.noForecastsDescription.linkText": "シングルメトリックビューアー", - "xpack.ml.jobsList.jobDetails.forecastsTable.noForecastsTitle": "このジョブには予測が実行されていません", - "xpack.ml.jobsList.jobDetails.forecastsTable.processingTimeLabel": "処理時間", - "xpack.ml.jobsList.jobDetails.forecastsTable.statusLabel": "ステータス", - "xpack.ml.jobsList.jobDetails.forecastsTable.toLabel": "To", - "xpack.ml.jobsList.jobDetails.forecastsTable.viewAriaLabel": "{createdDate} に作成された予測を表示", - "xpack.ml.jobsList.jobDetails.forecastsTable.viewLabel": "表示", - "xpack.ml.jobsList.jobDetails.generalTitle": "一般", - "xpack.ml.jobsList.jobDetails.influencersTitle": "影響", - "xpack.ml.jobsList.jobDetails.modelSizeStatsTitle": "モデルサイズ統計", - "xpack.ml.jobsList.jobDetails.nodeTitle": "ノード", - "xpack.ml.jobsList.jobDetails.noPermissionToViewDatafeedPreviewTitle": "データフィードのプレビューを表示するパーミッションがありません", - "xpack.ml.jobsList.jobDetails.pleaseContactYourAdministratorLabel": "管理者にお問い合わせください", - "xpack.ml.jobsList.jobDetails.tabs.annotationsLabel": "注釈", - "xpack.ml.jobsList.jobDetails.tabs.countsLabel": "カウント", - "xpack.ml.jobsList.jobDetails.tabs.datafeedLabel": "データフィード", - "xpack.ml.jobsList.jobDetails.tabs.datafeedPreviewLabel": "データフィードのプレビュー", - "xpack.ml.jobsList.jobDetails.tabs.forecastsLabel": "予測", - "xpack.ml.jobsList.jobDetails.tabs.jobConfigLabel": "ジョブ構成", - "xpack.ml.jobsList.jobDetails.tabs.jobMessagesLabel": "ジョブメッセージ", - "xpack.ml.jobsList.jobDetails.tabs.jobSettingsLabel": "ジョブ設定", - "xpack.ml.jobsList.jobDetails.tabs.jsonLabel": "JSON", - "xpack.ml.jobsList.jobFilterBar.closedLabel": "クローズ済み", - "xpack.ml.jobsList.jobFilterBar.failedLabel": "失敗", - "xpack.ml.jobsList.jobFilterBar.groupLabel": "グループ", - "xpack.ml.jobsList.jobFilterBar.invalidSearchErrorMessage": "無効な検索: {errorMessage}", - "xpack.ml.jobsList.jobFilterBar.jobGroupTitle": "({jobsCount, plural, one {# ジョブ} other {# 件のジョブ}})", - "xpack.ml.jobsList.jobFilterBar.openedLabel": "オープン", - "xpack.ml.jobsList.jobFilterBar.startedLabel": "開始済み", - "xpack.ml.jobsList.jobFilterBar.stoppedLabel": "停止中", - "xpack.ml.jobsList.jobStateLabel": "ジョブ状態", - "xpack.ml.jobsList.latestTimestampLabel": "最新タイムスタンプ", - "xpack.ml.jobsList.loadingJobsLabel": "ジョブを読み込み中…", - "xpack.ml.jobsList.managementActions.cloneJobDescription": "ジョブのクローンを作成します", - "xpack.ml.jobsList.managementActions.cloneJobLabel": "ジョブのクローンを作成", - "xpack.ml.jobsList.managementActions.closeJobDescription": "ジョブを閉じます", - "xpack.ml.jobsList.managementActions.closeJobLabel": "ジョブを閉じる", - "xpack.ml.jobsList.managementActions.deleteJobDescription": "ジョブを削除します", - "xpack.ml.jobsList.managementActions.deleteJobLabel": "ジョブを削除", - "xpack.ml.jobsList.managementActions.editJobDescription": "ジョブを編集します", - "xpack.ml.jobsList.managementActions.editJobLabel": "ジョブを編集", - "xpack.ml.jobsList.managementActions.startDatafeedDescription": "データフィードを開始します", - "xpack.ml.jobsList.managementActions.startDatafeedLabel": "データフィードを開始", - "xpack.ml.jobsList.managementActions.stopDatafeedDescription": "データフィードを停止します", - "xpack.ml.jobsList.managementActions.stopDatafeedLabel": "データフィードを停止", - "xpack.ml.jobsList.memoryStatusLabel": "メモリー状態", - "xpack.ml.jobsList.multiJobActions.groupSelector.addButtonAriaLabel": "追加", - "xpack.ml.jobsList.multiJobActions.groupSelector.addNewGroupPlaceholder": "新規グループを追加", - "xpack.ml.jobsList.multiJobActions.groupSelector.applyButtonLabel": "適用", - "xpack.ml.jobsList.multiJobActions.groupSelector.applyGroupsToJobTitle": "{jobsCount, plural, one {ジョブ} other {件のジョブ}}にグループを適用", - "xpack.ml.jobsList.multiJobActions.groupSelector.editJobGroupsButtonAriaLabel": "ジョブグループを編集", - "xpack.ml.jobsList.multiJobActions.groupSelector.editJobGroupsButtonTooltip": "ジョブグループを編集します", - "xpack.ml.jobsList.multiJobActions.groupSelector.groupsAndJobsCanNotUseSameIdErrorMessage": "この ID のジョブが既に存在します。グループとジョブは同じ ID を共有できません。", - "xpack.ml.jobsList.multiJobActionsMenu.managementActionsAriaLabel": "管理アクション", - "xpack.ml.jobsList.multiJobsActions.closeJobsLabel": "{jobsCount, plural, one {ジョブ} other {件のジョブ}}を閉じる", - "xpack.ml.jobsList.multiJobsActions.deleteJobsLabel": "{jobsCount, plural, one {ジョブ} other {件のジョブ}}を削除", - "xpack.ml.jobsList.multiJobsActions.jobsSelectedLabel": "{selectedJobsCount, plural, one {# 件のジョブ} other {# 件のジョブ}} を選択済み", - "xpack.ml.jobsList.multiJobsActions.startDatafeedsLabel": "{jobsCount, plural, one {データフィード} other {データフィード}}を開始", - "xpack.ml.jobsList.multiJobsActions.stopDatafeedsLabel": "{jobsCount, plural, one {データフィード} other {データフィード}}を停止", - "xpack.ml.jobsList.nodeAvailableWarning.linkToCloud.hereLinkText": "こちら", - "xpack.ml.jobsList.nodeAvailableWarning.noMLNodesAvailableDescription": "利用可能な ML ノードがありません。", - "xpack.ml.jobsList.nodeAvailableWarning.noMLNodesAvailableTitle": "利用可能な ML ノードがありません", - "xpack.ml.jobsList.noJobsFoundLabel": "ジョブが見つかりません", - "xpack.ml.jobsList.processedRecordsLabel": "処理済みレコード", - "xpack.ml.jobsList.refreshButtonLabel": "更新", - "xpack.ml.jobsList.resultActions.openJobsInAnomalyExplorerText": "{jobsCount, plural, one {{jobId}} other {# 件のジョブ}} を異常エクスプローラーで開く", - "xpack.ml.jobsList.resultActions.openJobsInSingleMetricViewerText": "シングルメトリックビューアーで {jobsCount, plural, one {{jobId}} other {# 件のジョブ}} を開く", - "xpack.ml.jobsList.startActionStatusText": "開始", - "xpack.ml.jobsList.startDatafeedModal.cancelButtonLabel": "キャンセル", - "xpack.ml.jobsList.startDatafeedModal.continueFromNowLabel": "今から続行", - "xpack.ml.jobsList.startDatafeedModal.continueFromSpecifiedTimeLabel": "特定の時刻から続行", - "xpack.ml.jobsList.startDatafeedModal.continueFromStartTimeLabel": "{formattedStartTime} から続行", - "xpack.ml.jobsList.startDatafeedModal.createWatchDescription": "データフィードの開始後ウォッチを作成します", - "xpack.ml.jobsList.startDatafeedModal.noEndTimeLabel": "終了時刻が指定されていません (リアルタイム検索)", - "xpack.ml.jobsList.startDatafeedModal.searchEndTimeTitle": "検索終了時刻", - "xpack.ml.jobsList.startDatafeedModal.searchStartTimeTitle": "検索開始時刻", - "xpack.ml.jobsList.startDatafeedModal.specifyEndTimeLabel": "終了時刻を指定", - "xpack.ml.jobsList.startDatafeedModal.specifyStartTimeLabel": "開始時刻を指定", - "xpack.ml.jobsList.startDatafeedModal.startAtBeginningOfDataLabel": "データの初めから開始", - "xpack.ml.jobsList.startDatafeedModal.startButtonLabel": "開始", - "xpack.ml.jobsList.startDatafeedModal.startFromNowLabel": "今から開始", - "xpack.ml.jobsList.startDatafeedModal.startJobsTitle": "{jobsCount, plural, one {{jobId}} other {# 件のジョブ}}を開始", - "xpack.ml.jobsList.startedActionStatusText": "開始済み", - "xpack.ml.jobsList.startJobErrorMessage": "ジョブの開始に失敗しました", - "xpack.ml.jobsList.statsBar.activeDatafeedsLabel": "アクティブなデータフィード", - "xpack.ml.jobsList.statsBar.activeMLNodesLabel": "アクティブな ML ノード", - "xpack.ml.jobsList.statsBar.closedJobsLabel": "ジョブを作成", - "xpack.ml.jobsList.statsBar.failedJobsLabel": "失敗したジョブ", - "xpack.ml.jobsList.statsBar.openJobsLabel": "ジョブを開く", - "xpack.ml.jobsList.statsBar.totalJobsLabel": "合計ジョブ数", - "xpack.ml.jobsList.stopActionStatusText": "停止", - "xpack.ml.jobsList.stopJobErrorMessage": "ジョブの停止に失敗しました", - "xpack.ml.jobsList.stoppedActionStatusText": "停止中", - "xpack.ml.machineLearningBreadcrumbLabel": "機械学習", - "xpack.ml.machineLearningDescription": "時系列データから通常の動作を自動的に学習し、異常を検知します。", - "xpack.ml.machineLearningTitle": "機械学習", - "xpack.ml.mlNavDescription": "Elastic Stack 用の機械学習", - "xpack.ml.mlNavTitle": "機械学習", - "xpack.ml.models.jobService.allOtherRequestsCancelledDescription": " 他のすべてのリクエストはキャンセルされました。", - "xpack.ml.models.jobService.deletingJob": "削除中", - "xpack.ml.models.jobService.jobHasNoDatafeedErrorMessage": "ジョブにデータフィードがありません", - "xpack.ml.models.jobService.requestToActionTimedOutErrorMessage": "「{id}」を{action}するリクエストがタイムアウトしました。{extra}", - "xpack.ml.models.jobValidation.analysisConfigIsNotObjectErrorMessage": "無効な {invalidParamName}:オブジェクトでなければなりません。", - "xpack.ml.models.jobValidation.detectorsAreNotArrayErrorMessage": "無効な {invalidParamName}:配列でなければなりません。", - "xpack.ml.models.jobValidation.jobIsNotObjectErrorMessage": "無効な {invalidParamName}:オブジェクトでなければなりません。", - "xpack.ml.models.jobValidation.messages.bucketSpanEmptyMessage": "バケットスパンフィールドを指定する必要があります。", - "xpack.ml.models.jobValidation.messages.bucketSpanEstimationMismatchHeading": "バケットスパン", - "xpack.ml.models.jobValidation.messages.bucketSpanEstimationMismatchMessage": "現在のバケットスパンは {currentBucketSpan} ですが、バケットスパンの予測からは {estimateBucketSpan} が返されました。", - "xpack.ml.models.jobValidation.messages.bucketSpanHighHeading": "バケットスパン", - "xpack.ml.models.jobValidation.messages.bucketSpanHighMessage": "バケットスパンは 1 日かそれ以上です。日数は現地日数ではなく UTC での日数が適用されるのでご注意ください。", - "xpack.ml.models.jobValidation.messages.bucketSpanInvalidHeading": "バケットスパン", - "xpack.ml.models.jobValidation.messages.bucketSpanInvalidMessage": "指定されたバケットスパンは有効な間隔のフォーマット (例: 10m、1h) ではありません。また、0 よりも大きい数字である必要があります。", - "xpack.ml.models.jobValidation.messages.bucketSpanValidHeading": "バケットスパン", - "xpack.ml.models.jobValidation.messages.bucketSpanValidMessage": "{bucketSpan} のフォーマットは有効です。", - "xpack.ml.models.jobValidation.messages.cardinalityByFieldMessage": "{fieldName} の基数が 1000 を超えているため、メモリーの使用量が大きくなる可能性があります。", - "xpack.ml.models.jobValidation.messages.cardinalityModelPlotHighMessage": "モデルプロットの作成に関連したフィールドの予測基数 {modelPlotCardinality} は、ジョブが大量のリソースを消費する原因となる可能性があります。", - "xpack.ml.models.jobValidation.messages.cardinalityOverFieldHighMessage": "{fieldName} の基数が 1000000 を超えているため、メモリーの使用量が大きくなる可能性があります。", - "xpack.ml.models.jobValidation.messages.cardinalityOverFieldLowMessage": "{fieldName} の基数が 10 未満のため、人口分析に不適切な可能性があります。", - "xpack.ml.models.jobValidation.messages.cardinalityPartitionFieldMessage": "{fieldName} の基数が 1000 を超えているため、メモリーの使用量が大きくなる可能性があります。", - "xpack.ml.models.jobValidation.messages.categorizationFiltersInvalidMessage": "カテゴリー分けフィルターの構成が無効です。フィルターが有効な正規表現で {categorizationFieldName} が設定されていることを確認してください。", - "xpack.ml.models.jobValidation.messages.categorizationFiltersValidMessage": "カテゴリー分けフィルターチェックが合格しました。", - "xpack.ml.models.jobValidation.messages.detectorsDuplicatesMessage": "重複する検知器が検出されました。{functionParam}、{fieldNameParam}、{byFieldNameParam}、{overFieldNameParam}、{partitionFieldNameParam} の構成の組み合わせが同じ検知器は、同じジョブで使用できません。", - "xpack.ml.models.jobValidation.messages.detectorsEmptyMessage": "重複する検知器は検出されませんでした。検知器を少なくとも 1 つ指定する必要があります。", - "xpack.ml.models.jobValidation.messages.detectorsFunctionEmptyMessage": "検知器の関数が 1 つも入力されていません。", - "xpack.ml.models.jobValidation.messages.detectorsFunctionNotEmptyHeading": "検知器関数", - "xpack.ml.models.jobValidation.messages.detectorsFunctionNotEmptyMessage": "すべての検知器で検知器関数の存在が確認されました。", - "xpack.ml.models.jobValidation.messages.estimatedMmlGreaterThanMaxMmlMessage": "予測モデルメモリー制限が、このクラスターに構成された最大モデルメモリー制限を超えています。", - "xpack.ml.models.jobValidation.messages.estimatedMmlGreaterThanMmlMessage": "この予測モデルメモリー制限は、構成されたモデルメモリー制限を超えています。", - "xpack.ml.models.jobValidation.messages.fieldNotAggregatableMessage": "ディテクターフィールド {fieldName} が集約フィールドではありません。", - "xpack.ml.models.jobValidation.messages.fieldsNotAggregatableMessage": "検知器フィールドの 1 つがアグリゲーションフィールドではありません。", - "xpack.ml.models.jobValidation.messages.halfEstimatedMmlGreaterThanMmlMessage": "指定されたモデルメモリー制限は、予測モデルメモリー制限の半分未満で、ハードリミットに達する可能性が高いです。", - "xpack.ml.models.jobValidation.messages.indexFieldsInvalidMessage": "インデックスからフィールドを読み込めませんでした。", - "xpack.ml.models.jobValidation.messages.indexFieldsValidMessage": "データフィードにインデックスフィールドがあります。", - "xpack.ml.models.jobValidation.messages.influencerHighMessage": "ジョブの構成に 3 つを超える影響因子が含まれています。影響因子の数を減らすか、複数ジョブの作成をお勧めします。", - "xpack.ml.models.jobValidation.messages.influencerLowMessage": "影響因子が構成されていません。影響因子の構成を強くお勧めします。", - "xpack.ml.models.jobValidation.messages.influencerLowSuggestionMessage": "影響因子が構成されていません。{influencerSuggestion} を影響因子として使用することをお勧めします。", - "xpack.ml.models.jobValidation.messages.influencerLowSuggestionsMessage": "影響因子が構成されていません。{influencerSuggestion} を 1 つまたは複数使用することをお勧めします。", - "xpack.ml.models.jobValidation.messages.jobGroupIdInvalidMessage": "ジョブグループ名の 1 つが無効です。アルファベットの小文字 (a-z と 0-9)、ハイフンまたはアンダーラインが使用でき、最初と最後を英数字にする必要があります。", - "xpack.ml.models.jobValidation.messages.jobGroupIdValidHeading": "ジョブグループ ID のフォーマットは有効です。", - "xpack.ml.models.jobValidation.messages.jobIdEmptyMessage": "ジョブ名フィールドは未入力のままにできません。", - "xpack.ml.models.jobValidation.messages.jobIdInvalidMessage": "ジョブ ID が無効です。アルファベットの小文字 (a-z と 0-9)、ハイフンまたはアンダーラインが使用でき、最初と最後を英数字にする必要があります。", - "xpack.ml.models.jobValidation.messages.jobIdValidHeading": "ジョブ ID のフォーマットは有効です。", - "xpack.ml.models.jobValidation.messages.mmlGreaterThanMaxMmlMessage": "モデルメモリー制限が、このクラスターに構成された最大モデルメモリー制限を超えています。", - "xpack.ml.models.jobValidation.messages.mmlValueInvalidMessage": "{mml} はモデルメモリー制限の有効な値ではありません。この値は最低 1MB で、バイト (例: 10MB) で指定する必要があります。", - "xpack.ml.models.jobValidation.messages.skippedExtendedTestsMessage": "ジョブの構成の基本要件が満たされていないため、他のチェックをスキップしました。", - "xpack.ml.models.jobValidation.messages.successBucketSpanHeading": "バケットスパン", - "xpack.ml.models.jobValidation.messages.successBucketSpanMessage": "{bucketSpan} のフォーマットは有効で、検証に合格しました。", - "xpack.ml.models.jobValidation.messages.successCardinalityHeading": "基数", - "xpack.ml.models.jobValidation.messages.successCardinalityMessage": "検知器フィールドの基数は推奨バウンド内です。", - "xpack.ml.models.jobValidation.messages.successInfluencersMessage": "影響因子の構成は検証に合格しました。", - "xpack.ml.models.jobValidation.messages.successMmlHeading": "モデルメモリー制限", - "xpack.ml.models.jobValidation.messages.successMmlMessage": "有効で予測モデルメモリー制限内です。", - "xpack.ml.models.jobValidation.messages.successTimeRangeHeading": "時間範囲", - "xpack.ml.models.jobValidation.messages.successTimeRangeMessage": "有効で、データのパターンのモデリングに十分な長さです。", - "xpack.ml.models.jobValidation.messages.timeFieldInvalidMessage": "{timeField} は「date」タイプの有効なフィールドではないため、時間フィールドとして使用できません。", - "xpack.ml.models.jobValidation.messages.timeRangeBeforeEpochHeading": "時間範囲", - "xpack.ml.models.jobValidation.messages.timeRangeBeforeEpochMessage": "選択された、または利用可能な時間範囲には、UNIX 時間の開始以前のタイムスタンプのデータが含まれています。01/01/1970 00:00:00 (UTC) よりも前のタイムスタンプは機械学習ジョブでサポートされていません。", - "xpack.ml.models.jobValidation.messages.timeRangeShortHeading": "時間範囲", - "xpack.ml.models.jobValidation.messages.timeRangeShortMessage": "選択された、または利用可能な時間範囲が短すぎます。推奨最低時間範囲は {minTimeSpanReadable} で、バケットスパンの {bucketSpanCompareFactor} 倍です。", - "xpack.ml.models.jobValidation.payloadIsNotObjectErrorMessage": "無効な {invalidParamName}:オブジェクトでなければなりません。", - "xpack.ml.models.jobValidation.unknownMessageIdErrorMessage": "{messageId} (不明なメッセージ ID)", - "xpack.ml.models.jobValidation.validateJobObject.analysisConfigIsNotObjectErrorMessage": "無効な {invalidParamName}:オブジェクトでなければなりません。", - "xpack.ml.models.jobValidation.validateJobObject.dataDescriptionIsNotObjectErrorMessage": "無効な {invalidParamName}:オブジェクトでなければなりません。", - "xpack.ml.models.jobValidation.validateJobObject.datafeedConfigIsNotObjectErrorMessage": "無効な {invalidParamName}:オブジェクトでなければなりません。", - "xpack.ml.models.jobValidation.validateJobObject.detectorsAreNotArrayErrorMessage": "無効な {invalidParamName}:配列でなければなりません。", - "xpack.ml.models.jobValidation.validateJobObject.indicesAreNotArrayErrorMessage": "無効な {invalidParamName}:配列でなければなりません。", - "xpack.ml.models.jobValidation.validateJobObject.influencersAreNotArrayErrorMessage": "無効な {invalidParamName}:配列でなければなりません。", - "xpack.ml.models.jobValidation.validateJobObject.jobIsNotObjectErrorMessage": "無効な {invalidParamName}:オブジェクトでなければなりません。", - "xpack.ml.models.jobValidation.validateJobObject.timeFieldIsNotStringErrorMessage": "無効な {invalidParamName}:文字列でなければなりません。", - "xpack.ml.navMenu.anomalyExplorerTabLinkText": "異常エクスプローラー", - "xpack.ml.navMenu.dataVisualizerTabLinkText": "データビジュアライザー", - "xpack.ml.navMenu.jobManagementTabLinkText": "ジョブ管理", - "xpack.ml.navMenu.settingsTabLinkText": "設定", - "xpack.ml.navMenu.singleMetricViewerTabLinkText": "シングルメトリックビューアー", - "xpack.ml.newJob.simple.createWatchView.emailAddressPlaceholder": "メールアドレス", - "xpack.ml.newJob.simple.createWatchView.nowLabel": "今 - {selectInterval}", - "xpack.ml.newJob.simple.createWatchView.sendEmailLabel": "メールを送信", - "xpack.ml.newJob.simple.createWatchView.severityThresholdLabel": "深刻度のしきい値", - "xpack.ml.newJob.simple.createWatchView.successLabel": "成功", - "xpack.ml.newJob.simple.createWatchView.timeRangeLabel": "時間範囲", - "xpack.ml.newJob.simple.createWatchView.watchAlreadyExistsWarningMessage": "警告、ウォッチ mi-{jobId} は既に存在します。適用をクリックするとオリジナルが上書きされます。", - "xpack.ml.newJob.simple.createWatchView.watchEmailAddressAriaLabel": "ウォッチのメールアドレス", - "xpack.ml.newJob.simple.watcher.email.anomalyScoreLabel": "異常スコア", - "xpack.ml.newJob.simple.watcher.email.elasticStackMachineLearningAlertLabel": "Elastic Stack 機械学習アラート", - "xpack.ml.newJob.simple.watcher.email.jobLabel": "ジョブ", - "xpack.ml.newJob.simple.watcher.email.mlWatcherAlertSubjectTitle": "ML Watcher アラート", - "xpack.ml.newJob.simple.watcher.email.openInAnomalyExplorerLinkText": "異常エクスプローラーを開くにはここをクリックしてください。", - "xpack.ml.newJob.simple.watcher.email.timeLabel": "時間", - "xpack.ml.newJob.simple.watcher.email.topInfluencersLabel": "トップ影響因子:", - "xpack.ml.newJob.simple.watcher.email.topRecordsLabel": "トップの記録:", - "xpack.ml.newJob.wizard.jobType.advancedAriaLabel": "高度なジョブ", - "xpack.ml.newJob.wizard.jobType.advancedDescription": "より高度なユースケースでは、ジョブの作成にすべてのオプションを使用します。", - "xpack.ml.newJob.wizard.jobType.advancedTitle": "高度な設定", - "xpack.ml.newJob.wizard.jobType.createJobFromTitle": "{pageTitleLabel} からジョブを作成", - "xpack.ml.newJob.wizard.jobType.dataVisualizerAriaLabel": "データビジュアライザー", - "xpack.ml.newJob.wizard.jobType.dataVisualizerDescription": "機械学習により、データのより詳しい特徴や、分析するフィールドを把握できます。", - "xpack.ml.newJob.wizard.jobType.dataVisualizerTitle": "データビジュアライザー", - "xpack.ml.newJob.wizard.jobType.howToRunAnomalyDetectionDescription": "異常検知は時間ベースのインデックスのみに実行できます。", - "xpack.ml.newJob.wizard.jobType.indexPatternFromSavedSearchNotTimeBasedMessage": "{savedSearchTitle} は時間ベースではないインデックスパターン {indexPatternTitle} を使用します", - "xpack.ml.newJob.wizard.jobType.indexPatternNotTimeBasedMessage": "インデックスパターン {indexPatternTitle} は時間ベースではありません", - "xpack.ml.newJob.wizard.jobType.indexPatternPageTitleLabel": "インデックスパターン {indexPatternTitle}", - "xpack.ml.newJob.wizard.jobType.learnMoreAboutDataDescription": "作成するジョブのタイプがわからない場合は、まず初めにデータのフィールドとメトリックを見てみましょう。", - "xpack.ml.newJob.wizard.jobType.learnMoreAboutDataTitle": "データに関する詳細", - "xpack.ml.newJob.wizard.jobType.multiMetricAriaLabel": "マルチメトリックジョブ", - "xpack.ml.newJob.wizard.jobType.multiMetricDescription": "カテゴリーフィールドで時系列を分割して複数メトリックの異常を検知します。", - "xpack.ml.newJob.wizard.jobType.multiMetricTitle": "マルチメトリック", - "xpack.ml.newJob.wizard.jobType.populationAriaLabel": "集団", - "xpack.ml.newJob.wizard.jobType.populationDescription": "集団の挙動に比較して普通ではないアクティビティを検知します。", - "xpack.ml.newJob.wizard.jobType.populationTitle": "集団", - "xpack.ml.newJob.wizard.jobType.savedSearchPageTitleLabel": "保存された検索 {savedSearchTitle}", - "xpack.ml.newJob.wizard.jobType.selectDifferentIndexLinkText": "別のインデックスを選択", - "xpack.ml.newJob.wizard.jobType.singleMetricAriaLabel": "シングルメトリックジョブ", - "xpack.ml.newJob.wizard.jobType.singleMetricDescription": "単独の時系列の異常を検知します。", - "xpack.ml.newJob.wizard.jobType.singleMetricTitle": "シングルメトリック", - "xpack.ml.newJob.wizard.jobType.useSuppliedConfigurationDescription": "データのフィールドが既知のカテゴリーと一致することが認識されました。選択して一連の機械学習ジョブと関連ダッシュボードを作成します。", - "xpack.ml.newJob.wizard.jobType.useSuppliedConfigurationTitle": "提供された構成を使用", - "xpack.ml.newJob.wizard.jobType.useWizardDescription": "ウィザードの 1 つを使用し、データの異常を検知する機械学習ジョブを作成します。", - "xpack.ml.newJob.wizard.jobType.useWizardTitle": "ウィザードを使用", - "xpack.ml.privilege.licenseHasExpiredTooltip": "ご使用のライセンスは期限切れです。", - "xpack.ml.privilege.noPermission.createCalendarsTooltip": "カレンダーを作成するパーミッションがありません。", - "xpack.ml.privilege.noPermission.createMLJobsTooltip": "機械学習ジョブを作成するパーミッションがありません。", - "xpack.ml.privilege.noPermission.deleteCalendarsTooltip": "カレンダーを削除するパーミッションがありません。", - "xpack.ml.privilege.noPermission.deleteJobsTooltip": "ジョブを削除するパーミッションがありません。", - "xpack.ml.privilege.noPermission.editJobsTooltip": "ジョブを編集するパーミッションがありません。", - "xpack.ml.privilege.noPermission.runForecastsTooltip": "予測を実行するパーミッションがありません。", - "xpack.ml.privilege.noPermission.startOrStopDatafeedsTooltip": "データフィードを開始・停止するパーミッションがありません。", - "xpack.ml.privilege.pleaseContactAdministratorTooltip": "{message} 管理者にお問い合わせください。", - "xpack.ml.routes.annotations.annotationsFeatureUnavailableErrorMessage": "注釈機能に必要なインデックスとエイリアスが作成されていないか、現在のユーザーがアクセスできません。", - "xpack.ml.ruleEditor.actionsSection.chooseActionsDescription": "ルールが異常と一致した際のアクションを選択します。", - "xpack.ml.ruleEditor.actionsSection.resultWillNotBeCreatedTooltip": "結果は作成されません。", - "xpack.ml.ruleEditor.actionsSection.skipModelUpdateLabel": "モデルの更新をスキップ", - "xpack.ml.ruleEditor.actionsSection.skipResultLabel": "結果をスキップ (推奨)", - "xpack.ml.ruleEditor.actionsSection.valueWillNotBeUsedToUpdateModelTooltip": "その数列の値はモデルの更新に使用されなくなります。", - "xpack.ml.ruleEditor.actualAppliesTypeText": "実際", - "xpack.ml.ruleEditor.addValueToFilterListLinkText": "{fieldValue} を {filterId} に追加", - "xpack.ml.ruleEditor.conditionExpression.appliesToButtonLabel": "タイミング", - "xpack.ml.ruleEditor.conditionExpression.appliesToPopoverTitle": "タイミング", - "xpack.ml.ruleEditor.conditionExpression.deleteConditionButtonAriaLabel": "条件を削除", - "xpack.ml.ruleEditor.conditionExpression.operatorValueButtonLabel": "は {operator}", - "xpack.ml.ruleEditor.conditionExpression.operatorValuePopoverTitle": "が", - "xpack.ml.ruleEditor.conditionsSection.addNewConditionButtonLabel": "新規条件を追加", - "xpack.ml.ruleEditor.deleteJobRule.ruleNoLongerExistsErrorMessage": "ジョブ {jobId} の検知器インデックス {detectorIndex} のルールが現在存在しません", - "xpack.ml.ruleEditor.deleteRuleModal.cancelButtonLabel": "キャンセル", - "xpack.ml.ruleEditor.deleteRuleModal.deleteButtonLabel": "削除", - "xpack.ml.ruleEditor.deleteRuleModal.deleteRuleDescription": "このルールを削除してよろしいですか?", - "xpack.ml.ruleEditor.deleteRuleModal.deleteRuleLinkText": "ルールを削除", - "xpack.ml.ruleEditor.deleteRuleModal.deleteRuleTitle": "ルールの削除", - "xpack.ml.ruleEditor.detectorDescriptionList.detectorTitle": "検知器", - "xpack.ml.ruleEditor.detectorDescriptionList.jobIdTitle": "ジョブ ID", - "xpack.ml.ruleEditor.detectorDescriptionList.selectedAnomalyDescription": "実際値 {actual}、通常値 {typical}", - "xpack.ml.ruleEditor.detectorDescriptionList.selectedAnomalyTitle": "選択された異常", - "xpack.ml.ruleEditor.diffFromTypicalAppliesTypeText": "通常の diff", - "xpack.ml.ruleEditor.editConditionLink.enterNumericValueForConditionAriaLabel": "条件の数値を入力", - "xpack.ml.ruleEditor.editConditionLink.enterValuePlaceholder": "値を入力", - "xpack.ml.ruleEditor.editConditionLink.updateLinkText": "アップデート", - "xpack.ml.ruleEditor.editConditionLink.updateRuleConditionFromText": "ルールの条件を {conditionValue} から次の条件に更新します:", - "xpack.ml.ruleEditor.excludeFilterTypeText": "次に含まれない:", - "xpack.ml.ruleEditor.greaterThanOperatorTypeText": "greater than", - "xpack.ml.ruleEditor.greaterThanOrEqualToOperatorTypeText": "よりも大きいまたは等しい", - "xpack.ml.ruleEditor.includeFilterTypeText": "次に含まれる:", - "xpack.ml.ruleEditor.lessThanOperatorTypeText": "less than", - "xpack.ml.ruleEditor.lessThanOrEqualToOperatorTypeText": "より小さいまたは等しい", - "xpack.ml.ruleEditor.ruleActionPanel.editRuleLinkText": "ルールを編集", - "xpack.ml.ruleEditor.ruleActionPanel.ruleTitle": "ルール", - "xpack.ml.ruleEditor.ruleDescription": "{conditions}{filters} の場合 {actions} をスキップ", - "xpack.ml.ruleEditor.ruleDescription.conditionsText": "{appliesTo} が {operator} {value}", - "xpack.ml.ruleEditor.ruleDescription.filtersText": "{fieldName} が {filterType} {filterId}", - "xpack.ml.ruleEditor.ruleDescription.modelUpdateActionTypeText": "モデルを更新", - "xpack.ml.ruleEditor.ruleDescription.resultActionTypeText": "結果", - "xpack.ml.ruleEditor.ruleEditorFlyout.actionTitle": "アクション", - "xpack.ml.ruleEditor.ruleEditorFlyout.addedItemToFilterListNotificationMessageDescription": "変更は新しい結果のみに適用されます。", - "xpack.ml.ruleEditor.ruleEditorFlyout.addedItemToFilterListNotificationMessageTitle": "{item} が {filterId} に追加されました", - "xpack.ml.ruleEditor.ruleEditorFlyout.changesToJobDetectorRulesSavedNotificationMessageDescription": "変更は新しい結果のみに適用されます。", - "xpack.ml.ruleEditor.ruleEditorFlyout.changesToJobDetectorRulesSavedNotificationMessageTitle": "{jobId} 検知器ルールへの変更が保存されました", - "xpack.ml.ruleEditor.ruleEditorFlyout.closeButtonLabel": "閉じる", - "xpack.ml.ruleEditor.ruleEditorFlyout.conditionsDescription": "ルールが適用される際に数値的条件を追加します。AND を使用して複数条件を組み合わせます。", - "xpack.ml.ruleEditor.ruleEditorFlyout.conditionsNotSupportedTitle": "{functionName} 関数を使用する検知器では条件がサポートされていません。", - "xpack.ml.ruleEditor.ruleEditorFlyout.conditionsTitle": "条件", - "xpack.ml.ruleEditor.ruleEditorFlyout.createRuleTitle": "ルールの作成", - "xpack.ml.ruleEditor.ruleEditorFlyout.editRulesTitle": "ルールの編集", - "xpack.ml.ruleEditor.ruleEditorFlyout.editRuleTitle": "ルールの編集", - "xpack.ml.ruleEditor.ruleEditorFlyout.errorWithAddingItemToFilterListNotificationMessage": "フィルター {filterId} に {item} を追加中にエラーが発生しました", - "xpack.ml.ruleEditor.ruleEditorFlyout.errorWithDeletingRuleFromJobDetectorNotificationMessage": "{jobId} 検知器からルールを削除中にエラーが発生しました", - "xpack.ml.ruleEditor.ruleEditorFlyout.errorWithLoadingFilterListsNotificationMesssage": "ルール範囲に使用されるフィルターリストの読み込み中にエラーが発生しました", - "xpack.ml.ruleEditor.ruleEditorFlyout.errorWithSavingChangesToJobDetectorRulesNotificationMessage": "{jobId} 検知器ルールへの変更の保存中にエラーが発生しました", - "xpack.ml.ruleEditor.ruleEditorFlyout.howToApplyChangesToExistingResultsDescription": "これらの変更を既存の結果に適用するには、ジョブのクローンを作成して再度実行する必要があります。ジョブを再度実行するには時間がかかる可能性があるため、このジョブのルールへの変更がすべて完了してから行ってください。", - "xpack.ml.ruleEditor.ruleEditorFlyout.rerunJobTitle": "ジョブを再度実行", - "xpack.ml.ruleEditor.ruleEditorFlyout.ruleDeletedFromJobDetectorNotificationMessage": "{jobId} 検知器からルールが検知されました", - "xpack.ml.ruleEditor.ruleEditorFlyout.rulesDescription": "ルールにより、異常検知器がユーザーに提供されたドメインごとの知識に基づき動作を変更するよう指示されています。ルールを作成すると、条件、範囲、アクションを指定できます。ルールの条件が満たされた時、アクションが実行されます。{learnMoreLink}", - "xpack.ml.ruleEditor.ruleEditorFlyout.rulesDescription.learnMoreLinkText": "詳細", - "xpack.ml.ruleEditor.ruleEditorFlyout.saveButtonLabel": "保存", - "xpack.ml.ruleEditor.ruleEditorFlyout.unableToConfigureRulesNotificationMesssage": "ジョブ ID {jobId} の詳細の取得中にエラーが発生したためルールを構成できませんでした", - "xpack.ml.ruleEditor.ruleEditorFlyout.whenChangesTakeEffectDescription": "ルールへの変更は新しい結果のみに適用されます。", - "xpack.ml.ruleEditor.scopeExpression.scopeFieldWhenLabel": "タイミング", - "xpack.ml.ruleEditor.scopeExpression.scopeFilterTypeButtonLabel": "は {filterType}", - "xpack.ml.ruleEditor.scopeExpression.scopeFilterTypePopoverTitle": "が", - "xpack.ml.ruleEditor.scopeSection.addFilterListLabel": "フィルターリストを追加してルールの適用範囲を制限。", - "xpack.ml.ruleEditor.scopeSection.createFilterListsDescription": "範囲を構成するには、まず初めに {filterListsLink} 設定ページでルールの対象と対象外の値のリストを作成する必要があります。", - "xpack.ml.ruleEditor.scopeSection.createFilterListsDescription.filterListsLinkText": "フィルターリスト", - "xpack.ml.ruleEditor.scopeSection.noFilterListsConfiguredTitle": "フィルターリストが構成されていません", - "xpack.ml.ruleEditor.scopeSection.noPermissionToViewFilterListsTitle": "フィルターリストを表示するパーミッションがありません", - "xpack.ml.ruleEditor.scopeSection.scopeTitle": "範囲", - "xpack.ml.ruleEditor.selectRuleAction.createRuleLinkText": "ルールを作成", - "xpack.ml.ruleEditor.selectRuleAction.orText": "または ", - "xpack.ml.ruleEditor.typicalAppliesTypeText": "通常", - "xpack.ml.sampleDataLinkLabel": "ML ジョブ", - "xpack.ml.settings.breadcrumbs.calendarManagement.createLabel": "作成", - "xpack.ml.settings.breadcrumbs.calendarManagement.editLabel": "編集", - "xpack.ml.settings.breadcrumbs.calendarManagementLabel": "カレンダー管理", - "xpack.ml.settings.breadcrumbs.filterLists.createLabel": "作成", - "xpack.ml.settings.breadcrumbs.filterLists.editLabel": "編集", - "xpack.ml.settings.breadcrumbs.filterListsLabel": "フィルターリスト", - "xpack.ml.settings.calendarManagementButtonLabel": "カレンダー管理", - "xpack.ml.settings.calendars.listHeader.calendarsDescription": "カレンダーにはシステム停止日や祝日などの予定を含むことができ、異常検知から除外します。カレンダーは複数のジョブに割り当てることができます。{br}{learnMoreLink}", - "xpack.ml.settings.calendars.listHeader.calendarsDescription.learnMoreLinkText": "詳細", - "xpack.ml.settings.calendars.listHeader.calendarsListTotalCount": "合計 {totalCount}", - "xpack.ml.settings.calendars.listHeader.calendarsTitle": "カレンダー", - "xpack.ml.settings.calendars.listHeader.refreshButtonLabel": "更新", - "xpack.ml.settings.filterLists.addItemPopover.addButtonLabel": "追加", - "xpack.ml.settings.filterLists.addItemPopover.addItemButtonLabel": "アイテムを追加", - "xpack.ml.settings.filterLists.addItemPopover.enterItemPerLineDescription": "1 行につき 1 つアイテムを追加します", - "xpack.ml.settings.filterLists.addItemPopover.itemsLabel": "アイテム", - "xpack.ml.settings.filterLists.deleteFilterListModal.cancelButtonLabel": "キャンセル", - "xpack.ml.settings.filterLists.deleteFilterListModal.confirmButtonLabel": "削除", - "xpack.ml.settings.filterLists.deleteFilterListModal.deleteButtonLabel": "削除", - "xpack.ml.settings.filterLists.deleteFilterListModal.deleteWarningMessage": "{selectedFilterListsLength, plural, one {このフィルダー} other {これらのフィルター}}を削除してよろしいですか?", - "xpack.ml.settings.filterLists.deleteFilterListModal.modalTitle": "{selectedFilterListsLength, plural, one {{selectedFilterId}} other {# フィルターリスト}}の削除", - "xpack.ml.settings.filterLists.deleteFilterLists.deletingErrorMessage": "フィルターリスト {filterListId} の削除中にエラーが発生しました。{respMessage}", - "xpack.ml.settings.filterLists.deleteFilterLists.deletingNotificationMessage": "{filterListsToDeleteLength, plural, one {{filterListToDeleteId}} other {# フィルターリスト}}を削除しています", - "xpack.ml.settings.filterLists.deleteFilterLists.filtersSuccessfullyDeletedNotificationMessage": "{filterListsToDeleteLength, plural, one {{filterListToDeleteId}} other {# フィルターリスト}} が削除されました", - "xpack.ml.settings.filterLists.editDescriptionPopover.editDescriptionAriaLabel": "説明を編集", - "xpack.ml.settings.filterLists.editDescriptionPopover.filterListDescriptionAriaLabel": "フィルターリストの説明", - "xpack.ml.settings.filterLists.editFilterHeader.allowedCharactersDescription": "アルファベットの小文字 (a-z と 0-9)、ハイフンまたはアンダーラインを使用し、最初と最後を英数字にする必要があります", - "xpack.ml.settings.filterLists.editFilterHeader.createFilterListTitle": "新規フィルターリストの作成", - "xpack.ml.settings.filterLists.editFilterHeader.filterListIdAriaLabel": "フィルターリスト ID", - "xpack.ml.settings.filterLists.editFilterHeader.filterListTitle": "フィルターリスト {filterId}", - "xpack.ml.settings.filterLists.editFilterList.acrossText": "すべてを対象にする", - "xpack.ml.settings.filterLists.editFilterList.addDescriptionText": "説明を追加", - "xpack.ml.settings.filterLists.editFilterList.cancelButtonLabel": "キャンセル", - "xpack.ml.settings.filterLists.editFilterList.duplicatedItemsInFilterListWarningMessage": "次のアイテムはフィルターリストに既に存在します: {alreadyInFilter}", - "xpack.ml.settings.filterLists.editFilterList.filterIsNotUsedInJobsDescription": "このフィルターリストはどのジョブにも使用されていません。", - "xpack.ml.settings.filterLists.editFilterList.filterIsUsedInJobsDescription": "このフィルターリストは次のジョブに使用されています:", - "xpack.ml.settings.filterLists.editFilterList.loadingDetailsOfFilterErrorMessage": "フィルター {filterId} の詳細の読み込み中にエラーが発生しました", - "xpack.ml.settings.filterLists.editFilterList.saveButtonLabel": "保存", - "xpack.ml.settings.filterLists.editFilterList.savingFilterErrorMessage": "フィルター {filterId} の保存中にエラーが発生しました", - "xpack.ml.settings.filterLists.editFilterList.totalItemsDescription": "合計{totalItemCount, plural, one {# 個のアイテム} other {# 個のアイテム}}", - "xpack.ml.settings.filterLists.filterLists.loadingFilterListsErrorMessage": "フィルターリストの読み込み中にエラーが発生しました", - "xpack.ml.settings.filterLists.filterWithIdExistsErrorMessage": "ID {filterId} のフィルターが既に存在します", - "xpack.ml.settings.filterLists.listHeader.filterListsContainsNotAllowedValuesDescription": "フィルターリストには、イベントを機械学習分析に含める、または除外するのに使用する値が含まれています。同じフィルターリストを複数ジョブに使用できます。{br}{learnMoreLink}", - "xpack.ml.settings.filterLists.listHeader.filterListsContainsNotAllowedValuesDescription.learnMoreLinkText": "詳細", - "xpack.ml.settings.filterLists.listHeader.filterListsDescription": "合計 {totalCount}", - "xpack.ml.settings.filterLists.listHeader.filterListsTitle": "フィルターリスト", - "xpack.ml.settings.filterLists.listHeader.refreshButtonLabel": "更新", - "xpack.ml.settings.filterLists.table.descriptionColumnName": "説明", - "xpack.ml.settings.filterLists.table.idColumnName": "ID", - "xpack.ml.settings.filterLists.table.inUseAriaLabel": "使用中", - "xpack.ml.settings.filterLists.table.inUseColumnName": "使用中", - "xpack.ml.settings.filterLists.table.itemCountColumnName": "アイテムカウント", - "xpack.ml.settings.filterLists.table.newButtonLabel": "新規", - "xpack.ml.settings.filterLists.table.noFiltersCreatedTitle": "フィルターが 1 つも作成されていません", - "xpack.ml.settings.filterLists.table.notInUseAriaLabel": "使用されていません", - "xpack.ml.settings.filterLists.toolbar.deleteItemButtonLabel": "アイテムを削除", - "xpack.ml.settings.filterListsButtonLabel": "フィルターリスト", - "xpack.ml.settings.jobManagementTitle": "ジョブ管理", - "xpack.ml.singleMetricViewerPageLabel": "シングルメトリックビューアー", - "xpack.ml.timeSeriesExplorer.allPartitionValuesLabel": "すべて", - "xpack.ml.timeSeriesExplorer.annotationDescriptionList.createdByTitle": "作成者", - "xpack.ml.timeSeriesExplorer.annotationDescriptionList.createdTitle": "作成済み", - "xpack.ml.timeSeriesExplorer.annotationDescriptionList.endTitle": "終了", - "xpack.ml.timeSeriesExplorer.annotationDescriptionList.jobIdTitle": "ジョブ ID", - "xpack.ml.timeSeriesExplorer.annotationDescriptionList.lastModifiedTitle": "最終更新:", - "xpack.ml.timeSeriesExplorer.annotationDescriptionList.modifiedByTitle": "変更者:", - "xpack.ml.timeSeriesExplorer.annotationDescriptionList.startTitle": "開始", - "xpack.ml.timeSeriesExplorer.annotationFlyout.addAnnotationTitle": "注釈の追加", - "xpack.ml.timeSeriesExplorer.annotationFlyout.annotationTextLabel": "注釈テキスト", - "xpack.ml.timeSeriesExplorer.annotationFlyout.approachingMaxLengthWarning": "残り {charsRemaining, number} {charsRemaining, plural, one {文字} other {文字}}", - "xpack.ml.timeSeriesExplorer.annotationFlyout.cancelButtonLabel": "キャンセル", - "xpack.ml.timeSeriesExplorer.annotationFlyout.createButtonLabel": "作成", - "xpack.ml.timeSeriesExplorer.annotationFlyout.deleteButtonLabel": "削除", - "xpack.ml.timeSeriesExplorer.annotationFlyout.editAnnotationTitle": "注釈を編集します", - "xpack.ml.timeSeriesExplorer.annotationFlyout.maxLengthError": "最長 {maxChars} 文字を {charsOver, number} {charsOver, plural, one {文字} other {文字}} 超過", - "xpack.ml.timeSeriesExplorer.annotationFlyout.noAnnotationTextError": "注釈テキストを入力してください", - "xpack.ml.timeSeriesExplorer.annotationFlyout.updateButtonLabel": "更新", - "xpack.ml.timeSeriesExplorer.annotationsLabel": "注釈", - "xpack.ml.timeSeriesExplorer.annotationsTitle": "注釈", - "xpack.ml.timeSeriesExplorer.anomaliesTitle": "異常", - "xpack.ml.timeSeriesExplorer.autoSelectingFirstJobText": "、初めのジョブを自動選択します", - "xpack.ml.timeSeriesExplorer.canNotViewRequestedJobsWarningMessage": "リクエストされた‘{invalidIdsCount, plural, one {ジョブ} other {件のジョブ}} {invalidIds} をこのダッシュボードで表示できません", - "xpack.ml.timeSeriesExplorer.countDataInChartDetailsDescription": "{openBrace}{cardinalityValue} 特徴的な {fieldName} {cardinality, plural, one {} other { 値}}{closeBrace}", - "xpack.ml.timeSeriesExplorer.createNewSingleMetricJobLinkText": "新規シングルメトリックジョブを作成", - "xpack.ml.timeSeriesExplorer.dataNotChartableDescription": "選択された{entityCount, plural, one {エンティティ} other {エンティティ}}のモデルプロットは収集されていません。\nこのディテクターのソースデータはプロットできません。", - "xpack.ml.timeSeriesExplorer.deleteAnnotationModal.cancelButtonLabel": "キャンセル", - "xpack.ml.timeSeriesExplorer.deleteAnnotationModal.deleteAnnotationTitle": "この注釈を削除しますか?", - "xpack.ml.timeSeriesExplorer.deleteAnnotationModal.deleteButtonLabel": "削除", - "xpack.ml.timeSeriesExplorer.detectorLabel": "検知器", - "xpack.ml.timeSeriesExplorer.enterValuePlaceholder": "値を入力", - "xpack.ml.timeSeriesExplorer.forecastingModal.closeButtonLabel": "閉じる", - "xpack.ml.timeSeriesExplorer.forecastingModal.closingJobTitle": "ジョブをクローズ中...", - "xpack.ml.timeSeriesExplorer.forecastingModal.dataContainsMorePartitionsMessage": "このデータには {warnNumPartitions} 個以上のパーティションが含まれているため、予測の実行に時間がかかり、多くのリソースを消費する可能性があります", - "xpack.ml.timeSeriesExplorer.forecastingModal.errorWithClosingJobAfterRunningForecastErrorMessage": "予測の実行後にジョブを閉じる際にエラーが発生しました", - "xpack.ml.timeSeriesExplorer.forecastingModal.errorWithClosingJobErrorMessage": "ジョブをの取得中にエラーが発生しました", - "xpack.ml.timeSeriesExplorer.forecastingModal.errorWithLoadingStatsOfRunningForecastErrorMessage": "実行中の予測の統計の読み込み中にエラーが発生しました。", - "xpack.ml.timeSeriesExplorer.forecastingModal.errorWithObtainingListOfPreviousForecastsErrorMessage": "以前の予測のリストを取得中にエラーが発生しました", - "xpack.ml.timeSeriesExplorer.forecastingModal.errorWithOpeningJobBeforeRunningForecastErrorMessage": "予測の実行前にジョブを開く際にエラーが発生しました", - "xpack.ml.timeSeriesExplorer.forecastingModal.forecastButtonLabel": "予測", - "xpack.ml.timeSeriesExplorer.forecastingModal.forecastDurationMustNotBeGreaterThanMaximumErrorMessage": "{maximumForecastDurationDays} 日を超える予想期間は使用できません", - "xpack.ml.timeSeriesExplorer.forecastingModal.forecastDurationMustNotBeZeroErrorMessage": "予測期間は 0 にできません", - "xpack.ml.timeSeriesExplorer.forecastingModal.forecastingNotAvailableForPopulationDetectorsMessage": "オーバーフィールドでは集団検知器に予測機能を使用できません。", - "xpack.ml.timeSeriesExplorer.forecastingModal.forecastingOnlyAvailableForJobsCreatedInSpecifiedVersionMessage": "予測はバージョン{minVersion} 以降で作成されたジョブでのみ利用できます", - "xpack.ml.timeSeriesExplorer.forecastingModal.forecastingTitle": "予測を行う", - "xpack.ml.timeSeriesExplorer.forecastingModal.invalidDurationFormatErrorMessage": "無効な期間フォーマット", - "xpack.ml.timeSeriesExplorer.forecastingModal.noProgressReportedForNewForecastErrorMessage": "{WarnNoProgressMs}ms の新規予測の進捗が報告されていません。予測の実行中にエラーが発生した可能性があります。", - "xpack.ml.timeSeriesExplorer.forecastingModal.openingJobTitle": "ジョブを開いています...", - "xpack.ml.timeSeriesExplorer.forecastingModal.runningForecastTitle": "予測を実行中…", - "xpack.ml.timeSeriesExplorer.forecastingModal.unexpectedResponseFromRunningForecastErrorMessage": "予測の実行中に予期せぬ応答が返されました。リクエストに失敗した可能性があります。", - "xpack.ml.timeSeriesExplorer.forecastsList.createdColumnName": "作成済み", - "xpack.ml.timeSeriesExplorer.forecastsList.fromColumnName": "開始:", - "xpack.ml.timeSeriesExplorer.forecastsList.listsOfFiveRecentlyRunForecastsTooltip": "最も最近実行された予測を最大 5 件リストアップします。", - "xpack.ml.timeSeriesExplorer.forecastsList.previousForecastsTitle": "以前の予測", - "xpack.ml.timeSeriesExplorer.forecastsList.toColumnName": "終了:", - "xpack.ml.timeSeriesExplorer.forecastsList.viewColumnName": "表示", - "xpack.ml.timeSeriesExplorer.forecastsList.viewForecastAriaLabel": "{createdDate} に作成された予測を表示", - "xpack.ml.timeSeriesExplorer.intervalLabel": "間隔", - "xpack.ml.timeSeriesExplorer.loadingLabel": "読み込み中", - "xpack.ml.timeSeriesExplorer.noResultsFoundLabel": "結果が見つかりませんでした", - "xpack.ml.timeSeriesExplorer.noSingleMetricJobsFoundLabel": "シングルメトリックジョブが見つかりませんでした", - "xpack.ml.timeSeriesExplorer.requestedDetectorIndexNotValidWarningMessage": "リクエストされた検知器インデックス {detectorIndex} はジョブ {jobId} に有効ではありません", - "xpack.ml.timeSeriesExplorer.runControls.durationLabel": "期間", - "xpack.ml.timeSeriesExplorer.runControls.forecastMaximumLengthHelpText": "予想の長さで、最長 {maximumForecastDurationDays} 日です。秒には s、分には m、時間には h、日には d、週には w を使います。", - "xpack.ml.timeSeriesExplorer.runControls.forecastsCanNotBeRunOnJobsTooltip": "予測は {jobState} のジョブには利用できません。", - "xpack.ml.timeSeriesExplorer.runControls.noMLNodesAvailableTooltip": "利用可能な ML ノードがありません。", - "xpack.ml.timeSeriesExplorer.runControls.runButtonLabel": "実行", - "xpack.ml.timeSeriesExplorer.runControls.runNewForecastTitle": "新規予測の実行", - "xpack.ml.timeSeriesExplorer.severityThresholdLabel": "深刻度のしきい値", - "xpack.ml.timeSeriesExplorer.showForecastLabel": "予測を表示", - "xpack.ml.timeSeriesExplorer.showModelBoundsLabel": "モデルバウンドを表示", - "xpack.ml.timeSeriesExplorer.singleTimeSeriesAnalysisTitle": "{functionLabel} の単独時系列分析", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.addedAnnotationNotificationMessage": "ID {jobId} のジョブに注釈が追加されました。", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.deletedAnnotationNotificationMessage": "ID {jobId} のジョブの注釈が削除されました。", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.errorWithCreatingAnnotationNotificationErrorMessage": "ID {jobId} のジョブの注釈を作成中にエラーが発生しました: {error}", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.errorWithDeletingAnnotationNotificationErrorMessage": "ID {jobId} のジョブの注釈を削除中にエラーが発生しました: {error}", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.errorWithUpdatingAnnotationNotificationErrorMessage": "ID {jobId} のジョブの注釈を更新中にエラーが発生しました: {error}", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.modelBoundsNotAvailableLabel": "モデルバウンドが利用できません", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.updatedAnnotationNotificationMessage": "ID {jobId} のジョブの注釈が更新されました。", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.zoomAggregationIntervalLabel": "(集約間隔: {focusAggInt}、バケットスパン: {bucketSpan})", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.zoomGroupAggregationIntervalLabel": "(集約間隔: 、バケットスパン: )", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.zoomLabel": "ズーム:", - "xpack.ml.timeSeriesExplorer.tryWideningTheTimeSelectionDescription": "時間範囲を広げるか、さらに過去に遡ってみてください。", - "xpack.ml.timeSeriesExplorer.youCanViewOneJobAtTimeWarningMessage": "このダッシュボードでは 1 度に 1 つのジョブしか表示できません", - "xpack.ml.tooltips.newJobDedicatedIndexTooltip": "選択すると、このジョブの結果が別のインデックスに格納されます。", - "xpack.ml.tooltips.newJobRecognizerJobPrefixTooltip": "それぞれのジョブ ID の頭に付ける接頭辞です。", - "xpack.ml.upgrade.upgradeWarning.upgradeInProgressWarningDescription": "機械学習に関連したインデックスは現在アップグレード中です。", - "xpack.ml.upgrade.upgradeWarning.upgradeInProgressWarningDescriptionExtra": "現在いくつかのアクションが利用できません。", - "xpack.ml.upgrade.upgradeWarning.upgradeInProgressWarningTitle": "インデックスの移行が進行中です", - "xpack.ml.validateJob.learnMoreLinkText": "その他のリソース", - "xpack.ml.validateJob.modal.closeButtonLabel": "閉じる", - "xpack.ml.validateJob.modal.jobValidationDescriptionText": "ジョブ検証は、ジョブの構成と使用されるソースデータに一定のチェックを行い、役立つ結果が得られるよう設定を調整する方法に関する具体的なアドバイスを提供します。", - "xpack.ml.validateJob.modal.linkToJobTipsText": "詳細は {mlJobTipsLink} をご覧ください。", - "xpack.ml.validateJob.modal.linkToJobTipsText.mlJobTipsLinkText": "機械学習ジョブのヒント", - "xpack.ml.validateJob.modal.validateJobTitle": "ジョブ {title} の検証", - "xpack.ml.validateJob.validateJobButtonLabel": "ジョブを検証", - "xpack.ml.datavisualizer.actionsPanel.advancedDescription": "より高度なユースケースでは、ジョブの作成にすべてのオプションを使用します", - "xpack.ml.datavisualizer.actionsPanel.advancedTitle": "高度な設定", - "xpack.ml.datavisualizer.actionsPanel.createJobDescription": "高度なジョブウィザードでジョブを作成し、このデータの異常を検出します:", - "xpack.ml.datavisualizer.actionsPanel.createJobTitle": "ジョブの作成", - "xpack.ml.datavisualizer.dataLoader.internalServerErrorMessage": "インデックス {index} のデータの読み込み中にエラーが発生。{message}。リクエストがタイムアウトした可能性があります。小さなサンプルサイズを使うか、時間範囲を狭めてみてください。", - "xpack.ml.datavisualizer.fieldsPanel.fieldsCountDescription": "ドキュメントに {wrappedCardsCount} {cardsCount, plural, one {個のフィールドが存在します} other {個のフィールドが存在します}} (合計 {wrappedTotalFieldCount} 個)", - "xpack.ml.datavisualizer.fieldsPanel.filterFieldsPlaceholder": "フィルター", - "xpack.ml.datavisualizer.fieldsPanel.searchBarError": "検索の実行中にエラーが発生。{message}。", - "xpack.ml.datavisualizer.fieldsPanel.showAllCountDescription": "{wrappedCardsCount} {cardsCount, plural, one {field} other {fields}} ({wrappedPopulatedFieldCount} {populatedFieldCount, plural, one {exists} other {exist}}ドキュメントに)", - "xpack.ml.datavisualizer.fieldsPanel.showEmptyFieldsLabel": "空のフィールドを表示", - "xpack.ml.datavisualizer.fieldTypesSelect.allFieldsTypeOptionLabel": "すべてのフィールドタイプ", - "xpack.ml.datavisualizer.fieldTypesSelect.selectAriaLabel": "表示するフィールドタイプを選択してください", - "xpack.ml.datavisualizer.fieldTypesSelect.typeOptionLabel": "{fieldType} タイプ", - "xpack.ml.datavisualizer.page.errorLoadingDataMessage": "インデックス {index} のデータの読み込み中にエラーが発生。{message}。", - "xpack.ml.datavisualizer.page.fieldsPanelTitle": "フィールド", - "xpack.ml.datavisualizer.page.metricsPanelTitle": "メトリック", - "xpack.ml.datavisualizer.searchPanel.allOptionLabel": "すべて", - "xpack.ml.datavisualizer.searchPanel.documentsPerShardLabel": "合計 {wrappedTotalCount} {totalCount, plural, one {document} other {documents}}からのシャードごとのドキュメント数", - "xpack.ml.datavisualizer.searchPanel.kqlEditOnlyLabel": "現在 KQAL で保存された検索のみ編集できます。", - "xpack.ml.datavisualizer.searchPanel.queryBarPlaceholder": "小さいサンプルサイズを選択することで、クエリの実行時間を短縮しクラスターへの負荷を軽減できます。", - "xpack.ml.datavisualizer.searchPanel.queryBarPlaceholderText": "検索… (例: status:200 AND extension:\"PHP\")", - "xpack.ml.datavisualizer.searchPanel.sampleLabel": "サンプル", - "xpack.ml.datavisualizer.searchPanel.sampleSizeAriaLabel": "サンプリングするドキュメント数を選択してください", - "xpack.ml.dfAnalyticsList.analyticsDetails.messagesPane.errorMessage": "メッセージを読み込めませんでした", - "xpack.ml.fieldDataCard.cardBoolean.documentsCountDescription": "{count, plural, zero {# document} one {# document} other {# documents}} ({docsPercent}%)", - "xpack.ml.fieldDataCard.cardDate.documentsCountDescription": "{count, plural, zero {# document} one {# document} other {# documents}} ({docsPercent}%)", - "xpack.ml.fieldDataCard.cardDate.earliestDescription": "最も古い {earliestFormatted}", - "xpack.ml.fieldDataCard.cardDate.latestDescription": "最近の {latestFormatted}", - "xpack.ml.fieldDataCard.cardGeoPoint.distinctCountDescription": "{cardinality} 個の特徴的な {cardinality, plural, zero {value} one {value} other {values}}", - "xpack.ml.fieldDataCard.cardGeoPoint.documentsCountDescription": "{count, plural, zero {# document} one {# document} other {# documents}} ({docsPercent}%)", - "xpack.ml.fieldDataCard.cardIp.distinctCountDescription": "{cardinality} 個の特徴的な {cardinality, plural, zero {value} one {value} other {values}}", - "xpack.ml.fieldDataCard.cardIp.documentsCountDescription": "{count, plural, zero {# document} one {# document} other {# documents}} ({docsPercent}%)", - "xpack.ml.fieldDataCard.cardKeyword.distinctCountDescription": "{cardinality} 個の特徴的な {cardinality, plural, zero {value} one {value} other {values}}", - "xpack.ml.fieldDataCard.cardKeyword.documentsCountDescription": "{count, plural, zero {# document} one {# document} other {# documents}} ({docsPercent}%)", - "xpack.ml.fieldDataCard.cardNumber.displayingPercentilesLabel": "{minPercent} - {maxPercent} パーセンタイルを表示中", - "xpack.ml.fieldDataCard.cardNumber.distinctCountDescription": "{cardinality} 個の特徴的な {cardinality, plural, zero {value} one {value} other {values}}", - "xpack.ml.fieldDataCard.cardNumber.documentsCountDescription": "{count, plural, zero {# document} one {# document} other {# documents}} ({docsPercent}%)", - "xpack.ml.fieldDataCard.cardNumber.selectMetricDetailsDisplayAriaLabel": "メトリック詳細の表示オプションを選択してください", - "xpack.ml.fieldDataCard.cardOther.distinctCountDescription": "{cardinality} 個の特徴的な {cardinality, plural, zero {value} one {value} other {values}}", - "xpack.ml.fieldDataCard.cardOther.documentsCountDescription": "{count, plural, zero {# document} one {# document} other {# documents}} ({docsPercent}%)", - "xpack.ml.fieldDataCard.cardText.examplesTitle": "{numExamples, plural, one {値} other {例}}", - "xpack.ml.fieldDataCard.cardText.fieldNotPresentDescription": "このフィールドはクエリが実行されたドキュメントの {sourceParam} フィールドにありませんでした。", - "xpack.ml.fieldDataCard.cardText.noExamplesForFieldsTitle": "このフィールドの例が取得されませんでした", - "xpack.ml.fieldDataCard.documentCountChart.seriesLabel": "ドキュメントカウント", - "xpack.ml.fieldDataCard.fieldNotInDocsLabel": "このフィールドは選択された時間範囲のドキュメントにありません", - "xpack.ml.fieldDataCard.metricDistributionChart.seriesName": "分布", - "xpack.ml.fieldDataCard.metricDistributionChart.tooltipValueBetweenLabel": "{percent}% のドキュメントに {minValFormatted} から {maxValFormatted} の間の値があります", - "xpack.ml.fieldDataCard.metricDistributionChart.tooltipValueEqualLabel": "{percent}% のドキュメントに {valFormatted} の値があります", - "xpack.ml.fieldDataCard.topValues.calculatedFromSampleDescription": "1 つのシャードにつき {topValuesSamplerShardSize} のドキュメントのサンプルで計算されています", - "xpack.ml.jobSelector.noResultsForJobLabel": "成果がありません", - "xpack.ml.jobsList.analyticsSpacesLabel": "Space", - "xpack.ml.jobsList.breadcrumb": "ジョブ", - "xpack.ml.jobsList.jobDetails.datafeedTimingStatsTitle": "タイミング統計", - "xpack.ml.jobsList.spacesLabel": "Space", - "xpack.ml.management.jobsList.accessDeniedTitle": "アクセスが拒否されました", - "xpack.ml.management.jobsList.analyticsDocsLabel": "分析ジョブドキュメント", - "xpack.ml.management.jobsList.analyticsTab": "分析", - "xpack.ml.management.jobsList.anomalyDetectionDocsLabel": "異常検知ジョブドキュメント", - "xpack.ml.management.jobsList.anomalyDetectionTab": "異常検知", - "xpack.ml.management.jobsList.jobsListTagline": "機械学習分析と異常検知ジョブを表示。", - "xpack.ml.management.jobsList.jobsListTitle": "機械学習ジョブ", - "xpack.ml.management.jobsList.noGrantedPrivilegesDescription": "ML ジョブを管理するパーミッションがありません", - "xpack.ml.management.jobsList.noPermissionToAccessLabel": "ML ジョブへのアクセスにはパーミッションが必要です", - "xpack.ml.management.jobsListTitle": "ジョブリスト", - "xpack.ml.management.mlTitle": "Machine Learning", - "xpack.ml.messagebarService.errorTitle": "エラーが発生しました", - "xpack.ml.navMenu.dataFrameAnalyticsTabLinkText": "分析", - "xpack.ml.newJob.wizard.jobDetailsStep.additionalSection.calendarsSelection.title": "カレンダー", - "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.enableModelPlot.description": "モデルバウンドのプロットに使用される他のモデル情報を格納するには選択してください。これにより、システムのパフォーマンスにオーバーヘッドが追加されるため、基数の高いデータにはお勧めしません。", - "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.enableModelPlot.title": "モデルプロットを有効にする", - "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.modelMemoryLimit.description": "分析モデルが使用するメモリー容量の上限を設定します。", - "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.modelMemoryLimit.title": "モデルメモリー制限", - "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.useDedicatedIndex.description": "選択すると、このジョブの結果が別のインデックスに格納されます。", - "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.useDedicatedIndex.title": "専用インデックスを使用", - "xpack.ml.newJob.wizard.jobDetailsStep.advancedSectionButton": "高度な設定", - "xpack.ml.newJob.wizard.jobDetailsStep.jobDescription.description": "オプションの説明テキストです", - "xpack.ml.newJob.wizard.jobDetailsStep.jobDescription.title": "ジョブの説明", - "xpack.ml.newJob.wizard.jobDetailsStep.jobGroupSelect.description": " ジョブのオプションのグループ分けです。新規グループを作成するか、既存のグループのリストから選択できます。", - "xpack.ml.newJob.wizard.jobDetailsStep.jobGroupSelect.placeholder": "ジョブを選択または作成", - "xpack.ml.newJob.wizard.jobDetailsStep.jobGroupSelect.title": "グループ", - "xpack.ml.newJob.wizard.jobDetailsStep.jobId.description": "ジョブの固有の識別子です。スペースと / ? , \" < > | * は使用できません", - "xpack.ml.newJob.wizard.jobDetailsStep.jobId.title": "ジョブ ID", - "xpack.ml.newJob.wizard.nextStepButton": "次へ", - "xpack.ml.newJob.wizard.pickFieldsStep.bucketSpan.description": "時系列分析の間隔を設定します。通常 15m ~ 1h です。", - "xpack.ml.newJob.wizard.pickFieldsStep.bucketSpan.placeholder": "バケットスパン", - "xpack.ml.newJob.wizard.pickFieldsStep.bucketSpan.title": "バケットスパン", - "xpack.ml.newJob.wizard.pickFieldsStep.bucketSpanEstimatorButton": "バケットスパンを推定", - "xpack.ml.newJob.wizard.pickFieldsStep.detectorTitle.placeholder": "{field} で分割された {title}", - "xpack.ml.newJob.wizard.pickFieldsStep.influencers.description": "どのカテゴリーフィールドが結果に影響を与えるか選択します。異常の原因は誰または何だと思いますか?1-3 個の影響因子をお勧めします。", - "xpack.ml.newJob.wizard.pickFieldsStep.influencers.title": "影響因子", - "xpack.ml.newJob.wizard.pickFieldsStep.multiMetricView.addMetric": "メトリックを追加", - "xpack.ml.newJob.wizard.pickFieldsStep.populationField.description": "選択されたフィールドのすべての値が集団として一緒にモデリングされます。この分析タイプは基数の高いデータにお勧めです。", - "xpack.ml.newJob.wizard.pickFieldsStep.populationField.placeholder": "データを分割", - "xpack.ml.newJob.wizard.pickFieldsStep.populationField.title": "集団フィールド", - "xpack.ml.newJob.wizard.pickFieldsStep.populationView.addMetric": "メトリックを追加", - "xpack.ml.newJob.wizard.pickFieldsStep.populationView.splitFieldTitle": "{field} で分割された集団", - "xpack.ml.newJob.wizard.pickFieldsStep.singleMetricView.convertToMultiMetricButton": "マルチメトリックジョブに変換", - "xpack.ml.newJob.wizard.pickFieldsStep.sparseData.description": "空のバケットを異常とみなさず無視するには選択します。カウントと合計分析に利用できます。", - "xpack.ml.newJob.wizard.pickFieldsStep.sparseData.title": "まばらなデータ", - "xpack.ml.newJob.wizard.pickFieldsStep.splitCards.dataSplitBy": "{field} で分割されたデータ", - "xpack.ml.newJob.wizard.pickFieldsStep.splitField.description": "分析のパーティションに使用するフィールドを選択します。このフィールドのそれぞれの値は、個々に独立してモデリングされます。", - "xpack.ml.newJob.wizard.pickFieldsStep.splitField.title": "フィールドの分割", - "xpack.ml.newJob.wizard.previousStepButton": "前へ", - "xpack.ml.newJob.wizard.step.jobDetailsTitle": "ジョブの詳細", - "xpack.ml.newJob.wizard.step.pickFieldsTitle": "フィールドの選択", - "xpack.ml.newJob.wizard.step.summaryTitle": "まとめ", - "xpack.ml.newJob.wizard.step.timeRangeTitle": "時間範囲", - "xpack.ml.newJob.wizard.step.validationTitle": "検証", - "xpack.ml.newJob.wizard.stepComponentWrapper.jobDetailsTitle": "ジョブの詳細", - "xpack.ml.newJob.wizard.stepComponentWrapper.pickFieldsTitle": "フィールドの選択", - "xpack.ml.newJob.wizard.stepComponentWrapper.summaryTitleIndexPattern": "インデックスパターン {title} からの新規ジョブ", - "xpack.ml.newJob.wizard.stepComponentWrapper.summaryTitleSavedSearch": "保存された検索 {title} からの新規ジョブ", - "xpack.ml.newJob.wizard.stepComponentWrapper.timeRangeTitle": "時間範囲", - "xpack.ml.newJob.wizard.stepComponentWrapper.validationTitle": "検証", - "xpack.ml.newJob.wizard.summaryStep.convertToAdvancedButton": "高度なジョブに変換", - "xpack.ml.newJob.wizard.summaryStep.createJobButton": "ジョブを作成", - "xpack.ml.newJob.wizard.summaryStep.createJobError": "ジョブの作成エラー", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.bucketSpan.title": "バケットスパン", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.enableModelPlot.title": "モデルプロットを有効にする", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.groups.placeholder": "グループが選択されていません", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.groups.title": "グループ", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.influencers.placeholder": "影響因子が選択されていません", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.influencers.title": "影響因子", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.jobDescription.placeholder": "説明が入力されていません", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.jobDescription.title": "ジョブの説明", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.jobDetails.title": "ジョブ ID", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.modelMemoryLimit.title": "モデルメモリー制限", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.populationField.placeholder": "集団フィールドが選択されていません", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.populationField.title": "集団フィールド", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.splitField.placeholder": "分割フィールドが選択されていません", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.splitField.title": "分割フィールド", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.useDedicatedIndex.title": "専用インデックスを使用", - "xpack.ml.newJob.wizard.summaryStep.postSaveOptions.createWatch": "ウォッチを作成", - "xpack.ml.newJob.wizard.summaryStep.postSaveOptions.startJobInRealTime": "リアルタイムで実行中のジョブを開始", - "xpack.ml.newJob.wizard.summaryStep.postSaveOptions.startJobInRealTimeError": "ジョブの開始エラー", - "xpack.ml.newJob.wizard.summaryStep.postSaveOptions.startJobInRealTimeSuccess": "ジョブ {jobId} が開始しました", - "xpack.ml.newJob.wizard.summaryStep.resetJobButton": "ジョブをリセット", - "xpack.ml.newJob.wizard.summaryStep.viewResultsButton": "結果を表示", - "xpack.ml.newJob.wizard.timeRangeStep.timeRangePicker.endDateLabel": "終了日", - "xpack.ml.newJob.wizard.timeRangeStep.timeRangePicker.startDateLabel": "開始日", - "xpack.ml.newJob.wizard.validateJob.bucketSpanMustBeSetErrorMessage": "バケットスパンを設定する必要があります", - "xpack.ml.newJob.wizard.validateJob.duplicatedDetectorsErrorMessage": "重複する検知器が検出されました。", - "xpack.ml.newJob.wizard.validateJob.groupNameAlreadyExists": "グループ ID が既に存在します。グループ ID は既存のジョブやグループと同じにできません。", - "xpack.ml.newJob.wizard.validateJob.jobGroupAllowedCharactersDescription": "ジョブグループ名にはアルファベットの小文字 (a-z と 0-9)、ハイフンまたはアンダーラインが使用でき、最初と最後を英数字にする必要があります", - "xpack.ml.newJob.wizard.validateJob.jobNameAllowedCharactersDescription": "ジョブ名にはアルファベットの小文字 (a-z と 0-9)、ハイフンまたはアンダーラインが使用でき、最初と最後を英数字にする必要があります", - "xpack.ml.newJob.wizard.validateJob.jobNameAlreadyExists": "ジョブ ID が既に存在しますジョブ ID は既存のジョブやグループと同じにできません。", - "xpack.ml.newJob.wizard.validateJob.modelMemoryLimitRangeInvalidErrorMessage": "モデルメモリー制限は最高値の {maxModelMemoryLimit} よりも高くできません", - "xpack.ml.newJob.wizard.validateJob.modelMemoryLimitUnitsInvalidErrorMessage": "モデルメモリー制限のデータユニットが認識されません。{str} でなければなりません", - "xpack.ml.accessDenied.description": "ML プラグインへのアクセスパーミッションがありません", - "xpack.ml.accessDenied.label": "パーミッションがありません", - "xpack.ml.anomalyDetection.anomalyExplorerLabel": "異常エクスプローラー", - "xpack.ml.anomalyDetection.jobManagementLabel": "ジョブ管理", - "xpack.ml.anomalyDetection.singleMetricViewerLabel": "シングルメトリックビューアー", - "xpack.ml.anomalyDetectionBreadcrumbLabel": "異常検知", - "xpack.ml.dataframe.analytics.create.advancedEditorMessage.dependentVariableEmpty": "従属変数フィールドは未入力のままにできません。", - "xpack.ml.dataframe.analytics.create.dependentVariableInputAriaLabel": "従属変数として使用するフィールドを入力してください。", - "xpack.ml.dataframe.analytics.create.dependentVariableLabel": "従属変数", - "xpack.ml.dataframe.analytics.create.dependentVariableOptionsFetchError": "フィールドの取得中にエラーが発生しました。ページを更新して再起動してください。", - "xpack.ml.dataframe.analytics.create.dependentVariablePlaceholder": "従属変数", - "xpack.ml.dataframe.analytics.create.enableAdvancedEditorHelpText": "高度なエディターからこのフォームには戻れません。", - "xpack.ml.dataframe.analytics.create.enableAdvancedEditorSwitch": "詳細エディターを有効にする", - "xpack.ml.dataframe.analytics.create.flyoutCancelButton": "キャンセル", - "xpack.ml.dataframe.analytics.create.flyoutCloseButton": "閉じる", - "xpack.ml.dataframe.analytics.create.flyoutCreateButton": "作成", - "xpack.ml.dataframe.analytics.create.flyoutHeaderTitle": "分析ジョブの作成", - "xpack.ml.dataframe.analytics.create.flyoutStartButton": "開始", - "xpack.ml.dataframe.analytics.create.indexPatternAlreadyExistsError": "このタイトルのインデックスパターンが既に存在します。", - "xpack.ml.dataframe.analytics.create.indexPatternExistsError": "このタイトルのインデックスパターンが既に存在します。", - "xpack.ml.dataframe.analytics.create.jobIdInvalidMaxLengthErrorMessage": "ジョブ ID は {maxLength, plural, one {# 文字} other {# 文字}} 以内でなければなりません。", - "xpack.ml.dataframe.analytics.create.outlierDetectionHelpText": "外れ値検出ジョブには表のようなデータストラクチャでマッピングされたソースインデックスが必要で、数字とブールフィールドのみ分析されます。モデルメモリー制限や分析タイプなどのカスタムオプションを適用するには、詳細エディターを使用してください。", - "xpack.ml.dataframe.analytics.create.outlierRegressionHelpText": "リグレッションジョブは数値フィールドのみを分析します。モデルメモリー制限や予測フィールド名などのカスタムオプションを適用するには、詳細エディターを使用してください。", - "xpack.ml.dataframe.analytics.create.trainingPercentLabel": "トレーニングパーセンテージ", - "xpack.ml.dataframe.analytics.regressionExploration.evaluateError": "データの読み込み中にエラーが発生しました。", - "xpack.ml.dataframe.analytics.regressionExploration.generalError": "データの読み込み中にエラーが発生しました。", - "xpack.ml.dataframe.analytics.regressionExploration.generalizationErrorTitle": "一般化エラー", - "xpack.ml.dataframe.analytics.regressionExploration.meanSquaredErrorText": "平均二乗エラー", - "xpack.ml.dataframe.analytics.regressionExploration.noDataCalloutBody": "インデックスのクエリが結果を返しませんでした。ジョブが完了済みで、インデックスにドキュメントがあることを確認してください。", - "xpack.ml.dataframe.analytics.regressionExploration.noDataCalloutTitle": "空のインデックスクエリ結果。", - "xpack.ml.dataframe.analytics.regressionExploration.noIndexCalloutBody": "インデックスのクエリが結果を返しませんでした。デスティネーションインデックスが存在し、ドキュメントがあることを確認してください。", - "xpack.ml.dataframe.analytics.regressionExploration.rSquaredText": "R の二乗", - "xpack.ml.dataframe.analytics.regressionExploration.trainingErrorTitle": "トレーニングエラー", - "xpack.ml.dataFrameAnalyticsBreadcrumbs.indexLabel": "インデックス", - "xpack.ml.datavisualizer.actionsPanel.selectKnownConfigurationDescription": "認識されたデータの既知の構成を選択します:", - "xpack.ml.dataVisualizer.fileBasedLabel": "ファイル", - "xpack.ml.datavisualizerBreadcrumbLabel": "データビジュアライザー", - "xpack.ml.explorer.distributionChart.entityLabel": "エンティティ", - "xpack.ml.jobsList.editJobFlyout.leaveAnywayButtonLabel": "それでも移動", - "xpack.ml.jobsList.editJobFlyout.saveChangesButtonLabel": "変更を保存", - "xpack.ml.jobsList.editJobFlyout.unsavedChangesDialogMessage": "保存しないと、変更が失われます。", - "xpack.ml.jobsList.editJobFlyout.unsavedChangesDialogTitle": "閉じる前に変更を保存しますか?", - "xpack.ml.models.jobValidation.messages.jobGroupIdInvalidMaxLengthErrorMessage": "ジョブグループ名は {maxLength, plural, one {# 文字} other {# 文字}} 以内でなければなりません。", - "xpack.ml.models.jobValidation.messages.jobIdInvalidMaxLengthErrorMessage": "ジョブ ID は {maxLength, plural, one {# 文字} other {# 文字}} 以内でなければなりません。", - "xpack.ml.navMenu.anomalyDetectionTabLinkText": "異常検知", - "xpack.ml.navMenu.overviewTabLinkText": "概要", - "xpack.ml.newJi18n(ob.recognize.jobsCreationFailed.resetButtonAriaLabel": "リセット", - "xpack.ml.newJob.recognize.advancedLabel": "高度な設定", - "xpack.ml.newJob.recognize.advancedSettingsAriaLabel": "高度な設定", - "xpack.ml.newJob.recognize.alreadyExistsLabel": "(既に存在します)", - "xpack.ml.newJob.recognize.analysisRunningLabel": "分析を実行中", - "xpack.ml.newJob.recognize.createJobButtonAriaLabel": "ジョブの作成", - "xpack.ml.newJob.recognize.createJobButtonLabel": "{numberOfJobs, plural, zero {Job} one {Job} other {Jobs}} を作成", - "xpack.ml.newJob.recognize.dashboardsLabel": "ダッシュボード", - "xpack.ml.newJob.recognize.datafeed.savedAriaLabel": "保存されました", - "xpack.ml.newJob.recognize.datafeed.saveFailedAriaLabel": "保存に失敗", - "xpack.ml.newJob.recognize.datafeedLabel": "データフィード", - "xpack.ml.newJob.recognize.indexPatternPageTitle": "インデックスパターン {indexPatternTitle}", - "xpack.ml.newJob.recognize.job.savedAriaLabel": "保存されました", - "xpack.ml.newJob.recognize.job.saveFailedAriaLabel": "保存に失敗", - "xpack.ml.newJob.recognize.jobGroupAllowedCharactersDescription": "ジョブグループ名にはアルファベットの小文字 (a-z と 0-9)、ハイフンまたはアンダーラインが使用でき、最初と最後を英数字にする必要があります", - "xpack.ml.newJob.recognize.jobIdPrefixLabel": "ジョブ ID の接頭辞", - "xpack.ml.newJob.recognize.jobLabel": "ジョブ名", - "xpack.ml.newJob.recognize.jobLabelAllowedCharactersDescription": "ジョブラベルにはアルファベットの小文字 (a-z と 0-9)、ハイフンまたはアンダーラインが使用でき、最初と最後を英数字にする必要があります", - "xpack.ml.newJob.recognize.jobPrefixInvalidMaxLengthErrorMessage": "ジョブ ID 接頭辞は {maxLength, plural, one {# 文字} other {# 文字}}以内でなければなりません。", - "xpack.ml.newJob.recognize.jobsCreatedTitle": "ジョブが作成されました", - "xpack.ml.newJob.recognize.jobSettingsTitle": "ジョブ設定", - "xpack.ml.newJob.recognize.jobsTitle": "ジョブ", - "xpack.ml.newJob.recognize.moduleCheckJobsExistWarningDescription": "モジュールのジョブがクラッシュしたか確認する際にエラーが発生しました。", - "xpack.ml.newJob.recognize.moduleCheckJobsExistWarningTitle": "モジュール {moduleId} の確認中にエラーが発生", - "xpack.ml.newJob.recognize.moduleSetupFailedWarningDescription": "モジュールでの{count, plural, one { 件のジョブ} other { 件のジョブ}}の作成中にエラーが発生しました。", - "xpack.ml.newJob.recognize.moduleSetupFailedWarningTitle": "モジュール {moduleId} のセットアップ中にエラーが発生", - "xpack.ml.newJob.recognize.newJobFromTitle": "{pageTitle} からの新規ジョブ", - "xpack.ml.newJob.recognize.results.savedAriaLabel": "保存されました", - "xpack.ml.newJob.recognize.results.saveFailedAriaLabel": "保存に失敗", - "xpack.ml.newJob.recognize.running.startedAriaLabel": "開始済み", - "xpack.ml.newJob.recognize.running.startFailedAriaLabel": "開始に失敗", - "xpack.ml.newJob.recognize.runningLabel": "実行中", - "xpack.ml.newJob.recognize.savedSearchPageTitle": "保存検索 {savedSearchTitle}", - "xpack.ml.newJob.recognize.searchesLabel": "検索", - "xpack.ml.newJob.recognize.searchWillBeOverwrittenLabel": "検索は上書きされます", - "xpack.ml.newJob.recognize.someJobsCreationFailed.resetButtonLabel": "リセット", - "xpack.ml.newJob.recognize.someJobsCreationFailedTitle": "一部のジョブの作成に失敗しました", - "xpack.ml.newJob.recognize.startDatafeedAfterSaveLabel": "保存後データフィードを開始", - "xpack.ml.newJob.recognize.useDedicatedIndexLabel": "専用インデックスを使用", - "xpack.ml.newJob.recognize.useFullDataLabel": "完全な {indexPatternTitle} データを使用", - "xpack.ml.newJob.recognize.usingSavedSearchDescription": "保存検索を使用すると、データフィードで使用されるクエリが、{moduleId} モジュールでデフォルトで提供されるものと異なるものになります。", - "xpack.ml.newJob.recognize.viewResultsAriaLabel": "結果を表示", - "xpack.ml.newJob.recognize.viewResultsLinkText": "結果を表示", - "xpack.ml.newJob.recognize.visualizationsLabel": "ビジュアライゼーション", - "xpack.ml.newJob.wizard.autoSetJobCreatorTimeRange.error": "インデックスの開始時刻と終了時刻の取得中にエラーが発生しました", - "xpack.ml.newJob.wizard.datafeedPreviewFlyout.closeButton": "閉じる", - "xpack.ml.newJob.wizard.datafeedPreviewFlyout.datafeedDoesNotExistLabel": "データフィードが存在しません", - "xpack.ml.newJob.wizard.datafeedPreviewFlyout.showButton": "データフィードのプレビュー", - "xpack.ml.newJob.wizard.datafeedPreviewFlyout.title": "データフィードのプレビュー", - "xpack.ml.newJob.wizard.datafeedStep.frequency.description": "検索の間隔。", - "xpack.ml.newJob.wizard.datafeedStep.frequency.title": "頻度", - "xpack.ml.newJob.wizard.datafeedStep.query.title": "Elasticsearch クエリ", - "xpack.ml.newJob.wizard.datafeedStep.queryDelay.description": "現在の時刻と最新のインプットデータ時刻の間の秒単位での遅延です。", - "xpack.ml.newJob.wizard.datafeedStep.queryDelay.title": "クエリの遅延", - "xpack.ml.newJob.wizard.datafeedStep.scrollSize.description": "検索ごとにリクエストするドキュメントの最高数です。", - "xpack.ml.newJob.wizard.datafeedStep.scrollSize.title": "スクロールサイズ", - "xpack.ml.newJob.wizard.datafeedStep.timeField.description": "インデックスパターンのデフォルトの時間フィールドは自動的に選択されますが、上書きできます。", - "xpack.ml.newJob.wizard.datafeedStep.timeField.title": "時間フィールド", - "xpack.ml.newJob.wizard.editJsonButton": "JSON を編集", - "xpack.ml.newJob.wizard.jsonFlyout.closeButton": "閉じる", - "xpack.ml.newJob.wizard.jsonFlyout.datafeed.title": "データフィード構成 JSON", - "xpack.ml.newJob.wizard.jsonFlyout.job.title": "ジョブ構成 JSON", - "xpack.ml.newJob.wizard.jsonFlyout.saveButton": "保存", - "xpack.ml.newJob.wizard.pickFieldsStep.addDetectorButton": "ディテクターを追加", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorList.deleteButton": "削除", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorList.editButton": "編集", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorList.title": "検知器", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.aggSelect.description": "実行される分析機能です (例: sum、count)。", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.aggSelect.title": "関数", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.byFieldSelect.description": "エンティティ自体の過去の動作と比較し異常が検出された個々の分析に必要です。", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.byFieldSelect.title": "フィールド別", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.cancelButton": "キャンセル", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.description.description": "デフォルトのディテクターの説明で、ディテクターの分析内容を説明します。", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.description.title": "説明", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.excludeFrequent.description": "true の場合、頻繁に発生するエンティティを自動的に認識し除外し、結果の大部分を占めるのを防ぎます。", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.excludeFrequent.title": "頻繁なものを除外", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.fieldSelect.description": "関数 sum、mean、median、max、min、info_content、distinct_count に必要です。", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.fieldSelect.title": "フィールド", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.overFieldSelect.description": "集団の動きと比較して異常が検出された部分の集団分析に必要です。", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.overFieldSelect.title": "オーバーフィールド", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.partitionFieldSelect.description": "モデリングの論理グループへの分裂を可能にします。", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.partitionFieldSelect.title": "パーティションフィールド", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.saveButton": "保存", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.title": "ディテクターの作成", - "xpack.ml.newJob.wizard.pickFieldsStep.categorizationField.description": "オプション。非構造化ログデータの場合使用。テキストデータタイプの使用をお勧めします。", - "xpack.ml.newJob.wizard.pickFieldsStep.categorizationField.title": "カテゴリー分けフィールド", - "xpack.ml.newJob.wizard.pickFieldsStep.noDetectorsCallout.message": "ジョブを作成するには最低 1 つのディテクターが必要です。", - "xpack.ml.newJob.wizard.pickFieldsStep.noDetectorsCallout.title": "ディテクターがありません", - "xpack.ml.newJob.wizard.pickFieldsStep.summaryCountField.description": "オプション。インプットデータが事前にまとめられている場合に使用、例: \\{docCountParam\\}。", - "xpack.ml.newJob.wizard.pickFieldsStep.summaryCountField.title": "サマリーカウントフィールド", - "xpack.ml.newJob.wizard.previewJsonButton": "JSON をプレビュー", - "xpack.ml.newJob.wizard.searchSelection.notFoundLabel": "一致するインデックスまたは保存検索が見つかりませんでした。", - "xpack.ml.newJob.wizard.searchSelection.savedObjectType.indexPattern": "インデックスパターン", - "xpack.ml.newJob.wizard.searchSelection.savedObjectType.search": "保存検索", - "xpack.ml.newJob.wizard.selectIndexPatternOrSavedSearch": "インデックスパターンまたは保存検索を選択してください", - "xpack.ml.newJob.wizard.step.configureDatafeedTitle": "データフィードの構成", - "xpack.ml.newJob.wizard.stepComponentWrapper.configureDatafeedTitle": "データフィードの構成", - "xpack.ml.newJob.wizard.summaryStep.datafeedConfig.title": "データフィードの構成", - "xpack.ml.newJob.wizard.summaryStep.datafeedDetails.frequency.title": "頻度", - "xpack.ml.newJob.wizard.summaryStep.datafeedDetails.query.title": "スクロールサイズ", - "xpack.ml.newJob.wizard.summaryStep.datafeedDetails.queryDelay.title": "クエリの遅延", - "xpack.ml.newJob.wizard.summaryStep.datafeedDetails.scrollSize.title": "スクロールサイズ", - "xpack.ml.newJob.wizard.summaryStep.datafeedDetails.timeField.title": "時間フィールド", - "xpack.ml.newJob.wizard.summaryStep.defaultString": "デフォルト", - "xpack.ml.newJob.wizard.summaryStep.falseLabel": "False", - "xpack.ml.newJob.wizard.summaryStep.jobConfig.title": "ジョブの構成", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.categorizationField.title": "カテゴリー分けフィールド", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.summaryCountField.title": "サマリーカウントフィールド", - "xpack.ml.newJob.wizard.summaryStep.timeRange.end.title": "終了", - "xpack.ml.newJob.wizard.summaryStep.timeRange.start.title": "開始", - "xpack.ml.newJob.wizard.summaryStep.trueLabel": "True", - "xpack.ml.newJob.wizard.validateJob.frequencyInvalidTimeIntervalFormatErrorMessage": "{value} は有効な時間間隔のフォーマット (例: {tenMinutes}、{oneHour}) ではありません。また、0 よりも大きい数字である必要があります。", - "xpack.ml.newJob.wizard.validateJob.jobGroupMaxLengthDescription": "ジョブグループ名は {maxLength, plural, one {# 文字} other {# 文字}} 以内でなければなりません。", - "xpack.ml.newJob.wizard.validateJob.jobIdInvalidMaxLengthErrorMessage": "ジョブ ID は {maxLength, plural, one {# 文字} other {# 文字}} 以内でなければなりません。", - "xpack.ml.newJob.wizard.validateJob.queryCannotBeEmpty": "データフィードクエリは未入力のままにできません。", - "xpack.ml.newJob.wizard.validateJob.queryIsInvalidEsQuery": "データフィードクエリは有効な Elasticsearch クエリでなければなりません。", - "xpack.ml.overview.analyticsList.createFirstJobMessage": "初めての分析ジョブを作ってみましょう。", - "xpack.ml.overview.analyticsList.createJobButtonText": "ジョブを作成", - "xpack.ml.overview.analyticsList.emptyPromptText": "データフレーム分析は、様々なデータ分析を行い結果と共に注釈に追加することができます。分析ジョブは注釈付きデータと共に、ソースデータのコピーを新規インデックスに保存します。", - "xpack.ml.overview.analyticsList.errorPromptTitle": "データフレーム分析リストの取得中にエラーが発生しました。", - "xpack.ml.overview.analyticsList.id": "ID", - "xpack.ml.overview.analyticsList.manageJobsButtonText": "ジョブの管理", - "xpack.ml.overview.analyticsList.PanelTitle": "分析", - "xpack.ml.overview.analyticsList.reatedTimeColumnName": "作成時刻", - "xpack.ml.overview.analyticsList.refreshJobsButtonText": "更新", - "xpack.ml.overview.analyticsList.status": "ステータス", - "xpack.ml.overview.analyticsList.tableActionLabel": "アクション", - "xpack.ml.overview.analyticsList.type": "タイプ", - "xpack.ml.overview.anomalyDetection.createFirstJobMessage": "初めての異常検知ジョブを作成しましょう。", - "xpack.ml.overview.anomalyDetection.createJobButtonText": "ジョブを作成", - "xpack.ml.overview.anomalyDetection.emptyPromptText": "機械学習により、Elasticsearch に格納された時系列データの異常検知が容易になります。1 つのメトリックを 1 台のマシンから確認したり、何百ものメトリックを何千台ものマシンから確認したりできます。データに隠れた異常を自動的に検出して問題をより素早く解決しましょう。", - "xpack.ml.overview.anomalyDetection.errorPromptTitle": "異常検出ジョブリストの取得中にエラーが発生しました。", - "xpack.ml.overview.anomalyDetection.errorWithFetchingAnomalyScoreNotificationErrorMessage": "異常スコアの取得中にエラーが発生しました: {error}", - "xpack.ml.overview.anomalyDetection.exploreActionName": "探索", - "xpack.ml.overview.anomalyDetection.manageJobsButtonText": "ジョブの管理", - "xpack.ml.overview.anomalyDetection.panelTitle": "異常検知", - "xpack.ml.overview.anomalyDetection.refreshJobsButtonText": "更新", - "xpack.ml.overview.anomalyDetection.resultActions.openJobsInAnomalyExplorerText": "{jobsCount, plural, one {{jobId}} other {# 件のジョブ}} を異常エクスプローラーで開く", - "xpack.ml.overview.anomalyDetection.tableActionLabel": "アクション", - "xpack.ml.overview.anomalyDetection.tableDocsProcessed": "処理されたドキュメント", - "xpack.ml.overview.anomalyDetection.tableId": "グループ ID", - "xpack.ml.overview.anomalyDetection.tableLatestTimestamp": "最新タイムスタンプ", - "xpack.ml.overview.anomalyDetection.tableMaxScore": "最高異常スコア", - "xpack.ml.overview.anomalyDetection.tableMaxScoreErrorTooltip": "最高異常スコアの読み込み中に問題が発生しました", - "xpack.ml.overview.anomalyDetection.tableMaxScoreTooltip": "グループ内の 24 時間以内のすべてのジョブの最高スコアです", - "xpack.ml.overview.anomalyDetection.tableNumJobs": "グループのジョブ", - "xpack.ml.overview.feedbackSectionLink": "オンラインでのフィードバック", - "xpack.ml.overview.feedbackSectionText": "機械学習に関するご意見やご提案は、お気軽に {feedbackLink} にお寄せください。", - "xpack.ml.overview.feedbackSectionTitle": "フィードバック", - "xpack.ml.overview.gettingStartedSectionCreateJob": "新規ジョブを作成中", - "xpack.ml.overview.gettingStartedSectionDocs": "ドキュメンテーション", - "xpack.ml.overview.gettingStartedSectionTitle": "はじめて使う", - "xpack.ml.overview.statsBar.failedAnalyticsLabel": "失敗", - "xpack.ml.overview.statsBar.runningAnalyticsLabel": "実行中", - "xpack.ml.overview.statsBar.stoppedAnalyticsLabel": "停止中", - "xpack.ml.overview.statsBar.totalAnalyticsLabel": "分析ジョブ合計", - "xpack.ml.overviewJobsList.statsBar.activeMLNodesLabel": "アクティブな ML ノード", - "xpack.ml.overviewJobsList.statsBar.closedJobsLabel": "ジョブを作成", - "xpack.ml.overviewJobsList.statsBar.failedJobsLabel": "失敗したジョブ", - "xpack.ml.overviewJobsList.statsBar.openJobsLabel": "ジョブを開く", - "xpack.ml.overviewJobsList.statsBar.totalJobsLabel": "合計ジョブ数", - "xpack.ml.settingsBreadcrumbLabel": "設定", - "xpack.ml.validateJob.allPassed": "すべてのチェックに合格しました", - "xpack.ml.dataframe.analytics.create.startDataFrameAnalyticsSuccessMessage": "データフレーム分析 {jobId} の開始リクエストが受け付けられました。", - "xpack.ml.dataframe.analyticsList.deleteAnalyticsSuccessMessage": "データフレーム分析 {analyticsId} の削除リクエストが受け付けられました。", - "xpack.ml.dataframe.analyticsList.startAnalyticsSuccessMessage": "データフレーム分析 {analyticsId} の開始リクエストが受け付けられました。", - "xpack.ml.dataframe.analyticsList.stopAnalyticsSuccessMessage": "データフレーム分析 {analyticsId} の停止リクエストが受け付けられました。", - "xpack.ml.dataframe.stepCreateForm.createDataFrameAnalyticsSuccessMessage": "データフレーム分析 {jobId} の作成リクエストが受け付けられました。", - "xpack.ml.explorer.distributionChart.anomalyScoreLabel": "異常スコア", - "xpack.ml.explorer.distributionChart.typicalLabel": "通常", - "xpack.ml.explorer.distributionChart.unusualByFieldValuesLabel": "{ numberOfCauses, plural, one {# 個の異常な {byFieldName} 値 } other {#{plusSign}異常な{byFieldName}値}}", - "xpack.ml.explorer.distributionChart.valueLabel": "値", - "xpack.ml.explorer.distributionChart.valueWithoutAnomalyScoreLabel": "値", - "xpack.ml.explorer.singleMetricChart.actualLabel": "実際", - "xpack.ml.explorer.singleMetricChart.anomalyScoreLabel": "異常スコア", - "xpack.ml.explorer.singleMetricChart.multiBucketImpactLabel": "複数バケットの影響", - "xpack.ml.explorer.singleMetricChart.scheduledEventsLabel": "予定イベント", - "xpack.ml.explorer.singleMetricChart.typicalLabel": "通常", - "xpack.ml.explorer.singleMetricChart.valueLabel": "値", - "xpack.ml.explorer.singleMetricChart.valueWithoutAnomalyScoreLabel": "値", - "xpack.ml.explorer.swimlane.maxAnomalyScoreLabel": "最高異常スコア", - "xpack.ml.models.jobValidation.messages.jobGroupIdValidMessage": "アルファベットの小文字 (a-z と 0-9)、ハイフンまたはアンダーライン、最初と最後を英数字にし、{maxLength, plural, one {# 文字} other {# 文字}}以内にする必要があります。", - "xpack.ml.models.jobValidation.messages.jobIdValidMessage": "アルファベットの小文字 (a-z と 0-9)、ハイフンまたはアンダーライン、最初と最後を英数字にし、{maxLength, plural, one {# 文字} other {# 文字}}以内にする必要があります。", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.actualLabel": "実際", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.anomalyScoreLabel": "異常スコア", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.modelPlotEnabled.lowerBoundsLabel": "下の境界", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.modelPlotEnabled.upperBoundsLabel": "上の境界", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.moreThanOneUnusualByFieldValuesLabel": "{numberOfCauses} 個の {plusSign}異常な{byFieldName}値", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.multiBucketImpactLabel": "複数バケットの影響", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.scheduledEventsLabel": "予定イベント {counter}", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.typicalLabel": "通常", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.valueLabel": "値", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.withoutAnomalyScore.predictionLabel": "予測", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.withoutAnomalyScore.valueLabel": "値", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.withoutAnomalyScoreAndModelPlotEnabled.lowerBoundsLabel": "下の境界", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.withoutAnomalyScoreAndModelPlotEnabled.upperBoundsLabel": "上の境界", - "xpack.transform.capability.noPermission.createTransformTooltip": "データフレーム変換を作成するパーミッションがありません。", - "xpack.transform.capability.noPermission.deleteTransformTooltip": "データフレーム変換を削除するパーミッションがありません。", - "xpack.transform.capability.noPermission.startOrStopTransformTooltip": "データフレーム変換を開始・停止するパーミッションがありません。", - "xpack.transform.models.transformService.allOtherRequestsCancelledDescription": "他のすべてのリクエストはキャンセルされました。", - "xpack.transform.models.transformService.requestToActionTimedOutErrorMessage": "「{id}」を{action}するリクエストがタイムアウトしました。{extra}", - "xpack.transform.transformList.stepDetails.previewPane.errorMessage": "プレビューを読み込めませんでした", - "xpack.transform.transformList.transformDetails.messagesPane.errorMessage": "メッセージを読み込めませんでした", - "xpack.transform.transformList.transformDetails.messagesPane.messageLabel": "メッセージ", - "xpack.transform.transformList.transformDetails.messagesPane.nodeLabel": "ノード", - "xpack.transform.transformList.transformDetails.messagesPane.timeLabel": "時間", - "xpack.transform.agg.popoverForm.aggLabel": "集約", - "xpack.transform.agg.popoverForm.aggNameAlreadyUsedError": "別の集約で既に同じ名前が使用されています。", - "xpack.transform.agg.popoverForm.aggNameInvalidCharError": "無効な名前です。「[」、「]」「>」は使用できず、名前の始めと終わりにはスペースを使用できません。", - "xpack.transform.agg.popoverForm.fieldLabel": "フィールド", - "xpack.transform.agg.popoverForm.nameLabel": "集約名", - "xpack.transform.agg.popoverForm.submitButtonLabel": "適用", - "xpack.transform.aggLabelForm.deleteItemAriaLabel": "アイテムを削除", - "xpack.transform.aggLabelForm.editAggAriaLabel": "集約を編集", - "xpack.transform.stepDefineForm.aggExistsErrorMessage": "「{aggName}」という名前の集約構成は既に存在します。", - "xpack.transform.stepDefineForm.groupByExistsErrorMessage": "「{aggName}」という名前のグループ分け構成は既に存在します。", - "xpack.transform.stepDefineForm.nestedAggListConflictErrorMessage": "「{aggListName}」とネスティングの矛盾があるため、構成「{aggName}」を追加できませんでした。", - "xpack.transform.stepDefineForm.nestedConflictErrorMessage": "「{aggNameCheck}」とネスティングの矛盾があるため、構成「{aggName}」を追加できませんでした。", - "xpack.transform.stepDefineForm.nestedGroupByListConflictErrorMessage": "「{groupByListName}」とネスティングの矛盾があるため、構成「{aggName}」を追加できませんでした。", - "xpack.transform.stepDefineForm.aggregationsLabel": "アグリゲーション(集計)", - "xpack.transform.stepDefineForm.aggregationsPlaceholder": "集約を追加…", - "xpack.transform.stepDefineForm.formHelp": "変換は、ピボット用のスケーラブルで自動化されたプロセスです。開始するにはグループ分けの条件と集約を少なくとも 1 つ選んでください。", - "xpack.transform.stepDefineForm.groupByLabel": "グループ分けの条件", - "xpack.transform.stepDefineForm.groupByPlaceholder": "グループ分けの条件フィールドを追加…", - "xpack.transform.stepDefineForm.indexPatternHelpText": "このインデックスパターンのオプションのクエリはサポートされていません。サポートされているインデックスフィールドの数は {maxIndexFields} で、このインデックスには {numIndexFields} 個のフィールドがあります。", - "xpack.transform.stepDefineForm.indexPatternLabel": "インデックスパターン", - "xpack.transform.stepDefineForm.queryHelpText": "クエリ文字列でソースデータをフィルタリングしてください (オプション)。", - "xpack.transform.stepDefineForm.queryLabel": "クエリ", - "xpack.transform.stepDefineForm.savedSearchLabel": "保存検索", - "xpack.transform.stepDefineSummary.aggregationsLabel": "アグリゲーション(集計)", - "xpack.transform.stepDefineSummary.groupByLabel": "グループ分けの条件", - "xpack.transform.stepDefineSummary.indexPatternLabel": "インデックスパターン", - "xpack.transform.stepDefineSummary.queryLabel": "クエリ", - "xpack.transform.groupby.popoverForm.aggLabel": "集約", - "xpack.transform.groupBy.popoverForm.aggNameAlreadyUsedError": "別のグループ分けの構成が既にこの名前を使用しています。", - "xpack.transform.groupBy.popoverForm.aggNameInvalidCharError": "無効な名前です。「[」、「]」「>」は使用できず、名前の始めと終わりにはスペースを使用できません。", - "xpack.transform.groupBy.popoverForm.fieldLabel": "フィールド", - "xpack.transform.groupBy.popoverForm.intervalError": "無効な間隔。", - "xpack.transform.groupBy.popoverForm.intervalLabel": "間隔", - "xpack.transform.groupBy.popoverForm.nameLabel": "グループ分け名", - "xpack.transform.groupBy.popoverForm.submitButtonLabel": "適用", - "xpack.transform.groupByLabelForm.deleteItemAriaLabel": "アイテムを削除", - "xpack.transform.groupByLabelForm.editIntervalAriaLabel": "間隔を編集", - "xpack.transform.stepCreateForm.copyTransformConfigToClipboardButton": "クリップボードにコピー", - "xpack.transform.stepCreateForm.copyTransformConfigToClipboardDescription": "ジョブを作成する Kibana 開発コンソールのコマンドをクリップボードにコピーします。", - "xpack.transform.stepCreateForm.createIndexPatternLabel": "インデックスパターンを作成", - "xpack.transform.stepCreateForm.createTransformSuccessMessage": "変換 {transformId} の作成リクエストが受け付けられました。", - "xpack.transform.stepCreateForm.creatingIndexPatternMessage": "Kibana インデックスパターンを作成中…", - "xpack.transform.stepCreateForm.discoverCardDescription": "ディスカバリでデータフレームピボットを閲覧します。", - "xpack.transform.stepCreateForm.discoverCardTitle": "ディスカバー", - "xpack.transform.stepCreateForm.transformListCardDescription": "データフレームジョブの管理ページに戻ります。", - "xpack.transform.stepCreateForm.transformListCardTitle": "データフレームジョブ", - "xpack.transform.stepCreateForm.progressTitle": "進捗", - "xpack.transform.stepCreateForm.createIndexPatternSuccessMessage": "Kibana インデックスパターン {indexPatternName} が作成されました", - "xpack.transform.stepCreateForm.startTransformSuccessMessage": "変換 {transformId} の開始リクエストが受け付けられました。", - "xpack.transform.stepDetailsForm.indexPatternTitleError": "このタイトルのインデックスパターンが既に存在します。", - "xpack.transform.stepDetailsForm.transformIdInputAriaLabel": "固有のジョブ ID を選択してください。", - "xpack.transform.stepDetailsForm.transformIdLabel": "ジョブ ID", - "xpack.transform.stepDetailsSummary.createIndexPatternMessage": "このジョブの Kibana インデックスパターンが作成されます。", - "xpack.transform.stepDetailsSummary.transformIdLabel": "ジョブ ID", - "xpack.transform.transformList.betaBadgeLabel": "ベータ", - "xpack.transform.transformList.betaBadgeTooltipContent": "変換はベータ機能です。フィードバックをお待ちしています。", - "xpack.transform.transformList.completeBatchTransformToolTip": "{transformId} は完了済みの一斉変換で、再度開始できません。", - "xpack.transform.transformList.deleteActionDisabledToolTipContent": "削除するにはデータフレームジョブを停止してください。", - "xpack.transform.transformList.deleteActionName": "削除", - "xpack.transform.transformList.deleteTransformSuccessMessage": "変換 {transformId} の削除リクエストが受け付けられました。", - "xpack.transform.transformList.deleteModalBody": "この変換を削除してよろしいですか?変換の送信先インデックスとオプションの Kibana インデックスパターンは削除されません。", - "xpack.transform.transformList.deleteModalCancelButton": "キャンセル", - "xpack.transform.transformList.deleteModalDeleteButton": "削除", - "xpack.transform.transformList.deleteModalTitle": "{transformId} 削除", - "xpack.transform.transformList.transformDetails.tabs.transformSettingsLabel": "ジョブの詳細", - "xpack.transform.transformList.rowCollapse": "{transformId} の詳細を非表示", - "xpack.transform.transformList.rowExpand": "{transformId} の詳細を表示", - "xpack.transform.transformList.startActionName": "開始", - "xpack.transform.transformList.startTransformSuccessMessage": "変換 {transformId} の開始リクエストが受け付けられました。", - "xpack.transform.transformList.startModalCancelButton": "キャンセル", - "xpack.transform.transformList.startModalStartButton": "開始", - "xpack.transform.transformList.startModalTitle": "{transformId} を開始", - "xpack.transform.transformList.stopActionName": "停止", - "xpack.transform.transformList.stopTransformSuccessMessage": "データフレーム変換 {transformId} の停止リクエストが受け付けられました。", - "xpack.transform.pivotPreview.copyClipboardTooltip": "ピボットプレビューの開発コンソールステートメントをクリップボードにコピーします。", - "xpack.transform.progress": "進捗", - "xpack.transform.sourceIndex": "ソースインデックス", - "xpack.transform.sourceIndexPreview.copyClipboardTooltip": "ソースインデックスプレビューの開発コンソールステートメントをクリップボードにコピーします。", - "xpack.transform.sourceIndexPreview.fieldSelection": "{docFieldsCount, number} 件中 {selectedFieldsLength, number} 件の {docFieldsCount, plural, one {フィールド} other {フィールド}}を選択済み", - "xpack.transform.sourceIndexPreview.rowCollapse": "縮小", - "xpack.transform.sourceIndexPreview.rowExpand": "拡張", - "xpack.transform.sourceIndexPreview.selectColumnsAriaLabel": "列を選択", - "xpack.transform.sourceIndexPreview.selectFieldsPopoverTitle": "フィールドを選択", - "xpack.transform.sourceIndexPreview.sourceIndexPatternError": "ソースインデックスデータの読み込み中にエラーが発生しました。", - "xpack.transform.sourceIndexPreview.sourceIndexPatternTitle": "ソースインデックス {indexPatternTitle}", - "xpack.transform.status": "ステータス", - "xpack.transform.tableActionLabel": "アクション", - "xpack.transform.transformsWizard.betaBadgeLabel": "ベータ", - "xpack.transform.transformsWizard.betaBadgeTooltipContent": "変換はベータ機能です。フィードバックをお待ちしています。", - "xpack.transform.transformsWizard.stepCreateTitle": "作成", - "xpack.transform.transformsWizard.stepDefineTitle": "ピボットの定義", - "xpack.transform.transformsWizard.stepDetailsTitle": "ジョブの詳細", - "xpack.transform.wizard.nextStepButton": "次へ", - "xpack.transform.wizard.previousStepButton": "前へ", - "xpack.transform.agg.popoverForm.unsupportedAggregationHelpText": "このフォームでは集約名のみを編集できます。詳細エディターを使用して、集約の他の部分を編集してください。", - "xpack.transform.app.checkingPrivilegesDescription": "権限を確認中…", - "xpack.transform.app.checkingPrivilegesErrorMessage": "サーバーからユーザー特権を取得中にエラーが発生。", - "xpack.transform.app.deniedPrivilegeDescription": "Transforms のこのセクションを使用するには、{privilegesCount, plural, one {このクラスター特権} other {これらのクラスター特権}}が必要です: {missingPrivileges}。", - "xpack.transform.app.deniedPrivilegeTitle": "クラスター特権が足りません", - "xpack.transform.appName": "データフレームジョブ", - "xpack.transform.capability.pleaseContactAdministratorTooltip": "{message} 管理者にお問い合わせください。", - "xpack.transform.createTransform.breadcrumbTitle": "変換の作成", - "xpack.transform.description": "説明", - "xpack.transform.destinationIndex": "デスティネーションインデックス", - "xpack.transform.groupBy.popoverForm.unsupportedGroupByHelpText": "このフォームでは group_by 名のみを編集できます。詳細エディターを使用して、group_by 構成の他の部分を編集してください。", - "xpack.transform.home.breadcrumbTitle": "データフレームジョブ", - "xpack.transform.list.emptyPromptButtonText": "初めての変換を作成してみましょう。", - "xpack.transform.list.emptyPromptTitle": "変換が見つかりません", - "xpack.transform.list.errorPromptTitle": "変換リストの取得中にエラーが発生しました。", - "xpack.transform.mode": "モード", - "xpack.transform.modeFilter": "モード", - "xpack.transform.multiTransformActionsMenu.managementActionsAriaLabel": "管理アクション", - "xpack.transform.multiTransformActionsMenu.transformsCount": "{count} 件の{count, plural, one {変換} other {変換}}を選択済み", - "xpack.transform.newTransform.chooseSourceTitle": "ソースの選択", - "xpack.transform.newTransform.newTransformTitle": "新規変換", - "xpack.transform.newTransform.searchSelection.notFoundLabel": "一致するインデックスまたは保存検索が見つかりませんでした。", - "xpack.transform.newTransform.searchSelection.savedObjectType.indexPattern": "インデックスパターン", - "xpack.transform.newTransform.searchSelection.savedObjectType.search": "保存検索", - "xpack.transform.pivotPreview.PivotPreviewError": "ピボットプレビューの読み込み中にエラーが発生しました。", - "xpack.transform.pivotPreview.PivotPreviewIncompleteConfigCalloutBody": "group-by フィールドと集約を 1 つ以上選んでください。", - "xpack.transform.pivotPreview.PivotPreviewNoDataCalloutBody": "プレビューリクエストはデータを返しませんでした。オプションのクエリがデータを返し、グループ分け基準により使用されるフィールドと集約フィールドに値が存在することを確認してください。", - "xpack.transform.pivotPreview.PivotPreviewNoDataCalloutTitle": "ピボットプレビューを利用できません", - "xpack.transform.pivotPreview.PivotPreviewTitle": "ピボットプレビューを変換", - "xpack.transform.sourceIndexPreview.SourceIndexArrayBadgeContent": "配列", - "xpack.transform.sourceIndexPreview.SourceIndexArrayToolTipContent": "この配列に基づく列の完全な内容は、展開された行に表示されます。", - "xpack.transform.sourceIndexPreview.SourceIndexNoDataCalloutBody": "ソースインデックスのクエリが結果を返しませんでした。インデックスにドキュメントが含まれていて、クエリ要件が妥当であることを確認してください。", - "xpack.transform.sourceIndexPreview.SourceIndexNoDataCalloutTitle": "ソースインデックスクエリの結果がありません", - "xpack.transform.sourceIndexPreview.SourceIndexObjectBadgeContent": "オブジェクト", - "xpack.transform.sourceIndexPreview.SourceIndexObjectToolTipContent": "このオブジェクトベースの列の完全な内容は、展開された行に表示されます。", - "xpack.transform.statsBar.batchTransformsLabel": "一斉", - "xpack.transform.statsBar.continuousTransformsLabel": "連続", - "xpack.transform.statsBar.failedTransformsLabel": "失敗", - "xpack.transform.statsBar.startedTransformsLabel": "開始済み", - "xpack.transform.statsBar.totalTransformsLabel": "変換合計", - "xpack.transform.statusFilter": "ステータス", - "xpack.transform.stepCreateForm.continuousModeLabel": "連続モード", - "xpack.transform.stepCreateForm.createAndStartTransformButton": "作成して開始", - "xpack.transform.stepCreateForm.createAndStartTransformDescription": "変換を作成して開始します。変換は、クラスターの検索とインデックスによる負荷を増やします。過剰な負荷が生じた場合は変換を停止してください。変換の開始後、変換の閲覧を続けるオプションが提供されます。", - "xpack.transform.stepCreateForm.createIndexPatternErrorMessage": "Kibana インデックスパターン {indexPatternName} の作成中にエラーが発生しました:", - "xpack.transform.stepCreateForm.createTransformButton": "作成", - "xpack.transform.stepCreateForm.createTransformDescription": "変換を開始せずに作成します。変換は後程変換リストに戻って開始できます。", - "xpack.transform.stepCreateForm.createTransformErrorMessage": "変換 {transformId} の取得中にエラーが発生しました。", - "xpack.transform.stepCreateForm.duplicateIndexPatternErrorMessage": "Kibana インデックスパターン {indexPatternName} の作成中にエラーが発生しました:インデックスパターンが既に存在します。", - "xpack.transform.stepCreateForm.progressErrorMessage": "進捗パーセンテージの取得中にエラーが発生しました:", - "xpack.transform.stepCreateForm.startTransformButton": "開始", - "xpack.transform.stepCreateForm.startTransformDescription": "変換を開始します。変換は、クラスターの検索とインデックスによる負荷を増やします。過剰な負荷が生じた場合は変換を停止してください。変換の開始後、変換の閲覧を続けるオプションが提供されます。", - "xpack.transform.stepCreateForm.startTransformErrorMessage": "変換 {transformId} の開始中にエラーが発生しました。", - "xpack.transform.stepDefineForm.advancedEditorApplyButtonText": "変更を適用", - "xpack.transform.stepDefineForm.advancedEditorAriaLabel": "高度なピボットエディター", - "xpack.transform.stepDefineForm.advancedEditorHelpText": "詳細エディターでは、変換のピボット構成を編集できます。", - "xpack.transform.stepDefineForm.advancedEditorHelpTextLink": "使用可能なオプションの詳細を確認してください。", - "xpack.transform.stepDefineForm.advancedEditorLabel": "ピボット構成オブジェクト", - "xpack.transform.stepDefineForm.advancedEditorSourceConfigSwitchLabel": "クエリの詳細エディター", - "xpack.transform.stepDefineForm.advancedEditorSwitchLabel": "ピボットの詳細エディター", - "xpack.transform.stepDefineForm.advancedEditorSwitchModalBodyText": "詳細エディターの変更は適用されませんでした。詳細エディターを無効にすると、編集内容が失われます。", - "xpack.transform.stepDefineForm.advancedEditorSwitchModalCancelButtonText": "キャンセル", - "xpack.transform.stepDefineForm.advancedEditorSwitchModalConfirmButtonText": "詳細エディターを無効にする", - "xpack.transform.stepDefineForm.advancedEditorSwitchModalTitle": "適用されていない変更", - "xpack.transform.stepDefineForm.advancedSourceEditorApplyButtonText": "変更を適用", - "xpack.transform.stepDefineForm.advancedSourceEditorAriaLabel": "クエリの詳細エディター", - "xpack.transform.stepDefineForm.advancedSourceEditorHelpText": "高度なエディターでは、変換のソースクエリ句を編集できます。", - "xpack.transform.stepDefineForm.advancedSourceEditorLabel": "ソースクエリ句", - "xpack.transform.stepDefineForm.advancedSourceEditorSwitchModalBodyText": "KQL クエリバーに戻すと、編集内容が失われます。", - "xpack.transform.stepDefineForm.advancedSourceEditorSwitchModalConfirmButtonText": "KQL に切り替える", - "xpack.transform.stepDefineForm.advancedSourceEditorSwitchModalTitle": "編集内容は失われます", - "xpack.transform.stepDefineForm.queryPlaceholder": "例: {example}.", - "xpack.transform.stepDefineSummary.queryCodeBlockLabel": "クエリ", - "xpack.transform.stepDefineSummary.savedSearchLabel": "保存検索", - "xpack.transform.stepDetailsForm.continuousModeAriaLabel": "遅延を選択してください。", - "xpack.transform.stepDetailsForm.continuousModeDateFieldHelpText": "新しいドキュメントを特定するために使用できる日付フィールドを選択してください。", - "xpack.transform.stepDetailsForm.continuousModeDateFieldLabel": "日付フィールド", - "xpack.transform.stepDetailsForm.continuousModeDelayError": "無効な遅延フォーマット", - "xpack.transform.stepDetailsForm.continuousModeDelayHelpText": "現在の時刻と最新のインプットデータ時刻の間の遅延です。", - "xpack.transform.stepDetailsForm.continuousModeDelayLabel": "遅延", - "xpack.transform.stepDetailsForm.continuousModeError": "日付フィールドがないインデックスでは、連続モードを使用できません。", - "xpack.transform.stepDetailsForm.destinationIndexHelpText": "この名前のインデックスが既に存在します。この変換を実行すると、デスティネーションインデックスが変更されます。", - "xpack.transform.stepDetailsForm.destinationIndexInputAriaLabel": "固有の宛先インデックス名を選択してください。", - "xpack.transform.stepDetailsForm.destinationIndexInvalidError": "無効なデスティネーションインデックス名。", - "xpack.transform.stepDetailsForm.destinationIndexInvalidErrorLink": "インデックス名の制限に関する詳細。", - "xpack.transform.stepDetailsForm.destinationIndexLabel": "デスティネーションインデックス", - "xpack.transform.stepDetailsForm.errorGettingIndexNames": "既存のインデックス名の取得中にエラーが発生しました:", - "xpack.transform.stepDetailsForm.errorGettingIndexPatternTitles": "既存のインデックスパターンのタイトルの取得中にエラーが発生しました:", - "xpack.transform.stepDetailsForm.errorGettingTransformList": "既存の変換 ID の取得中にエラーが発生しました:", - "xpack.transform.stepDetailsForm.transformDescriptionHelpText": "オプションの説明テキストです。", - "xpack.transform.stepDetailsForm.transformDescriptionInputAriaLabel": "オプションの変換の説明を選択してください。", - "xpack.transform.stepDetailsForm.transformDescriptionLabel": "変換の説明", - "xpack.transform.stepDetailsForm.transformIdExistsError": "この ID の変換が既に存在します。", - "xpack.transform.stepDetailsForm.transformIdInvalidError": "小文字のアルファベットと数字 (a-z と 0-9)、ハイフンまたはアンダーラインのみ使用でき、最初と最後を英数字にする必要があります。", - "xpack.transform.stepDetailsSummary.continuousModeDateFieldLabel": "連続モード日付フィールド", - "xpack.transform.stepDetailsSummary.destinationIndexLabel": "デスティネーションインデックス", - "xpack.transform.stepDetailsSummary.transformDescriptionLabel": "変換の説明", - "xpack.transform.toastText.closeModalButtonText": "閉じる", - "xpack.transform.toastText.modalTitle": "詳細を入力", - "xpack.transform.toastText.openModalButtonText": "詳細を表示", - "xpack.transform.transformForm.sizeNotationPlaceholder": "例: {example1}、{example2}、{example3}、{example4}", - "xpack.transform.transformList.bulkDeleteModalBody": "{count, plural, one {この} other {これらの}} {count} 件の{count, plural, one {変換} other {変換}}を削除してよろしいですか?変換の送信先インデックスとオプションの Kibana インデックスパターンは削除されません。", - "xpack.transform.transformList.bulkDeleteModalTitle": "{count} 件の{count, plural, one {変換} other {変換}}を削除", - "xpack.transform.transformList.bulkStartModalTitle": "{count} 件の{count, plural, one {変換} other {変換}}を開始", - "xpack.transform.transformList.completeBatchTransformBulkActionToolTip": "1 つまたは複数の変換が完了済みの一斉変換で、再度開始できません。", - "xpack.transform.transformList.createTransformButton": "変換の作成", - "xpack.transform.transformList.deleteBulkActionDisabledToolTipContent": "削除するには、選択された変換のうちの 1 つまたは複数を停止する必要があります。", - "xpack.transform.transformList.deleteTransformErrorMessage": "変換 {transformId} の削除中にエラーが発生しました", - "xpack.transform.transformList.deleteTransformGenericErrorMessage": "変換を削除するための API エンドポイントの呼び出し中にエラーが発生しました。", - "xpack.transform.transformList.refreshButtonLabel": "更新", - "xpack.transform.transformList.startedTransformBulkToolTip": "1 つまたは複数の変換が既に開始済みです。", - "xpack.transform.transformList.startedTransformToolTip": "{transformId} は既に開始済みです。", - "xpack.transform.transformList.startModalBody": "変換は、クラスターの検索とインデックスによる負荷を増やします。過剰な負荷が生じた場合は変換を停止してください。{count, plural, one {この} other {これら}} {count} 件の{count, plural, one {変換} other {変換}}を開始してよろしいですか?", - "xpack.transform.transformList.startTransformErrorMessage": "変換 {transformId} の開始中にエラーが発生しました", - "xpack.transform.transformList.stoppedTransformBulkToolTip": "1 つまたは複数の変換が既に開始済みです。", - "xpack.transform.transformList.stoppedTransformToolTip": "{transformId} は既に停止済みです。", - "xpack.transform.transformList.stopTransformErrorMessage": "データフレーム変換 {transformId} の停止中にエラーが発生しました", - "xpack.transform.transformList.transformDetails.tabs.transformMessagesLabel": "メッセージ", - "xpack.transform.transformList.transformDetails.tabs.transformPreviewLabel": "プレビュー", - "xpack.transform.transformList.transformTitle": "データフレームジョブ", - "xpack.transform.transformsWizard.createTransformTitle": "変換の作成", - "xpack.monitoring.accessDenied.backToKibanaButtonLabel": "Kibana に戻る", - "xpack.monitoring.accessDenied.clusterNotConfiguredDescription": "専用の監視クラスターへのアクセスを試みている場合、監視クラスターで構成されていないユーザーとしてログインしていることが原因である可能性があります。", - "xpack.monitoring.accessDenied.notAuthorizedDescription": "監視アクセスが許可されていません。監視を利用するには、「{kibanaUser}」と「{monitoringUser}」の両方のロールからの権限が必要です。", - "xpack.monitoring.accessDeniedTitle": "アクセス拒否", - "xpack.monitoring.ajaxErrorHandler.httpErrorMessage": "HTTP {errStatus}", - "xpack.monitoring.ajaxErrorHandler.requestErrorNotificationTitle": "監視リクエストエラー", - "xpack.monitoring.ajaxErrorHandler.requestFailedNotification.retryButtonLabel": "再試行", - "xpack.monitoring.ajaxErrorHandler.requestFailedNotificationTitle": "監視リクエスト失敗", - "xpack.monitoring.alerts.categoryColumn.generalLabel": "一般", - "xpack.monitoring.alerts.categoryColumnTitle": "カテゴリー", - "xpack.monitoring.alerts.clusterAlertsTitle": "クラスターアラート", - "xpack.monitoring.alerts.clusterOverviewLinkLabel": "« クラスターの概要", - "xpack.monitoring.alerts.filterAlertsPlaceholder": "フィルターアラート…", - "xpack.monitoring.alerts.highSeverityName": "高", - "xpack.monitoring.alerts.lastCheckedColumnTitle": "最終確認", - "xpack.monitoring.alerts.lowSeverityName": "低", - "xpack.monitoring.alerts.mediumSeverityName": "中", - "xpack.monitoring.alerts.messageColumnTitle": "メッセージ", - "xpack.monitoring.alerts.notResolvedDescription": "未解決", - "xpack.monitoring.alerts.resolvedAgoDescription": "{duration} 前", - "xpack.monitoring.alerts.resolvedColumnTitle": "解決済み", - "xpack.monitoring.alerts.severityTitle": "{severity}深刻度アラート", - "xpack.monitoring.alerts.statusColumnTitle": "ステータス", - "xpack.monitoring.alerts.triggeredColumnTitle": "実行済み", - "xpack.monitoring.alerts.triggeredColumnValue": "{timestamp} 前", - "xpack.monitoring.apm.healthStatusLabel": "ヘルス: {status}", - "xpack.monitoring.apm.instance.routeTitle": "{apm} - インスタンス", - "xpack.monitoring.apm.instance.status.lastEventDescription": "{timeOfLastEvent} 前", - "xpack.monitoring.apm.instance.status.lastEventLabel": "最後のイベント", - "xpack.monitoring.apm.instance.status.nameLabel": "名前", - "xpack.monitoring.apm.instance.status.outputLabel": "アウトプット", - "xpack.monitoring.apm.instance.status.uptimeLabel": "起動時間", - "xpack.monitoring.apm.instance.status.versionLabel": "バージョン", - "xpack.monitoring.apm.instance.statusDescription": "ステータス: {apmStatusIcon}", - "xpack.monitoring.apm.instances.allocatedMemoryTitle": "割当メモリー", - "xpack.monitoring.apm.instances.bytesSentRateTitle": "送信バイトレート", - "xpack.monitoring.apm.instances.filterInstancesPlaceholder": "フィルターインスタンス…", - "xpack.monitoring.apm.instances.lastEventTitle": "最後のイベント", - "xpack.monitoring.apm.instances.lastEventValue": "{timeOfLastEvent} 前", - "xpack.monitoring.apm.instances.nameTitle": "名前", - "xpack.monitoring.apm.instances.outputEnabledTitle": "アウトプットが有効です", - "xpack.monitoring.apm.instances.outputErrorsTitle": "アウトプットエラー", - "xpack.monitoring.apm.instances.routeTitle": "{apm} - インスタンス", - "xpack.monitoring.apm.instances.status.lastEventDescription": "{timeOfLastEvent} 前", - "xpack.monitoring.apm.instances.status.lastEventLabel": "最後のイベント", - "xpack.monitoring.apm.instances.status.serversLabel": "サーバー", - "xpack.monitoring.apm.instances.status.totalEventsLabel": "合計イベント数", - "xpack.monitoring.apm.instances.statusDescription": "ステータス: {apmStatusIcon}", - "xpack.monitoring.apm.instances.totalEventsRateTitle": "合計イベントレート", - "xpack.monitoring.apm.instances.versionFilter": "バージョン", - "xpack.monitoring.apm.instances.versionTitle": "バージョン", - "xpack.monitoring.apmNavigation.instancesLinkText": "インスタンス", - "xpack.monitoring.apmNavigation.overviewLinkText": "概要", - "xpack.monitoring.beats.filterBeatsPlaceholder": "ビートをフィルタリング…", - "xpack.monitoring.beats.instance.bytesSentLabel": "送信バイト", - "xpack.monitoring.beats.instance.configReloadsLabel": "構成の再読み込み", - "xpack.monitoring.beats.instance.eventsDroppedLabel": "ドロップイベント", - "xpack.monitoring.beats.instance.eventsEmittedLabel": "送信イベント", - "xpack.monitoring.beats.instance.eventsTotalLabel": "イベント合計", - "xpack.monitoring.beats.instance.handlesLimitHardLabel": "ハンドル制限 (ハード)", - "xpack.monitoring.beats.instance.handlesLimitSoftLabel": "ハンドル制限 (ソフト)", - "xpack.monitoring.beats.instance.hostLabel": "ホスト", - "xpack.monitoring.beats.instance.nameLabel": "名前", - "xpack.monitoring.beats.instance.outputLabel": "アウトプット", - "xpack.monitoring.beats.instance.routeTitle": "ビート - {instanceName} - 概要", - "xpack.monitoring.beats.instance.typeLabel": "タイプ", - "xpack.monitoring.beats.instance.uptimeLabel": "起動時間", - "xpack.monitoring.beats.instance.versionLabel": "バージョン", - "xpack.monitoring.beats.instances.allocatedMemoryTitle": "割当メモリー", - "xpack.monitoring.beats.instances.bytesSentRateTitle": "送信バイトレート", - "xpack.monitoring.beats.instances.nameTitle": "名前", - "xpack.monitoring.beats.instances.outputEnabledTitle": "アウトプットが有効です", - "xpack.monitoring.beats.instances.outputErrorsTitle": "アウトプットエラー", - "xpack.monitoring.beats.instances.totalEventsRateTitle": "合計イベントレート", - "xpack.monitoring.beats.instances.typeFilter": "タイプ", - "xpack.monitoring.beats.instances.typeTitle": "タイプ", - "xpack.monitoring.beats.instances.versionFilter": "バージョン", - "xpack.monitoring.beats.instances.versionTitle": "バージョン", - "xpack.monitoring.beats.overview.activeBeatsInLastDayTitle": "最終日のアクティブなビート", - "xpack.monitoring.beats.overview.bytesSentLabel": "送信バイト数", - "xpack.monitoring.beats.overview.latestActive.last1DayLabel": "過去 1 日", - "xpack.monitoring.beats.overview.latestActive.last1HourLabel": "過去 1 時間", - "xpack.monitoring.beats.overview.latestActive.last1MinuteLabel": "過去 1 か月", - "xpack.monitoring.beats.overview.latestActive.last20MinutesLabel": "過去 20 分間", - "xpack.monitoring.beats.overview.latestActive.last5MinutesLabel": "過去 5 分間", - "xpack.monitoring.beats.overview.noActivityDescription": "こんにちは!ここには最新のビートアクティビティが表示されますが、1 日以内にアクティビティがないようです。", - "xpack.monitoring.beats.overview.routeTitle": "ビート - 概要", - "xpack.monitoring.beats.overview.top5BeatTypesInLastDayTitle": "最終日のトップ 5 のビートタイプ", - "xpack.monitoring.beats.overview.top5VersionsInLastDayTitle": "最終日のトップ 5 のバージョン", - "xpack.monitoring.beats.overview.totalBeatsLabel": "合計ビート数", - "xpack.monitoring.beats.overview.totalEventsLabel": "合計イベント数", - "xpack.monitoring.beats.routeTitle": "Beats", - "xpack.monitoring.beatsNavigation.instance.overviewLinkText": "概要", - "xpack.monitoring.beatsNavigation.instancesLinkText": "インスタンス", - "xpack.monitoring.beatsNavigation.overviewLinkText": "概要", - "xpack.monitoring.breadcrumbs.apm.instancesLabel": "インスタンス", - "xpack.monitoring.breadcrumbs.apmLabel": "APM", - "xpack.monitoring.breadcrumbs.beats.instancesLabel": "インスタンス", - "xpack.monitoring.breadcrumbs.beatsLabel": "ビート", - "xpack.monitoring.breadcrumbs.clustersLabel": "クラスター", - "xpack.monitoring.breadcrumbs.es.ccrLabel": "CCR", - "xpack.monitoring.breadcrumbs.es.indicesLabel": "インデックス", - "xpack.monitoring.breadcrumbs.es.jobsLabel": "ジョブ", - "xpack.monitoring.breadcrumbs.es.nodesLabel": "ノード", - "xpack.monitoring.breadcrumbs.kibana.instancesLabel": "インスタンス", - "xpack.monitoring.breadcrumbs.logstash.nodesLabel": "ノード", - "xpack.monitoring.breadcrumbs.logstash.pipelinesLabel": "パイプライン", - "xpack.monitoring.breadcrumbs.logstashLabel": "Logstash", - "xpack.monitoring.chart.horizontalLegend.notAvailableLabel": "N/A", - "xpack.monitoring.chart.horizontalLegend.toggleButtonAriaLabel": "トグルボタン", - "xpack.monitoring.chart.infoTooltip.intervalLabel": "間隔", - "xpack.monitoring.chart.screenReaderUnaccessibleTitle": "このチャートはスクリーンリーダーではアクセスできません", - "xpack.monitoring.chart.seriesScreenReaderListDescription": "間隔: {bucketSize}", - "xpack.monitoring.cluster.listing.alertsInticator.alertsTooltip": "アラート", - "xpack.monitoring.cluster.listing.alertsInticator.clearStatusTooltip": "クラスターステータスはクリアです!", - "xpack.monitoring.cluster.listing.alertsInticator.clearTooltip": "クリア", - "xpack.monitoring.cluster.listing.alertsInticator.highSeverityTooltip": "クラスターにすぐに対処が必要な致命的な問題があります!", - "xpack.monitoring.cluster.listing.alertsInticator.lowSeverityTooltip": "クラスターに低深刻度の問題があります", - "xpack.monitoring.cluster.listing.alertsInticator.mediumSeverityTooltip": "クラスターに影響を及ぼす可能性がある問題があります。", - "xpack.monitoring.cluster.listing.dataColumnTitle": "データ", - "xpack.monitoring.cluster.listing.incompatibleLicense.getLicenseLinkLabel": "全機能を利用できるライセンスを取得", - "xpack.monitoring.cluster.listing.incompatibleLicense.infoMessage": "複数クラスターの監視が必要ですか?{getLicenseInfoLink} して、複数クラスターの監視をご利用ください。", - "xpack.monitoring.cluster.listing.incompatibleLicense.noMultiClusterSupportMessage": "ベーシックライセンスは複数クラスターの監視をサポートしていません。", - "xpack.monitoring.cluster.listing.incompatibleLicense.warningMessageTitle": "{clusterName} クラスターを表示できません。", - "xpack.monitoring.cluster.listing.indicesColumnTitle": "インデックス", - "xpack.monitoring.cluster.listing.invalidLicense.getBasicLicenseLinkLabel": "無料のベーシックライセンスを取得", - "xpack.monitoring.cluster.listing.invalidLicense.getLicenseLinkLabel": "全機能を利用できるライセンスを取得", - "xpack.monitoring.cluster.listing.invalidLicense.infoMessage": "ライセンスが必要ですか?{getBasicLicenseLink}、または {getLicenseInfoLink} して、複数クラスターの監視をご利用ください。", - "xpack.monitoring.cluster.listing.invalidLicense.invalidInfoMessage": "ライセンス情報が無効です。", - "xpack.monitoring.cluster.listing.invalidLicense.warningMessageTitle": "{clusterName} クラスターを表示できません。", - "xpack.monitoring.cluster.listing.kibanaColumnTitle": "Kibana", - "xpack.monitoring.cluster.listing.licenseColumnTitle": "ライセンス", - "xpack.monitoring.cluster.listing.logstashColumnTitle": "Logstash", - "xpack.monitoring.cluster.listing.nameColumnTitle": "名前", - "xpack.monitoring.cluster.listing.nodesColumnTitle": "ノード", - "xpack.monitoring.cluster.listing.standaloneClusterCallOutDismiss": "閉じる", - "xpack.monitoring.cluster.listing.standaloneClusterCallOutLink": "これらのインスタンスを表示。", - "xpack.monitoring.cluster.listing.standaloneClusterCallOutText": "または、下の表のスタンドアローンクラスターをクリックしてください", - "xpack.monitoring.cluster.listing.standaloneClusterCallOutTitle": "Elasticsearch クラスターに接続されていないインスタンスがあるようです。", - "xpack.monitoring.cluster.listing.statusColumnTitle": "ステータス", - "xpack.monitoring.cluster.overview.alertsPanel.lastCheckedTimeText": "最終確認 {updateDateTime} ({duration} 前に実行)", - "xpack.monitoring.cluster.overview.alertsPanel.severityIconTitle": "{severityIconTitle} ({time} 前に解決)", - "xpack.monitoring.cluster.overview.alertsPanel.topClusterTitle": "トップクラスターアラート", - "xpack.monitoring.cluster.overview.alertsPanel.viewAllButtonLabel": "すべてのアラートを表示", - "xpack.monitoring.cluster.overview.apmPanel.apmTitle": "APM", - "xpack.monitoring.cluster.overview.apmPanel.instancesTotalLinkAriaLabel": "APM インスタンス: {apmsTotal}", - "xpack.monitoring.cluster.overview.apmPanel.lastEventDescription": "{timeOfLastEvent} 前", - "xpack.monitoring.cluster.overview.apmPanel.lastEventLabel": "最後のイベント", - "xpack.monitoring.cluster.overview.apmPanel.memoryUsageLabel": "メモリー使用状況", - "xpack.monitoring.cluster.overview.apmPanel.overviewLinkAriaLabel": "APM の概要", - "xpack.monitoring.cluster.overview.apmPanel.overviewLinkLabel": "概要", - "xpack.monitoring.cluster.overview.apmPanel.processedEventsLabel": "処理済みのイベント", - "xpack.monitoring.cluster.overview.apmPanel.serversTotalLinkLabel": "APM Server: {apmsTotal}", - "xpack.monitoring.cluster.overview.beatsPanel.beatsTitle": "ビート", - "xpack.monitoring.cluster.overview.beatsPanel.beatsTotalLinkLabel": "ビート: {beatsTotal}", - "xpack.monitoring.cluster.overview.beatsPanel.bytesSentLabel": "送信バイト数", - "xpack.monitoring.cluster.overview.beatsPanel.instancesTotalLinkAriaLabel": "ビートインスタンス: {beatsTotal}", - "xpack.monitoring.cluster.overview.beatsPanel.overviewLinkAriaLabel": "ビートの概要", - "xpack.monitoring.cluster.overview.beatsPanel.overviewLinkLabel": "概要", - "xpack.monitoring.cluster.overview.beatsPanel.totalEventsLabel": "合計イベント数", - "xpack.monitoring.cluster.overview.esPanel.debugLogsTooltipText": "デバッグログの数です", - "xpack.monitoring.cluster.overview.esPanel.diskAvailableLabel": "利用可能なディスク容量", - "xpack.monitoring.cluster.overview.esPanel.diskUsageLabel": "ディスク使用量", - "xpack.monitoring.cluster.overview.esPanel.documentsLabel": "ドキュメント", - "xpack.monitoring.cluster.overview.esPanel.errorLogsTooltipText": "エラーログの数です", - "xpack.monitoring.cluster.overview.esPanel.fatalLogsTooltipText": "致命的ログの数です", - "xpack.monitoring.cluster.overview.esPanel.indicesCountLinkAriaLabel": "Elasticsearch インデックス: {indicesCount}", - "xpack.monitoring.cluster.overview.esPanel.indicesCountLinkLabel": "インデックス: {indicesCount}", - "xpack.monitoring.cluster.overview.esPanel.infoLogsTooltipText": "情報ログの数です", - "xpack.monitoring.cluster.overview.esPanel.jobsLabel": "ジョブ", - "xpack.monitoring.cluster.overview.esPanel.jvmHeapLabel": "{javaVirtualMachine} ヒープ", - "xpack.monitoring.cluster.overview.esPanel.logsLinkAriaLabel": "Elasticsearch ログ", - "xpack.monitoring.cluster.overview.esPanel.logsLinkLabel": "ログ", - "xpack.monitoring.cluster.overview.esPanel.nodesTotalLinkLabel": "ノード: {nodesTotal}", - "xpack.monitoring.cluster.overview.esPanel.overviewLinkAriaLabel": "Elasticsearch の概要", - "xpack.monitoring.cluster.overview.esPanel.overviewLinkLabel": "概要", - "xpack.monitoring.cluster.overview.esPanel.primaryShardsLabel": "プライマリシャード", - "xpack.monitoring.cluster.overview.esPanel.replicaShardsLabel": "レプリカシャード", - "xpack.monitoring.cluster.overview.esPanel.uptimeLabel": "起動時間", - "xpack.monitoring.cluster.overview.esPanel.versionLabel": "バージョン", - "xpack.monitoring.cluster.overview.esPanel.versionNotAvailableDescription": "N/A", - "xpack.monitoring.cluster.overview.esPanel.warnLogsTooltipText": "警告ログの数です", - "xpack.monitoring.cluster.overview.healthStatusDescription": "ヘルス: {status}", - "xpack.monitoring.cluster.overview.kibanaPanel.connectionsLabel": "接続", - "xpack.monitoring.cluster.overview.kibanaPanel.instancesCountLinkAriaLabel": "Kibana インスタンス: {instancesCount}", - "xpack.monitoring.cluster.overview.kibanaPanel.instancesCountLinkLabel": "インスタンス: {instancesCount}", - "xpack.monitoring.cluster.overview.kibanaPanel.kibanaTitle": "Kibana", - "xpack.monitoring.cluster.overview.kibanaPanel.maxResponseTimeDescription": "{maxTime} ms", - "xpack.monitoring.cluster.overview.kibanaPanel.maxResponseTimeLabel": "最高応答時間", - "xpack.monitoring.cluster.overview.kibanaPanel.memoryUsageLabel": "メモリー使用状況", - "xpack.monitoring.cluster.overview.kibanaPanel.overviewLinkAriaLabel": "Kibana の概要", - "xpack.monitoring.cluster.overview.kibanaPanel.overviewLinkLabel": "概要", - "xpack.monitoring.cluster.overview.kibanaPanel.requestsLabel": "リクエスト", - "xpack.monitoring.cluster.overview.licenseText.expireDateText": "の有効期限は {expiryDate} です", - "xpack.monitoring.cluster.overview.licenseText.toLicensePageLinkLabel": "{licenseType} ライセンス {willExpireOn}", - "xpack.monitoring.cluster.overview.logsPanel.logTypeTitle": "{type}", - "xpack.monitoring.cluster.overview.logsPanel.noLogsFound": "ログが見つかりませんでした。", - "xpack.monitoring.cluster.overview.logstashPanel.betaFeatureTooltip": "ベータ機能", - "xpack.monitoring.cluster.overview.logstashPanel.eventsEmittedLabel": "送信イベント", - "xpack.monitoring.cluster.overview.logstashPanel.eventsReceivedLabel": "受信イベント", - "xpack.monitoring.cluster.overview.logstashPanel.jvmHeapLabel": "{javaVirtualMachine} ヒープ", - "xpack.monitoring.cluster.overview.logstashPanel.logstashTitle": "Logstash", - "xpack.monitoring.cluster.overview.logstashPanel.nodesCountLinkAriaLabel": "Logstash ノード: {nodesCount}", - "xpack.monitoring.cluster.overview.logstashPanel.nodesCountLinkLabel": "ノード: {nodesCount}", - "xpack.monitoring.cluster.overview.logstashPanel.overviewLinkAriaLabel": "Logstash の概要", - "xpack.monitoring.cluster.overview.logstashPanel.overviewLinkLabel": "概要", - "xpack.monitoring.cluster.overview.logstashPanel.pipelineCountLinkAriaLabel": "Logstash パイプライン (ベータ機能): {pipelineCount}", - "xpack.monitoring.cluster.overview.logstashPanel.pipelinesCountLinkLabel": "パイプライン: {pipelineCount}", - "xpack.monitoring.cluster.overview.logstashPanel.uptimeLabel": "起動時間", - "xpack.monitoring.cluster.overview.logstashPanel.withMemoryQueuesLabel": "メモリーキューあり", - "xpack.monitoring.cluster.overview.logstashPanel.withPersistentQueuesLabel": "永続キューあり", - "xpack.monitoring.cluster.overviewTitle": "概要", - "xpack.monitoring.clusterAlerts.checkLicense.licenseIsBasicDescription": "Watcher が無効になっているか、[{clusterSource}] クラスターの現在のライセンスがベーシックの場合、クラスターアラートは表示されません。", - "xpack.monitoring.clusterAlerts.checkLicense.licenseNotActiveDescription": "[{clusterSource}] クラスターの現在のライセンス [{type}] がアクティブでないため、クラスターアラートは表示されません。", - "xpack.monitoring.clusterAlerts.checkLicense.licenseNotDeterminedDescription": "[{clusterSource}] クラスターのライセンスが確認できなかったため、クラスターアラートは表示されません。", - "xpack.monitoring.clusterAlerts.checkLicense.watcherIsDisabledDescription": "Watcher が無効なため、クラスターアラートを利用できません。", - "xpack.monitoring.clusterAlerts.clusterNeedsTSLEnabledDescription": "セキュリティが有効な場合、ゴールドまたはプラチナライセンスの適用に TLS の構成が必要です。", - "xpack.monitoring.clusterAlerts.disabledLicenseDescription": "クラスターアラート機能は無効になっています。", - "xpack.monitoring.clusterAlerts.notDeterminedLicenseDescription": "クラスターアラート機能のステータスが確認できませんでした。", - "xpack.monitoring.clusterAlerts.seeDocumentationDescription": "詳細はドキュメンテーションをご覧ください。", - "xpack.monitoring.clusterAlerts.unsupportedClusterAlertsDescription": "クラスター [{clusterName}] ライセンスタイプ [{licenseType}] はクラスターアラートをサポートしていません", - "xpack.monitoring.clusterAlertsNavigation.clusterAlertsLinkText": "クラスターアラート", - "xpack.monitoring.clustersNavigation.clustersLinkText": "クラスター", - "xpack.monitoring.clusterStats.uuidNotFoundErrorMessage": "選択された時間範囲にクラスターが見つかりませんでした。UUID: {clusterUuid}", - "xpack.monitoring.clusterStats.uuidNotSpecifiedErrorMessage": "{clusterUuid} が指定されていません", - "xpack.monitoring.elasticsearch.ccr.ccrListingTable.errorColumnTitle": "エラー", - "xpack.monitoring.elasticsearch.ccr.ccrListingTable.followsColumnTitle": "フォロー", - "xpack.monitoring.elasticsearch.ccr.ccrListingTable.indexColumnTitle": "インデックス", - "xpack.monitoring.elasticsearch.ccr.ccrListingTable.lastFetchTimeColumnTitle": "最終取得時刻", - "xpack.monitoring.elasticsearch.ccr.ccrListingTable.opsSyncedColumnTitle": "同期されたオペレーション", - "xpack.monitoring.elasticsearch.ccr.ccrListingTable.syncLagOpsColumnTitle": "同期の遅延 (オペレーション数)", - "xpack.monitoring.elasticsearch.ccr.routeTitle": "Elasticsearch - CCR", - "xpack.monitoring.elasticsearch.ccr.shard.instanceTitle": "インデックス{followerIndex} シャード: {shardId}", - "xpack.monitoring.elasticsearch.ccr.shard.routeTitle": "Elasticsearch - CCR - シャード", - "xpack.monitoring.elasticsearch.ccr.shardsTable.errorColumnTitle": "エラー", - "xpack.monitoring.elasticsearch.ccr.shardsTable.lastFetchTimeColumnTitle": "最終取得時刻", - "xpack.monitoring.elasticsearch.ccr.shardsTable.opsSyncedColumnTitle": "同期されたオペレーション", - "xpack.monitoring.elasticsearch.ccr.shardsTable.shardColumnTitle": "シャード", - "xpack.monitoring.elasticsearch.ccr.shardsTable.syncLagOpsColumn.followerLagTooltip": "フォロワーラグ: {syncLagOpsFollower}", - "xpack.monitoring.elasticsearch.ccr.shardsTable.syncLagOpsColumn.leaderLagTooltip": "リーダーラグ: {syncLagOpsLeader}", - "xpack.monitoring.elasticsearch.ccr.shardsTable.syncLagOpsColumnTitle": "同期の遅延 (オペレーション数)", - "xpack.monitoring.elasticsearch.ccrShard.errorsTable.reasonColumnTitle": "理由", - "xpack.monitoring.elasticsearch.ccrShard.errorsTable.typeColumnTitle": "タイプ", - "xpack.monitoring.elasticsearch.ccrShard.errorsTableTitle": "エラー", - "xpack.monitoring.elasticsearch.ccrShard.latestStateAdvancedButtonLabel": "高度な設定", - "xpack.monitoring.elasticsearch.ccrShard.status.failedFetchesLabel": "失敗した取得", - "xpack.monitoring.elasticsearch.ccrShard.status.followerIndexLabel": "フォロワーインデックス", - "xpack.monitoring.elasticsearch.ccrShard.status.leaderIndexLabel": "リーダーインデックス", - "xpack.monitoring.elasticsearch.ccrShard.status.opsSyncedLabel": "同期されたオペレーション", - "xpack.monitoring.elasticsearch.ccrShard.status.shardIdLabel": "シャード ID", - "xpack.monitoring.elasticsearch.clusterStatus.dataLabel": "データ", - "xpack.monitoring.elasticsearch.clusterStatus.documentsLabel": "ドキュメント", - "xpack.monitoring.elasticsearch.clusterStatus.indicesLabel": "インデックス", - "xpack.monitoring.elasticsearch.clusterStatus.memoryLabel": "メモリー", - "xpack.monitoring.elasticsearch.clusterStatus.nodesLabel": "ノード", - "xpack.monitoring.elasticsearch.clusterStatus.totalShardsLabel": "合計シャード数", - "xpack.monitoring.elasticsearch.clusterStatus.unassignedShardsLabel": "未割り当てシャード", - "xpack.monitoring.elasticsearch.healthStatusLabel": "ヘルス: {status}", - "xpack.monitoring.elasticsearch.indexDetailStatus.documentsTitle": "ドキュメント", - "xpack.monitoring.elasticsearch.indexDetailStatus.iconStatusLabel": "ヘルス: {elasticsearchStatusIcon}", - "xpack.monitoring.elasticsearch.indexDetailStatus.primariesTitle": "プライマリ", - "xpack.monitoring.elasticsearch.indexDetailStatus.totalShardsTitle": "合計シャード数", - "xpack.monitoring.elasticsearch.indexDetailStatus.totalTitle": "合計", - "xpack.monitoring.elasticsearch.indexDetailStatus.unassignedShardsTitle": "未割り当てシャード", - "xpack.monitoring.elasticsearch.indices.advanced.routeTitle": "Elasticsearch - インデックス - {indexName} - 高度な設定", - "xpack.monitoring.elasticsearch.indices.dataTitle": "データ", - "xpack.monitoring.elasticsearch.indices.documentCountTitle": "ドキュメントカウント", - "xpack.monitoring.elasticsearch.indices.howToShowSystemIndicesDescription": "システムインデックス (例: Kibana) をご希望の場合は、「システムインデックスを表示」にチェックを入れてみてください。", - "xpack.monitoring.elasticsearch.indices.indexRateTitle": "インデックスレート", - "xpack.monitoring.elasticsearch.indices.monitoringTablePlaceholder": "インデックスのフィルタリング…", - "xpack.monitoring.elasticsearch.indices.nameTitle": "名前", - "xpack.monitoring.elasticsearch.indices.noIndicesMatchYourSelectionDescription": "選択項目に一致するインデックスがありません。時間範囲を変更してみてください。", - "xpack.monitoring.elasticsearch.indices.overview.routeTitle": "Elasticsearch - インデックス - {indexName} - 概要", - "xpack.monitoring.elasticsearch.indices.routeTitle": "Elasticsearch - インデックス", - "xpack.monitoring.elasticsearch.indices.searchRateTitle": "検索レート", - "xpack.monitoring.elasticsearch.indices.statusTitle": "ステータス", - "xpack.monitoring.elasticsearch.indices.systemIndicesLabel": "システムインデックス", - "xpack.monitoring.elasticsearch.indices.unassignedShardsTitle": "未割り当てシャード", - "xpack.monitoring.elasticsearch.mlJobListing.filterJobsPlaceholder": "ジョブをフィルタリング…", - "xpack.monitoring.elasticsearch.mlJobListing.forecastsTitle": "予測", - "xpack.monitoring.elasticsearch.mlJobListing.jobIdTitle": "ジョブ ID", - "xpack.monitoring.elasticsearch.mlJobListing.modelSizeTitle": "モデルサイズ", - "xpack.monitoring.elasticsearch.mlJobListing.noDataLabel": "N/A", - "xpack.monitoring.elasticsearch.mlJobListing.nodeTitle": "ノード", - "xpack.monitoring.elasticsearch.mlJobListing.noJobsDescription": "クエリに一致する機械学習ジョブがありません。時間範囲を変更してみてください。", - "xpack.monitoring.elasticsearch.mlJobListing.processedRecordsTitle": "処理済みレコード", - "xpack.monitoring.elasticsearch.mlJobListing.stateTitle": "ステータス", - "xpack.monitoring.elasticsearch.mlJobListing.statusIconLabel": "ジョブ状態: {status}", - "xpack.monitoring.elasticsearch.mlJobs.routeTitle": "Elasticsearch - 機械学習ジョブ", - "xpack.monitoring.elasticsearch.node.advanced.routeTitle": "Elasticsearch - ノード - {nodeSummaryName} - 高度な設定", - "xpack.monitoring.elasticsearch.node.overview.routeTitle": "Elasticsearch - ノード - {nodeName} - 概要", - "xpack.monitoring.elasticsearch.node.statusIconLabel": "ステータス: {status}", - "xpack.monitoring.elasticsearch.nodeDetailStatus.dataLabel": "データ", - "xpack.monitoring.elasticsearch.nodeDetailStatus.documentsLabel": "ドキュメント", - "xpack.monitoring.elasticsearch.nodeDetailStatus.freeDiskSpaceLabel": "空きディスク容量", - "xpack.monitoring.elasticsearch.nodeDetailStatus.indicesLabel": "インデックス", - "xpack.monitoring.elasticsearch.nodeDetailStatus.jvmHeapLabel": "{javaVirtualMachine} ヒープ", - "xpack.monitoring.elasticsearch.nodeDetailStatus.shardsLabel": "シャード", - "xpack.monitoring.elasticsearch.nodeDetailStatus.transportAddress": "トランスポートアドレス", - "xpack.monitoring.elasticsearch.nodeDetailStatus.typeLabel": "タイプ", - "xpack.monitoring.elasticsearch.nodes.cells.maxText": "最高 {metric}", - "xpack.monitoring.elasticsearch.nodes.cells.minText": "最低 {metric}", - "xpack.monitoring.elasticsearch.nodes.cpuThrottlingColumnTitle": "CPU スロットル", - "xpack.monitoring.elasticsearch.nodes.cpuUsageColumnTitle": "CPU 使用状況", - "xpack.monitoring.elasticsearch.nodes.diskFreeSpaceColumnTitle": "ディスクの空き容量", - "xpack.monitoring.elasticsearch.nodes.jvmMemoryColumnTitle": "{javaVirtualMachine} メモリー", - "xpack.monitoring.elasticsearch.nodes.loadAverageColumnTitle": "平均負荷", - "xpack.monitoring.elasticsearch.nodes.monitoringTablePlaceholder": "ノードをフィルタリング…", - "xpack.monitoring.elasticsearch.nodes.nameColumnTitle": "名前", - "xpack.monitoring.elasticsearch.nodes.routeTitle": "Elasticsearch - ノード", - "xpack.monitoring.elasticsearch.nodes.shardsColumnTitle": "シャード", - "xpack.monitoring.elasticsearch.nodes.statusColumn.offlineLabel": "オフライン", - "xpack.monitoring.elasticsearch.nodes.statusColumn.onlineLabel": "オンライン", - "xpack.monitoring.elasticsearch.nodes.statusColumnTitle": "ステータス", - "xpack.monitoring.elasticsearch.shardActivity.completedRecoveriesLabel": "完了済みの復元", - "xpack.monitoring.elasticsearch.shardActivity.noActiveShardRecoveriesMessage.completedRecoveriesLinkText": "完了済みの復元", - "xpack.monitoring.elasticsearch.shardActivity.noActiveShardRecoveriesMessage.completedRecoveriesLinkTextProblem": "このクラスターにはアクティブなシャードの復元がありません。", - "xpack.monitoring.elasticsearch.shardActivity.noActiveShardRecoveriesMessage.completedRecoveriesLinkTextSolution": "{shardActivityHistoryLink} を試してみてください。", - "xpack.monitoring.elasticsearch.shardActivity.noDataMessage": "選択された時間範囲には過去のシャードアクティビティ記録がありません。", - "xpack.monitoring.elasticsearch.shardActivity.progress.noTranslogProgressLabel": "n/a", - "xpack.monitoring.elasticsearch.shardActivity.recoveryIndex.recoveryTypeDescription": "復元タイプ: {relocationType}", - "xpack.monitoring.elasticsearch.shardActivity.recoveryIndex.shardDescription": "シャード: {shard}", - "xpack.monitoring.elasticsearch.shardActivity.snapshotTitle": "レポジトリ: {repo} / スナップショット: {snapshot}", - "xpack.monitoring.elasticsearch.shardActivity.sourceTooltip": "{copiedFrom} シャードからコピーされました", - "xpack.monitoring.elasticsearch.shardActivity.sourceTooltip.primarySourceText": "プライマリ", - "xpack.monitoring.elasticsearch.shardActivity.sourceTooltip.replicaSourceText": "レプリカ", - "xpack.monitoring.elasticsearch.shardActivity.totalTimeTooltip": "開始: {startTime}", - "xpack.monitoring.elasticsearch.shardActivityTitle": "シャードアクティビティ", - "xpack.monitoring.elasticsearch.shardAllocation.clusterViewDisplayName": "ClusterView", - "xpack.monitoring.elasticsearch.shardAllocation.decorateShards.relocatingFromTextMessage": "{nodeName} から移動しています", - "xpack.monitoring.elasticsearch.shardAllocation.decorateShards.relocatingToTextMessage": "{nodeName} に移動しています", - "xpack.monitoring.elasticsearch.shardAllocation.initializingLabel": "初期化中", - "xpack.monitoring.elasticsearch.shardAllocation.labels.indicesLabel": "インデックス", - "xpack.monitoring.elasticsearch.shardAllocation.labels.nodesLabel": "ノード", - "xpack.monitoring.elasticsearch.shardAllocation.labels.unassignedLabel": "割り当てなし", - "xpack.monitoring.elasticsearch.shardAllocation.labels.unassignedNodesLabel": "ノード", - "xpack.monitoring.elasticsearch.shardAllocation.primaryLabel": "プライマリ", - "xpack.monitoring.elasticsearch.shardAllocation.relocatingLabel": "移動中", - "xpack.monitoring.elasticsearch.shardAllocation.replicaLabel": "レプリカ", - "xpack.monitoring.elasticsearch.shardAllocation.shardDisplayName": "シャード", - "xpack.monitoring.elasticsearch.shardAllocation.shardLegendTitle": "シャードの凡例", - "xpack.monitoring.elasticsearch.shardAllocation.tableBody.noShardsAllocatedDescription": "シャードが割り当てられていません。", - "xpack.monitoring.elasticsearch.shardAllocation.tableBodyDisplayName": "TableBody", - "xpack.monitoring.elasticsearch.shardAllocation.tableHead.indicesLabel": "インデックス", - "xpack.monitoring.elasticsearch.shardAllocation.unassignedDisplayName": "割り当てなし", - "xpack.monitoring.elasticsearch.shardAllocation.unassignedPrimaryLabel": "未割り当てプライマリ", - "xpack.monitoring.elasticsearch.shardAllocation.unassignedReplicaLabel": "未割り当てレプリカ", - "xpack.monitoring.errors.connectionFaultErrorMessage": "Elasticsearch 監視クラスターのネットワーク接続を確認し、詳細は Kibana のログをご覧ください。", - "xpack.monitoring.errors.insufficientUserErrorMessage": "データの監視に必要なユーザーパーミッションがありません", - "xpack.monitoring.errors.invalidAuthErrorMessage": "クラスターの監視に無効な認証です", - "xpack.monitoring.errors.noConnectionsErrorMessage": "Elasticsearch 監視クラスターのネットワーク接続を確認し、詳細は Kibana のログをご覧ください。", - "xpack.monitoring.errors.statusCodeErrorMessage": "Elasticsearch 監視クラスターのネットワーク接続、またはノードの負荷レベルを確認してください。", - "xpack.monitoring.es.indices.deletedClosedStatusLabel": "削除済み / クローズ済み", - "xpack.monitoring.es.indices.notAvailableStatusLabel": "利用不可", - "xpack.monitoring.es.indices.unknownStatusLabel": "不明", - "xpack.monitoring.es.nodes.offlineNodeStatusLabel": "オフラインノード", - "xpack.monitoring.es.nodes.offlineStatusLabel": "オフライン", - "xpack.monitoring.es.nodes.onlineStatusLabel": "オンライン", - "xpack.monitoring.es.nodeType.clientNodeLabel": "クライアントノード", - "xpack.monitoring.es.nodeType.dataOnlyNodeLabel": "データ専用ノード", - "xpack.monitoring.es.nodeType.invalidNodeLabel": "無効なノード", - "xpack.monitoring.es.nodeType.masterNodeLabel": "マスターノード", - "xpack.monitoring.es.nodeType.masterOnlyNodeLabel": "マスター専用ノード", - "xpack.monitoring.es.nodeType.nodeLabel": "ノード", - "xpack.monitoring.esNavigation.ccrLinkText": "CCR", - "xpack.monitoring.esNavigation.indicesLinkText": "インデックス", - "xpack.monitoring.esNavigation.instance.advancedLinkText": "高度な設定", - "xpack.monitoring.esNavigation.instance.overviewLinkText": "概要", - "xpack.monitoring.esNavigation.jobsLinkText": "ジョブ", - "xpack.monitoring.esNavigation.nodesLinkText": "ノード", - "xpack.monitoring.esNavigation.overviewLinkText": "概要", - "xpack.monitoring.euiTable.isFullyMigratedLabel": "Metricbeat 収集", - "xpack.monitoring.euiTable.isInternalCollectorLabel": "内部収集", - "xpack.monitoring.euiTable.isPartiallyMigratedLabel": "内部収集と Metricbeat 収集", - "xpack.monitoring.feature.reserved.description": "ユーザーアクセスを許可するには、monitoring_user ロールも割り当てる必要があります。", - "xpack.monitoring.featureRegistry.monitoringFeatureName": "スタック監視", - "xpack.monitoring.formatNumbers.notAvailableLabel": "N/A", - "xpack.monitoring.kibana.clusterStatus.connectionsLabel": "接続", - "xpack.monitoring.kibana.clusterStatus.instancesLabel": "インスタンス", - "xpack.monitoring.kibana.clusterStatus.maxResponseTimeLabel": "最高応答時間", - "xpack.monitoring.kibana.clusterStatus.memoryLabel": "メモリー", - "xpack.monitoring.kibana.clusterStatus.requestsLabel": "リクエスト", - "xpack.monitoring.kibana.detailStatus.osFreeMemoryLabel": "OS の空きメモリー", - "xpack.monitoring.kibana.detailStatus.transportAddressLabel": "トランスポートアドレス", - "xpack.monitoring.kibana.detailStatus.uptimeLabel": "起動時間", - "xpack.monitoring.kibana.detailStatus.versionLabel": "バージョン", - "xpack.monitoring.kibana.listing.filterInstancesPlaceholder": "フィルターインスタンス…", - "xpack.monitoring.kibana.listing.instanceStatus.offlineLabel": "オフライン", - "xpack.monitoring.kibana.listing.instanceStatusTitle": "インスタンスステータス: {kibanaStatus}", - "xpack.monitoring.kibana.listing.loadAverageColumnTitle": "平均負荷", - "xpack.monitoring.kibana.listing.memorySizeColumnTitle": "メモリーサイズ", - "xpack.monitoring.kibana.listing.nameColumnTitle": "名前", - "xpack.monitoring.kibana.listing.requestsColumnTitle": "リクエスト", - "xpack.monitoring.kibana.listing.responseTimeColumnTitle": "応答時間", - "xpack.monitoring.kibana.listing.statusColumnTitle": "ステータス", - "xpack.monitoring.kibana.shardActivity.bytesTitle": "バイト", - "xpack.monitoring.kibana.shardActivity.filesTitle": "ファイル", - "xpack.monitoring.kibana.shardActivity.indexTitle": "インデックス", - "xpack.monitoring.kibana.shardActivity.sourceDestinationTitle": "ソース / 行先", - "xpack.monitoring.kibana.shardActivity.stageTitle": "ステージ", - "xpack.monitoring.kibana.shardActivity.totalTimeTitle": "合計時間", - "xpack.monitoring.kibana.shardActivity.translogTitle": "Translog", - "xpack.monitoring.kibana.statusIconLabel": "ヘルス: {status}", - "xpack.monitoring.kibanaNavigation.instancesLinkText": "インスタンス", - "xpack.monitoring.kibanaNavigation.overviewLinkText": "概要", - "xpack.monitoring.license.howToUpdateLicenseDescription": "このクラスターのライセンスを更新するには、Elasticsearch {apiText}でライセンスファイルを提供してください:", - "xpack.monitoring.license.licenseRouteTitle": "ライセンス", - "xpack.monitoring.logs.listing.calloutLinkText": "ログ", - "xpack.monitoring.logs.listing.calloutTitle": "他のログを表示する場合", - "xpack.monitoring.logs.listing.clusterPageDescription": "このクラスターの最も新しいログを最高合計 {limit} 件まで表示しています。", - "xpack.monitoring.logs.listing.componentTitle": "コンポーネント", - "xpack.monitoring.logs.listing.indexPageDescription": "このインデックスの最も新しいログを最高合計 {limit} 件まで表示しています。", - "xpack.monitoring.logs.listing.levelTitle": "レベル", - "xpack.monitoring.logs.listing.linkText": "詳細は {link} をご覧ください。", - "xpack.monitoring.logs.listing.messageTitle": "メッセージ", - "xpack.monitoring.logs.listing.nodePageDescription": "このノードの最も新しいログを最高合計 {limit} 件まで表示しています。", - "xpack.monitoring.logs.listing.nodeTitle": "ノード", - "xpack.monitoring.logs.listing.pageTitle": "最近のログ", - "xpack.monitoring.logs.listing.timestampTitle": "タイムスタンプ", - "xpack.monitoring.logs.listing.typeTitle": "タイプ", - "xpack.monitoring.logs.reason.noClusterLink": "セットアップ", - "xpack.monitoring.logs.reason.noClusterMessage": "{link} が正しいことを確認してください。", - "xpack.monitoring.logs.reason.noClusterTitle": "このクラスターにはログがありません", - "xpack.monitoring.logs.reason.noIndexMessage": "ログが見つかりましたが、このインデックスのものはありません。この問題が解決されない場合は、{link} が正しいことを確認してください。", - "xpack.monitoring.logs.reason.noIndexPatternInTimePeriodMessage": "時間フィルターでタイムフレームを調整してください。", - "xpack.monitoring.logs.reason.noIndexPatternInTimePeriodTitle": "選択された時間にログはありません", - "xpack.monitoring.logs.reason.noIndexPatternLink": "Filebeat", - "xpack.monitoring.logs.reason.noIndexPatternMessage": "{link} をセットアップして、監視クラスターへの Elasticsearch アウトプットを構成してください。", - "xpack.monitoring.logs.reason.noIndexPatternTitle": "ログデータが見つかりませんでした", - "xpack.monitoring.logs.reason.noIndexTitle": "このインデックスにはログがありません", - "xpack.monitoring.logs.reason.noNodeLink": "セットアップ", - "xpack.monitoring.logs.reason.noNodeMessage": "{link} が正しいことを確認してください。", - "xpack.monitoring.logs.reason.noNodeTitle": "この Elasticsearch ノードにはログがありません", - "xpack.monitoring.logs.reason.noTypeLink": "these directions", - "xpack.monitoring.logs.reason.noTypeMessage": "{link} に従って Elasticsearch をセットアップしてください。", - "xpack.monitoring.logs.reason.noTypeTitle": "Elasticsearch のログがありません", - "xpack.monitoring.logstash.clusterStatus.eventsEmittedLabel": "送信イベント", - "xpack.monitoring.logstash.clusterStatus.eventsReceivedLabel": "受信イベント", - "xpack.monitoring.logstash.clusterStatus.memoryLabel": "メモリー", - "xpack.monitoring.logstash.clusterStatus.nodesLabel": "ノード", - "xpack.monitoring.logstash.detailStatus.batchSizeLabel": "バッチサイズ", - "xpack.monitoring.logstash.detailStatus.configReloadsLabel": "構成の再読み込み", - "xpack.monitoring.logstash.detailStatus.eventsEmittedLabel": "送信イベント", - "xpack.monitoring.logstash.detailStatus.eventsReceivedLabel": "受信イベント", - "xpack.monitoring.logstash.detailStatus.pipelineWorkersLabel": "パイプラインワーカー", - "xpack.monitoring.logstash.detailStatus.queueTypeLabel": "キュータイプ", - "xpack.monitoring.logstash.detailStatus.transportAddressLabel": "トランスポートアドレス", - "xpack.monitoring.logstash.detailStatus.uptimeLabel": "起動時間", - "xpack.monitoring.logstash.detailStatus.versionLabel": "バージョン", - "xpack.monitoring.logstash.filterNodesPlaceholder": "ノードをフィルタリング…", - "xpack.monitoring.logstash.filterPipelinesPlaceholder": "パイプラインのフィルタリング…", - "xpack.monitoring.logstash.node.advanced.routeTitle": "Logstash - {nodeName} - 高度な設定", - "xpack.monitoring.logstash.node.pipelines.notAvailableDescription": "パイプラインの監視は Logstash バージョン 6.0.0 以降でのみ利用できます。このノードはバージョン {logstashVersion} を実行しています。", - "xpack.monitoring.logstash.node.pipelines.routeTitle": "Logstash - {nodeName} - パイプライン", - "xpack.monitoring.logstash.node.routeTitle": "Logstash - {nodeName}", - "xpack.monitoring.logstash.nodes.configReloadsFailuresCountLabel": "{reloadsFailures} 失敗", - "xpack.monitoring.logstash.nodes.configReloadsSuccessCountLabel": "{reloadsSuccesses} 成功", - "xpack.monitoring.logstash.nodes.configReloadsTitle": "構成の再読み込み", - "xpack.monitoring.logstash.nodes.cpuUsageTitle": "CPU 使用状況", - "xpack.monitoring.logstash.nodes.eventsIngestedTitle": "イベントが投入されました", - "xpack.monitoring.logstash.nodes.jvmHeapUsedTitle": "{javaVirtualMachine} ヒープを使用中", - "xpack.monitoring.logstash.nodes.loadAverageTitle": "平均負荷", - "xpack.monitoring.logstash.nodes.nameTitle": "名前", - "xpack.monitoring.logstash.nodes.versionTitle": "バージョン", - "xpack.monitoring.logstash.pipeline.detailDrawer.conditionalStatementDescription": "これはパイプラインのコンディションのステートメントです。", - "xpack.monitoring.logstash.pipeline.detailDrawer.eventsEmittedLabel": "送信イベント", - "xpack.monitoring.logstash.pipeline.detailDrawer.eventsEmittedRateLabel": "イベント送信レート", - "xpack.monitoring.logstash.pipeline.detailDrawer.eventsLatencyLabel": "イベントレイテンシ", - "xpack.monitoring.logstash.pipeline.detailDrawer.eventsReceivedLabel": "受信イベント", - "xpack.monitoring.logstash.pipeline.detailDrawer.noMetricsForIfDescription": "現在この if 条件で表示するメトリックがありません。", - "xpack.monitoring.logstash.pipeline.detailDrawer.noMetricsForQueueDescription": "現在このキューに表示するメトリックがありません。", - "xpack.monitoring.logstash.pipeline.detailDrawer.specifyVertexIdDescription": "この {vertexType} には指定された ID がありません。ID を指定することで、パイプラインの変更時にその差をトラッキングできます。このプラグインの ID を次のように指定できます:", - "xpack.monitoring.logstash.pipeline.detailDrawer.structureDescription": "これは Logstash でインプットと残りのパイプラインの間のイベントのバッファリングに使用される内部構造です。", - "xpack.monitoring.logstash.pipeline.detailDrawer.vertexIdDescription": "この {vertexType} の ID は {vertexId} です。", - "xpack.monitoring.logstash.pipeline.queue.noMetricsDescription": "キューメトリックが利用できません", - "xpack.monitoring.logstash.pipeline.relativeFirstSeenAgoLabel": "{relativeFirstSeen} 前", - "xpack.monitoring.logstash.pipeline.relativeLastSeenAgoLabel": "{relativeLastSeen} 前まで", - "xpack.monitoring.logstash.pipeline.relativeLastSeenNowLabel": "今", - "xpack.monitoring.logstash.pipeline.routeTitle": "Logstash - パイプライン", - "xpack.monitoring.logstash.pipelines.eventsEmittedRateTitle": "イベント送信レート", - "xpack.monitoring.logstash.pipelines.idTitle": "ID", - "xpack.monitoring.logstash.pipelines.numberOfNodesTitle": "ノード数", - "xpack.monitoring.logstash.pipelineStatement.viewDetailsAriaLabel": "詳細を表示", - "xpack.monitoring.logstash.pipelineViewer.filtersTitle": "フィルター", - "xpack.monitoring.logstash.pipelineViewer.inputsTitle": "インプット", - "xpack.monitoring.logstash.pipelineViewer.outputsTitle": "アウトプット", - "xpack.monitoring.logstashNavigation.instance.advancedLinkText": "高度な設定", - "xpack.monitoring.logstashNavigation.instance.overviewLinkText": "概要", - "xpack.monitoring.logstashNavigation.instance.pipelinesLinkText": "パイプライン", - "xpack.monitoring.logstashNavigation.nodesLinkText": "ノード", - "xpack.monitoring.logstashNavigation.overviewLinkText": "概要", - "xpack.monitoring.logstashNavigation.pipelinesLinkText": "パイプライン", - "xpack.monitoring.logstashNavigation.pipelineVersionDescription": "バージョンは {relativeLastSeen} 時点でアクティブ、初回検知 {relativeFirstSeen}", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.configureMetricbeatDescription": "{file} を変更して接続情報を設定します。:", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.configureMetricbeatTitle": "Metricbeat を構成して監視クラスターに送ります", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.disableInternalCollectionDescription": "Elasticsearch 監視メトリックの自己監視を無効にする本番クラスターの各サーバーの {monospace} を false に設定します。", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.disableInternalCollectionTitle": "Elasticsearch 監視メトリックの内部収集を無効にする", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.enableMetricbeatModuleDescription": "デフォルトで、モジュールは {url} から Elasticsearch メトリックを収集します。ローカルサーバーのアドレスが異なる場合は、{module} のホスト設定に追加します。", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.enableMetricbeatModuleTitle": "Metricbeat の Elasticsearch X-Pack モジュールの有効化と構成", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.installMetricbeatLinkText": "こちらの手順に従ってください", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.installMetricbeatTitle": "Metricbeat を Elasticsearch と同じサーバーにインストール", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.startMetricbeatLinkText": "こちらの手順に従ってください", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.startMetricbeatTitle": "Metricbeat を起動します", - "xpack.monitoring.metricbeatMigration.flyout.closeButtonLabel": "閉じる", - "xpack.monitoring.metricbeatMigration.flyout.doneButtonLabel": "完了", - "xpack.monitoring.metricbeatMigration.flyout.nextButtonLabel": "次へ", - "xpack.monitoring.metricbeatMigration.flyout.step1.monitoringUrlHelpText": "通常 1 つの URL です。複数 URL の場合、コンマで区切ります。\n 実行中の Metricbeat インスタンスは、これらの Elasticsearch サーバーとの通信が必要です。", - "xpack.monitoring.metricbeatMigration.flyout.step1.monitoringUrlLabel": "監視クラスター URL", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.configureMetricbeatDescription": "{file} にこれらの変更を加えます。", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.configureMetricbeatTitle": "Metricbeat を構成して監視クラスターに送ります", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.disableInternalCollection.description": "この設定を {file} に追加します。", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.disableInternalCollection.note": "{config} ではデフォルト値 ({defaultValue}) のままにしてください。", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.disableInternalCollection.restartNote": "このステップには Kibana サーバーの再起動が必要です。サーバーの再起動が完了するまでエラーが表示されます。", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.disableInternalCollection.restartWarningTitle": "警告", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.disableInternalCollection.title": "Kibana 監視メトリックの内部収集を無効にする", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.enableMetricbeatModuleDescription": "モジュールはデフォルトで http://localhost:5601 から Kibana 監視メトリックを収集します。ローカル Kibana インスタンスのアドレスが異なる場合は、{file} ファイルの {hosts} 設定で指定する必要があります。", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.enableMetricbeatModuleTitle": "Metricbeat の Kibana X-Pack もウールの有効化と構成", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.installMetricbeatLinkText": "こちらの手順に従ってください", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.installMetricbeatTitle": "Metricbeat を Kibana と同じサーバーにインストール", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.startMetricbeatLinkText": "こちらの手順に従ってください", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.startMetricbeatTitle": "Metricbeat を起動します", - "xpack.monitoring.metrics.apm.outputAckedEventsRate.ackedDescription": "アウトプットにより処理されたイベントです (再試行を含む)", - "xpack.monitoring.metrics.apm.outputAckedEventsRate.ackedLabel": "承認済み", - "xpack.monitoring.metrics.apm.outputAckedEventsRateTitle": "アウトプット承認イベントレート", - "xpack.monitoring.metrics.apm.outputActiveEventsRate.activeDescription": "アウトプットにより処理されたイベントです (再試行を含む)", - "xpack.monitoring.metrics.apm.outputActiveEventsRate.activeLabel": "アクティブ", - "xpack.monitoring.metrics.apm.outputActiveEventsRateTitle": "アウトプットアクティブイベントレート", - "xpack.monitoring.metrics.apm.outputDroppedEventsRate.droppedDescription": "アウトプットにより処理されたイベントです (再試行を含む)", - "xpack.monitoring.metrics.apm.outputDroppedEventsRate.droppedLabel": "ドロップ", - "xpack.monitoring.metrics.apm.outputDroppedEventsRateTitle": "アウトプットのイベントドロップレート", - "xpack.monitoring.metrics.apm.outputEventsRate.totalDescription": "アウトプットにより処理されたイベントです (再試行を含む)", - "xpack.monitoring.metrics.apm.outputEventsRate.totalLabel": "合計", - "xpack.monitoring.metrics.apm.outputEventsRateTitle": "アウトプットイベントレート", - "xpack.monitoring.metrics.apm.outputFailedEventsRate.failedDescription": "アウトプットにより処理されたイベントです (再試行を含む)", - "xpack.monitoring.metrics.apm.outputFailedEventsRate.failedLabel": "失敗", - "xpack.monitoring.metrics.apm.outputFailedEventsRateTitle": "アウトプットイベント失敗率", - "xpack.monitoring.metrics.apm.perMinuteUnitLabel": "/m", - "xpack.monitoring.metrics.apm.processedEvents.transactionDescription": "処理されたトランザクションイベントです", - "xpack.monitoring.metrics.apm.processedEvents.transactionLabel": "トランザクション", - "xpack.monitoring.metrics.apm.processedEventsTitle": "処理済みのイベント", - "xpack.monitoring.metrics.apm.requests.requestedDescription": "サーバーから受信した HTTP リクエストです", - "xpack.monitoring.metrics.apm.requests.requestedLabel": "リクエストされました", - "xpack.monitoring.metrics.apm.requestsTitle": "リクエストカウントインテーク API", - "xpack.monitoring.metrics.apm.response.acceptedDescription": "新規イベントを正常にレポートしている HTTP リクエストです", - "xpack.monitoring.metrics.apm.response.acceptedLabel": "受領", - "xpack.monitoring.metrics.apm.response.acceptedTitle": "受領", - "xpack.monitoring.metrics.apm.response.okDescription": "200 OK 応答カウント", - "xpack.monitoring.metrics.apm.response.okLabel": "OK", - "xpack.monitoring.metrics.apm.response.okTitle": "OK", - "xpack.monitoring.metrics.apm.responseCount.totalDescription": "サーバーにより応答された HTTP リクエストです", - "xpack.monitoring.metrics.apm.responseCount.totalLabel": "合計", - "xpack.monitoring.metrics.apm.responseCountTitle": "レスポンスカウントインテーク API", - "xpack.monitoring.metrics.apm.responseErrors.closedDescription": "サーバーのシャットダウン中に拒否された HTTP リクエストです", - "xpack.monitoring.metrics.apm.responseErrors.closedLabel": "クローズ済み", - "xpack.monitoring.metrics.apm.responseErrors.closedTitle": "クローズ済み", - "xpack.monitoring.metrics.apm.responseErrors.concurrencyDescription": "全体的な同時実行制限を超えたため拒否された HTTP リクエストです", - "xpack.monitoring.metrics.apm.responseErrors.concurrencyLabel": "同時実行", - "xpack.monitoring.metrics.apm.responseErrors.concurrencyTitle": "同時実行", - "xpack.monitoring.metrics.apm.responseErrors.decodeDescription": "デコードエラーのため拒否された HTTP リクエストです - 無効な JSON、エンティティに対し誤った接続データタイプ", - "xpack.monitoring.metrics.apm.responseErrors.decodeLabel": "デコード", - "xpack.monitoring.metrics.apm.responseErrors.decodeTitle": "デコード", - "xpack.monitoring.metrics.apm.responseErrors.forbiddenDescription": "禁止されていて拒否された HTTP リクエストです - CORS 違反、無効なエンドポイント", - "xpack.monitoring.metrics.apm.responseErrors.forbiddenLabel": "禁止", - "xpack.monitoring.metrics.apm.responseErrors.forbiddenTitle": "禁止", - "xpack.monitoring.metrics.apm.responseErrors.internalDescription": "様々な内部エラーのため拒否された HTTP リクエストです", - "xpack.monitoring.metrics.apm.responseErrors.internalLabel": "内部", - "xpack.monitoring.metrics.apm.responseErrors.internalTitle": "内部", - "xpack.monitoring.metrics.apm.responseErrors.methodDescription": "HTTP メソドが正しくなかったため拒否された HTTP リクエストです", - "xpack.monitoring.metrics.apm.responseErrors.methodLabel": "メソド", - "xpack.monitoring.metrics.apm.responseErrors.methodTitle": "メソド", - "xpack.monitoring.metrics.apm.responseErrors.queueDescription": "内部キューが貯まっていたため拒否された HTTP リクエストです", - "xpack.monitoring.metrics.apm.responseErrors.queueLabel": "キュー", - "xpack.monitoring.metrics.apm.responseErrors.queueTitle": "キュー", - "xpack.monitoring.metrics.apm.responseErrors.rateLimitDescription": "過剰なレート制限のため拒否された HTTP リクエストです", - "xpack.monitoring.metrics.apm.responseErrors.rateLimitLabel": "レート制限", - "xpack.monitoring.metrics.apm.responseErrors.rateLimitTitle": "レート制限", - "xpack.monitoring.metrics.apm.responseErrors.tooLargeLabelDescription": "過剰なペイロードサイズのため拒否された HTTP リクエストです", - "xpack.monitoring.metrics.apm.responseErrors.tooLargeLabelTitle": "サイズ超過", - "xpack.monitoring.metrics.apm.responseErrors.unauthorizedDescription": "無効な秘密トークンのため拒否された HTTP リクエストです", - "xpack.monitoring.metrics.apm.responseErrors.unauthorizedLabel": "不正", - "xpack.monitoring.metrics.apm.responseErrors.unauthorizedTitle": "不正", - "xpack.monitoring.metrics.apm.responseErrors.validateDescription": "ペイロード違反エラーのため拒否された HTTP リクエストです", - "xpack.monitoring.metrics.apm.responseErrors.validateLabel": "検証", - "xpack.monitoring.metrics.apm.responseErrors.validateTitle": "検証", - "xpack.monitoring.metrics.apm.responseErrorsTitle": "レスポンスエラーインテーク API", - "xpack.monitoring.metrics.apm.transformations.errorDescription": "処理されたエラーイベントです", - "xpack.monitoring.metrics.apm.transformations.errorLabel": "エラー", - "xpack.monitoring.metrics.apm.transformations.metricDescription": "処理されたメトリックイベントです", - "xpack.monitoring.metrics.apm.transformations.metricLabel": "メトリック", - "xpack.monitoring.metrics.apm.transformations.spanDescription": "処理されたスパンイベントです", - "xpack.monitoring.metrics.apm.transformations.spanLabel": "スパン", - "xpack.monitoring.metrics.apm.transformationsTitle": "変換", - "xpack.monitoring.metrics.apmInstance.cpuUtilization.totalDescription": "APM プロセスに使用された CPU 時間のパーセンテージです (user+kernel モード)", - "xpack.monitoring.metrics.apmInstance.cpuUtilization.totalLabel": "合計", - "xpack.monitoring.metrics.apmInstance.cpuUtilizationTitle": "CPU 使用状況", - "xpack.monitoring.metrics.apmInstance.memory.allocatedMemoryDescription": "割当メモリー", - "xpack.monitoring.metrics.apmInstance.memory.allocatedMemoryLabel": "割当メモリー", - "xpack.monitoring.metrics.apmInstance.memory.gcNextDescription": "ガーベージコレクションが行われるメモリー割当の制限です", - "xpack.monitoring.metrics.apmInstance.memory.gcNextLabel": "GC Next", - "xpack.monitoring.metrics.apmInstance.memory.processTotalDescription": "APM サービスにより OS から確保されたメモリーの RSS です", - "xpack.monitoring.metrics.apmInstance.memory.processTotalLabel": "プロセス合計", - "xpack.monitoring.metrics.apmInstance.memoryTitle": "メモリー", - "xpack.monitoring.metrics.apmInstance.systemLoad.last15MinutesDescription": "過去 15 分間の平均負荷です", - "xpack.monitoring.metrics.apmInstance.systemLoad.last15MinutesLabel": "15m", - "xpack.monitoring.metrics.apmInstance.systemLoad.last1MinuteDescription": "過去 1 分間の平均負荷です", - "xpack.monitoring.metrics.apmInstance.systemLoad.last1MinuteLabel": "1m", - "xpack.monitoring.metrics.apmInstance.systemLoad.last5MinutesDescription": "過去 5 分間の平均負荷です", - "xpack.monitoring.metrics.apmInstance.systemLoad.last5MinutesLabel": "5m", - "xpack.monitoring.metrics.apmInstance.systemLoadTitle": "システム負荷", - "xpack.monitoring.metrics.beats.eventsRate.acknowledgedDescription": "インプットに認識されたイベントです (アウトプットにドロップされたイベントを含む)", - "xpack.monitoring.metrics.beats.eventsRate.acknowledgedLabel": "認識", - "xpack.monitoring.metrics.beats.eventsRate.emittedDescription": "アウトプットにより処理されたイベントです (再試行を含む)", - "xpack.monitoring.metrics.beats.eventsRate.emittedLabel": "送信", - "xpack.monitoring.metrics.beats.eventsRate.queuedDescription": "イベントパイプラインキューに追加されたイベントです", - "xpack.monitoring.metrics.beats.eventsRate.queuedLabel": "キュー", - "xpack.monitoring.metrics.beats.eventsRate.totalDescription": "パブリッシュするパイプラインで新規作成されたすべてのイベントです", - "xpack.monitoring.metrics.beats.eventsRate.totalLabel": "合計", - "xpack.monitoring.metrics.beats.eventsRateTitle": "イベントレート", - "xpack.monitoring.metrics.beats.failRates.droppedInOutputDescription": "(致命的なドロップ) アウトプットに「無効」としてドロップされたイベントです。 この場合もアウトプットはビートがキューから削除できるようイベントを認識します。", - "xpack.monitoring.metrics.beats.failRates.droppedInOutputLabel": "アウトプットでドロップ", - "xpack.monitoring.metrics.beats.failRates.droppedInPipelineDescription": "N 回の試行後ドロップされたtイベントです (N = max_retries 設定)", - "xpack.monitoring.metrics.beats.failRates.droppedInPipelineLabel": "パイプラインでドロップ", - "xpack.monitoring.metrics.beats.failRates.failedInPipelineDescription": "イベントがパブリッシュするパイプラインに追加される前の失敗です (アウトプットが無効またはパブリッシャークライアントがクローズ)", - "xpack.monitoring.metrics.beats.failRates.failedInPipelineLabel": "パイプラインで失敗", - "xpack.monitoring.metrics.beats.failRates.retryInPipelineDescription": "アウトプットへの送信を再試行中のパイプライン内のイベントです", - "xpack.monitoring.metrics.beats.failRates.retryInPipelineLabel": "パイプラインで再試行", - "xpack.monitoring.metrics.beats.failRatesTitle": "失敗率", - "xpack.monitoring.metrics.beats.outputErrors.receivingDescription": "アウトプットからの応答の読み込み中のエラーです", - "xpack.monitoring.metrics.beats.outputErrors.receivingLabel": "受信", - "xpack.monitoring.metrics.beats.outputErrors.sendingDescription": "アウトプットからの応答の書き込み中のエラーです", - "xpack.monitoring.metrics.beats.outputErrors.sendingLabel": "送信", - "xpack.monitoring.metrics.beats.outputErrorsTitle": "アウトプットエラー", - "xpack.monitoring.metrics.beats.perSecondUnitLabel": "/s", - "xpack.monitoring.metrics.beats.throughput.bytesReceivedDescription": "アウトプットからの応答から読み込まれたバイト数です", - "xpack.monitoring.metrics.beats.throughput.bytesReceivedLabel": "受信イベント", - "xpack.monitoring.metrics.beats.throughput.bytesSentDescription": "アウトプットに書き込まれたバイト数です (ネットワークヘッダーと圧縮されたペイロードのサイズで構成されています)", - "xpack.monitoring.metrics.beats.throughput.bytesSentLabel": "送信バイト数", - "xpack.monitoring.metrics.beats.throughputTitle": "スループット", - "xpack.monitoring.metrics.beatsInstance.cpuUtilization.totalDescription": "ビートプロセスに使用された CPU 時間のパーセンテージです (user+kernel モード)", - "xpack.monitoring.metrics.beatsInstance.cpuUtilization.totalLabel": "合計", - "xpack.monitoring.metrics.beatsInstance.cpuUtilizationTitle": "CPU 使用状況", - "xpack.monitoring.metrics.beatsInstance.eventsRate.acknowledgedDescription": "インプットに認識されたイベントです (アウトプットにドロップされたイベントを含む)", - "xpack.monitoring.metrics.beatsInstance.eventsRate.acknowledgedLabel": "認識", - "xpack.monitoring.metrics.beatsInstance.eventsRate.emittedDescription": "アウトプットにより処理されたイベントです (再試行を含む)", - "xpack.monitoring.metrics.beatsInstance.eventsRate.emittedLabel": "送信", - "xpack.monitoring.metrics.beatsInstance.eventsRate.newDescription": "パブリッシュするパイプラインに送信された新規イベントです", - "xpack.monitoring.metrics.beatsInstance.eventsRate.newLabel": "新規", - "xpack.monitoring.metrics.beatsInstance.eventsRate.queuedDescription": "イベントパイプラインキューに追加されたイベントです", - "xpack.monitoring.metrics.beatsInstance.eventsRate.queuedLabel": "キュー", - "xpack.monitoring.metrics.beatsInstance.eventsRateTitle": "イベントレート", - "xpack.monitoring.metrics.beatsInstance.failRates.droppedInOutputDescription": "(致命的なドロップ) アウトプットに「無効」としてドロップされたイベントです。 この場合もアウトプットはビートがキューから削除できるようイベントを認識します。", - "xpack.monitoring.metrics.beatsInstance.failRates.droppedInOutputLabel": "アウトプットでドロップ", - "xpack.monitoring.metrics.beatsInstance.failRates.droppedInPipelineDescription": "N 回の試行後ドロップされたtイベントです (N = max_retries 設定)", - "xpack.monitoring.metrics.beatsInstance.failRates.droppedInPipelineLabel": "パイプラインでドロップ", - "xpack.monitoring.metrics.beatsInstance.failRates.failedInPipelineDescription": "イベントがパブリッシュするパイプラインに追加される前の失敗です (アウトプットが無効またはパブリッシャークライアントがクローズ)", - "xpack.monitoring.metrics.beatsInstance.failRates.failedInPipelineLabel": "パイプラインで失敗", - "xpack.monitoring.metrics.beatsInstance.failRates.retryInPipelineDescription": "アウトプットへの送信を再試行中のパイプライン内のイベントです", - "xpack.monitoring.metrics.beatsInstance.failRates.retryInPipelineLabel": "パイプラインで再試行", - "xpack.monitoring.metrics.beatsInstance.failRatesTitle": "失敗率", - "xpack.monitoring.metrics.beatsInstance.memory.activeDescription": "ビートによりアクティブに使用されているプライベートメモリーです", - "xpack.monitoring.metrics.beatsInstance.memory.activeLabel": "アクティブ", - "xpack.monitoring.metrics.beatsInstance.memory.gcNextDescription": "ガーベージコレクションが行われるメモリー割当の制限です", - "xpack.monitoring.metrics.beatsInstance.memory.gcNextLabel": "GC Next", - "xpack.monitoring.metrics.beatsInstance.memory.processTotalDescription": "ビートにより OS から確保されたメモリーの RSS です", - "xpack.monitoring.metrics.beatsInstance.memory.processTotalLabel": "プロセス合計", - "xpack.monitoring.metrics.beatsInstance.memoryTitle": "メモリー", - "xpack.monitoring.metrics.beatsInstance.openHandlesDescription": "オープンのファイルハンドラーのカウントです", - "xpack.monitoring.metrics.beatsInstance.openHandlesLabel": "オープンハンドラー", - "xpack.monitoring.metrics.beatsInstance.openHandlesTitle": "オープンハンドラー", - "xpack.monitoring.metrics.beatsInstance.outputErrors.receivingDescription": "アウトプットからの応答の読み込み中のエラーです", - "xpack.monitoring.metrics.beatsInstance.outputErrors.receivingLabel": "受信", - "xpack.monitoring.metrics.beatsInstance.outputErrors.sendingDescription": "アウトプットからの応答の書き込み中のエラーです", - "xpack.monitoring.metrics.beatsInstance.outputErrors.sendingLabel": "送信", - "xpack.monitoring.metrics.beatsInstance.outputErrorsTitle": "アウトプットエラー", - "xpack.monitoring.metrics.beatsInstance.systemLoad.last15MinutesDescription": "過去 15 分間の平均負荷です", - "xpack.monitoring.metrics.beatsInstance.systemLoad.last15MinutesLabel": "15m", - "xpack.monitoring.metrics.beatsInstance.systemLoad.last1MinuteDescription": "過去 1 分間の平均負荷です", - "xpack.monitoring.metrics.beatsInstance.systemLoad.last1MinuteLabel": "1m", - "xpack.monitoring.metrics.beatsInstance.systemLoad.last5MinutesDescription": "過去 5 分間の平均負荷です", - "xpack.monitoring.metrics.beatsInstance.systemLoad.last5MinutesLabel": "5m", - "xpack.monitoring.metrics.beatsInstance.systemLoadTitle": "システム負荷", - "xpack.monitoring.metrics.beatsInstance.throughput.bytesReceivedDescription": "アウトプットからの応答から読み込まれたバイト数です", - "xpack.monitoring.metrics.beatsInstance.throughput.bytesReceivedLabel": "受信イベント", - "xpack.monitoring.metrics.beatsInstance.throughput.bytesSentDescription": "アウトプットに書き込まれたバイト数です (ネットワークヘッダーと圧縮されたペイロードのサイズで構成されています)", - "xpack.monitoring.metrics.beatsInstance.throughput.bytesSentLabel": "送信バイト数", - "xpack.monitoring.metrics.beatsInstance.throughputTitle": "スループット", - "xpack.monitoring.metrics.es.indexingLatencyDescription": "ドキュメントのインデックスの平均レイテンシです。ドキュメントのインデックスの所要時間をインデックス数で割った時間です。プライマリシャードのみが含まれています。", - "xpack.monitoring.metrics.es.indexingLatencyLabel": "インデックスレイテンシ", - "xpack.monitoring.metrics.es.indexingRate.primaryShardsDescription": "プライマリシャードにインデックスされたドキュメントの数です。", - "xpack.monitoring.metrics.es.indexingRate.primaryShardsLabel": "プライマリシャード", - "xpack.monitoring.metrics.es.indexingRate.totalShardsDescription": "プライマリとレプリカシャードにインデックスされたドキュメントの数です。", - "xpack.monitoring.metrics.es.indexingRate.totalShardsLabel": "合計シャード", - "xpack.monitoring.metrics.es.indexingRateTitle": "インデックスレート", - "xpack.monitoring.metrics.es.latencyMetricParamErrorMessage": "レイテンシメトリックパラメーターは「index」または「query」と等しい文字列でなければなりません", - "xpack.monitoring.metrics.es.msTimeUnitLabel": "ms", - "xpack.monitoring.metrics.es.nsTimeUnitLabel": "ナノ秒", - "xpack.monitoring.metrics.es.perSecondsUnitLabel": "/秒", - "xpack.monitoring.metrics.es.perSecondTimeUnitLabel": "/s", - "xpack.monitoring.metrics.es.searchLatencyDescription": "検索の平均レイテンシです。検索の実行に所要した時間を送信された検索数で割った時間です。プライマリとレプリカシャードが含まれています。", - "xpack.monitoring.metrics.es.searchLatencyLabel": "検索レイテンシ", - "xpack.monitoring.metrics.es.searchRate.totalShardsDescription": "プライマリとレプリカシャードで実行されている検索リクエストの数です。1 つの検索を複数シャードに対して実行することができます!", - "xpack.monitoring.metrics.es.searchRate.totalShardsLabel": "合計シャード", - "xpack.monitoring.metrics.es.searchRateTitle": "検索レート", - "xpack.monitoring.metrics.es.secondsUnitLabel": "s", - "xpack.monitoring.metrics.esCcr.fetchDelayDescription": "フォロワーインデックスがリーダーから遅れている時間です。", - "xpack.monitoring.metrics.esCcr.fetchDelayLabel": "取得遅延", - "xpack.monitoring.metrics.esCcr.fetchDelayTitle": "取得遅延", - "xpack.monitoring.metrics.esCcr.opsDelayDescription": "フォロワーインデックスがリーダーから遅れているオペレーションの数です。", - "xpack.monitoring.metrics.esCcr.opsDelayLabel": "オペレーション遅延", - "xpack.monitoring.metrics.esCcr.opsDelayTitle": "オペレーション遅延", - "xpack.monitoring.metrics.esIndex.disk.mergesDescription": "プライマリとレプリカシャードの結合サイズです。", - "xpack.monitoring.metrics.esIndex.disk.mergesLabel": "結合", - "xpack.monitoring.metrics.esIndex.disk.mergesPrimariesDescription": "プライマリシャードの結合サイズです。", - "xpack.monitoring.metrics.esIndex.disk.mergesPrimariesLabel": "結合 (プライマリ)", - "xpack.monitoring.metrics.esIndex.disk.storeDescription": "ディスク上のプライマリとレプリカシャードのサイズです。", - "xpack.monitoring.metrics.esIndex.disk.storeLabel": "格納サイズ", - "xpack.monitoring.metrics.esIndex.disk.storePrimariesDescription": "ディスク上のプライマリシャードのサイズです。", - "xpack.monitoring.metrics.esIndex.disk.storePrimariesLabel": "格納サイズ (プライマリ)", - "xpack.monitoring.metrics.esIndex.diskTitle": "ディスク", - "xpack.monitoring.metrics.esIndex.docValuesDescription": "ドキュメント値が使用中のヒープ領域です。Lucene の一部です。", - "xpack.monitoring.metrics.esIndex.docValuesLabel": "ドキュメント値", - "xpack.monitoring.metrics.esIndex.fielddataDescription": "フィールドデータ (例: グローバル序数またはテキストフィールドで特別に有効化されたフィールドデータ) が使用中のヒープ領域です同じシャードのものですが、Lucene 合計には含まれません。", - "xpack.monitoring.metrics.esIndex.fielddataLabel": "フィールドデータ", - "xpack.monitoring.metrics.esIndex.fixedBitsetsDescription": "固定ビットセット (例: ディープネスト構造のドキュメント) が使用中のヒープ領域です。Lucene の一部です。", - "xpack.monitoring.metrics.esIndex.fixedBitsetsLabel": "固定ビットセット", - "xpack.monitoring.metrics.esIndex.indexingRate.primaryShardsDescription": "プライマリシャードにインデックスされたドキュメントの数です。", - "xpack.monitoring.metrics.esIndex.indexingRate.primaryShardsLabel": "プライマリシャード", - "xpack.monitoring.metrics.esIndex.indexingRate.totalShardsDescription": "プライマリとレプリカシャードにインデックスされたドキュメントの数です。", - "xpack.monitoring.metrics.esIndex.indexingRate.totalShardsLabel": "合計シャード", - "xpack.monitoring.metrics.esIndex.indexingRateTitle": "インデックスレート", - "xpack.monitoring.metrics.esIndex.indexMemoryEs.queryCacheDescription": "クエリキャッシュ (例: キャッシュされたフィルター) が使用中のヒープ領域です。同じシャードのものですが、Lucene 合計には含まれません。", - "xpack.monitoring.metrics.esIndex.indexMemoryEs.queryCacheLabel": "クエリキャッシュ", - "xpack.monitoring.metrics.esIndex.indexMemoryEsTitle": "インデックスメモリー - {elasticsearch}", - "xpack.monitoring.metrics.esIndex.indexMemoryLucene1.luceneTotalDescription": "Lucene が現在のインデックスに使用中の合計ヒープ領域です。これはプライマリとレプリカシャードの他のフィールドの合計です。", - "xpack.monitoring.metrics.esIndex.indexMemoryLucene1.luceneTotalLabel": "Lucene 合計", - "xpack.monitoring.metrics.esIndex.indexMemoryLucene1Title": "インデックスメモリー - Lucene 1", - "xpack.monitoring.metrics.esIndex.indexMemoryLucene2.luceneTotalDescription": "Lucene が現在のインデックスに使用中の合計ヒープ領域です。これはプライマリとレプリカシャードの他のフィールドの合計です。", - "xpack.monitoring.metrics.esIndex.indexMemoryLucene2.luceneTotalLabel": "Lucene 合計", - "xpack.monitoring.metrics.esIndex.indexMemoryLucene2Title": "インデックスメモリー - Lucene 2", - "xpack.monitoring.metrics.esIndex.indexMemoryLucene3.luceneTotalDescription": "Lucene が現在のインデックスに使用中の合計ヒープ領域です。これはプライマリとレプリカシャードの他のフィールドの合計です。", - "xpack.monitoring.metrics.esIndex.indexMemoryLucene3.luceneTotalLabel": "Lucene 合計", - "xpack.monitoring.metrics.esIndex.indexMemoryLucene3Title": "インデックスメモリー - Lucene 3", - "xpack.monitoring.metrics.esIndex.indexWriterDescription": "Index Writer が使用中のヒープ領域です。Lucene 合計の一部ではありません。", - "xpack.monitoring.metrics.esIndex.indexWriterLabel": "Index Writer", - "xpack.monitoring.metrics.esIndex.latency.indexingLatencyDescription": "ドキュメントのインデックスの平均レイテンシです。ドキュメントのインデックスの所要時間をインデックス数で割った時間です。プライマリシャードのみが含まれています。", - "xpack.monitoring.metrics.esIndex.latency.indexingLatencyLabel": "インデックスレイテンシ", - "xpack.monitoring.metrics.esIndex.latency.searchLatencyDescription": "検索の平均レイテンシです。検索の実行に所要した時間を送信された検索数で割った時間です。プライマリとレプリカシャードが含まれています。", - "xpack.monitoring.metrics.esIndex.latency.searchLatencyLabel": "検索レイテンシ", - "xpack.monitoring.metrics.esIndex.latencyTitle": "レイテンシ", - "xpack.monitoring.metrics.esIndex.luceneTotalDescription": "Lucene が現在のインデックスに使用中の合計ヒープ領域です。これはプライマリとレプリカシャードの他のフィールドの合計です。", - "xpack.monitoring.metrics.esIndex.luceneTotalLabel": "Lucene 合計", - "xpack.monitoring.metrics.esIndex.normsDescription": "Norms (クエリ時間、テキストスコアリングの規格化因子) が使用中のヒープ領域です。Lucene の一部です。", - "xpack.monitoring.metrics.esIndex.normsLabel": "Norms", - "xpack.monitoring.metrics.esIndex.pointsDescription": "ポイント (例: 数字、IP、地理データ) が使用中のヒープ領域です。Lucene の一部です。", - "xpack.monitoring.metrics.esIndex.pointsLabel": "ポイント", - "xpack.monitoring.metrics.esIndex.refreshTime.primariesDescription": "プライマリシャードの更新オペレーションの所要時間です。", - "xpack.monitoring.metrics.esIndex.refreshTime.primariesLabel": "プライマリ", - "xpack.monitoring.metrics.esIndex.refreshTime.totalDescription": "プライマリとレプリカシャードの更新オペレーションの所要時間です。", - "xpack.monitoring.metrics.esIndex.refreshTime.totalLabel": "合計", - "xpack.monitoring.metrics.esIndex.refreshTimeTitle": "更新時間", - "xpack.monitoring.metrics.esIndex.requestCacheDescription": "リクエストキャッシュ (例: 瞬間集約) が使用中のヒープ領域です。同じシャードのものですが、Lucene 合計には含まれません。", - "xpack.monitoring.metrics.esIndex.requestCacheLabel": "リクエストキャッシュ", - "xpack.monitoring.metrics.esIndex.requestRate.indexTotalDescription": "インデックスオペレーションの数です。", - "xpack.monitoring.metrics.esIndex.requestRate.indexTotalLabel": "インデックス合計", - "xpack.monitoring.metrics.esIndex.requestRate.searchTotalDescription": "検索オペレーションの数です (シャードごと)。", - "xpack.monitoring.metrics.esIndex.requestRate.searchTotalLabel": "検索合計", - "xpack.monitoring.metrics.esIndex.requestRateTitle": "リクエストレート", - "xpack.monitoring.metrics.esIndex.requestTime.indexingDescription": "プライマリとレプリカシャードのインデックスオペレーションの所要時間です。", - "xpack.monitoring.metrics.esIndex.requestTime.indexingLabel": "インデックス", - "xpack.monitoring.metrics.esIndex.requestTime.indexingPrimariesDescription": "プライマリシャードのみのインデックスオペレーションの所要時間です。", - "xpack.monitoring.metrics.esIndex.requestTime.indexingPrimariesLabel": "インデックス (プライマリ)", - "xpack.monitoring.metrics.esIndex.requestTime.searchDescription": "検索オペレーションの所要時間です (シャードごと)。", - "xpack.monitoring.metrics.esIndex.requestTime.searchLabel": "検索", - "xpack.monitoring.metrics.esIndex.requestTimeTitle": "リクエスト時間", - "xpack.monitoring.metrics.esIndex.searchRate.totalShardsDescription": "プライマリとレプリカシャードで実行されている検索リクエストの数です。1 つの検索を複数シャードに対して実行することができます!", - "xpack.monitoring.metrics.esIndex.searchRate.totalShardsLabel": "合計シャード", - "xpack.monitoring.metrics.esIndex.searchRateTitle": "検索レート", - "xpack.monitoring.metrics.esIndex.segmentCount.primariesDescription": "プライマリシャードのセグメント数です。", - "xpack.monitoring.metrics.esIndex.segmentCount.primariesLabel": "プライマリ", - "xpack.monitoring.metrics.esIndex.segmentCount.totalDescription": "プライマリとレプリカシャードのセグメント数です。", - "xpack.monitoring.metrics.esIndex.segmentCount.totalLabel": "合計", - "xpack.monitoring.metrics.esIndex.segmentCountTitle": "セグメントカウント", - "xpack.monitoring.metrics.esIndex.storedFieldsDescription": "格納フィールド (例: _source) が使用中のヒープ領域です。Lucene の一部です。", - "xpack.monitoring.metrics.esIndex.storedFieldsLabel": "格納フィールド", - "xpack.monitoring.metrics.esIndex.termsDescription": "用語が使用中のヒープ領域です (例: テキスト)。Lucene の一部です。", - "xpack.monitoring.metrics.esIndex.termsLabel": "用語", - "xpack.monitoring.metrics.esIndex.termVectorsDescription": "用語ベクトルが使用中のヒープ領域です。Lucene の一部です。", - "xpack.monitoring.metrics.esIndex.termVectorsLabel": "用語ベクトル", - "xpack.monitoring.metrics.esIndex.throttleTime.indexingDescription": "プライマリとレプリカシャードのインデックスオペレーションのスロットリングの所要時間です。", - "xpack.monitoring.metrics.esIndex.throttleTime.indexingLabel": "インデックス", - "xpack.monitoring.metrics.esIndex.throttleTime.indexingPrimariesDescription": "プライマリシャードのインデックスオペレーションのスロットリングの所要時間です。", - "xpack.monitoring.metrics.esIndex.throttleTime.indexingPrimariesLabel": "インデックス (プライマリ)", - "xpack.monitoring.metrics.esIndex.throttleTimeTitle": "スロットル時間", - "xpack.monitoring.metrics.esIndex.versionMapDescription": "バージョニング (例: 更新、削除) が使用中のヒープ領域です。Lucene 合計の一部ではありません。", - "xpack.monitoring.metrics.esIndex.versionMapLabel": "バージョンマップ", - "xpack.monitoring.metrics.esNode.cgroupCfsStats.cgroupElapsedPeriodsDescription": "Completely Fair Scheduler (CFS) からのサンプリング期間の数です。スロットル回数と比較します。", - "xpack.monitoring.metrics.esNode.cgroupCfsStats.cgroupElapsedPeriodsLabel": "Cgroup 経過時間", - "xpack.monitoring.metrics.esNode.cgroupCfsStats.cgroupThrottledCountDescription": "Cgroup により CPU がスロットリングされた回数です。", - "xpack.monitoring.metrics.esNode.cgroupCfsStats.cgroupThrottledCountLabel": "Cgroup スロットルカウント", - "xpack.monitoring.metrics.esNode.cgroupCfsStatsTitle": "Cgroup CFS 統計", - "xpack.monitoring.metrics.esNode.cgroupCpuPerformance.cgroupThrottlingDescription": "Cgroup のナノ秒単位で報告されたスロットル時間です。", - "xpack.monitoring.metrics.esNode.cgroupCpuPerformance.cgroupThrottlingLabel": "Cgroup スロットリング", - "xpack.monitoring.metrics.esNode.cgroupCpuPerformance.cgroupUsageDescription": "Cgroup のナノ秒単位で報告された使用状況です。スロットリングと比較して問題を発見します。", - "xpack.monitoring.metrics.esNode.cgroupCpuPerformance.cgroupUsageLabel": "Cgroup の使用状況", - "xpack.monitoring.metrics.esNode.cgroupCpuPerformanceTitle": "Cgroup CPU パフォーマンス", - "xpack.monitoring.metrics.esNode.cpuUtilization.cgroupCpuUtilizationDescription": "CPU クォータに対する CPU 使用時間のパーセンテージです。CPU クォータが設定されていない場合、データは表示されません。", - "xpack.monitoring.metrics.esNode.cpuUtilization.cgroupCpuUtilizationLabel": "Cgroup CPU 活用状況", - "xpack.monitoring.metrics.esNode.cpuUtilizationDescription": "Elasticsearch プロセスの CPU 使用量のパーセンテージです。", - "xpack.monitoring.metrics.esNode.cpuUtilizationLabel": "CPU 使用状況", - "xpack.monitoring.metrics.esNode.cpuUtilizationTitle": "CPU 使用状況", - "xpack.monitoring.metrics.esNode.diskFreeSpaceDescription": "ノードで利用可能な空きディスク容量です。", - "xpack.monitoring.metrics.esNode.diskFreeSpaceLabel": "ディスクの空き容量", - "xpack.monitoring.metrics.esNode.documentCountDescription": "プライマリシャードのみのドキュメントの合計数です。", - "xpack.monitoring.metrics.esNode.documentCountLabel": "ドキュメントカウント", - "xpack.monitoring.metrics.esNode.docValuesDescription": "ドキュメント値が使用中のヒープ領域です。Lucene の一部です。", - "xpack.monitoring.metrics.esNode.docValuesLabel": "ドキュメント値", - "xpack.monitoring.metrics.esNode.fielddataDescription": "フィールドデータ (例: グローバル序数またはテキストフィールドで特別に有効化されたフィールドデータ) が使用中のヒープ領域です同じシャードのものですが、Lucene 合計には含まれません。", - "xpack.monitoring.metrics.esNode.fielddataLabel": "フィールドデータ", - "xpack.monitoring.metrics.esNode.fixedBitsetsDescription": "固定ビットセット (例: ディープネスト構造のドキュメント) が使用中のヒープ領域です。Lucene の一部です。", - "xpack.monitoring.metrics.esNode.fixedBitsetsLabel": "固定ビットセット", - "xpack.monitoring.metrics.esNode.gcCount.oldDescription": "古いガーベージコレクションの数です。", - "xpack.monitoring.metrics.esNode.gcCount.oldLabel": "古", - "xpack.monitoring.metrics.esNode.gcCount.youngDescription": "新しいガーベージコレクションの数です。", - "xpack.monitoring.metrics.esNode.gcCount.youngLabel": "新", - "xpack.monitoring.metrics.esNode.gcDuration.oldDescription": "古いガーベージコレクションの所要時間です。", - "xpack.monitoring.metrics.esNode.gcDuration.oldLabel": "古", - "xpack.monitoring.metrics.esNode.gcDuration.youngDescription": "新しいガーベージコレクションの所要時間です。", - "xpack.monitoring.metrics.esNode.gcDuration.youngLabel": "新", - "xpack.monitoring.metrics.esNode.gsCountTitle": "GC カウント", - "xpack.monitoring.metrics.esNode.gsDurationTitle": "GC 時間", - "xpack.monitoring.metrics.esNode.indexingThreads.searchRejectionsDescription": "キューがいっぱいの時に拒否された検索オペレーションの数です。", - "xpack.monitoring.metrics.esNode.indexingThreads.searchRejectionsLabel": "検索拒否", - "xpack.monitoring.metrics.esNode.indexingThreads.writeQueueDescription": "キューにあるインデックス、一斉、書き込みオペレーションの数です。6.3 では一斉スレッドプールが書き込みになり、インデックススレッドプールが廃止されました。", - "xpack.monitoring.metrics.esNode.indexingThreads.writeQueueLabel": "書き込みキュー", - "xpack.monitoring.metrics.esNode.indexingThreads.writeRejectionsDescription": "キューがいっぱいの時に拒否されたインデックス、一斉、書き込みオペレーションの数です。6.3 では一斉スレッドプールが書き込みになり、インデックススレッドプールが廃止されました。", - "xpack.monitoring.metrics.esNode.indexingThreads.writeRejectionsLabel": "書き込み拒否", - "xpack.monitoring.metrics.esNode.indexingThreadsTitle": "インデックススレッド", - "xpack.monitoring.metrics.esNode.indexingTime.indexThrottlingTimeDescription": "インデックススロットリングの所要時間です。ノードのディスクが遅いことを示します。", - "xpack.monitoring.metrics.esNode.indexingTime.indexThrottlingTimeLabel": "インデックススロットリング時間", - "xpack.monitoring.metrics.esNode.indexingTime.indexTimeDescription": "インデックスオペレーションの所要時間です。", - "xpack.monitoring.metrics.esNode.indexingTime.indexTimeLabel": "インデックス時間", - "xpack.monitoring.metrics.esNode.indexingTimeTitle": "インデックス時間", - "xpack.monitoring.metrics.esNode.indexMemoryEs.queryCacheDescription": "クエリキャッシュ (例: キャッシュされたフィルター) が使用中のヒープ領域です。同じシャードのものですが、Lucene 合計には含まれません。", - "xpack.monitoring.metrics.esNode.indexMemoryEs.queryCacheLabel": "クエリキャッシュ", - "xpack.monitoring.metrics.esNode.indexMemoryEsTitle": "インデックスメモリー - {elasticsearch}", - "xpack.monitoring.metrics.esNode.indexMemoryLucene1.lucenceTotalDescription": "Lucene が現在のインデックスに使用中の合計ヒープ領域です。これはノードのプライマリとレプリカシャードの他のフィールドの合計です。", - "xpack.monitoring.metrics.esNode.indexMemoryLucene1.lucenceTotalLabel": "Lucene 合計", - "xpack.monitoring.metrics.esNode.indexMemoryLucene1Title": "インデックスメモリー - Lucene 1", - "xpack.monitoring.metrics.esNode.indexMemoryLucene2.lucenceTotalDescription": "Lucene が現在のインデックスに使用中の合計ヒープ領域です。これはノードのプライマリとレプリカシャードの他のフィールドの合計です。", - "xpack.monitoring.metrics.esNode.indexMemoryLucene2.lucenceTotalLabel": "Lucene 合計", - "xpack.monitoring.metrics.esNode.indexMemoryLucene2Title": "インデックスメモリー - Lucene 2", - "xpack.monitoring.metrics.esNode.indexMemoryLucene3.lucenceTotalDescription": "Lucene が現在のインデックスに使用中の合計ヒープ領域です。これはノードのプライマリとレプリカシャードの他のフィールドの合計です。", - "xpack.monitoring.metrics.esNode.indexMemoryLucene3.lucenceTotalLabel": "Lucene 合計", - "xpack.monitoring.metrics.esNode.indexMemoryLucene3Title": "インデックスメモリー - Lucene 3", - "xpack.monitoring.metrics.esNode.indexThrottlingTimeDescription": "インデックススロットリングの所要時間です。結合に時間がかかっていることを示します。", - "xpack.monitoring.metrics.esNode.indexThrottlingTimeLabel": "インデックススロットリング時間", - "xpack.monitoring.metrics.esNode.indexWriterDescription": "Index Writer が使用中のヒープ領域です。Lucene 合計の一部ではありません。", - "xpack.monitoring.metrics.esNode.indexWriterLabel": "Index Writer", - "xpack.monitoring.metrics.esNode.jvmHeap.maxHeapDescription": "JVM で実行中の Elasticsearch が利用できるヒープの合計です。", - "xpack.monitoring.metrics.esNode.jvmHeap.maxHeapLabel": "最大ヒープ", - "xpack.monitoring.metrics.esNode.jvmHeap.usedHeapDescription": "JVM で実行中の Elasticsearch が使用中のヒープの合計です。", - "xpack.monitoring.metrics.esNode.jvmHeap.usedHeapLabel": "使用ヒープ", - "xpack.monitoring.metrics.esNode.jvmHeapTitle": "{javaVirtualMachine} ヒープ", - "xpack.monitoring.metrics.esNode.latency.indexingDescription": "ドキュメントのインデックスの平均レイテンシです。ドキュメントのインデックスの所要時間をインデックス数で割った時間です。これにはレプリカを含む、このノードにあるすべてのシャードが含まれます。", - "xpack.monitoring.metrics.esNode.latency.indexingLabel": "インデックス", - "xpack.monitoring.metrics.esNode.latency.searchDescription": "検索の平均レイテンシです。検索の実行に所要した時間を送信された検索数で割った時間です。プライマリとレプリカシャードが含まれています。", - "xpack.monitoring.metrics.esNode.latency.searchLabel": "検索", - "xpack.monitoring.metrics.esNode.latencyTitle": "レイテンシ", - "xpack.monitoring.metrics.esNode.luceneTotalDescription": "Lucene が現在のインデックスに使用中の合計ヒープ領域です。これはノードのプライマリとレプリカシャードの他のフィールドの合計です。", - "xpack.monitoring.metrics.esNode.luceneTotalLabel": "Lucene 合計", - "xpack.monitoring.metrics.esNode.mergeRateDescription": "結合されたセグメントのバイト数です。この数字が大きいほどディスクアクティビティが多いことを示します。", - "xpack.monitoring.metrics.esNode.mergeRateLabel": "結合レート", - "xpack.monitoring.metrics.esNode.normsDescription": "Norms (クエリ時間、テキストスコアリングの規格化因子) が使用中のヒープ領域です。Lucene の一部です。", - "xpack.monitoring.metrics.esNode.normsLabel": "Norms", - "xpack.monitoring.metrics.esNode.pointsDescription": "ポイント (例: 数字、IP、地理データ) が使用中のヒープ領域です。Lucene の一部です。", - "xpack.monitoring.metrics.esNode.pointsLabel": "ポイント", - "xpack.monitoring.metrics.esNode.readThreads.getQueueDescription": "キューにある GET オペレーションの数です。", - "xpack.monitoring.metrics.esNode.readThreads.getQueueLabel": "GET キュー", - "xpack.monitoring.metrics.esNode.readThreads.getRejectionsDescription": "キューがいっぱいの時に拒否された GET オペレーションの数です。", - "xpack.monitoring.metrics.esNode.readThreads.getRejectionsLabel": "GET 拒否", - "xpack.monitoring.metrics.esNode.readThreads.searchQueueDescription": "キューにある検索オペレーション (例: シャードレベル検索) の数です。", - "xpack.monitoring.metrics.esNode.readThreads.searchQueueLabel": "検索キュー", - "xpack.monitoring.metrics.esNode.readThreadsTitle": "読み込みスレッド", - "xpack.monitoring.metrics.esNode.requestCacheDescription": "リクエストキャッシュ (例: 瞬間集約) が使用中のヒープ領域です。同じシャードのものですが、Lucene 合計には含まれません。", - "xpack.monitoring.metrics.esNode.requestCacheLabel": "リクエストキャッシュ", - "xpack.monitoring.metrics.esNode.requestRate.indexingTotalDescription": "インデックスオペレーションの数です。", - "xpack.monitoring.metrics.esNode.requestRate.indexingTotalLabel": "インデックス合計", - "xpack.monitoring.metrics.esNode.requestRate.searchTotalDescription": "検索オペレーションの数です (シャードごと)。", - "xpack.monitoring.metrics.esNode.requestRate.searchTotalLabel": "検索合計", - "xpack.monitoring.metrics.esNode.requestRateTitle": "リクエストレート", - "xpack.monitoring.metrics.esNode.searchRate.totalShardsDescription": "プライマリとレプリカシャードで実行されている検索リクエストの数です。1 つの検索を複数シャードに対して実行することができます!", - "xpack.monitoring.metrics.esNode.searchRate.totalShardsLabel": "合計シャード", - "xpack.monitoring.metrics.esNode.searchRateTitle": "検索レート", - "xpack.monitoring.metrics.esNode.segmentCountDescription": "このノードのプライマリとレプリカシャードの最大セグメントカウントです。", - "xpack.monitoring.metrics.esNode.segmentCountLabel": "セグメントカウント", - "xpack.monitoring.metrics.esNode.storedFieldsDescription": "格納フィールド (例: _source) が使用中のヒープ領域です。Lucene の一部です。", - "xpack.monitoring.metrics.esNode.storedFieldsLabel": "格納フィールド", - "xpack.monitoring.metrics.esNode.systemLoad.last1MinuteDescription": "過去 1 分間の平均負荷です。", - "xpack.monitoring.metrics.esNode.systemLoad.last1MinuteLabel": "1m", - "xpack.monitoring.metrics.esNode.systemLoadTitle": "システム負荷", - "xpack.monitoring.metrics.esNode.termsDescription": "用語が使用中のヒープ領域です (例: テキスト)。Lucene の一部です。", - "xpack.monitoring.metrics.esNode.termsLabel": "用語", - "xpack.monitoring.metrics.esNode.termVectorsDescription": "用語ベクトルが使用中のヒープ領域です。Lucene の一部です。", - "xpack.monitoring.metrics.esNode.termVectorsLabel": "用語ベクトル", - "xpack.monitoring.metrics.esNode.threadQueue.getDescription": "このノードでプロセス待ちの Get オペレーションの数です。", - "xpack.monitoring.metrics.esNode.threadQueue.getLabel": "Get", - "xpack.monitoring.metrics.esNode.threadQueueTitle": "スレッドキュー", - "xpack.monitoring.metrics.esNode.threadsQueued.bulkDescription": "このノードでプロセス待ちの一斉インデックスオペレーションの数です。1 つの一斉リクエストが複数の一斉オペレーションを作成します。", - "xpack.monitoring.metrics.esNode.threadsQueued.bulkLabel": "一斉", - "xpack.monitoring.metrics.esNode.threadsQueued.genericDescription": "このノードでプロセス待ちのジェネリック (内部) オペレーションの数です。", - "xpack.monitoring.metrics.esNode.threadsQueued.genericLabel": "ジェネリック", - "xpack.monitoring.metrics.esNode.threadsQueued.indexDescription": "このノードでプロセス待ちの非一斉インデックスオペレーションの数です。", - "xpack.monitoring.metrics.esNode.threadsQueued.indexLabel": "インデックス", - "xpack.monitoring.metrics.esNode.threadsQueued.managementDescription": "このノードでプロセス待ちの管理 (内部) オペレーションの数です。", - "xpack.monitoring.metrics.esNode.threadsQueued.managementLabel": "管理", - "xpack.monitoring.metrics.esNode.threadsQueued.searchDescription": "このノードでプロセス待ちの検索オペレーションの数です。1 つの検索リクエストが複数の検索オペレーションを作成します。", - "xpack.monitoring.metrics.esNode.threadsQueued.searchLabel": "検索", - "xpack.monitoring.metrics.esNode.threadsQueued.watcherDescription": "このノードでプロセス待ちの Watcher オペレーションの数です。", - "xpack.monitoring.metrics.esNode.threadsQueued.watcherLabel": "Watcher", - "xpack.monitoring.metrics.esNode.threadsRejected.bulkDescription": "一斉拒否です。キューがいっぱいの時に起こります。", - "xpack.monitoring.metrics.esNode.threadsRejected.bulkLabel": "一斉", - "xpack.monitoring.metrics.esNode.threadsRejected.genericDescription": "ジェネリック (内部) オペレーションキューがいっぱいの時に起こります。", - "xpack.monitoring.metrics.esNode.threadsRejected.genericLabel": "ジェネリック", - "xpack.monitoring.metrics.esNode.threadsRejected.getDescription": "Get の拒否です。キューがいっぱいの時に起こります。", - "xpack.monitoring.metrics.esNode.threadsRejected.getLabel": "Get", - "xpack.monitoring.metrics.esNode.threadsRejected.indexDescription": "インデックスの拒否です。キューがいっぱいの時に起こります。一斉インデックスを確認してください。", - "xpack.monitoring.metrics.esNode.threadsRejected.indexLabel": "インデックス", - "xpack.monitoring.metrics.esNode.threadsRejected.managementDescription": "Get (内部) 拒否です。キューがいっぱいの時に起こります。", - "xpack.monitoring.metrics.esNode.threadsRejected.managementLabel": "管理", - "xpack.monitoring.metrics.esNode.threadsRejected.searchDescription": "検索拒否です。キューがいっぱいの時に起こります。オーバーシャードを示している可能性があります。", - "xpack.monitoring.metrics.esNode.threadsRejected.searchLabel": "検索", - "xpack.monitoring.metrics.esNode.threadsRejected.watcherDescription": "ウォッチの拒否です。キューがいっぱいの時に起こります。ウォッチのスタックを示している可能性があります。", - "xpack.monitoring.metrics.esNode.threadsRejected.watcherLabel": "Watcher", - "xpack.monitoring.metrics.esNode.totalRefreshTimeDescription": "プライマリとレプリカシャードの Elasticsearch の更新所要時間です。", - "xpack.monitoring.metrics.esNode.totalRefreshTimeLabel": "合計更新時間", - "xpack.monitoring.metrics.esNode.versionMapDescription": "バージョニング (例: 更新、削除) が使用中のヒープ領域です。Lucene 合計の一部ではありません。", - "xpack.monitoring.metrics.esNode.versionMapLabel": "バージョンマップ", - "xpack.monitoring.metrics.kibana.clientRequestsDescription": "Kibana インスタンスが受信したクライアントリクエストの合計数です。", - "xpack.monitoring.metrics.kibana.clientRequestsLabel": "クライアントリクエスト", - "xpack.monitoring.metrics.kibana.clientResponseTime.averageDescription": "Kibana インスタンスへのクライアントリクエストの平均応答時間です。", - "xpack.monitoring.metrics.kibana.clientResponseTime.averageLabel": "平均", - "xpack.monitoring.metrics.kibana.clientResponseTime.maxDescription": "Kibana インスタンスへのクライアントリクエストの最長応答時間です。", - "xpack.monitoring.metrics.kibana.clientResponseTime.maxLabel": "最高", - "xpack.monitoring.metrics.kibana.clientResponseTimeTitle": "クライアント応答時間", - "xpack.monitoring.metrics.kibana.httpConnectionsDescription": "Kibana へのオープンソケット接続の数です。", - "xpack.monitoring.metrics.kibana.httpConnectionsLabel": "HTTP 接続", - "xpack.monitoring.metrics.kibana.msTimeUnitLabel": "ms", - "xpack.monitoring.metrics.kibanaInstance.clientRequestsDescription": "Kibana インスタンスが受信したクライアントリクエストの合計数です。", - "xpack.monitoring.metrics.kibanaInstance.clientRequestsLabel": "クライアントリクエスト", - "xpack.monitoring.metrics.kibanaInstance.clientResponseTime.averageDescription": "Kibana インスタンスへのクライアントリクエストの平均応答時間です。", - "xpack.monitoring.metrics.kibanaInstance.clientResponseTime.averageLabel": "平均", - "xpack.monitoring.metrics.kibanaInstance.clientResponseTime.maxDescription": "Kibana インスタンスへのクライアントリクエストの最長応答時間です。", - "xpack.monitoring.metrics.kibanaInstance.clientResponseTime.maxLabel": "最高", - "xpack.monitoring.metrics.kibanaInstance.clientResponseTimeTitle": "クライアント応答時間", - "xpack.monitoring.metrics.kibanaInstance.eventLoopDelayDescription": "Kibana サーバーイベントループの遅延です。長い遅延は、同時機能が多くの CPU 時間を取るなど、サーバースレッドのイベントのブロックを示している可能性があります。", - "xpack.monitoring.metrics.kibanaInstance.eventLoopDelayLabel": "イベントループの遅延", - "xpack.monitoring.metrics.kibanaInstance.memorySize.heapSizeLimitDescription": "ガーベージコレクション前のメモリー使用量の制限です。", - "xpack.monitoring.metrics.kibanaInstance.memorySize.heapSizeLimitLabel": "ヒープサイズ制限", - "xpack.monitoring.metrics.kibanaInstance.memorySizeDescription": "Node.js で実行中の Kibana によるヒープの合計使用量です。", - "xpack.monitoring.metrics.kibanaInstance.memorySizeLabel": "メモリーサイズ", - "xpack.monitoring.metrics.kibanaInstance.memorySizeTitle": "メモリーサイズ", - "xpack.monitoring.metrics.kibanaInstance.systemLoad.last15MinutesDescription": "過去 15 分間の平均負荷です。", - "xpack.monitoring.metrics.kibanaInstance.systemLoad.last15MinutesLabel": "15m", - "xpack.monitoring.metrics.kibanaInstance.systemLoad.last1MinuteDescription": "過去 1 分間の平均負荷です。", - "xpack.monitoring.metrics.kibanaInstance.systemLoad.last1MinuteLabel": "1m", - "xpack.monitoring.metrics.kibanaInstance.systemLoad.last5MinutesDescription": "過去 5 分間の平均負荷です。", - "xpack.monitoring.metrics.kibanaInstance.systemLoad.last5MinutesLabel": "5m", - "xpack.monitoring.metrics.kibanaInstance.systemLoadTitle": "システム負荷", - "xpack.monitoring.metrics.logstash.eventLatencyDescription": "フィルターとアウトプットステージのイベントの平均所要時間です。イベントの処理に所要した合計時間を送信イベント数で割った時間です。", - "xpack.monitoring.metrics.logstash.eventLatencyLabel": "イベントレイテンシ", - "xpack.monitoring.metrics.logstash.eventsEmittedRateDescription": "すべての Logstash ノードによりアウトプットステージで 1 秒間に送信されたイベント数です。", - "xpack.monitoring.metrics.logstash.eventsEmittedRateLabel": "イベント送信レート", - "xpack.monitoring.metrics.logstash.eventsPerSecondUnitLabel": "e/s", - "xpack.monitoring.metrics.logstash.eventsReceivedRateDescription": "すべての Logstash ノードによりアウトプットステージで 1 秒間に受信されたイベント数です。", - "xpack.monitoring.metrics.logstash.eventsReceivedRateLabel": "イベント受信レート", - "xpack.monitoring.metrics.logstash.msTimeUnitLabel": "ms", - "xpack.monitoring.metrics.logstash.nsTimeUnitLabel": "ナノ秒", - "xpack.monitoring.metrics.logstash.perSecondUnitLabel": "/s", - "xpack.monitoring.metrics.logstash.systemLoadTitle": "システム負荷", - "xpack.monitoring.metrics.logstashInstance.cgroupCfsStats.cgroupElapsedPeriodsDescription": "Completely Fair Scheduler (CFS) からのサンプリング期間の数です。スロットル回数と比較します。", - "xpack.monitoring.metrics.logstashInstance.cgroupCfsStats.cgroupElapsedPeriodsLabel": "Cgroup 経過時間", - "xpack.monitoring.metrics.logstashInstance.cgroupCfsStats.cgroupThrottledCountDescription": "Cgroup により CPU がスロットリングされた回数です。", - "xpack.monitoring.metrics.logstashInstance.cgroupCfsStats.cgroupThrottledCountLabel": "Cgroup スロットルカウント", - "xpack.monitoring.metrics.logstashInstance.cgroupCfsStatsTitle": "Cgroup CFS 統計", - "xpack.monitoring.metrics.logstashInstance.cgroupCpuPerformance.cgroupThrottlingDescription": "Cgroup のナノ秒単位で報告されたスロットル時間です。", - "xpack.monitoring.metrics.logstashInstance.cgroupCpuPerformance.cgroupThrottlingLabel": "Cgroup スロットリング", - "xpack.monitoring.metrics.logstashInstance.cgroupCpuPerformance.cgroupUsageDescription": "Cgroup のナノ秒単位で報告された使用状況です。スロットリングと比較して問題を発見します。", - "xpack.monitoring.metrics.logstashInstance.cgroupCpuPerformance.cgroupUsageLabel": "Cgroup の使用状況", - "xpack.monitoring.metrics.logstashInstance.cgroupCpuPerformanceTitle": "Cgroup CPU パフォーマンス", - "xpack.monitoring.metrics.logstashInstance.cgroupCpuUtilizationDescription": "CPU クォータに対する CPU 使用時間のパーセンテージです。CPU クォータが設定されていない場合、データは表示されません。", - "xpack.monitoring.metrics.logstashInstance.cpuUtilization.cgroupCpuUtilizationLabel": "Cgroup CPU 活用状況", - "xpack.monitoring.metrics.logstashInstance.cpuUtilizationDescription": "OS により報告された CPU 使用量のパーセンテージです (最大 100%)。", - "xpack.monitoring.metrics.logstashInstance.cpuUtilizationLabel": "CPU 使用状況", - "xpack.monitoring.metrics.logstashInstance.cpuUtilizationTitle": "CPU 使用状況", - "xpack.monitoring.metrics.logstashInstance.eventLatencyDescription": "フィルターとアウトプットステージのイベントの平均所要時間です。イベントの処理に所要した合計時間を送信イベント数で割った時間です。", - "xpack.monitoring.metrics.logstashInstance.eventLatencyLabel": "イベントレイテンシ", - "xpack.monitoring.metrics.logstashInstance.eventsEmittedRateDescription": "Logstash ノードによりアウトプットステージで 1 秒間に送信されたイベント数です。", - "xpack.monitoring.metrics.logstashInstance.eventsEmittedRateLabel": "イベント送信レート", - "xpack.monitoring.metrics.logstashInstance.eventsQueuedDescription": "フィルターとアウトプットステージによる処理待ちの、永続キューのイベントの平均数です。", - "xpack.monitoring.metrics.logstashInstance.eventsQueuedLabel": "キューのイベント", - "xpack.monitoring.metrics.logstashInstance.eventsReceivedRateDescription": "Logstash ノードによりアウトプットステージで 1 秒間に受信されたイベント数です。", - "xpack.monitoring.metrics.logstashInstance.eventsReceivedRateLabel": "イベント受信レート", - "xpack.monitoring.metrics.logstashInstance.jvmHeap.maxHeapDescription": "JVM で実行中の Logstash が利用できるヒープの合計です。", - "xpack.monitoring.metrics.logstashInstance.jvmHeap.maxHeapLabel": "最大ヒープ", - "xpack.monitoring.metrics.logstashInstance.jvmHeap.usedHeapDescription": "JVM で実行中の Logstash が使用しているヒープの合計です。", - "xpack.monitoring.metrics.logstashInstance.jvmHeap.usedHeapLabel": "使用ヒープ", - "xpack.monitoring.metrics.logstashInstance.jvmHeapTitle": "{javaVirtualMachine} ヒープ", - "xpack.monitoring.metrics.logstashInstance.maxQueueSizeDescription": "このノードの永続キューに設定された最大サイズです。", - "xpack.monitoring.metrics.logstashInstance.maxQueueSizeLabel": "最大キューサイズ", - "xpack.monitoring.metrics.logstashInstance.persistentQueueEventsTitle": "永続キューイベント", - "xpack.monitoring.metrics.logstashInstance.persistentQueueSizeTitle": "永続キューサイズ", - "xpack.monitoring.metrics.logstashInstance.pipelineNodeCountDescription": "Logstash パイプラインが実行されているノードの数です。", - "xpack.monitoring.metrics.logstashInstance.pipelineNodeCountLabel": "パイプラインノードカウント", - "xpack.monitoring.metrics.logstashInstance.pipelineThroughputDescription": "Logstash パイプラインによりアウトプットステージで 1 秒間に送信されたイベント数です。", - "xpack.monitoring.metrics.logstashInstance.pipelineThroughputLabel": "パイプラインスループット", - "xpack.monitoring.metrics.logstashInstance.queueSizeDescription": "このノードの Logstash パイプラインのすべての永続キューの現在のサイズです。", - "xpack.monitoring.metrics.logstashInstance.queueSizeLabel": "キューサイズ", - "xpack.monitoring.metrics.logstashInstance.systemLoad.last15MinutesDescription": "過去 15 分間の平均負荷です。", - "xpack.monitoring.metrics.logstashInstance.systemLoad.last15MinutesLabel": "15m", - "xpack.monitoring.metrics.logstashInstance.systemLoad.last1MinuteDescription": "過去 1 分間の平均負荷です。", - "xpack.monitoring.metrics.logstashInstance.systemLoad.last1MinuteLabel": "1m", - "xpack.monitoring.metrics.logstashInstance.systemLoad.last5MinutesDescription": "過去 5 分間の平均負荷です。", - "xpack.monitoring.metrics.logstashInstance.systemLoad.last5MinutesLabel": "5m", - "xpack.monitoring.monitoringDescription": "Elastic Stack のリアルタイムのヘルスとパフォーマンスをトラッキングします。", - "xpack.monitoring.monitoringTitle": "Monitoring", - "xpack.monitoring.noData.blurbs.changesNeededDescription": "監視を実行するには、次の手順に従います", - "xpack.monitoring.noData.blurbs.changesNeededTitle": "調整が必要です", - "xpack.monitoring.noData.blurbs.lookingForMonitoringDataDescription": "監視は、ハードウェアパフォーマンスと負荷の情報を提供します。", - "xpack.monitoring.noData.blurbs.lookingForMonitoringDataTitle": "監視データを検索中です", - "xpack.monitoring.noData.blurbs.monitoringIsOffDescription": "監視は、ハードウェアパフォーマンスと負荷の情報を提供します。", - "xpack.monitoring.noData.blurbs.monitoringIsOffTitle": "監視は現在オフになっています", - "xpack.monitoring.noData.checkerErrors.checkEsSettingsErrorMessage": "Elasticsearch の設定の確認中にエラーが発生しました。設定の確認には管理者権限が必要で、必要に応じて監視収集設定を有効にする必要があります。", - "xpack.monitoring.noData.explanations.collectionEnabled.monitoringTurnedOnDescription": "データがクラスターにある場合、ここに監視ダッシュボードが表示されます。これには数秒かかる場合があります。", - "xpack.monitoring.noData.explanations.collectionEnabled.monitoringTurnedOnTitle": "成功!監視データを取得中です。", - "xpack.monitoring.noData.explanations.collectionEnabled.stillWaitingLinkText": "まだ待っていますか?", - "xpack.monitoring.noData.explanations.collectionEnabled.turnItOnDescription": "オンにしますか?", - "xpack.monitoring.noData.explanations.collectionEnabled.turnOnMonitoringButtonLabel": "監視をオンにする", - "xpack.monitoring.noData.explanations.collectionEnabledDescription": "{context} 設定を確認し、 {property} が {data} に設定されていることが判明しました。", - "xpack.monitoring.noData.explanations.collectionInterval.changeIntervalDescription": "この設定を変更して監視を有効にしますか?", - "xpack.monitoring.noData.explanations.collectionInterval.monitoringTurnedOnDescription": "クラスターに監視データが現れ次第、ページが自動的に監視ダッシュボードと共に更新されます。これにはたった数秒しかかかりません。", - "xpack.monitoring.noData.explanations.collectionInterval.monitoringTurnedOnTitle": "成功!少々お待ちください。", - "xpack.monitoring.noData.explanations.collectionInterval.turnOnMonitoringButtonLabel": "監視をオンにする", - "xpack.monitoring.noData.explanations.collectionInterval.wrongIntervalValueDescription": "収集エージェントをアクティブにするには、収集間隔設定がプラスの整数 (推奨: 10s) でなければなりません。", - "xpack.monitoring.noData.explanations.collectionIntervalDescription": "{context} 設定を確認し、 {property} が {data} に設定されていることが判明しました。", - "xpack.monitoring.noData.explanations.exporters.checkConfigDescription": "この Kibana のインスタンスで監視データを表示するには、意図されたエクスポーターの監視クラスターへの統計の送信が有効になっていて、監視クラスターのホストが {kibanaConfig} の {monitoringEs} 設定と一致していることを確認してください。", - "xpack.monitoring.noData.explanations.exporters.problemWithConfigDescription": "監視エクスポーターを使用し監視データをリモート監視クラスターに送信することで、本番クラスターの状態にかかわらず監視データが安全に保管されるため、強くお勧めします。但し、この Kibana のインスタンスは監視データを見つけられませんでした。{property} 構成または {kibanaConfig} の {monitoringEs} 設定に問題があるようです。", - "xpack.monitoring.noData.explanations.exportersDescription": "{property} の {context} 設定を確認し理由が判明しました: {data}。", - "xpack.monitoring.noData.explanations.pluginEnabledDescription": "{context} 設定を確認し、 {property} が {data} に設定されていることが判明しました。これにより監視が無効になっています。構成から {monitoringEnableFalse} 設定を削除することで、デフォルトの設定になり監視が有効になります。", - "xpack.monitoring.noData.reasons.couldNotActivateMonitoringTitle": "監視を有効にできませんでした", - "xpack.monitoring.noData.reasons.explainWhyNoDataDescription": "{context} 設定で {property} が {data} に設定されています。", - "xpack.monitoring.noData.reasons.ifDataInClusterDescription": "クラスターにデータがある場合、ここに監視ダッシュボードが表示されます。", - "xpack.monitoring.noData.reasons.noMonitoringDataFoundDescription": "監視データが見つかりません。時間フィルターを「過去 1 時間」に設定するか、別の期間にデータがあるか確認してください。", - "xpack.monitoring.pageLoadingTitle": "読み込み中…", - "xpack.monitoring.requestedClusters.uuidNotFoundErrorMessage": "選択された時間範囲にクラスターが見つかりませんでした。UUID: {clusterUuid}", - "xpack.monitoring.stackMonitoringDocTitle": "スタック監視 {clusterName} {suffix}", - "xpack.monitoring.stackMonitoringTitle": "スタック監視", - "xpack.monitoring.summaryStatus.statusDescription": "ステータス", - "xpack.monitoring.summaryStatus.statusIconLabel": "ステータス: {status}", - "xpack.monitoring.summaryStatus.statusIconTitle": "ステータス: {statusIcon}", - "xpack.monitoring.uiExportsDescription": "Elastic Stack の監視です", - "xpack.monitoring.chart.timeSeries.zoomOut": "ズームアウト", - "xpack.monitoring.errors.monitoringLicenseErrorDescription": "クラスター = 「{clusterId}」のライセンス情報が見つかりませんでした。クラスターのマスターノードサーバーログにエラーや警告がないか確認してください。", - "xpack.monitoring.errors.monitoringLicenseErrorTitle": "監視ライセンスエラー", - "xpack.monitoring.logs.reason.defaultMessage": "ログデータが見つからず、理由を診断することができません。{link}", - "xpack.monitoring.logs.reason.defaultMessageLink": "正しくセットアップされていることを確認してください。", - "xpack.monitoring.logs.reason.defaultTitle": "ログデータが見つかりませんでした", - "xpack.monitoring.metricbeatMigration.apmInstructions.configureMetricbeatDescription": "{file} にこれらの変更を加えます。", - "xpack.monitoring.metricbeatMigration.apmInstructions.configureMetricbeatTitle": "Metricbeat を構成して監視クラスターに送ります", - "xpack.monitoring.metricbeatMigration.apmInstructions.disableInternalCollection.description": "APM サーバーの構成ファイル ({file}) に次の設定を追加します:", - "xpack.monitoring.metricbeatMigration.apmInstructions.disableInternalCollection.note": "この変更後、APM サーバーの再起動が必要です。", - "xpack.monitoring.metricbeatMigration.apmInstructions.disableInternalCollection.title": "APM サーバーの監視メトリックの内部収集を無効にする", - "xpack.monitoring.metricbeatMigration.apmInstructions.enableMetricbeatModuleDescription": "モジュールはデフォルトで http://localhost:5066 から APM サーバーの監視メトリックを収集します。ローカル APM サーバーのアドレスが異なる場合は、{file} ファイルの {hosts} 設定で指定する必要があります。", - "xpack.monitoring.metricbeatMigration.apmInstructions.enableMetricbeatModuleTitle": "Metricbeat の Beat X-Pack モジュールの有効化と構成", - "xpack.monitoring.metricbeatMigration.apmInstructions.installMetricbeatLinkText": "こちらの手順に従ってください", - "xpack.monitoring.metricbeatMigration.apmInstructions.installMetricbeatTitle": "Metricbeat を APM サーバーと同じサーバーにインストール", - "xpack.monitoring.metricbeatMigration.apmInstructions.startMetricbeatLinkText": "こちらの手順に従ってください", - "xpack.monitoring.metricbeatMigration.apmInstructions.startMetricbeatTitle": "Metricbeat を起動します", - "xpack.monitoring.metricbeatMigration.beatsInstructions.configureMetricbeatDescription": "{file} にこれらの変更を加えます。", - "xpack.monitoring.metricbeatMigration.beatsInstructions.configureMetricbeatTitle": "Metricbeat を構成して監視クラスターに送ります", - "xpack.monitoring.metricbeatMigration.beatsInstructions.disableInternalCollection.description": "{beatType} の構成ファイル ({file}) に次の設定を追加します:", - "xpack.monitoring.metricbeatMigration.beatsInstructions.disableInternalCollection.note": "この変更後、{beatType} の再起動が必要です。", - "xpack.monitoring.metricbeatMigration.beatsInstructions.disableInternalCollection.title": "{beatType} の監視メトリックの自己監視を無効にする", - "xpack.monitoring.metricbeatMigration.beatsInstructions.enableMetricbeatModuleDescription": "モジュールはデフォルトで http://localhost:5066 から {beatType} 監視メトリックを収集します。監視されている {beatType} インスタンスのアドレスが異なる場合は、{file} ファイルの {hosts} 設定で指定する必要があります。", - "xpack.monitoring.metricbeatMigration.beatsInstructions.enableMetricbeatModuleHttpEnabledDirections": "Metricbeat が実行中の {beatType} からメトリックを収集するには、{link} 必要があります。", - "xpack.monitoring.metricbeatMigration.beatsInstructions.enableMetricbeatModuleHttpEnabledDirectionsLinkText": "監視されている {beatType} の HTTP エンドポイントを有効にする", - "xpack.monitoring.metricbeatMigration.beatsInstructions.enableMetricbeatModuleTitle": "Metricbeat の Beat X-Pack モジュールの有効化と構成", - "xpack.monitoring.metricbeatMigration.beatsInstructions.installMetricbeatLinkText": "こちらの手順に従ってください", - "xpack.monitoring.metricbeatMigration.beatsInstructions.installMetricbeatTitle": "Metricbeat を {beatType} と同じサーバーにインストール", - "xpack.monitoring.metricbeatMigration.beatsInstructions.startMetricbeatLinkText": "こちらの手順に従ってください", - "xpack.monitoring.metricbeatMigration.beatsInstructions.startMetricbeatTitle": "Metricbeat を起動します", - "xpack.monitoring.metricbeatMigration.flyout.noClusterUuidTitle": "クラスターが検出されてませんでした", - "xpack.monitoring.metricbeatMigration.logstashInstructions.configureMetricbeatDescription": "{file} にこれらの変更を加えます。", - "xpack.monitoring.metricbeatMigration.logstashInstructions.configureMetricbeatTitle": "Metricbeat を構成して監視クラスターに送ります", - "xpack.monitoring.metricbeatMigration.logstashInstructions.disableInternalCollection.description": "Logstash 構成ファイル ({file}) に次の設定を追加します:", - "xpack.monitoring.metricbeatMigration.logstashInstructions.disableInternalCollection.note": "この変更後、Logstash の再起動が必要です。", - "xpack.monitoring.metricbeatMigration.logstashInstructions.disableInternalCollection.title": "Logstash 監視メトリックの内部収集を無効にする", - "xpack.monitoring.metricbeatMigration.logstashInstructions.enableMetricbeatModuleDescription": "モジュールはデフォルトで http://localhost:9600 から Logstash 監視メトリックを収集します。ローカル Logstash インスタンスのアドレスが異なる場合は、{file} ファイルの {hosts} 設定で指定する必要があります。", - "xpack.monitoring.metricbeatMigration.logstashInstructions.enableMetricbeatModuleTitle": "Metricbeat の Logstash X-Pack もウールの有効化と構成", - "xpack.monitoring.metricbeatMigration.logstashInstructions.installMetricbeatLinkText": "こちらの手順に従ってください", - "xpack.monitoring.metricbeatMigration.logstashInstructions.installMetricbeatTitle": "Metricbeat を Logstash と同じサーバーにインストール", - "xpack.monitoring.metricbeatMigration.logstashInstructions.startMetricbeatLinkText": "こちらの手順に従ってください", - "xpack.monitoring.metricbeatMigration.logstashInstructions.startMetricbeatTitle": "Metricbeat を起動します", - "xpack.monitoring.noData.blurbs.cloudDeploymentDescription": "次の場所に戻ってください: ", - "xpack.monitoring.noData.blurbs.cloudDeploymentDescriptionMore": "Elastic Cloud での監視の詳細は、 ", - "xpack.monitoring.noData.blurbs.cloudDeploymentTitle": "監視データはこちらに表示されません。", - "xpack.monitoring.noData.explanations.exportersCloudDescription": "Elastic Cloud では、監視データが専用の監視クラスターに格納されます。", - "xpack.monitoring.elasticsearch.nodes.metricbeatMigration.detectedNodeDescription": "次のインデックスは監視されていません。下の「Metricbeat で監視」をクリックして、監視を開始してください。", - "xpack.monitoring.elasticsearch.nodes.metricbeatMigration.detectedNodeTitle": "Elasticsearch ノードが検出されました", - "xpack.monitoring.elasticsearch.nodes.metricbeatMigration.disableInternalCollectionDescription": "移行を完了させるには、自己監視を無効にしてください。", - "xpack.monitoring.elasticsearch.nodes.metricbeatMigration.disableInternalCollectionMigrationButtonLabel": "自己監視を無効にする", - "xpack.monitoring.elasticsearch.nodes.metricbeatMigration.disableInternalCollectionTitle": "Metricbeat による Elasticsearch ノードの監視が開始されました", - "xpack.monitoring.euiSSPTable.setupNewButtonLabel": "新規 {identifier} の監視を設定", - "xpack.monitoring.euiTable.setupNewButtonLabel": "Metricbeat で別の {identifier} を監視", - "xpack.monitoring.kibana.instances.metricbeatMigration.detectedNodeDescription": "次のインスタンスは監視されていません。\n 下の「Metricbeat で監視」をクリックして、監視を開始してください。", - "xpack.monitoring.kibana.instances.metricbeatMigration.detectedNodeTitle": "Kibana インスタンスが検出されました", - "xpack.monitoring.metricbeatMigration.disableInternalCollection.fullyMigratedStatusDescription": "自己監視からのドキュメントがありません。移行完了!", - "xpack.monitoring.metricbeatMigration.disableInternalCollection.fullyMigratedStatusTitle": "おめでとうございます!", - "xpack.monitoring.metricbeatMigration.disableInternalCollection.partiallyMigratedStatusDescription": "最後の自己監視は {secondsSinceLastInternalCollectionLabel} 前です。", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.enableMetricbeatModuleInstallDirectory": "インストールディレクトリから次のファイルを実行します:", - "xpack.monitoring.metricbeatMigration.flyout.learnMore": "詳細な理由", - "xpack.monitoring.metricbeatMigration.fullyMigratedStatusDescription": "Metricbeat は監視データを送信しています。", - "xpack.monitoring.metricbeatMigration.fullyMigratedStatusTitle": "おめでとうございます!", - "xpack.monitoring.metricbeatMigration.isInternalCollectorStatusTitle": "監視データは検出されませんでしたが、引き続き確認します。", - "xpack.monitoring.metricbeatMigration.migrationStatus": "移行ステータス", - "xpack.monitoring.metricbeatMigration.monitoringStatus": "監視ステータス", - "xpack.monitoring.metricbeatMigration.partiallyMigratedStatusDescription": "データの検出には最長 {secondsAgo} 秒かかる場合があります。", - "xpack.monitoring.metricbeatMigration.partiallyMigratedStatusTitle": "まだ自己監視からのデータが届いています", - "xpack.monitoring.metricbeatMigration.securitySetup": "セキュリティが有効の場合、{link} が必要な可能性があります。", - "xpack.monitoring.metricbeatMigration.securitySetupLinkText": "追加設定", - "xpack.monitoring.metrics.esNode.ioRateTitle": "I/O オペレーションレート", - "xpack.monitoring.metrics.esNode.totalIoDescription": "I/O 合計。(このメトリックはすべてのプラットフォームでサポートされておらず、I/O が利用できない場合 N/A が表示されることがあります。)", - "xpack.monitoring.metrics.esNode.totalIoLabel": "I/O 合計", - "xpack.monitoring.metrics.esNode.totalIoReadDescription": "読み込み I/O 合計。(このメトリックはすべてのプラットフォームでサポートされておらず、I/O が利用できない場合 N/A が表示されることがあります。)", - "xpack.monitoring.metrics.esNode.totalIoReadLabel": "読み込み I/O 合計", - "xpack.monitoring.metrics.esNode.totalIoWriteDescription": "書き込み I/O 合計。(このメトリックはすべてのプラットフォームでサポートされておらず、I/O が利用できない場合 N/A が表示されることがあります。)", - "xpack.monitoring.metrics.esNode.totalIoWriteLabel": "書き込み I/O 合計", - "xpack.monitoring.noData.collectionInterval.turnOnMonitoringButtonLabel": "Metricbeat で監視を設定", - "xpack.monitoring.noData.defaultLoadingMessage": "読み込み中、お待ちください", - "xpack.monitoring.noData.noMonitoringDataFound": "既に監視を設定済みですか?その場合、右上に選択された期間に監視データが含まれていることを確認してください。", - "xpack.monitoring.noData.noMonitoringDetected": "監視データが見つかりません。", - "xpack.monitoring.noData.routeTitle": "監視の設定", - "xpack.monitoring.noData.setupInternalInstead": "または、自己監視で設定", - "xpack.monitoring.noData.setupMetricbeatInstead": "または、Metricbeat で設定 (推奨)", - "xpack.monitoring.setupMode.clickToDisableInternalCollection": "自己監視を無効にする", - "xpack.monitoring.setupMode.clickToMonitorWithMetricbeat": "Metricbeat で監視", - "xpack.monitoring.setupMode.description": "現在設定モードです。({flagIcon}) アイコンは構成オプションを意味します。", - "xpack.monitoring.setupMode.detectedNodeDescription": "下の「監視を設定」をクリックしてこの {identifier} の監視を開始します。", - "xpack.monitoring.setupMode.detectedNodeTitle": "{product} {identifier} が検出されました", - "xpack.monitoring.setupMode.disableInternalCollectionDescription": "Metricbeat による {product} {identifier} の監視が開始されました。移行を完了させるには、自己監視を無効にしてください。", - "xpack.monitoring.setupMode.disableInternalCollectionTitle": "自己監視を無効にする", - "xpack.monitoring.setupMode.exit": "設定モードを修了", - "xpack.monitoring.setupMode.instance": "インスタンス", - "xpack.monitoring.setupMode.instances": "インスタンス", - "xpack.monitoring.setupMode.metricbeatAllNodes": "Metricbeat がすべての {identifier} を監視しています。", - "xpack.monitoring.setupMode.migrateSomeToMetricbeatDescription": "{product} {identifier} の一部は自己監視で監視されています。Metricbeat での監視に移行してください。", - "xpack.monitoring.setupMode.migrateToMetricbeat": "Metricbeat で監視", - "xpack.monitoring.setupMode.migrateToMetricbeatDescription": "これらの {product} {identifier} は自己監視されています。\n 移行するには「Metricbeat で監視」をクリックしてください。", - "xpack.monitoring.setupMode.monitorAllNodes": "ノードの一部は自己監視のみ使用できます。", - "xpack.monitoring.setupMode.netNewUserDescription": "「監視を設定」をクリックして監視を開始します。", - "xpack.monitoring.setupMode.node": "ノード", - "xpack.monitoring.setupMode.nodes": "ノード", - "xpack.monitoring.setupMode.noMonitoringDataFound": "{product} {identifier} が検出されませんでした", - "xpack.monitoring.setupMode.server": "サーバー", - "xpack.monitoring.setupMode.servers": "サーバー", - "xpack.monitoring.setupMode.tooltip.allSet": "Metricbeat がすべての {identifierPlural} を監視しています。", - "xpack.monitoring.setupMode.tooltip.detected": "監視なし", - "xpack.monitoring.setupMode.tooltip.disableInternal": "Metricbeat がすべての {identifierPlural} を監視しています。クリックして {identifierPlural} を表示し、自己監視を無効にしてください。", - "xpack.monitoring.setupMode.tooltip.mightExist": "この製品の使用が検出されました。クリックして監視を開始してください。", - "xpack.monitoring.setupMode.tooltip.noUsage": "使用なし", - "xpack.monitoring.setupMode.tooltip.noUsageDetected": "使用が検出されませんでした。{identifier} を表示するにはクリックしてください。", - "xpack.monitoring.setupMode.tooltip.oneInternal": "少なくとも 1 つの {identifier} が Metricbeat によって監視されていません。ステータスを表示するにはクリックしてください。", - "xpack.monitoring.setupMode.unknown": "N/A", - "xpack.monitoring.setupMode.usingMetricbeatCollection": "Metricbeat で監視", - "xpack.monitoring.metricbeatMigration.flyout.flyoutTitle": "Metricbeat で「{instanceName}」の {instanceIdentifier} を監視", - "xpack.monitoring.metricbeatMigration.flyout.flyoutTitleNewUser": "Metricbeat で「{instanceName}」の {instanceIdentifier} を監視", - "xpack.monitoring.metricbeatMigration.flyout.noClusterUuidCheckboxLabel": "はい、\n この {productName} {instanceIdentifier} スタンドアロンクラスターを調べる必要があることを理解しています。", - "xpack.monitoring.metricbeatMigration.flyout.noClusterUuidDescription": "この {productName} {instanceIdentifier} は Elasticsearch クラスターに接続されていないため、完全に移行された時点で、この {productName} {instanceIdentifier} はこのクラスターではなくスタンドアロンクラスターに表示されます。 {link}", - "xpack.remoteClusters.addAction.clusterNameAlreadyExistsErrorMessage": "「{clusterName}」という名前のクラスターが既に存在します。", - "xpack.remoteClusters.addAction.errorTitle": "クラスターの追加中にエラーが発生", - "xpack.remoteClusters.addAction.failedDefaultErrorMessage": "{statusCode} エラーでリクエスト失敗: {message}", - "xpack.remoteClusters.addAction.successTitle": "リモートクラスター「{name}」が追加されました", - "xpack.remoteClusters.addBreadcrumbTitle": "追加", - "xpack.remoteClusters.addTitle": "リモートクラスターを追加", - "xpack.remoteClusters.appName": "リモートクラスター", - "xpack.remoteClusters.appTitle": "リモートクラスター", - "xpack.remoteClusters.configuredByNodeWarningTitle": "このリモートクラスターはノードの elasticsearch.yml 構成ファイルで定義されているため、編集または削除できません。", - "xpack.remoteClusters.connectedStatus.connectedAriaLabel": "接続済み", - "xpack.remoteClusters.connectedStatus.notConnectedAriaLabel": "未接続", - "xpack.remoteClusters.connectedStatus.notConnectedToolTip": "シードノードが HTTP ポートではなくリモートクラスターのトランスポートポートで構成されていることを確認してください。", - "xpack.remoteClusters.detailPanel.closeButtonLabel": "閉じる", - "xpack.remoteClusters.detailPanel.connectedLabel": "接続", - "xpack.remoteClusters.detailPanel.connectedNodesLabel": "接続済みのノード", - "xpack.remoteClusters.detailPanel.editButtonLabel": "編集", - "xpack.remoteClusters.detailPanel.initialConnectTimeoutLabel": "初期接続タイムアウト", - "xpack.remoteClusters.detailPanel.maxConnectionsPerClusterLabel": "最大接続数", - "xpack.remoteClusters.detailPanel.notFoundLabel": "リモートクラスターが見つかりません", - "xpack.remoteClusters.detailPanel.removeButtonLabel": "削除", - "xpack.remoteClusters.detailPanel.seedsLabel": "シード", - "xpack.remoteClusters.detailPanel.skipUnavailableFalseValue": "いいえ", - "xpack.remoteClusters.detailPanel.skipUnavailableLabel": "利用不可のものをスキップ", - "xpack.remoteClusters.detailPanel.skipUnavailableNullValue": "デフォルト", - "xpack.remoteClusters.detailPanel.skipUnavailableTrueValue": "はい", - "xpack.remoteClusters.detailPanel.statusTitle": "ステータス", - "xpack.remoteClusters.edit.backToRemoteClustersButtonLabel": "リモートクラスターに戻る", - "xpack.remoteClusters.edit.loadingErrorMessage": "リモートクラスター「{name}」が存在しません。", - "xpack.remoteClusters.edit.loadingErrorTitle": "リモートクラスターの読み込み中にエラーが発生", - "xpack.remoteClusters.edit.loadingLabel": "リモートクラスターを読み込み中…", - "xpack.remoteClusters.edit.viewRemoteClustersButtonLabel": "リモートクラスターを表示", - "xpack.remoteClusters.editAction.errorTitle": "クラスターの編集中にエラーが発生", - "xpack.remoteClusters.editAction.failedDefaultErrorMessage": "{statusCode} エラーでリクエスト失敗: {message}", - "xpack.remoteClusters.editAction.successTitle": "リモートクラスター「{name}」が編集されました", - "xpack.remoteClusters.editBreadcrumbTitle": "編集", - "xpack.remoteClusters.editTitle": "リモートクラスターを編集", - "xpack.remoteClusters.form.errors.illegalCharacters": "名前から {characterListLength, plural, one {文字} other {文字}} {characterList} を削除してください。", - "xpack.remoteClusters.form.errors.illegalSpace": "名前にスペースは使用できません。", - "xpack.remoteClusters.form.errors.nameMissing": "名前が必要です。", - "xpack.remoteClusters.form.errors.seedMissing": "シードノードが最低 1 つ必要です。", - "xpack.remoteClusters.listBreadcrumbTitle": "リモートクラスター", - "xpack.remoteClusters.loadAction.errorTitle": "リモートクラスターの読み込み中にエラーが発生", - "xpack.remoteClusters.readDocsButtonLabel": "リモートクラスタードキュメント", - "xpack.remoteClusters.refreshAction.errorTitle": "リモートクラスターの更新中にエラーが発生", - "xpack.remoteClusters.remoteClusterForm.actions.savingText": "保存中", - "xpack.remoteClusters.remoteClusterForm.cancelButtonLabel": "キャンセル", - "xpack.remoteClusters.remoteClusterForm.errorTitle": "続行する前にエラーを修正してください", - "xpack.remoteClusters.remoteClusterForm.fieldNameLabel": "名前", - "xpack.remoteClusters.remoteClusterForm.fieldNameLabelHelpText": "名前には文字、数字、アンダーライン、ハイフンのみ使用できます。", - "xpack.remoteClusters.remoteClusterForm.fieldSeedsLabel": "シードノード", - "xpack.remoteClusters.remoteClusterForm.fieldSeedsPlaceholder": "ホストポート", - "xpack.remoteClusters.remoteClusterForm.localSeedError.duplicateMessage": "重複シードノードは使用できません。", - "xpack.remoteClusters.remoteClusterForm.localSeedError.invalidCharactersMessage": "シードノードはホストポートのフォーマットを使用する必要があります。例:127.0.0.1:9400、localhost:9400.ホストには文字、数字、ハイフンのみが使用できます。", - "xpack.remoteClusters.remoteClusterForm.localSeedError.invalidPortMessage": "ポートが必要です。", - "xpack.remoteClusters.remoteClusterForm.saveButtonLabel": "保存", - "xpack.remoteClusters.remoteClusterForm.sectionNameDescription": "リモートクラスターの固有の名前です。", - "xpack.remoteClusters.remoteClusterForm.sectionNameTitle": "名前", - "xpack.remoteClusters.remoteClusterForm.sectionSeedsDescription1": "クラスターステータスのクエリを実行するリモートクラスターノードのリストです。1 つのノードが利用できない場合にディスカバリが失敗しないよう、複数シードノードを指定してください。", - "xpack.remoteClusters.remoteClusterForm.sectionSeedsHelpText": "リモートクラスターの {transportPort} の前にくる IP アドレスまたはホスト名です。", - "xpack.remoteClusters.remoteClusterForm.sectionSeedsHelpText.transportPortLinkText": "トランスポートポート", - "xpack.remoteClusters.remoteClusterForm.sectionSeedsTitle": "クラスターディスカバリのシードノード", - "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableDescription": "デフォルトで、リクエストのリモートクラスターのどれかが利用できないと、リクエストは失敗となります。このクラスターが利用できない場合にリクエストを他のリモートクラスターに送信し続けるには、{optionName} を有効にします。{learnMoreLink}", - "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableDescription.learnMoreLinkLabel": "詳細", - "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableDescription.optionNameLabel": "利用不可の場合スキップ", - "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableLabel": "利用不可の場合スキップ", - "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableResetLabel": "デフォルトにリセット", - "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableTitle": "リモートクラスターをオプションにする", - "xpack.remoteClusters.remoteClusterList.connectButtonLabel": "リモートクラスターを追加", - "xpack.remoteClusters.remoteClusterList.emptyPrompt.connectButtonLabel": "リモートクラスターを追加", - "xpack.remoteClusters.remoteClusterList.emptyPromptDescription": "リモートクラスターは、ローカルクラスターから他のクラスターへの一方行接続を作成します。", - "xpack.remoteClusters.remoteClusterList.emptyPromptTitle": "初めのリモートクラスターの追加", - "xpack.remoteClusters.remoteClusterList.loadingErrorTitle": "リモートクラスターの読み込み中にエラーが発生", - "xpack.remoteClusters.remoteClusterList.loadingTitle": "リモートクラスターを読み込み中", - "xpack.remoteClusters.remoteClusterList.noPermissionText": "リモートクラスターの表示または追加パーミッションがありません。", - "xpack.remoteClusters.remoteClusterList.noPermissionTitle": "パーミッションエラー", - "xpack.remoteClusters.remoteClusterList.table.actionBlockedDeleteDescription": "elasticsearch.yml で定義されたリモートクラスターは削除できません", - "xpack.remoteClusters.remoteClusterList.table.actionBlockedEditDescription": "elasticsearch.yml で定義されたリモートクラスターは編集できません", - "xpack.remoteClusters.remoteClusterList.table.actionDeleteDescription": "リモートクラスターを削除します", - "xpack.remoteClusters.remoteClusterList.table.actionEditDescription": "リモートクラスターを編集します", - "xpack.remoteClusters.remoteClusterList.table.actionsColumnTitle": "アクション", - "xpack.remoteClusters.remoteClusterList.table.connectedColumnTitle": "接続", - "xpack.remoteClusters.remoteClusterList.table.connectedNodesColumnTitle": "接続済みのノード", - "xpack.remoteClusters.remoteClusterList.table.isConfiguredByNodeMessage": "elasticsearch.yml で定義されています", - "xpack.remoteClusters.remoteClusterList.table.nameColumnTitle": "名前", - "xpack.remoteClusters.remoteClusterList.table.removeButtonLabel": "{count, plural, one {リモートクラスター} other {{count}リモートクラスター}}を削除", - "xpack.remoteClusters.remoteClusterList.table.seedsColumnTitle": "シード", - "xpack.remoteClusters.remoteClusterListTitle": "リモートクラスター", - "xpack.remoteClusters.removeAction.errorMultipleNotificationTitle": "「{count}」リモートクラスターの削除中にエラーが発生", - "xpack.remoteClusters.removeAction.errorSingleNotificationTitle": "リモートクラスター「{name}」の削除中にエラーが発生", - "xpack.remoteClusters.removeAction.successMultipleNotificationTitle": "{count} 個のリモートクラスターが削除されました", - "xpack.remoteClusters.removeAction.successSingleNotificationTitle": "リモートクラスター「{name}」が削除されました", - "xpack.remoteClusters.removeButton.confirmModal.cancelButtonText": "キャンセル", - "xpack.remoteClusters.removeButton.confirmModal.confirmButtonText": "削除", - "xpack.remoteClusters.removeButton.confirmModal.deleteSingleClusterTitle": "リモートクラスター「{name}」を削除しますか?", - "xpack.remoteClusters.removeButton.confirmModal.multipleDeletionDescription": "これらのリモートクラスターを削除しようとしています。", - "xpack.remoteClusters.removeButton.confirmModal.multipleDeletionTitle": "{count} 個のリモートクラスターを削除しますか?", - "xpack.remoteClusters.remoteClusterForm.hideRequestButtonLabel": "リクエストを非表示", - "xpack.remoteClusters.remoteClusterForm.inputLocalSeedErrorMessage": "「シードノード」フィールドが無効です。", - "xpack.remoteClusters.remoteClusterForm.inputNameErrorMessage": "「名前」フィールドが無効です。", - "xpack.remoteClusters.remoteClusterForm.inputSeedsErrorMessage": "「シードノード」フィールドが無効です。", - "xpack.remoteClusters.remoteClusterForm.showRequestButtonLabel": "リクエストを表示", - "xpack.remoteClusters.requestFlyout.closeButtonLabel": "閉じる", - "xpack.remoteClusters.requestFlyout.descriptionText": "この Elasticsearch リクエストは、このリモートクラスターを作成または更新します。", - "xpack.remoteClusters.requestFlyout.namedTitle": "「{name}」のリクエスト", - "xpack.remoteClusters.requestFlyout.unnamedTitle": "リクエスト", - "xpack.reporting.breadcrumb": "Reporting", - "xpack.reporting.dashboard.csvDownloadStartedMessage": "間もなく CSV がダウンロードされます。", - "xpack.reporting.dashboard.csvDownloadStartedTitle": "CSV のダウンロードが開始しました", - "xpack.reporting.dashboard.downloadCsvPanelTitle": "CSV をダウンロード", - "xpack.reporting.dashboard.failedCsvDownloadMessage": "現在 CSV を生成できません。", - "xpack.reporting.dashboard.failedCsvDownloadTitle": "CSV のダウンロードに失敗", - "xpack.reporting.errorButton.showReportErrorAriaLabel": "レポートエラーを表示", - "xpack.reporting.errorButton.unableToFetchReportContentTitle": "レポートのコンテンツを取得できません", - "xpack.reporting.errorButton.unableToGenerateReportTitle": "レポートを生成できません", - "xpack.reporting.exportTypes.csv_from_savedobject.executeJob.failedToDecryptReportJobDataErrorMessage": "レポートジョブデータの解読に失敗しました{encryptionKey} が設定されていることを確認してこのレポートを再生成してください。{err}", - "xpack.reporting.exportTypes.csv.executeJob.failedToDecryptReportJobDataErrorMessage": "レポートジョブデータの解読に失敗しました{encryptionKey} が設定されていることを確認してこのレポートを再生成してください。{err}", - "xpack.reporting.exportTypes.csv.hitIterator.expectedHitsErrorMessage": "次の Elasticsearch からの応答で期待される {hits}: {response}", - "xpack.reporting.exportTypes.csv.hitIterator.expectedScrollIdErrorMessage": "次の Elasticsearch からの応答で期待される {scrollId}: {response}", - "xpack.reporting.exportTypes.printablePdf.documentStreamIsNotgeneratedErrorMessage": "ドキュメントストリームが生成されていません。", - "xpack.reporting.exportTypes.printablePdf.logoDescription": "Elastic 提供", - "xpack.reporting.exportTypes.printablePdf.pagingDescription": "{pageCount} ページ中 {currentPage} ページ目", - "xpack.reporting.exportTypes.printablePdf.screenshots.unexpectedErrorMessage": "ページで予期せぬメッセージが発生しました: {toastHeaderText}", - "xpack.reporting.jobStatuses.cancelledText": "キャンセル済み", - "xpack.reporting.jobStatuses.completedText": "完了", - "xpack.reporting.jobStatuses.failedText": "失敗", - "xpack.reporting.jobStatuses.pendingText": "保留中", - "xpack.reporting.jobStatuses.processingText": "処理中", - "xpack.reporting.listing.reports.subtitle": "Kibana アプリケーションで生成されたレポートがここに表示されます", - "xpack.reporting.listing.reportstitle": "レポート", - "xpack.reporting.listing.table.downloadReportAriaLabel": "レポートをダウンロード", - "xpack.reporting.listing.table.loadingReportsDescription": "レポートを読み込み中です", - "xpack.reporting.listing.table.maxSizeReachedTooltip": "最大サイズに達成、部分データが含まれています。", - "xpack.reporting.listing.table.noCreatedReportsDescription": "レポートが作成されていません", - "xpack.reporting.listing.table.requestFailedErrorMessage": "リクエストに失敗しました", - "xpack.reporting.listing.tableColumns.actionsTitle": "アクション", - "xpack.reporting.listing.tableColumns.createdAtTitle": "作成日時:", - "xpack.reporting.listing.tableColumns.reportTitle": "レポート", - "xpack.reporting.listing.tableColumns.statusTitle": "ステータス", - "xpack.reporting.listing.tableValue.createdAtDetail.maxSizeReachedText": " - 最大サイズに達成", - "xpack.reporting.listing.tableValue.createdAtDetail.pendingStatusReachedText": "保留中 - ジョブの処理持ち", - "xpack.reporting.listing.tableValue.createdAtDetail.statusTimestampText": "{statusTimestamp} 時点で {statusLabel}", - "xpack.reporting.management.reportingTitle": "レポート", - "xpack.reporting.panelContent.copyUrlButtonLabel": "POST URL をコピー", - "xpack.reporting.panelContent.generateButtonLabel": "{reportingType} を生成", - "xpack.reporting.panelContent.generationTimeDescription": "{objectType} のサイズによって、{reportingType} の作成には数分かかる場合があります。", - "xpack.reporting.panelContent.howToCallGenerationDescription": "POST URL をコピーして Kibana 外または ウォッチャー から生成を実行することもできます。", - "xpack.reporting.panelContent.noPermissionToGenerateReportDescription": "このレポートを生成するパーミッションがありません。", - "xpack.reporting.panelContent.notification.cantReachServerDescription": "サーバーと通信できません。再試行してください。", - "xpack.reporting.panelContent.notification.reportingErrorTitle": "レポートエラー", - "xpack.reporting.panelContent.saveWorkDescription": "レポートの生成前に変更内容を保存してください。", - "xpack.reporting.panelContent.successfullyQueuedReportNotificationDescription": "管理で進捗を確認できます", - "xpack.reporting.panelContent.successfullyQueuedReportNotificationTitle": "{objectType} のレポートキュー", - "xpack.reporting.panelContent.whatCanBeExportedWarningDescription": "初めに変更内容を保存してください", - "xpack.reporting.panelContent.whatCanBeExportedWarningTitle": "保存された {objectType} のみエクスポートできます", - "xpack.reporting.pdfFooterImageDescription": "PDF のフッターに使用するカスタム画像です", - "xpack.reporting.pdfFooterImageLabel": "PDF フッター画像", - "xpack.reporting.registerFeature.reportingDescription": "ディスカバリ、可視化、ダッシュボードから生成されたレポートを管理します。", - "xpack.reporting.registerFeature.reportingTitle": "レポート", - "xpack.reporting.screenCapturePanelContent.optimizeForPrintingLabel": "印刷用に最適化", - "xpack.reporting.shareContextMenu.csvReportsButtonLabel": "CSV レポート", - "xpack.reporting.shareContextMenu.pdfReportsButtonLabel": "PDF レポート", - "xpack.rollupJobs.appTitle": "ロールアップジョブ", - "xpack.rollupJobs.checkLicense.errorExpiredMessage": "{licenseType} ライセンスが期限切れのため {pluginName} を使用できません", - "xpack.rollupJobs.checkLicense.errorUnavailableMessage": "現在ライセンス情報が利用できないため {pluginName} を使用できません。", - "xpack.rollupJobs.checkLicense.errorUnsupportedMessage": "ご使用の {licenseType} ライセンスは {pluginName} をサポートしていません。ライセンスをアップグレードしてください。", - "xpack.rollupJobs.create.backButton.label": "戻る", - "xpack.rollupJobs.create.dateTypeField": "日付", - "xpack.rollupJobs.create.errors.dateHistogramFieldMissing": "日付フィールドが必要です。", - "xpack.rollupJobs.create.errors.dateHistogramIntervalInvalidCalendarInterval": "「{unit}」単位には 1 の値しか使用できません。{suggestion} を試してみてください。", - "xpack.rollupJobs.create.errors.dateHistogramIntervalInvalidCalendarIntervalSuggestion": "1{unit}", - "xpack.rollupJobs.create.errors.dateHistogramIntervalInvalidFormat": "無効な間隔フォーマット。", - "xpack.rollupJobs.create.errors.dateHistogramIntervalMissing": "間隔が必要です。", - "xpack.rollupJobs.create.errors.histogramIntervalMissing": "これらのヒストグラムフィールドのロールアップには間隔が必要です。", - "xpack.rollupJobs.create.errors.histogramIntervalWholeNumber": "間隔は整数でなければなりません。", - "xpack.rollupJobs.create.errors.histogramIntervalZero": "間隔は 0 よりも大きい値でなければなりません。", - "xpack.rollupJobs.create.errors.idMissing": "名前が必要です。", - "xpack.rollupJobs.create.errors.indexPatternIllegalCharacters": "インデックスパターンから {characterList} を削除してください。", - "xpack.rollupJobs.create.errors.indexPatternMatchesRollupIndices": "インデックスパターンはロールアップインデックスと一致させることができません。", - "xpack.rollupJobs.create.errors.indexPatternMissing": "インデックスパターンが必要です。", - "xpack.rollupJobs.create.errors.indexPatternNoMatchingIndices": "インデックスパターンがどのインデックスとも一致していません。", - "xpack.rollupJobs.create.errors.indexPatternNoTimeFields": "インデックスパターンは時間フィールドを含むインデックスと一致している必要があります。", - "xpack.rollupJobs.create.errors.indexPatternSameAsRollupIndex": "インデックスパターンはロールアップインデックスと同じにできません。", - "xpack.rollupJobs.create.errors.indexPatternSpaces": "インデックスパターンからスペースを削除してください。", - "xpack.rollupJobs.create.errors.indexPatternValidationError": "インデックスパターンの検証中に問題が発生しました: {statusCode} {error}", - "xpack.rollupJobs.create.errors.indexPatternValidationFatalErrorTitle": "ロールアップジョブウィザード、インデックスパターンの検証", - "xpack.rollupJobs.create.errors.metricsTypesMissing": "これらのフィールドのメトリックタイプを選択するか、削除してください: {allMissingTypes}.", - "xpack.rollupJobs.create.errors.rollupCronMissing": "Cron パターンまたは基本間隔が必要です。", - "xpack.rollupJobs.create.errors.rollupDelayInvalidCalendarInterval": "「{unit}」単位には 1 の値しか使用できません。{suggestion} を試してみてください。", - "xpack.rollupJobs.create.errors.rollupDelayInvalidCalendarIntervalSuggestion": "1{unit}", - "xpack.rollupJobs.create.errors.rollupDelayInvalidFormat": "無効な遅延フォーマット。", - "xpack.rollupJobs.create.errors.rollupIndexBeginningPeriod": "インデックス名はピリオドで始めることができません。", - "xpack.rollupJobs.create.errors.rollupIndexCommas": "ロールアップインデックス名からコンマを削除してください。", - "xpack.rollupJobs.create.errors.rollupIndexIllegalCharacters": "ロールアップインデックス名から {characterList} を削除してください。", - "xpack.rollupJobs.create.errors.rollupIndexMissing": "ロールアップインデックスが必要です。", - "xpack.rollupJobs.create.errors.rollupIndexSameAsIndexPattern": "ロールアップインデックスはインデックスパターンと同じにできません。", - "xpack.rollupJobs.create.errors.rollupIndexSpaces": "ロールアップインデックス名からスペースを削除してください。", - "xpack.rollupJobs.create.errors.rollupPageSizeGreaterThanZero": "ページサイズは 0 よりも大きい値でなければなりません。", - "xpack.rollupJobs.create.errors.rollupPageSizeMissing": "ページサイズが必要です。", - "xpack.rollupJobs.create.jobDetails.tabHistogramLabel": "Histogram", - "xpack.rollupJobs.create.jobDetails.tabJsonLabel": "JSON", - "xpack.rollupJobs.create.jobDetails.tabMetricsLabel": "メトリック", - "xpack.rollupJobs.create.jobDetails.tabSummaryLabel": "概要", - "xpack.rollupJobs.create.jobDetails.tabTermsLabel": "用語", - "xpack.rollupJobs.create.keywordTypeField": "キーワード", - "xpack.rollupJobs.create.navigation.savingText": "保存中", - "xpack.rollupJobs.create.nextButton.label": "次へ", - "xpack.rollupJobs.create.numericTypeField": "数字", - "xpack.rollupJobs.create.saveButton.label": "保存", - "xpack.rollupJobs.create.stepDateHistogram.fieldDateFieldLabel": "日付フィールド", - "xpack.rollupJobs.create.stepDateHistogram.fieldDelay.helpExampleLabel": "値の例:30s、20m、24h、2d、1w、1M", - "xpack.rollupJobs.create.stepDateHistogram.fieldDelayLabel": "レイテンシバッファー (オプション)", - "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.helpExampleLabel": "サイズの例:1000ms、30s、20m、24h、2d、1w、1M、1y", - "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.preferFixedWarningDayLabel": "1d の代わりに 24h を使うことをお勧めします。そうすることでより柔軟なクエリが可能になります。", - "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.preferFixedWarningHourLabel": "1h の代わりに 60m を使うことをお勧めします。そうすることでより柔軟なクエリが可能になります。", - "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.preferFixedWarningMonthLabel": "M ではなく d 単位の使用をお勧めします。そうすることでより柔軟なクエリが可能です。", - "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.preferFixedWarningWeekLabel": "w ではなく d 単位の使用をお勧めします。そうすることでより柔軟なクエリが可能になります。", - "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.preferFixedWarningYearLabel": "y ではなく d 単位の使用をお勧めします。そうすることでより柔軟なクエリが可能になります。", - "xpack.rollupJobs.create.stepDateHistogram.fieldIntervalLabel": "時間バケットサイズ", - "xpack.rollupJobs.create.stepDateHistogram.fieldTimeZoneLabel": "タイムゾーン", - "xpack.rollupJobs.create.stepDateHistogram.readDocsButtonLabel": "日付ヒストグラムドキュメント", - "xpack.rollupJobs.create.stepDateHistogram.sectionDataSourceDescription": "小さな時間バケットはそれに比例しより多くのスペースを使用します。", - "xpack.rollupJobs.create.stepDateHistogramDescription": "ロールアップデータでの {link} のオペレーションを定義してください。", - "xpack.rollupJobs.create.stepDateHistogramDescription.aggregationsLinkLabel": "日付ヒストグラムの集約", - "xpack.rollupJobs.create.stepDateHistogramTitle": "Date histogram", - "xpack.rollupJobs.create.stepErrorTitle": "続行する前にエラーを修正してください", - "xpack.rollupJobs.create.stepHistogram.fieldHistogramIntervalLabel": "間隔", - "xpack.rollupJobs.create.stepHistogram.fieldsChooserLabel": "ヒストグラムフィールドを追加", - "xpack.rollupJobs.create.stepHistogram.histogramDescription": "数字の間隔でバケットするフィールドを選択してください。", - "xpack.rollupJobs.create.stepHistogram.readDocsButtonLabel": "ヒストグラムドキュメント", - "xpack.rollupJobs.create.stepHistogram.sectionHistogramIntervalDescription": "これはロールアップ時にヒストグラムバケットが作成される間隔です (例: 5 に設定すると 5 単位 (0-5、5-10 など) のバケットが作成されます)。ヒストグラムグループに対し1 つの間隔しか指定できないため、ヒストグラムでグループ分けされているフィールドには同じ間隔が適用されます。", - "xpack.rollupJobs.create.stepHistogram.sectionHistogramIntervalTitle": "ヒストグラムの間隔", - "xpack.rollupJobs.create.stepHistogramTitle": "ヒストグラム (オプション)", - "xpack.rollupJobs.create.stepLogistics.fieldCron.helpReferenceLinkLabel": "Cron expression の詳細", - "xpack.rollupJobs.create.stepLogistics.fieldCronLabel": "Cron expression", - "xpack.rollupJobs.create.stepLogistics.fieldIdLabel": "名前", - "xpack.rollupJobs.create.stepLogistics.fieldIndexPattern.helpAllowLabel": "複数インデックスの一致にワイルドカード ({asterisk}) を使用。", - "xpack.rollupJobs.create.stepLogistics.fieldIndexPattern.helpDisallowLabel": "スペースと {characterList} は使用できません。", - "xpack.rollupJobs.create.stepLogistics.fieldIndexPattern.helpHasMatchesLabel": "成功!インデックスパターンに一致するインデックスがあります。", - "xpack.rollupJobs.create.stepLogistics.fieldIndexPattern.helpMustMatchLabel": "インデックスパターンは、最低 1 つのロールアップ以外のインデックスと一致している必要があります。", - "xpack.rollupJobs.create.stepLogistics.fieldIndexPattern.helpSearchingLabel": "一致するインデックスを検索中…", - "xpack.rollupJobs.create.stepLogistics.fieldIndexPatternLabel": "インデックスパターン", - "xpack.rollupJobs.create.stepLogistics.fieldPageSizeLabel": "ページサイズ", - "xpack.rollupJobs.create.stepLogistics.fieldRollupIndex.helpDisallowLabel": "スペース、コンマ、{characterList} は使用できません。", - "xpack.rollupJobs.create.stepLogistics.fieldRollupIndexLabel": "ロールアップインデックス名", - "xpack.rollupJobs.create.stepLogistics.logisticsDescription": "ロールアップジョブの実行方法とドキュメントのインデックスのタイミングを定義します。", - "xpack.rollupJobs.create.stepLogistics.readDocsButtonLabel": "ロジスティクスドキュメント", - "xpack.rollupJobs.create.stepLogistics.sectionDataFlowDescription": "どのインデックスをロールアップし、いつデータを格納しますか?", - "xpack.rollupJobs.create.stepLogistics.sectionDataFlowTitle": "データフロー", - "xpack.rollupJobs.create.stepLogistics.sectionDelayDescription": "レイテンシバッファーは、データのロールアップを遅らせます。これにより様々な投入レイテンシが可能になり、より忠実性の高いロールアップとなります。デフォルトで、ロールアップジョブは利用可能なすべてのデータのロールアップを試みます。", - "xpack.rollupJobs.create.stepLogistics.sectionDelayTitle": "ロールアップジョブは新しいデータをロールアップするまでどのくらい待ちますか?", - "xpack.rollupJobs.create.stepLogistics.sectionIdDescription": "この名前はロールアップジョブの固有の識別子として使用されます。", - "xpack.rollupJobs.create.stepLogistics.sectionIdTitle": "名前", - "xpack.rollupJobs.create.stepLogistics.sectionPageSizeDescription": "ページサイズが大きいとデータのロールアップが速くなりますが、より多くのメモリーを必要とします。", - "xpack.rollupJobs.create.stepLogistics.sectionPageSizeTitle": "一度にいくつのドキュメントをロールアップしますか?", - "xpack.rollupJobs.create.stepLogistics.sectionSchedule.buttonAdvancedLabel": "Cron expression を作成", - "xpack.rollupJobs.create.stepLogistics.sectionSchedule.buttonBasicLabel": "基本間隔を作成", - "xpack.rollupJobs.create.stepLogistics.sectionScheduleDescription": "データをどの程度の頻度でロールアップしますか?", - "xpack.rollupJobs.create.stepLogistics.sectionScheduleTitle": "スケジュール", - "xpack.rollupJobs.create.stepLogisticsTitle": "ロジスティクス", - "xpack.rollupJobs.create.stepMetrics.checkboxAverageLabel": "平均", - "xpack.rollupJobs.create.stepMetrics.checkboxMaxLabel": "最高", - "xpack.rollupJobs.create.stepMetrics.checkboxMinLabel": "最低", - "xpack.rollupJobs.create.stepMetrics.checkboxSumLabel": "合計", - "xpack.rollupJobs.create.stepMetrics.checkboxValueCountLabel": "値カウント", - "xpack.rollupJobs.create.stepMetrics.fieldsChooserLabel": "メトリックフィールドを追加", - "xpack.rollupJobs.create.stepMetrics.readDocsButtonLabel": "メトリックドキュメント", - "xpack.rollupJobs.create.stepMetricsDescription": "データのロールアップ時に収集するメトリックを選択します。デフォルトでは各グループの doc_counts のみが収集されます。", - "xpack.rollupJobs.create.stepMetricsTitle": "メトリック (オプション)", - "xpack.rollupJobs.create.stepReviewTitle": "「{jobId}」の詳細の確認", - "xpack.rollupJobs.create.steps.stepDateHistogramTitle": "Date histogram", - "xpack.rollupJobs.create.steps.stepHistogramTitle": "Histogram", - "xpack.rollupJobs.create.steps.stepLogisticsTitle": "ロジスティクス", - "xpack.rollupJobs.create.steps.stepMetricsTitle": "メトリック", - "xpack.rollupJobs.create.steps.stepReviewTitle": "確認して保存", - "xpack.rollupJobs.create.steps.stepTermsTitle": "用語", - "xpack.rollupJobs.create.stepTerms.fieldsChooserLabel": "アイテムフィールドを追加", - "xpack.rollupJobs.create.stepTerms.readDocsButtonLabel": "用語ドキュメント", - "xpack.rollupJobs.create.stepTermsDescription": "用語集約でバケットするフィールドを選択してください。IP アドレスなどの基数の高いフィールドで時間バケットが限られている場合、コストが高くなる可能性があります。", - "xpack.rollupJobs.create.stepTermsTitle": "用語 (オプション)", - "xpack.rollupJobs.createAction.errorTitle": "ロールアップジョブの作成中にエラーが発生", - "xpack.rollupJobs.createAction.failedDefaultErrorMessage": "{statusCode} エラーでリクエスト失敗: {message}", - "xpack.rollupJobs.createAction.jobIdAlreadyExistsErrorMessage": "ID「{jobConfigId}」のジョブが既に存在します。", - "xpack.rollupJobs.createBreadcrumbTitle": "作成", - "xpack.rollupJobs.createTitle": "ロールアップジョブを作成", - "xpack.rollupJobs.deleteAction.errorTitle": "ロールアップジョブの削除中にエラーが発生", - "xpack.rollupJobs.deleteAction.successMultipleNotificationTitle": "{count} 件のロールアップジョブが削除されました", - "xpack.rollupJobs.deleteAction.successSingleNotificationTitle": "ロールアップジョブ「{jobId}」が削除されました", - "xpack.rollupJobs.detailPanel.jobActionMenu.buttonLabel": "管理", - "xpack.rollupJobs.detailPanel.loadingLabel": "ロールアップジョブを読み込み中…", - "xpack.rollupJobs.detailPanel.notFoundLabel": "ロールアップジョブが見つかりません", - "xpack.rollupJobs.editorConfig.dateHistogram.customInterval.helpText": "ロールアップ構成の間隔の倍数でなければなりません: {interval}", - "xpack.rollupJobs.editorConfig.histogram.interval.helpText": "ロールアップ構成の間隔の倍数でなければなりません: {interval}", - "xpack.rollupJobs.editRollupIndexPattern.createIndex.defaultButtonDescription": "要約データに制限された集約を実行します。", - "xpack.rollupJobs.editRollupIndexPattern.createIndex.defaultButtonText": "ロールアップインデックスパターン", - "xpack.rollupJobs.editRollupIndexPattern.createIndex.defaultTypeName": "ロールアップインデックスパターン", - "xpack.rollupJobs.editRollupIndexPattern.createIndex.indexLabel": "ロールアップ", - "xpack.rollupJobs.editRollupIndexPattern.createIndex.noMatchError": "ロールアップインデックスパターンエラー: ロールアップインデックスの 1 つと一致している必要があります", - "xpack.rollupJobs.editRollupIndexPattern.createIndex.tooManyMatchesError": "ロールアップインデックスパターンエラー: 一致できるロールアップインデックスは 1 つだけです", - "xpack.rollupJobs.editRollupIndexPattern.createIndex.uncaughtError": "ロールアップインデックスパターンエラー: {error}", - "xpack.rollupJobs.featureCatalogueDescription": "今後の分析用に履歴データを小さなインデックスに要約して格納します。", - "xpack.rollupJobs.indexMgmtBadge.rollupLabel": "ロールアップ", - "xpack.rollupJobs.indexMgmtToggle.toggleLabel": "ロールアップインデックスを含める", - "xpack.rollupJobs.jobActionMenu.buttonLabel": "{jobCount, plural, one {ジョブ} other {件のジョブ}}の管理", - "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.cancelButtonText": "キャンセル", - "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.confirmButtonText": "削除", - "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.deleteSingleJobDescription": "このジョブは開始しました。", - "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.deleteSingleJobTitle": "ロールアップジョブ「{id}」を削除しますか?", - "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.multipleDeletionDescription": "{isSingleSelection, plural, one {このジョブ} other {これらのジョブ}}を削除しようとしています", - "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.multipleDeletionTitle": "{count} 件のロールアップジョブを削除しますか?", - "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.startedMessage": "開始済み", - "xpack.rollupJobs.jobActionMenu.deleteJobLabel": "{isSingleSelection, plural, one {ジョブ} other {件のジョブ}}を削除", - "xpack.rollupJobs.jobActionMenu.jobActionMenuButtonAriaLabel": "ジョブオプション", - "xpack.rollupJobs.jobActionMenu.panelTitle": "ジョブオプション", - "xpack.rollupJobs.jobActionMenu.startJobLabel": "{isSingleSelection, plural, one {ジョブ} other {件のジョブ}}を開始", - "xpack.rollupJobs.jobActionMenu.stopJobLabel": "{isSingleSelection, plural, one {ジョブ} other {件のジョブ}}を停止", - "xpack.rollupJobs.jobActionMenu.updatingText": "更新中", - "xpack.rollupJobs.jobDetails.tabHistogram.intervalLabel": "ヒストグラムの間隔", - "xpack.rollupJobs.jobDetails.tabHistogram.nameColumnLabel": "フィールド", - "xpack.rollupJobs.jobDetails.tabMetrics.nameColumnLabel": "フィールド", - "xpack.rollupJobs.jobDetails.tabMetrics.typesColumnLabel": "タイプ", - "xpack.rollupJobs.jobDetails.tabSummary.itemCronLabel": "Cron", - "xpack.rollupJobs.jobDetails.tabSummary.itemCronTip": "データをロールアップする頻度です", - "xpack.rollupJobs.jobDetails.tabSummary.itemDelay.none": "なし", - "xpack.rollupJobs.jobDetails.tabSummary.itemDelayLabel": "遅延", - "xpack.rollupJobs.jobDetails.tabSummary.itemDocumentsProcessedLabel": "処理されたドキュメント", - "xpack.rollupJobs.jobDetails.tabSummary.itemIndexPatternLabel": "インデックスパターン", - "xpack.rollupJobs.jobDetails.tabSummary.itemIntervalLabel": "間隔", - "xpack.rollupJobs.jobDetails.tabSummary.itemIntervalTip": "データがロールアップされる時間バケットの間隔です", - "xpack.rollupJobs.jobDetails.tabSummary.itemPagesProcessedLabel": "処理されたページ", - "xpack.rollupJobs.jobDetails.tabSummary.itemRollupIndexLabel": "ロールアップインデックス", - "xpack.rollupJobs.jobDetails.tabSummary.itemRollupsIndexedLabel": "インデックスされたロールアップ", - "xpack.rollupJobs.jobDetails.tabSummary.itemTimeFieldLabel": "時間フィールド", - "xpack.rollupJobs.jobDetails.tabSummary.itemTimezoneLabel": "タイムゾーン", - "xpack.rollupJobs.jobDetails.tabSummary.itemTriggerCountLabel": "トリガーカウント", - "xpack.rollupJobs.jobDetails.tabSummary.sectionDateHistogramLabel": "Date histogram", - "xpack.rollupJobs.jobDetails.tabSummary.sectionLogisticsLabel": "ロジスティクス", - "xpack.rollupJobs.jobDetails.tabSummary.sectionStatsTitle": "統計", - "xpack.rollupJobs.jobList.createButtonLabel": "ロールアップジョブを作成", - "xpack.rollupJobs.jobList.emptyPrompt.createButtonLabel": "ロールアップジョブの作成", - "xpack.rollupJobs.jobList.emptyPromptDescription": "ロールアップジョブは、今後の分析用に履歴データを小さなインデックスに要約して格納します。", - "xpack.rollupJobs.jobList.emptyPromptTitle": "初めてのロールアップジョブの作成", - "xpack.rollupJobs.jobList.loadingErrorTitle": "ロールアップジョブを読み込み中にエラーが発生", - "xpack.rollupJobs.jobList.loadingTitle": "ロールアップジョブを読み込み中…", - "xpack.rollupJobs.jobList.noPermissionText": "ロールアップジョブの表示または追加パーミッションがありません。", - "xpack.rollupJobs.jobList.noPermissionTitle": "パーミッションエラー", - "xpack.rollupJobs.jobListTitle": "ロールアップジョブ", - "xpack.rollupJobs.jobStatus.abortingLabel": "中断中", - "xpack.rollupJobs.jobStatus.indexingLabel": "インデックス", - "xpack.rollupJobs.jobStatus.startedLabel": "開始済み", - "xpack.rollupJobs.jobStatus.stoppedLabel": "停止中", - "xpack.rollupJobs.jobTable.headers.delayHeader": "遅延", - "xpack.rollupJobs.jobTable.headers.groupsHeader": "グループ", - "xpack.rollupJobs.jobTable.headers.indexPatternHeader": "インデックスパターン", - "xpack.rollupJobs.jobTable.headers.intervalHeader": "間隔", - "xpack.rollupJobs.jobTable.headers.metricsHeader": "メトリック", - "xpack.rollupJobs.jobTable.headers.nameHeader": "ID", - "xpack.rollupJobs.jobTable.headers.rollupIndexHeader": "ロールアップインデックス", - "xpack.rollupJobs.jobTable.headers.statusHeader": "ステータス", - "xpack.rollupJobs.jobTable.noJobsMatchSearchMessage": "検索条件に一致するロールアップジョブがありません", - "xpack.rollupJobs.jobTable.searchInputPlaceholder": "検索", - "xpack.rollupJobs.listBreadcrumbTitle": "ロールアップジョブ", - "xpack.rollupJobs.loadAction.errorTitle": "ロールアップジョブを読み込み中にエラーが発生", - "xpack.rollupJobs.refreshAction.errorTitle": "ロールアップジョブの更新中にエラーが発生", - "xpack.rollupJobs.rollupIndexPatternsDescription": "ロールアップインデックスを捕捉するインデックスパターンの作成を有効にします。\n それによりロールアップデータに基づくビジュアライゼーションが可能になります。更新\n 変更を適用するにはページ。", - "xpack.rollupJobs.rollupIndexPatternsTitle": "ロールアップインデックスパターンを有効にする", - "xpack.rollupJobs.startJobsAction.errorTitle": "ロールアップジョブの開始中にエラーが発生", - "xpack.rollupJobs.stopJobsAction.errorTitle": "ロールアップジョブの停止中にエラーが発生", - "xpack.rollupJobs.create.errors.idSameAsCloned": "名前はクローン名「{clonedId}」と同じにできません。", - "xpack.rollupJobs.create.jobDetails.tabRequestLabel": "リクエスト", - "xpack.rollupJobs.create.startJobLabel": "今すぐジョブを開始", - "xpack.rollupJobs.create.stepMetrics.allCheckbox": "すべて", - "xpack.rollupJobs.create.stepMetrics.emptyListLabel": "メトリックフィールドが追加されていません", - "xpack.rollupJobs.create.stepMetrics.fieldColumnLabel": "フィールド", - "xpack.rollupJobs.create.stepMetrics.metricsColumnHeader": "メトリック", - "xpack.rollupJobs.create.stepMetrics.selectAllPopoverButtonLabel": "メトリックを選択", - "xpack.rollupJobs.create.stepMetrics.selectAllRowLabel": "すべて", - "xpack.rollupJobs.create.stepMetrics.typeColumnLabel": "タイプ", - "xpack.rollupJobs.jobActionMenu.cloneJobLabel": "ジョブのクローンを作成します", - "xpack.rollupJobs.jobDetails.tabRequest.descriptionText": "この Elasticsearch リクエストは、このロールアップジョブを作成します。", - "xpack.rollupJobs.jobStatus.stoppingLabel": "停止中", - "xpack.rollupJobs.jobStatus.unknownLabel": "不明", - "xpack.searchProfiler.aggregationProfileTabTitle": "集約プロフィール", - "xpack.searchProfiler.basicLicenseTitle": "ベーシック", - "xpack.searchProfiler.formIndexLabel": "インデックス", - "xpack.searchProfiler.formProfileButtonLabel": "プロフィール", - "xpack.searchProfiler.goldLicenseTitle": "ゴールド", - "xpack.searchProfiler.highlightDetails.descriptionTitle": "説明", - "xpack.searchProfiler.highlightDetails.selfTimeTitle": "セルフタイム", - "xpack.searchProfiler.highlightDetails.selfTimeTooltip": "子を除き、このクエリコンポーネントだけに使用された時間です", - "xpack.searchProfiler.highlightDetails.timingBreakdownTitle": "時間の内訳", - "xpack.searchProfiler.highlightDetails.totalTimeTitle": "合計時間", - "xpack.searchProfiler.highlightDetails.totalTimeTooltip": "子を除き、このクエリコンポーネントだけに使用された合計時間です", - "xpack.searchProfiler.highlightDetails.typeTitle": "タイプ", - "xpack.searchProfiler.licenseErrorMessageDescription": "さらに可視化するには有効なライセンス ({licenseTypeList} または {platinumLicenseType}), が必要ですが、クラスターに見つかりませんでした。", - "xpack.searchProfiler.licenseErrorMessageTitle": "ライセンスエラー", - "xpack.searchProfiler.licenseHasExpiredMessage": "検索プロフィールを利用できません。ライセンスが期限切れです。", - "xpack.searchProfiler.pageDisplayName": "検索プロファイラー", - "xpack.searchProfiler.platinumLicenseTitle": "プラチナ", - "xpack.searchProfiler.profileTree.cumulativeTimeTitle": "累積時間:", - "xpack.searchProfiler.profileTree.cumulativeTimeTooltip": "インデックス内のすべてのシャードの累積時間です。注: シャードは並行実行が可能なため、実時間ではありません。", - "xpack.searchProfiler.profileTree.header.selfTimeTitle": "セルフタイム", - "xpack.searchProfiler.profileTree.header.totalTimeTitle": "合計時間", - "xpack.searchProfiler.profileTree.header.typeTitle": "タイプと説明", - "xpack.searchProfiler.profileTree.indexTitle": "インデックス", - "xpack.searchProfiler.queryProfileTabTitle": "クエリプロフィール", - "xpack.searchProfiler.registerLicenseDescription": "検索プロファイラーの使用を続けるには、{registerLicenseLink}してください", - "xpack.searchProfiler.registerLicenseLinkLabel": "ライセンスを登録", - "xpack.searchProfiler.registryProviderDescription": "Elasticsearch クエリのパフォーマンスを素早く確認します.", - "xpack.searchProfiler.registryProviderTitle": "検索プロファイラー", - "xpack.searchProfiler.trialLicenseTitle": "トライアル", - "xpack.searchProfiler.unavailableLicenseInformationMessage": "検索プロファイラーを利用できません。現在ライセンス情報が利用できません。", - "xpack.searchProfiler.upgradeLicenseMessage": "現在の {licenseInfo} ライセンスでは検索プロファイラーを利用できません。ライセンスをアップグレードしてください。", - "xpack.searchProfiler.errorToastTitle": "JSON 解析エラー", - "xpack.security.account.breadcrumb": "アカウント管理", - "xpack.security.account.changePasswordDescription": "アカウントのパスワードを変更します。", - "xpack.security.account.changePasswordForm.cancelButtonLabel": "リセット", - "xpack.security.account.changePasswordForm.confirmPasswordLabel": "新しいパスワードの再入力", - "xpack.security.account.changePasswordForm.currentPasswordLabel": "現在のパスワード", - "xpack.security.account.changePasswordForm.invalidPassword": "現在のパスワードが正しくありません。", - "xpack.security.account.changePasswordForm.newPasswordLabel": "新しいパスワード", - "xpack.security.account.changePasswordForm.passwordRequirements": "6 文字以上使用してください。", - "xpack.security.account.changePasswordForm.saveChangesButtonLabel": "パスワードを変更", - "xpack.security.account.changePasswordNotSupportedText": "このアカウントのパスワードは変更できません。", - "xpack.security.account.changePasswordSuccess": "パスワードが変更されました。", - "xpack.security.account.changePasswordTitle": "パスワード", - "xpack.security.account.currentPasswordRequired": "現在のパスワードが必要です。", - "xpack.security.account.noEmailMessage": "メールアドレスがありません", - "xpack.security.account.passwordLengthDescription": "パスワードが短すぎます。", - "xpack.security.account.passwordsDoNotMatch": "パスワードが一致していません。", - "xpack.security.account.usernameGroupDescription": "この情報は変更できません。", - "xpack.security.account.usernameGroupTitle": "ユーザー名とメールアドレス", - "xpack.security.components.sessionIdleTimeoutWarning.okButtonText": "OK", - "xpack.security.components.sessionIdleTimeoutWarning.title": "警告", - "xpack.security.loggedOut.login": "ログイン", - "xpack.security.loggedOut.title": "ログアウト完了", - "xpack.security.login.basicLoginForm.invalidUsernameOrPasswordErrorMessage": "無効なユーザー名またはパスワード再試行してください。", - "xpack.security.login.basicLoginForm.logInButtonLabel": "ログイン", - "xpack.security.login.basicLoginForm.passwordFormRowLabel": "パスワード", - "xpack.security.login.basicLoginForm.unknownErrorMessage": "おっと!エラー。再試行してください。", - "xpack.security.login.basicLoginForm.usernameFormRowLabel": "ユーザー名", - "xpack.security.login.loggedOutDescription": "Kibana からログアウトしました。", - "xpack.security.login.sessionExpiredDescription": "セッションがタイムアウトしました。再試行してください。", - "xpack.security.loginPage.esUnavailableMessage": "詳細は Kibana ログを確認し、このページを再度読み込んでみてください。", - "xpack.security.loginPage.esUnavailableTitle": "Elasticsearch クラスターに接続できません", - "xpack.security.loginPage.requiresSecureConnectionMessage": "システム管理者にお問い合わせください。", - "xpack.security.loginPage.requiresSecureConnectionTitle": "ログインにはセキュアな接続が必要です", - "xpack.security.loginPage.unknownLayoutMessage": "詳細は Kibana ログを確認し、ページを更新して再試行してください。", - "xpack.security.loginPage.unknownLayoutTitle": "サポートされていないログインフォームレイアウト。", - "xpack.security.loginPage.welcomeDescription": "Elastic Stack への入口", - "xpack.security.loginPage.welcomeTitle": "Kibana へようこそ", - "xpack.security.loginPage.xpackUnavailableMessage": "この Kibana ディストリビューションの無料の機能をすべて使用するには、デフォルトの Elasticsearch をアップデートしてください。", - "xpack.security.loginPage.xpackUnavailableTitle": "現在 Kibana に構成されている Elasticsearch クラスターへの接続をキャンセルします。", - "xpack.security.management.changePasswordForm.cancelButtonLabel": "キャンセル", - "xpack.security.management.changePasswordForm.changePasswordLinkLabel": "パスワードを変更", - "xpack.security.management.changePasswordForm.confirmPasswordLabel": "パスワードの確認", - "xpack.security.management.changePasswordForm.currentPasswordLabel": "現在のパスワード", - "xpack.security.management.changePasswordForm.incorrectPasswordDescription": "入力された現在のパスワードが正しくありません。", - "xpack.security.management.changePasswordForm.newPasswordLabel": "新しいパスワード", - "xpack.security.management.changePasswordForm.passwordDontMatchDescription": "パスワードが一致しません", - "xpack.security.management.changePasswordForm.passwordLabel": "パスワード", - "xpack.security.management.changePasswordForm.passwordLengthDescription": "パスワードは最低 6 文字必要です", - "xpack.security.management.changePasswordForm.saveChangesButtonLabel": "変更を保存", - "xpack.security.management.changePasswordForm.updateAndRestartKibanaDescription": "Kibana ユーザーのパスワードを変更後、kibana.yml ファイルを更新し Kibana を再起動する必要があります。", - "xpack.security.management.editRole.cancelButtonLabel": "キャンセル", - "xpack.security.management.editRole.changeAllPrivilegesLink": "(すべて変更)", - "xpack.security.management.editRole.collapsiblePanel.hideLinkText": "非表示", - "xpack.security.management.editRole.collapsiblePanel.showLinkText": "表示", - "xpack.security.management.editRole.createRoleText": "ロールを作成", - "xpack.security.management.editRole.createRoleTitle": "ロールを作成", - "xpack.security.management.editRole.deleteRoleButton.cancelButtonLabel": "いいえ、削除しません", - "xpack.security.management.editRole.deleteRoleButton.confirmButtonLabel": "はい、削除します", - "xpack.security.management.editRole.deleteRoleButton.deleteRoleButtonLabel": "ロールを削除", - "xpack.security.management.editRole.deleteRoleButton.deleteRoleTitle": "ロールの削除", - "xpack.security.management.editRole.deleteRoleButton.deletingRoleConfirmationText": "このロールを削除してよろしいですか?", - "xpack.security.management.editRole.deleteRoleButton.deletingRoleWarningText": "この操作は元に戻すことができません!", - "xpack.security.management.editRole.editRoleTitle": "ロールの編集", - "xpack.security.management.editRole.elasticSearchPrivileges.addIndexPrivilegesButtonLabel": "インデックスの権限を追加", - "xpack.security.management.editRole.elasticSearchPrivileges.addUserTitle": "ユーザーの追加…", - "xpack.security.management.editRole.elasticSearchPrivileges.clusterPrivilegesTitle": "クラスターの権限", - "xpack.security.management.editRole.elasticSearchPrivileges.controlAccessToClusterDataDescription": "クラスターのデータへのアクセスを管理します。", - "xpack.security.management.editRole.elasticSearchPrivileges.howToBeSubmittedOnBehalfOfOtherUsersDescription": "他のユーザーの代理でのリクエストの送信を許可します。", - "xpack.security.management.editRole.elasticSearchPrivileges.indexPrivilegesTitle": "インデックスの権限", - "xpack.security.management.editRole.elasticSearchPrivileges.learnMoreLinkText": "詳細", - "xpack.security.management.editRole.elasticSearchPrivileges.manageRoleActionsDescription": "このロールがクラスターに対して実行できる操作を管理します。", - "xpack.security.management.editRole.elasticSearchPrivileges.runAsPrivilegesTitle": "権限として実行", - "xpack.security.management.editRole.featureTable.enabledRoleFeaturesEnabledColumnTitle": "権限", - "xpack.security.management.editRole.featureTable.enabledRoleFeaturesFeatureColumnTitle": "機能", - "xpack.security.management.editRole.indexPrivilegeForm.deleteSpacePrivilegeAriaLabel": "インデックスの権限を削除", - "xpack.security.management.editRole.indexPrivilegeForm.grantedDocumentsQueryFormRowLabel": "提供されたドキュメントのクエリ", - "xpack.security.management.editRole.indexPrivilegeForm.grantReadPrivilegesLabel": "特定のドキュメントの読み込み権限を提供", - "xpack.security.management.editRole.indexPrivilegeForm.indicesFormRowLabel": "インデックス", - "xpack.security.management.editRole.indexPrivilegeForm.privilegesFormRowLabel": "権限", - "xpack.security.management.editRole.modifyingReversedRolesDescription": "リザーブされたロールはビルトインのため削除または変更できません。", - "xpack.security.management.editRole.returnToRoleListButtonLabel": "ロールリストに戻る", - "xpack.security.management.editRole.reversedRoleBadge.reservedRolesCanNotBeModifiedTooltip": "リザーブされたロールはビルトインのため削除または変更できません。", - "xpack.security.management.editRole.roleNameFormRowHelpText": "ロール名は作成後変更できません。", - "xpack.security.management.editRole.roleNameFormRowTitle": "ロール名", - "xpack.security.management.editRole.roleSuccessfullyDeletedNotificationMessage": "ロールを削除しました", - "xpack.security.management.editRole.roleSuccessfullySavedNotificationMessage": "ロールを保存しました", - "xpack.security.management.editRole.setPrivilegesToKibanaDescription": "Elasticsearch データの権限を設定し、Kibana へのアクセスを管理します。", - "xpack.security.management.editRole.setPrivilegesToKibanaSpacesDescription": "Elasticsearch データの権限を設定し、Kibana スペースへのアクセスを管理します。", - "xpack.security.management.editRole.simplePrivilegeForm.allPrivilegeDropdown": "すべて", - "xpack.security.management.editRole.simplePrivilegeForm.allPrivilegeDropdownDescription": "Kibana 全体への完全アクセスを許可します", - "xpack.security.management.editRole.simplePrivilegeForm.allPrivilegeInput": "すべて", - "xpack.security.management.editRole.simplePrivilegeForm.customPrivilegeDropdown": "カスタム", - "xpack.security.management.editRole.simplePrivilegeForm.customPrivilegeDropdownDescription": "Kibana へのアクセスをカスタマイズします", - "xpack.security.management.editRole.simplePrivilegeForm.customPrivilegeInput": "カスタム", - "xpack.security.management.editRole.simplePrivilegeForm.kibanaPrivilegesTitle": "Kibana の権限", - "xpack.security.management.editRole.simplePrivilegeForm.noPrivilegeDropdown": "なし", - "xpack.security.management.editRole.simplePrivilegeForm.noPrivilegeDropdownDescription": "Kibana へのアクセス不可", - "xpack.security.management.editRole.simplePrivilegeForm.noPrivilegeInput": "なし", - "xpack.security.management.editRole.simplePrivilegeForm.readPrivilegeDropdown": "読み込み", - "xpack.security.management.editRole.simplePrivilegeForm.readPrivilegeDropdownDescription": "Kibana 全体への読み込み専用アクセスを許可します", - "xpack.security.management.editRole.simplePrivilegeForm.readPrivilegeInput": "読み込み", - "xpack.security.management.editRole.simplePrivilegeForm.specifyPrivilegeForRoleDescription": "このロールの Kibana の権限を指定します。", - "xpack.security.management.editRole.simplePrivilegeForm.unsupportedSpacePrivilegesWarning": "このロールはスペースへの権限が定義されていますが、Kibana でスペースが有効ではありません。このロールを保存するとこれらの権限が削除されます。", - "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.effectivePrivilegeMessage": "{source} で許可されています。", - "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.globalBasePrivilegeSource": "グローバルベース権限", - "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.globalFeaturePrivilegeSource": "グローバル機能権限", - "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.privilegeSupercededMessage": "{supersededPrivilege} のオリジナルの権限は {actualPrivilegeSource} により上書きされています", - "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.spaceBasePrivilegeSource": "スペースベース権限", - "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.spaceFeaturePrivilegeSource": "スペース機能権限", - "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.unknownPrivilegeSource": "**不明**", - "xpack.security.management.editRole.spaceAwarePrivilegeForm.ensureAccountHasAllPrivilegesGrantedDescription": "{kibanaUser} ロールによりアカウントにすべての権限が提供されていることを確認し、再試行してください。", - "xpack.security.management.editRole.spaceAwarePrivilegeForm.globalSpacesName": "* グローバル (すべてのスペース)", - "xpack.security.management.editRole.spaceAwarePrivilegeForm.howToViewAllAvailableSpacesDescription": "利用可能なすべてのスペースを表示する権限がありません。", - "xpack.security.management.editRole.spaceAwarePrivilegeForm.insufficientPrivilegesDescription": "権限が不十分です", - "xpack.security.management.editRole.spaceAwarePrivilegeForm.kibanaUserTitle": "kibana_user", - "xpack.security.management.editRole.spacePrivilegeForm.allPrivilegeDetails": "選択されたスペースの全機能への完全アクセスを許可します。", - "xpack.security.management.editRole.spacePrivilegeForm.allPrivilegeDisplay": "すべて", - "xpack.security.management.editRole.spacePrivilegeForm.allPrivilegeDropdownDisplay": "すべて", - "xpack.security.management.editRole.spacePrivilegeForm.customizeFeaturePrivilegeDescription": "機能ごとに権限のレベルを上げます。機能によってはスペースごとに非表示になっているか、グローバルスペース権限による影響を受けているものもあります。", - "xpack.security.management.editRole.spacePrivilegeForm.customizeFeaturePrivileges": "機能ごとにカスタマイズ", - "xpack.security.management.editRole.spacePrivilegeForm.customPrivilegeDetails": "選択されたスペースの機能ごとにアクセスをカスタマイズします", - "xpack.security.management.editRole.spacePrivilegeForm.customPrivilegeDisplay": "カスタム", - "xpack.security.management.editRole.spacePrivilegeForm.customPrivilegeDropdownDisplay": "カスタム", - "xpack.security.management.editRole.spacePrivilegeForm.featurePrivilegeSummaryDescription": "機能によってはスペースごとに非表示になっているか、グローバルスペース権限による影響を受けているものもあります。", - "xpack.security.management.editRole.spacePrivilegeForm.globalPrivilegeNotice": "これらの権限はすべての現在および未来のスペースに適用されます。", - "xpack.security.management.editRole.spacePrivilegeForm.globalPrivilegeWarning": "グローバル権限の作成は他のスペース権限に影響を与える可能性があります。", - "xpack.security.management.editRole.spacePrivilegeForm.modalTitle": "スペース権限", - "xpack.security.management.editRole.spacePrivilegeForm.privilegeSelectorFormLabel": "権限", - "xpack.security.management.editRole.spacePrivilegeForm.readPrivilegeDetails": "選択されたスペースの全機能への読み込み専用アクセスを許可します。", - "xpack.security.management.editRole.spacePrivilegeForm.readPrivilegeDisplay": "読み込み", - "xpack.security.management.editRole.spacePrivilegeForm.readPrivilegeDropdownDisplay": "読み込み", - "xpack.security.management.editRole.spacePrivilegeForm.spaceSelectorFormLabel": "スペース", - "xpack.security.management.editRole.spacePrivilegeForm.summaryOfFeaturePrivileges": "機能権限のサマリー", - "xpack.security.management.editRole.spacePrivilegeMatrix.basePrivilegeText": "ベース権限", - "xpack.security.management.editRole.spacePrivilegeMatrix.basePrivilegeTooltip": "基本権限は自動的にすべての機能に与えられます。", - "xpack.security.management.editRole.spacePrivilegeMatrix.closeButton": "閉じる", - "xpack.security.management.editRole.spacePrivilegeMatrix.featureColumnTitle": "機能", - "xpack.security.management.editRole.spacePrivilegeMatrix.globalSpaceName": "グローバル", - "xpack.security.management.editRole.spacePrivilegeMatrix.modalTitle": "権限のサマリー", - "xpack.security.management.editRole.spacePrivilegeMatrix.showAllSpacesLink": "(すべてのスペース)", - "xpack.security.management.editRole.spacePrivilegeMatrix.showNMoreSpacesLink": "他 {count} 件", - "xpack.security.management.editRole.spacePrivilegeMatrix.showSummaryText": "権限サマリーを表示", - "xpack.security.management.editRole.spacePrivilegeSection.addSpacePrivilegeButton": "スペース権限を追加", - "xpack.security.management.editRole.spacePrivilegeSection.noAccessToKibanaTitle": "このロールは Kibana へのアクセスを許可しません", - "xpack.security.management.editRole.spacePrivilegeTable.deletePrivilegesLabel": "次のスペースの権限を削除: {spaceNames}", - "xpack.security.management.editRole.spacePrivilegeTable.editPrivilegesLabel": "次のスペースの権限を編集: {spaceNames}", - "xpack.security.management.editRole.spacePrivilegeTable.showAllSpacesLink": "スペースを表示", - "xpack.security.management.editRole.spacePrivilegeTable.showLessSpacesLink": "縮小表示", - "xpack.security.management.editRole.spacePrivilegeTable.showNMoreSpacesLink": "他 {count} 件", - "xpack.security.management.editRole.spaceSelectorLabel": "スペース", - "xpack.security.management.editRole.spacesPopoverList.findSpacePlaceholder": "スペースを検索", - "xpack.security.management.editRole.spacesPopoverList.noSpacesFoundTitle": " スペースが見つかりません ", - "xpack.security.management.editRole.spacesPopoverList.popoverTitle": "スペース", - "xpack.security.management.editRole.transformErrorSectionDescription": "このロール定義は無効です。この画面では編集できません。", - "xpack.security.management.editRole.transformErrorSectionTitle": "不正形式のロール", - "xpack.security.management.editRole.updateRoleText": "ロールを更新", - "xpack.security.management.editRole.validateRole.indicesTypeErrorMessage": "{elasticIndices} は数列でなければなりません", - "xpack.security.management.editRole.validateRole.nameAllowedCharactersWarningMessage": "名前は文字またはアンダーラインで始まり、文字、アンダーライン、数字のみ使用できます。", - "xpack.security.management.editRole.validateRole.nameLengthWarningMessage": "名前は 1024 文字以内でなければなりません", - "xpack.security.management.editRole.validateRole.onePrivilegeRequiredWarningMessage": "権限が最低 1 つ必要です", - "xpack.security.management.editRole.validateRole.oneSpaceRequiredWarningMessage": "スペースが最低 1 つ必要です", - "xpack.security.management.editRole.validateRole.privilegeRequiredWarningMessage": "権限が必要です", - "xpack.security.management.editRole.validateRole.provideRoleNameWarningMessage": "ロール名を入力してください", - "xpack.security.management.editRole.viewingRoleTitle": "ロールを閲覧中", - "xpack.security.management.editRoles.indexPrivilegeForm.deniedFieldsFormRowLabel": "拒否されたフィールド", - "xpack.security.management.editRoles.indexPrivilegeForm.grantedFieldsFormRowHelpText": "フィールドが提供されていない場合、このロールのユーザーはこのインデックスのデータを表示できません。", - "xpack.security.management.editRoles.indexPrivilegeForm.grantedFieldsFormRowLabel": "許可されたフィールド", - "xpack.security.management.editRoles.indexPrivilegeForm.grantFieldPrivilegesLabel": "特定のフィールドへのアクセスを許可", - "xpack.security.management.editRolespacePrivilegeForm.cancelButton": "キャンセル", - "xpack.security.management.editRolespacePrivilegeForm.createGlobalPrivilegeButton": "グローバル権限を作成", - "xpack.security.management.editRolespacePrivilegeForm.createPrivilegeButton": "スペース権限を作成", - "xpack.security.management.editRolespacePrivilegeForm.updateGlobalPrivilegeButton": "グローバル特権を更新", - "xpack.security.management.editRolespacePrivilegeForm.updatePrivilegeButton": "スペース権限を更新", - "xpack.security.management.passwordForm.confirmPasswordLabel": "パスワードの確認", - "xpack.security.management.passwordForm.passwordDontMatchDescription": "パスワードが一致しません", - "xpack.security.management.passwordForm.passwordLabel": "パスワード", - "xpack.security.management.passwordForm.passwordLengthDescription": "パスワードは最低 6 文字必要です", - "xpack.security.management.roles.confirmDelete.cancelButtonLabel": "キャンセル", - "xpack.security.management.roles.confirmDelete.deleteButtonLabel": "削除", - "xpack.security.management.roles.confirmDelete.removingRolesDescription": "これらのロールを削除しようとしています:", - "xpack.security.management.roles.confirmDelete.roleDeletingErrorNotificationMessage": "ロール {roleName} の削除中にエラーが発生しました", - "xpack.security.management.roles.confirmDelete.roleSuccessfullyDeletedNotificationMessage": "ロール {roleName} を削除しました", - "xpack.security.management.roles.createRoleButtonLabel": "ロールを作成", - "xpack.security.management.roles.deleteRoleTitle": "ロール {value, plural, one {{roleName}} other {}} を削除しました", - "xpack.security.management.roles.deleteSelectedRolesButtonLabel": "ロール {numSelected} {numSelected, plural, one { } other {}} を削除しました", - "xpack.security.management.roles.deletingRolesWarningMessage": "この操作は元に戻すことができません。", - "xpack.security.management.roles.deniedPermissionTitle": "ロールを管理するにはパーミッションが必要です", - "xpack.security.management.roles.disabledTooltip": " (無効)", - "xpack.security.management.roles.fetchingRolesErrorMessage": "ロールの取得中にエラーが発生: {message}", - "xpack.security.management.roles.nameColumnName": "ロール", - "xpack.security.management.roles.noPermissionToManageRolesDescription": "システム管理者にお問い合わせください。", - "xpack.security.management.roles.reservedColumnDescription": "リザーブされたロールはビルトインのため削除または変更できません。", - "xpack.security.management.roles.reservedColumnName": "リザーブ", - "xpack.security.management.roles.reservedRoleIconLabel": "指定済みロール", - "xpack.security.management.roles.roleNotFound": "「{roleName}」ロールが見つかりません。", - "xpack.security.management.roles.roleTitle": "ロール", - "xpack.security.management.roles.subtitle": "ユーザーのグループにロールを適用してスタック全体のパーミッションを管理", - "xpack.security.management.rolesTitle": "ロール", - "xpack.security.management.securityTitle": "セキュリティ", - "xpack.security.management.users.confirmDelete.cancelButtonLabel": "キャンセル", - "xpack.security.management.users.confirmDelete.confirmButtonLabel": "削除", - "xpack.security.management.users.confirmDelete.deleteMultipleUsersTitle": "{userLength} ユーザーの削除", - "xpack.security.management.users.confirmDelete.deleteOneUserTitle": "ユーザー {userLength} の削除", - "xpack.security.management.users.confirmDelete.removingUsersDescription": "これらのユーザーを削除しようとしています:", - "xpack.security.management.users.confirmDelete.removingUsersWarningMessage": "この操作は元に戻すことができません。", - "xpack.security.management.users.confirmDelete.userDeletingErrorNotificationMessage": "ユーザー {username} の削除中にエラーが発生しました", - "xpack.security.management.users.confirmDelete.userSuccessfullyDeletedNotificationMessage": "ユーザー {username} が削除されました", - "xpack.security.management.users.createNewUserButtonLabel": "ユーザーを作成", - "xpack.security.management.users.deleteUsersButtonLabel": "{numSelected} 人のユーザー{numSelected, plural, one { } other {s}} 削除", - "xpack.security.management.users.deniedPermissionTitle": "ユーザーを管理するにはパーミッションが必要です", - "xpack.security.management.users.editUser.addRolesPlaceholder": "ロールを追加", - "xpack.security.management.users.editUser.cancelButtonLabel": "キャンセル", - "xpack.security.management.users.editUser.changePasswordButtonLabel": "パスワードを変更", - "xpack.security.management.users.editUser.changePasswordExtraStepTitle": "追加ステップが必要です", - "xpack.security.management.users.editUser.changePasswordUpdateKibanaTitle": "Kibana ユーザーのパスワードを変更後、{kibana} ファイルを更新し Kibana を再起動する必要があります。", - "xpack.security.management.users.editUser.changingUserNameAfterCreationDescription": "ユーザー名は作成後変更できません。", - "xpack.security.management.users.editUser.confirmPasswordFormRowLabel": "パスワードの確認", - "xpack.security.management.users.editUser.createUserButtonLabel": "ユーザーを作成", - "xpack.security.management.users.editUser.deleteUserButtonLabel": "ユーザーを削除", - "xpack.security.management.users.editUser.editUserTitle": "ユーザー {userName} の編集", - "xpack.security.management.users.editUser.emailAddressFormRowLabel": "メールアドレス", - "xpack.security.management.users.editUser.errorLoadingRolesTitle": "ロールの読み込み中にエラーが発生", - "xpack.security.management.users.editUser.errorLoadingUserTitle": "ユーザーの読み込み中にエラーが発生", - "xpack.security.management.users.editUser.fullNameFormRowLabel": "フルネーム", - "xpack.security.management.users.editUser.modifyingReservedUsersDescription": "リザーブされたユーザーはビルトインのため削除または変更できません。パスワードのみ変更できます。", - "xpack.security.management.users.editUser.newUserTitle": "新規ユーザー", - "xpack.security.management.users.editUser.passwordDoNotMatchErrorMessage": "パスワードが一致しません", - "xpack.security.management.users.editUser.passwordFormRowLabel": "パスワード", - "xpack.security.management.users.editUser.passwordLengthErrorMessage": "パスワードは最低 6 文字必要です", - "xpack.security.management.users.editUser.requiredUsernameErrorMessage": "ユーザー名が必要です", - "xpack.security.management.users.editUser.returnToUserListButtonLabel": "ユーザーリストに戻る", - "xpack.security.management.users.editUser.rolesFormRowLabel": "ロール", - "xpack.security.management.users.editUser.savingUserErrorMessage": "ユーザーの保存中にエラーが発生しました: {message}", - "xpack.security.management.users.editUser.settingPasswordErrorMessage": "パスワードの設定中にエラーが発生しました: {message}", - "xpack.security.management.users.editUser.updateUserButtonLabel": "ユーザーを更新", - "xpack.security.management.users.editUser.usernameAllowedCharactersErrorMessage": "ユーザー名は文字またはアンダーラインで始まり、文字、アンダーライン、数字のみ使用できます", - "xpack.security.management.users.editUser.usernameFormRowLabel": "ユーザー名", - "xpack.security.management.users.editUser.userSuccessfullySavedNotificationMessage": "保存されたユーザー {message}", - "xpack.security.management.users.editUser.validEmailRequiredErrorMessage": "メールアドレスが無効です", - "xpack.security.management.users.emailAddressColumnName": "メールアドレス", - "xpack.security.management.users.fetchingUsersErrorMessage": "ユーザーの取得中にエラーが発生: {message}", - "xpack.security.management.users.fullNameColumnName": "フルネーム", - "xpack.security.management.users.permissionDeniedToManageUsersDescription": "システム管理者にお問い合わせください。", - "xpack.security.management.users.reservedColumnDescription": "リザーブされたユーザーはビルトインのため削除できません。パスワードのみ変更できます。", - "xpack.security.management.users.reservedColumnName": "リザーブ", - "xpack.security.management.users.rolesColumnName": "ロール", - "xpack.security.management.users.userNameColumnName": "ユーザー名", - "xpack.security.management.users.usersTitle": "ユーザー", - "xpack.security.management.usersTitle": "ユーザー", - "xpack.security.navControlComponent.accountMenuAriaLabel": "アカウントメニュー", - "xpack.security.navControlComponent.editProfileLinkText": "プロフィールを編集", - "xpack.security.navControlComponent.logoutLinkText": "ログアウト", - "xpack.security.overwrittenSession.continueAsUserText": "{username} として続行", - "xpack.security.overwrittenSession.title": "以前別のユーザー名でログインしました。", - "xpack.security.registerFeature.securitySettingsDescription": "ユーザーとロールでデータを保護し、誰が何にアクセスできるのか簡単に管理できます。", - "xpack.security.registerFeature.securitySettingsTitle": "セキュリティ設定", - "xpack.security.roles.breadcrumb": "ロール", - "xpack.security.roles.createBreadcrumb": "作成", - "xpack.security.users.breadcrumb": "ユーザー", - "xpack.security.users.createBreadcrumb": "作成", - "xpack.security.management.editRole.featureTable.excludedFromBasePrivilegsTooltip": "アクセスを許可するには、「カスタム」特権を使用します。{featureName} は基本権限の一部ではありません。", - "xpack.security.apiKeys.breadcrumb": "API キー", - "xpack.security.management.apiKeys.deniedPermissionTitle": "API キーを管理するにはパーミッションが必要です", - "xpack.security.management.apiKeys.invalidateApiKey.confirmModal.cancelButtonLabel": "キャンセル", - "xpack.security.management.apiKeys.invalidateApiKey.confirmModal.confirmButtonLabel": "{count, plural, one {API キー} other {API キー}}の無効化", - "xpack.security.management.apiKeys.invalidateApiKey.confirmModal.invalidateMultipleListDescription": "これらの API キーを無効化しようとしています:", - "xpack.security.management.apiKeys.invalidateApiKey.confirmModal.invalidateMultipleTitle": "{count}API キーを無効にしますか?", - "xpack.security.management.apiKeys.invalidateApiKey.confirmModal.invalidateSingleTitle": "API キー「{name}」を無効にしますか?", - "xpack.security.management.apiKeys.invalidateApiKey.errorMultipleNotificationTitle": "{count} 個の API キーの削除中にエラーが発生", - "xpack.security.management.apiKeys.invalidateApiKey.errorSingleNotificationTitle": "API キー「{name}」の削除中にエラーが発生", - "xpack.security.management.apiKeys.invalidateApiKey.successMultipleNotificationTitle": "{count} 個の API キーが無効になりました", - "xpack.security.management.apiKeys.invalidateApiKey.successSingleNotificationTitle": "API キー「{name}」を無効にしますか?", - "xpack.security.management.apiKeys.noPermissionToManageRolesDescription": "システム管理者にお問い合わせください。", - "xpack.security.management.apiKeys.table.actionDeleteAriaLabel": "「{name}」を無効にする", - "xpack.security.management.apiKeys.table.actionDeleteTooltip": "無効にする", - "xpack.security.management.apiKeys.table.actionsColumnName": "アクション", - "xpack.security.management.apiKeys.table.adminText": "あなたは API キー管理者です。", - "xpack.security.management.apiKeys.table.apiKeysAllDescription": "API キーを表示して無効にします。API キーはユーザーの代わりにリクエストを送信します。", - "xpack.security.management.apiKeys.table.apiKeysDisabledErrorDescription": "システム管理者に連絡し、{link} を伝えて API キーを有効にしてください。", - "xpack.security.management.apiKeys.table.apiKeysDisabledErrorLinkText": "ドキュメント", - "xpack.security.management.apiKeys.table.apiKeysDisabledErrorTitle": "Elasticsearch で API キーが有効ではありません", - "xpack.security.management.apiKeys.table.apiKeysOwnDescription": "API キーを表示して無効にします。API キーはユーザーの代わりにリクエストを送信します。", - "xpack.security.management.apiKeys.table.apiKeysTableLoadingMessage": "API キーを読み込み中…", - "xpack.security.management.apiKeys.table.apiKeysTitle": "API キー", - "xpack.security.management.apiKeys.table.creationDateColumnName": "作成済み", - "xpack.security.management.apiKeys.table.emptyPromptAdminTitle": "API キーがありません", - "xpack.security.management.apiKeys.table.emptyPromptConsoleButtonMessage": "コンソールに移動してください", - "xpack.security.management.apiKeys.table.emptyPromptDescription": "コンソールで {link} を作成できます。", - "xpack.security.management.apiKeys.table.emptyPromptDocsLinkMessage": "API キー", - "xpack.security.management.apiKeys.table.emptyPromptNonAdminTitle": "まだ API キーがありません", - "xpack.security.management.apiKeys.table.expirationDateColumnName": "有効期限", - "xpack.security.management.apiKeys.table.expirationDateNeverMessage": "無し", - "xpack.security.management.apiKeys.table.invalidateApiKeyButton": "{count, plural, one {API キー} other {API キー}}を無効にする", - "xpack.security.management.apiKeys.table.loadingApiKeysDescription": "API キーを読み込み中…", - "xpack.security.management.apiKeys.table.loadingApiKeysErrorTitle": "API キーを読み込み中にエラーが発生", - "xpack.security.management.apiKeys.table.nameColumnName": "名前", - "xpack.security.management.apiKeys.table.realmColumnName": "レルム", - "xpack.security.management.apiKeys.table.realmFilterLabel": "レルム", - "xpack.security.management.apiKeys.table.reloadApiKeysButton": "再読み込み", - "xpack.security.management.apiKeys.table.statusColumnName": "ステータス", - "xpack.security.management.apiKeys.table.userFilterLabel": "ユーザー", - "xpack.security.management.apiKeys.table.userNameColumnName": "ユーザー", - "xpack.security.management.apiKeysTitle": "API キー", - "xpack.server.checkLicense.errorExpiredMessage": "{licenseType} ライセンスが期限切れのため {pluginName} を使用できません", - "xpack.server.checkLicense.errorUnavailableMessage": "現在ライセンス情報が利用できないため {pluginName} を使用できません。", - "xpack.server.checkLicense.errorUnsupportedMessage": "ご使用の {licenseType} ライセンスは {pluginName} をサポートしていません。ライセンスをアップグレードしてください。", - "xpack.siem.andOrBadge.and": "AND", - "xpack.siem.andOrBadge.or": "OR", - "xpack.siem.auditd.abortedAuditStartupDescription": "中断された監査のスタートアップ", - "xpack.siem.auditd.accessErrorDescription": "アクセスエラー", - "xpack.siem.auditd.accessPermissionDescription": "アクセス権限", - "xpack.siem.auditd.accessResultDescription": "アクセス結果", - "xpack.siem.auditd.acquiredCredentialsDescription": "認証情報を取得しました:", - "xpack.siem.auditd.adddedGroupAccountUsingDescription": "以下を使用してグループアカウントを追加:", - "xpack.siem.auditd.addedUserAccountDescription": "ユーザーアカウントを追加しました", - "xpack.siem.auditd.allocatedMemoryForDescription": "割当メモリー", - "xpack.siem.auditd.asDescription": "as", - "xpack.siem.auditd.assignedUserRoleToDescription": "ユーザーロールをアサインしました:", - "xpack.siem.auditd.assignedVmIdDescription": "vm id が割り当てられました", - "xpack.siem.auditd.assignedVMResourceDescription": "割り当てられた vm リソース", - "xpack.siem.auditd.attemptedLoginDescription": "以下を経由してログインを試行しました:", - "xpack.siem.auditd.attemptedLoginFromUnusalPlaceDescription": "通常と異なる場所からログインを試行しました", - "xpack.siem.auditd.attemptedLoginFromUnusualHourDescription": "通常と異なる時間にログインを試行しました", - "xpack.siem.auditd.auditErrorDescription": "監査エラー", - "xpack.siem.auditd.authenticatedToGroupDescription": "グループに認証しました", - "xpack.siem.auditd.authenticatedUsingDescription": "次の手段で認証しました:", - "xpack.siem.auditd.bootedSystemDescription": "システムを起動しました", - "xpack.siem.auditd.boundSocketFromDescription": "次からソケットをバインドしました:", - "xpack.siem.auditd.causedMacPolicyErrorDescription": "がmacポリシーエラーを発生させました", - "xpack.siem.auditd.changedAuditConfigurationDescription": "監査設定を変更しました", - "xpack.siem.auditd.changedAuditFeatureDescription": "監査機能を変更しました", - "xpack.siem.auditd.changedConfigurationWIthDescription": "次の設定を変更しました:", - "xpack.siem.auditd.ChangedFileAttributesOfDescription": "次のファイル属性を変更しました:", - "xpack.siem.auditd.changedFilePermissionOfDescription": "次のファイル権限を変更しました:", - "xpack.siem.auditd.changedGroupDescription": "グループを変更しました", - "xpack.siem.auditd.changedGroupPasswordDescription": "グループのパスワードを変更しました", - "xpack.siem.auditd.changedIdentityUsingDescription": "以下を使用してIDを変更しました:", - "xpack.siem.auditd.changedLoginIdToDescription": "ログインIDを次に変更しました:", - "xpack.siem.auditd.changedMacConfigurationDescription": "mac構成を変更しました", - "xpack.siem.auditd.changedPasswordWithDescription": "次のパスワードを変更しました:", - "xpack.siem.auditd.changedRoleUsingDescription": "以下を使用してロールを変更しました:", - "xpack.siem.auditd.changedSeLinuxBooleanDescription": "selinuxブールを変更しました", - "xpack.siem.auditd.changedSelinuxEnforcementDescription": "selinux執行を変更しました", - "xpack.siem.auditd.changedSystemNameDescription": "システム名を変更しました", - "xpack.siem.auditd.changedSystemTimeWithDescription": "次のシステム時刻を変更しました:", - "xpack.siem.auditd.changedTimeStampOfDescription": "次のタイムスタンプを変更しました:", - "xpack.siem.auditd.changedToRunLevelWithDescription": "次の実行レベルを変更しました:", - "xpack.siem.auditd.changedUserIdDescription": "ユーザー ID が変更されました", - "xpack.siem.auditd.changeidleOwernshipOfDescription": "次のファイルの所有者を変更:", - "xpack.siem.auditd.checkedFileSystemMetadataOfDescription": "次のファイルシステムメタデータを確認しました:", - "xpack.siem.auditd.checkedIntegrityOfDescription": "次の整合性を確認しました:", - "xpack.siem.auditd.chedckedMetaDataOfDescription": "次のメタデータを確認しました:", - "xpack.siem.auditd.connectedUsingDescription": "以下を使用して接続しました:", - "xpack.siem.auditd.crashedProgramDescription": "がプログラムをクラッシュさせました", - "xpack.siem.auditd.createdDirectoryDescription": "ディレクトリを作成しました", - "xpack.siem.auditd.createdVmImageDescription": "仮想マシンイメージを作成しました", - "xpack.siem.auditd.cryptoOfficerLoggedInDescription": "クリプトオフィサーがログイン", - "xpack.siem.auditd.cryptoOfficerLoggedOutDescription": "クリプトオフィサーがログアウト", - "xpack.siem.auditd.deletedDescription": "削除されました", - "xpack.siem.auditd.deletedGroupAccountUsingDescription": "次の手段でグループアカウントを削除", - "xpack.siem.auditd.deletedUserAccountUsingDescription": "以下を使用してユーザーアカウントを削除しました:", - "xpack.siem.auditd.deletedVmImageDescription": "仮想マシンイメージを削除しました", - "xpack.siem.auditd.disposedCredentialsDescription": "次のアカウント認証情報を処理しました:", - "xpack.siem.auditd.endedFromDescription": "終了:", - "xpack.siem.auditd.errorFromDescription": "エラー:", - "xpack.siem.auditd.executedDescription": "実行", - "xpack.siem.auditd.executionOfForbiddenProgramDescription": "禁止されたプログラムの実行", - "xpack.siem.auditd.failedLoginTooManyTimesDescription": "ログイン回数超過によりログインに失敗", - "xpack.siem.auditd.inDescription": "次に含まれる:", - "xpack.siem.auditd.initializedAuditSubsystemDescription": "監査サブシステムを初期化しました", - "xpack.siem.auditd.issuedVmControlDescription": "仮想マシンコントロールを発行しました", - "xpack.siem.auditd.killedProcessIdDescription": "プロセスIDを強制終了しました:", - "xpack.siem.auditd.ListeningForConnectionsUsingDescription": "以下を使用して接続をlistenしています:", - "xpack.siem.auditd.loadedFirewallRuleDescription": "ファイアウォールルールを読み込みました", - "xpack.siem.auditd.loadedMacPolicyDescription": "macポリシーを読み込みました", - "xpack.siem.auditd.loadedSeLinuxPolicyDescription": "selinuxポリシーを読み込みました", - "xpack.siem.auditd.loaedKernelModuleOfDescription": "次のカーネルモジュールを読み込みました:", - "xpack.siem.auditd.lockedAccountDescription": "アカウントをロック", - "xpack.siem.auditd.loggedOutDescription": "ログアウト", - "xpack.siem.auditd.macPermissionDescription": "mac権限", - "xpack.siem.auditd.madeDeviceWithDescription": "デバイスを作成しました:", - "xpack.siem.auditd.migratedVmFromDescription": "仮想マシンを以下から移行しました:", - "xpack.siem.auditd.migratedVmToDescription": "仮想マシンを以下に移行しました:", - "xpack.siem.auditd.modifiedGroupAccountDescription": "グループアカウントを修正", - "xpack.siem.auditd.modifiedLevelOfDescription": "次のレベルを修正:", - "xpack.siem.auditd.modifiedRoleDescription": "ロールを修正:", - "xpack.siem.auditd.modifiedUserAccountDescription": "ユーザーアカウントを修正", - "xpack.siem.auditd.mountedDescription": "マウントしました", - "xpack.siem.auditd.negotiatedCryptoKeyDescription": "暗号キーを交渉しました", - "xpack.siem.auditd.nonExistentDescription": "不明なプロセスに", - "xpack.siem.auditd.OpenedFileDescription": "ファイルを開きました", - "xpack.siem.auditd.openedTooManySessionsDescription": "開いたセッション数が多すぎました", - "xpack.siem.auditd.overrodeLabelOfDescription": "次のラベルを上書き:", - "xpack.siem.auditd.promiscuousModeDescription": "以下を使用してデバイスの無差別モードを変更しました:", - "xpack.siem.auditd.ranCommandDescription": "コマンドを実行しました", - "xpack.siem.auditd.receivedFromDescription": "以下より受信しました:", - "xpack.siem.auditd.reconfiguredAuditDescription": "監査を再構成しました", - "xpack.siem.auditd.refreshedCredentialsForDescription": "認証情報をリフレッシュしました", - "xpack.siem.auditd.relabeledFileSystemDescription": "ファイルシステムのラベルを変更しました", - "xpack.siem.auditd.remoteAuditConnectedDescription": "リモート監査を接続", - "xpack.siem.auditd.remoteAuditDisconnectedDescription": "リモート監査を切断", - "xpack.siem.auditd.removedUserRoleFromDescription": "以下からユーザーロールを削除しました:", - "xpack.siem.auditd.renamedDescription": "名前を変更しました", - "xpack.siem.auditd.resumedAuditLoggingDescription": "監査ログを再開しました", - "xpack.siem.auditd.rotatedAuditLogsDescription": "rotated-audit-logs", - "xpack.siem.auditd.scheduledPolicyOFDescription": "次のポリシーをスケジュール設定しました:", - "xpack.siem.auditd.sentMessageDescription": "メッセージを送信しました", - "xpack.siem.auditd.sentTestDescription": "テストを送信しました", - "xpack.siem.auditd.sentToDescription": "送信先:", - "xpack.siem.auditd.sessionDescription": "セッション", - "xpack.siem.auditd.shutDownAuditDescription": "監査をシャットダウン", - "xpack.siem.auditd.shutdownSystemDescription": "システムをシャットダウン", - "xpack.siem.auditd.startedAtDescription": "開始済み", - "xpack.siem.auditd.startedAuditDescription": "監査を開始", - "xpack.siem.auditd.startedCryptoSessionDescription": "暗号セッションを開始しました", - "xpack.siem.auditd.startedServiceDescription": "サービスを開始しました", - "xpack.siem.auditd.stoppedServiceDescription": "サービスを停止しました", - "xpack.siem.auditd.suspiciousProgramDescription": "不審なプログラムを使用しました", - "xpack.siem.auditd.symLinkedDescription": "シンボルでリンクしました", - "xpack.siem.auditd.testedFileSystemIntegrityDescription": "ファイルシステムの完全性をテスト", - "xpack.siem.auditd.unknownDescription": "不明", - "xpack.siem.auditd.unloadedKernelModuleOfDescription": "次のカーネルモジュールをアンロードしました:", - "xpack.siem.auditd.unlockedAccountDescription": "アカウントのロックを解除しました:", - "xpack.siem.auditd.unmountedDescription": "マウント解除しました", - "xpack.siem.auditd.usingDescription": "using", - "xpack.siem.auditd.violatedAppArmorPolicyFromDescription": "以下からのAppArmorポリシーに違反しました:", - "xpack.siem.auditd.violatedSeccompPolicyWithDescription": "以下からのseccompポリシーに違反しました:", - "xpack.siem.auditd.violatedSeLinuxPolicyDescription": "selinuxポリシーに違反しました", - "xpack.siem.auditd.wasAuthorizedToUseDescription": "が以下の使用を承認されました:", - "xpack.siem.auditd.withResultDescription": "with result", - "xpack.siem.authenticationsTable.authenticationFailures": "認証", - "xpack.siem.authenticationsTable.failures": "失敗", - "xpack.siem.authenticationsTable.lastFailedDestination": "前回失敗したデスティネーション", - "xpack.siem.authenticationsTable.lastFailedSource": "前回失敗したソース", - "xpack.siem.authenticationsTable.lastFailedTime": "前回の失敗", - "xpack.siem.authenticationsTable.lastSuccessfulDestination": "前回成功したデスティネーション", - "xpack.siem.authenticationsTable.lastSuccessfulSource": "前回成功したソース", - "xpack.siem.authenticationsTable.lastSuccessfulTime": "前回の成功", - "xpack.siem.authenticationsTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", - "xpack.siem.authenticationsTable.successes": "成功", - "xpack.siem.authenticationsTable.uncommonProcessTable": "非共通プロセス", - "xpack.siem.authenticationsTable.unit": "{totalCount, plural, =1 {user} other {users}}", - "xpack.siem.authenticationsTable.user": "ユーザー", - "xpack.siem.certificate.fingerprint.clientCertLabel": "クライアント証明書", - "xpack.siem.certificate.fingerprint.serverCertLabel": "サーバー証明書", - "xpack.siem.chart.dataNotAvailableTitle": "チャートデータが利用できません", - "xpack.siem.clipboard.copied": "コピー完了", - "xpack.siem.clipboard.copy": "コピー", - "xpack.siem.clipboard.to.the.clipboard": "クリップボードに", - "xpack.siem.components.flowControls.selectFlowDirection.bidirectionalButtonLabel": "双方向", - "xpack.siem.components.flowControls.selectFlowDirection.unidirectionalButtonLabel": "一方向", - "xpack.siem.components.flowControls.selectFlowTarget.clientDropDownOptionLabel": "クライアント", - "xpack.siem.components.flowControls.selectFlowTarget.destinationDropDownOptionLabel": "送信先", - "xpack.siem.components.flowControls.selectFlowTarget.serverDropDownOptionLabel": "サーバー", - "xpack.siem.components.flowControls.selectFlowTarget.sourceDropDownOptionLabel": "送信元", - "xpack.siem.containers.errors.dataFetchFailureTitle": "データの取得に失敗", - "xpack.siem.containers.errors.networkFailureTitle": "ネットワーク障害", - "xpack.siem.dataProviders.and": "AND", - "xpack.siem.dataProviders.deleteDataProvider": "削除", - "xpack.siem.dataProviders.dropAnything": "何でもドロップできます", - "xpack.siem.dataProviders.dropHere": "ここにドロップしてください", - "xpack.siem.dataProviders.dropHereToAddAnLabel": "ここにドロップして追加します", - "xpack.siem.dataProviders.editMenuItem": "フィルターを編集", - "xpack.siem.dataProviders.editTitle": "フィルターの編集", - "xpack.siem.dataProviders.excludeDataProvider": "結果を除外", - "xpack.siem.dataProviders.existsLabel": "存在する", - "xpack.siem.dataProviders.filterForFieldPresentLabel": "現在のフィールドのフィルター", - "xpack.siem.dataProviders.hereToBuildAn": "して開発", - "xpack.siem.dataProviders.highlighted": "ハイライト", - "xpack.siem.dataProviders.includeDataProvider": "結果を含める", - "xpack.siem.dataProviders.not": "NOT", - "xpack.siem.dataProviders.or": "または", - "xpack.siem.dataProviders.query": "クエリ", - "xpack.siem.dataProviders.reEnableDataProvider": "再度有効にする", - "xpack.siem.dataProviders.removeDataProvider": "データプロバイダーを削除", - "xpack.siem.dataProviders.showOptionsDataProvider": "次のオプションを表示:", - "xpack.siem.dataProviders.temporaryDisableDataProvider": "一時的に無効にする", - "xpack.siem.dataProviders.toBuildAn": "して開発", - "xpack.siem.dataProviders.toggle": "切り替え", - "xpack.siem.dataProviders.valueAriaLabel": "値", - "xpack.siem.dataProviders.valuePlaceholder": "値", - "xpack.siem.draggables.field.categoryLabel": "カテゴリー", - "xpack.siem.draggables.field.fieldLabel": "フィールド", - "xpack.siem.draggables.field.typeLabel": "タイプ", - "xpack.siem.draggables.field.viewCategoryTooltip": "カテゴリーを表示します", - "xpack.siem.editDataProvider.doesNotExistLabel": "存在しません", - "xpack.siem.editDataProvider.existsLabel": "存在する", - "xpack.siem.editDataProvider.fieldLabel": "フィールド", - "xpack.siem.editDataProvider.fieldPlaceholder": "フィールドを選択", - "xpack.siem.editDataProvider.isLabel": "が", - "xpack.siem.editDataProvider.isNotLabel": "is not", - "xpack.siem.editDataProvider.operatorLabel": "演算子", - "xpack.siem.editDataProvider.saveButton": "保存", - "xpack.siem.editDataProvider.selectAnOperatorPlaceholder": "演算子を選択", - "xpack.siem.editDataProvider.valueLabel": "値", - "xpack.siem.editDataProvider.valuePlaceholder": "値", - "xpack.siem.emptyString.emptyStringDescription": "空の文字列", - "xpack.siem.eventDetails.copyToClipboard": "クリップボードにコピー", - "xpack.siem.eventDetails.copyToClipboardTooltip": "クリップボードにコピー", - "xpack.siem.eventDetails.description": "説明", - "xpack.siem.eventDetails.field": "フィールド", - "xpack.siem.eventDetails.filter.placeholder": "フィールド、値、または説明でフィルター…", - "xpack.siem.eventDetails.jsonView": "JSON ビュー", - "xpack.siem.eventDetails.table": "表", - "xpack.siem.eventDetails.value": "値", - "xpack.siem.featureRegistry.linkSiemTitle": "SIEM", - "xpack.siem.fieldBrowser.categoriesCountTitle": "{totalCount} {totalCount, plural, =1 {category} other {categories}}", - "xpack.siem.fieldBrowser.categoriesTitle": "カテゴリー", - "xpack.siem.fieldBrowser.categoryLabel": "カテゴリー", - "xpack.siem.fieldBrowser.copyToClipboard": "クリップボードにコピー", - "xpack.siem.fieldBrowser.customizeColumnsTitle": "列のカスタマイズ", - "xpack.siem.fieldBrowser.descriptionLabel": "説明", - "xpack.siem.fieldBrowser.fieldLabel": "フィールド", - "xpack.siem.fieldBrowser.fieldsCountTitle": "{totalCount} {totalCount, plural, =1 {field} other {fields}}", - "xpack.siem.fieldBrowser.fieldsTitle": "フィールド", - "xpack.siem.fieldBrowser.filterPlaceholder": "フィールド名", - "xpack.siem.fieldBrowser.noFieldsMatchInputLabel": "{searchInput} に一致するフィールドがありません", - "xpack.siem.fieldBrowser.noFieldsMatchLabel": "一致するフィールドがありません", - "xpack.siem.fieldBrowser.resetFieldsLink": "フィールドをリセット", - "xpack.siem.fieldBrowser.viewCategoryTooltip": "すべての {categoryId} フィールドを表示します", - "xpack.siem.fieldRenderers.moreLabel": "もっと", - "xpack.siem.flyout.button.timeline": "タイムライン", - "xpack.siem.footer.autoRefreshActiveDescription": "自動更新アクション", - "xpack.siem.footer.autoRefreshActiveTooltip": "自動更新が有効な間、タイムラインはクエリに一致する最新の {numberOfItems} 件のイベントを表示します。", - "xpack.siem.footer.data": "データ", - "xpack.siem.footer.events": "イベント", - "xpack.siem.footer.live": "ライブ", - "xpack.siem.footer.loadingLabel": "読み込み中", - "xpack.siem.footer.loadingTimelineData": "タイムラインデータを読み込み中", - "xpack.siem.footer.loadMoreLabel": "さらに読み込む", - "xpack.siem.footer.of": "/", - "xpack.siem.footer.rows": "行", - "xpack.siem.footer.totalCountOfEvents": "イベントが検索条件に一致します", - "xpack.siem.footer.updated": "更新しました", - "xpack.siem.formatted.duration.aFewMillisecondsTooltip": "数ミリ秒", - "xpack.siem.formatted.duration.aFewNanosecondsTooltip": "数ナノ秒", - "xpack.siem.formatted.duration.aMillisecondTooltip": "1 ミリ秒", - "xpack.siem.formatted.duration.aNanosecondTooltip": "1 ナノ秒", - "xpack.siem.formatted.duration.aSecondTooltip": "1 秒", - "xpack.siem.formatted.duration.invalidDurationTooltip": "無効な期間", - "xpack.siem.formatted.duration.noDurationTooltip": "期間がありません", - "xpack.siem.formatted.duration.zeroNanosecondsTooltip": "0ナノ秒", - "xpack.siem.formattedDuration.tooltipLabel": "生", - "xpack.siem.headerPage.pageSubtitle": "前回のイベント: {beat}", - "xpack.siem.host.details.architectureLabel": "アーキテクチャー", - "xpack.siem.host.details.firstSeenTitle": "初回の認識", - "xpack.siem.host.details.lastSeenTitle": "前回の認識", - "xpack.siem.host.details.overview.cloudProviderTitle": "クラウドプロバイダー", - "xpack.siem.host.details.overview.familyTitle": "ファミリー", - "xpack.siem.host.details.overview.hostIdTitle": "ホスト ID", - "xpack.siem.host.details.overview.instanceIdTitle": "インスタンス ID", - "xpack.siem.host.details.overview.ipAddressesTitle": "IP アドレス", - "xpack.siem.host.details.overview.macAddressesTitle": "MAC アドレス", - "xpack.siem.host.details.overview.machineTypeTitle": "マシンタイプ", - "xpack.siem.host.details.overview.osTitle": "オペレーティングシステム", - "xpack.siem.host.details.overview.platformTitle": "プラットフォーム", - "xpack.siem.host.details.overview.regionTitle": "地域", - "xpack.siem.host.details.versionLabel": "バージョン", - "xpack.siem.hosts.emptyActionPrimary": "セットアップの手順を表示", - "xpack.siem.hosts.emptyActionSecondary": "ドキュメントに移動", - "xpack.siem.hosts.emptyTitle": "SIEM アプリケーションのホストに関連したインデックスがないようです", - "xpack.siem.hosts.kqlPlaceholder": "例: host.name: \"foo\"", - "xpack.siem.hosts.pageTitle": "すべてのホスト", - "xpack.siem.hostsTable.firstLastSeenToolTip": "選択された日付範囲との相関付けです", - "xpack.siem.hostsTable.hostsTitle": "すべてのホスト", - "xpack.siem.hostsTable.lastSeenTitle": "前回の認識", - "xpack.siem.hostsTable.nameTitle": "名前", - "xpack.siem.hostsTable.osTitle": "オペレーティングシステム", - "xpack.siem.hostsTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", - "xpack.siem.hostsTable.unit": "{totalCount, plural, =1 {host} other {hosts}}", - "xpack.siem.hostsTable.versionTitle": "バージョン", - "xpack.siem.ja3.fingerprint.ja3.fingerprintLabel": "ja3", - "xpack.siem.linkSecurityDescription": "SIEM アプリを閲覧します", - "xpack.siem.markdown.hint.boldLabel": "**太字**", - "xpack.siem.markdown.hint.bulletLabel": "* ビュレット", - "xpack.siem.markdown.hint.codeLabel": "「コード」", - "xpack.siem.markdown.hint.headingLabel": "# 見出し", - "xpack.siem.markdown.hint.imageUrlLabel": "![image](url)", - "xpack.siem.markdown.hint.italicsLabel": "_斜体_", - "xpack.siem.markdown.hint.preformattedLabel": "```プリフォーマット```", - "xpack.siem.markdown.hint.quoteLabel": ">引用", - "xpack.siem.markdown.hint.strikethroughLabel": "取り消し線", - "xpack.siem.markdown.hint.urlLabel": "[link](url)", - "xpack.siem.navigation.hosts": "すべてのホスト", - "xpack.siem.navigation.network": "ネットワーク", - "xpack.siem.navigation.overview": "概要", - "xpack.siem.navigation.timelines": "タイムライン", - "xpack.siem.network.emptyActionPrimary": "セットアップの手順を表示", - "xpack.siem.network.emptyActionSecondary": "ドキュメントに移動", - "xpack.siem.network.emptyTitle": "SIEM アプリケーションのネットワークに関連したインデックスがないようです", - "xpack.siem.network.ipDetails.ipOverview.autonomousSystemTitle": "自動システム", - "xpack.siem.network.ipDetails.ipOverview.firstSeenTitle": "初回の認識", - "xpack.siem.network.ipDetails.ipOverview.hostIdTitle": "ホスト ID", - "xpack.siem.network.ipDetails.ipOverview.hostNameTitle": "ホスト名", - "xpack.siem.network.ipDetails.ipOverview.ipReputationTitle": "評判", - "xpack.siem.network.ipDetails.ipOverview.lastSeenTitle": "前回の認識", - "xpack.siem.network.ipDetails.ipOverview.locationTitle": "場所", - "xpack.siem.network.ipDetails.ipOverview.viewWhoisTitle": "iana.org", - "xpack.siem.network.ipDetails.ipOverview.whoIsTitle": "WhoIs", - "xpack.siem.network.ipDetails.tlsTable.columns.issuerTitle": "発行者", - "xpack.siem.network.ipDetails.tlsTable.columns.ja3FingerPrintTitle": "JA3 フィンガープリント", - "xpack.siem.network.ipDetails.tlsTable.columns.sha1FingerPrintTitle": "SHA1フィンガープリント", - "xpack.siem.network.ipDetails.tlsTable.columns.subjectTitle": "件名", - "xpack.siem.network.ipDetails.tlsTable.columns.validUntilTitle": "有効期限:", - "xpack.siem.network.ipDetails.tlsTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", - "xpack.siem.network.ipDetails.tlsTable.transportLayerSecurityTitle": "トランスポートレイヤーセキュリティ", - "xpack.siem.network.ipDetails.tlsTable.unit": "{totalCount, plural, =1 {issuer} other {issuers}}", - "xpack.siem.network.ipDetails.usersTable.columns.documentCountTitle": "ドキュメントカウント", - "xpack.siem.network.ipDetails.usersTable.columns.groupIdTitle": "グループ ID", - "xpack.siem.network.ipDetails.usersTable.columns.groupNameTitle": "グループ名", - "xpack.siem.network.ipDetails.usersTable.columns.userIdTitle": "ID", - "xpack.siem.network.ipDetails.usersTable.columns.userNameTitle": "ユーザー", - "xpack.siem.network.ipDetails.usersTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", - "xpack.siem.network.ipDetails.usersTable.unit": "{totalCount, plural, =1 {user} other {users}}", - "xpack.siem.network.ipDetails.usersTable.usersTitle": "ユーザー", - "xpack.siem.network.kqlPlaceholder": "例: source.ip: \"foo\"", - "xpack.siem.network.pageTitle": "ネットワーク", - "xpack.siem.networkDnsTable.column.bytesInTitle": "受信 DNS バイト", - "xpack.siem.networkDnsTable.column.bytesOutTitle": "送信 DNS バイト", - "xpack.siem.networkDnsTable.column.registeredDomain": "登録ドメイン", - "xpack.siem.networkDnsTable.column.TotalQueriesTitle": "クエリ合計", - "xpack.siem.networkDnsTable.column.uniqueDomainsTitle": "固有のドメイン", - "xpack.siem.networkDnsTable.helperTooltip": "これは DNS プロトコルトラフィックのみを示しており、DNS データ逆浸出に使用されたドメインの調査に役立ちます。", - "xpack.siem.networkDnsTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", - "xpack.siem.networkDnsTable.select.includePtrRecords": "PTR 記録を含める", - "xpack.siem.networkDnsTable.title": "トップ DNS ドメイン", - "xpack.siem.networkDnsTable.unit": "{totalCount, plural, =1 {domain} other {domains}}", - "xpack.siem.networkTopNFlowTable.column.destinationIpTitle": "デスティネーション IP", - "xpack.siem.networkTopNFlowTable.column.sourceIpTitle": "ソース IP", - "xpack.siem.networkTopNFlowTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", - "xpack.siem.networkTopNFlowTable.unit": "{totalCount, plural, =1 {IP} other {IPs}}", - "xpack.siem.notes.addANotePlaceholder": "メモを追加", - "xpack.siem.notes.addedANoteLabel": "メモを追加しました", - "xpack.siem.notes.addNoteButtonLabel": "メモを追加", - "xpack.siem.notes.cancelButtonLabel": "キャンセル", - "xpack.siem.notes.copyToClipboardButtonLabel": "クリップボードにコピー", - "xpack.siem.notes.noteLabel": "注", - "xpack.siem.notes.notesTitle": "メモ", - "xpack.siem.notes.previewMarkdownTitle": "プレビュー(マークダウン)", - "xpack.siem.notes.search.FilterByUserOrNotePlaceholder": "ユーザーまたはメモでフィルター", - "xpack.siem.open.timeline.cancelButton": "キャンセル", - "xpack.siem.open.timeline.collapseButton": "縮小", - "xpack.siem.open.timeline.deleteButton": "削除", - "xpack.siem.open.timeline.deleteSelectedButton": "選択項目を削除", - "xpack.siem.open.timeline.deleteTimelineModalTitle": "「{title}」を削除しますか?", - "xpack.siem.open.timeline.deleteWarningLabel": "削除すると、このタイムライン自体またはそのメモを復元することはできません。", - "xpack.siem.open.timeline.descriptionTableHeader": "説明", - "xpack.siem.open.timeline.expandButton": "拡張", - "xpack.siem.open.timeline.favoriteSelectedButton": "選択中のお気に入り", - "xpack.siem.open.timeline.favoritesTooltip": "お気に入り", - "xpack.siem.open.timeline.lastModifiedTableHeader": "最終更新:", - "xpack.siem.open.timeline.missingSavedObjectIdTooltip": "savedObjectId がありません", - "xpack.siem.open.timeline.modifiedByTableHeader": "変更者:", - "xpack.siem.open.timeline.notesTooltip": "メモ", - "xpack.siem.open.timeline.onlyFavoritesButtonLabel": "お気に入りのみ", - "xpack.siem.open.timeline.openAsDuplicateTooltip": "重複タイムラインとして開く", - "xpack.siem.open.timeline.openTimelineButton": "タイムラインを開く…", - "xpack.siem.open.timeline.openTimelineTitle": "タイムラインを開く", - "xpack.siem.open.timeline.pinnedEventsTooltip": "ピン付けされたイベント", - "xpack.siem.open.timeline.postedLabel": "投稿:", - "xpack.siem.open.timeline.searchPlaceholder": "例:タイムライン名、または説明", - "xpack.siem.open.timeline.showingNTimelinesLabel": "{totalSearchResultsCount} 件の{totalSearchResultsCount, plural, one {タイムライン} other {タイムライン}}{with}を表示中", - "xpack.siem.open.timeline.timelineNameTableHeader": "タイムライン名", - "xpack.siem.open.timeline.untitledTimelineLabel": "無題のタイムライン", - "xpack.siem.open.timeline.withLabel": "With", - "xpack.siem.open.timeline.zeroTimelinesMatchLabel": "0 件のタイムラインが検索条件に一致", - "xpack.siem.overview.auditBeatAuditTitle": "Auditbeat監査", - "xpack.siem.overview.auditBeatFimTitle": "Auditbeat File Integrityモジュール", - "xpack.siem.overview.auditBeatLoginTitle": "Auditbeatログイン", - "xpack.siem.overview.auditBeatPackageTitle": "Auditbeatパッケージ", - "xpack.siem.overview.auditBeatProcessTitle": "Auditbeatプロセス", - "xpack.siem.overview.auditBeatSocketTitle": "Auditbeatソケット", - "xpack.siem.overview.auditBeatUserTitle": "Auditbeatユーザー", - "xpack.siem.overview.emptyActionPrimary": "セットアップの手順を表示", - "xpack.siem.overview.emptyActionSecondary": "ドキュメントに移動", - "xpack.siem.overview.emptyTitle": "SIEM アプリケーションに関連したインデックスがないようです", - "xpack.siem.overview.feedbackText": "Elastic SIEM に関するご意見やご提案は、お気軽に {feedback}", - "xpack.siem.overview.feedbackText.feedbackLinkText": "フィードバックをオンラインで送信", - "xpack.siem.overview.feedbackTitle": "フィードバック", - "xpack.siem.overview.filebeatCiscoTitle": "Filebeat Cisco", - "xpack.siem.overview.filebeatNetflowTitle": "Filebeat Netflow", - "xpack.siem.overview.filebeatPanwTitle": "Filebeat Palo Alto Networks", - "xpack.siem.overview.fileBeatSuricataTitle": "Filebeat Suricata", - "xpack.siem.overview.filebeatSystemModuleTitle": "Filebeat システムモジュール", - "xpack.siem.overview.fileBeatZeekTitle": "Filebeat Zeek", - "xpack.siem.overview.hostsAction": "ホストを表示", - "xpack.siem.overview.hostsSubtitle": "表示中:過去 24 時間", - "xpack.siem.overview.hostsTitle": "ホストイベント", - "xpack.siem.overview.networkAction": "ネットワークを表示", - "xpack.siem.overview.networkSubtitle": "表示中:過去 24 時間", - "xpack.siem.overview.networkTitle": "ネットワークイベント", - "xpack.siem.overview.packetBeatDnsTitle": "Packetbeat DNS", - "xpack.siem.overview.packetBeatFlowTitle": "Packetbeatフロー", - "xpack.siem.overview.packetbeatTLSTitle": "Packetbeat TLS", - "xpack.siem.overview.pageBadgeLabel": "ベータ", - "xpack.siem.overview.pageBadgeTooltip": "SIEM は現在ベータ段階です。Kibana repo で問題やバグを報告して、製品の改善にご協力ください。", - "xpack.siem.overview.pageSubtitle": "Elastic Stackによるセキュリティ情報とイベント管理", - "xpack.siem.overview.pageTitle": "SIEM", - "xpack.siem.overview.startedText": "セキュリティ情報およびイベント管理(SIEM)へようこそ。はじめに{docs}や{data}をご参照ください。今後の機能に関する情報やチュートリアルは、{siemSolution} ページをお見逃しなく。", - "xpack.siem.overview.startedText.dataLinkText": "投入データ", - "xpack.siem.overview.startedText.docsLinkText": "ドキュメンテーション", - "xpack.siem.overview.startedText.siemSolutionLinkText": "SIEM ソリューション", - "xpack.siem.overview.startedTitle": "はじめて使う", - "xpack.siem.overview.winlogbeatTitle": "Winlogbeat", - "xpack.siem.pages.fourohfour.noContentFoundDescription": "コンテンツがありません", - "xpack.siem.securityDescription": "SIEM アプリを閲覧します", - "xpack.siem.source.destination.packetsLabel": "パケット", - "xpack.siem.system.acceptedDescription": "以下を経由してユーザーを受け入れました:", - "xpack.siem.system.attemptedLoginDescription": "以下を経由してログインを試行しました:", - "xpack.siem.system.errorDescription": "以下でエラーが生じました:", - "xpack.siem.system.existingPackageDescription": "は既存のパッケージを使用しています", - "xpack.siem.system.existingProcessDescription": "がプロセスを実行しています", - "xpack.siem.system.existingSocketDescription": "が以下から既存のソケットを使用しています:", - "xpack.siem.system.existingUserDescription": "は既存のユーザーです", - "xpack.siem.system.hostDescription": "ホスト情報", - "xpack.siem.system.invalidDescription": "以下を使用しようとする無効な試み:", - "xpack.siem.system.loggedOutDescription": "以下を経由してログアウト:", - "xpack.siem.system.packageInstalledDescription": "パッケージをインストールしました", - "xpack.siem.system.packageRemovedDescription": "パッケージを削除しました", - "xpack.siem.system.packageSystemStartedDescription": "システムを開始しました", - "xpack.siem.system.packageUpdatedDescription": "パッケージを更新しました", - "xpack.siem.system.processErrorDescription": "次に関するプロセスエラーが発生:", - "xpack.siem.system.processStartedDescription": "プロセスを開始しました", - "xpack.siem.system.processStoppedDescription": "プロセスを停止しました", - "xpack.siem.system.socketClosedDescription": "以下とのソケットをクローズしました:", - "xpack.siem.system.socketOpenedDescription": "以下とソケットを開きました:", - "xpack.siem.system.systemDescription": "システム", - "xpack.siem.system.userAddedDescription": "ユーザーが追加されました", - "xpack.siem.system.userChangedDescription": "ユーザーが変更されました", - "xpack.siem.system.userRemovedDescription": "が削除されました", - "xpack.siem.system.usingDescription": "using", - "xpack.siem.system.wasAuthorizedToUseDescription": "が以下の使用を承認されました:", - "xpack.siem.system.withResultDescription": "結果付き", - "xpack.siem.tables.rowItemHelper.moreDescription": "行は表示されていません", - "xpack.siem.timeline.autosave.warning.description": "別のユーザーがこのタイムラインに変更を加えました。このタイムラインを更新してこれらの変更を取り入れるまで、ユーザーによる変更は自動的に保存されません。", - "xpack.siem.timeline.autosave.warning.refresh.title": "タイムラインを更新", - "xpack.siem.timeline.autosave.warning.title": "更新されるまで自動保存は無効です", - "xpack.siem.timeline.body.actions.collapseAriaLabel": "縮小", - "xpack.siem.timeline.body.actions.expandAriaLabel": "拡張", - "xpack.siem.timeline.body.copyToClipboardButtonLabel": "クリップボードにコピー", - "xpack.siem.timeline.body.notes.addOrViewNotesForThisEventTooltip": "このイベントのメモを追加または表示します", - "xpack.siem.timeline.body.pinning.pinnedTooltip": "イベントはこのタイムラインで継続しています", - "xpack.siem.timeline.body.pinning.pinnnedWithNotesTooltip": "イベントにメモがあり、ピンを外すことができません", - "xpack.siem.timeline.body.pinning.unpinnedTooltip": "このイベントはタイムラインと共に継続していません", - "xpack.siem.timeline.categoryTooltip": "カテゴリー", - "xpack.siem.timeline.descriptionTooltip": "説明", - "xpack.siem.timeline.destination": "送信先", - "xpack.siem.timeline.eventsSelect.actions.pinSelected": "選択項目にピン付け", - "xpack.siem.timeline.eventsSelect.actions.selectAll": "すべて", - "xpack.siem.timeline.eventsSelect.actions.selectNone": "なし", - "xpack.siem.timeline.eventsSelect.actions.selectPinned": "ピン付け済み", - "xpack.siem.timeline.eventsSelect.actions.selectUnpinned": "ピンが外されました", - "xpack.siem.timeline.eventsSelect.actions.unpinSelected": "選択項目のピンを外す", - "xpack.siem.timeline.expandableEvent.copyToClipboardToolTip": "クリップボードにコピー", - "xpack.siem.timeline.expandableEvent.eventToolTipTitle": "イベント", - "xpack.siem.timeline.fieldTooltip": "フィールド", - "xpack.siem.timeline.flyout.pane.closeTimelineButtonLabel": "タイムラインを閉じる", - "xpack.siem.timeline.flyout.pane.removeColumnButtonLabel": "列を削除", - "xpack.siem.timeline.flyout.pane.timelinePropertiesAriaLabel": "タイムラインのプロパティ", - "xpack.siem.timeline.properties.descriptionPlaceholder": "説明", - "xpack.siem.timeline.properties.descriptionTooltip": "このタイムラインのイベントのサマリーとメモ", - "xpack.siem.timeline.properties.favoriteTooltip": "お気に入り", - "xpack.siem.timeline.properties.historyLabel": "履歴", - "xpack.siem.timeline.properties.historyToolTip": "このタイムラインに関連したアクションの履歴", - "xpack.siem.timeline.properties.isViewingTooltip": "がこのタイムラインを表示しています", - "xpack.siem.timeline.properties.lockDatePickerDescription": "日付ピッカーをグローバル日付ピッカーにロック", - "xpack.siem.timeline.properties.lockDatePickerTooltip": "現在表示中のページとタイムラインの間の日付/時刻範囲の同期を無効にします", - "xpack.siem.timeline.properties.newTimelineButtonLabel": "新規タイムラインを作成", - "xpack.siem.timeline.properties.notAFavoriteTooltip": "お気に入りではありません", - "xpack.siem.timeline.properties.notesButtonLabel": "メモ", - "xpack.siem.timeline.properties.notesToolTip": "このタイムラインに関するメモを追加して確認します。メモはイベントにも追加できます。", - "xpack.siem.timeline.properties.streamLiveButtonLabel": "ライブストリーム", - "xpack.siem.timeline.properties.streamLiveToolTip": "新しいデータが利用可能になるにつれタイムラインを更新します", - "xpack.siem.timeline.properties.timelineDescription": "タイムラインの説明", - "xpack.siem.timeline.properties.timelineTitleAriaLabel": "タイムラインのタイトル", - "xpack.siem.timeline.properties.titleTitle": "タイトル", - "xpack.siem.timeline.properties.unlockDatePickerDescription": "日付ピッカーのグローバル日付ピッカーへのロックを解除", - "xpack.siem.timeline.properties.unlockDatePickerTooltip": "現在表示中のページとタイムラインの間の日付/時刻範囲の同期を有効にします", - "xpack.siem.timeline.properties.untitledTimelinePlaceholder": "無題のタイムライン", - "xpack.siem.timeline.protocol": "プロトコル", - "xpack.siem.timeline.rangePicker.oneDay": "1 日", - "xpack.siem.timeline.rangePicker.oneMonth": "1 か月", - "xpack.siem.timeline.rangePicker.oneWeek": "1 週間", - "xpack.siem.timeline.rangePicker.oneYear": "1 年", - "xpack.siem.timeline.searchOrFilter.filterDescription": "上のデータプロバイダーからのイベントは、隣接の KQL でフィルターされます", - "xpack.siem.timeline.searchOrFilter.filterKqlPlaceholder": "イベントをフィルター", - "xpack.siem.timeline.searchOrFilter.filterKqlSelectedText": "フィルター", - "xpack.siem.timeline.searchOrFilter.filterKqlTooltip": "上のデータプロバイダーからのイベントは、この KQL でフィルターされます", - "xpack.siem.timeline.searchOrFilter.filterOrSearchWithKql": "KQLでフィルターまたは検索", - "xpack.siem.timeline.searchOrFilter.searchDescription": "上のデータプロバイダーからのイベントは、隣接のKQLからの結果と組み合わされます。", - "xpack.siem.timeline.searchOrFilter.searchKqlPlaceholder": "イベントを検索", - "xpack.siem.timeline.searchOrFilter.searchKqlSelectedText": "検索", - "xpack.siem.timeline.searchOrFilter.searchKqlTooltip": "上のデータプロバイダーからのイベントは、この KQL からの結果と組み合わされます。", - "xpack.siem.timeline.source": "送信元", - "xpack.siem.timeline.tcp": "TCP", - "xpack.siem.timeline.typeTooltip": "タイプ", - "xpack.siem.timelines.allTimelines.panelTitle": "すべてのタイムライン", - "xpack.siem.timelines.pageTitle": "タイムライン", - "xpack.siem.uiSettings.defaultIndexDescription": "

SIEM アプリがイベントを収集する Elasticsearch インデックスのコンマ区切りのリストです。

", - "xpack.siem.uiSettings.defaultIndexLabel": "デフォルトのインデックス", - "xpack.siem.uncommonProcessTable.hostsTitle": "すべてのホスト", - "xpack.siem.uncommonProcessTable.lastCommandTitle": "前回のコマンド", - "xpack.siem.uncommonProcessTable.lastUserTitle": "前回のユーザー", - "xpack.siem.uncommonProcessTable.nameTitle": "名前", - "xpack.siem.uncommonProcessTable.numberOfHostsTitle": "ホスト数", - "xpack.siem.uncommonProcessTable.numberOfInstances": "インスタンス", - "xpack.siem.uncommonProcessTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", - "xpack.siem.uncommonProcessTable.unit": "{totalCount, plural, =1 {process} other {processes}}", - "xpack.siem.zeek.othDescription": "SYNが検出されません。ミッドストリームトラフィックのみです", - "xpack.siem.zeek.rejDescription": "接続試行が拒否されました", - "xpack.siem.zeek.rstoODescription": "接続が確立され、接続元が中断しました(RSTを送信)", - "xpack.siem.zeek.rstosoDescription": "接続元がRSTに続きSYNを送信しました。レスポンダーからSYN-ACKはありません", - "xpack.siem.zeek.rstrDescription": "確立され、レスポンダーが中断しました", - "xpack.siem.zeek.rstrhDescription": "レスポンダーがRSTに続き SYNを送信しました。接続元(推定)からSYN-ACKはありません", - "xpack.siem.zeek.s0Description": "接続試行を検出し、返答はありません", - "xpack.siem.zeek.s1Description": "接続が確立され、中断されていません", - "xpack.siem.zeek.s2Description": "接続が確立され、接続元からの終了試行が検出されました(レスポンダーからの返答はありません)", - "xpack.siem.zeek.s3Description": "接続が確立され、レスポンダーからの終了試行が検出されました(接続元からの返答はありません)", - "xpack.siem.zeek.sfDescription": "通常のSYN/FIN完了", - "xpack.siem.zeek.shDescription": "接続元がFINに続きSYNを送信しました。レスポンダーからSYN-ACKはありません", - "xpack.siem.zeek.shrDescription": "レスポンダーがFINに続きSYNを送信しました。接続元からSYN-ACKはありません", - "xpack.siem.anomaliesTable.table.anomaliesTooltip": "異常表は SIEM グローバル KQL 検索でフィルタリングできません。", - "xpack.siem.anomaliesTable.table.unit": "{totalCount, plural, =1 {anomaly} other {anomalies}}", - "xpack.siem.clipboard.copy.to.the.clipboard": "クリップボードにコピー", - "xpack.siem.components.embeddables.indexPatternsMissingPrompt.errorButtonLabel": "インデックスパターンを編集", - "xpack.siem.components.embeddables.indexPatternsMissingPrompt.errorTitle": "必要なインデックスパターンが構成されていません", - "xpack.siem.components.ml.anomaly.errors.anomaliesTableFetchFailureTitle": "異常表の取得に失敗", - "xpack.siem.components.ml.api.errors.networkErrorFailureTitle": "ネットワークエラー", - "xpack.siem.components.ml.api.errors.statusCodeFailureTitle": "ステータスコード:", - "xpack.siem.components.ml.permissions.errors.machineLearningPermissionsFailureTitle": "機械学習パーミッションエラー", - "xpack.siem.components.mlPopup.anomalyDetectionButtonLabel": "異常検知", - "xpack.siem.components.mlPopup.anomalyDetectionDescription": "下のいずれかの機械学習ジョブを実行して、SIEM アプリケーション全体の異常イベントを表示することができます。始めに使えるように、いくつかの一般的な検出ジョブが提供されています。独自のカスタムジョブを追加する場合は、{machineLearning} アプリケーションでジョブを作成して「SIEM」でタグ付けすると、ここに追加されます。", - "xpack.siem.components.mlPopup.anomalyDetectionTitle": "異常検知設定", - "xpack.siem.components.mlPopup.errors.createJobFailureTitle": "ジョブ作成エラー", - "xpack.siem.components.mlPopup.errors.startJobFailureTitle": "ジョブ開始エラー", - "xpack.siem.components.mlPopup.hooks.errors.indexPatternFetchFailureTitle": "インデックスパターン取得エラー", - "xpack.siem.components.mlPopup.hooks.errors.siemJobFetchFailureTitle": "SIEM ジョブ取得エラー", - "xpack.siem.components.mlPopup.jobsTable.createCustomJobButtonLabel": "カスタムジョブを作成", - "xpack.siem.components.mlPopup.jobsTable.jobNameColumn": "ジョブ名", - "xpack.siem.components.mlPopup.jobsTable.noItemsDescription": "SIEM 機械学習ジョブが見つかりませんでした", - "xpack.siem.components.mlPopup.jobsTable.runJobColumn": "ジョブを実行", - "xpack.siem.components.mlPopup.machineLearningLink": "Machine Learning", - "xpack.siem.components.mlPopup.showingLabel": "{filterResultsLength} 件の{filterResultsLength, plural, one {ジョブ} other {ジョブ}}を表示中", - "xpack.siem.components.mlPopup.upgradeButtonLabel": "サブスクリプションオプション", - "xpack.siem.components.mlPopup.upgradeTitle": "E lastic Platinum へのアップグレード", - "xpack.siem.containers.errors.stopJobFailureTitle": "ジョブ停止エラー", - "xpack.siem.eventDetails.blank": " ", - "xpack.siem.eventDetails.toggleColumnTooltip": "列を切り替えます", - "xpack.siem.eventsViewer.eventsLabel": "イベント", - "xpack.siem.eventsViewer.showingLabel": "表示中", - "xpack.siem.eventsViewer.unit": "{totalCount, plural, =1 {event} other {events}}", - "xpack.siem.fieldBrowser.toggleColumnTooltip": "列を切り替えます", - "xpack.siem.hosts.navigation.allHostsTitle": "すべてのホスト", - "xpack.siem.hosts.navigation.anomaliesTitle": "異常", - "xpack.siem.hosts.navigation.authenticationsTitle": "認証", - "xpack.siem.hosts.navigation.eventsTitle": "イベント", - "xpack.siem.hosts.navigation.uncommonProcessesTitle": "非共通プロセス", - "xpack.siem.inspect.modal.indexPatternDescription": "Elasticsearch インデックスに接続したインデックスパターンです。これらのインデックスは Kibana > 高度な設定で構成できます。", - "xpack.siem.inspect.modal.indexPatternLabel": "インデックスパターン", - "xpack.siem.inspect.modal.queryTimeDescription": "クエリの処理の所要時間です。リクエストの送信やブラウザでのパースの時間は含まれません。", - "xpack.siem.inspect.modal.queryTimeLabel": "クエリ時間", - "xpack.siem.inspect.modal.reqTimestampDescription": "リクエストの開始が記録された時刻です", - "xpack.siem.inspect.modal.reqTimestampLabel": "リクエストのタイムスタンプ", - "xpack.siem.inspect.modal.somethingWentWrongDescription": "申し訳ございませんが、何か問題が発生しました。", - "xpack.siem.kpiHosts.hosts.title": "すべてのホスト", - "xpack.siem.kpiHosts.uniqueIps.destinationChartLabel": "Dest.", - "xpack.siem.kpiHosts.uniqueIps.destinationUnitLabel": "デスティネーション", - "xpack.siem.kpiHosts.uniqueIps.sourceChartLabel": "Src.", - "xpack.siem.kpiHosts.uniqueIps.sourceUnitLabel": "ソース", - "xpack.siem.kpiHosts.uniqueIps.title": "固有の IP", - "xpack.siem.kpiHosts.userAuthentications.failChartLabel": "失敗", - "xpack.siem.kpiHosts.userAuthentications.failUnitLabel": "失敗", - "xpack.siem.kpiHosts.userAuthentications.successChartLabel": "成功", - "xpack.siem.kpiHosts.userAuthentications.successUnitLabel": "成功", - "xpack.siem.kpiHosts.userAuthentications.title": "ユーザー認証", - "xpack.siem.kpiNetwork.dnsQueries.title": "DNS クエリ", - "xpack.siem.kpiNetwork.networkEvents.title": "ネットワークイベント", - "xpack.siem.kpiNetwork.tlsHandshakes.title": "TLSハンドシェイク", - "xpack.siem.kpiNetwork.uniqueFlowIds.title": "固有のフロー ID", - "xpack.siem.kpiNetwork.uniquePrivateIps.destinationChartLabel": "Dest.", - "xpack.siem.kpiNetwork.uniquePrivateIps.destinationUnitLabel": "デスティネーション", - "xpack.siem.kpiNetwork.uniquePrivateIps.sourceChartLabel": "Src.", - "xpack.siem.kpiNetwork.uniquePrivateIps.sourceUnitLabel": "ソース", - "xpack.siem.kpiNetwork.uniquePrivateIps.title": "固有のプライベート IP", - "xpack.siem.ml.score.anomalousEntityTitle": "異常エンティティ", - "xpack.siem.ml.table.timestampTitle": "タイムスタンプ", - "xpack.siem.modalAllErrors.close.button": "閉じる", - "xpack.siem.modalAllErrors.seeAllErrors.button": "完全なエラーを表示", - "xpack.siem.modalAllErrors.title": "ビジュアライゼーションにエラーがあります", - "xpack.siem.networkTopNFlowTable.column.asTitle": "自動システム", - "xpack.siem.networkTopNFlowTable.column.bytesInTitle": "受信バイト", - "xpack.siem.networkTopNFlowTable.column.bytesOutTitle": "送信バイト", - "xpack.siem.networkTopNFlowTable.column.domainTitle": "ドメイン", - "xpack.siem.networkTopNFlowTable.column.IpTitle": "IP", - "xpack.siem.networkTopNFlowTable.destinationIps": "デスティネーション IP", - "xpack.siem.networkTopNFlowTable.flows": "Flow", - "xpack.siem.networkTopNFlowTable.sourceIps": "ソース IP", - "xpack.siem.paginatedTable.rowsButtonLabel": "ページごとの行数", - "xpack.siem.paginatedTable.showingSubtitle": "表示中", - "xpack.siem.paginatedTable.tooManyResultsToastText": "クエリ範囲を縮めて結果をさらにフィルタリングしてください", - "xpack.siem.paginatedTable.tooManyResultsToastTitle": " - 結果が多すぎます", - "xpack.siem.timeline.callOut.unauthorized.message.description": "SIEM アプリケーションでタイムラインを自動保存するにはパーミッションが必要ですが、引き続きタイムラインを使用してセキュリティイベントの検索とフィルタリングを行うことはできます。", - "xpack.siem.uiSettings.defaultAnomalyScoreDescription": "

機械学習ジョブの異常がこの値を超えると SIEM アプリに表示されます。

有効な値:0 ~ 100。

", - "xpack.siem.uiSettings.defaultAnomalyScoreLabel": "デフォルトの異常しきい値", - "xpack.siem.uiSettings.defaultRefreshIntervalDescription": "

SIEM 時間フィルターのミリ単位のデフォルトの更新間隔です。

", - "xpack.siem.uiSettings.defaultRefreshIntervalLabel": "タイムピッカーの更新間隔", - "xpack.siem.uiSettings.defaultTimeRangeDescription": "

SIEM 時間フィルダーのデフォルトの期間です。

", - "xpack.siem.uiSettings.defaultTimeRangeLabel": "デフォルトのタイムピッカー", - "xpack.siem.host.details.overview.maxAnomalyScoreByJobTitle": "ジョブ別の最高異常スコア", - "xpack.siem.ml.score.anomalyJobTitle": "ジョブ", - "xpack.siem.ml.table.detectorTitle": "ジョブ名", - "xpack.siem.ml.table.hostNameTitle": "ホスト名", - "xpack.siem.ml.table.influencedByTitle": "影響因子:", - "xpack.siem.ml.table.scoreTitle": "異常スコア", - "xpack.siem.network.ipDetails.ipOverview.maxAnomalyScoreByJobTitle": "ジョブ別の最高異常スコア", - "xpack.siem.chart.dataAllValuesZerosTitle": "すべての値はゼロを返します", - "xpack.siem.components.embeddables.embeddedMap.destinationLayerLabel": "デスティネーションポイント", - "xpack.siem.components.embeddables.embeddedMap.embeddablePanelTitle": "ソース -> デスティネーション ポイントツーポイントマップ", - "xpack.siem.components.embeddables.embeddedMap.errorConfiguringEmbeddableApiTitle": "埋め込み可能な API の構成中にエラーが発生", - "xpack.siem.components.embeddables.embeddedMap.errorCreatingMapEmbeddableTitle": "マップに’埋め込み可能なアイテムの作成中にエラーが発生", - "xpack.siem.components.embeddables.embeddedMap.lineLayerLabel": "折れ線", - "xpack.siem.components.embeddables.embeddedMap.sourceLayerLabel": "ソースポイント", - "xpack.siem.components.embeddables.mapToolTip.errorTitle": "マップ機能の読み込み中にエラーが発生", - "xpack.siem.components.embeddables.mapToolTip.filterForValueHoverAction": "値でフィルターします", - "xpack.siem.components.embeddables.mapToolTip.footerLabel": "{totalFeatures} 件中 {currentFeature} 件 {totalFeatures, plural, =1 {feature} other {features}}", - "xpack.siem.components.embeddables.mapToolTip.lineContent.destinationLabel": "送信先", - "xpack.siem.components.embeddables.mapToolTip.lineContent.sourceLabel": "送信元", - "xpack.siem.components.embeddables.mapToolTip.pointContent.asnTitle": "ASN", - "xpack.siem.components.embeddables.mapToolTip.pointContent.destinationDomainTitle": "デスティネーションドメイン", - "xpack.siem.components.embeddables.mapToolTip.pointContent.destinationIPTitle": "デスティネーション IP", - "xpack.siem.components.embeddables.mapToolTip.pointContent.hostTitle": "ホスト", - "xpack.siem.components.embeddables.mapToolTip.pointContent.locationTitle": "場所", - "xpack.siem.components.embeddables.mapToolTip.pointContent.sourceDomainTitle": "ソースドメイン", - "xpack.siem.components.embeddables.mapToolTip.pointContent.sourceIPTitle": "ソース IP", - "xpack.siem.components.mlPopover.jobsTable.filters.groupsLabel": "グループ", - "xpack.siem.components.mlPopover.jobsTable.filters.noGroupsAvailableDescription": "利用可能なグループがありません", - "xpack.siem.components.mlPopover.jobsTable.filters.searchFilterPlaceholder": "例: rare_process_linux", - "xpack.siem.components.mlPopover.jobsTable.filters.showAllJobsLabel": "Elastic ジョブ", - "xpack.siem.components.mlPopover.jobsTable.filters.showSiemJobsLabel": "カスタムジョブ", - "xpack.siem.components.mlPopup.cloudLink": "クラウド展開", - "xpack.siem.components.mlPopup.jobsTable.tagsColumn": "グループ", - "xpack.siem.components.mlPopup.licenseButtonLabel": "ライセンスの管理", - "xpack.siem.components.mlPopup.moduleNotCompatibleTitle": "{incompatibleJobCount} 件が {incompatibleJobCount, plural, =1 {job} other {jobs}} 現在利用できません", - "xpack.siem.eventsOverTime.eventCountFrequencyByActionTitle": "アクション別のイベントカウント", - "xpack.siem.eventsOverTime.showing": "表示中", - "xpack.siem.eventsOverTime.unit": "{totalCount, plural, =1 {event} other {events}}", - "xpack.siem.flyout.button.text": "タイムライン", - "xpack.siem.network.navigation.anomaliesTitle": "異常", - "xpack.siem.network.navigation.dnsTitle": "DNS", - "xpack.siem.network.navigation.flowsTitle": "Flow", - "xpack.siem.network.navigation.tlsTitle": "TLS", - "xpack.siem.networkTopCountriesTable.column.bytesInTitle": "受信バイト", - "xpack.siem.networkTopCountriesTable.column.bytesOutTitle": "送信バイト", - "xpack.siem.networkTopCountriesTable.column.countryTitle": "国", - "xpack.siem.networkTopCountriesTable.column.destinationIps": "デスティネーション IP", - "xpack.siem.networkTopCountriesTable.column.flows": "Flow", - "xpack.siem.networkTopCountriesTable.column.sourceIps": "ソース IP", - "xpack.siem.networkTopCountriesTable.heading.destinationCountries": "デスティネーションの国", - "xpack.siem.networkTopCountriesTable.heading.sourceCountries": "ソースの国", - "xpack.siem.networkTopCountriesTable.heading.unit": "{totalCount, plural, =1 {Country} other {Countries}}", - "xpack.siem.networkTopCountriesTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", - "xpack.siem.overview.endgameDnsTitle": "Endgame DNS", - "xpack.siem.overview.endgameFileTitle": "Endgame ファイル", - "xpack.siem.overview.endgameImageLoadTitle": "Endgame 画像の読み込み", - "xpack.siem.overview.endgameNetworkTitle": "Endgame ネットワーク", - "xpack.siem.overview.endgameProcessTitle": "Endgame プロセス", - "xpack.siem.overview.endgameRegistryTitle": "Endgame レジストリ", - "xpack.siem.overview.endgameSecurityTitle": "Endgame セキュリティ", - "xpack.siem.system.acceptedAConnectionViaDescription": "次の手段で接続を受け付けました:", - "xpack.siem.system.createdFileDescription": "ファイルを作成しました", - "xpack.siem.system.deletedFileDescription": "ファイルを削除しました", - "xpack.siem.system.disconnectedViaDescription": "次の手段で接続を解除しました", - "xpack.siem.system.terminatedProcessDescription": "プロセスを中断しました", - "xpack.siem.system.viaDescription": "経由", - "xpack.siem.system.viaParentProcessDescription": "親プロセスで", - "xpack.siem.system.withExitCodeDescription": "終了コードで", - "xpack.siem.timeline.body.renderers.dns.askedForDescription": "要求された", - "xpack.siem.timeline.body.renderers.dns.responseCodeDescription": "応答コード", - "xpack.siem.timeline.body.renderers.dns.viaDescription": "経由", - "xpack.siem.timeline.body.renderers.dns.whichResolvedToDescription": "で解決する", - "xpack.siem.timeline.body.renderers.dns.withQuestionTypeDescription": "質問タイプで", - "xpack.siem.timeline.body.renderers.endgame.aLoginWasAttemptedUsingExplicitCredentialsDescription": "明示認証情報でログインが試みられました", - "xpack.siem.timeline.body.renderers.endgame.asRequestedBySubjectDescription": "サブジェクトにリクエストされた通り", - "xpack.siem.timeline.body.renderers.endgame.loggedOffDescription": "ログオフ", - "xpack.siem.timeline.body.renderers.endgame.logonTypeBatchDescription": "一斉", - "xpack.siem.timeline.body.renderers.endgame.logonTypeCachedInteractiveDescription": "キャッシュインタラクティブ", - "xpack.siem.timeline.body.renderers.endgame.logonTypeInteractiveDescription": "インタラクティブ", - "xpack.siem.timeline.body.renderers.endgame.logonTypeNetworkCleartextDescription": "ネットワーククリアテキスト", - "xpack.siem.timeline.body.renderers.endgame.logonTypeNetworkDescription": "ネットワーク", - "xpack.siem.timeline.body.renderers.endgame.logonTypeNewCredentialsDescription": "新規認証情報", - "xpack.siem.timeline.body.renderers.endgame.logonTypeRemoteInteractiveDescription": "リモートインタラクティブ", - "xpack.siem.timeline.body.renderers.endgame.logonTypeServiceDescription": "サービス", - "xpack.siem.timeline.body.renderers.endgame.logonTypeUnlockDescription": "ロック解除", - "xpack.siem.timeline.body.renderers.endgame.subjectLogonIdDescription": "サブジェクトログオン ID", - "xpack.siem.timeline.body.renderers.endgame.successfullyLoggedInDescription": "正常にログイン", - "xpack.siem.timeline.body.renderers.endgame.targetLogonIdDescription": "ターゲットログオン ID", - "xpack.siem.timeline.body.renderers.endgame.toDescription": "に", - "xpack.siem.timeline.body.renderers.endgame.usingLogonTypeDescription": "ログオンタイプを使用して", - "xpack.siem.timeline.body.renderers.endgame.viaDescription": "経由", - "xpack.siem.timeline.body.renderers.endgame.withSpecialPrivilegesDescription": "割り当てられた特別な権限", - "xpack.siem.components.mlPopup.upgradeDescription": "SIEM の異常検出機能にアクセスするには、ライセンスをプラチナに更新するか、30 日間の無料トライアルを開始するか、AWS、GCP、または Azure で{cloudLink} にサインアップしてください。その後、機械学習ジョブを実行して異常を表示できます。", - "xpack.snapshotRestore.addRepository.breadcrumbTitle": "レポジトリの追加", - "xpack.snapshotRestore.addRepository.savingRepositoryErrorTitle": "新規レポジトリを登録できません", - "xpack.snapshotRestore.addRepositoryButtonLabel": "レポジトリを登録", - "xpack.snapshotRestore.addRepositoryTitle": "レポジトリの登録", - "xpack.snapshotRestore.appName": "スナップショットリポジドリ", - "xpack.snapshotRestore.dataPlaceholderLabel": "-", - "xpack.snapshotRestore.deleteRepository.confirmModal.cancelButtonLabel": "キャンセル", - "xpack.snapshotRestore.deleteRepository.confirmModal.confirmMultipleButtonLabel": "レポジトリを削除", - "xpack.snapshotRestore.deleteRepository.confirmModal.confirmSingleButtonLabel": "レポジトリを削除", - "xpack.snapshotRestore.deleteRepository.confirmModal.deleteMultipleDescription": "これらのレポジトリのスナップショットは現在も存在しますが、Elasticsearch はこれらにアクセスできません。スケジュールされたスナップショットがエラーにならないように、これらのレポジトリを使用するポリシーを調整してください。", - "xpack.snapshotRestore.deleteRepository.confirmModal.deleteMultipleListDescription": "これらのリモートクラスターを削除しようとしています:", - "xpack.snapshotRestore.deleteRepository.confirmModal.deleteMultipleTitle": "{count} 件のレポジトリを削除しますか?", - "xpack.snapshotRestore.deleteRepository.confirmModal.deleteSingleDescription": "これらのレポジトリのスナップショットは現在も存在しますが、Elasticsearch はこれらにアクセスできません。スケジュールされたスナップショットがエラーにならないように、このレポジトリを使用するポリシーを調整してください。", - "xpack.snapshotRestore.deleteRepository.confirmModal.deleteSingleTitle": "レポジトリ「{name}」を削除しますか?", - "xpack.snapshotRestore.deleteRepository.errorMultipleNotificationTitle": "{count} 件のレポジトリの削除中にエラーが発生", - "xpack.snapshotRestore.deleteRepository.errorSingleNotificationTitle": "{name} 件のレポジトリの削除中にエラーが発生", - "xpack.snapshotRestore.deleteRepository.successMultipleNotificationTitle": "{count} 件のレポジトリが削除されました", - "xpack.snapshotRestore.deleteRepository.successSingleNotificationTitle": "レポジトリ「{name}」が削除されました", - "xpack.snapshotRestore.editRepository.breadcrumbTitle": "レポジトリの編集", - "xpack.snapshotRestore.editRepository.loadingRepositoryDescription": "レポジトリ情報を読み込み中…", - "xpack.snapshotRestore.editRepository.loadingRepositoryErrorTitle": "レポジトリ情報の読み込み中にエラーが発生", - "xpack.snapshotRestore.editRepository.managedRepositoryWarningTitle": "これは管理されているレポジトリです。このレポジトリを変更すると、他に使用しているクエリに影響が及ぶ可能性があります。ご注意ください。", - "xpack.snapshotRestore.editRepository.repositoryNotFoundErrorMessage": "レポジトリ「{name}」は存在しません。", - "xpack.snapshotRestore.editRepository.savingRepositoryErrorTitle": "レポジトリを保存できません", - "xpack.snapshotRestore.editRepositoryTitle": "レポジトリの編集", - "xpack.snapshotRestore.emptyPrompt.noSnapshotsDocLinkText": "スナップショットの作成方法をご覧ください", - "xpack.snapshotRestore.home.breadcrumbTitle": "スナップショットリポジドリ", - "xpack.snapshotRestore.home.repositoriesTabTitle": "レポジトリ", - "xpack.snapshotRestore.home.snapshotRestoreDescription": "レポジトリを使用して Elasticsearch のインデックスとクラスターのバックアップを保管します。", - "xpack.snapshotRestore.home.snapshotRestoreDocsLinkText": "ドキュメントのスナップショット", - "xpack.snapshotRestore.home.snapshotRestoreTitle": "スナップショットリポジドリ", - "xpack.snapshotRestore.home.snapshotsTabTitle": "スナップショット", - "xpack.snapshotRestore.repositoryDetails.closeButtonLabel": "閉じる", - "xpack.snapshotRestore.repositoryDetails.editButtonLabel": "編集", - "xpack.snapshotRestore.repositoryDetails.genericSettingsDescription": "レポジトリ「{name}」のランダムな設定です", - "xpack.snapshotRestore.repositoryDetails.loadingRepositoryDescription": "レポジトリを読み込み中…", - "xpack.snapshotRestore.repositoryDetails.loadingRepositoryErrorTitle": "レポジトリの読み込み中にエラーが発生", - "xpack.snapshotRestore.repositoryDetails.managedRepositoryWarningTitle": "これは管理されているレポジトリで、他のシステムにより使用されています。変更を加えるとこれらのシステムのオペレーションに影響が及ぶ可能性があります。", - "xpack.snapshotRestore.repositoryDetails.noSnapshotInformationDescription": "スナップショット情報がありません", - "xpack.snapshotRestore.repositoryDetails.removeButtonLabel": "削除", - "xpack.snapshotRestore.repositoryDetails.removeManagedRepositoryButtonTitle": "管理されているレポジトリは削除できません。", - "xpack.snapshotRestore.repositoryDetails.repositoryNotFoundErrorMessage": "レポジトリ「{name}」は存在しません。", - "xpack.snapshotRestore.repositoryDetails.repositoryTypeDocLink": "レポジトリドキュメント", - "xpack.snapshotRestore.repositoryDetails.settingsTitle": "設定", - "xpack.snapshotRestore.repositoryDetails.snapshotsDescription": "{count} 件の {count, plural, one {スナップショット} other {スナップショット}}が見つかりました", - "xpack.snapshotRestore.repositoryDetails.snapshotsTitle": "スナップショット", - "xpack.snapshotRestore.repositoryDetails.typeAzure.basePathLabel": "ベースパス", - "xpack.snapshotRestore.repositoryDetails.typeAzure.chunkSizeLabel": "チャンクサイズ", - "xpack.snapshotRestore.repositoryDetails.typeAzure.clientLabel": "クライアント", - "xpack.snapshotRestore.repositoryDetails.typeAzure.compressLabel": "スナップショットの圧縮", - "xpack.snapshotRestore.repositoryDetails.typeAzure.containerLabel": "コンテナー", - "xpack.snapshotRestore.repositoryDetails.typeAzure.locationModeLabel": "位置情報モード", - "xpack.snapshotRestore.repositoryDetails.typeAzure.maxRestoreBytesLabel": "1 秒間の最高復元バイト数", - "xpack.snapshotRestore.repositoryDetails.typeAzure.maxSnapshotBytesLabel": "1 秒間の最高スナップショットバイト数", - "xpack.snapshotRestore.repositoryDetails.typeAzure.readonlyLabel": "読み込み専用", - "xpack.snapshotRestore.repositoryDetails.typeFS.chunkSizeLabel": "チャンクサイズ", - "xpack.snapshotRestore.repositoryDetails.typeFS.compressLabel": "スナップショットの圧縮", - "xpack.snapshotRestore.repositoryDetails.typeFS.locationLabel": "場所", - "xpack.snapshotRestore.repositoryDetails.typeFS.maxRestoreBytesLabel": "1 秒間の最高復元バイト数", - "xpack.snapshotRestore.repositoryDetails.typeFS.maxSnapshotBytesLabel": "1 秒間の最高スナップショットバイト数", - "xpack.snapshotRestore.repositoryDetails.typeFS.readonlyLabel": "読み込み専用", - "xpack.snapshotRestore.repositoryDetails.typeGCS.basePathLabel": "ベースパス", - "xpack.snapshotRestore.repositoryDetails.typeGCS.bucketLabel": "バケット", - "xpack.snapshotRestore.repositoryDetails.typeGCS.chunkSizeLabel": "チャンクサイズ", - "xpack.snapshotRestore.repositoryDetails.typeGCS.clientLabel": "クライアント", - "xpack.snapshotRestore.repositoryDetails.typeGCS.compressLabel": "スナップショットの圧縮", - "xpack.snapshotRestore.repositoryDetails.typeGCS.maxRestoreBytesLabel": "1 秒間の最高復元バイト数", - "xpack.snapshotRestore.repositoryDetails.typeGCS.maxSnapshotBytesLabel": "1 秒間の最高スナップショットバイト数", - "xpack.snapshotRestore.repositoryDetails.typeGCS.readonlyLabel": "読み込み専用", - "xpack.snapshotRestore.repositoryDetails.typeHDFS.chunkSizeLabel": "チャンクサイズ", - "xpack.snapshotRestore.repositoryDetails.typeHDFS.compressLabel": "スナップショットの圧縮", - "xpack.snapshotRestore.repositoryDetails.typeHDFS.loadDefaultsLabel": "デフォルトを読み込む", - "xpack.snapshotRestore.repositoryDetails.typeHDFS.maxRestoreBytesLabel": "1 秒間の最高復元バイト数", - "xpack.snapshotRestore.repositoryDetails.typeHDFS.maxSnapshotBytesLabel": "1 秒間の最高スナップショットバイト数", - "xpack.snapshotRestore.repositoryDetails.typeHDFS.pathLabel": "パス", - "xpack.snapshotRestore.repositoryDetails.typeHDFS.readonlyLabel": "読み込み専用", - "xpack.snapshotRestore.repositoryDetails.typeHDFS.securityPrincipalLabel": "セキュリティプリンシパル", - "xpack.snapshotRestore.repositoryDetails.typeHDFS.uriLabel": "URI", - "xpack.snapshotRestore.repositoryDetails.typeReadonly.urlLabel": "URL", - "xpack.snapshotRestore.repositoryDetails.typeS3.basePathLabel": "ベースパス", - "xpack.snapshotRestore.repositoryDetails.typeS3.bucketLabel": "バケット", - "xpack.snapshotRestore.repositoryDetails.typeS3.bufferSizeLabel": "バッファーサイズ", - "xpack.snapshotRestore.repositoryDetails.typeS3.cannedAclLabel": "Canned ACL", - "xpack.snapshotRestore.repositoryDetails.typeS3.chunkSizeLabel": "チャンクサイズ", - "xpack.snapshotRestore.repositoryDetails.typeS3.clientLabel": "クライアント", - "xpack.snapshotRestore.repositoryDetails.typeS3.compressLabel": "スナップショットの圧縮", - "xpack.snapshotRestore.repositoryDetails.typeS3.maxRestoreBytesLabel": "1 秒間の最高復元バイト数", - "xpack.snapshotRestore.repositoryDetails.typeS3.maxSnapshotBytesLabel": "1 秒間の最高スナップショットバイト数", - "xpack.snapshotRestore.repositoryDetails.typeS3.readonlyLabel": "読み込み専用", - "xpack.snapshotRestore.repositoryDetails.typeS3.serverSideEncryptionLabel": "サーバー側エコシステム", - "xpack.snapshotRestore.repositoryDetails.typeS3.storageClassLabel": "ストレージクラス", - "xpack.snapshotRestore.repositoryDetails.typeTitle": "レポジトリタイプ", - "xpack.snapshotRestore.repositoryDetails.verificationDetailsTitle": "詳細", - "xpack.snapshotRestore.repositoryDetails.verificationTitle": "認証ステータス", - "xpack.snapshotRestore.repositoryDetails.verifyButtonLabel": "レポジトリを検証", - "xpack.snapshotRestore.repositoryDetails.zeroSnapshotsDescription": "レポジトリにスナップショットがありません", - "xpack.snapshotRestore.repositoryFor.typeFS.locationDescription": "すべてのマスターおよびデータノードで {settingKey} 設定に場所を登録する必要があります。", - "xpack.snapshotRestore.repositoryForm.backButtonLabel": "戻る", - "xpack.snapshotRestore.repositoryForm.errorUnknownRepositoryTypesMessage": "レポジトリタイプ「{type}」はサポートされていません。", - "xpack.snapshotRestore.repositoryForm.errorUnknownRepositoryTypesTitle": "不明なレポジトリタイプ", - "xpack.snapshotRestore.repositoryForm.fields.cloudTypeDescription": "Elasticsearch はカスタムレポジトリ用のコアプラグインを提供します。{docLink}", - "xpack.snapshotRestore.repositoryForm.fields.defaultTypeDescription": "Elasticsearch はファイルシステムと読み取り専用の URL レポジトリをサポートします。他のタイプにはプラグインが必要です。{docLink}", - "xpack.snapshotRestore.repositoryForm.fields.nameDescription": "レポジトリのの固有の名前です。", - "xpack.snapshotRestore.repositoryForm.fields.nameDescriptionTitle": "レポジトリ名", - "xpack.snapshotRestore.repositoryForm.fields.nameLabel": "名前", - "xpack.snapshotRestore.repositoryForm.fields.settingsTitle": "{repositoryName} 設定", - "xpack.snapshotRestore.repositoryForm.fields.sourceOnlyDescription": "最大 50% のスペースを節約できるソースのみのスナップショットを作成します。{docLink}", - "xpack.snapshotRestore.repositoryForm.fields.sourceOnlyDescriptionTitle": "ソースのみのスナップショット", - "xpack.snapshotRestore.repositoryForm.fields.sourceOnlyDocLinkText": "ソースのみのレポジトリに関する詳細をご覧ください。", - "xpack.snapshotRestore.repositoryForm.fields.sourceOnlyLabel": "ソースのみのスナップショット", - "xpack.snapshotRestore.repositoryForm.fields.typeDescriptionTitle": "レポジトリタイプ", - "xpack.snapshotRestore.repositoryForm.fields.typeDocsLinkText": "その他のリソース", - "xpack.snapshotRestore.repositoryForm.fields.typePluginsDocLinkText": "プラグインの詳細をご覧ください。", - "xpack.snapshotRestore.repositoryForm.loadingRepositoryTypesDescription": "レポジトリタイプを読み込み中…", - "xpack.snapshotRestore.repositoryForm.loadingRepositoryTypesErrorMessage": "レポジトリタイプの読み込み中にエラーが発生しました", - "xpack.snapshotRestore.repositoryForm.nextButtonLabel": "次へ", - "xpack.snapshotRestore.repositoryForm.noRepositoryTypesErrorMessage": "プラグインをインストールして異なるレポジトリタイプを有効にできます。{docLink}", - "xpack.snapshotRestore.repositoryForm.noRepositoryTypesErrorTitle": "利用可能なレポジトリタイプがありません", - "xpack.snapshotRestore.repositoryForm.registerButtonLabel": "申込む", - "xpack.snapshotRestore.repositoryForm.repositoryTypeDocLink": "{repositoryType} レポジトリドキュメント", - "xpack.snapshotRestore.repositoryForm.saveButtonLabel": "保存", - "xpack.snapshotRestore.repositoryForm.savingButtonLabel": "保存中…", - "xpack.snapshotRestore.repositoryForm.typeAzure.basePathDescription": "レポジトリデータへのコンテナーパスです。", - "xpack.snapshotRestore.repositoryForm.typeAzure.basePathLabel": "ベースパス", - "xpack.snapshotRestore.repositoryForm.typeAzure.basePathTitle": "ベースパス", - "xpack.snapshotRestore.repositoryForm.typeAzure.chunkSizeDescription": "スナップショットの作成時にファイルを小さなユニットに分けます。", - "xpack.snapshotRestore.repositoryForm.typeAzure.chunkSizeLabel": "チャンクサイズ", - "xpack.snapshotRestore.repositoryForm.typeAzure.chunkSizeTitle": "チャンクサイズ", - "xpack.snapshotRestore.repositoryForm.typeAzure.clientDescription": "Azure クライアントの名前です。", - "xpack.snapshotRestore.repositoryForm.typeAzure.clientLabel": "クライアント", - "xpack.snapshotRestore.repositoryForm.typeAzure.clientTitle": "クライアント", - "xpack.snapshotRestore.repositoryForm.typeAzure.compressDescription": "スナップショット用にインデックスのマッピングと設定ファイルを圧縮します。データファイルは圧縮されません。", - "xpack.snapshotRestore.repositoryForm.typeAzure.compressLabel": "スナップショットを圧縮", - "xpack.snapshotRestore.repositoryForm.typeAzure.compressTitle": "スナップショットの圧縮", - "xpack.snapshotRestore.repositoryForm.typeAzure.containerDescription": "スナップショットに使用する Azure コンテナーの名前です。", - "xpack.snapshotRestore.repositoryForm.typeAzure.containerLabel": "コンテナー", - "xpack.snapshotRestore.repositoryForm.typeAzure.containerTitle": "コンテナー", - "xpack.snapshotRestore.repositoryForm.typeAzure.locationModeDescription": "プライマリまたはセカンダリの場所です。セカンダリの場合、読み込み専用が true です。", - "xpack.snapshotRestore.repositoryForm.typeAzure.locationModeLabel": "位置情報モード", - "xpack.snapshotRestore.repositoryForm.typeAzure.locationModeTitle": "位置情報モード", - "xpack.snapshotRestore.repositoryForm.typeAzure.maxRestoreBytesDescription": "各ノードのスナップショットの復元レートです。", - "xpack.snapshotRestore.repositoryForm.typeAzure.maxRestoreBytesLabel": "1 秒間の最高復元バイト数", - "xpack.snapshotRestore.repositoryForm.typeAzure.maxRestoreBytesTitle": "1 秒間の最高復元バイト数", - "xpack.snapshotRestore.repositoryForm.typeAzure.maxSnapshotBytesDescription": "各ノードのスナップショットの作成レートです。", - "xpack.snapshotRestore.repositoryForm.typeAzure.maxSnapshotBytesLabel": "1 秒間の最高スナップショットバイト数", - "xpack.snapshotRestore.repositoryForm.typeAzure.maxSnapshotBytesTitle": "1 秒間の最高スナップショットバイト数", - "xpack.snapshotRestore.repositoryForm.typeAzure.readonlyDescription": "このレポジトリへの書き込みアクセスがあるクラスターは 1 つだけでなければなりません。他のクラスターはすべて読み込み専用にする必要があります。", - "xpack.snapshotRestore.repositoryForm.typeAzure.readonlyLabel": "読み込み専用レポジトリ", - "xpack.snapshotRestore.repositoryForm.typeAzure.readonlyTitle": "読み込み専用", - "xpack.snapshotRestore.repositoryForm.typeFS.chunkSizeDescription": "スナップショットの作成時にファイルを小さなユニットに分けます。", - "xpack.snapshotRestore.repositoryForm.typeFS.chunkSizeLabel": "チャンクサイズ", - "xpack.snapshotRestore.repositoryForm.typeFS.chunkSizeTitle": "チャンクサイズ", - "xpack.snapshotRestore.repositoryForm.typeFS.compressDescription": "スナップショット用にインデックスのマッピングと設定ファイルを圧縮します。データファイルは圧縮されません。", - "xpack.snapshotRestore.repositoryForm.typeFS.compressLabel": "スナップショットを圧縮", - "xpack.snapshotRestore.repositoryForm.typeFS.compressTitle": "スナップショットの圧縮", - "xpack.snapshotRestore.repositoryForm.typeFS.locationLabel": "場所 (必須)", - "xpack.snapshotRestore.repositoryForm.typeFS.locationTitle": "ファイルシステムの場所", - "xpack.snapshotRestore.repositoryForm.typeFS.maxRestoreBytesDescription": "各ノードのスナップショットの復元レートです。", - "xpack.snapshotRestore.repositoryForm.typeFS.maxRestoreBytesLabel": "1 秒間の最高復元バイト数", - "xpack.snapshotRestore.repositoryForm.typeFS.maxRestoreBytesTitle": "1 秒間の最高復元バイト数", - "xpack.snapshotRestore.repositoryForm.typeFS.maxSnapshotBytesDescription": "各ノードのスナップショットの作成レートです。", - "xpack.snapshotRestore.repositoryForm.typeFS.maxSnapshotBytesLabel": "1 秒間の最高スナップショットバイト数", - "xpack.snapshotRestore.repositoryForm.typeFS.maxSnapshotBytesTitle": "1 秒間の最高スナップショットバイト数", - "xpack.snapshotRestore.repositoryForm.typeFS.readonlyDescription": "このレポジトリへの書き込みアクセスがあるクラスターは 1 つだけでなければなりません。他のクラスターはすべて読み込み専用にする必要があります。", - "xpack.snapshotRestore.repositoryForm.typeFS.readonlyLabel": "読み込み専用レポジトリ", - "xpack.snapshotRestore.repositoryForm.typeFS.readonlyTitle": "読み込み専用", - "xpack.snapshotRestore.repositoryForm.typeGCS.basePathDescription": "レポジトリデータへのバケットパスです。", - "xpack.snapshotRestore.repositoryForm.typeGCS.basePathLabel": "ベースパス", - "xpack.snapshotRestore.repositoryForm.typeGCS.basePathTitle": "ベースパス", - "xpack.snapshotRestore.repositoryForm.typeGCS.bucketDescription": "スナップショットに使用する Google Cloud Storage バケットの名前です。", - "xpack.snapshotRestore.repositoryForm.typeGCS.bucketLabel": "バケット (必須)", - "xpack.snapshotRestore.repositoryForm.typeGCS.bucketTitle": "バケット", - "xpack.snapshotRestore.repositoryForm.typeGCS.chunkSizeDescription": "スナップショットの作成時にファイルを小さなユニットに分けます。", - "xpack.snapshotRestore.repositoryForm.typeGCS.chunkSizeLabel": "チャンクサイズ", - "xpack.snapshotRestore.repositoryForm.typeGCS.chunkSizeTitle": "チャンクサイズ", - "xpack.snapshotRestore.repositoryForm.typeGCS.clientDescription": "Google Cloud Storage クライアントの名前です。", - "xpack.snapshotRestore.repositoryForm.typeGCS.clientLabel": "クライアント", - "xpack.snapshotRestore.repositoryForm.typeGCS.clientTitle": "クライアント", - "xpack.snapshotRestore.repositoryForm.typeGCS.compressDescription": "スナップショット用にインデックスのマッピングと設定ファイルを圧縮します。データファイルは圧縮されません。", - "xpack.snapshotRestore.repositoryForm.typeGCS.compressLabel": "スナップショットを圧縮", - "xpack.snapshotRestore.repositoryForm.typeGCS.compressTitle": "スナップショットを圧縮", - "xpack.snapshotRestore.repositoryForm.typeGCS.maxRestoreBytesDescription": "各ノードのスナップショットの復元レートです。", - "xpack.snapshotRestore.repositoryForm.typeGCS.maxRestoreBytesLabel": "1 秒間の最高復元バイト数", - "xpack.snapshotRestore.repositoryForm.typeGCS.maxRestoreBytesTitle": "1 秒間の最高復元バイト数", - "xpack.snapshotRestore.repositoryForm.typeGCS.maxSnapshotBytesDescription": "各ノードのスナップショットの作成レートです。", - "xpack.snapshotRestore.repositoryForm.typeGCS.maxSnapshotBytesLabel": "1 秒間の最高スナップショットバイト数", - "xpack.snapshotRestore.repositoryForm.typeGCS.maxSnapshotBytesTitle": "1 秒間の最高スナップショットバイト数", - "xpack.snapshotRestore.repositoryForm.typeGCS.readonlyDescription": "このレポジトリへの書き込みアクセスがあるクラスターは 1 つだけでなければなりません。他のクラスターはすべて読み込み専用にする必要があります。", - "xpack.snapshotRestore.repositoryForm.typeGCS.readonlyLabel": "読み込み専用レポジトリ", - "xpack.snapshotRestore.repositoryForm.typeGCS.readonlyTitle": "読み込み専用", - "xpack.snapshotRestore.repositoryForm.typeHDFS.chunkSizeDescription": "スナップショットの作成時にファイルを小さなユニットに分けます。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.chunkSizeLabel": "チャンクサイズ", - "xpack.snapshotRestore.repositoryForm.typeHDFS.chunkSizeTitle": "チャンクサイズ", - "xpack.snapshotRestore.repositoryForm.typeHDFS.compressDescription": "スナップショット用にインデックスのマッピングと設定ファイルを圧縮します。データファイルは圧縮されません。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.compressLabel": "スナップショットを圧縮", - "xpack.snapshotRestore.repositoryForm.typeHDFS.compressTitle": "スナップショットの圧縮", - "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationAriaLabel": "HDFS レポジトリ「{name}」の追加構成", - "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationDescription": "Hadoop 構成に追加する JSON フォーマット構成パラメーターです。Hadoop コアと HDFS ファイルからのクライアント中心のプロパティのみが認識されます。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationFormatError": "無効な JSON フォーマット", - "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationKeyDescription": "キーは {confKeyFormat} のフォーマットでなければなりません。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationLabel": "構成", - "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationTitle": "構成", - "xpack.snapshotRestore.repositoryForm.typeHDFS.loadDefaultsDescription": "デフォルトの Hadoop 構成を読み込みます。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.loadDefaultsLabel": "デフォルトを読み込む", - "xpack.snapshotRestore.repositoryForm.typeHDFS.loadDefaultsTitle": "デフォルトを読み込む", - "xpack.snapshotRestore.repositoryForm.typeHDFS.maxRestoreBytesDescription": "各ノードのスナップショットの復元レートです。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.maxRestoreBytesLabel": "1 秒間の最高復元バイト数", - "xpack.snapshotRestore.repositoryForm.typeHDFS.maxRestoreBytesTitle": "1 秒間の最高復元バイト数", - "xpack.snapshotRestore.repositoryForm.typeHDFS.maxSnapshotBytesDescription": "各ノードのスナップショットの作成レートです。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.maxSnapshotBytesLabel": "1 秒間の最高スナップショットバイト数", - "xpack.snapshotRestore.repositoryForm.typeHDFS.maxSnapshotBytesTitle": "1 秒間の最高スナップショットバイト数", - "xpack.snapshotRestore.repositoryForm.typeHDFS.pathDescription": "データが保管されているファイルへのパスです。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.pathLabel": "パス (必須)", - "xpack.snapshotRestore.repositoryForm.typeHDFS.pathTitle": "パス", - "xpack.snapshotRestore.repositoryForm.typeHDFS.readonlyDescription": "このレポジトリへの書き込みアクセスがあるクラスターは 1 つだけでなければなりません。他のクラスターはすべて読み込み専用にする必要があります。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.readonlyLabel": "読み込み専用レポジトリ", - "xpack.snapshotRestore.repositoryForm.typeHDFS.readonlyTitle": "読み込み専用", - "xpack.snapshotRestore.repositoryForm.typeHDFS.securityPrincipalDescription": "セキュアな HDFS クラスターへの接続時に使用する Kerberos プリンシパルです。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.securityPrincipalLabel": "セキュリティプリンシパル", - "xpack.snapshotRestore.repositoryForm.typeHDFS.securityPrincipalTitle": "セキュリティプリンシパル", - "xpack.snapshotRestore.repositoryForm.typeHDFS.uriDescription": "HDFS の URL アドレスです。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.uriLabel": "URI (必須)", - "xpack.snapshotRestore.repositoryForm.typeHDFS.uriTitle": "URI", - "xpack.snapshotRestore.repositoryForm.typeReadonly.urlDescription": "スナップショットの場所です。", - "xpack.snapshotRestore.repositoryForm.typeReadonly.urlFilePathDescription": "このファイルの場所は {settingKey} 設定で登録する必要があります。", - "xpack.snapshotRestore.repositoryForm.typeReadonly.urlLabel": "パス (必須)", - "xpack.snapshotRestore.repositoryForm.typeReadonly.urlSchemeLabel": "スキーム", - "xpack.snapshotRestore.repositoryForm.typeReadonly.urlTitle": "URL", - "xpack.snapshotRestore.repositoryForm.typeReadonly.urlWhitelistDescription": "この URL は {settingKey} 設定で登録する必要があります。", - "xpack.snapshotRestore.repositoryForm.typeS3.basePathDescription": "レポジトリデータへのバケットパスです。", - "xpack.snapshotRestore.repositoryForm.typeS3.basePathLabel": "ベースパス", - "xpack.snapshotRestore.repositoryForm.typeS3.basePathTitle": "ベースパス", - "xpack.snapshotRestore.repositoryForm.typeS3.bucketDescription": "スナップショットに使用する AWS S3 バケットの名前です。", - "xpack.snapshotRestore.repositoryForm.typeS3.bucketLabel": "バケット (必須)", - "xpack.snapshotRestore.repositoryForm.typeS3.bucketTitle": "バケット", - "xpack.snapshotRestore.repositoryForm.typeS3.bufferSizeDescription": "この最低しきい値を超えると、S3 レポジトリは AWS Multipart Upload API を使用してチャンクをいくつかのパーツに分け、各パーツをそれぞれのリクエストによってアップロードします。", - "xpack.snapshotRestore.repositoryForm.typeS3.bufferSizeLabel": "バッファーサイズ", - "xpack.snapshotRestore.repositoryForm.typeS3.bufferSizeTitle": "バッファーサイズ", - "xpack.snapshotRestore.repositoryForm.typeS3.cannedAclDescription": "新しい S3 バケットとオブジェクトに追加する canned ACL です。", - "xpack.snapshotRestore.repositoryForm.typeS3.cannedAclLabel": "Canned ACL", - "xpack.snapshotRestore.repositoryForm.typeS3.cannedAclTitle": "Canned ACL", - "xpack.snapshotRestore.repositoryForm.typeS3.chunkSizeDescription": "スナップショットの作成時にファイルを小さなユニットに分けます。", - "xpack.snapshotRestore.repositoryForm.typeS3.chunkSizeLabel": "チャンクサイズ", - "xpack.snapshotRestore.repositoryForm.typeS3.chunkSizeTitle": "チャンクサイズ", - "xpack.snapshotRestore.repositoryForm.typeS3.clientDescription": "AWS S3 クライアントの名前です。", - "xpack.snapshotRestore.repositoryForm.typeS3.clientLabel": "クライアント", - "xpack.snapshotRestore.repositoryForm.typeS3.clientTitle": "クライアント", - "xpack.snapshotRestore.repositoryForm.typeS3.compressDescription": "スナップショット用にインデックスのマッピングと設定ファイルを圧縮します。データファイルは圧縮されません。", - "xpack.snapshotRestore.repositoryForm.typeS3.compressLabel": "スナップショットを圧縮", - "xpack.snapshotRestore.repositoryForm.typeS3.compressTitle": "スナップショットの圧縮", - "xpack.snapshotRestore.repositoryForm.typeS3.maxRestoreBytesDescription": "各ノードのスナップショットの復元レートです。", - "xpack.snapshotRestore.repositoryForm.typeS3.maxRestoreBytesLabel": "1 秒間の最高復元バイト数", - "xpack.snapshotRestore.repositoryForm.typeS3.maxRestoreBytesTitle": "1 秒間の最高復元バイト数", - "xpack.snapshotRestore.repositoryForm.typeS3.maxSnapshotBytesDescription": "各ノードのスナップショットの作成レートです。", - "xpack.snapshotRestore.repositoryForm.typeS3.maxSnapshotBytesLabel": "1 秒間の最高スナップショットバイト数", - "xpack.snapshotRestore.repositoryForm.typeS3.maxSnapshotBytesTitle": "1 秒間の最高スナップショットバイト数", - "xpack.snapshotRestore.repositoryForm.typeS3.readonlyDescription": "このレポジトリへの書き込みアクセスがあるクラスターは 1 つだけでなければなりません。他のクラスターはすべて読み込み専用にする必要があります。", - "xpack.snapshotRestore.repositoryForm.typeS3.readonlyLabel": "読み込み専用レポジトリ", - "xpack.snapshotRestore.repositoryForm.typeS3.readonlyTitle": "読み込み専用", - "xpack.snapshotRestore.repositoryForm.typeS3.serverSideEncryptionDescription": "AES256 アルゴリズムでサーバーのファイルを暗号化します。", - "xpack.snapshotRestore.repositoryForm.typeS3.serverSideEncryptionLabel": "サーバー側エコシステム", - "xpack.snapshotRestore.repositoryForm.typeS3.serverSideEncryptionTitle": "サーバー側エコシステム", - "xpack.snapshotRestore.repositoryForm.typeS3.storageClassDescription": "S3 レポジトリの新規オブジェクトのストレージクラスです。", - "xpack.snapshotRestore.repositoryForm.typeS3.storageClassLabel": "ストレージクラス", - "xpack.snapshotRestore.repositoryForm.typeS3.storageClassTitle": "ストレージクラス", - "xpack.snapshotRestore.repositoryForm.validationErrorTitle": "続行する前にエラーを修正してください。", - "xpack.snapshotRestore.repositoryList.addRepositoryButtonLabel": "レポジトリを登録", - "xpack.snapshotRestore.repositoryList.emptyPromptDescription": "スナップショットを保管するレポジトリが必要です。", - "xpack.snapshotRestore.repositoryList.emptyPromptTitle": "まだレポジトリがありません", - "xpack.snapshotRestore.repositoryList.loadingRepositoriesDescription": "レポジトリを読み込み中…", - "xpack.snapshotRestore.repositoryList.LoadingRepositoriesErrorMessage": "レポジトリの読み込み中にエラーが発生しました", - "xpack.snapshotRestore.repositoryList.table.actionEditAriaLabel": "レポジトリ「{name}」を編集", - "xpack.snapshotRestore.repositoryList.table.actionEditTooltip": "編集", - "xpack.snapshotRestore.repositoryList.table.actionRemoveAriaLabel": "レポジトリ「{name}」を削除", - "xpack.snapshotRestore.repositoryList.table.actionRemoveTooltip": "削除", - "xpack.snapshotRestore.repositoryList.table.actionsColumnTitle": "アクション", - "xpack.snapshotRestore.repositoryList.table.deleteManagedRepositoryTooltip": "管理されているレポジトリは削除できません。", - "xpack.snapshotRestore.repositoryList.table.deleteMultipleRepositoriesButton": "レポジトリを削除", - "xpack.snapshotRestore.repositoryList.table.deleteSingleRepositoryButton": "レポジトリを削除", - "xpack.snapshotRestore.repositoryList.table.managedRepositoryBadgeLabel": "管理中", - "xpack.snapshotRestore.repositoryList.table.nameColumnTitle": "名前", - "xpack.snapshotRestore.repositoryList.table.reloadRepositoriesButton": "再読み込み", - "xpack.snapshotRestore.repositoryList.table.typeColumnTitle": "タイプ", - "xpack.snapshotRestore.repositoryType.azureTypeName": "Azure", - "xpack.snapshotRestore.repositoryType.fileSystemTypeName": "共有ファイルシステム", - "xpack.snapshotRestore.repositoryType.gcsTypeName": "Google Cloud Storage", - "xpack.snapshotRestore.repositoryType.hdfsTypeName": "Hadoop HDFS", - "xpack.snapshotRestore.repositoryType.readonlyTypeName": "読み込み専用 URL", - "xpack.snapshotRestore.repositoryType.s3TypeName": "AWS S3", - "xpack.snapshotRestore.repositoryType.sourceTypeName": "ソースのみ", - "xpack.snapshotRestore.repositoryValidation.bucketRequired": "バケットが必要です。", - "xpack.snapshotRestore.repositoryValidation.delegateTypeRequired": "タイプが必要です。", - "xpack.snapshotRestore.repositoryValidation.locationRequired": "場所が必要です。", - "xpack.snapshotRestore.repositoryValidation.nameRequired": "レポジトリ名が必要です。", - "xpack.snapshotRestore.repositoryValidation.nameValidation.errorSpace": "名前にスペースは使用できません。", - "xpack.snapshotRestore.repositoryValidation.nameValidation.invalidCharacter": "名前に「{char}」は使用できません。", - "xpack.snapshotRestore.repositoryValidation.pathRequired": "パスが必要です。", - "xpack.snapshotRestore.repositoryValidation.uriRequired": "URI が必要です。", - "xpack.snapshotRestore.repositoryValidation.urlRequired": "URL が必要です。", - "xpack.snapshotRestore.repositoryVerification.verificationErrorValue": "未接続", - "xpack.snapshotRestore.repositoryVerification.verificationSuccessfulValue": "接続済み", - "xpack.snapshotRestore.repositoryVerification.verificationUnknownValue": "不明", - "xpack.snapshotRestore.repositoryWarningDescription": "スナップショットの読み込みが遅い可能性があります。{repositoryLink} に移動してエラーを解決してください。", - "xpack.snapshotRestore.repositoryWarningLinkText": "レポジトリ", - "xpack.snapshotRestore.repositoryWarningTitle": "一部のレポジトリにエラーがあります", - "xpack.snapshotRestore.snapshotDetails.closeButtonLabel": "閉じる", - "xpack.snapshotRestore.snapshotDetails.errorLoadingRepositoryTitle": "レポジトリの読み込み中にエラーが発生", - "xpack.snapshotRestore.snapshotDetails.errorSnapshotNotFound": "スナップショット「{snapshotId}」がレポジトリ「{repositoryName}」に存在しないか、レポジトリが存在しません。", - "xpack.snapshotRestore.snapshotDetails.failureShardTitle": "ャード {shardId}", - "xpack.snapshotRestore.snapshotDetails.failuresTabTitle": "失敗したインデックス ({failuresCount})", - "xpack.snapshotRestore.snapshotDetails.itemDurationLabel": "期間", - "xpack.snapshotRestore.snapshotDetails.itemDurationValueLabel": "{seconds} {seconds, plural, one {秒} other {秒}}", - "xpack.snapshotRestore.snapshotDetails.itemEndTimeLabel": "終了時刻", - "xpack.snapshotRestore.snapshotDetails.itemIncludeGlobalStateLabel": "グローバルステータスを含める", - "xpack.snapshotRestore.snapshotDetails.itemIncludeGlobalStateNoLabel": "いいえ", - "xpack.snapshotRestore.snapshotDetails.itemIncludeGlobalStateYesLabel": "はい", - "xpack.snapshotRestore.snapshotDetails.itemIndicesLabel": "インデックス ({indicesCount})", - "xpack.snapshotRestore.snapshotDetails.itemIndicesNoneLabel": "-", - "xpack.snapshotRestore.snapshotDetails.itemStartTimeLabel": "開始時刻", - "xpack.snapshotRestore.snapshotDetails.itemStateLabel": "ステータス", - "xpack.snapshotRestore.snapshotDetails.itemUuidLabel": "UUID", - "xpack.snapshotRestore.snapshotDetails.itemVersionLabel": "バージョン / バージョン ID", - "xpack.snapshotRestore.snapshotDetails.loadingSnapshotDescription": "スナップショットを読み込み中…", - "xpack.snapshotRestore.snapshotDetails.noIndexFailuresMessage": "すべてのインデックスが保存されました。", - "xpack.snapshotRestore.snapshotDetails.repositoryTitle": "「{repositoryName}」レポジトリ", - "xpack.snapshotRestore.snapshotDetails.snapshotIsBeingCreatedMessage": "スナップショットを作成中です。", - "xpack.snapshotRestore.snapshotDetails.summaryTabTitle": "まとめ", - "xpack.snapshotRestore.snapshotList.emptyPrompt.errorRepositoriesTitle": "一部のレポジトリにエラーがあります", - "xpack.snapshotRestore.snapshotList.emptyPrompt.noRepositoriesAddButtonLabel": "レポジトリを登録", - "xpack.snapshotRestore.snapshotList.emptyPrompt.noRepositoriesDescription": "スナップショットのレポジトリを登録して始めます。", - "xpack.snapshotRestore.snapshotList.emptyPrompt.noRepositoriesTitle": "まだスナップショットやレポジトリがありません", - "xpack.snapshotRestore.snapshotList.emptyPrompt.noSnapshotsDescription": "Elasticsearch API でスナップショットを作成します。", - "xpack.snapshotRestore.snapshotList.emptyPrompt.noSnapshotsTitle": "まだスナップショットがありません", - "xpack.snapshotRestore.snapshotList.emptyPrompt.repositoryWarningDescription": "{repositoryLink} に移動してエラーを解決してください。", - "xpack.snapshotRestore.snapshotList.loadingSnapshotsDescription": "スナップショットを読み込み中…", - "xpack.snapshotRestore.snapshotList.loadingSnapshotsErrorMessage": "スナップショットの読み込み中にエラーが発生しました", - "xpack.snapshotRestore.snapshotList.table.durationColumnTitle": "期間", - "xpack.snapshotRestore.snapshotList.table.durationColumnValueLabel": "{seconds}秒", - "xpack.snapshotRestore.snapshotList.table.failedShardsColumnTitle": "シャードの失敗", - "xpack.snapshotRestore.snapshotList.table.indicesColumnTitle": "インデックス", - "xpack.snapshotRestore.snapshotList.table.reloadSnapshotsButton": "再読み込み", - "xpack.snapshotRestore.snapshotList.table.repositoryColumnTitle": "レポジトリ", - "xpack.snapshotRestore.snapshotList.table.shardsColumnTitle": "シャード", - "xpack.snapshotRestore.snapshotList.table.snapshotColumnTitle": "スナップショット", - "xpack.snapshotRestore.snapshotList.table.startTimeColumnTitle": "日付が作成されました", - "xpack.snapshotRestore.snapshotState.completeLabel": "スナップショット完了", - "xpack.snapshotRestore.snapshotState.failedLabel": "スナップショット失敗", - "xpack.snapshotRestore.snapshotState.incompatibleLabel": "互換性のないバージョン", - "xpack.snapshotRestore.snapshotState.incompatibleTipDescription": "このスナップショットはクラスターのバージョンと互換性のないバージョンの Elasticsearch で作成されました。", - "xpack.snapshotRestore.snapshotState.inProgressLabel": "スナップショットを撮影中…", - "xpack.snapshotRestore.snapshotState.partialLabel": "一部失敗", - "xpack.snapshotRestore.snapshotState.partialTipDescription": "グローバルクラスターステータスが保存されましたが、1 つまたは複数のシャードの保存に失敗しました。「失敗したインシデント」タブをご覧ください。", - "xpack.snapshotRestore.addPolicy.breadcrumbTitle": "ポリシーを追加", - "xpack.snapshotRestore.addPolicy.loadingIndicesDescription": "利用可能なインデックスを読み込み中…", - "xpack.snapshotRestore.addPolicy.LoadingIndicesErrorMessage": "利用可能なインデックスを読み込み中にエラーが発生", - "xpack.snapshotRestore.addPolicy.savingPolicyErrorTitle": "新規ポリシーを作成できません", - "xpack.snapshotRestore.addPolicyTitle": "ポリシーを作成", - "xpack.snapshotRestore.app.checkingPrivilegesDescription": "権限を確認中…", - "xpack.snapshotRestore.app.checkingPrivilegesErrorMessage": "サーバーからユーザー特権を取得中にエラーが発生。", - "xpack.snapshotRestore.app.deniedPrivilegeDescription": "スナップショットと復元を使用するには、{privilegesCount, plural, one {このクラスター特権} other {これらのクラスター特権}}が必要です: {missingPrivileges}。", - "xpack.snapshotRestore.app.deniedPrivilegeTitle": "クラスター特権が足りません", - "xpack.snapshotRestore.createPolicyButton": "ポリシーを作成", - "xpack.snapshotRestore.deletePolicy.confirmModal.cancelButtonLabel": "キャンセル", - "xpack.snapshotRestore.deletePolicy.confirmModal.confirmButtonLabel": "{count, plural, one {ポリシー} other {ポリシー}}を削除", - "xpack.snapshotRestore.deletePolicy.confirmModal.deleteMultipleListDescription": "これらのポリシーを削除しようとしています:", - "xpack.snapshotRestore.deletePolicy.confirmModal.deleteMultipleTitle": "{count} 件のポリシーを削除しますか?", - "xpack.snapshotRestore.deletePolicy.confirmModal.deleteSingleTitle": "ポリシー「{name}」を削除しますか?", - "xpack.snapshotRestore.deletePolicy.errorMultipleNotificationTitle": "{count} 件のポリシーの削除中にエラーが発生", - "xpack.snapshotRestore.deletePolicy.errorSingleNotificationTitle": "ポリシー {name} の削除中にエラーが発生", - "xpack.snapshotRestore.deletePolicy.successMultipleNotificationTitle": "{count} 件のポリシーが削除されました", - "xpack.snapshotRestore.deletePolicy.successSingleNotificationTitle": "ポリシー「{name}」が削除されました", - "xpack.snapshotRestore.editPolicy.breadcrumbTitle": "ポリシーの編集", - "xpack.snapshotRestore.editPolicy.loadingIndicesDescription": "利用可能なインデックスを読み込み中…", - "xpack.snapshotRestore.editPolicy.LoadingIndicesErrorMessage": "利用可能なインデックスを読み込み中にエラーが発生", - "xpack.snapshotRestore.editPolicy.loadingPolicyDescription": "ポリシー詳細を読み込み中…", - "xpack.snapshotRestore.editPolicy.loadingPolicyErrorTitle": "ポリシー詳細の読み込み中にエラーが発生", - "xpack.snapshotRestore.editPolicy.policyNotFoundErrorMessage": "ポリシー「{name}」が存在しません。", - "xpack.snapshotRestore.editPolicy.savingPolicyErrorTitle": "ポリシーを保存できません", - "xpack.snapshotRestore.editPolicyTitle": "ポリシーの編集", - "xpack.snapshotRestore.emptyPrompt.usePolicyDocLinkText": "Elasticsearch API", - "xpack.snapshotRestore.executePolicy.confirmModal.cancelButtonLabel": "キャンセル", - "xpack.snapshotRestore.executePolicy.confirmModal.confirmButtonLabel": "ポリシーを実行", - "xpack.snapshotRestore.executePolicy.confirmModal.executePolicyTitle": "今すぐ「{name}」を実行しますか?", - "xpack.snapshotRestore.executePolicy.errorNotificationTitle": "ポリシー「{name}」の実行中にエラーが発生", - "xpack.snapshotRestore.executePolicy.successNotificationTitle": "ポリシー「{name}」は実行中です", - "xpack.snapshotRestore.home.policiesTabTitle": "ポリシー", - "xpack.snapshotRestore.policies.breadcrumbTitle": "ポリシー", - "xpack.snapshotRestore.policyDetails.allIndicesLabel": "すべてのインデックス", - "xpack.snapshotRestore.policyDetails.closeButtonLabel": "閉じる", - "xpack.snapshotRestore.policyDetails.deleteButtonLabel": "削除", - "xpack.snapshotRestore.policyDetails.editButtonLabel": "編集", - "xpack.snapshotRestore.policyDetails.executeButtonLabel": "今すぐ実行", - "xpack.snapshotRestore.policyDetails.historyTabTitle": "履歴", - "xpack.snapshotRestore.policyDetails.ignoreUnavailableFalseLabel": "いいえ", - "xpack.snapshotRestore.policyDetails.ignoreUnavailableLabel": "利用不可能なインデックスを無視", - "xpack.snapshotRestore.policyDetails.ignoreUnavailableTrueLabel": "はい", - "xpack.snapshotRestore.policyDetails.includeGlobalStateFalseLabel": "いいえ", - "xpack.snapshotRestore.policyDetails.includeGlobalStateLabel": "グローバルステータスを含める", - "xpack.snapshotRestore.policyDetails.includeGlobalStateTrueLabel": "はい", - "xpack.snapshotRestore.policyDetails.indicesCollapseAllLink": "{count, plural, one {# インデックス} other {# インデックス}}を非表示", - "xpack.snapshotRestore.policyDetails.indicesLabel": "インデックス", - "xpack.snapshotRestore.policyDetails.indicesShowAllLink": "{count}その他の{count, plural, one {インデックス} other {インデックス}}を表示", - "xpack.snapshotRestore.policyDetails.inProgressSnapshotLinkText": "「{snapshotName}」が進行中", - "xpack.snapshotRestore.policyDetails.lastFailure.dateLabel": "日付", - "xpack.snapshotRestore.policyDetails.lastFailure.detailsAriaLabel": "ポリシー「{name}」の前回のエラーの詳細", - "xpack.snapshotRestore.policyDetails.lastFailure.detailsLabel": "詳細", - "xpack.snapshotRestore.policyDetails.lastFailure.snapshotNameLabel": "スナップショット名", - "xpack.snapshotRestore.policyDetails.lastFailureTitle": "前回のスナップショットエラー", - "xpack.snapshotRestore.policyDetails.lastSuccess.dateLabel": "日付", - "xpack.snapshotRestore.policyDetails.lastSuccess.snapshotNameLabel": "スナップショット名", - "xpack.snapshotRestore.policyDetails.lastSuccessTitle": "前回成功したスナップショット", - "xpack.snapshotRestore.policyDetails.loadingPolicyDescription": "ポリシーを読み込み中…", - "xpack.snapshotRestore.policyDetails.loadingPolicyErrorTitle": "ポリシーの読み込み中にエラーが発生", - "xpack.snapshotRestore.policyDetails.manageButtonLabel": "ポリシーを管理", - "xpack.snapshotRestore.policyDetails.managePanelTitle": "ポリシーオプション", - "xpack.snapshotRestore.policyDetails.modifiedDateLabel": "最終更新:", - "xpack.snapshotRestore.policyDetails.nextExecutionLabel": "次回のスナップショット", - "xpack.snapshotRestore.policyDetails.noHistoryMessage": "このポリシーは {date} {time} に実行されます。", - "xpack.snapshotRestore.policyDetails.partialFalseLabel": "いいえ", - "xpack.snapshotRestore.policyDetails.partialLabel": "部分シャードを許可", - "xpack.snapshotRestore.policyDetails.partialTrueLabel": "はい", - "xpack.snapshotRestore.policyDetails.policyNotFoundErrorMessage": "ポリシー「{name}」が存在しません。", - "xpack.snapshotRestore.policyDetails.reloadButtonAriaLabel": "再読み込み", - "xpack.snapshotRestore.policyDetails.repositoryLabel": "レポジトリ", - "xpack.snapshotRestore.policyDetails.scheduleLabel": "スケジュール", - "xpack.snapshotRestore.policyDetails.snapshotNameLabel": "スナップショット名", - "xpack.snapshotRestore.policyDetails.summaryTabTitle": "まとめ", - "xpack.snapshotRestore.policyDetails.versionLabel": "バージョン", - "xpack.snapshotRestore.policyForm.addRepositoryButtonLabel": "レポジトリを登録", - "xpack.snapshotRestore.policyForm.backButtonLabel": "戻る", - "xpack.snapshotRestore.policyForm.cancelButtonLabel": "キャンセル", - "xpack.snapshotRestore.policyForm.createButtonLabel": "ポリシーを作成", - "xpack.snapshotRestore.policyForm.loadingRepositoriesDescription": "レポジトリを読み込み中…", - "xpack.snapshotRestore.policyForm.loadingRepositoriesErrorMessage": "レポジトリの読み込み中にエラーが発生しました", - "xpack.snapshotRestore.policyForm.navigation.stepLogisticsName": "ロジスティクス", - "xpack.snapshotRestore.policyForm.navigation.stepReviewName": "確認", - "xpack.snapshotRestore.policyForm.navigation.stepSettingsName": "スナップショット設定", - "xpack.snapshotRestore.policyForm.nextButtonLabel": "次へ", - "xpack.snapshotRestore.policyForm.noRepositoriesErrorMessage": "スナップショットを格納するレポジトリの登録が必要です。", - "xpack.snapshotRestore.policyForm.noRepositoriesErrorTitle": "レポジトリがありません", - "xpack.snapshotRestore.policyForm.reloadRepositoriesButtonLabel": "レポジトリを再読み込み", - "xpack.snapshotRestore.policyForm.saveButtonLabel": "ポリシーを保存", - "xpack.snapshotRestore.policyForm.savingButtonLabel": "保存中…", - "xpack.snapshotRestore.policyForm.stepLogistics.docsButtonLabel": "ロジスティクスドキュメント", - "xpack.snapshotRestore.policyForm.stepLogistics.nameDescription": "このポリシーの固有の識別子です。", - "xpack.snapshotRestore.policyForm.stepLogistics.nameDescriptionTitle": "ポリシー名", - "xpack.snapshotRestore.policyForm.stepLogistics.nameLabel": "名前", - "xpack.snapshotRestore.policyForm.stepLogistics.namePlaceholder": "daily-snapshots", - "xpack.snapshotRestore.policyForm.stepLogistics.policyRepositoryLabel": "レポジトリ", - "xpack.snapshotRestore.policyForm.stepLogistics.policyScheduleButtonAdvancedLabel": "Cron expression を作成", - "xpack.snapshotRestore.policyForm.stepLogistics.policyScheduleButtonBasicLabel": "基本間隔を作成", - "xpack.snapshotRestore.policyForm.stepLogistics.policyScheduleHelpText": "Cron 表現を使用します。{docLink}", - "xpack.snapshotRestore.policyForm.stepLogistics.policyScheduleHelpTextDocLink": "さらに詳しく", - "xpack.snapshotRestore.policyForm.stepLogistics.policyScheduleLabel": "スケジュール", - "xpack.snapshotRestore.policyForm.stepLogistics.policySnapshotNameHelpText": "日付数学処理表現をサポート。{docLink}", - "xpack.snapshotRestore.policyForm.stepLogistics.policySnapshotNameHelpTextDocLink": "さらに詳しく", - "xpack.snapshotRestore.policyForm.stepLogistics.policySnapshotNameLabel": "スナップショット名", - "xpack.snapshotRestore.policyForm.stepLogistics.policySnapshotNamePlaceholder": "<daily-snap-\\{now \\}>", - "xpack.snapshotRestore.policyForm.stepLogistics.repositoryDescription": "スナップショットを格納する際のレポジトリです。", - "xpack.snapshotRestore.policyForm.stepLogistics.repositoryDescriptionTitle": "レポジトリ", - "xpack.snapshotRestore.policyForm.stepLogistics.scheduleDescription": "スナップショットを撮影する頻度です。", - "xpack.snapshotRestore.policyForm.stepLogistics.scheduleDescriptionTitle": "スケジュール", - "xpack.snapshotRestore.policyForm.stepLogistics.snapshotNameDescription": "スナップショットの名前です。それぞれの名前に自動的に追加される固有の識別子です。", - "xpack.snapshotRestore.policyForm.stepLogistics.snapshotNameDescriptionTitle": "スナップショット名", - "xpack.snapshotRestore.policyForm.stepLogisticsTitle": "ロジスティクス", - "xpack.snapshotRestore.policyForm.stepReview.requestTabTitle": "リクエスト", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.allIndicesValue": "すべてのインデックス", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.editStepTooltip": "編集", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.ignoreUnavailableFalseLabel": "いいえ", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.ignoreUnavailableLabel": "利用不可能なインデックスを無視", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.ignoreUnavailableTrueLabel": "はい", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.includeGlobalStateFalseLabel": "いいえ", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.includeGlobalStateLabel": "グローバルステータスを含める", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.includeGlobalStateTrueLabel": "はい", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.indicesCollapseAllLink": "{count, plural, one {# インデックス} other {# インデックス}}を非表示", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.indicesLabel": "インデックス", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.indicesShowAllLink": "{count}その他の{count, plural, one {インデックス} other {インデックス}}を表示", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.nameLabel": "ポリシー名", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.partialFalseLabel": "いいえ", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.partialLabel": "部分シャードを許可", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.partialTrueLabel": "はい", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.repositoryLabel": "レポジトリ", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.scheduleLabel": "スケジュール", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.sectionLogisticsTitle": "ロジスティクス", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.sectionSettingsTitle": "スナップショット設定", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.snapshotNameLabel": "スナップショット名", - "xpack.snapshotRestore.policyForm.stepReview.summaryTabTitle": "まとめ", - "xpack.snapshotRestore.policyForm.stepReviewTitle": "レビューポリシー", - "xpack.snapshotRestore.policyForm.stepSettings.allIndicesLabel": "システムインデックスを含むすべてのインデックス", - "xpack.snapshotRestore.policyForm.stepSettings.deselectAllIndicesLink": "すべて選択解除", - "xpack.snapshotRestore.policyForm.stepSettings.docsButtonLabel": "スナップショット設定ドキュメント", - "xpack.snapshotRestore.policyForm.stepSettings.ignoreUnavailableDescription": "スナップショットの撮影時に利用不可能なインデックスを無視します。これが設定されていない場合、スナップショット全体がエラーになります。", - "xpack.snapshotRestore.policyForm.stepSettings.ignoreUnavailableDescriptionTitle": "利用不可能なインデックスを無視", - "xpack.snapshotRestore.policyForm.stepSettings.ignoreUnavailableLabel": "利用不可能なインデックスを無視", - "xpack.snapshotRestore.policyForm.stepSettings.includeGlobalStateDescription": "スナップショットの一部としてクラスターのグローバルステータスを格納します。", - "xpack.snapshotRestore.policyForm.stepSettings.includeGlobalStateDescriptionTitle": "グローバルステータスを含める", - "xpack.snapshotRestore.policyForm.stepSettings.indicesDescription": "バックアップするインデックスです。", - "xpack.snapshotRestore.policyForm.stepSettings.indicesPatternLabel": "インデックスパターン", - "xpack.snapshotRestore.policyForm.stepSettings.indicesPatternPlaceholder": "logstash-* などのインデックスパターンを入力", - "xpack.snapshotRestore.policyForm.stepSettings.indicesTitle": "インデックス", - "xpack.snapshotRestore.policyForm.stepSettings.indicesToggleCustomLink": "インデックスパターンを使用", - "xpack.snapshotRestore.policyForm.stepSettings.indicesToggleListLink": "インデックスを選択", - "xpack.snapshotRestore.policyForm.stepSettings.partialDescription": "利用不可能なプライマリシャードのインデックスのスナップショットを許可します。これが設定されていない場合、スナップショット全体がエラーになります。", - "xpack.snapshotRestore.policyForm.stepSettings.partialDescriptionTitle": "部分インデックスを許可", - "xpack.snapshotRestore.policyForm.stepSettings.policyIncludeGlobalStateLabel": "グローバルステータスを含める", - "xpack.snapshotRestore.policyForm.stepSettings.selectAllIndicesLink": "すべて選択", - "xpack.snapshotRestore.policyForm.stepSettings.selectIndicesHelpText": "{count} 件の{count, plural, one {インデックス} other {インデックス}}がバックアップされます。{selectOrDeselectAllLink}", - "xpack.snapshotRestore.policyForm.stepSettings.selectIndicesLabel": "インデックスを選択", - "xpack.snapshotRestore.policyForm.stepSettingsTitle": "スナップショット設定", - "xpack.snapshotRestore.policyList.deniedPrivilegeDescription": "スナップショットライフサイクルポリシーを管理するには、{privilegesCount, plural, one {このクラスター特権} other {これらのクラスター特権}}が必要です: {missingPrivileges}。", - "xpack.snapshotRestore.policyList.deniedPrivilegeTitle": "クラスター特権が足りません", - "xpack.snapshotRestore.policyList.emptyPromptDescription": "クラスターを自動的にバックアップするポリシーを作成します。", - "xpack.snapshotRestore.policyList.emptyPromptTitle": "まだスナップショットポリシーがありません", - "xpack.snapshotRestore.policyList.loadingPoliciesDescription": "ポリシーを読み込み中…", - "xpack.snapshotRestore.policyList.LoadingPoliciesErrorMessage": "ポリシーの読み込み中にエラーが発生しました", - "xpack.snapshotRestore.policyList.table.actionDeleteAriaLabel": "ポリシー「{name}」を削除", - "xpack.snapshotRestore.policyList.table.actionDeleteTooltip": "削除", - "xpack.snapshotRestore.policyList.table.actionEditAriaLabel": "ポリシー「{name}」の編集", - "xpack.snapshotRestore.policyList.table.actionEditTooltip": "編集", - "xpack.snapshotRestore.policyList.table.actionExecuteAriaLabel": "「{name}」を直ちに実行", - "xpack.snapshotRestore.policyList.table.actionExecuteDisabledTooltip": "ポリシーを実行中です", - "xpack.snapshotRestore.policyList.table.actionExecuteTooltip": "今すぐ実行", - "xpack.snapshotRestore.policyList.table.actionsColumnTitle": "アクション", - "xpack.snapshotRestore.policyList.table.addPolicyButton": "ポリシーを作成", - "xpack.snapshotRestore.policyList.table.deletePolicyButton": "{count, plural, one {ポリシー} other {ポリシー}}を削除", - "xpack.snapshotRestore.policyList.table.inProgressTooltip": "スナップショット進行中", - "xpack.snapshotRestore.policyList.table.nextExecutionColumnTitle": "次回のスナップショット", - "xpack.snapshotRestore.policyList.table.policyNameColumnTitle": "ポリシー", - "xpack.snapshotRestore.policyList.table.reloadPoliciesButton": "再読み込み", - "xpack.snapshotRestore.policyList.table.repositoryColumnTitle": "レポジトリ", - "xpack.snapshotRestore.policyList.table.repositoryFilterLabel": "レポジトリ", - "xpack.snapshotRestore.policyList.table.scheduleColumnTitle": "スケジュール", - "xpack.snapshotRestore.policyList.table.snapshotNameColumnTitle": "スナップショット名", - "xpack.snapshotRestore.policyScheduleWarningDescription": "一度に 1 つのスナップショットしか撮影できません。スナップショットのエラーを避けるために、ポリシーを編集または削除してください。", - "xpack.snapshotRestore.policyScheduleWarningTitle": "2 つ以上のポリシーに同じスケジュールが設定されています", - "xpack.snapshotRestore.repositories.breadcrumbTitle": "レポジトリ", - "xpack.snapshotRestore.repositoryList.table.typeFilterLabel": "タイプ", - "xpack.snapshotRestore.restoreForm.stepLogistics.indicesPatternLabel": "インデックスパターン", - "xpack.snapshotRestore.restoreForm.stepLogistics.indicesPatternPlaceholder": "logstash-* などのインデックスパターンを入力", - "xpack.snapshotRestore.restoreForm.stepLogistics.indicesToggleCustomLink": "インデックスパターンを使用", - "xpack.snapshotRestore.restoreForm.stepLogistics.indicesToggleListLink": "インデックスを選択", - "xpack.snapshotRestore.restoreList.deniedPrivilegeDescription": "スナップショット復元ステータスを表示するには、1 つ以上のインデックスで{privilegesCount, plural, one {このインデックス特権} other {これらのインデックス特権}}が必要です: {missingPrivileges}。", - "xpack.snapshotRestore.restoreList.deniedPrivilegeTitle": "インデックス特権がありません", - "xpack.snapshotRestore.restoreList.loadingRestoresErrorMessage": "リソースの読み込みエラー", - "xpack.snapshotRestore.restoreStatus.breadcrumbTitle": "ステータスの復元", - "xpack.snapshotRestore.restoreValidation.indexPatternRequiredError": "インデックスパターンが最低 1 つ必要です。", - "xpack.snapshotRestore.snapshotDetails.createdByLabel": "作成者", - "xpack.snapshotRestore.snapshotList.emptyPrompt.addPolicyText": "ポリシーを作成", - "xpack.snapshotRestore.snapshotList.emptyPrompt.goToPoliciesText": "ポリシーを表示", - "xpack.snapshotRestore.snapshotList.emptyPrompt.usePolicyDescription": "スナップショットを作成するには、スナップショットライフサイクルポリシーを実行してください。スナップショットは {docLink} でも作成できます。", - "xpack.snapshotRestore.snapshotList.table.repositoryFilterLabel": "レポジトリ", - "xpack.snapshotRestore.snapshots.breadcrumbTitle": "スナップショット", - "xpack.snapshotRestore.restoreForm.stepLogistics.docsButtonLabel": "スナップショットと復元ドキュメント", - "xpack.snapshotRestore.restoreForm.stepLogisticsTitle": "詳細を復元", - "xpack.snapshotRestore.restoreSnapshot.executeRestoreErrorTitle": "スナップショットを復元できません", - "xpack.snapshotRestore.executeRetention.confirmModal.cancelButtonLabel": "キャンセル", - "xpack.snapshotRestore.executeRetention.confirmModal.confirmButtonLabel": "保存を実行", - "xpack.snapshotRestore.executeRetention.confirmModal.executeRetentionTitle": "今すぐスナップショットの保存を実行しますか?", - "xpack.snapshotRestore.executeRetention.errorMessage": "保存の実行中にエラーが発生しました", - "xpack.snapshotRestore.executeRetention.successMessage": "保存を実行中です", - "xpack.snapshotRestore.policyDetails.expireAfterLabel": "次の期間後削除:", - "xpack.snapshotRestore.policyDetails.generalTitle": "一般", - "xpack.snapshotRestore.policyDetails.maxCountLabel": "最高カウント", - "xpack.snapshotRestore.policyDetails.minCountLabel": "最低カウント", - "xpack.snapshotRestore.policyDetails.retentionTitle": "保存", - "xpack.snapshotRestore.policyDetails.snapshotDeletionFailuresStat": "削除失敗", - "xpack.snapshotRestore.policyDetails.snapshotsDeletedStat": "削除されました", - "xpack.snapshotRestore.policyDetails.snapshotsFailedStat": "失敗", - "xpack.snapshotRestore.policyDetails.snapshotsTakenStat": "スナップショット", - "xpack.snapshotRestore.policyForm.navigation.stepRetentionName": "スナップショットの保存", - "xpack.snapshotRestore.policyForm.stepRetention.countDescription": "クラスターに格納するスナップショットの最少数と最大数。", - "xpack.snapshotRestore.policyForm.stepRetention.countTitle": "保存するスナップショット", - "xpack.snapshotRestore.policyForm.stepRetention.docsButtonLabel": "スナップショット保存ドキュメント", - "xpack.snapshotRestore.policyForm.stepRetention.expirationDescription": "スナップショットの削除までに待つ時間です。", - "xpack.snapshotRestore.policyForm.stepRetention.expirationTitle": "有効期限", - "xpack.snapshotRestore.policyForm.stepRetention.expireAfterLabel": "次の期間後削除:", - "xpack.snapshotRestore.policyForm.stepRetention.maxCountLabel": "最高カウント", - "xpack.snapshotRestore.policyForm.stepRetention.minCountLabel": "最低カウント", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionAddTitle": "保存スケジュールの追加", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionAdvancedLabel": "Cron expression を作成", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionBasicLabel": "基本間隔を作成", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionCancelButtonLabel": "キャンセル", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionEditButtonLabel": "変更を保存", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionEditTitle": "保存スケジュールの編集", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionErrorTitle": "保存スケジュールの保存中にエラーが発生", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionHelpText": "Cron 式を使用します。{docLink}", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionHelpTextDocLinkText": "さらに詳しく", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionSaveButtonLabel": "スケジュール", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionScheduleFieldErrorMessage": "保存スケジュールが必要です。", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionScheduleLabel": "保存スケジュール", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionSuccessMessage": "保存スケジュールが更新されました", - "xpack.snapshotRestore.policyForm.stepRetentionTitle": "スナップショットの保存 (オプション)", - "xpack.snapshotRestore.policyForm.stepReview.editIconAriaLabel": "ステップを編集", - "xpack.snapshotRestore.policyForm.stepReview.retentionTab.expireAfterLabel": "次の期間後削除:", - "xpack.snapshotRestore.policyForm.stepReview.retentionTab.maxCountLabel": "最高カウント", - "xpack.snapshotRestore.policyForm.stepReview.retentionTab.minCountLabel": "最低カウント", - "xpack.snapshotRestore.policyForm.stepReview.retentionTab.sectionRetentionTitle": "スナップショットの保存", - "xpack.snapshotRestore.policyForm.stepSettings.partialIndicesToggleSwitch": "部分インデックスを許可", - "xpack.snapshotRestore.policyList.table.lastSnapshotFailedTooltip": "前回失敗したスナップショットです", - "xpack.snapshotRestore.policyList.table.retentionColumnAriaLabel": "構成された保存", - "xpack.snapshotRestore.policyList.table.retentionColumnTitle": "保存", - "xpack.snapshotRestore.policyRetentionSchedulePanel.addButtonLabel": "スケジュール", - "xpack.snapshotRestore.policyRetentionSchedulePanel.errorFetchingRetentionScheduleReloadButtonLabel": "再読み込み", - "xpack.snapshotRestore.policyRetentionSchedulePanel.errorFetchingRetentionScheduleTitle": "保存スケジュールの取得中にエラーが発生", - "xpack.snapshotRestore.policyRetentionSchedulePanel.executeButtonLabel": "今すぐ実行", - "xpack.snapshotRestore.policyRetentionSchedulePanel.managePanelTitle": "保存オプション", - "xpack.snapshotRestore.policyRetentionSchedulePanel.manageRetentionButtonLabel": "保存の管理", - "xpack.snapshotRestore.policyRetentionSchedulePanel.noScheduleConfiguredWarningDescription": "1 つまたは複数のポリシーに保存期間がありますが、保存がスケジュールされていません。", - "xpack.snapshotRestore.policyRetentionSchedulePanel.noScheduleConfiguredWarningTitle": "保存がスケジュールされていません", - "xpack.snapshotRestore.policyRetentionSchedulePanel.retentionScheduleDescription": "スナップショットを保存する cron スケジュール は {cronSchedule} です。", - "xpack.snapshotRestore.policyRetentionSchedulePanel.retentionScheduleEditLinkAriaLabel": "保存スケジュールの編集", - "xpack.snapshotRestore.policyRetentionSchedulePanel.retentionScheduleEditLinkTooltip": "保存スケジュールの編集", - "xpack.snapshotRestore.policyRetentionSchedulePanel.retentionScheduleExecuteLinkAriaLabel": "今すぐ保存を実行", - "xpack.snapshotRestore.policyRetentionSchedulePanel.retentionScheduleExecuteLinkTooltip": "今すぐ保存を実行", - "xpack.snapshotRestore.policyValidation.indexPatternRequiredErrorMessage": "インデックスパターンが最低 1 つ必要です。", - "xpack.snapshotRestore.policyValidation.indicesRequiredErrorMessage": "インデックスを最低 1 つ選択する必要があります。", - "xpack.snapshotRestore.policyValidation.invalidMinCountErrorMessage": "最低カウントは最高カウントよりも大きい値にできません。", - "xpack.snapshotRestore.policyValidation.nameRequiredErroMessage": "ポリシー名が必要です。", - "xpack.snapshotRestore.policyValidation.repositoryRequiredErrorMessage": "レポジトリが必要です。", - "xpack.snapshotRestore.policyValidation.scheduleRequiredErrorMessage": "スケジュールが必要です。", - "xpack.snapshotRestore.policyValidation.snapshotNameRequiredErrorMessage": "スナップショット名が必要です。", - "xpack.spaces.defaultSpaceDescription": "これはデフォルトのスペースです!", - "xpack.spaces.defaultSpaceTitle": "デフォルト", - "xpack.spaces.displayName": "スペース", - "xpack.spaces.featureDescription": "ダッシュボードやその他の保存済みオブジェクトを、わかりやすいカテゴリー別に整理することができます。", - "xpack.spaces.management.advancedSettingsSubtitle.applyingSettingsOnPageToSpaceDescription": "このページの設定は、別途指定されていない限り {spaceName}’スペースに適用されます。’", - "xpack.spaces.management.advancedSettingsTitle.settingsTitle": "設定", - "xpack.spaces.management.collapsiblePanel.hideLinkDescription": "{title} を非表示", - "xpack.spaces.management.collapsiblePanel.hideLinkText": "非表示", - "xpack.spaces.management.collapsiblePanel.showLinkDescription": "{title} を表示", - "xpack.spaces.management.collapsiblePanel.showLinkText": "表示", - "xpack.spaces.management.confirmAlterActiveSpaceModal.cancelButton": "キャンセル", - "xpack.spaces.management.confirmAlterActiveSpaceModal.reloadWarningMessage": "このスペースで表示される機能を更新しました。保存後にページが更新されます。", - "xpack.spaces.management.confirmAlterActiveSpaceModal.title": "スペースの更新の確認", - "xpack.spaces.management.confirmAlterActiveSpaceModal.updateSpaceButton": "スペースを更新", - "xpack.spaces.management.confirmDeleteModal.allContentsText": "すべてのコンテンツ", - "xpack.spaces.management.confirmDeleteModal.cancelButtonLabel": "キャンセル", - "xpack.spaces.management.confirmDeleteModal.confirmDeleteSpaceButtonLabel": "スペース {spaceName} を削除", - "xpack.spaces.management.confirmDeleteModal.confirmSpaceNameFormRowLabel": "削除するスペース名の確定", - "xpack.spaces.management.confirmDeleteModal.deleteSpaceAndAllContentsButtonLabel": " スペースとすべてのコンテンツを削除", - "xpack.spaces.management.confirmDeleteModal.deletingSpaceWarningMessage": "スペースを削除すると、スペースと {allContents} が永久に削除されます。この操作は元に戻すことができません。", - "xpack.spaces.management.confirmDeleteModal.redirectAfterDeletingCurrentSpaceWarningMessage": "現在のスペース {name} を削除しようとしています。続行すると、別のスペースを選択する画面に移動します。", - "xpack.spaces.management.confirmDeleteModal.spaceNamesDoNoMatchErrorMessage": "スペース名が一致していません。", - "xpack.spaces.management.customizeSpaceAvatar.colorFormRowLabel": "色", - "xpack.spaces.management.customizeSpaceAvatar.initialItemsFormRowLabel": "イニシャル (最大 2 文字)", - "xpack.spaces.management.deleteSpacesButton.deleteSpaceAriaLabel": "スペースを削除", - "xpack.spaces.management.deleteSpacesButton.deleteSpaceButtonLabel": "スペースを削除", - "xpack.spaces.management.deleteSpacesButton.deleteSpaceErrorTitle": "スペースの削除中にエラーが発生: {errorMessage}", - "xpack.spaces.management.deleteSpacesButton.spaceSuccessfullyDeletedNotificationMessage": "{spaceName} スペースが削除されました。", - "xpack.spaces.management.enabledSpaceFeatures.allFeaturesEnabledMessage": "(表示されているすべての機能)", - "xpack.spaces.management.enabledSpaceFeatures.enabledFeaturesSectionMessage": "機能の表示をカスタマイズ", - "xpack.spaces.management.enabledSpaceFeatures.enableFeaturesInSpaceMessage": "このスペースでどの機能が表示されるかを管理します。", - "xpack.spaces.management.enabledSpaceFeatures.goToRolesLink": "セキュアなアクセスをご希望の場合は、{rolesLink} にアクセスしてください。", - "xpack.spaces.management.enabledSpaceFeatures.noFeaturesEnabledMessage": "(表示されている機能がありません)", - "xpack.spaces.management.enabledSpaceFeatures.notASecurityMechanismMessage": "この機能は UI で非表示になっていますが、無効ではありません。", - "xpack.spaces.management.enabledSpaceFeatures.rolesLinkText": "ロール", - "xpack.spaces.management.enabledSpaceFeatures.someFeaturesEnabledMessage": "({featureCount} 件中 {enabledCount} 件の機能を表示中)", - "xpack.spaces.management.enabledSpaceFeaturesEnabledColumnTitle": "表示しますか?", - "xpack.spaces.management.enabledSpaceFeaturesFeatureColumnTitle": "機能", - "xpack.spaces.management.hideAllFeaturesText": "すべて非表示", - "xpack.spaces.management.manageSpacePage.avatarFormRowLabel": "アバター", - "xpack.spaces.management.manageSpacePage.awesomeSpacePlaceholder": "素晴らしいスペース", - "xpack.spaces.management.manageSpacePage.cancelSpaceButton": "キャンセル", - "xpack.spaces.management.manageSpacePage.clickToCustomizeTooltip": "クリックしてこのスペースのアバターをカスタマイズします", - "xpack.spaces.management.manageSpacePage.createSpaceButton": "スペースを作成", - "xpack.spaces.management.manageSpacePage.createSpaceTitle": "スペースの作成", - "xpack.spaces.management.manageSpacePage.customizeSpacePanelDescription": "スペースに名前を付けてアバターをカスタマイズします", - "xpack.spaces.management.manageSpacePage.customizeSpacePanelUrlIdentifierEditable": "URL 識別子に注意してください。スペースの作成後に変更することはできません。", - "xpack.spaces.management.manageSpacePage.customizeSpacePanelUrlIdentifierNotEditable": "URL 識別子は変更できません。", - "xpack.spaces.management.manageSpacePage.customizeSpaceTitle": "スペースのカスタマイズ", - "xpack.spaces.management.manageSpacePage.customizeVisibleFeatures": "表示される機能のカスタマイズ", - "xpack.spaces.management.manageSpacePage.errorLoadingSpaceTitle": "スペースの読み込み中にエラーが発生: {message}", - "xpack.spaces.management.manageSpacePage.errorSavingSpaceTitle": "スペースの保存中にエラーが発生: {message}", - "xpack.spaces.management.manageSpacePage.manageDescription": "保存済みオブジェクトをわかりやすいカテゴリー別に整理します。", - "xpack.spaces.management.manageSpacePage.nameFormRowLabel": "名前", - "xpack.spaces.management.manageSpacePage.spaceDescriptionFormRowLabel": "説明 (オプション)", - "xpack.spaces.management.manageSpacePage.spaceDescriptionHelpText": "説明はスペース選択画面に表示されます。", - "xpack.spaces.management.manageSpacePage.spaceSuccessfullySavedNotificationMessage": "スペース {name} が保存されました。", - "xpack.spaces.management.manageSpacePage.updateSpaceButton": "スペースを更新", - "xpack.spaces.management.reversedSpaceBadge.reversedSpacesCanBePartiallyModifiedTooltip": "リザーブされたスペースはビルトインのため、部分的な変更しかできません。", - "xpack.spaces.management.secureSpaceMessage.howToAssignRoleToSpaceDescription": "スペースへのロールの割り当てをご希望ですか?{rolesLink} にアクセスしてください。", - "xpack.spaces.management.secureSpaceMessage.rolesLinkText": "ロール", - "xpack.spaces.management.secureSpaceMessage.rolesLinkTextAriaLabel": "ロール管理ページ", - "xpack.spaces.management.showAllFeaturesText": "すべて表示", - "xpack.spaces.management.spaceIdentifier.customizeSpaceLinkText": "[カスタマイズ]", - "xpack.spaces.management.spaceIdentifier.customizeSpaceNameLinkLabel": "URL 識別子をカスタマイズ", - "xpack.spaces.management.spaceIdentifier.emptySpaceIdentifierText": "awesome-space", - "xpack.spaces.management.spaceIdentifier.kibanaURLForSpaceIdentifierDescription": "例: https://my-kibana.example{spaceIdentifier}/app/kibana.", - "xpack.spaces.management.spaceIdentifier.resetSpaceNameLinkLabel": "URL 識別子をリセット", - "xpack.spaces.management.spaceIdentifier.resetSpaceNameLinkText": "[リセット]", - "xpack.spaces.management.spaceIdentifier.urlIdentifierGeneratedFromSpaceNameTooltip": "awesome-space", - "xpack.spaces.management.spaceIdentifier.urlIdentifierLabel": "URL 識別子 ", - "xpack.spaces.management.spaceIdentifier.urlIdentifierTitle": "URL 識別子", - "xpack.spaces.management.spacesGridPage.actionsColumnName": "アクション", - "xpack.spaces.management.spacesGridPage.allFeaturesEnabled": "表示されているすべての機能", - "xpack.spaces.management.spacesGridPage.createSpaceButtonLabel": "スペースの作成", - "xpack.spaces.management.spacesGridPage.deleteActionName": "{spaceName} を削除。", - "xpack.spaces.management.spacesGridPage.descriptionColumnName": "説明", - "xpack.spaces.management.spacesGridPage.editSpaceActionName": "{spaceName} を編集。", - "xpack.spaces.management.spacesGridPage.errorDeletingSpaceErrorMessage": "スペースの削除中にエラーが発生: {errorMessage}", - "xpack.spaces.management.spacesGridPage.featuresColumnName": "機能", - "xpack.spaces.management.spacesGridPage.identifierColumnName": "識別子", - "xpack.spaces.management.spacesGridPage.loadingTitle": "読み込み中…", - "xpack.spaces.management.spacesGridPage.noFeaturesEnabled": "表示されている機能がありません", - "xpack.spaces.management.spacesGridPage.searchPlaceholder": "検索", - "xpack.spaces.management.spacesGridPage.someFeaturesEnabled": "{totalFeatureCount} 件中 {enabledFeatureCount} 件の機能を表示中", - "xpack.spaces.management.spacesGridPage.spaceColumnName": "スペース", - "xpack.spaces.management.spacesGridPage.spacesTitle": "スペース", - "xpack.spaces.management.spacesGridPage.spaceSuccessfullyDeletedNotificationMessage": "「{spaceName}」 スペースが削除されました。", - "xpack.spaces.management.toggleAllFeaturesLink": "(すべて変更)", - "xpack.spaces.management.unauthorizedPrompt.permissionDeniedDescription": "スペースを管理するパーミッションがありません。", - "xpack.spaces.management.unauthorizedPrompt.permissionDeniedTitle": "パーミッションが拒否されました", - "xpack.spaces.management.validateSpace.describeMaxLengthErrorMessage": "説明は 2000 文字以内でなければなりません。", - "xpack.spaces.management.validateSpace.nameMaxLengthErrorMessage": "名前はは 1024 文字以内でなければなりません。", - "xpack.spaces.management.validateSpace.requiredNameErrorMessage": "名前が必要です。", - "xpack.spaces.management.validateSpace.urlIdentifierAllowedCharactersErrorMessage": "URL 識別子には a-z、0-9、「_」、「-」のみ使用できます。", - "xpack.spaces.management.validateSpace.urlIdentifierRequiredErrorMessage": "URL 識別子が必要です。", - "xpack.spaces.manageSpacesButton.manageSpacesButtonLabel": "スペースの管理", - "xpack.spaces.navControl.spacesMenu.changeCurrentSpaceTitle": "現在のスペースの変更", - "xpack.spaces.navControl.spacesMenu.findSpacePlaceholder": "スペースを検索", - "xpack.spaces.navControl.spacesMenu.noSpacesFoundTitle": " スペースが見つかりません ", - "xpack.spaces.spaceSelector.changeSpaceAnytimeAvailabilityText": "スペースはいつでも変更できます", - "xpack.spaces.spaceSelector.findSpacePlaceholder": "スペースを検索", - "xpack.spaces.spaceSelector.noSpacesMatchSearchCriteriaDescription": "検索条件に一致するスペースがありません", - "xpack.spaces.spaceSelector.selectSpacesTitle": "スペースの選択", - "xpack.spaces.spacesTitle": "スペース", - "xpack.spaces.management.customizeSpaceAvatar.imageUrl": "カスタム画像", - "xpack.spaces.management.customizeSpaceAvatar.removeImage": "カスタム画像を削除", - "xpack.spaces.management.customizeSpaceAvatar.selectImageUrl": "画像ファイルを選択", - "telemetry.callout.appliesSettingTitle": "この設定は {allOfKibanaText} に適用されます", - "telemetry.callout.appliesSettingTitle.allOfKibanaText": "Kibana のすべて", - "telemetry.callout.clusterStatisticsDescription": "これは収集される基本的なクラスター統計の例です。インデックス、シャード、ノードの数が含まれます。監視がオンになっているかどうかなどのハイレベルの使用統計も含まれます。", - "telemetry.callout.clusterStatisticsTitle": "クラスター統計", - "telemetry.callout.errorLoadingClusterStatisticsDescription": "クラスター統計の取得中に予期せぬエラーが発生しました。Elasticsearch、Kibana、またはネットワークのエラーが原因の可能性があります。Kibana を確認し、ページを再読み込みして再試行してください。", - "telemetry.callout.errorLoadingClusterStatisticsTitle": "クラスター統計の読み込みエラー", - "telemetry.callout.errorUnprivilegedUserDescription": "暗号化されていないクラスター統計を表示するアクセス権がありません。", - "telemetry.callout.errorUnprivilegedUserTitle": "クラスター統計の表示エラー", - "telemetry.readOurUsageDataPrivacyStatementLinkText": "使用データのプライバシーステートメントをお読みください", - "telemetry.seeExampleOfWhatWeCollectLinkText": "収集されるデータの例を見る", - "telemetry.telemetryConfigDescription": "基本的な機能の利用状況に関する統計情報を提供して、Elastic Stack の改善にご協力ください。このデータは Elastic 社外と共有されません。", - "telemetry.telemetryConfigTitle": "遠隔測定オプトイン", - "telemetry.telemetryErrorNotificationMessageDescription.tryAgainText": "Kibana と Elasticsearch が現在も実行中であることを確認し、再試行してください。", - "telemetry.telemetryErrorNotificationMessageDescription.unableToSaveTelemetryPreferenceText": "遠隔測定設定を保存できません。", - "telemetry.telemetryErrorNotificationMessageTitle": "遠隔測定エラー", - "telemetry.usageDataTitle": "使用データ", - "telemetry.welcomeBanner.telemetryConfigDetailsDescription.telemetryPrivacyStatementLinkText": "遠隔測定に関するプライバシーステートメント", - "telemetry.optInErrorToastText": "使用状況統計設定の設定中にエラーが発生しました。", - "telemetry.optInErrorToastTitle": "エラー", - "telemetry.welcomeBanner.title": "Elastic Stack の改善にご協力ください", - "xpack.upgradeAssistant.appTitle": "{version} アップグレードアシスタント", - "xpack.upgradeAssistant.checkupTab.backUpCallout.calloutBody.calloutDetail": "{snapshotRestoreDocsButton} でデータをバックアップします。", - "xpack.upgradeAssistant.checkupTab.backUpCallout.calloutBody.snapshotRestoreDocsButtonLabel": "API のスナップショットと復元", - "xpack.upgradeAssistant.checkupTab.backUpCallout.calloutTitle": "今すぐインデックをバックアップ", - "xpack.upgradeAssistant.checkupTab.changeFiltersShowMoreLabel": "より多く表示させるにはフィルターを変更します。", - "xpack.upgradeAssistant.checkupTab.clusterTabLabel": "クラスター", - "xpack.upgradeAssistant.checkupTab.controls.collapseAllButtonLabel": "すべて縮小", - "xpack.upgradeAssistant.checkupTab.controls.expandAllButtonLabel": "すべて拡張", - "xpack.upgradeAssistant.checkupTab.controls.filterBar.allButtonLabel": "すべて", - "xpack.upgradeAssistant.checkupTab.controls.filterBar.criticalButtonLabel": "致命的", - "xpack.upgradeAssistant.checkupTab.controls.groupByBar.byIndexLabel": "インデックス別", - "xpack.upgradeAssistant.checkupTab.controls.groupByBar.byIssueLabel": "問題別", - "xpack.upgradeAssistant.checkupTab.controls.refreshButtonLabel": "更新", - "xpack.upgradeAssistant.checkupTab.controls.searchBarPlaceholder": "フィルター", - "xpack.upgradeAssistant.checkupTab.deprecations.criticalActionTooltip": "アップグレード前にこの問題を解決してください。", - "xpack.upgradeAssistant.checkupTab.deprecations.criticalLabel": "致命的", - "xpack.upgradeAssistant.checkupTab.deprecations.documentationButtonLabel": "ドキュメント", - "xpack.upgradeAssistant.checkupTab.deprecations.indexTable.detailsColumnLabel": "詳細", - "xpack.upgradeAssistant.checkupTab.deprecations.indexTable.indexColumnLabel": "インデックス", - "xpack.upgradeAssistant.checkupTab.deprecations.warningActionTooltip": "アップグレード前にこの問題を解決することをお勧めしますが、必須ではありません。", - "xpack.upgradeAssistant.checkupTab.deprecations.warningLabel": "警告", - "xpack.upgradeAssistant.checkupTab.indexLabel": "インデックス", - "xpack.upgradeAssistant.checkupTab.indicesBadgeLabel": "{numIndices, plural, one {インデックス} other {インデックス}}", - "xpack.upgradeAssistant.checkupTab.indicesTabLabel": "インデックス", - "xpack.upgradeAssistant.checkupTab.noDeprecationsLabel": "説明がありません", - "xpack.upgradeAssistant.checkupTab.noIssues.nextStepsDetail": "{overviewTabButton} で次のステップを確認してください。", - "xpack.upgradeAssistant.checkupTab.noIssues.nextStepsDetail.overviewTabButtonLabel": "概要タブ", - "xpack.upgradeAssistant.checkupTab.noIssues.noIssuesLabel": "{strongCheckupLabel} の問題がありません。", - "xpack.upgradeAssistant.checkupTab.noIssues.noIssuesTitle": "完璧です!", - "xpack.upgradeAssistant.checkupTab.numDeprecationsShownLabel": "{total} 件中 {numShown} 件を表示中", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.cancelButtonLabel": "キャンセル", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.closeButtonLabel": "閉じる", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.continueButtonLabel": "再インデックスを続ける", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.insufficientPrivilegeCallout.calloutTitle": "このインデックスを再インデックスするための権限がありません", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.readonlyCallout.backgroundResumeDetail": "再インデックスはバックグラウンドで継続しますが、Kibana がシャットダウンまたは再起動した場合、このページに戻り再インデックスを再開させる必要があります。", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.readonlyCallout.calloutTitle": "インデックスは再インデックス中にドキュメントを投入、更新、または削除できません", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.readonlyCallout.cantStopDetail": "ドキュメントの更新を停止できない場合、または新しいクラスターに再インデックスする必要がある場合は、異なるアップグレード方法をお勧めします。", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexButton.doneLabel": "完了!", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexButton.reindexingLabel": "再インデックス中…", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexButton.resumeLabel": "再開", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexButton.runReindexLabel": "再インデックスを実行", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexButton.tryAgainLabel": "再試行", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.aliasSwapStepTitle": "オリジナルのインデックスをエイリアスと交換中", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.cancelButton.cancelLabel": "キャンセル", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.cancelButton.cancelledLabel": "キャンセル済み", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.cancelButton.cancellingLabel": "キャンセル中…", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.cancelButton.errorLabel": "キャンセルできませんでした", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.createIndexStepTitle": "新規インデックスを作成中", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.pauseMlStepTitle": "機械学習ジョブを一時停止中", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.readonlyStepTitle": "古いインデックスを読み込み専用に設定中", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.reindexingDocumentsStepTitle": "ドキュメントを再インデックス中", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.resumeMlStepTitle": "機械学習ジョブを再開中", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.resumeWatcherStepTitle": "Watcher を再開中", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.stopWatcherStepTitle": "Watcher を停止中", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklistTitle": "プロセスを再インデックス中", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.flyoutHeader": "{indexName} を再インデックス", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.warningsStep.apmReindexWarningDetail": "バージョン 7.0.0 以降、APM データは Elastic Common Schema で表示されます。過去の APM データは再インデックスされるまで表示されません。", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.warningsStep.apmReindexWarningTitle": "このインデックスは ECS 形式に変換されます", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.warningsStep.destructiveCallout.calloutDetail": "インデックスをバックアップして、互換性を破るそれぞれの変更に同意することで再インデックスしてください。", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.warningsStep.destructiveCallout.calloutTitle": "このインデックスには元に戻すことのできない破壊的な変更が含まれています", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.warningsStep.documentationLinkLabel": "ドキュメンテーション", - "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.cancelledLabel": "キャンセル済み", - "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.doneLabel": "完了", - "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.failedLabel": "失敗", - "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.loadingLabel": "読み込み中…", - "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.pausedLabel": "一時停止中", - "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.reindexLabel": "再インデックス", - "xpack.upgradeAssistant.checkupTab.tabDetail": "これらの {strongCheckupLabel} の問題への対処が必要です。Elasticsearch {nextEsVersion} へのアップグレード前に解決してください。", - "xpack.upgradeAssistant.forbiddenErrorCallout.calloutTitle": "このページを表示するための権限がありません。", - "xpack.upgradeAssistant.genericErrorCallout.calloutTitle": "チェックアップの結果を取得中にエラーが発生しました。", - "xpack.upgradeAssistant.overviewTab.overviewTabTitle": "概要", - "xpack.upgradeAssistant.overviewTab.steps.clusterStep.issuesRemainingStepTitle": "クラスターの問題を確認してください", - "xpack.upgradeAssistant.overviewTab.steps.clusterStep.noIssuesRemainingStepTitle": "クラスターの設定は準備完了です", - "xpack.upgradeAssistant.overviewTab.steps.clusterStep.noRemainingIssuesLabel": "廃止された設定は残っていません。", - "xpack.upgradeAssistant.overviewTab.steps.clusterStep.remainingIssuesDetail": "{numIssues} 件の問題が解決されました。", - "xpack.upgradeAssistant.overviewTab.steps.clusterStep.todo.clusterTabButtonLabel": "クラスタータブ", - "xpack.upgradeAssistant.overviewTab.steps.clusterStep.todo.todoDetail": "{clusterTabButton} に移動して廃止された設定を更新してください。", - "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.deprecationLogs.deprecationLogsDocButtonLabel": "廃止ログ", - "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.deprecationLogs.logsDetail": "{deprecationLogsDocButton} で、アプリケーションが {nextEsVersion} で利用できない機能を使用していないか確認してください。廃止ログを有効にする必要があるかもしれません。", - "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.enableDeprecationLoggingLabel": "廃止ログを有効にしますか?", - "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.enableDeprecationLoggingToggleSwitch.disabledLabel": "オフ", - "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.enableDeprecationLoggingToggleSwitch.enabledLabel": "オン", - "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.enableDeprecationLoggingToggleSwitch.errorLabel": "ログステータスを読み込めませんでした", - "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.stepTitle": "Elasticsearch の廃止ログを確認してください", - "xpack.upgradeAssistant.overviewTab.steps.indicesStep.issuesRemainingStepTitle": "インデックスの問題を確認してください", - "xpack.upgradeAssistant.overviewTab.steps.indicesStep.noIssuesRemainingStepTitle": "インデックスの設定は準備完了です", - "xpack.upgradeAssistant.overviewTab.steps.indicesStep.noRemainingIssuesLabel": "廃止された設定は残っていません。", - "xpack.upgradeAssistant.overviewTab.steps.indicesStep.remainingIssuesDetail": "{numIssues} 件の問題が解決されました。", - "xpack.upgradeAssistant.overviewTab.steps.indicesStep.todo.indicesTabButtonLabel": "インデックスタブ", - "xpack.upgradeAssistant.overviewTab.steps.indicesStep.todo.todoDetail": "{indicesTabButton} に移動して廃止された設定を更新してください。", - "xpack.upgradeAssistant.overviewTab.steps.startUpgradeStep.stepTitle": "アップグレード開始", - "xpack.upgradeAssistant.overviewTab.steps.startUpgradeStepCloud.stepDetail.goToCloudDashboardDetail": "Elastic Cloud ダッシュボードのデプロイセクションに移動し、アップグレードを開始します。", - "xpack.upgradeAssistant.overviewTab.steps.startUpgradeStepOnPrem.stepDetail.followInstructionsDetail": "{instructionButton} に従い、アップグレードを開始します。", - "xpack.upgradeAssistant.overviewTab.steps.startUpgradeStepOnPrem.stepDetail.instructionButtonLabel": "これらの手順", - "xpack.upgradeAssistant.overviewTab.steps.waitForReleaseStep.stepDetail": "リリースされ次第最新の {currentEsMajorVersion} バージョンにアップグレードし、ここに戻って {nextEsMajorVersion} へのアップグレードを行ってください。", - "xpack.upgradeAssistant.overviewTab.steps.waitForReleaseStep.stepTitle": "Elasticsearch {nextEsVersion} のリリース待ち", - "xpack.upgradeAssistant.overviewTab.tabDetail": "このアシスタントは、クラスターとインデックスの Elasticsearch への準備に役立ちます {nextEsVersion} 対処が必要な他の問題に関しては、Elasticsearch のログをご覧ください。", - "xpack.upgradeAssistant.tabs.checkupTab.clusterLabel": "クラスター", - "xpack.upgradeAssistant.tabs.incompleteCallout.calloutBody.breackingChangesDocButtonLabel": "廃止と互換性を破る変更", - "xpack.upgradeAssistant.tabs.incompleteCallout.calloutBody.calloutDetail": "Elasticsearch {nextEsVersion} の {breakingChangesDocButton} の完全なリストは、最終の {currentEsVersion} マイナーリリースで確認できます。この警告は、リストがすべて解決されると消えます。", - "xpack.upgradeAssistant.tabs.incompleteCallout.calloutTitle": "リストの問題がすべて解決されていない可能性があります。", - "xpack.upgradeAssistant.tabs.upgradingInterstitial.upgradeCompleteDescription": "すべての Elasticsearch ノードがアップグレードされました。Kibana をアップデートする準備ができました。", - "xpack.upgradeAssistant.tabs.upgradingInterstitial.upgradeCompleteTitle": "クラスターがアップグレードされました", - "xpack.upgradeAssistant.tabs.upgradingInterstitial.upgradingDescription": "1 つまたは複数の Elasticsearch ノードに、 Kibana よりも新しいバージョンの Elasticsearch があります。すべてのノードがアップグレードされた後で Kibana をアップグレードしてください。", - "xpack.upgradeAssistant.tabs.upgradingInterstitial.upgradingTitle": "クラスターをアップグレード中です", - "xpack.uptime.apmIntegrationAction.description": "このモニターの検索 APM", - "xpack.uptime.apmIntegrationAction.text": "ドメインでAPMを確認", - "xpack.uptime.badge.readOnly.text": "読み込み専用", - "xpack.uptime.badge.readOnly.tooltip": "を保存できませんでした", - "xpack.uptime.breadcrumbs.overviewBreadcrumbText": "アップタイム", - "xpack.uptime.emptyState.configureHeartbeatLinkText": "Heartbeat を構成", - "xpack.uptime.emptyState.configureHeartbeatToGetStartedMessage": "アップタイムデータの収集を開始するには {configureHeartbeatLink}。", - "xpack.uptime.emptyState.loadingMessage": "読み込み中…", - "xpack.uptime.emptyState.noDataTitle": "利用可能なアップタイムデータがありません", - "xpack.uptime.emptyStateError.title": "エラー", - "xpack.uptime.errorMessage": "エラー: {message}", - "xpack.uptime.featureCatalogueDescription": "エンドポイントヘルスチェックとアップタイム監視を行います。", - "xpack.uptime.featureRegistry.uptimeFeatureName": "アップタイム", - "xpack.uptime.filterBar.filterDownLabel": "ダウン", - "xpack.uptime.filterBar.filterUpLabel": "アップ", - "xpack.uptime.filterBar.options.location.name": "場所", - "xpack.uptime.filterBar.options.portLabel": "ポート", - "xpack.uptime.filterBar.options.schemeLabel": "スキーム", - "xpack.uptime.integrationLink.missingDataMessage": "この統合に必要なデータが見つかりませんでした。", - "xpack.uptime.monitorCharts.checkStatus.series.downCountLabel": "ダウンカウント", - "xpack.uptime.monitorCharts.checkStatus.series.upCountLabel": "アップカウント", - "xpack.uptime.monitorCharts.checkStatus.title": "ステータスを確認", - "xpack.uptime.monitorCharts.loadingMessage": "読み込み中…", - "xpack.uptime.monitorCharts.monitorDuration.titleLabel": "ミリ秒単位の監視時間", - "xpack.uptime.monitorList.downLineSeries.downLabel": "ダウン", - "xpack.uptime.monitorList.infraIntegrationAction.container.message": "コンテナーメトリックを表示", - "xpack.uptime.monitorList.infraIntegrationAction.docker.description": "このモニターのコンテナー ID のインフラストラクチャ UI を確認します", - "xpack.uptime.monitorList.infraIntegrationAction.docker.tooltip": "コンテナー ID「{containerId}」のインフラストラクチャ UI を確認します", - "xpack.uptime.monitorList.infraIntegrationAction.ip.ariaLabel": "このモニターの IP アドレスのインフラストラクチャ UI を確認します", - "xpack.uptime.monitorList.infraIntegrationAction.ip.message": "ホストメトリックを表示", - "xpack.uptime.monitorList.infraIntegrationAction.ip.tooltip": "IP「{ip}」のインフラストラクチャ UI を確認します", - "xpack.uptime.monitorList.infraIntegrationAction.kubernetes.description": "このモニターのポッド ID のインフラストラクチャ UI を確認します", - "xpack.uptime.monitorList.infraIntegrationAction.kubernetes.message": "ポッドメトリックを表示", - "xpack.uptime.monitorList.infraIntegrationAction.kubernetes.tooltip": "ポッド UID「{podUid}」のインフラストラクチャ UI を確認します", - "xpack.uptime.monitorList.integrationGroup.emptyMessage": "統合されたアプリケーションがありません", - "xpack.uptime.monitorList.loggingIntegrationAction.container.id": "コンテナーログを表示", - "xpack.uptime.monitorList.loggingIntegrationAction.container.message": "コンテナーログを表示", - "xpack.uptime.monitorList.loggingIntegrationAction.container.tooltip": "コンテナー ID「{containerId}」のロギング UI を確認します", - "xpack.uptime.monitorList.loggingIntegrationAction.kubernetes.ariaLabel": "ポッドログを表示", - "xpack.uptime.monitorList.loggingIntegrationAction.kubernetes.message": "ポッドログを表示", - "xpack.uptime.monitorList.loggingIntegrationAction.kubernetes.tooltip": "ポッド UID「{podUid}」のログを確認します", - "xpack.uptime.monitorList.monitorHistoryColumnLabel": "ダウンタイム履歴", - "xpack.uptime.monitorList.monitoringStatusTitle": "監視ステータス", - "xpack.uptime.monitorList.observabilityIntegrationsColumn.apmIntegrationLink.tooltip": "ここをクリックしてAPM でドメイン「{domain}」を確認します。", - "xpack.uptime.monitorList.observabilityIntegrationsColumn.popoverIconButton.ariaLabel": "URL {monitorUrl}で監査のための移行ポップオーバーを開く", - "xpack.uptime.monitorList.statusColumn.downLabel": "ダウン", - "xpack.uptime.monitorList.statusColumn.upLabel": "アップ", - "xpack.uptime.monitorList.statusColumnLabel": "ステータス", - "xpack.uptime.monitorStatusBar.durationTextAriaLabel": "ミリ秒単位の監視時間", - "xpack.uptime.monitorStatusBar.healthStatusMessage.downLabel": "ダウン", - "xpack.uptime.monitorStatusBar.healthStatusMessage.upLabel": "アップ", - "xpack.uptime.monitorStatusBar.healthStatusMessageAriaLabel": "監視ステータス", - "xpack.uptime.monitorStatusBar.loadingMessage": "読み込み中…", - "xpack.uptime.monitorStatusBar.monitorUrlLinkAriaLabel": "監視 URL リンク", - "xpack.uptime.monitorStatusBar.timestampFromNowTextAriaLabel": "最終確認からの経過時間", - "xpack.uptime.overviewPage.headerText": "概要", - "xpack.uptime.pingList.checkHistoryTitle": "履歴", - "xpack.uptime.pingList.durationMsColumnLabel": "期間", - "xpack.uptime.pingList.errorTypeColumnLabel": "エラータイプ", - "xpack.uptime.pingList.ipAddressColumnLabel": "IP", - "xpack.uptime.pingList.recencyMessage": "最終確認 {fromNow}", - "xpack.uptime.pingList.responseCodeColumnLabel": "応答コード", - "xpack.uptime.pingList.statusColumnHealthDownLabel": "ダウン", - "xpack.uptime.pingList.statusColumnHealthUpLabel": "アップ", - "xpack.uptime.pingList.statusColumnLabel": "ステータス", - "xpack.uptime.pingList.statusLabel": "ステータス", - "xpack.uptime.pingList.statusOptions.allStatusOptionLabel": "すべて", - "xpack.uptime.pingList.statusOptions.downStatusOptionLabel": "ダウン", - "xpack.uptime.pingList.statusOptions.upStatusOptionLabel": "アップ", - "xpack.uptime.pluginDescription": "アップタイム監視", - "xpack.uptime.snapshot.noDataDescription": "申し訳ございませんが、ヒストグラムに利用可能なデータがありません", - "xpack.uptime.snapshot.noDataTitle": "ヒストグラムデータがありません", - "xpack.uptime.snapshotHistogram.series.downLabel": "ダウン", - "xpack.uptime.snapshotHistogram.series.upLabel": "アップ", - "xpack.uptime.uptimeFeatureCatalogueTitle": "起動時間", - "xpack.uptime.emptyState.noDataMessage": "アップタイムデータが見つかりませんでした", - "xpack.uptime.pingList.collapseRow": "縮小", - "xpack.uptime.pingList.durationMsColumnFormatting": "{millis}ミリ秒", - "xpack.uptime.pingList.expandedRow.bodySize": "本文サイズは {bodyBytes} です。", - "xpack.uptime.pingList.expandedRow.error": "エラー", - "xpack.uptime.pingList.expandedRow.response_body": "応答本文", - "xpack.uptime.pingList.expandedRow.truncated": "初めの {contentBytes} バイトを表示中。", - "xpack.uptime.pingList.expandRow": "拡張", - "xpack.uptime.snapshot.pingsOverTimeTitle": "一定時間のピング", - "xpack.uptime.snapshotHistogram.yAxis.title": "ピング", - "xpack.uptime.snapshot.donutChart.ariaLabel": "現在のステータスを表す円グラフ、{total} 個中 {down} 個のモニターがダウンしています。", - "xpack.uptime.snapshot.donutChart.legend.downRowLabel": "ダウン", - "xpack.uptime.snapshot.donutChart.legend.upRowLabel": "アップ", - "xpack.uptime.durationChart.emptyPrompt.description": "このモニターは選択された時間範囲で一度も {emphasizedText} していません。", - "xpack.uptime.durationChart.emptyPrompt.title": "利用可能な期間データがありません", - "xpack.uptime.emptyStateError.notAuthorized": "アップタイムデータの表示が承認されていません。システム管理者にお問い合わせください。", - "xpack.uptime.emptyStateError.notFoundPage": "ページが見つかりません", - "xpack.uptime.filterPopout.loadingMessage": "読み込み中…", - "xpack.uptime.filterPopout.searchMessage": "{title} を検索", - "xpack.uptime.kueryBar.indexPatternMissingWarningMessage": "インデックスパターンの取得中にエラーが発生しました。", - "xpack.uptime.kueryBar.searchPlaceholder": "モニター ID、名前、プロトコルタイプなどを検索…", - "xpack.uptime.monitorList.noItemForSelectedFiltersMessage": "選択されたフィルター条件でモニターが見つかりませんでした", - "xpack.uptime.monitorList.table.description": "列にステータス、名前、URL、IP、ダウンタイム履歴、統合が入力されたモニターステータス表です。この表は現在 {length} 項目を表示しています。", - "xpack.uptime.notFountPage.homeLinkText": "ホームへ戻る", - "xpack.uptime.overviewPageLink.disabled.ariaLabel": "無効になったページ付けボタンです。モニターリストがこれ以上ナビゲーションできないことを示しています。", - "xpack.uptime.overviewPageLink.next.ariaLabel": "次の結果ページ", - "xpack.uptime.overviewPageLink.prev.ariaLabel": "前の結果ページ", - "xpack.uptime.overviewPageParsingErrorCallout.content": "フィルタークエリの解析中にエラーが発生しました. {content}", - "xpack.uptime.overviewPageParsingErrorCallout.noMessage": "エラーメッセージはありませんでした", - "xpack.uptime.overviewPageParsingErrorCallout.title": "エラーを解析中", - "xpack.uptime.snapshot.downCountsMessage": "{down}/{total} 個のモニターがダウンしています", - "xpack.uptime.snapshotHistogram.description": "{startTime} から {endTime} までの期間のアップタイムステータスを表示する棒グラフです。", - "xpack.watcher.constants.actionStates.acknowledgedStateText": "承認済み", - "xpack.watcher.constants.actionStates.configErrorStateText": "構成エラー", - "xpack.watcher.constants.actionStates.errorStateText": "エラー", - "xpack.watcher.constants.actionStates.firingStateText": "実行中", - "xpack.watcher.constants.actionStates.okStateText": "OK", - "xpack.watcher.constants.actionStates.throttledStateText": "スロットル", - "xpack.watcher.constants.watchStateComments.acknowledgedStateCommentText": "承認済み", - "xpack.watcher.constants.watchStateComments.executionFailingStateCommentText": "実行失敗", - "xpack.watcher.constants.watchStateComments.partiallyAcknowledgedStateCommentText": "部分承認済み", - "xpack.watcher.constants.watchStateComments.partiallyThrottledStateCommentText": "部分スロットル", - "xpack.watcher.constants.watchStateComments.throttledStateCommentText": "スロットル", - "xpack.watcher.constants.watchStates.configErrorStateText": "構成エラー", - "xpack.watcher.constants.watchStates.disabledStateText": "無効", - "xpack.watcher.constants.watchStates.errorStateText": "エラー", - "xpack.watcher.constants.watchStates.firingStateText": "実行中", - "xpack.watcher.constants.watchStates.okStateText": "OK", - "xpack.watcher.models.actionStatus.notDetermineActionStatusBadImplementationMessage": "アクションステータスを把握できませんでした; action = {actionStatusJson}", - "xpack.watcher.models.baseAction.selectMessageText": "アクションを実行します。", - "xpack.watcher.models.baseAction.simulateButtonLabel": "今すぐこのアクションをシミュレート", - "xpack.watcher.models.baseAction.simulateMessage": "アクション {id} のシミュレーションが完了しました", - "xpack.watcher.models.baseAction.typeName": "アクション", - "xpack.watcher.models.baseWatch.createUnknownActionTypeErrorMessage": "不明なアクションタイプ {type} を作成しようとしました。", - "xpack.watcher.models.baseWatch.displayName": "新規ウォッチ", - "xpack.watcher.models.baseWatch.idPropertyMissingBadRequestMessage": "json 引数には {id} プロパティが含まれている必要があります", - "xpack.watcher.models.baseWatch.selectMessageText": "新規ウォッチをセットアップします。", - "xpack.watcher.models.baseWatch.typeName": "ウォッチ", - "xpack.watcher.models.baseWatch.watchJsonPropertyMissingBadRequestMessage": "json 引数には {watchJson} プロパティが含まれている必要があります", - "xpack.watcher.models.baseWatch.watchStatusJsonPropertyMissingBadRequestMessage": "json 引数には {watchStatusJson} プロパティが含まれている必要があります", - "xpack.watcher.models.emailAction.actionJsonEmailPropertyMissingBadRequestMessage": "json 引数には {actionJsonEmail} プロパティが含まれている必要があります", - "xpack.watcher.models.emailAction.actionJsonEmailToPropertyMissingBadRequestMessage": "json 引数には {actionJsonEmailTo} プロパティが含まれている必要があります", - "xpack.watcher.models.emailAction.selectMessageText": "サーバーからメールを送信します。", - "xpack.watcher.models.emailAction.simulateButtonLabel": "今すぐメールをテスト送信", - "xpack.watcher.models.emailAction.simulateFailMessage": "{toList} へのメールの送信に失敗しました。", - "xpack.watcher.models.emailAction.simulateMessage": "{toList} にサンプルメールが送信されました", - "xpack.watcher.models.emailAction.typeName": "メール", - "xpack.watcher.models.fields.fieldsPropertyMissingBadRequestMessage": "json 引数には {fields} プロパティが含まれている必要があります", - "xpack.watcher.models.indexAction.simulateFailMessage": "{index} のインデックスに失敗しました。", - "xpack.watcher.models.indexAction.simulateMessage": "インデックス {index} がインデックスされました。", - "xpack.watcher.models.jiraAction.simulateFailMessage": "Jira の問題の作成に失敗しました。", - "xpack.watcher.models.jiraAction.simulateMessage": "Jira の問題が作成されました。", - "xpack.watcher.models.jsonWatch.selectMessageText": "生 JSON のカスタムウォッチをセットアップします。", - "xpack.watcher.models.jsonWatch.typeName": "高度なウォッチ", - "xpack.watcher.models.loggingAction.actionJsonLoggingPropertyMissingBadRequestMessage": "json 引数には {actionJsonLogging} プロパティが含まれている必要があります", - "xpack.watcher.models.loggingAction.actionJsonLoggingTextPropertyMissingBadRequestMessage": "json 引数には {actionJsonLoggingText} プロパティが含まれている必要があります", - "xpack.watcher.models.loggingAction.selectMessageText": "ログに新規項目を追加します。", - "xpack.watcher.models.loggingAction.simulateButtonLabel": "今すぐサンプルメッセージを記録", - "xpack.watcher.models.loggingAction.simulateFailMessage": "サンプルメッセージの記録に失敗しました", - "xpack.watcher.models.loggingAction.simulateMessage": "サンプルメッセージが記録されました", - "xpack.watcher.models.loggingAction.typeName": "ログ", - "xpack.watcher.models.monitoringWatch.formatVisualizeDataCalledBadRequestMessage": "ウォッチの監視に {formatVisualizeData} が必要です", - "xpack.watcher.models.monitoringWatch.fromDownstreamJsonCalledBadRequestMessage": "ウォッチの監視に {fromDownstreamJson} が必要です", - "xpack.watcher.models.monitoringWatch.getVisualizeQueryCalledBadRequestMessage": "ウォッチの監視に {getVisualizeQuery} が必要です", - "xpack.watcher.models.monitoringWatch.upstreamJsonCalledBadRequestMessage": "ウォッチの監視に {upstreamJson} が必要です", - "xpack.watcher.models.pagerDutyAction.simulateFailMessage": "Hipchat イベントの送信に失敗しました.。", - "xpack.watcher.models.pagerDutyAction.simulateMessage": "PagerDuty イベントが送信されました。", - "xpack.watcher.models.slackAction.actionJsonSlackMessagePropertyMissingBadRequestMessage": "json 引数には {actionJsonSlackMessage} プロパティが含まれている必要があります", - "xpack.watcher.models.slackAction.actionJsonSlackPropertyMissingBadRequestMessage": "json 引数には {actionJsonSlack} プロパティが含まれている必要があります", - "xpack.watcher.models.slackAction.selectMessageText": "Slack ユーザーまたはチャンネルにメッセージを送信します。", - "xpack.watcher.models.slackAction.simulateButtonLabel": "今すぐサンプルメッセージを送信", - "xpack.watcher.models.slackAction.simulateFailMessage": "{toList} へのサンプル Slack メッセージの送信に失敗しました。", - "xpack.watcher.models.slackAction.simulateMessage": "{toList} にサンプル Slack メッセージが送信されました。", - "xpack.watcher.models.slackAction.TypeName": "Slack", - "xpack.watcher.models.thresholdWatch.selectMessageText": "特定の条件でアラートを送信します", - "xpack.watcher.models.thresholdWatch.sendAlertOnSpecificConditionTitleDescription": "特定の条件が満たされた時にアラートを送信します。", - "xpack.watcher.models.thresholdWatch.thresholdWatchIntervalTitleDescription": "これは {triggerIntervalSize} {timeUnitLabel} ごとに実行されます。", - "xpack.watcher.models.thresholdWatch.typeName": "しきい値アラート", - "xpack.watcher.models.unknownAction.actionJsonPropertyMissingBadRequestMessage": "json 引数には {actionJson} プロパティが含まれている必要があります", - "xpack.watcher.models.watch.typePropertyMissingBadRequestMessage": "json 引数には {type} プロパティが含まれている必要があります", - "xpack.watcher.models.watch.unknownWatchTypeLoadingAttemptBadRequestMessage": "不明なタイプ {jsonType} を読み込もうとしました", - "xpack.watcher.models.watch.watchJsonPropertyMissingBadRequestMessage": "json 引数には {watchJson} プロパティが含まれている必要があります", - "xpack.watcher.models.watchHistoryItem.idPropertyMissingBadRequestMessage": "json 引数には {id} プロパティが含まれている必要があります", - "xpack.watcher.models.watchHistoryItem.watchHistoryItemJsonPropertyMissingBadRequestMessage": "json 引数には {watchHistoryItemJson} プロパティが含まれている必要があります", - "xpack.watcher.models.watchHistoryItem.watchIdPropertyMissingBadRequestMessage": "json 引数には {watchId} プロパティが含まれている必要があります", - "xpack.watcher.models.watchStatus.idPropertyMissingBadRequestMessage": "json 引数には {id} プロパティが含まれている必要があります", - "xpack.watcher.models.watchStatus.watchStatusJsonPropertyMissingBadRequestMessage": "json 引数には {watchStatusJson} プロパティが含まれている必要があります", - "xpack.watcher.models.webhookAction.simulateFailMessage": "{fullPath} へのリクエストの送信に失敗しました。", - "xpack.watcher.models.webhookAction.simulateMessage": "{fullPath} にサンプルリクエストが送信されました", - "xpack.watcher.sections.watchEdit.json.editTabLabel": "編集", - "xpack.watcher.sections.watchEdit.json.saveSuccessNotificationText": "「{watchDisplayName}」が保存されました", - "xpack.watcher.sections.watchEdit.json.simulateTabLabel": "シミュレート", - "xpack.watcher.sections.watchEdit.threshold.saveButtonLabel": "保存", - "xpack.watcher.sections.watchEdit.titlePanel.howToBroadenSearchQueryDescription": "* で検索クエリの範囲を広げます", - "xpack.watcher.sections.watchEdit.titlePanel.indicesToQueryLabel": "クエリを実行するインデックス", - "xpack.watcher.sections.watchEdit.titlePanel.timeFieldLabel": "時間フィールド", - "xpack.watcher.sections.watchEdit.titlePanel.timeFieldOptionLabel": "フィールドを選択", - "xpack.watcher.sections.watchEdit.titlePanel.watchIntervalLabel": "次の間隔でウォッチを実行:", - "xpack.watcher.sections.watchEdit.titlePanel.watchNameLabel": "名前", - "xpack.watcher.sections.watchList.createAdvancedWatchButtonLabel": "高度なウォッチを作成", - "xpack.watcher.sections.watchList.createAdvancedWatchTooltip": "生 JSON のカスタムウォッチをセットアップします", - "xpack.watcher.sections.watchList.createThresholdAlertButtonLabel": "しきい値アラートを作成", - "xpack.watcher.sections.watchList.createThresholdAlertButtonTooltip": "特定の条件でアラートを送信します", - "xpack.watcher.sections.watchList.header": "しきい値アラートを作成", - "xpack.watcher.sections.watchList.managementSection.editDisplayName": "編集", - "xpack.watcher.sections.watchList.managementSection.newWatchDisplayName": "新規ウォッチ", - "xpack.watcher.sections.watchList.managementSection.statusDisplayName": "ステータス", - "xpack.watcher.sections.watchList.managementSection.watcherDisplayName": "Watcher", - "xpack.watcher.sections.watchList.managementSection.watchesDisplayName": "ウォッチ", - "xpack.watcher.sections.watchList.subhead": "特定のパラメーターに到達した際にメール、Slack メッセージ、ログイベントを送信します。", - "xpack.watcher.thresholdPreviewChart.dataDoesNotExistTextMessage": "インデックスと条件がデータを返しませんでした", - "xpack.watcher.thresholdWatchExpression.comparators.isAboveLabel": "より大きい:", - "xpack.watcher.thresholdWatchExpression.comparators.isBelowLabel": "より小さい:", - "xpack.watcher.thresholdWatchExpression.fixErrorInExpressionBelowValidationMessage": "下の表現のエラーを修正してください。", - "xpack.watcher.thresholdWatchExpression.groupBy.requiredFieldValidationMessage": "フィールドを選択してください。", - "xpack.watcher.thresholdWatchExpression.groupByLabel.allDocumentsLabel": "すべてのドキュメント", - "xpack.watcher.thresholdWatchExpression.groupByLabel.topLabel": "トップ", - "xpack.watcher.thresholdWatchExpression.thresholdLevel.valueIsRequiredValidationMessage": "値が必要です。", - "xpack.watcher.thresholdWatchExpression.timeWindow.durationSizeIsRequiredValidationMessage": "ウィンドウ期間サイズが必要です。", - "xpack.watcher.watchActions.logging.logTextIsRequiredValidationMessage": "ログテキストが必要です。", - "xpack.watcher.watcherDescription": "アラートの作成、管理、監視によりデータへの変更を検知します。", - "xpack.watcher.requestFlyout.closeButtonLabel": "閉じる", - "xpack.watcher.requestFlyout.descriptionText": "この Elasticsearch リクエストは、このウォッチを作成または更新します。", - "xpack.watcher.requestFlyout.namedTitle": "「{id}」のリクエスト", - "xpack.watcher.requestFlyout.unnamedTitle": "リクエスト", - "xpack.watcher.sections.watchEdit.json.hideRequestButtonLabel": "リクエストを非表示", - "xpack.watcher.sections.watchEdit.json.showRequestButtonLabel": "リクエストを表示", - "esUi.cronEditor.cronDaily.fieldHour.textAtLabel": "に", - "esUi.cronEditor.cronDaily.fieldTimeLabel": "時間", - "esUi.cronEditor.cronHourly.fieldMinute.textAtLabel": "に", - "esUi.cronEditor.cronHourly.fieldTimeLabel": "分", - "esUi.cronEditor.cronMonthly.fieldDateLabel": "日付", - "esUi.cronEditor.cronMonthly.fieldHour.textAtLabel": "に", - "esUi.cronEditor.cronMonthly.fieldTimeLabel": "時間", - "esUi.cronEditor.cronMonthly.textOnTheLabel": "に", - "esUi.cronEditor.cronWeekly.fieldDateLabel": "日", - "esUi.cronEditor.cronWeekly.fieldHour.textAtLabel": "に", - "esUi.cronEditor.cronWeekly.fieldTimeLabel": "時間", - "esUi.cronEditor.cronWeekly.textOnLabel": "オン", - "esUi.cronEditor.cronYearly.fieldDate.textOnTheLabel": "に", - "esUi.cronEditor.cronYearly.fieldDateLabel": "日付", - "esUi.cronEditor.cronYearly.fieldHour.textAtLabel": "に", - "esUi.cronEditor.cronYearly.fieldMonth.textInLabel": "に", - "esUi.cronEditor.cronYearly.fieldMonthLabel": "月", - "esUi.cronEditor.cronYearly.fieldTimeLabel": "時間", - "esUi.cronEditor.day.friday": "金曜日", - "esUi.cronEditor.day.monday": "月曜日", - "esUi.cronEditor.day.saturday": "土曜日", - "esUi.cronEditor.day.sunday": "日曜日", - "esUi.cronEditor.day.thursday": "木曜日", - "esUi.cronEditor.day.tuesday": "火曜日", - "esUi.cronEditor.day.wednesday": "水曜日", - "esUi.cronEditor.fieldFrequencyLabel": "頻度", - "esUi.cronEditor.month.april": "4 月", - "esUi.cronEditor.month.august": "8 月", - "esUi.cronEditor.month.december": "12 月", - "esUi.cronEditor.month.february": "2 月", - "esUi.cronEditor.month.january": "1 月", - "esUi.cronEditor.month.july": "7 月", - "esUi.cronEditor.month.june": "6 月", - "esUi.cronEditor.month.march": "3 月", - "esUi.cronEditor.month.may": "5 月", - "esUi.cronEditor.month.november": "11 月", - "esUi.cronEditor.month.october": "10 月", - "esUi.cronEditor.month.september": "9 月", - "esUi.cronEditor.textEveryLabel": "毎", - "esUi.cronEditor.cronDaily.hourSelectLabel": "時間", - "esUi.cronEditor.cronDaily.minuteSelectLabel": "分", - "esUi.cronEditor.cronMonthly.hourSelectLabel": "時間", - "esUi.cronEditor.cronMonthly.minuteSelectLabel": "分", - "esUi.cronEditor.cronWeekly.hourSelectLabel": "時間", - "esUi.cronEditor.cronWeekly.minuteSelectLabel": "分", - "esUi.cronEditor.cronYearly.hourSelectLabel": "時間", - "esUi.cronEditor.cronYearly.minuteSelectLabel": "分", - "esUi.forms.comboBoxField.placeHolderText": "入力してエンターキーを押してください", - "esUi.forms.fieldValidation.indexNameInvalidCharactersError": "インデックス名に無効な{characterListLength, plural, one {文字} other {文字}} { characterList } が含まれています。", - "esUi.forms.fieldValidation.indexNameSpacesError": "インデックス名にはスペースを使用できません。", - "esUi.forms.fieldValidation.indexNameStartsWithDotError": "インデックス名の始めにピリオド (.) は使用できません。", - "esUi.forms.fieldValidation.indexPatternInvalidCharactersError": "インデックスパターンに無効な{characterListLength, plural, one {文字} other {文字}} { characterList } が含まれています。", - "esUi.forms.fieldValidation.indexPatternSpacesError": "インデックスパターンにはスペースを使用できません。", - "visTypeMarkdown.tabs.dataText": "データ", - "visTypeMarkdown.tabs.optionsText": "オプション", - "visTypeMarkdown.params.fontSizeLabel": "ポイント単位のベースフォントサイズです。", - "xpack.actions.actionTypeRegistry.get.missingActionTypeErrorMessage": "アクションタイプ \"{id}\" は登録されていません。", - "xpack.actions.actionTypeRegistry.register.duplicateActionTypeErrorMessage": "アクションタイプ \"{id}\" は既に登録されています。", - "xpack.actions.builtin.slack.unexpectedNullResponseErrorMessage": "Slack から予期せぬ null 応答", - "xpack.actions.builtin.webhook.webhookConfigurationError": "Web フックアクションの構成中にエラーが発生: {message}", - "xpack.actions.urlWhitelistConfigurationError": "ターゲット {field} 「{value}」は Kibana のホワイトリストに登録されていません", - "xpack.advancedUiActions.customizePanelTimeRange.modal.addToPanelButtonTitle": "パネルに追加", - "xpack.advancedUiActions.customizePanelTimeRange.modal.cancelButtonTitle": "キャンセル", - "xpack.advancedUiActions.customizePanelTimeRange.modal.optionsMenuForm.panelTitleFormRowLabel": "時間範囲", - "xpack.advancedUiActions.customizePanelTimeRange.modal.removeButtonTitle": "削除", - "xpack.advancedUiActions.customizePanelTimeRange.modal.updatePanelTimeRangeButtonTitle": "更新", - "xpack.advancedUiActions.customizeTimeRange.modal.headerTitle": "パネルの時間範囲のカスタマイズ", - "xpack.advancedUiActions.customizeTimeRangeMenuItem.displayName": "時間範囲のカスタマイズ", - "xpack.fileUpload.fileParser.errorReadingFile": "ファイルの読み込み中にエラーが発生しました", - "xpack.fileUpload.fileParser.noFileProvided": "エラー、ファイルが提供されていません", - "xpack.fileUpload.fileParser.noFeaturesDetected": "エラー、機能が検出されませんでした", - "xpack.fileUpload.jsonIndexFilePicker.fileParseError": "ファイル解析エラーが検出されました: {error}", - "xpack.fileUpload.jsonIndexFilePicker.fileProcessingError": "ファイル処理エラー: {errorMessage}", - "xpack.fileUpload.jsonIndexFilePicker.fileSizeError": "ファイルサイズエラー: {errorMessage}", - "xpack.fileUpload.jsonUploadAndParse.indexingComplete": "インデックス完了", - "xpack.fileUpload.patternReader.featuresOmitted": "ジオメトリのない一部の機能は省略されました", - "xpack.fileUpload.jsonIndexFilePicker.acceptableFileSize": "ファイルサイズ {fileSize} は最大ファイルサイズの{maxFileSize} を超えています", - "xpack.fileUpload.jsonIndexFilePicker.parsingFile": "{featuresProcessed} 件の機能が解析されました…", + "timelion.badge.readOnly.text": "読み込み専用", + "timelion.badge.readOnly.tooltip": "Timelion シートを保存できません", + "timelion.breadcrumbs.create": "作成", + "timelion.breadcrumbs.root": "Timelion", + "timelion.cells.actions.fullscreenAriaLabel": "全画面チャート", + "timelion.cells.actions.fullscreenTooltip": "全画面", + "timelion.cells.actions.removeAriaLabel": "リモートスタート", + "timelion.cells.actions.removeTooltip": "削除", + "timelion.cells.actions.reorderAriaLabel": "ドラッグして並べ替え", + "timelion.cells.actions.reorderTooltip": "ドラッグして並べ替え", + "timelion.chart.seriesList.noSchemaWarning": "次のパネルタイプは存在しません: {renderType}", + "timelion.emptyExpressionErrorMessage": "Timelion エラー式が入力されていません", + "timelion.expressionInputAriaLabel": "Timelion 式", + "timelion.expressionInputPlaceholder": "{esQuery} でのクエリを試してみてください。", + "timelion.expressionSuggestions.arg.infoTitle": "情報", + "timelion.expressionSuggestions.arg.listTitle": "引数:", + "timelion.expressionSuggestions.arg.nameTitle": "引数名", + "timelion.expressionSuggestions.arg.typesTitle": "対応タイプ", + "timelion.expressionSuggestions.func.description.chainableText": "{help} (連鎖可能)", + "timelion.expressionSuggestions.func.description.dataSourceText": "{help} (データソース)", + "timelion.fitFunctions.carry.downSampleErrorMessage": "ダウンサンプルには「carry」フィットメソドを使用せず、「scale」または「average」を使用してください", + "timelion.fullscreen.exitAriaLabel": "全画面を終了", + "timelion.fullscreen.exitTooltip": "全画面を終了", + "timelion.function.help": "Timelion のビジュアライゼーションです。", + "timelion.help.configuration.firstTimeConfigurationLinkText": "初回構成", + "timelion.help.configuration.notValid.advancedSettingsPathText": "管理 / Kibana / 高度な設定", + "timelion.help.configuration.notValid.notValidSettingsErrorMessage": "Elasticsearch の設定を確認できませんでした: {reason}。高度な設定を確認して再試行してください。({count})", + "timelion.help.configuration.notValid.paragraph1": "Logstash を使用している場合、Timelion でのログデータの探索開始に何も構成する必要はありません。他のインデックスを検索するには、{advancedSettingsPath} に移動してインデックスと一致するよう {esDefaultIndex} と {esTimefield} を設定します。", + "timelion.help.configuration.notValid.paragraph2": "他の Timelion 設定もあります。今のところ他の設定は気にしなくて大丈夫です。後程、必要に応じていつでも設定できることがわかります。", + "timelion.help.configuration.notValid.validateButtonLabel": "構成を検証", + "timelion.help.configuration.notValidTitle": "初回構成", + "timelion.help.configuration.valid.advancedSettingsPathText": "管理/Kibana/高度な設定", + "timelion.help.configuration.valid.intervalIsAutoText": "準備完了です!", + "timelion.help.configuration.valid.intervals.content.intervalIsNotAutoText": "Timelion が適切な間隔を選択できるよう、{auto} に設定します。", + "timelion.help.configuration.valid.intervalsTextPart1": "インプットバーの右にある間隔設定は、サンプリングの頻度をコントロールできます。現在 {interval} に設定されています。", + "timelion.help.configuration.valid.intervalsTextPart2": "Timelion が選択された時間範囲と間隔の組み合わせによりデータポイントが多くなりすぎると判断した場合、エラーが発生します。{advancedSettingsPath} の {maxBuckets} を構成することでこの制限を調整できます。", + "timelion.help.configuration.valid.intervalsTitle": "間隔", + "timelion.help.configuration.valid.paragraph1Part1": "デフォルトのインデックスと時間フィールドを検証し、すべて問題なさそうです。{statsMin} から {statsMax} までのデータが見つかりました。恐らく準備完了です。何か問題がある場合は、", + "timelion.help.configuration.valid.paragraph1Part2": "で Elasticsearch データソースの構成に関する詳細をご覧ください。", + "timelion.help.configuration.valid.paragraph2": "既にチャートが 1 つ表示されていますが、興味深いデータを得るにはいくつか調整が必要な可能性があります。", + "timelion.help.configuration.valid.paragraph3": "これで、一定期間のデータポイントの数を示す折れ線グラフが表示されるはずです。", + "timelion.help.configuration.valid.timeRangeText": "Kibana ツールバーのタイムピッカーで可視化するデータを含む期間を選択します。上記のすべてまたは一部の時間範囲を含む時間範囲を選択するようにしてください。", + "timelion.help.configuration.valid.timeRangeTitle": "時間範囲", + "timelion.help.configuration.validTitle": "良いお知らせです。Elasticsearch が正しく構成されました!", + "timelion.help.dataTransforming.functionReferenceLinkText": "機能リファレンス", + "timelion.help.dataTransforming.paragraph1": "基本を覚えたところで、Timelion の実力を発揮させましょう。エータのサブセットが、一定期間における全体の何パーセントを表しているか見てみましょう。例えば、Web トラフィックの何パーセントが米国からのものでしょう?", + "timelion.help.dataTransforming.paragraph2": "まず初めに、米国を含むすべてのイベントを見つけます: {esUsQuery}。", + "timelion.help.dataTransforming.paragraph3": "次に、全体に対する米国のイベントの比率を割り出します。{us} を全体で割るには、{divide} 関数を使用します: {divideDataQuery}。", + "timelion.help.dataTransforming.paragraph4": "まぁまぁですが、これでは 0 から 1 までの値になってしまいます。パーセンテージに変換するには、100 を掛けます: {multiplyDataQuery}。", + "timelion.help.dataTransforming.paragraph5": "これでトラフィックの何パーセントが米国からのものなのか分かり、一定期間内にどのように変化したのか見ることができます!Timelion には、{sum}、{subtract}、{multiply}、{divide} などのいくつもの演算機能が搭載されています。これらの多くが数列や数字を扱えます。また、{movingaverage}、{abs}、{derivative} といった他の便利な変換機能もあります。", + "timelion.help.dataTransforming.paragraph6Part1": "構文を学んだところで、", + "timelion.help.dataTransforming.paragraph6Part2": "で、Timelion で利用できるすべての機能の使い方をご覧ください。Kibana ツールバーの \\{ドキュメント\\} をクリックしていつでもリファレンスを参照することができます。このチュートリアルに戻るには、リファレンスの上にある \\{チュートリアル\\} リンクをクリックします。", + "timelion.help.dataTransformingTitle": "データの変換: お楽しみの始まりです!", + "timelion.help.dontShowHelpButtonLabel": "今後表示しない", + "timelion.help.expressions.examples.customStylingDescription": "{descriptionTitle}初めの数列を赤くし、2 つ目の数列に 1 ピクセル幅のバーを使用します。", + "timelion.help.expressions.examples.customStylingDescriptionTitle": "カスタムスタイリング。", + "timelion.help.expressions.examples.groupedExpressionsDescription": "{descriptionTitle}式のグループを関数に連結させることもできます。ここでは両方の数列が線ではなく点で表示されています。", + "timelion.help.expressions.examples.groupedExpressionsDescriptionTitle": "式のグループ化。", + "timelion.help.expressions.examples.namedArgumentsDescription": "{descriptionTitle}引数の指定順序を覚える必要はありません。名前付き引数を使えば、式の読み書きが楽になります。", + "timelion.help.expressions.examples.namedArgumentsDescriptionTitle": "名前付き引数。", + "timelion.help.expressions.examples.twoExpressionsDescription": "{descriptionTitle}同じチャートに 2 つの式が使えます。", + "timelion.help.expressions.examples.twoExpressionsDescriptionTitle": "2 倍の楽しみ。", + "timelion.help.expressions.functionReferenceLinkText": "関数リファレンス", + "timelion.help.expressions.paragraph1": "それぞれの式はデータソース関数で始まります。ここから、新しい関数をデータソースに追加して変換や強化ができます。", + "timelion.help.expressions.paragraph2": "ところで、ここから先はデータの持ち主が一番よくご存知なのではないでしょうか。サンプルクエリをより有意義なものと自由に置き換えてみてください。", + "timelion.help.expressions.paragraph3": "Kibana ツールバーの {strongAdd} をクリックして、他のチャートをいくつか追加してみみましょう。そして、チャートを選択して次の式の内の 1 つをコピーし、インプットバーに貼り付けて、Enter を押します。リセットして繰り返し、他の式を試してみましょう。", + "timelion.help.expressions.paragraph4": "Timelion は、チャートの見た目をカスタマイズするための他のビュー変換機能も搭載しています。完全なリストは次のリソースをご覧ください", + "timelion.help.expressions.strongAddText": "追加", + "timelion.help.expressionsTitle": "式を使って式を定義", + "timelion.help.functions.absHelpText": "数列リストの各値の絶対値を返します", + "timelion.help.functions.aggregate.args.functionHelpText": "{functions} の 1 つ", + "timelion.help.functions.aggregateHelpText": "数列のすべての点の処理結果に基づく線を作成します。利用可能な関数: {functions}", + "timelion.help.functions.bars.args.stackHelpText": "バーがスタックした場合はデフォルトで true にする", + "timelion.help.functions.bars.args.widthHelpText": "バーの幅 (ピクセル)", + "timelion.help.functions.barsHelpText": "seriesList をバーとして表示", + "timelion.help.functions.color.args.colorHelpText": "ヘックスとしての数列の色です。例: #c6c6c6 はかわいいライトグレー。複数の色を指定し、複数数列がある場合、グラデーションになります。例: 「#00B1CC:#00FF94:#FF3A39:#CC1A6F」", + "timelion.help.functions.colorHelpText": "数列の色を変更します", + "timelion.help.functions.common.args.fitHelpText": "ターゲットの期間と間隔に数列を合わせるためのアルゴリズムです。利用可能: {fitFunctions}", + "timelion.help.functions.common.args.offsetHelpText": "日付表現による数列の取得をオフセットします。例: 1 か月前からイベントを作成する -1M tは現在のように表示されます。「 timerange」によって、チャートの全体的な時間範囲に関連した数列をオフセットします。例: 「timerange:-2」は過去に対する全体的なチャート時間範囲の 2 倍をオフセットします。", + "timelion.help.functions.condition.args.elseHelpText": "比較が false の場合に点が設定される値です。ここで seriesList を引き渡した場合、初めの数列が使用されます。", + "timelion.help.functions.condition.args.ifHelpText": "点が比較される値です。ここで seriesList を引き渡した場合、初めの数列が使用されます。", + "timelion.help.functions.condition.args.operator.suggestions.eqHelpText": "equal", + "timelion.help.functions.condition.args.operator.suggestions.gteHelpText": "超過", + "timelion.help.functions.condition.args.operator.suggestions.gtHelpText": "以上", + "timelion.help.functions.condition.args.operator.suggestions.lteHelpText": "未満", + "timelion.help.functions.condition.args.operator.suggestions.ltHelpText": "以下", + "timelion.help.functions.condition.args.operator.suggestions.neHelpText": "not equal", + "timelion.help.functions.condition.args.operatorHelpText": "比較に使用する比較演算子、有効な演算子は eq (=)、ne (≠), lt (<), lte (≦), gt (>), gte (≧)", + "timelion.help.functions.condition.args.thenHelpText": "比較が true の場合に点が設定される値です。ここで seriesList を引き渡した場合、初めの数列が使用されます。", + "timelion.help.functions.conditionHelpText": "演算子を使って各点を数字、または別の数列の同じ点と比較し、true の場合値を結果の値に設定し、オプションとして else が使用されます。", + "timelion.help.functions.cusum.args.baseHelpText": "開始の数字です。基本的に、数列の初めにこの数字が追加されます", + "timelion.help.functions.cusumHelpText": "ベースから始め、数列の累積和を返します。", + "timelion.help.functions.derivativeHelpText": "一定期間の値の変化をプロットします。", + "timelion.help.functions.divide.args.divisorHelpText": "割る数字または数列です。複数数列を含む seriesList はラベルに適用されます。", + "timelion.help.functions.divideHelpText": "seriesList の 1 つまたは複数の数列の値をインプット seriesList の各数列のそれぞれの配置に割けます。", + "timelion.help.functions.es.args.indexHelpText": "クエリを実行するインデックスで、ワイルドカードが使えます。「metrics」、「split」、「timefield」引数のスクリプトフィールドのフィールド名のインデックスパターン名とフィールド名の入力候補を提供します。", + "timelion.help.functions.es.args.intervalHelpText": "**これは使用しないでください**。fit 関数のデバッグは楽しいですが、間隔ピッカーを使用すべきです。", + "timelion.help.functions.es.args.kibanaHelpText": "Kibana ダッシュボードでフィルターを適用します。Kibana ダッシュボードの使用時にのみ適用されます。", + "timelion.help.functions.es.args.metricHelpText": "Elasticsearch メトリック集約: avg、sum、min、max、percentiles、または基数、後ろにフィールドを付けます。例: 「sum:bytes」、「percentiles:bytes:95,99,99.9」、「count」", + "timelion.help.functions.es.args.qHelpText": "Lucene クエリ文字列の構文のクエリ", + "timelion.help.functions.es.args.splitHelpText": "分割する Elasticsearch フィールドと制限です。例: トップ 10 のホスト名を割り出す「{hostnameSplitArg}」", + "timelion.help.functions.es.args.timefieldHelpText": "X 軸にフィールドタイプ「date」を使用", + "timelion.help.functions.esHelpText": "Elasticsearch インスタンスからデータを取得します", + "timelion.help.functions.firstHelpText": "これは単純に input seriesList を返す内部機能です。この機能は使わないでください", + "timelion.help.functions.fit.args.modeHelpText": "数列をターゲットに合わせるためのアルゴリズムです。{fitFunctions} の 1 つ", + "timelion.help.functions.fitHelpText": "定義された fit 関数を使用して空値を入力します", + "timelion.help.functions.graphite.args.metricHelpText": "取得する Graphite メトリック、例: {metricExample}", + "timelion.help.functions.graphiteHelpText": "[実験的] Graphite からデータを取得します。Kibana の高度な設定で Graphite サーバーを構成します", + "timelion.help.functions.hide.args.hideHelpText": "数列の表示と非表示を切り替えます", + "timelion.help.functions.hideHelpText": "デフォルトで数列を非表示にします", + "timelion.help.functions.holt.args.alphaHelpText": "\n 0 から 1 の平滑化加重です。\n アルファを上げると新しい数列がオリジナルにさらに近くなります。\n 下げると数列がスムーズになります", + "timelion.help.functions.holt.args.betaHelpText": "\n 0 から 1 の傾向加重です。\n ベータを上げると線の上下の動きが長くなります。\n 下げると新しい傾向をより早く反映するようになります", + "timelion.help.functions.holt.args.gammaHelpText": "0 から 1 のシーズン加重です。データが波のようになっていますか?\n この数字を上げると、最近のシーズンの重要性が高まり、波形の動きを速くします。\n 下げると新しいシーズンの重要性が下がり、過去がより重要視されます。", + "timelion.help.functions.holt.args.sampleHelpText": "\n シーズン数列の「予測」を開始する前にサンプリングするシーズンの数です。\n (gamma でのみ有効、デフォルト: all)", + "timelion.help.functions.holt.args.seasonHelpText": "シーズンの長さです、例: パターンが毎週繰り返される場合は 1w。(gamma でのみ有効)", + "timelion.help.functions.holtHelpText": "\n 数列の始めをサンプリングし、\n いくつかのオプションパラメーターを使用して何が起こるか予測します。基本的に、この機能は未来を予測するのではなく、\n 過去のデータに基づき現在何が起きているべきかを予測します。\n この情報は異常検知に役立ちます。null には予測値が入力されます。", + "timelion.help.functions.label.args.labelHelpText": "数列の凡例値です。文字列で $1、$2 などを使用して、正規表現の捕捉グループに合わせることができます。", + "timelion.help.functions.label.args.regexHelpText": "捕捉グループをサポートする正規表現です", + "timelion.help.functions.labelHelpText": "数列のラベルを変更します。%s で既存のラベルを参照します", + "timelion.help.functions.legend.args.columnsHelpText": "凡例を分ける列の数です", + "timelion.help.functions.legend.args.position.suggestions.falseHelpText": "凡例を無効にします", + "timelion.help.functions.legend.args.position.suggestions.neHelpText": "北東の角に凡例を配置します", + "timelion.help.functions.legend.args.position.suggestions.nwHelpText": "北西の角に凡例を配置します", + "timelion.help.functions.legend.args.position.suggestions.seHelpText": "南東の角に凡例を配置します", + "timelion.help.functions.legend.args.position.suggestions.swHelpText": "南西の角に凡例を配置します", + "timelion.help.functions.legend.args.positionHelpText": "凡例を配置する角: nw、ne、se、または sw。false で凡例を無効にすることもできます", + "timelion.help.functions.legend.args.showTimeHelpText": "グラフにカーソルを合わせた時、凡例の時間値を表示します。デフォルト: true", + "timelion.help.functions.legend.args.timeFormatHelpText": "moment.js フォーマットパターンです。デフォルト: {defaultTimeFormat}", + "timelion.help.functions.legendHelpText": "プロットの凡例の位置とスタイルを設定します", + "timelion.help.functions.lines.args.fillHelpText": "0 と 10 の間の数字です。エリアチャートの作成に使用します。", + "timelion.help.functions.lines.args.showHelpText": "線の表示と非表示を切り替えます", + "timelion.help.functions.lines.args.stackHelpText": "線をスタックします。よく誤解を招きます。この機能を使用する際は塗りつぶしを使うようにしましょう。", + "timelion.help.functions.lines.args.stepsHelpText": "線をステップとして表示します。つまり、点の間に中間値を挿入しません。", + "timelion.help.functions.lines.args.widthHelpText": "線の太さです", + "timelion.help.functions.linesHelpText": "seriesList を線として表示します", + "timelion.help.functions.log.args.baseHelpText": "対数のベースを設定します、デフォルトは 10 です", + "timelion.help.functions.logHelpText": "数列リストの各値の対数値を返します (デフォルトのベース:10)", + "timelion.help.functions.max.args.valueHelpText": "点を既存の値と引き渡された値のどちらか高い方に設定します。seriesList を引き渡す場合、数列がちょうど 1 つでなければなりません。", + "timelion.help.functions.maxHelpText": "インプット seriesList の各数列のそれぞれの配置の seriesList の 1 つまたは複数の数列の最高値です", + "timelion.help.functions.min.args.valueHelpText": "点を既存の値と引き渡された値のどちらか低い方に設定します。seriesList を引き渡す場合、数列がちょうど 1 つでなければなりません。", + "timelion.help.functions.minHelpText": "インプット seriesList の各数列のそれぞれの配置の seriesList の 1 つまたは複数の数列の最低値です", + "timelion.help.functions.movingaverage.args.positionHelpText": "結果時間に比較した平均点の配置です。{validPositions} の 1 つ", + "timelion.help.functions.movingaverage.args.windowHelpText": "平均を出す点の数、または日付計算式 (例: 1d、1M) です。日付計算式が指定された場合、この機能は現在選択された間隔でできるだけ近づけます。日付計算式が間隔で均等に分けられない場合、結果に異常が出る場合があります。", + "timelion.help.functions.movingaverageHelpText": "特定期間の移動平均を計算します。ばらばらの数列を滑らかにするのに有効です。", + "timelion.help.functions.movingstd.args.positionHelpText": "結果時間に比較した期間スライスの配置です。オプションは {positions} です。デフォルト: {defaultPosition}", + "timelion.help.functions.movingstd.args.windowHelpText": "標準偏差を計算する点の数です。", + "timelion.help.functions.movingstdHelpText": "特定期間の移動標準偏差を計算します。ネイティブ two-pass アルゴリズムを使用します。非常に長い数列や、非常に大きな数字を含む数列では、四捨五入による誤差がより明らかになる可能性があります。", + "timelion.help.functions.multiply.args.multiplierHelpText": "掛ける数字または数列です。複数数列を含む seriesList はラベルに適用されます。", + "timelion.help.functions.multiplyHelpText": "seriesList の 1 つまたは複数の数列の値をインプット seriesList の各数列のそれぞれの配置に掛けます。", + "timelion.help.functions.notAllowedGraphiteUrl": "この Graphite URL は kibana.yml ファイルで構成されていません。\n 「'timelion.graphiteUrls」で kibana.yml ファイルの Graphite サーバーリストを構成して\n Kibana の高度な設定で選択してください", + "timelion.help.functions.points.args.fillColorHelpText": "点を塗りつぶす色です。", + "timelion.help.functions.points.args.fillHelpText": "塗りつぶしの透明度を表す 0 から 10 までの数字です", + "timelion.help.functions.points.args.radiusHelpText": "点のサイズです", + "timelion.help.functions.points.args.showHelpText": "点の表示・非表示です", + "timelion.help.functions.points.args.symbolHelpText": "点のシンボルです。{validSymbols} の 1 つ", + "timelion.help.functions.points.args.weightHelpText": "点の周りの太さです", + "timelion.help.functions.pointsHelpText": "数列を点として表示します", + "timelion.help.functions.precision.args.precisionHelpText": "各値を四捨五入する桁数です", + "timelion.help.functions.precisionHelpText": "値の小数点以下の四捨五入する桁数です", + "timelion.help.functions.props.args.globalHelpText": "各数列に対し、seriesList にプロップを設定します", + "timelion.help.functions.propsHelpText": "数列に任意のプロパティを設定するため、自己責任で行ってください。例: {example}", + "timelion.help.functions.quandl.args.codeHelpText": "プロットする Quandl コードです。これらは quandl.com に掲載されています。", + "timelion.help.functions.quandl.args.positionHelpText": "Quandl ソースによっては、複数数列を返すものがあります。どれを使用しますか?1 ベースインデックス", + "timelion.help.functions.quandlHelpText": "\n [実験的]\n Quandl コードで quandl.com からデータを取得します。{quandlKeyField} を Kibana の空いている API キーに設定します。\n 高度な設定です。API は、キーなしでは非常に低いレート制限があります。", + "timelion.help.functions.range.args.maxHelpText": "新しい最高値です", + "timelion.help.functions.range.args.minHelpText": "新しい最低値です", + "timelion.help.functions.rangeHelpText": "同じシェイプを維持しつつ数列の最高値と最低値を変更します", + "timelion.help.functions.scaleInterval.args.intervalHelpText": "新しい間隔の日付計算表記です。例: 1 秒 = 1s。1m、5m、1M、1w、1y など。", + "timelion.help.functions.scaleIntervalHelpText": "変更すると、値 (通常合計またはカウント) が新しい間隔にスケーリングされます。例: 毎秒のレート", + "timelion.help.functions.static.args.labelHelpText": "数列のラベルを簡単に設定する方法です。.label() 関数を使用することもできます。", + "timelion.help.functions.static.args.valueHelpText": "表示する単一の値です。複数の値が引き渡された場合、指定された時間範囲に均等に挿入されます。", + "timelion.help.functions.staticHelpText": "チャートに 1 つの値を挿入します", + "timelion.help.functions.subtract.args.termHelpText": "インプットから引く数字または数列です。複数数列を含む seriesList はラベルに適用されます。", + "timelion.help.functions.subtractHelpText": "seriesList の 1 つまたは複数の数列の値をインプット seriesList の各数列のそれぞれの配置から引きます。", + "timelion.help.functions.sum.args.termHelpText": "インプット数列に足す数字または数列です。複数数列を含む seriesList はラベルに適用されます。", + "timelion.help.functions.sumHelpText": "seriesList の 1 つまたは複数の数列の値をインプット seriesList の各数列のそれぞれの配置に足します。", + "timelion.help.functions.title.args.titleHelpText": "プロットのタイトルです。", + "timelion.help.functions.titleHelpText": "プロットの上部にタイトルを追加します。複数の seriesList がコールされた場合、最後のコールが使用されます。", + "timelion.help.functions.trend.args.endHelpText": "始めまたは終わりからの計算を修了する場所です。例えば、-10 の場合終わりから 10 点目で計算が終了し、+15 の場合始めから 15 点目で終了します。デフォルト:0", + "timelion.help.functions.trend.args.modeHelpText": "傾向線の生成に使用するアルゴリズムです。{validRegressions} の 1 つ", + "timelion.help.functions.trend.args.startHelpText": "始めまたは終わりからの計算を開始する場所です。例えば、-10 の場合終わりから 10 点目から計算を開始し、+15 の場合始めから 15 点目から開始します。デフォルト:0", + "timelion.help.functions.trendHelpText": "指定された回帰アルゴリズムで傾向線を描きます", + "timelion.help.functions.trim.args.endHelpText": "数列の終わりから切り取るバケットです。デフォルト:1", + "timelion.help.functions.trim.args.startHelpText": "数列の始めから切り取るバケットです。デフォルト:1", + "timelion.help.functions.trimHelpText": "「部分的バケットの問題」に合わせて、数列の始めか終わりの N 個のバケットを無効化するように設定します。", + "timelion.help.functions.worldbank.args.codeHelpText": "Worldbank API パスです。これは通常ドメインの後ろからクエリ文字列までのすべてです。例: {apiPathExample}。", + "timelion.help.functions.worldbankHelpText": "\n [experimental]\n 数列のパスを使用して {worldbankUrl} からデータを取得します。\n Worldbank は主に年間データを提供し、現在の年のデータがないことがよくあります。\n 最近の期間範囲のデータが取得できない場合は、{offsetQuery} をお試しください。", + "timelion.help.functions.worldbankIndicators.args.countryHelpText": "Worldbank の国 ID です。通常は国の 2 文字のコートです", + "timelion.help.functions.worldbankIndicators.args.indicatorHelpText": "使用するインジケーターコードです。{worldbankUrl} で調べる必要があります。多くが分かりずらいものです。例えば、人口は {indicatorExample} です。", + "timelion.help.functions.worldbankIndicatorsHelpText": "\n [experimental]\n 国名とインジケーターを使って {worldbankUrl} からデータを取得します。Worldbank は\n 主に年間データを提供し、現在の年のデータがないことがよくあります。最近の期間のデータが取得できない場合は、{offsetQuery} をお試しください\n 時間範囲", + "timelion.help.functions.yaxis.args.colorHelpText": "軸ラベルの色です", + "timelion.help.functions.yaxis.args.labelHelpText": "軸のラベルです", + "timelion.help.functions.yaxis.args.maxHelpText": "最高値", + "timelion.help.functions.yaxis.args.minHelpText": "最低値", + "timelion.help.functions.yaxis.args.positionHelpText": "左から右", + "timelion.help.functions.yaxis.args.tickDecimalsHelpText": "y 軸とティックラベルの小数点以下の桁数です。", + "timelion.help.functions.yaxis.args.unitsHelpText": "Y 軸のラベルのフォーマットに使用する機能です。{formatters} の 1 つ", + "timelion.help.functions.yaxis.args.yaxisHelpText": "この数列をプロットする数字の Y 軸です。例: 2 本目の Y 軸は .yaxis(2) になります。", + "timelion.help.functions.yaxisHelpText": "様々な Y 軸のオプションを構成します。恐らく最も重要なのは、N 本目 (例: 2 本目) の Y 軸を追加する機能です。", + "timelion.help.mainPage.functionReference.detailsTable.acceptedTypesColumnLabel": "対応タイプ", + "timelion.help.mainPage.functionReference.detailsTable.argumentNameColumnLabel": "引数名", + "timelion.help.mainPage.functionReference.detailsTable.informationColumnLabel": "情報", + "timelion.help.mainPage.functionReference.gettingStartedText": "関数をクリックすると詳細が表示されます。初心者の方ですか?", + "timelion.help.mainPage.functionReference.noArgumentsFunctionErrorMessage": "この関数には引数を使用できません。簡単でしょう?", + "timelion.help.mainPage.functionReference.welcomePageLinkText": "チュートリアルをご覧ください", + "timelion.help.mainPage.functionReferenceTitle": "関数リファレンス", + "timelion.help.mainPage.keyboardTips.autoComplete.downArrowDescription": "自動入力メニューに焦点を切り替えます。矢印でさらに用語を選択します", + "timelion.help.mainPage.keyboardTips.autoComplete.downArrowLabel": "下矢印", + "timelion.help.mainPage.keyboardTips.autoComplete.enterTabDescription": "現在の選択項目または自動入力メニューで最も使用されている用語を選択します", + "timelion.help.mainPage.keyboardTips.autoComplete.escDescription": "自動入力メニューを閉じます", + "timelion.help.mainPage.keyboardTips.autoCompleteTitle": "自動入力が有効な場合", + "timelion.help.mainPage.keyboardTips.generalEditing.submitRequestText": "リクエストを送信します", + "timelion.help.mainPage.keyboardTips.generalEditingTitle": "一般編集", + "timelion.help.mainPage.keyboardTipsTitle": "キーボードのヒント", + "timelion.help.mainPageTitle": "ヘルプ", + "timelion.help.nextPageButtonLabel": "次へ", + "timelion.help.previousPageButtonLabel": "前へ", + "timelion.help.querying.countMetricAggregationLinkText": "Elasticsearch メトリック集約", + "timelion.help.querying.countTextPart1": "イベントをカウントするのも良いですが、Elasticsearch のデータソースは単独の値を返す", + "timelion.help.querying.countTextPart2": "もサポートしています。最も便利なものには {min}、{max}、{avg}、{sum}、{cardinality} などがあります。{srcIp}フィールドのユニークカウントを求めたいとしましょう。{cardinality} メトリックを使うだけです: {esCardinalityQuery}{bytes}フィールドの平均を求めるには、{avg} メトリックが使えます: {esAvgQuery}", + "timelion.help.querying.countTitle": "カウントを超えて", + "timelion.help.querying.esAsteriskQueryDescriptionText": "Elasticsearch、デフォルトインデックスのすべてを計算", + "timelion.help.querying.esIndexQueryDescriptionText": "* を logstash-* インデックスの q (クエリ) として使用します", + "timelion.help.querying.luceneQueryLinkText": "Lucene クエリ文字列", + "timelion.help.querying.paragraph1": "Elasticsearch データソースが利用可能であることを確認済みなので、クエリの送信ができます。手始めに、インプットバーに {esPattern} と入力し Enter を押してみましょう。", + "timelion.help.querying.paragraph2Part1": "{esAsteriskQueryDescription} が返されます。サブセットを把握したい場合は、{htmlQuery} で {html} に一致するイベントをカウントしたり、{bobQuery} で {user} フィールドに {bob} を含み、{bytes} フィールドが 100 より大きな値のイベントを検索したりできます。このクエリはシングルクォートで囲まれています。スペースを含むためです。いずれかの", + "timelion.help.querying.paragraph2Part2": "を {esQuery} 関数の初めの引数として入力することができます。", + "timelion.help.querying.passingArgumentsText": "Timelion には一般的な操作を簡単に行えるよう、いくつものショートカットがあります。スペースや特殊文字を含まないシンプルな引数用のものがその一つで、クォートを使う必要はありません。また、多くの関数にデフォルトがあります。例えば、{esEmptyQuery} と {esStarQuery} の動作は同じです。引数には名前も付いているため、特定の順序で指定する必要はありません。例えば、{esLogstashQuery} と入力して Elasticsearch データソースに {esIndexQueryDescription} させることができます。", + "timelion.help.querying.passingArgumentsTitle": "引数の受け渡し", + "timelion.help.queryingTitle": "Elasticsearch データソースにクエリを実行中", + "timelion.help.unknownErrorMessage": "不明なエラー", + "timelion.help.welcome.content.emphasizedEverythingText": "すべて", + "timelion.help.welcome.content.functionReferenceLinkText": "関数リファレンスに移動", + "timelion.help.welcome.content.paragraph1": "Timelion は時系列に関する {emphasizedEverything} を司る、全知全能のツールです。データストアから提供された時系列データは、Timelion にお任せください。Timelion は複数データソースのデータセットを、覚えやすい式構文で比較、結合、整理できます。このチュートリアルは Elasticsearch が中心となりますが、ここで学んだことは Timelion がサポートするすべてのデータソースに適用できます。", + "timelion.help.welcome.content.paragraph2": "準備はいいですか?{strongNext} をクリックしてください。チュートリアルをスキップしてドキュメントを表示しますか?", + "timelion.help.welcome.content.strongNextText": "次へ", + "timelion.help.welcomeTitle": "{strongTimelionLabel} へようこそ!", + "timelion.intervals.customIntervalAriaLabel": "カスタム間隔", + "timelion.intervals.selectIntervalAriaLabel": "間隔を選択", + "timelion.noFunctionErrorMessage": "そのような関数はありません: {name}", + "timelion.panels.noRenderFunctionErrorMessage": "パネルにはレンダリング関数が必要です", + "timelion.panels.timechart.unknownIntervalErrorMessage": "不明な間隔", + "timelion.registerFeatureDescription": "時系列データを分析して結果を可視化するには、式言語を使用してください。", + "timelion.requestHandlerErrorTitle": "Timelion リクエストエラー", + "timelion.saveExpression.successNotificationText": "保存された式「{title}」", + "timelion.saveSheet.successNotificationText": "保存されたシート「{title}」", + "timelion.search.submitAriaLabel": "検索", + "timelion.searchErrorTitle": "Timelion リクエストエラー", + "timelion.serverSideErrors.argumentsOverflowErrorMessage": "{functionName} に引き渡された引数が多すぎます", + "timelion.serverSideErrors.bucketsOverflowErrorMessage": "バケットの最高数を超過: {maxBuckets} 個中 {bucketCount} 個が使用できます。より広い間隔または短い期間を選択してください", + "timelion.serverSideErrors.colorFunction.colorNotProvidedErrorMessage": "色が指定されていません", + "timelion.serverSideErrors.conditionFunction.unknownOperatorErrorMessage": "不明な演算子", + "timelion.serverSideErrors.conditionFunction.wrongArgTypeErrorMessage": "数字または seriesList でなければなりません", + "timelion.serverSideErrors.esFunction.indexNotFoundErrorMessage": "Elasticsearch インデックス {index} が見つかりません", + "timelion.serverSideErrors.holtFunction.missingParamsErrorMessage": "シーズンの長さとサンプルサイズ >= 2 を指定する必要があります", + "timelion.serverSideErrors.holtFunction.notEnoughPointsErrorMessage": "二重指数平滑化を使用するには最低 2 つの点が必要です", + "timelion.serverSideErrors.movingaverageFunction.notValidPositionErrorMessage": "有効な配置: {validPositions}", + "timelion.serverSideErrors.movingstdFunction.notValidPositionErrorMessage": "有効な配置: {validPositions}", + "timelion.serverSideErrors.pointsFunction.notValidSymbolErrorMessage": "有効なシンボル: {validSymbols}", + "timelion.serverSideErrors.quandlFunction.unsupportedIntervalErrorMessage": "quandl() でサポートされていない間隔: {interval}. quandl() でサポートされている間隔: {intervals}", + "timelion.serverSideErrors.sheetParseErrorMessage": "予想: 文字 {column} で {expectedDescription}。", + "timelion.serverSideErrors.unknownArgumentErrorMessage": "{functionName} への不明な引数: {argumentName}", + "timelion.serverSideErrors.unknownArgumentTypeErrorMessage": "引数タイプがサポートされていません: {argument}", + "timelion.serverSideErrors.worldbankFunction.noDataErrorMessage": "Worldbank へのリクエストは成功しましたが、{code} のデータがありませんでした", + "timelion.serverSideErrors.wrongFunctionArgumentTypeErrorMessage": "{functionName} ({argumentName}) は {requiredTypes} の内の 1 つでなければなりません。{actualType} を入手", + "timelion.serverSideErrors.yaxisFunction.notSupportedUnitTypeErrorMessage": "{units} はサポートされているユニットタイプではありません。.", + "timelion.serverSideErrors.yaxisFunction.notValidCurrencyFormatErrorMessage": "通貨は 3 文字のコードでなければなりません", + "timelion.timelionDescription": "関数式で時系列チャートを作成します。", + "timelion.topNavMenu.addChartButtonAriaLabel": "チャートを追加", + "timelion.topNavMenu.addChartButtonLabel": "追加", + "timelion.topNavMenu.delete.modal.confirmButtonLabel": "削除", + "timelion.topNavMenu.delete.modal.successNotificationText": "「{title}」が削除されました", + "timelion.topNavMenu.delete.modal.warningText": "削除されたシートは復元できません。", + "timelion.topNavMenu.delete.modalTitle": "Timelion シート「{title}」を削除しますか?", + "timelion.topNavMenu.deleteSheetButtonAriaLabel": "現在のシートを削除", + "timelion.topNavMenu.deleteSheetButtonLabel": "削除", + "timelion.topNavMenu.helpButtonAriaLabel": "ヘルプ", + "timelion.topNavMenu.helpButtonLabel": "ヘルプ", + "timelion.topNavMenu.newSheetButtonAriaLabel": "新規シート", + "timelion.topNavMenu.newSheetButtonLabel": "新規", + "timelion.topNavMenu.openSheetButtonAriaLabel": "シートを開く", + "timelion.topNavMenu.openSheetButtonLabel": "開く", + "timelion.topNavMenu.openSheetTitle": "シートを開く", + "timelion.topNavMenu.options.columnsCountLabel": "列 (列カウントは 12 できっかりと割れる必要があります)", + "timelion.topNavMenu.options.rowsCountLabel": "行 (これは現在のウィンドウの縦の長さに基づく目標値です)。", + "timelion.topNavMenu.optionsButtonAriaLabel": "オプション", + "timelion.topNavMenu.optionsButtonLabel": "オプション", + "timelion.topNavMenu.save.saveAsDashboardPanel.inputPlaceholder": "このパネルに名前を付ける", + "timelion.topNavMenu.save.saveAsDashboardPanel.selectedExpressionLabel": "現在選択されている式", + "timelion.topNavMenu.save.saveAsDashboardPanel.submitButtonLabel": "保存", + "timelion.topNavMenu.save.saveAsDashboardPanelDescription": "Kibana ダッシュボードにチャートの追加が必要ですか?できます!このオプションは、現在選択されている式を、他のオブジェクトの追加と同じように Kibana ダッシュボードに追加可能なパネルとして保存します。他のパネルへのリファレンスが使用されている場合、リファレンスの表現を直接保存する表現にコピーして、リファレンスを削除する必要があります。他の表現式を保存するよう選択すrには、チャートをクリックします。", + "timelion.topNavMenu.save.saveAsDashboardPanelLabel": "式に名前を付けて保存", + "timelion.topNavMenu.save.saveAsDashboardPanelTitle": "現在の式を Kibana ダッシュボードのパネルとして保存", + "timelion.topNavMenu.save.saveEntireSheet.inputAriaLabel": "名前", + "timelion.topNavMenu.save.saveEntireSheet.inputPlaceholder": "このシートに名前を付ける…", + "timelion.topNavMenu.save.saveEntireSheet.submitButtonLabel": "保存", + "timelion.topNavMenu.save.saveEntireSheetDescription": "Timelion 式を主に Timelion アプリで使用し、Kibana のダッシュボードに Timelion のチャートを追加する必要がない場合は、このオプションを使用します。他のパネルへのリファレンスを使用する場合もこのオプションを使用します。", + "timelion.topNavMenu.save.saveEntireSheetLabel": "シートに名前を付けて保存", + "timelion.topNavMenu.save.saveEntireSheetTitle": "Timelion シート全体の保存", + "timelion.topNavMenu.saveSheetButtonAriaLabel": "シートを保存", + "timelion.topNavMenu.saveSheetButtonLabel": "保存", + "timelion.topNavMenu.sheetOptionsTitle": "シートオプション", + "timelion.topNavMenu.statsDescription": "クエリ時間 {queryTime}ms / 処理時間 {processingTime}ms", + "timelion.uiSettings.defaultColumnsDescription": "デフォルトの Timelion シートの列数です", + "timelion.uiSettings.defaultColumnsLabel": "デフォルトの列", + "timelion.uiSettings.defaultIndexDescription": "{esParam} で検索するデフォルトの Elasticsearch インデックスです", + "timelion.uiSettings.defaultIndexLabel": "デフォルトのインデックス", + "timelion.uiSettings.defaultRowsDescription": "デフォルトの Timelion シートの行数です", + "timelion.uiSettings.defaultRowsLabel": "デフォルトの行", + "timelion.uiSettings.experimentalLabel": "実験的", + "timelion.uiSettings.graphiteURLDescription": "{experimentalLabel}Graphite ホストの URL です", + "timelion.uiSettings.graphiteURLLabel": "Graphite URL", + "timelion.uiSettings.maximumBucketsDescription": "1 つのデータソースが返せるバケットの最大数です", + "timelion.uiSettings.maximumBucketsLabel": "バケットの最大数", + "timelion.uiSettings.minimumIntervalDescription": "「auto」を使用時に計算される最小の間隔です", + "timelion.uiSettings.minimumIntervalLabel": "最低間隔", + "timelion.uiSettings.quandlKeyDescription": "{experimentalLabel} www.quandl.com からの API キーです", + "timelion.uiSettings.quandlKeyLabel": "Quandl キー", + "timelion.uiSettings.showTutorialDescription": "Timelion アプリの起動時にデフォルトでチュートリアルを表示しますか?", + "timelion.uiSettings.showTutorialLabel": "チュートリアルを表示", + "timelion.uiSettings.targetBucketsDescription": "自動間隔の使用時に目標となるバケット数です。", + "timelion.uiSettings.targetBucketsLabel": "目標バケット数", + "timelion.uiSettings.timeFieldDescription": "{esParam} の使用時にタイムスタンプを含むデフォルトのフィールドです", + "timelion.uiSettings.timeFieldLabel": "時間フィールド", + "timelion.vis.expressionLabel": "Timelion 式", + "timelion.vis.intervalLabel": "間隔", "uiActions.actionPanel.title": "オプション", "uiActions.errors.incompatibleAction": "操作に互換性がありません", + "visTypeMarkdown.function.font.help": "フォント設定です。", + "visTypeMarkdown.function.help": "マークダウンビジュアライゼーション", + "visTypeMarkdown.function.markdown.help": "レンダリングするマークダウン", + "visTypeMarkdown.function.openLinksInNewTab.help": "新規タブでリンクを開きます", + "visTypeMarkdown.markdownDescription": "マークダウン構文でドキュメントを作成します", + "visTypeMarkdown.params.fontSizeLabel": "ポイント単位のベースフォントサイズです。", + "visTypeMarkdown.params.helpLinkLabel": "ヘルプ", + "visTypeMarkdown.params.openLinksLabel": "新規タブでリンクを開く", + "visTypeMarkdown.tabs.dataText": "データ", + "visTypeMarkdown.tabs.optionsText": "オプション", + "visTypeMetric.colorModes.backgroundOptionLabel": "背景", + "visTypeMetric.colorModes.labelsOptionLabel": "ラベル", + "visTypeMetric.colorModes.noneOptionLabel": "なし", + "visTypeMetric.function.bgFill.help": "html 16 進数コード (#123456)、html 色 (red、blue)、または rgba 値 (rgba(255,255,255,1))。", + "visTypeMetric.function.bucket.help": "バケットディメンションの構成です。", + "visTypeMetric.function.colorMode.help": "色を変更するメトリックの部分", + "visTypeMetric.function.colorRange.help": "別の色が適用される値のグループを指定する範囲オブジェクト。", + "visTypeMetric.function.colorScheme.help": "使用する配色", + "visTypeMetric.function.font.help": "フォント設定です。", + "visTypeMetric.function.help": "メトリックビジュアライゼーション", + "visTypeMetric.function.invertColors.help": "色範囲を反転します", + "visTypeMetric.function.metric.help": "メトリックディメンションの構成です。", + "visTypeMetric.function.percentage.help": "パーセンテージモードでメトリックを表示します。colorRange を設定する必要があります。", + "visTypeMetric.function.showLabels.help": "メトリック値の下にラベルを表示します。", + "visTypeMetric.function.subText.help": "メトリックの下に表示するカスタムテキスト", + "visTypeMetric.function.useRanges.help": "有効な色範囲です。", + "visTypeMetric.metricDescription": "計算結果を単独の数字として表示します。", + "visTypeMetric.metricTitle": "メトリック", + "visTypeMetric.params.color.useForLabel": "使用する色", + "visTypeMetric.params.percentageModeLabel": "パーセンテージモード", + "visTypeMetric.params.rangesTitle": "範囲", + "visTypeMetric.params.settingsTitle": "設定", + "visTypeMetric.params.showTitleLabel": "タイトルを表示", + "visTypeMetric.params.style.fontSizeLabel": "ポイント単位のメトリックフォントサイズ", + "visTypeMetric.params.style.styleTitle": "スタイル", + "visTypeMetric.schemas.metricTitle": "メトリック", + "visTypeMetric.schemas.splitGroupTitle": "グループを分割", + "visTypeTable.aggTable.exportLabel": "エクスポート:", + "visTypeTable.aggTable.formattedLabel": "フォーマット済み", + "visTypeTable.aggTable.rawLabel": "生", + "visTypeTable.directives.tableCellFilter.filterForValueTooltip": "値でフィルタリング", + "visTypeTable.directives.tableCellFilter.filterOutValueTooltip": "値を除外", + "visTypeTable.function.help": "表ビジュアライゼーション", + "visTypeTable.params.defaultPercentageCol": "非表示", + "visTypeTable.params.PercentageColLabel": "パーセンテージ列", + "visTypeTable.params.percentageTableColumnName": "{title} パーセント", + "visTypeTable.params.perPageLabel": "ページごとの行数", + "visTypeTable.params.showMetricsLabel": "すべてのバケット/レベルのメトリックを表示", + "visTypeTable.params.showPartialRowsLabel": "部分的な行を表示", + "visTypeTable.params.showPartialRowsTip": "部分データのある行を表示。表示されていなくてもすべてのバケット/レベルのメトリックが計算されます。", + "visTypeTable.params.showTotalLabel": "合計を表示", + "visTypeTable.params.totalFunctionLabel": "合計機能", + "visTypeTable.tableVisDescription": "テーブルに値を表示します。", + "visTypeTable.tableVisEditorConfig.schemas.bucketTitle": "行を分割", + "visTypeTable.tableVisEditorConfig.schemas.metricTitle": "メトリック", + "visTypeTable.tableVisEditorConfig.schemas.splitTitle": "テーブルを分割", + "visTypeTable.tableVisTitle": "データテーブル", + "visTypeTable.totalAggregations.averageText": "平均", + "visTypeTable.totalAggregations.countText": "カウント", + "visTypeTable.totalAggregations.maxText": "最高", + "visTypeTable.totalAggregations.minText": "最低", + "visTypeTable.totalAggregations.sumText": "合計", + "visTypeTable.vis.noResultsFoundTitle": "結果が見つかりませんでした", + "visTypeTagCloud.feedbackMessage.tooSmallContainerDescription": "コンテナーが小さすぎてクラウド全体を表示できません。タグが切り取られたか省略されている可能性があります。", + "visTypeTagCloud.feedbackMessage.truncatedTagsDescription": "描写時間が長くなるのを防ぐため、タグの数が切り捨てられています。", + "visTypeTagCloud.function.bucket.help": "バケットディメンションの構成です。", + "visTypeTagCloud.function.help": "タグクラウドのビジュアライゼーションです。", + "visTypeTagCloud.function.metric.help": "メトリックディメンションの構成です。", + "visTypeTagCloud.function.orientation.help": "タグクラウド内の単語の方向です。", + "visTypeTagCloud.function.scale.help": "単語のフォントサイズを決定するスケールです", + "visTypeTagCloud.vis.editorConfig.orientations.multipleText": "複数", + "visTypeTagCloud.vis.editorConfig.orientations.rightAngledText": "直角", + "visTypeTagCloud.vis.editorConfig.orientations.singleText": "単一", + "visTypeTagCloud.vis.editorConfig.scales.linearText": "直線", + "visTypeTagCloud.vis.editorConfig.scales.logText": "ログ", + "visTypeTagCloud.vis.editorConfig.scales.squareRootText": "平方根", + "visTypeTagCloud.vis.schemas.metricTitle": "タグサイズ", + "visTypeTagCloud.vis.schemas.segmentTitle": "タグ", + "visTypeTagCloud.vis.tagCloudDescription": "重要度に基づき大きさを変えた単語のグループ表示です。", + "visTypeTagCloud.vis.tagCloudTitle": "タグクラウド", + "visTypeTagCloud.visParams.fontSizeLabel": "フォントサイズ範囲 (ピクセル)", + "visTypeTagCloud.visParams.orientationsLabel": "方向", + "visTypeTagCloud.visParams.showLabelToggleLabel": "ラベルを表示", + "visTypeTagCloud.visParams.textScaleLabel": "テキストスケール", "visTypeTimeseries.addDeleteButtons.addButtonDefaultTooltip": "追加", "visTypeTimeseries.addDeleteButtons.cloneButtonDefaultTooltip": "クローンを作成", "visTypeTimeseries.addDeleteButtons.deleteButtonDefaultTooltip": "削除", @@ -12537,7 +3730,1914 @@ "visTypeTimeseries.visPicker.timeSeriesLabel": "時系列", "visTypeTimeseries.visPicker.topNLabel": "トップ N", "visTypeTimeseries.yesButtonLabel": "はい", + "visTypeVega.editor.formatError": "仕様のフォーマット中にエラーが発生", + "visTypeVega.editor.reformatAsHJSONButtonLabel": "HJSON に変換", + "visTypeVega.editor.reformatAsJSONButtonLabel": "JSON に変換しコメントを削除", + "visTypeVega.editor.vegaDocumentationLinkText": "Vega ドキュメント", + "visTypeVega.editor.vegaEditorOptionsButtonAriaLabel": "Vega エディターオプション", + "visTypeVega.editor.vegaHelpButtonAriaLabel": "Vega ヘルプ", + "visTypeVega.editor.vegaHelpLinkText": "Kibana Vega ヘルプ", + "visTypeVega.editor.vegaLiteDocumentationLinkText": "Vega-Lite ドキュメンテーション", + "visTypeVega.emsFileParser.emsFileNameDoesNotExistErrorMessage": "{emsfile} {emsfileName} が存在しません", + "visTypeVega.emsFileParser.missingNameOfFileErrorMessage": "{dataUrlParamValue} の {dataUrlParam} には {nameParam} パラメーター (ファイル名) が必要です", + "visTypeVega.esQueryParser.autointervalValueTypeErrorMessage": "{autointerval} は文字 {trueValue} または数字である必要があります", + "visTypeVega.esQueryParser.dataUrlMustNotHaveLegacyAndBodyQueryValuesAtTheSameTimeErrorMessage": "{dataUrlParam} はレガシー {legacyContext} と {bodyQueryConfigName} の値を同時に含めることができません。", + "visTypeVega.esQueryParser.dataUrlMustNotHaveLegacyContextTogetherWithContextOrTimefieldErrorMessage": "{dataUrlParam} は {legacyContext} と同時に {context} または {timefield} を含めることができません", + "visTypeVega.esQueryParser.legacyContextCanBeTrueErrorMessage": "レガシー {legacyContext} は {trueValue} (時間範囲ピッカーを無視)、または時間フィールドの名前のどちらかです。例: {timestampParam}", + "visTypeVega.esQueryParser.legacyUrlShouldChangeToWarningMessage": "レガシー {urlParam}: {legacyUrl} を {result} に変更する必要があります", + "visTypeVega.esQueryParser.shiftMustValueTypeErrorMessage": "{shiftParam} は数値でなければなりません", + "visTypeVega.esQueryParser.timefilterValueErrorMessage": "{timefilter} のプロパティは {trueValue}、{minValue}、または {maxValue} に設定する必要があります", + "visTypeVega.esQueryParser.unknownUnitValueErrorMessage": "不明な {unitParamName} 値。[{unitParamValues}] の内の 1 つでなければなりません", + "visTypeVega.esQueryParser.urlBodyValueTypeErrorMessage": "{configName} はオブジェクトでなければなりません", + "visTypeVega.esQueryParser.urlContextAndUrlTimefieldMustNotBeUsedErrorMessage": "{urlContext} と {timefield} は {queryParam} が設定されている場合使用できません", + "visTypeVega.function.help": "Vega ビジュアライゼーション", + "visTypeVega.mapView.mapStyleNotFoundWarningMessage": "{mapStyleParam} が見つかりませんでした", + "visTypeVega.mapView.minZoomAndMaxZoomHaveBeenSwappedWarningMessage": "{minZoomPropertyName} と {maxZoomPropertyName} が交換されました", + "visTypeVega.mapView.resettingPropertyToMaxValueWarningMessage": "{name} を {max} にリセットしています", + "visTypeVega.mapView.resettingPropertyToMinValueWarningMessage": "{name} を {min} にリセットしています", + "visTypeVega.type.vegaDescription": "Vega と Vega-Lite を使用してカスタムビジュアライゼーションを作成します。", + "visTypeVega.urlParser.dataUrlRequiresUrlParameterInFormErrorMessage": "{dataUrlParam} には「{formLink}」の形で {urlParam} パラメーターが必要です", + "visTypeVega.urlParser.urlShouldHaveQuerySubObjectWarningMessage": "{urlObject} を使用するには {subObjectName} サブオブジェクトが必要です", + "visTypeVega.vegaParser.baseView.externalUrlsAreNotEnabledErrorMessage": "外部 URL が無効です。{enableExternalUrls} を {kibanaConfigFileName} に追加します", + "visTypeVega.vegaParser.baseView.functionIsNotDefinedForGraphErrorMessage": "このグラフには {funcName} が定義されていません", + "visTypeVega.vegaParser.baseView.timeValuesTypeErrorMessage": "時間フィルターの設定エラー: 両方の時間の値は相対的または絶対的な日付である必要があります。 {start}、{end}", + "visTypeVega.vegaParser.centerOnMarkConfigValueTypeErrorMessage": "{configName} は {trueValue}、{falseValue}、または数字でなければなりません", + "visTypeVega.vegaParser.dataExceedsSomeParamsUseTimesLimitErrorMessage": "データには {urlParam}、{valuesParam}、 {sourceParam} の内複数を含めることができません", + "visTypeVega.vegaParser.hostConfigIsDeprecatedWarningMessage": "{deprecatedConfigName} は廃止されました。代わりに {newConfigName} を使用してください。", + "visTypeVega.vegaParser.hostConfigValueTypeErrorMessage": "{configName} が含まれている場合、オブジェクトでなければなりません", + "visTypeVega.vegaParser.inputSpecDoesNotSpecifySchemaWarningMessage": "インプット仕様で {schemaParam} が指定されていないため、デフォルトで {defaultSchema} になります", + "visTypeVega.vegaParser.invalidVegaSpecErrorMessage": "無効な Vega 仕様", + "visTypeVega.vegaParser.kibanaConfigValueTypeErrorMessage": "{configName} が含まれている場合、オブジェクトでなければなりません", + "visTypeVega.vegaParser.mapStyleValueTypeWarningMessage": "{mapStyleConfigName} は {mapStyleConfigFirstAllowedValue} か {mapStyleConfigSecondAllowedValue} のどちらかです", + "visTypeVega.vegaParser.maxBoundsValueTypeWarningMessage": "{maxBoundsConfigName} は 4 つの数字の配列でなければなりません", + "visTypeVega.vegaParser.notSupportedUrlTypeErrorMessage": "{urlObject} はサポートされていません", + "visTypeVega.vegaParser.notValidLibraryVersionForInputSpecWarningMessage": "インプット仕様に {schemaLibrary} {schemaVersion} が使用されていますが、現在のバージョンの {schemaLibrary} は {libraryVersion} です。’", + "visTypeVega.vegaParser.paddingConfigValueTypeErrorMessage": "{configName} は数字でなければなりません", + "visTypeVega.vegaParser.someKibanaConfigurationIsNoValidWarningMessage": "{configName} は有効ではありません", + "visTypeVega.vegaParser.someKibanaParamValueTypeWarningMessage": "{configName} はブール値でなければなりません", + "visTypeVega.vegaParser.unexpectedValueForPositionConfigurationErrorMessage": "{configurationName} 構成に予期せぬ値が使用されています", + "visTypeVega.vegaParser.unrecognizedControlsLocationValueErrorMessage": "認識されない {controlsLocationParam} 値[{locToDirMap}] のいずれかである必要があります", + "visTypeVega.vegaParser.unrecognizedDirValueErrorMessage": "認識されない {dirParam} 値[{expectedValues}] のいずれかである必要があります", + "visTypeVega.vegaParser.VLCompilerShouldHaveGeneratedSingleProtectionObjectErrorMessage": "内部エラー:Vega-Lite コンパイラーがシングルプロジェクションオブジェクトを生成したはずです", + "visTypeVega.vegaParser.widthAndHeightParamsAreIgnoredWithAutosizeFitWarningMessage": "{widthParam} と {heightParam} パラメーターは {autosizeParam} で無視されます", + "visTypeVega.visualization.indexNotFoundErrorMessage": "インデックス {index} が見つかりません", + "visTypeVega.visualization.renderErrorTitle": "Vega エラー", + "visTypeVega.visualization.unableToFindDefaultIndexErrorMessage": "デフォルトのインデックスが見つかりません", + "visTypeVega.visualization.unableToRenderWithoutDataWarningMessage": "データなしにはレンダリングできません", + "xpack.actions.actionTypeRegistry.get.missingActionTypeErrorMessage": "アクションタイプ \"{id}\" は登録されていません。", + "xpack.actions.actionTypeRegistry.register.duplicateActionTypeErrorMessage": "アクションタイプ \"{id}\" は既に登録されています。", + "xpack.actions.builtin.slack.unexpectedNullResponseErrorMessage": "Slack から予期せぬ null 応答", + "xpack.actions.builtin.webhook.webhookConfigurationError": "Web フックアクションの構成中にエラーが発生: {message}", + "xpack.actions.urlWhitelistConfigurationError": "ターゲット {field} 「{value}」は Kibana のホワイトリストに登録されていません", + "xpack.advancedUiActions.customizePanelTimeRange.modal.addToPanelButtonTitle": "パネルに追加", + "xpack.advancedUiActions.customizePanelTimeRange.modal.cancelButtonTitle": "キャンセル", + "xpack.advancedUiActions.customizePanelTimeRange.modal.optionsMenuForm.panelTitleFormRowLabel": "時間範囲", + "xpack.advancedUiActions.customizePanelTimeRange.modal.removeButtonTitle": "削除", + "xpack.advancedUiActions.customizePanelTimeRange.modal.updatePanelTimeRangeButtonTitle": "更新", + "xpack.advancedUiActions.customizeTimeRange.modal.headerTitle": "パネルの時間範囲のカスタマイズ", + "xpack.advancedUiActions.customizeTimeRangeMenuItem.displayName": "時間範囲のカスタマイズ", "xpack.alerting.alertsClient.validateActions.invalidGroups": "無効なアクショングループ: {groups}", + "xpack.alerting.alertTypeRegistry.get.missingAlertTypeError": "アラートタイプ\"{id}\"は登録されていません。", + "xpack.alerting.alertTypeRegistry.register.duplicateAlertTypeError": "アラートタイプ\"{id}\"は既に登録されています。", + "xpack.apm.agentMetrics.java.gcRate": "GC レート", + "xpack.apm.agentMetrics.java.gcRateChartTitle": "1 分ごとのごみ収集レート", + "xpack.apm.agentMetrics.java.gcTime": "GC 時間", + "xpack.apm.agentMetrics.java.gcTimeChartTitle": "1 分ごとのごみ収集の時間", + "xpack.apm.agentMetrics.java.heapMemoryChartTitle": "ヒープ領域", + "xpack.apm.agentMetrics.java.heapMemorySeriesCommitted": "平均実行割当", + "xpack.apm.agentMetrics.java.heapMemorySeriesMax": "平均制限", + "xpack.apm.agentMetrics.java.heapMemorySeriesUsed": "平均使用", + "xpack.apm.agentMetrics.java.nonHeapMemoryChartTitle": "ヒープ領域以外", + "xpack.apm.agentMetrics.java.nonHeapMemorySeriesCommitted": "平均実行割当", + "xpack.apm.agentMetrics.java.nonHeapMemorySeriesUsed": "平均使用", + "xpack.apm.agentMetrics.java.threadCount": "平均カウント", + "xpack.apm.agentMetrics.java.threadCountChartTitle": "スレッド数", + "xpack.apm.agentMetrics.java.threadCountMax": "最高カウント", + "xpack.apm.apmDescription": "アプリケーション内から自動的に詳細なパフォーマンスメトリックやエラーを集めます。", + "xpack.apm.apmForESDescription": "Elastic Stack 用の APM", + "xpack.apm.applyFilter": "{title} フィルターを適用", + "xpack.apm.applyOptions": "オプションを適用", + "xpack.apm.breadcrumb.errorsTitle": "エラー", + "xpack.apm.breadcrumb.listSettingsTitle": "設定", + "xpack.apm.breadcrumb.metricsTitle": "メトリック", + "xpack.apm.breadcrumb.nodesTitle": "JVM", + "xpack.apm.breadcrumb.serviceMapTitle": "サービスマップ", + "xpack.apm.breadcrumb.servicesTitle": "サービス", + "xpack.apm.breadcrumb.tracesTitle": "トレース", + "xpack.apm.breadcrumb.transactionsTitle": "トランザクション", + "xpack.apm.chart.cpuSeries.processAverageLabel": "プロセス平均", + "xpack.apm.chart.cpuSeries.processMaxLabel": "プロセス最大", + "xpack.apm.chart.cpuSeries.systemAverageLabel": "システム平均", + "xpack.apm.chart.cpuSeries.systemMaxLabel": "システム最大", + "xpack.apm.chart.memorySeries.systemAverageLabel": "平均", + "xpack.apm.chart.memorySeries.systemMaxLabel": "最高", + "xpack.apm.clearFilters": "フィルターを消去", + "xpack.apm.datePicker.last15MinutesLabel": "過去 15 分間", + "xpack.apm.datePicker.last1HourLabel": "過去 1 時間", + "xpack.apm.datePicker.last1YearLabel": "過去 1 年間", + "xpack.apm.datePicker.last24HoursLabel": "過去 24 時間", + "xpack.apm.datePicker.last30DaysLabel": "過去 30 日間", + "xpack.apm.datePicker.last30MinutesLabel": "過去 30 分間", + "xpack.apm.datePicker.last7DaysLabel": "過去 7 日間", + "xpack.apm.datePicker.last90DaysLabel": "過去 90 日間", + "xpack.apm.emptyMessage.noDataFoundDescription": "別の時間範囲を試すか検索フィルターをリセットしてください。", + "xpack.apm.emptyMessage.noDataFoundLabel": "データが見つかりません。", + "xpack.apm.error.prompt.body": "詳細はブラウザの開発者コンソールをご確認ください。", + "xpack.apm.error.prompt.title": "申し訳ございませんが、エラーが発生しました :(", + "xpack.apm.errorGroupDetails.culpritLabel": "原因", + "xpack.apm.errorGroupDetails.errorGroupTitle": "エラーグループ {errorGroupId}", + "xpack.apm.errorGroupDetails.errorOccurrenceTitle": "エラーのオカレンス", + "xpack.apm.errorGroupDetails.exceptionMessageLabel": "例外メッセージ", + "xpack.apm.errorGroupDetails.logMessageLabel": "ログメッセージ", + "xpack.apm.errorGroupDetails.noErrorsLabel": "エラーが見つかりませんでした", + "xpack.apm.errorGroupDetails.occurrencesChartLabel": "オカレンス", + "xpack.apm.errorGroupDetails.occurrencesLongLabel": "{occCount} 件", + "xpack.apm.errorGroupDetails.occurrencesShortLabel": "{occCount} 件", + "xpack.apm.errorGroupDetails.relatedTransactionSample": "関連トランザクションサンプル", + "xpack.apm.errorGroupDetails.unhandledLabel": "未対応", + "xpack.apm.errorGroupDetails.viewOccurrencesInDiscoverButtonLabel": "ディスカバリで {occurrencesCount} 件の{occurrencesCount, plural, one {ドキュメント} other {ドキュメント}}を表示。", + "xpack.apm.errorsTable.errorMessageAndCulpritColumnLabel": "エラーメッセージと原因", + "xpack.apm.errorsTable.groupIdColumnLabel": "グループ ID", + "xpack.apm.errorsTable.latestOccurrenceColumnLabel": "最近のオカレンス", + "xpack.apm.errorsTable.noErrorsLabel": "エラーが見つかりませんでした", + "xpack.apm.errorsTable.occurrencesColumnLabel": "オカレンス", + "xpack.apm.errorsTable.unhandledLabel": "未対応", + "xpack.apm.featureRegistry.apmFeatureName": "APM", + "xpack.apm.fetcher.error.status": "エラー", + "xpack.apm.fetcher.error.title": "リソースの取得中にエラーが発生しました", + "xpack.apm.fetcher.error.url": "URL", + "xpack.apm.filter.environment.allLabel": "すべて", + "xpack.apm.filter.environment.label": "環境", + "xpack.apm.filter.environment.notDefinedLabel": "未定義", + "xpack.apm.filter.environment.selectEnvironmentLabel": "環境を選択", + "xpack.apm.formatters.hoursTimeUnitLabel": "h", + "xpack.apm.formatters.microsTimeUnitLabel": "マイクロ秒", + "xpack.apm.formatters.millisTimeUnitLabel": "ミリ秒", + "xpack.apm.formatters.minutesTimeUnitLabel": "最低", + "xpack.apm.formatters.requestsPerMinLabel": "1分あたりリクエスト数", + "xpack.apm.formatters.secondsTimeUnitLabel": "秒", + "xpack.apm.formatters.transactionsPerMinLabel": "1分あたりトランザクション数", + "xpack.apm.header.badge.readOnly.text": "読み込み専用", + "xpack.apm.header.badge.readOnly.tooltip": "を保存できませんでした", + "xpack.apm.helpMenu.upgradeAssistantLink": "アップグレードアシスタント", + "xpack.apm.home.serviceMapTabLabel": "サービスマップ", + "xpack.apm.home.servicesTabLabel": "サービス", + "xpack.apm.home.tracesTabLabel": "トレース", + "xpack.apm.invalidLicense.licenseManagementLink": "ライセンスを更新", + "xpack.apm.invalidLicense.message": "現在ご使用のライセンスが期限切れか有効でなくなったため、APM UI を利用できません。", + "xpack.apm.invalidLicense.title": "無効なライセンス", + "xpack.apm.jvmsTable.cpuColumnLabel": "CPU 平均", + "xpack.apm.jvmsTable.explainServiceNodeNameMissing": "これらのメトリックが所属する JVM を特定できませんでした。7.5 よりも古い APM Server を実行していることが原因である可能性が高いです。この問題は APM Server 7.5 以降にアップグレードすることで解決されます。", + "xpack.apm.jvmsTable.heapMemoryColumnLabel": "ヒープ領域の平均", + "xpack.apm.jvmsTable.nameColumnLabel": "名前", + "xpack.apm.jvmsTable.nameExplanation": "JVM 名はデフォルトでコンピューター ID (該当する場合) またはホスト名ですが、エージェントの「'service_node_name」で手動で構成することもできます。", + "xpack.apm.jvmsTable.noJvmsLabel": "JVM が見つかりませんでした", + "xpack.apm.jvmsTable.nonHeapMemoryColumnLabel": "非ヒープ領域の平均", + "xpack.apm.jvmsTable.threadCountColumnLabel": "最大スレッド数", + "xpack.apm.localFilters.titles.agentName": "エージェント名", + "xpack.apm.localFilters.titles.containerId": "コンテナー ID", + "xpack.apm.localFilters.titles.host": "ホスト", + "xpack.apm.localFilters.titles.podName": "ポッド", + "xpack.apm.localFilters.titles.transactionResult": "トランザクション結果", + "xpack.apm.localFilters.titles.transactionType": "トランザクションタイプ", + "xpack.apm.localFiltersTitle": "各種フィルター", + "xpack.apm.metadataTable.section.agentLabel": "エージェント", + "xpack.apm.metadataTable.section.containerLabel": "コンテナー", + "xpack.apm.metadataTable.section.customLabel": "カスタム", + "xpack.apm.metadataTable.section.errorLabel": "エラー", + "xpack.apm.metadataTable.section.hostLabel": "ホスト", + "xpack.apm.metadataTable.section.httpLabel": "HTTP", + "xpack.apm.metadataTable.section.labelsLabel": "ラベル", + "xpack.apm.metadataTable.section.pageLabel": "ページ", + "xpack.apm.metadataTable.section.processLabel": "プロセス", + "xpack.apm.metadataTable.section.serviceLabel": "サービス", + "xpack.apm.metadataTable.section.spanLabel": "スパン", + "xpack.apm.metadataTable.section.traceLabel": "トレース", + "xpack.apm.metadataTable.section.transactionLabel": "トランザクション", + "xpack.apm.metadataTable.section.urlLabel": "URL", + "xpack.apm.metadataTable.section.userAgentLabel": "ユーザーエージェント", + "xpack.apm.metadataTable.section.userLabel": "ユーザー", + "xpack.apm.metrics.durationByCountryMap.avgPageLoadByCountryLabel": "国ごとの平均ページ読み込み時間の分布", + "xpack.apm.metrics.durationByCountryMap.RegionMapChart.ToolTip.avgPageLoadDuration": "平均ページ読み込み時間:", + "xpack.apm.metrics.durationByCountryMap.RegionMapChart.ToolTip.countPageLoads": "{docCount} ページの読み込み", + "xpack.apm.metrics.plot.noDataLabel": "この時間範囲のデータがありません。", + "xpack.apm.metrics.transactionChart.machineLearningLabel": "機械学習:", + "xpack.apm.metrics.transactionChart.machineLearningTooltip": "平均期間の周りのストリームには予測バウンドが表示されます。異常スコアが >= 75 の場合、注釈が表示されます。", + "xpack.apm.metrics.transactionChart.pageLoadTimesLabel": "ページ読み込み時間", + "xpack.apm.metrics.transactionChart.requestsPerMinuteLabel": "1 分あたりのリクエスト", + "xpack.apm.metrics.transactionChart.routeChangeTimesLabel": "ルート変更時間", + "xpack.apm.metrics.transactionChart.transactionDurationLabel": "トランザクション時間", + "xpack.apm.metrics.transactionChart.transactionsPerMinuteLabel": "1 分あたりのトランザクション数", + "xpack.apm.notAvailableLabel": "N/A", + "xpack.apm.percentOfParent": "({parentType, select, transaction { 件中 {value} 件のトランザクション} トレース {trace} })", + "xpack.apm.propertiesTable.agentFeature.noDataAvailableLabel": "利用可能なデータがありません", + "xpack.apm.propertiesTable.tabs.exceptionStacktraceLabel": "例外のスタックトレース", + "xpack.apm.propertiesTable.tabs.logStacktraceLabel": "ログのスタックトレース", + "xpack.apm.propertiesTable.tabs.metadataLabel": "メタデータ", + "xpack.apm.propertiesTable.tabs.timelineLabel": "タイムライン", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.callout.jobExistsDescription": "現在 {serviceName} ({transactionType}) の実行中のジョブがあります。", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.callout.jobExistsDescription.viewJobLinkText": "既存のジョブを表示", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.callout.jobExistsTitle": "ジョブが既に存在します", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.createMLJobDescription": "ここでは、{serviceName} 数列内の APM トランザクションの期間の異常スコアを計算する機械学習ジョブを作成できます。有効にすると、{transactionDurationGraphText} が予測バウンドを表示し、異常スコアが >=75 の場合グラフに注釈が追加されます。", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.createMLJobDescription.transactionDurationGraphText": "トランザクション時間のグラフ", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.createNewJobButtonLabel": "新規ジョブを作成", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.enableAnomalyDetectionTitle": "異常検知を有効にする", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.jobCreatedNotificationText": "現在 {serviceName} ({transactionType}) の分析を実行中です。応答時間グラフに結果が追加されるまで少し時間がかかる場合があります。", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.jobCreatedNotificationText.viewJobLinkText": "ジョブを表示", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.jobCreatedNotificationTitle": "ジョブが作成されました", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.jobCreationFailedNotificationText": "現在のライセンスでは機械学習ジョブの作成が許可されていないか、ジョブが既に存在する可能性があります。", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.jobCreationFailedNotificationTitle": "ジョブの作成に失敗", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.manageMLJobDescription": "ジョブはそれぞれのサービス + トランザクションタイプの組み合わせに対して作成できます。ジョブの作成後、{mlJobsPageLink} で管理と詳細の確認ができます。", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.manageMLJobDescription.mlJobsPageLinkText": "機械学習ジョブの管理ページ", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.manageMLJobDescription.noteText": "注:ジョブが結果の計算を開始するまでに少し時間がかかる場合があります。", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.selectTransactionTypeLabel": "このジョブのトランザクションタイプを選択してください", + "xpack.apm.serviceDetails.enableErrorReportsPanel.actionsDescription": "レポートはメールで送信するか Slack チャンネルに投稿できます。各レポートにはオカランス別のトップ 10 のエラーが含まれます。", + "xpack.apm.serviceDetails.enableErrorReportsPanel.actionsTitle": "アクション", + "xpack.apm.serviceDetails.enableErrorReportsPanel.conditionTitle": "コンディション", + "xpack.apm.serviceDetails.enableErrorReportsPanel.createWatchButtonLabel": "ウォッチを作成", + "xpack.apm.serviceDetails.enableErrorReportsPanel.dailyReportHelpText": "デイリーレポートは {dailyTimeFormatted} / {dailyTime12HourFormatted} に送信されます。", + "xpack.apm.serviceDetails.enableErrorReportsPanel.dailyReportRadioButtonLabel": "デイリーレポート", + "xpack.apm.serviceDetails.enableErrorReportsPanel.emailSubjectText": "{serviceName} にしきい値を超えたエラーグループがあります", + "xpack.apm.serviceDetails.enableErrorReportsPanel.emailTemplateText": "{serviceName} サービスに {timeRange}{br}{br}{errorGroupsBuckets}{br}{errorLogMessage}{br}{errorCulprit}N/A{slashErrorCulprit}{br}{docCountParam} オカレンス {br}{slashErrorGroupsBucket} 内で {threshold} 件のオカレンスを超えるエラーグループがあります", + "xpack.apm.serviceDetails.enableErrorReportsPanel.enableErrorReportsTitle": "エラーレポートを有効にする", + "xpack.apm.serviceDetails.enableErrorReportsPanel.formDescription": "このフォームは、このサービスでのエラーのオカレンスを通知するウォッチの作成をアシストします。Watcher の書斎は、{documentationLink} をご覧ください。", + "xpack.apm.serviceDetails.enableErrorReportsPanel.formDescription.documentationLinkText": "ドキュメンテーション", + "xpack.apm.serviceDetails.enableErrorReportsPanel.intervalHelpText": "レポートの間隔。", + "xpack.apm.serviceDetails.enableErrorReportsPanel.intervalRadioButtonLabel": "間隔", + "xpack.apm.serviceDetails.enableErrorReportsPanel.intervalUnit.hrsLabel": "時間", + "xpack.apm.serviceDetails.enableErrorReportsPanel.intervalUnit.minsLabel": "分", + "xpack.apm.serviceDetails.enableErrorReportsPanel.occurrencesThresholdHelpText": "エラーグループがレポートに含まれるしきい値です。", + "xpack.apm.serviceDetails.enableErrorReportsPanel.occurrencesThresholdLabel": "エラーグループごとのオカレンスのしきい値", + "xpack.apm.serviceDetails.enableErrorReportsPanel.recipientsHelpText": "メールを構成していない場合は、{documentationLink} をご覧ください。", + "xpack.apm.serviceDetails.enableErrorReportsPanel.recipientsHelpText.documentationLinkText": "ドキュメンテーション", + "xpack.apm.serviceDetails.enableErrorReportsPanel.recipientsLabel": "受信者 (コンマ区切り)", + "xpack.apm.serviceDetails.enableErrorReportsPanel.sendEmailLabel": "メールを送信", + "xpack.apm.serviceDetails.enableErrorReportsPanel.sendSlackNotificationLabel": "Slack 通知を送信", + "xpack.apm.serviceDetails.enableErrorReportsPanel.slackTemplateText": "{serviceName} サービスに {timeRange} 以内に {threshold} 件のオカレンスを超えるエラーグループがあります。\n{errorGroupsBuckets}\n{errorLogMessage}\n{errorCulprit}N/A{slashErrorCulprit}\n{docCountParam} 件のオカレンス\n{slashErrorGroupsBucket}", + "xpack.apm.serviceDetails.enableErrorReportsPanel.slackWebhookURLHelpText": "Slack webhook の取得方法は、{documentationLink} をご覧ください。", + "xpack.apm.serviceDetails.enableErrorReportsPanel.slackWebhookURLHelpText.documentationLinkText": "ドキュメンテーション", + "xpack.apm.serviceDetails.enableErrorReportsPanel.slackWebhookURLLabel": "Slack Webhook URL", + "xpack.apm.serviceDetails.enableErrorReportsPanel.triggerScheduleDescription": "しきい値を超えた際のレポートの間隔を選択してください。", + "xpack.apm.serviceDetails.enableErrorReportsPanel.triggerScheduleTitle": "トリガースケジュール", + "xpack.apm.serviceDetails.enableErrorReportsPanel.triggerText": "この値はトリガーセクションで変更する必要があります。", + "xpack.apm.serviceDetails.enableErrorReportsPanel.watchCreatedNotificationText": "ウォッチの準備が完了し、{serviceName} のエラーレポートが送信されます。", + "xpack.apm.serviceDetails.enableErrorReportsPanel.watchCreatedNotificationText.viewWatchLinkText": "ウォッチを表示", + "xpack.apm.serviceDetails.enableErrorReportsPanel.watchCreatedNotificationTitle": "新規ウォッチが作成されました!", + "xpack.apm.serviceDetails.enableErrorReportsPanel.watchCreationFailedNotificationText": "ユーザーにウォッチ作成のパーミッションがあることを確認してください。", + "xpack.apm.serviceDetails.enableErrorReportsPanel.watchCreationFailedNotificationTitle": "ウォッチの作成に失敗", + "xpack.apm.serviceDetails.errorsTabLabel": "エラー", + "xpack.apm.serviceDetails.integrationsMenu.enableMLAnomalyDetectionButtonLabel": "ML 異常検知を有効にする", + "xpack.apm.serviceDetails.integrationsMenu.enableMLAnomalyDetectionButtonTooltip": "このサービスの機械学習ジョブをセットアップします", + "xpack.apm.serviceDetails.integrationsMenu.enableWatcherErrorReportsButtonLabel": "ウォッチエラーレポートを有効にする", + "xpack.apm.serviceDetails.integrationsMenu.integrationsButtonLabel": "統合", + "xpack.apm.serviceDetails.integrationsMenu.viewWatchesButtonLabel": "既存のウォッチを表示", + "xpack.apm.serviceDetails.metrics.cpuUsageChartTitle": "CPU 使用状況", + "xpack.apm.serviceDetails.metrics.errorOccurrencesChartTitle": "エラーのオカレンス", + "xpack.apm.serviceDetails.metrics.memoryUsageChartTitle": "システムメモリー使用状況", + "xpack.apm.serviceDetails.metricsTabLabel": "メトリック", + "xpack.apm.serviceDetails.nodesTabLabel": "JVM", + "xpack.apm.serviceDetails.transactionsTabLabel": "トランザクション", + "xpack.apm.serviceMap.fullscreen": "全画面", + "xpack.apm.serviceMap.zoomIn": "ズームイン", + "xpack.apm.serviceMap.zoomOut": "ズームアウト", + "xpack.apm.serviceNodeMetrics.containerId": "コンテナー ID", + "xpack.apm.serviceNodeMetrics.host": "ホスト", + "xpack.apm.serviceNodeMetrics.unidentifiedServiceNodesWarningDocumentationLink": "APM Server のドキュメンテーション", + "xpack.apm.serviceNodeMetrics.unidentifiedServiceNodesWarningText": "これらのメトリックが所属する JVM を特定できませんでした。7.5 よりも古い APM Server を実行していることが原因である可能性が高いです。この問題は APM Server 7.5 以降にアップグレードすることで解決されます。アップグレードに関する詳細は、{link} をご覧ください。代わりに Kibana クエリバーを使ってホスト名、コンテナー ID、またはその他フィールドでフィルタリングすることもできます。", + "xpack.apm.serviceNodeMetrics.unidentifiedServiceNodesWarningTitle": "JVM を特定できませんでした", + "xpack.apm.serviceNodeNameMissing": "(空)", + "xpack.apm.serviceOverview.toastText": "現在 Elastic Stack 7.0+ を実行中で、以前のバージョン 6.x からの互換性のないデータを検知しました。このデータを APM で表示するには、移行が必要です。詳細: ", + "xpack.apm.serviceOverview.toastTitle": "選択された時間範囲内にレガシーデータが検知されました。", + "xpack.apm.serviceOverview.upgradeAssistantLink": "アップグレードアシスタント", + "xpack.apm.servicesTable.7xOldDataMessage": "また、移行が必要な古いデータがある可能性もあります。", + "xpack.apm.servicesTable.7xUpgradeServerMessage": "pre-7.x バージョンからのアップグレードですか?次のアップグレードも完了していることを確認してください:\n APM サーバーインスタンスを 7.0 以降に。", + "xpack.apm.servicesTable.agentColumnLabel": "エージェント", + "xpack.apm.servicesTable.avgResponseTimeColumnLabel": "平均応答時間", + "xpack.apm.servicesTable.environmentColumnLabel": "環境", + "xpack.apm.servicesTable.environmentCount": "{environmentCount, plural, one {1 個の環境} other {# 個の環境}}", + "xpack.apm.servicesTable.errorsPerMinuteColumnLabel": "1 分あたりのエラー", + "xpack.apm.servicesTable.errorsPerMinuteUnitLabel": "エラー", + "xpack.apm.servicesTable.nameColumnLabel": "名前", + "xpack.apm.servicesTable.noServicesLabel": "APM サービスがインストールされていないようです。追加しましょう!", + "xpack.apm.servicesTable.notFoundLabel": "サービスが見つかりません", + "xpack.apm.servicesTable.transactionsPerMinuteColumnLabel": "1 分あたりのトランザクション", + "xpack.apm.servicesTable.transactionsPerMinuteUnitLabel": "1分あたりトランザクション数", + "xpack.apm.servicesTable.UpgradeAssistantLink": "Kibana アップグレードアシスタントで詳細をご覧ください", + "xpack.apm.settings.agentConf.allOptionLabel": "すべて", + "xpack.apm.settings.agentConf.cancelButtonLabel": "キャンセル", + "xpack.apm.settings.agentConf.configTable.appliedTooltipMessage": "1 つまたは複数のエージェントにより適用されました。", + "xpack.apm.settings.agentConf.configTable.captureBodyColumnLabel": "キャプチャ本文", + "xpack.apm.settings.agentConf.configTable.configTable.failurePromptText": "エージェントの構成一覧を取得できませんでした。ユーザーに十分なパーミッションがない可能性があります。", + "xpack.apm.settings.agentConf.configTable.createConfigButtonLabel": "構成の作成", + "xpack.apm.settings.agentConf.configTable.editButtonDescription": "この構成を編集します", + "xpack.apm.settings.agentConf.configTable.editButtonLabel": "編集", + "xpack.apm.settings.agentConf.configTable.emptyPromptText": "変更しましょう。直接 Kibana からエージェント構成を微調整できます。再展開する必要はありません。まず、最初の構成を作成します。", + "xpack.apm.settings.agentConf.configTable.emptyPromptTitle": "構成が見つかりません。", + "xpack.apm.settings.agentConf.configTable.environmentColumnLabel": "サービス環境", + "xpack.apm.settings.agentConf.configTable.lastUpdatedColumnLabel": "最終更新", + "xpack.apm.settings.agentConf.configTable.notAppliedTooltipMessage": "まだエージェントにより適用されていません", + "xpack.apm.settings.agentConf.configTable.sampleRateColumnLabel": "サンプルレート", + "xpack.apm.settings.agentConf.configTable.serviceNameColumnLabel": "サービス名", + "xpack.apm.settings.agentConf.configTable.transactionMaxSpansColumnLabel": "トランザクションの最大範囲", + "xpack.apm.settings.agentConf.configurationsPanelTitle": "構成", + "xpack.apm.settings.agentConf.createConfigButtonLabel": "構成の作成", + "xpack.apm.settings.agentConf.createConfigTitle": "構成の作成", + "xpack.apm.settings.agentConf.editConfigTitle": "構成の編集", + "xpack.apm.settings.agentConf.flyout.deleteSection.buttonLabel": "削除", + "xpack.apm.settings.agentConf.flyout.deleteSection.deleteConfigFailedText": "{serviceName} の構成を削除中にエラーが発生しました。エラー「{errorMessage}」", + "xpack.apm.settings.agentConf.flyout.deleteSection.deleteConfigFailedTitle": "構成を削除できませんでした", + "xpack.apm.settings.agentConf.flyout.deleteSection.deleteConfigSucceededText": "「{serviceName}」の構成が正常に削除されました。エージェントに反映されるまでに少し時間がかかります。", + "xpack.apm.settings.agentConf.flyout.deleteSection.deleteConfigSucceededTitle": "構成が削除されました", + "xpack.apm.settings.agentConf.flyOut.serviceSection.alreadyConfiguredOption": "既に構成済み", + "xpack.apm.settings.agentConf.flyOut.serviceSection.selectPlaceholder": "選択してください", + "xpack.apm.settings.agentConf.flyOut.serviceSection.serviceEnvironmentSelectHelpText": "構成ごとに 1 つの環境のみがサポートされます。", + "xpack.apm.settings.agentConf.flyOut.serviceSection.serviceEnvironmentSelectLabel": "環境", + "xpack.apm.settings.agentConf.flyOut.serviceSection.serviceNameSelectHelpText": "構成するサービスを選択してください。", + "xpack.apm.settings.agentConf.flyOut.serviceSection.serviceNameSelectLabel": "名前", + "xpack.apm.settings.agentConf.flyOut.serviceSection.title": "サービス", + "xpack.apm.settings.agentConf.flyOut.settingsSection.captureBodyInputHelpText": "HTTP リクエストのトランザクションの場合、エージェントはリクエスト本文 (POST 変数など) をキャプチャすることができます。デフォルトは「off」です。", + "xpack.apm.settings.agentConf.flyOut.settingsSection.captureBodyInputLabel": "本文をキャプチャ", + "xpack.apm.settings.agentConf.flyOut.settingsSection.captureBodyInputPlaceholderText": "オプションを選択", + "xpack.apm.settings.agentConf.flyOut.settingsSection.sampleRateConfigurationInputErrorText": "サンプルレートは 0.000 ~ 1 の範囲でなければなりません", + "xpack.apm.settings.agentConf.flyOut.settingsSection.sampleRateConfigurationInputHelpText": "0.000 ~ 1.0 の範囲のレートを選択してください。デフォルトは 1.0 (トレースの 100%) です。", + "xpack.apm.settings.agentConf.flyOut.settingsSection.sampleRateConfigurationInputLabel": "トランザクションのサンプルレート", + "xpack.apm.settings.agentConf.flyOut.settingsSection.sampleRateConfigurationInputPlaceholderText": "サンプルレートを設定", + "xpack.apm.settings.agentConf.flyOut.settingsSection.title": "オプション", + "xpack.apm.settings.agentConf.flyOut.settingsSection.transactionMaxSpansConfigInputErrorText": "0 と 32000 の間でなければなりません", + "xpack.apm.settings.agentConf.flyOut.settingsSection.transactionMaxSpansConfigInputHelpText": "トランザクションごとに記録される範囲を制限します。デフォルトは 500 です。", + "xpack.apm.settings.agentConf.flyOut.settingsSection.transactionMaxSpansConfigInputLabel": "トランザクションの最大範囲", + "xpack.apm.settings.agentConf.flyOut.settingsSection.transactionMaxSpansConfigInputPlaceholderText": "トランザクションの最大範囲を設定", + "xpack.apm.settings.agentConf.saveConfig.failed.text": "「{serviceName}」の構成を保存中にエラーが発生しました。エラー「{errorMessage}」", + "xpack.apm.settings.agentConf.saveConfig.failed.title": "構成を保存できませんでした", + "xpack.apm.settings.agentConf.saveConfig.succeeded.text": "「{serviceName}」の構成が保存されました。エージェントに反映されるまでに少し時間がかかります。", + "xpack.apm.settings.agentConf.saveConfig.succeeded.title": "構成が保存されました", + "xpack.apm.settings.agentConf.saveConfigurationButtonLabel": "保存", + "xpack.apm.settingsLinkLabel": "設定", + "xpack.apm.setupInstructionsButtonLabel": "セットアップの手順", + "xpack.apm.stacktraceTab.localVariablesToogleButtonLabel": "ローカル変数", + "xpack.apm.stacktraceTab.noStacktraceAvailableLabel": "利用可能なスタックトレースがありません", + "xpack.apm.toggleHeight.showLessButtonLabel": "表示する行数を減らす", + "xpack.apm.toggleHeight.showMoreButtonLabel": "表示する行数を増やす", + "xpack.apm.tracesTable.avgResponseTimeColumnLabel": "平均応答時間", + "xpack.apm.tracesTable.impactColumnDescription": "ご利用のサービスで最も頻繁に使用されていて、最も遅いエンドポイントです。相対的平均時間に 1 分ごとのトランザクション数をかけて計算されます。", + "xpack.apm.tracesTable.impactColumnLabel": "インパクト", + "xpack.apm.tracesTable.nameColumnLabel": "名前", + "xpack.apm.tracesTable.notFoundLabel": "このクエリのトレースが見つかりません", + "xpack.apm.tracesTable.originatingServiceColumnLabel": "発生元サービス", + "xpack.apm.tracesTable.tracesPerMinuteColumnLabel": "1 分あたりのトレース", + "xpack.apm.tracesTable.tracesPerMinuteUnitLabel": "1分あたりトランザクション数", + "xpack.apm.transactionActionMenu.actionsButtonLabel": "アクション", + "xpack.apm.transactionActionMenu.actionsLabel": "アクション", + "xpack.apm.transactionActionMenu.showContainerLogsLinkLabel": "コンテナーログを表示", + "xpack.apm.transactionActionMenu.showContainerMetricsLinkLabel": "コンテナーメトリックを表示", + "xpack.apm.transactionActionMenu.showHostLogsLinkLabel": "ホストログを表示", + "xpack.apm.transactionActionMenu.showHostMetricsLinkLabel": "ホストメトリックを表示", + "xpack.apm.transactionActionMenu.showPodLogsLinkLabel": "ポッドログを表示", + "xpack.apm.transactionActionMenu.showPodMetricsLinkLabel": "ポッドメトリックを表示", + "xpack.apm.transactionActionMenu.showTraceLogsLinkLabel": "トレースログを表示", + "xpack.apm.transactionActionMenu.viewInUptime": "監視ステータスを表示", + "xpack.apm.transactionActionMenu.viewSampleDocumentLinkLabel": "サンプルドキュメントを表示", + "xpack.apm.transactionBreakdown.chartTitle": "スパンタイプ別時間", + "xpack.apm.transactionBreakdown.hideChart": "グラフを非表示", + "xpack.apm.transactionBreakdown.noData": "この時間範囲のデータがありません。", + "xpack.apm.transactionBreakdown.showChart": "グラフを表示", + "xpack.apm.transactionDetails.errorCount": "{errorCount, number} {errorCount, plural, one {件のエラー} other {件のエラー}}", + "xpack.apm.transactionDetails.errorsOverviewLinkTooltip": "{errorCount, plural, one {1 件の関連エラーを表示} other {# 件の関連エラーを表示}}", + "xpack.apm.transactionDetails.notFoundLabel": "トランザクションが見つかりませんでした。", + "xpack.apm.transactionDetails.noTraceParentButtonTooltip": "トレースの親が見つかりませんでした", + "xpack.apm.transactionDetails.percentOfTraceLabelExplanation": "{parentType, select, transaction {トランザクション} trace {トレース} }の割合が100%を超えています。これは、この{childType, select, span {スパン} transaction {トランザクション} }がルートトランザクションよりも時間がかかるためです。", + "xpack.apm.transactionDetails.requestMethodLabel": "リクエストメソッド", + "xpack.apm.transactionDetails.resultLabel": "結果", + "xpack.apm.transactionDetails.serviceLabel": "サービス", + "xpack.apm.transactionDetails.servicesTitle": "サービス", + "xpack.apm.transactionDetails.spanFlyout.databaseStatementTitle": "データベースステートメント", + "xpack.apm.transactionDetails.spanFlyout.nameLabel": "名前", + "xpack.apm.transactionDetails.spanFlyout.spanAction": "アクション", + "xpack.apm.transactionDetails.spanFlyout.spanDetailsTitle": "スパン詳細", + "xpack.apm.transactionDetails.spanFlyout.spanSubtype": "サブタイプ", + "xpack.apm.transactionDetails.spanFlyout.spanType": "タイプ", + "xpack.apm.transactionDetails.spanFlyout.spanType.navigationTimingLabel": "ナビゲーションタイミング", + "xpack.apm.transactionDetails.spanFlyout.stackTraceTabLabel": "スタックトレース", + "xpack.apm.transactionDetails.spanFlyout.viewSpanInDiscoverButtonLabel": "ディスカバリでスパンを表示", + "xpack.apm.transactionDetails.statusCode": "ステータスコード", + "xpack.apm.transactionDetails.traceNotFound": "選択されたトレースが見つかりません", + "xpack.apm.transactionDetails.traceSampleTitle": "トレースのサンプル", + "xpack.apm.transactionDetails.transactionLabel": "トランザクション", + "xpack.apm.transactionDetails.transactionsDurationDistributionChart.noSampleTooltip": "このバケットに利用可能なサンプルがありません", + "xpack.apm.transactionDetails.transactionsDurationDistributionChart.requestTypeUnitLongLabel": "{transCount, plural, =0 {# request} 1 {# 件のリクエスト} other {# 件のリクエスト}}", + "xpack.apm.transactionDetails.transactionsDurationDistributionChart.transactionTypeUnitLongLabel": "{transCount, plural, =0 {# transaction} 1 {# 件のトランザクション} other {# 件のトランザクション}}", + "xpack.apm.transactionDetails.transactionsDurationDistributionChart.unitShortLabel": "{transCount} {transType, select, request {件のリクエスト} other {件のトランザクション}}", + "xpack.apm.transactionDetails.transactionsDurationDistributionChartTitle": "トラザクション時間の分布", + "xpack.apm.transactionDetails.transactionsDurationDistributionChartTooltip.samplingDescription": "各バケットはサンプルトランザクションを示します。利用可能なサンプルがない場合、恐らくエージェントの構成で設定されたサンプリング制限が原因です。", + "xpack.apm.transactionDetails.transactionsDurationDistributionChartTooltip.samplingLabel": "サンプリング", + "xpack.apm.transactionDetails.transFlyout.callout.agentDroppedSpansMessage": "このトランザクションを報告した APM エージェントが、構成に基づき {dropped} 個以上のスパンをドロップしました。", + "xpack.apm.transactionDetails.transFlyout.callout.learnMoreAboutDroppedSpansLinkText": "ドロップされたスパンの詳細。", + "xpack.apm.transactionDetails.transFlyout.transactionDetailsTitle": "トランザクションの詳細", + "xpack.apm.transactionDetails.userAgentAndVersionLabel": "ユーザーエージェントとバージョン", + "xpack.apm.transactionDetails.viewFullTraceButtonLabel": "完全なトレースを表示", + "xpack.apm.transactionDetails.viewingFullTraceButtonTooltip": "現在完全なトレースが表示されています", + "xpack.apm.transactionDurationLabel": "期間", + "xpack.apm.transactions.chart.95thPercentileLabel": "95 パーセンタイル", + "xpack.apm.transactions.chart.99thPercentileLabel": "99 パーセンタイル", + "xpack.apm.transactions.chart.anomalyBoundariesLabel": "異常境界", + "xpack.apm.transactions.chart.anomalyScoreLabel": "異常スコア", + "xpack.apm.transactions.chart.averageLabel": "平均", + "xpack.apm.transactionsTable.95thPercentileColumnLabel": "95 パーセンタイル", + "xpack.apm.transactionsTable.avgDurationColumnLabel": "平均期間", + "xpack.apm.transactionsTable.impactColumnDescription": "ご利用のサービスで最も頻繁に使用されていて、最も遅いエンドポイントです。相対的平均時間に 1 分ごとのトランザクション数をかけて計算されます。", + "xpack.apm.transactionsTable.impactColumnLabel": "インパクト", + "xpack.apm.transactionsTable.nameColumnLabel": "名前", + "xpack.apm.transactionsTable.notFoundLabel": "トランザクションが見つかりませんでした。", + "xpack.apm.transactionsTable.transactionsPerMinuteColumnLabel": "1 分あたりのトランザクション", + "xpack.apm.transactionsTable.transactionsPerMinuteUnitLabel": "1分あたりトランザクション数", + "xpack.apm.waterfall.exceedsMax": "このトレースの項目数は表示されている範囲を超えています", + "xpack.beatsManagement.beat.actionSectionTypeLabel": "タイプ: {beatType}。", + "xpack.beatsManagement.beat.actionSectionVersionLabel": "バージョン: {beatVersion}", + "xpack.beatsManagement.beat.beatNameAndIdTitle": "ビート: {nameOrNoName} (ID: {id})", + "xpack.beatsManagement.beat.beatNotFoundErrorMessage": "ビートが見つかりません", + "xpack.beatsManagement.beat.beatNotFoundErrorTitle": "ビートが見つかりません", + "xpack.beatsManagement.beat.beatNotFoundMessage": "ビートが見つかりません", + "xpack.beatsManagement.beat.configTabLabel": "構成", + "xpack.beatsManagement.beat.configurationTagsTabLabel": "構成タグ", + "xpack.beatsManagement.beat.detailsConfigurationDescription": "1 つのタグに風数構成を適用することができます。これらの構成は必要に応じて同じタイプを繰り返したり、タイプを組み合わせることができます。例えば、3 つの Metricbeat 構成と同時に 1 つのインプットと Filebeat 構成を使用することができます。", + "xpack.beatsManagement.beat.detailsConfigurationTitle": "構成", + "xpack.beatsManagement.beat.lastConfigUpdateMessage": "前回の構成の更新: {lastUpdateTime}。", + "xpack.beatsManagement.beat.loadingTitle": "読み込み中", + "xpack.beatsManagement.beatConfigurations.descriptionColumnName": "説明", + "xpack.beatsManagement.beatConfigurations.moduleColumnName": "モジュール", + "xpack.beatsManagement.beatConfigurations.tagColumnName": "タグ", + "xpack.beatsManagement.beatConfigurations.typeColumnName": "タイプ", + "xpack.beatsManagement.beats.addedNotificationDescription": "タグ {tag} を {assignmentsLength, plural, one { ビート {beatName}} other {# ビート}}に追加しました。", + "xpack.beatsManagement.beats.addedNotificationTitle": "{assignmentsLength, plural, one {タグ } other {タグ}} が追加されました", + "xpack.beatsManagement.beats.beatDisenrolledNotificationDescription": "ID {firstBeatId} のビートの登録が解除されました。", + "xpack.beatsManagement.beats.beatDisenrolledNotificationTitle": "{firstBeatNameOrId} の登録解除", + "xpack.beatsManagement.beats.configurationTagsTabTitle": "構成タグ", + "xpack.beatsManagement.beats.disenrolledBeatsNotificationTitle": "{beatsLength} 個のビートの登録解除", + "xpack.beatsManagement.beats.enrollBeatsButtonLabel": "ビートを登録", + "xpack.beatsManagement.beats.enrolledBeatsTabTitle": "登録済みのビート", + "xpack.beatsManagement.beats.enrollNewBeatsTitle": "新規ビートの登録", + "xpack.beatsManagement.beats.installBeatsLearningButtonLabel": "ビートのインストール方法", + "xpack.beatsManagement.beats.removedNotificationDescription": "{assignmentsLength, plural, one {beat {beatName}} other {# beats}}からタグ{tag}が削除されました。", + "xpack.beatsManagement.beats.removedNotificationTitle": "{assignmentsLength, plural, one {Tag} other {Tags}} が削除されました", + "xpack.beatsManagement.beatsListAssignmentOptions.setTagsButtonLabel": "タグを設定", + "xpack.beatsManagement.beatsListAssignmentOptions.unenrollBeatsWarninigMessage": "選択されたビートは今後集中管理を使用しません", + "xpack.beatsManagement.beatsListAssignmentOptions.unenrollBeatsWarninigTitle": "選択されたビートの登録を解除しますか?", + "xpack.beatsManagement.beatsListAssignmentOptions.unenrollButtonLabel": "選択項目の登録を解除", + "xpack.beatsManagement.beatsTable.beatNameTitle": "ビート名", + "xpack.beatsManagement.beatsTable.configErrorStatusLabel": "構成エラー", + "xpack.beatsManagement.beatsTable.configStatus.errorTooltip": "このビートにエラーがあります。このホストのログを確認してください。", + "xpack.beatsManagement.beatsTable.configStatus.noConnectionTooltip": "このビートは 10 分以上 Kibana に接続していません", + "xpack.beatsManagement.beatsTable.configStatus.notStartedLabel": "未開始", + "xpack.beatsManagement.beatsTable.configStatus.notStartedTooltip": "このビートはまだ開始していません。", + "xpack.beatsManagement.beatsTable.configStatus.offlineLabel": "オフライン", + "xpack.beatsManagement.beatsTable.configStatus.okLabel": "OK", + "xpack.beatsManagement.beatsTable.configStatus.okTooltip": "最新の構成にビートが適用されました", + "xpack.beatsManagement.beatsTable.configStatus.progressTooltip": "このビートは現在 CM から構成を再読み込み中です。", + "xpack.beatsManagement.beatsTable.configStatus.runningTooltip": "このビートは問題なく動作中です。", + "xpack.beatsManagement.beatsTable.configStatus.startingTooltip": "このビートは開始中です。", + "xpack.beatsManagement.beatsTable.configStatusTitle": "構成ステータス", + "xpack.beatsManagement.beatsTable.disenrollSelectedLabel": "選択項目の登録を解除", + "xpack.beatsManagement.beatsTable.failedStatusLabel": "エラー", + "xpack.beatsManagement.beatsTable.runningStatusLabel": "実行中", + "xpack.beatsManagement.beatsTable.startingStatusLabel": "開始中", + "xpack.beatsManagement.beatsTable.stoppedStatusLabel": "停止中", + "xpack.beatsManagement.beatsTable.tagsTitle": "タグ", + "xpack.beatsManagement.beatsTable.typeLabel": "タイプ", + "xpack.beatsManagement.beatsTable.typeTitle": "タイプ", + "xpack.beatsManagement.beatsTable.updatingStatusLabel": "更新中", + "xpack.beatsManagement.beatTagsTable.addTagLabel": "タグを追加", + "xpack.beatsManagement.beatTagsTable.lastUpdateTitle": "最終更新", + "xpack.beatsManagement.beatTagsTable.removeSelectedLabel": "選択項目を削除", + "xpack.beatsManagement.beatTagsTable.tagNameTitle": "タグ名", + "xpack.beatsManagement.breadcrumb.beatDetails": "{beatId} のビート詳細", + "xpack.beatsManagement.breadcrumb.beatTags": "{beatId} のビートタグ", + "xpack.beatsManagement.breadcrumb.configurationTags": "構成タグ", + "xpack.beatsManagement.breadcrumb.enrolledBeats": "登録済みのビート", + "xpack.beatsManagement.centralManagementLinkLabel": "集中管理", + "xpack.beatsManagement.centralManagementSectionLabel": "ビート", + "xpack.beatsManagement.config.other.error": "有効な YAML フォーマットを使用してください", + "xpack.beatsManagement.config.otherConfigDescription": "YAML フォーマットで Filebeat インプットの他の設定を指定します", + "xpack.beatsManagement.config.otherConfigLabel": "他の構成", + "xpack.beatsManagement.confirmModal.cancelButtonLabel": "キャンセル", + "xpack.beatsManagement.confirmModal.confirmButtonLabel": "確認", + "xpack.beatsManagement.confirmModal.confirmWarningTitle": "確認", + "xpack.beatsManagement.createTag.errorSavingTagTitle": "タグの保存中にエラーが発生", + "xpack.beatsManagement.createTag.saveAndContinueButtonLabel": "保存して続行", + "xpack.beatsManagement.disabledSecurityDescription": "ビートの集中管理を使用するには、Kibana と Elasticsearch でセキュリティを有効にする必要があります。", + "xpack.beatsManagement.disabledSecurityTitle": "セキュリティが有効ではありません", + "xpack.beatsManagement.enrollBeat.assignTagToBeatInvalidURLNoTagFoundTitle": "無効な URL、createdTag が見つかりません", + "xpack.beatsManagement.enrollBeat.assignTagToBeatInvalidURLNoTokenFountTitle": "無効な URL、enrollmentToken が見つかりません", + "xpack.beatsManagement.enrollBeat.assignTagToBeatNotEnrolledProperlyTitle": "エラー:ビートを正常に登録できません", + "xpack.beatsManagement.enrollBeat.beatEnrolledTitle": "このビートは現在集中管理に登録されています:", + "xpack.beatsManagement.enrollBeat.beatsCentralManagementDescription": "一か所で構成を集中管理できます。", + "xpack.beatsManagement.enrollBeat.beatTypeColumnName": "ビートタイプ", + "xpack.beatsManagement.enrollBeat.beatTypeTitle": "ビートタイプ:", + "xpack.beatsManagement.enrollBeat.copyButtonLabel": "コマンドをコピー", + "xpack.beatsManagement.enrollBeat.createTagStepLabel": "タグを作成", + "xpack.beatsManagement.enrollBeat.enrollBeatButtonLabel": "ビートを登録", + "xpack.beatsManagement.enrollBeat.enrollBeatStepLabel": "ビートを登録", + "xpack.beatsManagement.enrollBeat.finishStepLabel": "終了", + "xpack.beatsManagement.enrollBeat.firstBeatEnrollingDoneButtonLabel": "完了", + "xpack.beatsManagement.enrollBeat.getStartedBeatsCentralManagementTitle": "ビートの集中管理を開始", + "xpack.beatsManagement.enrollBeat.hostnameColumnName": "ホスト名", + "xpack.beatsManagement.enrollBeat.nextStepDescription": "ビートを起動して構成エラーを確認し、「完了」をクリックしてください。", + "xpack.beatsManagement.enrollBeat.nextStepTitle": "ビートが登録されました。次のステップ", + "xpack.beatsManagement.enrollBeat.platformTitle": "プラットフォーム:", + "xpack.beatsManagement.enrollBeat.versionColumnName": "バージョン", + "xpack.beatsManagement.enrollBeat.waitingBeatTypeToEnrollTitle": "{beatType} の登録待ち…", + "xpack.beatsManagement.enrollBeat.yourBeatTypeHostTitle": "{beatType} がインストールされているホストでは次を実行:", + "xpack.beatsManagement.filebeatInputConfig.otherConfigDescription": "YAML フォーマットで Filebeat インプットの他の設定を指定します", + "xpack.beatsManagement.filebeatInputConfig.otherConfigErrorMessage": "有効な YAML フォーマットを使用してください", + "xpack.beatsManagement.filebeatInputConfig.otherConfigLabel": "他の構成", + "xpack.beatsManagement.filebeatInputConfig.pathsDescription": "それぞれのパスを別々の行に入力します", + "xpack.beatsManagement.filebeatInputConfig.pathsErrorMessage": "1 行につき 1 つのパスを入力してください", + "xpack.beatsManagement.filebeatInputConfig.pathsLabel": "パス", + "xpack.beatsManagement.filebeatModuleConfig.moduleDescription": "YAML フォーマットで Filebeat モジュールの他の設定を指定します", + "xpack.beatsManagement.filebeatModuleConfig.moduleErrorMessage": "モジュールを選択してください。", + "xpack.beatsManagement.filebeatModuleConfig.moduleLabel": "モジュール", + "xpack.beatsManagement.filebeatModuleConfig.otherConfigErrorMessage": "有効な YAML フォーマットを使用してください", + "xpack.beatsManagement.filebeatModuleConfig.otherConfigLabel": "他の構成", + "xpack.beatsManagement.invalidLicenseDescription": "現在のライセンスは期限切れです。登録されたビートは引き続き動作しますが、ビート管理 UI にアクセスするには有効なライセンスが必要です。", + "xpack.beatsManagement.invalidLicenseTitle": "ライセンスの期限切れ", + "xpack.beatsManagement.management.breadcrumb": "管理", + "xpack.beatsManagement.metricbeatModuleConfig.hostsDescription": "それぞれのパスを別々の行に入力します", + "xpack.beatsManagement.metricbeatModuleConfig.hostsErrorMessage": "1 行につき 1 つのファイルホストを入力してください", + "xpack.beatsManagement.metricbeatModuleConfig.hostsLabel": "すべてのホスト", + "xpack.beatsManagement.metricbeatModuleConfig.moduleErrorMessage": "モジュールを選択してください。", + "xpack.beatsManagement.metricbeatModuleConfig.moduleLabel": "モジュール", + "xpack.beatsManagement.metricbeatModuleConfig.otherConfigDescription": "YAML フォーマットで Metricbeat モジュールの他の設定を指定します", + "xpack.beatsManagement.metricbeatModuleConfig.otherConfigErrorMessage": "有効な YAML フォーマットを使用してください", + "xpack.beatsManagement.metricbeatModuleConfig.otherConfigLabel": "他の構成", + "xpack.beatsManagement.metricbeatModuleConfig.periodErrorMessage": "無効な期間、10 秒は「10s」というフォーマットを使用してください", + "xpack.beatsManagement.metricbeatModuleConfig.periodLabel": "期間", + "xpack.beatsManagement.noAccess.accessDeniedDescription": "ビート集中管理へのアクセス権がありません。ビート集中管理を使用するには、{beatsAdminRole} ロールから権限が必要です。", + "xpack.beatsManagement.noAccess.accessDeniedTitle": "アクセスが拒否されました", + "xpack.beatsManagement.noContentFoundErrorMessage": "コンテンツがありません", + "xpack.beatsManagement.outputConfig.hostsErrorMessage": "1 行につき 1 つのファイルホストを入力してください", + "xpack.beatsManagement.outputConfig.hostsLabel": "すべてのホスト", + "xpack.beatsManagement.outputConfig.outputTypeErrorMessage": "アウトプットタイプを選択してください", + "xpack.beatsManagement.outputConfig.outputTypeLabel": "アウトプットタイプ", + "xpack.beatsManagement.outputConfig.passwordErrorMessage": "処理不能なパスワードです", + "xpack.beatsManagement.outputConfig.passwordLabel": "パスワード", + "xpack.beatsManagement.outputConfig.usernameErrorMessage": "処理不能なユーザー名です", + "xpack.beatsManagement.outputConfig.usernameLabel": "ユーザー名", + "xpack.beatsManagement.overview.betaBadgeText": "ベータ", + "xpack.beatsManagement.table.filterResultsPlaceholder": "フィルター結果", + "xpack.beatsManagement.table.selectOptionLabel": "オプションを選択してください", + "xpack.beatsManagement.table.selectThisBeatTooltip": "このビートを選択します", + "xpack.beatsManagement.tag.addConfigurationButtonLabel": "構成ブロックを追加", + "xpack.beatsManagement.tag.beatsAssignedToTagTitle": "このタグが付いたビート", + "xpack.beatsManagement.tag.cancelButtonLabel": "キャンセル", + "xpack.beatsManagement.tag.createTagTitle": "タグの作成", + "xpack.beatsManagement.tag.saveButtonLabel": "保存", + "xpack.beatsManagement.tag.tagColorLabel": "タグの色", + "xpack.beatsManagement.tag.tagConfigurationsDescription": "タグには異なるタイプのビートの構成ブロックが使用できます。例えば、1 つのタグに 2 つの Metricbeat 構成ブロックと 1 つの Filebeat インプット構成ブロックを使用することができます。", + "xpack.beatsManagement.tag.tagConfigurationsTitle": "構成ブロック", + "xpack.beatsManagement.tag.tagDetailsDescription": "タグとは、1 つまたは複数のビートに適用できる構成ブロックのグループです。", + "xpack.beatsManagement.tag.tagDetailsTitle": "タグの詳細", + "xpack.beatsManagement.tag.tagName.validationErrorMessage": "タグ名には文字、数字、ハイフンのみが使用できます。", + "xpack.beatsManagement.tag.tagNameLabel": "タグ名", + "xpack.beatsManagement.tag.tagNamePlaceholder": "タグ名 (必須)", + "xpack.beatsManagement.tag.updateTagTitle": "タグ {tagId} を更新", + "xpack.beatsManagement.tagConfig.addConfigurationTitle\"": "構成ブロックを追加", + "xpack.beatsManagement.tagConfig.closeButtonLabel": "閉じる", + "xpack.beatsManagement.tagConfig.configurationTypeText": "{configType}‘構成", + "xpack.beatsManagement.tagConfig.descriptionLabel": "説明", + "xpack.beatsManagement.tagConfig.descriptionPlaceholder": "説明 (オプション)", + "xpack.beatsManagement.tagConfig.editConfigurationTitle": "構成ブロックの編集", + "xpack.beatsManagement.tagConfig.filebeatInputLabel": "Filebeat インプット", + "xpack.beatsManagement.tagConfig.filebeatModuleLabel": "Filebeat モジュール", + "xpack.beatsManagement.tagConfig.invalidSchema": "エラー:この構成は無効です。Beats でサポートされておらず、削除する必要があります", + "xpack.beatsManagement.tagConfig.metricbeatModuleLabel": "Metricbeat モジュール", + "xpack.beatsManagement.tagConfig.outputLabel": "アウトプット", + "xpack.beatsManagement.tagConfig.saveButtonLabel": "保存", + "xpack.beatsManagement.tagConfig.typeLabel": "タイプ", + "xpack.beatsManagement.tagConfig.viewConfigurationTitle\"": "構成ブロックの表示", + "xpack.beatsManagement.tagConfigAssignmentOptions.removeTagsButtonLabel": "タグを削除", + "xpack.beatsManagement.tagConfigAssignmentOptions.removeTagsWarninigMessage": "選択されたビートからタグを削除しますか?", + "xpack.beatsManagement.tagConfigAssignmentOptions.removeTagsWarninigTitle": "タグを削除", + "xpack.beatsManagement.tagListAssignmentOptions.removeTagsButtonLabel": "選択項目を削除", + "xpack.beatsManagement.tagListAssignmentOptions.removeTagsWarninigTitle": "タグを削除", + "xpack.beatsManagement.tagListAssignmentOptions.removeTagWarninigMessage": "タグを削除しますか?", + "xpack.beatsManagement.tags.addTagButtonLabel": "タグを追加", + "xpack.beatsManagement.tags.someTagsMightBeAssignedToBeatsTitle": "これらのタグのいくつかはビートに割り当てられている可能性があります。削除するタグが現在割り当てられていないことを確認してください", + "xpack.beatsManagement.tagsTable.lastUpdateTitle": "最終更新", + "xpack.beatsManagement.tagsTable.removeSelectedLabel": "選択項目を削除", + "xpack.beatsManagement.tagsTable.tagNameTitle": "タグ名", + "xpack.beatsManagement.tagTable.actions.removeButtonAriaLabel": "削除", + "xpack.beatsManagement.tagTable.actions.removeTooltip": "タグからこの構成を削除します", + "xpack.beatsManagement.tagTable.actionsColumnName": "アクション", + "xpack.beatsManagement.tagTable.descriptionColumnName": "説明", + "xpack.beatsManagement.tagTable.moduleColumn.notAvailibaleLabel": "N/A", + "xpack.beatsManagement.tagTable.moduleColumnName": "モジュール", + "xpack.beatsManagement.tagTable.typeColumnName": "タイプ", + "xpack.beatsManagement.walkthrough.initial.betaBadgeText": "ベータ", + "xpack.canvas.app.loadErrorMessage": "メッセージ: {error}", + "xpack.canvas.app.loadErrorTitle": "Canvas の読み込みに失敗", + "xpack.canvas.app.loadingMessage": "Canvas を読み込み中", + "xpack.canvas.appDescription": "データを完璧に美しく表現します。", + "xpack.canvas.argAddPopover.addAriaLabel": "引数を追加", + "xpack.canvas.argFormAdvancedFailure.applyButtonLabel": "適用", + "xpack.canvas.argFormAdvancedFailure.resetButtonLabel": "リセット", + "xpack.canvas.argFormAdvancedFailure.rowErrorMessage": "無効な表現", + "xpack.canvas.argFormArgSimpleForm.removeAriaLabel": "削除", + "xpack.canvas.argFormArgSimpleForm.requiredTooltip": "この引数は必須です。数値を入力してください。", + "xpack.canvas.argFormPendingArgValue.loadingMessage": "読み込み中", + "xpack.canvas.argFormSimpleFailure.failureTooltip": "この引数のインターフェースが値を解析できなかったため、フォールバックインプットが使用されています", + "xpack.canvas.asset.copyAssetTooltip": "ID をクリップボードにコピー", + "xpack.canvas.asset.createImageTooltip": "画像エレメントを作成", + "xpack.canvas.asset.deleteAssetTooltip": "削除", + "xpack.canvas.asset.downloadAssetTooltip": "ダウンロード", + "xpack.canvas.asset.thumbnailAltText": "アセットのサムネイル", + "xpack.canvas.assetManager.confirmModalButtonLabel": "削除", + "xpack.canvas.assetManager.confirmModalDetail": "このアセットを削除してよろしいですか?", + "xpack.canvas.assetManager.confirmModalTitle": "アセットの削除", + "xpack.canvas.assetManager.manageButtonLabel": "アセットの管理", + "xpack.canvas.assetModal.emptyAssetsDescription": "アセットをインポートして開始します", + "xpack.canvas.assetModal.filePickerPromptText": "画像を選択するかドラッグ &amp; ドロップしてください", + "xpack.canvas.assetModal.loadingText": "画像をアップロード中", + "xpack.canvas.assetModal.modalCloseButtonLabel": "閉じる", + "xpack.canvas.assetModal.modalDescription": "以下はこのワークパッドの画像アセットです。現在使用中のアセットは現時点で特定できません。スペースを取り戻すには、アセットを削除してください。", + "xpack.canvas.assetModal.modalTitle": "ワークパッドアセットの管理", + "xpack.canvas.assetModal.spacedUsedText": "{percentageUsed}% のスペースを使用中", + "xpack.canvas.assetpicker.assetAltText": "アセットのサムネイル", + "xpack.canvas.badge.readOnly.text": "読み込み専用", + "xpack.canvas.badge.readOnly.tooltip": "{canvas} ワークパッドを保存できません", + "xpack.canvas.colorManager.addAriaLabel": "色を追加", + "xpack.canvas.colorManager.codePlaceholder": "カラーコード", + "xpack.canvas.colorManager.removeAriaLabel": "色を削除", + "xpack.canvas.customElementModal.cancelButtonLabel": "キャンセル", + "xpack.canvas.customElementModal.descriptionInputLabel": "説明", + "xpack.canvas.customElementModal.elementPreviewTitle": "エレメントのプレビュー", + "xpack.canvas.customElementModal.imageFilePickerPlaceholder": "画像を選択するかドラッグ &amp; ドロップしてください", + "xpack.canvas.customElementModal.imageInputDescription": "エレメントのスクリーンショットを作成してここにアップロードします。保存後に行うこともできます。", + "xpack.canvas.customElementModal.imageInputLabel": "サムネイル画像", + "xpack.canvas.customElementModal.nameInputLabel": "名前", + "xpack.canvas.customElementModal.remainingCharactersDescription": "残り {numberOfRemainingCharacter} 文字", + "xpack.canvas.customElementModal.saveButtonLabel": "保存", + "xpack.canvas.datasourceDatasourceComponent.changeButtonLabel": "データソースを変更", + "xpack.canvas.datasourceDatasourceComponent.previewButtonLabel": "プレビュー", + "xpack.canvas.datasourceDatasourceComponent.saveButtonLabel": "保存", + "xpack.canvas.datasourceDatasourcePreview.emptyFirstLineDescription": "検索条件に一致するドキュメントが見つかりませんでした。", + "xpack.canvas.datasourceDatasourcePreview.emptySecondLineDescription": "データソース設定を確認して再試行してください。", + "xpack.canvas.datasourceDatasourcePreview.emptyTitle": "ドキュメントが見つかりませんでした", + "xpack.canvas.datasourceDatasourcePreview.modalDescription": "このデータを使用するには、サイドバーの {saveLabel} をクリックしてください。", + "xpack.canvas.datasourceDatasourcePreview.modalTitle": "データソースのプレビュー", + "xpack.canvas.datasourceNoDatasource.panelDescription": "このエレメントにはデータソースが添付されていません。これは通常、エレメントが画像または他の不動アセットであることが原因です。その場合、表現が正しい形式であることを確認することをお勧めします。", + "xpack.canvas.datasourceNoDatasource.panelTitle": "データソースなし", + "xpack.canvas.elementConfig.failedLabel": "失敗", + "xpack.canvas.elementConfig.loadedLabel": "読み込み済み", + "xpack.canvas.elementConfig.progressLabel": "進捗", + "xpack.canvas.elementConfig.title": "エレメント", + "xpack.canvas.elementConfig.totalLabel": "合計", + "xpack.canvas.elementControls.deleteAriaLabel": "エレメントを削除", + "xpack.canvas.elementControls.deleteToolTip": "削除", + "xpack.canvas.elementControls.editAriaLabel": "エレメントを編集", + "xpack.canvas.elementControls.editToolTip": "編集", + "xpack.canvas.elements.areaChartDisplayName": "面グラフ", + "xpack.canvas.elements.areaChartHelpText": "塗りつぶされた折れ線グラフ", + "xpack.canvas.elements.bubbleChartDisplayName": "バブルチャート", + "xpack.canvas.elements.bubbleChartHelpText": "カスタマイズ可能なバブルチャートです", + "xpack.canvas.elements.debugDisplayName": "デバッグ", + "xpack.canvas.elements.debugHelpText": "エレメントの構成をダンプします", + "xpack.canvas.elements.donutChartDisplayName": "ドーナッツチャート", + "xpack.canvas.elements.donutChartHelpText": "カスタマイズ可能なドーナッツチャートです", + "xpack.canvas.elements.dropdownFilterDisplayName": "ドロップダウンフィルター", + "xpack.canvas.elements.dropdownFilterHelpText": "「exactly」フィルターの値を選択できるドロップダウンです", + "xpack.canvas.elements.horizontalBarChartDisplayName": "水平棒グラフ", + "xpack.canvas.elements.horizontalBarChartHelpText": "カスタマイズ可能な水平棒グラフです", + "xpack.canvas.elements.horizontalProgressBarDisplayName": "水平プログレスバー", + "xpack.canvas.elements.horizontalProgressBarHelpText": "水平バーに進捗状況を表示します", + "xpack.canvas.elements.horizontalProgressPillDisplayName": "水平プログレスピル", + "xpack.canvas.elements.horizontalProgressPillHelpText": "水平ピルに進捗状況を表示します", + "xpack.canvas.elements.imageDisplayName": "画像", + "xpack.canvas.elements.imageHelpText": "静止画", + "xpack.canvas.elements.lineChartDisplayName": "折れ線グラフ", + "xpack.canvas.elements.lineChartHelpText": "カスタマイズ可能な折れ線グラフです", + "xpack.canvas.elements.markdownDisplayName": "マークダウン", + "xpack.canvas.elements.markdownHelpText": "マークダウンからマークアップします", + "xpack.canvas.elements.metricDisplayName": "メトリック", + "xpack.canvas.elements.metricHelpText": "ラベル付きの数字です", + "xpack.canvas.elements.pieDisplayName": "円グラフ", + "xpack.canvas.elements.pieHelpText": "円グラフ", + "xpack.canvas.elements.plotDisplayName": "座標プロット", + "xpack.canvas.elements.plotHelpText": "折れ線、棒、点の組み合わせです", + "xpack.canvas.elements.progressGaugeDisplayName": "進捗ゲージ", + "xpack.canvas.elements.progressGaugeHelpText": "進捗状況をゲージで表示します", + "xpack.canvas.elements.progressSemicircleDisplayName": "進捗半円", + "xpack.canvas.elements.progressSemicircleHelpText": "進捗状況を半円で表示します", + "xpack.canvas.elements.progressWheelDisplayName": "進捗ホイール", + "xpack.canvas.elements.progressWheelHelpText": "進捗状況をホイールで表示します", + "xpack.canvas.elements.repeatImageDisplayName": "画像の繰り返し", + "xpack.canvas.elements.repeatImageHelpText": "画像を N 回繰り返します", + "xpack.canvas.elements.revealImageDisplayName": "画像の部分表示", + "xpack.canvas.elements.revealImageHelpText": "画像のパーセンテージを表示します", + "xpack.canvas.elements.shapeDisplayName": "図形", + "xpack.canvas.elements.shapeHelpText": "カスタマイズ可能な図形です", + "xpack.canvas.elements.tableDisplayName": "データテーブル", + "xpack.canvas.elements.tableHelpText": "データをチューブ形式で表示する、スクロール可能なグリッドです", + "xpack.canvas.elements.tiltedPieDisplayName": "傾き円グラフ", + "xpack.canvas.elements.tiltedPieHelpText": "カスタマイズ可能な傾き円グラフです", + "xpack.canvas.elements.timeFilterDisplayName": "時間フィルター", + "xpack.canvas.elements.timeFilterHelpText": "期間を設定します", + "xpack.canvas.elements.verticalBarChartDisplayName": "垂直棒グラフ", + "xpack.canvas.elements.verticalBarChartHelpText": "カスタマイズ可能な垂直棒グラフです", + "xpack.canvas.elements.verticalProgressBarDisplayName": "垂直プログレスバー", + "xpack.canvas.elements.verticalProgressBarHelpText": "進捗状況を垂直のバーで表示します", + "xpack.canvas.elements.verticalProgressPillDisplayName": "垂直プログレスピル", + "xpack.canvas.elements.verticalProgressPillHelpText": "進捗状況を垂直のピルで表示します", + "xpack.canvas.elementSettings.dataTabLabel": "データ", + "xpack.canvas.elementSettings.displayTabLabel": "表示", + "xpack.canvas.elementTypes.addNewElementDescription": "ワークパッドのエレメントをグループ化して保存し、新規エレメントを作成します", + "xpack.canvas.elementTypes.addNewElementTitle": "新規エレメントの作成", + "xpack.canvas.elementTypes.cancelButtonLabel": "キャンセル", + "xpack.canvas.elementTypes.deleteButtonLabel": "削除", + "xpack.canvas.elementTypes.deleteElementDescription": "このエレメントを削除してよろしいですか?", + "xpack.canvas.elementTypes.deleteElementTitle": "エレメント「{elementName}」を削除しますか?", + "xpack.canvas.elementTypes.editElementTitle": "エレメントを編集", + "xpack.canvas.elementTypes.elementsTitle": "エレメント", + "xpack.canvas.elementTypes.findElementPlaceholder": "エレメントを検索", + "xpack.canvas.elementTypes.myElementsTitle": "マイエレメント", + "xpack.canvas.embedObject.noMatchingObjectsMessage": "一致するオブジェクトが見つかりませんでした。", + "xpack.canvas.embedObject.titleText": "オブジェクトの埋め込み", + "xpack.canvas.error.actionsElements.invaludArgIndexErrorMessage": "無効な引数インデックス: {index}", + "xpack.canvas.error.downloadWorkpad.downloadFailureErrorMessage": "ワークパッドをダウンロードできませんでした", + "xpack.canvas.error.downloadWorkpad.downloadRenderedWorkpadFailureErrorMessage": "レンダリングされたワークパッドをダウンロードできませんでした", + "xpack.canvas.error.downloadWorkpad.downloadRuntimeFailureErrorMessage": "共有可能なランタイムをダウンロードできませんでした", + "xpack.canvas.error.downloadWorkpad.downloadZippedRuntimeFailureErrorMessage": "ZIP ファイルをダウンロードできませんでした", + "xpack.canvas.error.esPersist.saveFailureTitle": "変更を Elasticsearch に保存できませんでした", + "xpack.canvas.error.esPersist.tooLargeErrorMessage": "サーバーからワークパッドデータが大きすぎるという返答が返されました。これは通常、アップロードされた画像アセットが Kibana またはプロキシに大きすぎることを意味します。アセットマネージャーでいくつかのアセットを削除してみてください。", + "xpack.canvas.error.esPersist.updateFailureTitle": "ワークパッドを更新できませんでした", + "xpack.canvas.error.esService.defaultIndexFetchErrorMessage": "デフォルトのインデックスを取得できませんでした", + "xpack.canvas.error.esService.fieldsFetchErrorMessage": "「{index}」の Elasticsearch フィールドを取得できませんでした", + "xpack.canvas.error.esService.indicesFetchErrorMessage": "Elasticsearch インデックスを取得できませんでした", + "xpack.canvas.error.RenderWithFn.renderErrorMessage": "「{functionName}」フィールドをレンダリング中", + "xpack.canvas.error.repeatImage.missingMaxArgument": "{emptyImageArgument} を提供する場合、{maxArgument} の設定が必要です。", + "xpack.canvas.error.workpadLoader.cloneFailureErrorMessage": "ワークパッドのクローンを作成できませんでした", + "xpack.canvas.error.workpadLoader.deleteFailureErrorMessage": "すべてのワークパッドを削除できませんでした", + "xpack.canvas.error.workpadLoader.findFailureErrorMessage": "ワークパッドが見つかりませんでした", + "xpack.canvas.error.workpadLoader.uploadFailureErrorMessage": "ワークパッドをアップロードできませんでした", + "xpack.canvas.error.workpadRoutes.createFailureErrorMessage": "ワークパッドを作成できませんでした", + "xpack.canvas.error.workpadRoutes.loadFailureErrorMessage": "ID でワークパッドを読み込めませんでした", + "xpack.canvas.error.workpadUpload.acceptJSONOnlyErrorMessage": "{JSON} 個のファイルしか受け付けられませんでした", + "xpack.canvas.error.workpadUpload.fileUploadFailureWithoutFileNameErrorMessage": "ファイルをアップロードできませんでした", + "xpack.canvas.error.workpadUpload.missingPropertiesErrorMessage": "{CANVAS} ワークパッドに必要なプロパティの一部が欠けています。 {JSON} ファイルを編集して正しいプロパティ値を入力し、再試行してください。", + "xpack.canvas.errorComponent.description": "表現が失敗し次のメッセージが返されました:", + "xpack.canvas.errorComponent.title": "おっと!表現が失敗しました", + "xpack.canvas.errors.workpadUpload.fileUploadFileWithFileNameErrorMessage": "「{fileName}」をアップロードできませんでした", + "xpack.canvas.expression.cancelButtonLabel": "キャンセル", + "xpack.canvas.expression.closeButtonLabel": "閉じる", + "xpack.canvas.expression.learnLinkText": "表現構文の詳細", + "xpack.canvas.expression.maximizeButtonLabel": "エディターを最大化", + "xpack.canvas.expression.minimizeButtonLabel": "エディターを最小化", + "xpack.canvas.expression.runButtonLabel": "実行", + "xpack.canvas.expression.runTooltip": "表現を実行", + "xpack.canvas.expressionElementNotSelected.closeButtonLabel": "閉じる", + "xpack.canvas.expressionElementNotSelected.selectDescription": "表現インプットを表示するエレメントを選択します", + "xpack.canvas.expressionInput.argReferenceAliasesDetail": "{BOLD_MD_TOKEN}Aliases{BOLD_MD_TOKEN}: {aliases}", + "xpack.canvas.expressionInput.argReferenceDefaultDetail": "{BOLD_MD_TOKEN}Default{BOLD_MD_TOKEN}: {defaultVal}", + "xpack.canvas.expressionInput.argReferenceRequiredDetail": "{BOLD_MD_TOKEN}Required{BOLD_MD_TOKEN}: {required}", + "xpack.canvas.expressionInput.argReferenceTypesDetail": "{BOLD_MD_TOKEN}Types{BOLD_MD_TOKEN}: {types}", + "xpack.canvas.expressionInput.functionReferenceAccepts": "{BOLD_MD_TOKEN}Accepts{BOLD_MD_TOKEN}: {acceptTypes}", + "xpack.canvas.expressionInput.functionReferenceReturns": "{BOLD_MD_TOKEN}Returns{BOLD_MD_TOKEN}: {returnType}", + "xpack.canvas.expressionTypes.argTypes.colorDisplayName": "色", + "xpack.canvas.expressionTypes.argTypes.colorHelp": "カラーピッカー", + "xpack.canvas.expressionTypes.argTypes.containerStyle.appearanceTitle": "見た目", + "xpack.canvas.expressionTypes.argTypes.containerStyle.borderTitle": "境界", + "xpack.canvas.expressionTypes.argTypes.containerStyle.colorLabel": "色", + "xpack.canvas.expressionTypes.argTypes.containerStyle.opacityLabel": "レイヤーの透明度", + "xpack.canvas.expressionTypes.argTypes.containerStyle.overflowHiddenDropDown": "非表示", + "xpack.canvas.expressionTypes.argTypes.containerStyle.overflowLabel": "オーバーフロー", + "xpack.canvas.expressionTypes.argTypes.containerStyle.overflowVisibleDropDown": "表示", + "xpack.canvas.expressionTypes.argTypes.containerStyle.paddingLabel": "パッド", + "xpack.canvas.expressionTypes.argTypes.containerStyle.radiusLabel": "半径", + "xpack.canvas.expressionTypes.argTypes.containerStyle.styleLabel": "スタイル", + "xpack.canvas.expressionTypes.argTypes.containerStyle.thicknessLabel": "太さ", + "xpack.canvas.expressionTypes.argTypes.containerStyleLabel": "エレメントコンテナーの見た目の調整", + "xpack.canvas.expressionTypes.argTypes.containerStyleTitle": "コンテナースタイル", + "xpack.canvas.expressionTypes.argTypes.fontHelpLabel": "フォント、サイズ、色を設定します", + "xpack.canvas.expressionTypes.argTypes.fontTitle": "テキスト設定", + "xpack.canvas.expressionTypes.argTypes.seriesStyle.barLabel": "バー", + "xpack.canvas.expressionTypes.argTypes.seriesStyle.colorLabel": "色", + "xpack.canvas.expressionTypes.argTypes.seriesStyle.lineLabel": "折れ線", + "xpack.canvas.expressionTypes.argTypes.seriesStyle.noneDropDown": "なし", + "xpack.canvas.expressionTypes.argTypes.seriesStyle.noSeriesTooltip": "データにスタイリングする数列がありません。カラーディメンションを追加してください", + "xpack.canvas.expressionTypes.argTypes.seriesStyle.pointLabel": "ポイント", + "xpack.canvas.expressionTypes.argTypes.seriesStyle.removeAriaLabel": "数列カラーを削除", + "xpack.canvas.expressionTypes.argTypes.seriesStyle.selectSeriesDropDown": "数列を選択します", + "xpack.canvas.expressionTypes.argTypes.seriesStyle.seriesIdentifierLabel": "数列識別子", + "xpack.canvas.expressionTypes.argTypes.seriesStyle.styleLabel": "スタイル", + "xpack.canvas.expressionTypes.argTypes.seriesStyleLabel": "選択された名前付きの数列のスタイルを設定", + "xpack.canvas.expressionTypes.argTypes.seriesStyleTitle": "数列スタイル", + "xpack.canvas.expressionTypes.datasources.esdocs.ascendingDropDown": "昇順", + "xpack.canvas.expressionTypes.datasources.esdocs.descendingDropDown": "降順", + "xpack.canvas.expressionTypes.datasources.esdocs.fieldsLabel": "抽出するフィールドです。Kibana スクリプトフィールドは現在利用できません", + "xpack.canvas.expressionTypes.datasources.esdocs.fieldsTitle": "フィールド", + "xpack.canvas.expressionTypes.datasources.esdocs.fieldsWarningLabel": "このデータソースは、10 個以下のフィールドで最も高い性能を発揮します", + "xpack.canvas.expressionTypes.datasources.esdocs.indexLabel": "インデックス名を入力するか、インデックスパターンを選択してください", + "xpack.canvas.expressionTypes.datasources.esdocs.indexTitle": "インデックス", + "xpack.canvas.expressionTypes.datasources.esdocs.queryLabel": "{lucene} クエリ文字列の構文", + "xpack.canvas.expressionTypes.datasources.esdocs.queryTitle": "クエリ", + "xpack.canvas.expressionTypes.datasources.esdocs.sortFieldLabel": "ドキュメントソートフィールド", + "xpack.canvas.expressionTypes.datasources.esdocs.sortFieldTitle": "ソートフィールド", + "xpack.canvas.expressionTypes.datasources.esdocs.sortOrderLabel": "ドキュメントの並べ替え順", + "xpack.canvas.expressionTypes.datasources.esdocs.sortOrderTitle": "並べ替え順", + "xpack.canvas.expressionTypes.datasources.esdocs.warningTitle": "ご注意ください", + "xpack.canvas.expressionTypes.datasources.esdocsLabel": "Elasticsearch から未加工のドキュメントを読み込みます", + "xpack.canvas.expressionTypes.datasources.esdocsTitle": "Elasticsearch 未加工ドキュメント", + "xpack.canvas.functionForm.contextError": "エラー: {errorMessage}", + "xpack.canvas.functionForm.functionUnknown.unknownArgumentTypeError": "未知の表現タイプ「{expressionType}」", + "xpack.canvas.functions.all.args.conditionHelpText": "確認する条件です。", + "xpack.canvas.functions.allHelpText": "すべての条件が満たされている場合、{BOOLEAN_TRUE} が返されます。{anyFn} もご参照ください。", + "xpack.canvas.functions.alterColumn.args.columnHelpText": "変更する列の名前です。", + "xpack.canvas.functions.alterColumn.args.nameHelpText": "変更後の列名です。名前を変更しない場合は未入力のままにします。", + "xpack.canvas.functions.alterColumn.args.typeHelpText": "列の変換語のタイプです。タイプを変更しない場合は未入力のままにします。", + "xpack.canvas.functions.alterColumn.cannotConvertTypeErrorMessage": "「{type}」に変換できません", + "xpack.canvas.functions.alterColumn.columnNotFoundErrorMessage": "列が見つかりません: 「{column}」", + "xpack.canvas.functions.alterColumnHelpText": "{list}、{end} などのコアタイプを変換し、列名を変更します。{mapColumnFn} および {staticColumnFn} もご参照ください。", + "xpack.canvas.functions.any.args.conditionHelpText": "確認する条件です。", + "xpack.canvas.functions.anyHelpText": "少なくとも 1 つの条件が満たされている場合、{BOOLEAN_TRUE} が返されます。{all_fn} もご参照ください。", + "xpack.canvas.functions.as.args.nameHelpText": "列に付ける名前です", + "xpack.canvas.functions.asHelpText": "単一の値で {DATATABLE} を作成します。{getCellFn} もご参照ください。", + "xpack.canvas.functions.asset.args.id": "読み込むアセットの ID です。", + "xpack.canvas.functions.asset.invalidAssetId": "ID「{assetId}」でアセットを取得できませんでした", + "xpack.canvas.functions.assetHelpText": "引数値を提供するために、Canvas ワークパッドアセットオブジェクトを取得します。通常画像です。", + "xpack.canvas.functions.axisConfig.args.maxHelpText": "軸に表示する最高値です。数字または新世紀からのミリ秒単位の日付、もしくは {ISO8601} 文字列でなければなりません。", + "xpack.canvas.functions.axisConfig.args.minHelpText": "軸に表示する最低値です。数字または新世紀からのミリ秒単位の日付、もしくは {ISO8601} 文字列でなければなりません。", + "xpack.canvas.functions.axisConfig.args.positionHelpText": "軸ラベルの配置です。例: {list} または {end}。", + "xpack.canvas.functions.axisConfig.args.showHelpText": "軸ラベルを表示しますか?", + "xpack.canvas.functions.axisConfig.args.tickSizeHelpText": "目盛り間の増加量です。「数字」軸のみで使用されます", + "xpack.canvas.functions.axisConfig.invalidMaxPositionErrorMessage": "無効なデータ文字列: 「{max}」。「max」は数字、ms での日付、または ISO8601 データ文字列出なければなりません", + "xpack.canvas.functions.axisConfig.invalidMinDateStringErrorMessage": "無効なデータ文字列: 「{min}」。「min」は数字、ms での日付、または ISO8601 データ文字列出なければなりません", + "xpack.canvas.functions.axisConfig.invalidPositionErrorMessage": "無効なポジション: 「{position}」", + "xpack.canvas.functions.axisConfigHelpText": "ビジュアライゼーションの軸を構成します。{plotFn} でのみ使用されます。", + "xpack.canvas.functions.case.args.ifHelpText": "この値は、条件が満たされているかを示し、通常部分式を使用します。両方が入力された場合、{IF_ARG} 引数が {WHEN_ARG} 引数を上書きします。", + "xpack.canvas.functions.case.args.thenHelpText": "条件が満たされた際に戻る値です。", + "xpack.canvas.functions.case.args.whenHelpText": "等しいかを確認するために {CONTEXT} と比較される値です。{IF_ARG} 引数も指定されている場合、{WHEN_ARG} 引数は無視されます。", + "xpack.canvas.functions.caseHelpText": "{switchFn} 関数に渡すため、条件と結果を含めて {case} を作成します。", + "xpack.canvas.functions.clearHelpText": "{CONTEXT} を消去し、{TYPE_NULL} を返します。", + "xpack.canvas.functions.columns.args.excludeHelpText": "{DATATABLE} から削除する列名のコンマ区切りのリストです。", + "xpack.canvas.functions.columns.args.includeHelpText": "{DATATABLE} にキープする列名のコンマ区切りのリストです。", + "xpack.canvas.functions.columnsHelpText": "{DATATABLE} に列を含める、または除外します。両方の引数が指定されている場合、まず初めに除外された列が削除されます。", + "xpack.canvas.functions.compare.args.opHelpText": "比較で使用する演算子です: {eq} (equal to)、{gt} (greater than)、{gte} (greater than or equal to)、{lt} (less than)、{lte} (less than or equal to)、{ne} または {neq} (not equal to)", + "xpack.canvas.functions.compare.args.toHelpText": "{CONTEXT} と比較される値です。", + "xpack.canvas.functions.compare.invalidCompareOperatorErrorMessage": "無効な比較演算子: 「{op}」。{ops} を使用してください", + "xpack.canvas.functions.compareHelpText": "{CONTEXT} を指定された値と比較し、{BOOLEAN_TRUE} または {BOOLEAN_FALSE} を決定します。通常「{ifFn}」または「{caseFn}」と組み合わせて使用されます。{examples} などの基本タイプにのみ使用できます。「{eqFn}」、「{gtFn}」、「{gteFn}」、「{ltFn}」、「{lteFn}」、「{neqFn}」もご参照ください", + "xpack.canvas.functions.containerStyle.args.backgroundColorHelpText": "有効な {CSS} 背景色。", + "xpack.canvas.functions.containerStyle.args.backgroundImageHelpText": "有効な {CSS} 背景画像。", + "xpack.canvas.functions.containerStyle.args.backgroundRepeatHelpText": "有効な {CSS} 背景繰り返し。", + "xpack.canvas.functions.containerStyle.args.backgroundSizeHelpText": "有効な {CSS} 背景サイズ。", + "xpack.canvas.functions.containerStyle.args.borderHelpText": "有効な {CSS} 境界。", + "xpack.canvas.functions.containerStyle.args.borderRadiusHelpText": "角を丸くする際に使用されるピクセル数です。", + "xpack.canvas.functions.containerStyle.args.opacityHelpText": "0 から 1 までの数字で、エレメントの透明度を示します。", + "xpack.canvas.functions.containerStyle.args.overflowHelpText": "有効な {CSS} オーバーフロー。", + "xpack.canvas.functions.containerStyle.args.paddingHelpText": "ピクセル単位のコンテンツの境界からの距離です。", + "xpack.canvas.functions.containerStyle.invalidBackgroundImageErrorMessage": "無効な背景画像。アセットまたは URL を入力してください。", + "xpack.canvas.functions.containerStyleHelpText": "背景、境界、透明度を含む、エレメントのコンテナーのスタイリングに使用されるオブジェクトを使用します。", + "xpack.canvas.functions.contextHelpText": "渡したものをすべて返します。これは、{CONTEXT} を部分式としての関数の引数として使用する際に有効です。", + "xpack.canvas.functions.csv.args.dataHelpText": "使用する {CSV} データです。", + "xpack.canvas.functions.csv.args.delimeterHelpText": "データの区切り文字です。", + "xpack.canvas.functions.csv.args.newlineHelpText": "行の区切り文字です。", + "xpack.canvas.functions.csv.invalidInputCSVErrorMessage": "インプット CSV の解析中にエラーが発生しました。", + "xpack.canvas.functions.csvHelpText": "{CSV} インプットから {DATATABLE} を作成します。", + "xpack.canvas.functions.date.args.formatHelpText": "指定された日付文字列の解析に使用される {MOMENTJS} フォーマットです。{url} を参照。", + "xpack.canvas.functions.date.args.valueHelpText": "新紀元からのミリ秒に解析するオプションの日付文字列です。日付文字列には、有効な {JS} {date} インプット、または {formatArg} 引数を使用して解析する文字列のどちらかが使用できます。{ISO8601} 文字列を使用するか、フォーマットを提供する必要があります。", + "xpack.canvas.functions.date.invalidDateInputErrorMessage": "無効な日付インプット: {date}", + "xpack.canvas.functions.dateHelpText": "現在時刻、または指定された文字列から解析された時刻を、新紀元からのミリ秒で返します。", + "xpack.canvas.functions.demodata.args.typeHelpText": "使用するデモデータセットの名前です。", + "xpack.canvas.functions.demodata.invalidDataSetErrorMessage": "無効なデータセット: 「{arg}」。「{ci}」または「{shirts}」を使用してください", + "xpack.canvas.functions.demodataHelpText": "プロジェクト {ci} の回数とユーザー名、国、実行フェーズを含む模擬データセットです。", + "xpack.canvas.functions.do.args.fnHelpText": "実行する部分式です。この機能は単に元の {CONTEXT} を戻すだけなので、これらの部分式の戻り値はルートパイプラインでは利用できません。", + "xpack.canvas.functions.doHelpText": "複数部分式を実行し、元の {CONTEXT} を戻します。元の {CONTEXT} を変更することなく、アクションまたは副作用を起こす関数の実行に使用します。", + "xpack.canvas.functions.dropdownControl.args.filterColumnHelpText": "フィルタリングする列またはフィールドです。", + "xpack.canvas.functions.dropdownControl.args.filterGroupHelpText": "フィルターのグループ名です。", + "xpack.canvas.functions.dropdownControl.args.valueColumnHelpText": "ドロップダウンコントロールの固有値を抽出する元の列またはフィールドです。", + "xpack.canvas.functions.dropdownControlHelpText": "ドロップダウンフィルターのコントロールエレメントを構成します。", + "xpack.canvas.functions.eq.args.valueHelpText": "{CONTEXT} と比較される値です。", + "xpack.canvas.functions.eqHelpText": "{CONTEXT} が引数と等しいかを戻します。", + "xpack.canvas.functions.escount.args.indexHelpText": "インデックスまたはインデックスパターンです。例: {example}。", + "xpack.canvas.functions.escount.args.queryHelpText": "{LUCENE} クエリ文字列です。", + "xpack.canvas.functions.escountHelpText": "{ELASTICSEARCH} にクエリを実行して、指定されたクエリに一致するヒット数を求めます。", + "xpack.canvas.functions.esdocs.args.countHelpText": "取得するドキュメント数です。パフォーマンスを向上させるには、小さなデータセットを使用します。", + "xpack.canvas.functions.esdocs.args.fieldsHelpText": "フィールドのコンマ区切りのリストです。パフォーマンスを向上させるには、フィールドの数を減らします。", + "xpack.canvas.functions.esdocs.args.indexHelpText": "インデックスまたはインデックスパターンです。例: {example}。", + "xpack.canvas.functions.esdocs.args.metaFieldsHelpText": "メタフィールドのコンマ区切りのリストです。例: {example}。", + "xpack.canvas.functions.esdocs.args.queryHelpText": "{LUCENE} クエリ文字列です。", + "xpack.canvas.functions.esdocs.args.sortHelpText": "{directions} フォーマットの並べ替え方向です。例: {example1} または {example2}。", + "xpack.canvas.functions.esdocsHelpText": "{ELASTICSEARCH} にクエリをかけて生ドキュメントを探します。特に多くの行を必要とする場合、希望のフィールドを指定してください。", + "xpack.canvas.functions.essql.args.countHelpText": "取得するドキュメント数です。パフォーマンスを向上させるには、小さなデータセットを使用します。", + "xpack.canvas.functions.essql.args.queryHelpText": "{ELASTICSEARCH} {SQL} クエリです。", + "xpack.canvas.functions.essql.args.timezoneHelpText": "日付操作の際に使用するタイムゾーンです。有効な {ISO8601} フォーマットと {UTC} は両方を相殺します。", + "xpack.canvas.functions.essqlHelpText": "{ELASTICSEARCH} {SQL} を使用して {ELASTICSEARCH} にクエリを実行します。", + "xpack.canvas.functions.exactly.args.columnHelpText": "フィルタリングする列またはフィールドです。", + "xpack.canvas.functions.exactly.args.filterGroupHelpText": "フィルターのグループ名です。", + "xpack.canvas.functions.exactly.args.valueHelpText": "ホワイトスペースと大文字・小文字を含め、正確に一致させる値です。", + "xpack.canvas.functions.exactlyHelpText": "特定の列をピッタリと正確な値に一致させるフィルターを作成します。", + "xpack.canvas.functions.filterrows.args.fnHelpText": "{DATATABLE} の各行に渡す表現式です。表現式は {TYPE_BOOLEAN} に戻ります。{BOOLEAN_TRUE} 値は行を維持し、{BOOLEAN_FALSE} 値は行を削除します。", + "xpack.canvas.functions.filterrowsHelpText": "{DATATABLE} の行を部分式の戻り値に基づきフィルタリングします。", + "xpack.canvas.functions.filters.args.group": "使用するフィルターグループの名前です。", + "xpack.canvas.functions.filters.args.ungrouped": "フィルターグループに属するフィルターを除外しますか?", + "xpack.canvas.functions.filtersHelpText": "ワークパッドのエレメントフィルターを他 (通常データソース) で使用できるように集約します。", + "xpack.canvas.functions.formatdate.args.formatHelpText": "{MOMENTJS} フォーマットです。例: {example}。{url} を参照。", + "xpack.canvas.functions.formatdateHelpText": "{MOMENTJS} を使って {ISO8601} 日付文字列、または新世紀からのミリ秒での日付をフォーマットします。{url} を参照。", + "xpack.canvas.functions.formatnumber.args.formatHelpText": "{NUMERALJS} 文字列のフォーマットです。例: {example1} または {example2}。{url} を参照。", + "xpack.canvas.functions.formatnumberHelpText": "{NUMERALJS} を使って数字をフォーマットされた数字文字列にフォーマットします。{url} を参照。", + "xpack.canvas.functions.getCell.args.columnHelpText": "値を取得する元の列の名前です。この値は入力されていないと、初めの列から取得されます。", + "xpack.canvas.functions.getCell.args.rowHelpText": "行番号で、0 から開始します。", + "xpack.canvas.functions.getCell.columnNotFoundErrorMessage": "列が見つかりません: 「{column}」", + "xpack.canvas.functions.getCell.rowNotFoundErrorMessage": "行が見つかりません: 「{row}」", + "xpack.canvas.functions.getCellHelpText": "{DATATABLE} から単一のセルを取得します。", + "xpack.canvas.functions.gt.args.valueHelpText": "{CONTEXT} と比較される値です。", + "xpack.canvas.functions.gte.args.valueHelpText": "{CONTEXT} と比較される値です。", + "xpack.canvas.functions.gteHelpText": "{CONTEXT} が引数以上かを戻します。", + "xpack.canvas.functions.gtHelpText": "{CONTEXT} が引数よりも大きいかを戻します。", + "xpack.canvas.functions.head.args.countHelpText": "{DATATABLE} の初めから取得する行数です。", + "xpack.canvas.functions.headHelpText": "{DATATABLE} から初めの {n} 行を取得します。{tailFn} もご参照ください", + "xpack.canvas.functions.if.args.conditionHelpText": "{BOOLEAN_TRUE} または {BOOLEAN_FALSE} で、条件が満たされているかを示し、通常部分式から戻されます。指定されていない場合、元の {CONTEXT} が戻されます。", + "xpack.canvas.functions.if.args.elseHelpText": "条件が {BOOLEAN_FALSE} の場合の戻り値です。指定されておらず、条件が満たされていない場合は、元の {CONTEXT} が戻されます。", + "xpack.canvas.functions.if.args.thenHelpText": "条件が {BOOLEAN_TRUE} の場合の戻り値です。指定されておらず、条件が満たされている場合は、元の {CONTEXT} が戻されます。", + "xpack.canvas.functions.ifHelpText": "条件付きロジックを実行します", + "xpack.canvas.functions.image.args.dataurlHelpText": "画像の {https} {URL} または {BASE64} データ {URL} です。", + "xpack.canvas.functions.image.args.modeHelpText": "{contain} はサイズに合わせて拡大・縮小して画像全体を表示し、{cover} はコンテナーを画像で埋め、必要に応じて両端や下をクロップします。{stretch} は画像の高さと幅をコンテナーの 100% になるよう変更します", + "xpack.canvas.functions.image.invalidImageModeErrorMessage": "「mode」は「{contain}」、「{cover}」、または「{stretch}」でなければなりません", + "xpack.canvas.functions.imageHelpText": "画像を表示します。画像アセットを {BASE64} データ {URL} として提供するか、部分式で渡します。", + "xpack.canvas.functions.joinRows.args.columnHelpText": "値を結合する元になる列", + "xpack.canvas.functions.joinRows.args.distinctHelpText": "重複する値を削除しますか?", + "xpack.canvas.functions.joinRows.args.quoteHelpText": "値を囲む引用文字", + "xpack.canvas.functions.joinRows.args.separatorHelpText": "行の値の間で使用する区切り文字", + "xpack.canvas.functions.joinRows.columnNotFoundErrorMessage": "列が見つかりません。'{column}'", + "xpack.canvas.functions.joinRowsHelpText": "データベースの行の値を文字列に結合", + "xpack.canvas.functions.locationHelpText": "ブラウザの {geolocationAPI} を使用して現在位置を取得します。パフォーマンスに違いはありますが、比較的正確です。{url} を参照。", + "xpack.canvas.functions.lt.args.valueHelpText": "{CONTEXT} と比較される値です。", + "xpack.canvas.functions.lte.args.valueHelpText": "{CONTEXT} と比較される値です。", + "xpack.canvas.functions.lteHelpText": "{CONTEXT} が引数以下かを戻します。", + "xpack.canvas.functions.ltHelpText": "{CONTEXT} が引数よりも小さいかを戻します。", + "xpack.canvas.functions.mapColumn.args.expressionHelpText": "単一行 {DATATABLE} として各行に渡される {CANVAS} 表現です。", + "xpack.canvas.functions.mapColumn.args.nameHelpText": "結果の列の名前です。", + "xpack.canvas.functions.mapColumnHelpText": "他の列の結果として計算された列を追加します。引数が提供された場合のみ変更が加えられます。{mapColumnFn} と {staticColumnFn} もご参照ください。", + "xpack.canvas.functions.markdown.args.contentHelpText": "{MARKDOWN} を含むテキストの文字列です。連結させるには、{stringFn} 関数を複数回渡します。", + "xpack.canvas.functions.markdown.args.fontHelpText": "コンテンツの {CSS} フォントプロパティです。例: {fontFamily} または {fontWeight}。", + "xpack.canvas.functions.markdownHelpText": "{MARKDOWN} テキストをレンダリングするエレメントを追加します。ヒント:単一の数字、メトリック、テキストの段落には {markdownFn} 関数を使います。", + "xpack.canvas.functions.math.args.expressionHelpText": "評価された {TINYMATH} 表現です。{TINYMATH_URL} をご覧ください。", + "xpack.canvas.functions.math.emptyDatatableErrorMessage": "空のデータベース", + "xpack.canvas.functions.math.emptyExpressionErrorMessage": "空の表現", + "xpack.canvas.functions.math.executionFailedErrorMessage": "数式の実行に失敗しました。列名を確認してください", + "xpack.canvas.functions.math.tooManyResultsErrorMessage": "表現は 1 つの数字を返す必要があります。表現を {mean} または {sum} で囲んでみてください", + "xpack.canvas.functions.mathHelpText": "数字または {DATATABLE} を {CONTEXT} として使用して {TINYMATH} 数式を解釈します。{DATATABLE} 列は列名で表示されます。{CONTEXT} が数字の場合は、{value} と表示されます。", + "xpack.canvas.functions.metric.args.labelFontHelpText": "ラベルの {CSS} フォントプロパティです。例: {FONT_FAMILY} または {FONT_WEIGHT}。", + "xpack.canvas.functions.metric.args.labelHelpText": "メトリックを説明するテキストです。", + "xpack.canvas.functions.metric.args.metricFontHelpText": "メトリックの {CSS} フォントプロパティです。例: {FONT_FAMILY} または {FONT_WEIGHT}。", + "xpack.canvas.functions.metric.args.metricFormatHelpText": "{NUMERALJS} 文字列のフォーマットです。例: {example1} または {example2}。{url} を参照。", + "xpack.canvas.functions.metricHelpText": "ラベルの上に数字を表示します。", + "xpack.canvas.functions.neq.args.valueHelpText": "{CONTEXT} と比較される値です。", + "xpack.canvas.functions.neqHelpText": "{CONTEXT} が引数と等しくないかを戻します。", + "xpack.canvas.functions.palette.args.colorHelpText": "パレットの色です。{html} カラー名、{hex}、{hsl}、{hsla}、{rgb}、または {rgba} を受け付けます。", + "xpack.canvas.functions.palette.args.gradientHelpText": "サポートされている場合グラデーションパレットを作成しますか?", + "xpack.canvas.functions.palette.args.reverseHelpText": "パレットを反転させますか?", + "xpack.canvas.functions.paletteHelpText": "カラーパレットを作成します。", + "xpack.canvas.functions.pie.args.fontHelpText": "表の {CSS} フォントプロパティです。例: {FONT_FAMILY} または {FONT_WEIGHT}。", + "xpack.canvas.functions.pie.args.holeHelpText": "円グラフに穴をあけます、0~100 で円グラフの半径のパーセンテージを指定します。", + "xpack.canvas.functions.pie.args.labelRadiusHelpText": "ラベルの円の半径として使用する、コンテナーの面積のパーセンテージです。", + "xpack.canvas.functions.pie.args.labelsHelpText": "円グラフのラベルを表示しますか?", + "xpack.canvas.functions.pie.args.legendHelpText": "凡例の配置です。例: {positions}、または {BOOLEAN_FALSE}。{BOOLEAN_FALSE} の場合、凡例は非表示になります。", + "xpack.canvas.functions.pie.args.paletteHelpText": "この円グラフに使用されている色を説明する {palette} オブジェクトです。{paletteFn} をご覧ください。", + "xpack.canvas.functions.pie.args.radiusHelpText": "利用可能なスペースのパーセンテージで示された円グラフの半径です (0 から 1 の間)。半径を自動的に設定するには {auto} を使用します。", + "xpack.canvas.functions.pie.args.seriesStyleHelpText": "特定の数列のスタイルです", + "xpack.canvas.functions.pie.args.tiltHelpText": "「1」 が完全に垂直、「0」が完全に水平を表す傾きのパーセンテージです。", + "xpack.canvas.functions.pieHelpText": "円グラフのエレメントを構成します。", + "xpack.canvas.functions.plot.args.defaultStyleHelpText": "すべての数列に使用するデフォルトのスタイルです。", + "xpack.canvas.functions.plot.args.fontHelpText": "表の {CSS} フォントプロパティです。例: {FONT_FAMILY} または {FONT_WEIGHT}。", + "xpack.canvas.functions.plot.args.legendHelpText": "凡例の配置です。例: {positions}、または {BOOLEAN_FALSE}。{BOOLEAN_FALSE} の場合、凡例は非表示になります。", + "xpack.canvas.functions.plot.args.paletteHelpText": "このチャートに使用される色を説明する {palette} オブジェクトです。{paletteFn} をご覧ください。", + "xpack.canvas.functions.plot.args.seriesStyleHelpText": "特定の数列のスタイルです", + "xpack.canvas.functions.plot.args.xaxisHelpText": "軸の構成です。{BOOLEAN_FALSE} の場合、軸は非表示になります。", + "xpack.canvas.functions.plot.args.yaxisHelpText": "軸の構成です。{BOOLEAN_FALSE} の場合、軸は非表示になります。", + "xpack.canvas.functions.plotHelpText": "チャートのエレメントを構成します", + "xpack.canvas.functions.ply.args.byHelpText": "{DATATABLE} を細分する列です。", + "xpack.canvas.functions.ply.args.expressionHelpText": "それぞれの結果の {DATATABLE} を渡す先の表現です。アドバイス:表現は {DATATABLE} を返す必要があります。直定数を {DATATABLE} にするには {asFn} を使用します。複数表現が同じ行数を戻す必要があります。異なる行数を戻す必要がある場合は、{plyFn} の別のインスタンスにパイピングします。複数表現が同じ名前の行を戻した場合、最後の行が優先されます。", + "xpack.canvas.functions.ply.columnNotFoundErrorMessage": "列が見つかりません: 「{by}」", + "xpack.canvas.functions.ply.rowCountMismatchErrorMessage": "すべての表現が同じ行数を返す必要があります。", + "xpack.canvas.functions.plyHelpText": "{DATATABLE} を指定された列の固有値で細分し、表現にその結果となる表を渡し、各表現のアウトプットを結合します。", + "xpack.canvas.functions.pointseries.args.colorHelpText": "マークの色を決めるのに使用する表現です。", + "xpack.canvas.functions.pointseries.args.sizeHelpText": "マークのサイズです。サポートされているエレメントのみに適用されます。", + "xpack.canvas.functions.pointseries.args.textHelpText": "マークに表示するテキストです。サポートされているエレメントのみに適用されます。", + "xpack.canvas.functions.pointseries.args.xHelpText": "X 軸の値です。", + "xpack.canvas.functions.pointseries.args.yHelpText": "Y 軸の値です。", + "xpack.canvas.functions.pointseries.unwrappedExpressionErrorMessage": "表現は {fn} などの関数で囲む必要があります", + "xpack.canvas.functions.pointseriesHelpText": "{DATATABLE} を点の配列モデルに変換します。現在 {TINYMATH} 表現でディメンションのメジャーを区別します。{TINYMATH_URL} をご覧ください。引数に {TINYMATH} 表現が入力された場合、その引数をメジャーとして使用し、そうでない場合はディメンションになります。ディメンションを組み合わせて固有のキーを作成します。その後メジャーはそれらのキーで、指定された {TINYMATH} 関数を使用して複製されます。", + "xpack.canvas.functions.progress.args.barColorHelpText": "背景バーの色です。", + "xpack.canvas.functions.progress.args.barWeightHelpText": "背景バーの太さです。", + "xpack.canvas.functions.progress.args.fontHelpText": "ラベルの {CSS} フォントプロパティです。例: {FONT_FAMILY} または {FONT_WEIGHT}。", + "xpack.canvas.functions.progress.args.labelHelpText": "ラベルの表示・非表示を切り替えるには、{BOOLEAN_TRUE} または {BOOLEAN_FALSE} を使用します。また、ラベルとして表示する文字列を入力することもできます。", + "xpack.canvas.functions.progress.args.maxHelpText": "進捗エレメントの最高値です。", + "xpack.canvas.functions.progress.args.shapeHelpText": "{list} または {end} を選択します。", + "xpack.canvas.functions.progress.args.valueColorHelpText": "進捗バーの色です。", + "xpack.canvas.functions.progress.args.valueWeightHelpText": "進捗バーの太さです。", + "xpack.canvas.functions.progress.invalidMaxValueErrorMessage": "無効な {arg} 値: 「{max, number}」。「{arg}」は 0 より大きい必要があります", + "xpack.canvas.functions.progress.invalidValueErrorMessage": "無効な値: 「{value, number}」。値は 0 と {max, number} の間でなければなりません", + "xpack.canvas.functions.progressHelpText": "進捗エレメントを構成します。", + "xpack.canvas.functions.render.args.asHelpText": "レンダリングに使用するエレメントタイプです。代わりに {plotFn} や {shapeFn} などの特殊な関数を使用するほうがいいでしょう。", + "xpack.canvas.functions.render.args.containerStyleHelpText": "背景、境界、透明度を含む、コンテナーのスタイルです。", + "xpack.canvas.functions.render.args.cssHelpText": "このエレメントの対象となるカスタム {CSS} のブロックです。", + "xpack.canvas.functions.renderHelpText": "{CONTEXT} を特定のエレメントとしてレンダリングし、背景と境界のスタイルなどのエレメントレベルのオプションを設定します。", + "xpack.canvas.functions.repeatImage.args.emptyImageHelpText": "{CONTEXT} と {maxArg} パラメーターの間をこの画像で埋めます。画像アセットは {BASE64} データ {URL} として提供するか、部分式で渡します。", + "xpack.canvas.functions.repeatImage.args.imageHelpText": "繰り返す画像です。画像アセットを {BASE64} データ {URL} として提供するか、部分式で渡します。", + "xpack.canvas.functions.repeatImage.args.maxHelpText": "画像が繰り返される最高回数です。", + "xpack.canvas.functions.repeatImage.args.sizeHelpText": "画像の高さまたは幅のピクセル単位での最高値です。画像が縦長の場合、この関数は高さを制限します。", + "xpack.canvas.functions.repeatImageHelpText": "繰り返し画像エレメントを構成します。", + "xpack.canvas.functions.replace.args.flagsHelpText": "フラグを指定します。{url} を参照。", + "xpack.canvas.functions.replace.args.patternHelpText": "{JS} 正規表現のテキストまたはパターンです。例: {example}。ここではキャプチャグループを使用できます。", + "xpack.canvas.functions.replace.args.replacementHelpText": "文字列の一致する部分の代わりです。キャプチャグループはノードによってアクセス可能です。例: {example}。", + "xpack.canvas.functions.replaceImageHelpText": "正規表現で文字列の一部を置き換えます。", + "xpack.canvas.functions.revealImage.args.emptyImageHelpText": "表示される背景画像です。画像アセットは {BASE64} データ {URL} として提供するか、部分式で渡します。", + "xpack.canvas.functions.revealImage.args.imageHelpText": "表示する画像です。画像アセットを {BASE64} データ {URL} として提供するか、部分式で渡します。", + "xpack.canvas.functions.revealImage.args.originHelpText": "画像で埋め始める位置です。例: {list} または {end}。", + "xpack.canvas.functions.revealImage.invalidPercentErrorMessage": "無効な値: 「{percent}」.パーセンテージは 0 と 1 の間でなければなりません ", + "xpack.canvas.functions.revealImageHelpText": "画像表示エレメントを構成します。", + "xpack.canvas.functions.rounddate.args.formatHelpText": "バケットに使用する {MOMENTJS} フォーマットです。たとえば、{example} はそれぞれの日付を月単位に繰り上げ・繰り下げします。{url} を参照。", + "xpack.canvas.functions.rounddateHelpText": "新世紀からのミリ秒の繰り上げ・繰り下げに {MOMENTJS} を使用し、新世紀からのミリ秒を戻します。", + "xpack.canvas.functions.rowCountHelpText": "行数を戻します。{plyFn} と組み合わせて、固有の列値の数、または固有の列値の組み合わせを求めます。", + "xpack.canvas.functions.savedMapHelpText": "保存されたマップオブジェクトの埋め込み可能なオブジェクトを返します", + "xpack.canvas.functions.savedSearchHelpText": "保存検索オブジェクトの埋め込み可能なオブジェクトを返します", + "xpack.canvas.functions.savedVisualizationHelpText": "保存されたビジュアライゼーションオブジェクトの埋め込み可能なオブジェクトを返します", + "xpack.canvas.functions.seriesStyle.args.barsHelpText": "バーの幅です。", + "xpack.canvas.functions.seriesStyle.args.colorHelpText": "ラインカラーです。", + "xpack.canvas.functions.seriesStyle.args.fillHelpText": "点を埋めますか?", + "xpack.canvas.functions.seriesStyle.args.horizontalBarsHelpText": "グラフの棒の方向を水平に設定します。", + "xpack.canvas.functions.seriesStyle.args.labelHelpText": "スタイルを適用する数列の名前です。", + "xpack.canvas.functions.seriesStyle.args.linesHelpText": "線の幅です。", + "xpack.canvas.functions.seriesStyle.args.pointsHelpText": "線上の点のサイズです", + "xpack.canvas.functions.seriesStyle.args.stackHelpText": "数列をスタックするかを指定します。数字はスタック ID です。同じスタック ID の数列は一緒にスタックされます。", + "xpack.canvas.functions.seriesStyleHelpText": "チャートの数列のプロパティの説明に使用されるオブジェクトを作成します。グラフ関数内では {plotFn} または {pieFn} のような {seriesStyleFn} を使用します。", + "xpack.canvas.functions.shape.args.borderHelpText": "図形の外郭の {SVG} カラーです。", + "xpack.canvas.functions.shape.args.borderWidthHelpText": "境界の太さです。", + "xpack.canvas.functions.shape.args.fillHelpText": "図形を塗りつぶす {SVG} カラーです。", + "xpack.canvas.functions.shape.args.maintainAspectHelpText": "図形の元の横縦比を維持しますか?", + "xpack.canvas.functions.shape.args.shapeHelpText": "図形を選択します。", + "xpack.canvas.functions.shapeHelpText": "図形を作成します。", + "xpack.canvas.functions.sort.args.byHelpText": "並べ替えの基準となる列です。指定されていない場合、「{DATATABLE}」は初めの列で並べられます。", + "xpack.canvas.functions.sort.args.reverseHelpText": "並び順を反転させます。指定されていない場合、「{DATATABLE}」は昇順で並べられます。", + "xpack.canvas.functions.sortHelpText": "データ表を指定された列で並べ替えます。", + "xpack.canvas.functions.staticColumn.args.nameHelpText": "新しい列の名前です。", + "xpack.canvas.functions.staticColumn.args.valueHelpText": "新しい列の各行に挿入する値です。ヒント: 部分式を使用して他の列を静的値にロールアップします。", + "xpack.canvas.functions.staticColumnHelpText": "すべての行に同じ静的値の列を追加します。{alterColumnFn} および {mapColumnFn} もご参照ください。", + "xpack.canvas.functions.string.args.valueHelpText": "1 つの文字列に結合する値です。必要な場所にスペースを入れてください。", + "xpack.canvas.functions.stringHelpText": "すべての引数を 1 つの文字列に連結させます。", + "xpack.canvas.functions.switch.args.caseHelpText": "確認する条件です", + "xpack.canvas.functions.switch.args.defaultHelpText": "条件が一切満たされていないときに戻される値です。指定されておらず、条件が一切満たされている場合は、元の {CONTEXT} が戻されます。", + "xpack.canvas.functions.switchHelpText": "複数条件の条件付きロジックを実行します。{case} を作成し {switchFn} 関数に渡す {caseFn} もご覧ください。", + "xpack.canvas.functions.table.args.fontHelpText": "表のコンテンツの {CSS} フォントプロパティです。例: {FONT_FAMILY} または {FONT_WEIGHT}。", + "xpack.canvas.functions.table.args.paginateHelpText": "ページ付けのコントロールを表示しますか?{BOOLEAN_FALSE} の場合、初めのページだけが表示されます。", + "xpack.canvas.functions.table.args.perPageHelpText": "各ページに表示される行数です。", + "xpack.canvas.functions.table.args.showHeaderHelpText": "各列のタイトルと共にヘッダー行を表示するかしないかです。", + "xpack.canvas.functions.tableHelpText": "表エレメントを構成します", + "xpack.canvas.functions.tail.args.countHelpText": "{DATATABLE} の終わりから取得する行数です。", + "xpack.canvas.functions.tailHelpText": "{DATATABLE} の終わりから N 行を取得します。{headFn} もご参照ください。", + "xpack.canvas.functions.timefilter.args.columnHelpText": "フィルタリングする列またはフィールドです。", + "xpack.canvas.functions.timefilter.args.filterGroupHelpText": "フィルターのグループ名です。", + "xpack.canvas.functions.timefilter.args.fromHelpText": "範囲の始まりです。{ISO8601} または {ELASTICSEARCH} {DATEMATH} のフォーマットを使用します", + "xpack.canvas.functions.timefilter.args.toHelpText": "範囲の終わりです。{ISO8601} または {ELASTICSEARCH} {DATEMATH} のフォーマットを使用します", + "xpack.canvas.functions.timefilter.invalidStringErrorMessage": "無効な日付/時刻文字列: 「{str}」", + "xpack.canvas.functions.timefilterControl.args.columnHelpText": "フィルタリングする列またはフィールドです。", + "xpack.canvas.functions.timefilterControl.args.compactHelpText": "時間フィルターを、ポップオーバーを実行するボタンとして表示します。", + "xpack.canvas.functions.timefilterControlHelpText": "時間フィルターのコントロールエレメントを構成します。", + "xpack.canvas.functions.timefilterHelpText": "ソースのクエリ用の時間フィルターを作成します。", + "xpack.canvas.functions.timelion.args.from": "時間範囲の始めの {ELASTICSEARCH} {DATEMATH} 文字列です。", + "xpack.canvas.functions.timelion.args.interval": "時系列のバケット間隔です。", + "xpack.canvas.functions.timelion.args.query": "Timelion クエリ", + "xpack.canvas.functions.timelion.args.timezone": "時間範囲のタイムゾーンです。{MOMENTJS_TIMEZONE_URL} をご覧ください。", + "xpack.canvas.functions.timelion.args.to": "時間範囲の終わりの {ELASTICSEARCH} {DATEMATH} 文字列です。", + "xpack.canvas.functions.timelionHelpText": "多くのソースから単独または複数の時系列を抽出するために、Timelion を使用します。", + "xpack.canvas.functions.to.args.type": "表現言語の既知のデータ型です。", + "xpack.canvas.functions.to.missingType": "型キャストを指定する必要があります", + "xpack.canvas.functions.toHelpText": "{CONTEXT} の型を指定された型に明確にキャストします。", + "xpack.canvas.functions.urlparam.args.defaultHelpText": "{URL} パラメーターが指定されていないときに戻される文字列です。", + "xpack.canvas.functions.urlparam.args.paramHelpText": "取得する {URL} ハッシュパラメーターです。", + "xpack.canvas.functions.urlparamHelpText": "表現で使用する {URL} パラメーターを取得します。{urlparamFn} 関数は常に {TYPE_STRING} を戻します。たとえば、値 {value} を {URL} {example} のパラメーター {myVar} から取得できます)。", + "xpack.canvas.groupSettings.multipleElementsActionsDescription": "個々の設定を編集するには、これらのエレメントの選択を解除し、 ({gKey}) を押してグループ化するか、この選択をワークパッド全体で再利用できるように新規エレメントとして保存します。", + "xpack.canvas.groupSettings.multipleElementsDescription": "現在複数エレメントが選択されています。", + "xpack.canvas.groupSettings.saveGroupDescription": "ワークパッド全体で再利用できるように、このグループを新規エレメントとして保存します。", + "xpack.canvas.groupSettings.ungroupDescription": "個々のエレメントの設定を編集できるように、({uKey}) のグループを解除します。", + "xpack.canvas.helpMenu.description": "{CANVAS} に関する情報", + "xpack.canvas.helpMenu.documentationLinkLabel": "{CANVAS} ドキュメント", + "xpack.canvas.helpMenu.keyboardShortcutsLinkLabel": "キーボードショートカット", + "xpack.canvas.keyboardShortcuts.bringFowardShortcutHelpText": "表面に移動", + "xpack.canvas.keyboardShortcuts.bringToFrontShortcutHelpText": "前に移動", + "xpack.canvas.keyboardShortcuts.cloneShortcutHelpText": "クローンを作成", + "xpack.canvas.keyboardShortcuts.copyShortcutHelpText": "コピー", + "xpack.canvas.keyboardShortcuts.cutShortcutHelpText": "切り取り", + "xpack.canvas.keyboardShortcuts.deleteShortcutHelpText": "削除", + "xpack.canvas.keyboardShortcuts.editingShortcutHelpText": "編集モードを切り替えます", + "xpack.canvas.keyboardShortcuts.fullscreenExitShortcutHelpText": "プレゼンテーションモードを終了します", + "xpack.canvas.keyboardShortcuts.fullscreenShortcutHelpText": "プレゼンテーションモードを開始します", + "xpack.canvas.keyboardShortcuts.gridShortcutHelpText": "グリッドを表示します", + "xpack.canvas.keyboardShortcuts.groupShortcutHelpText": "グループ", + "xpack.canvas.keyboardShortcuts.ignoreSnapShortcutHelpText": "スナップせずに移動、サイズ変更、回転します", + "xpack.canvas.keyboardShortcuts.multiselectShortcutHelpText": "複数エレメントを選択します", + "xpack.canvas.keyboardShortcuts.namespace.editorDisplayName": "エディターコントロール", + "xpack.canvas.keyboardShortcuts.namespace.elementDisplayName": "エレメントコントロール", + "xpack.canvas.keyboardShortcuts.namespace.expressionDisplayName": "表現コントロール", + "xpack.canvas.keyboardShortcuts.namespace.presentationDisplayName": "プレゼンテーションコントロール", + "xpack.canvas.keyboardShortcuts.nextShortcutHelpText": "次のページに移動します", + "xpack.canvas.keyboardShortcuts.nudgeDownShortcutHelpText": "{ELEMENT_NUDGE_OFFSET}px 下に移動させます", + "xpack.canvas.keyboardShortcuts.nudgeLeftShortcutHelpText": "{ELEMENT_NUDGE_OFFSET}px 左に移動させます", + "xpack.canvas.keyboardShortcuts.nudgeRightShortcutHelpText": "{ELEMENT_NUDGE_OFFSET}px 右に移動させます", + "xpack.canvas.keyboardShortcuts.nudgeUpShortcutHelpText": "{ELEMENT_NUDGE_OFFSET}px 上に移動させます", + "xpack.canvas.keyboardShortcuts.pageCycleToggleShortcutHelpText": "ページ周期を切り替えます", + "xpack.canvas.keyboardShortcuts.pasteShortcutHelpText": "貼り付け", + "xpack.canvas.keyboardShortcuts.prevShortcutHelpText": "前のページに移動します", + "xpack.canvas.keyboardShortcuts.redoShortcutHelpText": "最後の操作をやり直します", + "xpack.canvas.keyboardShortcuts.resizeFromCenterShortcutHelpText": "中央からサイズ変更します", + "xpack.canvas.keyboardShortcuts.runShortcutHelpText": "表現全体を実行します", + "xpack.canvas.keyboardShortcuts.selectBehindShortcutHelpText": "下のエレメントを選択します", + "xpack.canvas.keyboardShortcuts.sendBackwardShortcutHelpText": "後方に送ります", + "xpack.canvas.keyboardShortcuts.sendToBackShortcutHelpText": "後ろに送ります", + "xpack.canvas.keyboardShortcuts.shiftDownShortcutHelpText": "{ELEMENT_SHIFT_OFFSET}px 下に移動させます", + "xpack.canvas.keyboardShortcuts.shiftLeftShortcutHelpText": "{ELEMENT_SHIFT_OFFSET}px 左に移動させます", + "xpack.canvas.keyboardShortcuts.shiftRightShortcutHelpText": "{ELEMENT_SHIFT_OFFSET}px 右に移動させます", + "xpack.canvas.keyboardShortcuts.shiftUpShortcutHelpText": "{ELEMENT_SHIFT_OFFSET}px 上に移動させます", + "xpack.canvas.keyboardShortcuts.ShortcutHelpText": "ワークパッドを更新します", + "xpack.canvas.keyboardShortcuts.undoShortcutHelpText": "最後の操作を元に戻します", + "xpack.canvas.keyboardShortcuts.ungroupShortcutHelpText": "グループ解除", + "xpack.canvas.keyboardShortcuts.zoomInShortcutHelpText": "ズームイン", + "xpack.canvas.keyboardShortcuts.zoomOutShortcutHelpText": "ズームアウト", + "xpack.canvas.keyboardShortcuts.zoomResetShortcutHelpText": "ズームを 100% にリセットします", + "xpack.canvas.keyboardShortcutsDoc.flyout.closeButtonAriaLabel": "キーボードショートカットリファレンスを作成", + "xpack.canvas.keyboardShortcutsDoc.flyoutHeaderTitle": "キーボードショートカット", + "xpack.canvas.keyboardShortcutsDoc.shortcutListSeparator": "または", + "xpack.canvas.link.errorMessage": "リンクエラー: {message}", + "xpack.canvas.pageConfig.backgroundColorDescription": "HEX、RGB、また HTML 色名が使用できます", + "xpack.canvas.pageConfig.backgroundColorLabel": "背景色", + "xpack.canvas.pageConfig.title": "ページ", + "xpack.canvas.pageConfig.transitionLabel": "トランジション", + "xpack.canvas.pageConfig.transitionPreviewLabel": "プレビュー", + "xpack.canvas.pageConfig.transitions.noneDropDownOptionLabel": "なし", + "xpack.canvas.pageManager.pageNumberAriaLabel": "ページ {pageNumber} を読み込む", + "xpack.canvas.pagePreviewPageControls.clonePageAriaLabel": "ページのクローンを作成", + "xpack.canvas.pagePreviewPageControls.clonePageTooltip": "クローンを作成", + "xpack.canvas.pagePreviewPageControls.deletePageAriaLabel": "ページを削除", + "xpack.canvas.pagePreviewPageControls.deletePageTooltip": "削除", + "xpack.canvas.renderer.advancedFilter.applyButtonLabel": "適用", + "xpack.canvas.renderer.advancedFilter.displayName": "高度なフィルター", + "xpack.canvas.renderer.advancedFilter.helpDescription": "Canvas フィルター表現をレンダリングします。", + "xpack.canvas.renderer.advancedFilter.inputPlaceholder": "フィルター表現を入力", + "xpack.canvas.renderer.debug.displayName": "デバッグ", + "xpack.canvas.renderer.debug.helpDescription": "デバッグアウトプットをフォーマットされた {JSON} としてレンダリングします", + "xpack.canvas.renderer.dropdownFilter.displayName": "ドロップダウンフィルター", + "xpack.canvas.renderer.dropdownFilter.helpDescription": "「{exactly}」フィルターの値を選択できるドロップダウンです", + "xpack.canvas.renderer.dropdownFilter.matchAllOptionLabel": "すべて", + "xpack.canvas.renderer.embeddable.displayName": "埋め込み可能", + "xpack.canvas.renderer.embeddable.helpDescription": "Kibana の他の部分から埋め込み可能な保存済みオブジェクトをレンダリングします", + "xpack.canvas.renderer.error.displayName": "エラー情報", + "xpack.canvas.renderer.error.helpDescription": "エラーデータをユーザーにわかるようにレンダリングします", + "xpack.canvas.renderer.image.displayName": "画像", + "xpack.canvas.renderer.image.helpDescription": "画像をレンダリングします", + "xpack.canvas.renderer.markdown.displayName": "マークダウン", + "xpack.canvas.renderer.markdown.helpDescription": "{MARKDOWN} インプットで {HTML} をレンダリングします", + "xpack.canvas.renderer.metric.displayName": "メトリック", + "xpack.canvas.renderer.metric.helpDescription": "ラベルの上に数字をレンダリングします", + "xpack.canvas.renderer.pie.displayName": "円グラフ", + "xpack.canvas.renderer.pie.helpDescription": "データから円グラフをレンダリングします", + "xpack.canvas.renderer.plot.displayName": "座標プロット", + "xpack.canvas.renderer.plot.helpDescription": "データから XY プロットをレンダリングします", + "xpack.canvas.renderer.progress.displayName": "進捗インジケーター", + "xpack.canvas.renderer.progress.helpDescription": "エレメントのパーセンテージを示す進捗インジケーターをレンダリングします", + "xpack.canvas.renderer.repeatImage.displayName": "画像の繰り返し", + "xpack.canvas.renderer.repeatImage.helpDescription": "画像を指定回数繰り返し表示します", + "xpack.canvas.renderer.revealImage.displayName": "画像の部分表示", + "xpack.canvas.renderer.revealImage.helpDescription": "カスタムゲージスタイルチャートを作成するため、画像のパーセンテージを表示します", + "xpack.canvas.renderer.shape.displayName": "図形", + "xpack.canvas.renderer.shape.helpDescription": "基本的な図形をレンダリングします", + "xpack.canvas.renderer.table.displayName": "データテーブル", + "xpack.canvas.renderer.table.helpDescription": "表形式データを {HTML} としてレンダリングします", + "xpack.canvas.renderer.text.displayName": "プレインテキスト", + "xpack.canvas.renderer.text.helpDescription": "アウトプットをプレインテキストとしてレンダリングします", + "xpack.canvas.renderer.timeFilter.displayName": "時間フィルター", + "xpack.canvas.renderer.timeFilter.helpDescription": "時間枠を設定してデータをフィルタリングします", + "xpack.canvas.shareWebsiteFlyout.description": "外部 Web サイトでこのワークパッドの不動バージョンを共有するには、これらの手順に従ってください。現在のワークパッドのビジュアルスナップショットになり、ライブデータにはアクセスできません。", + "xpack.canvas.shareWebsiteFlyout.flyoutCalloutDescription": "共有するには、このワークパッド、{CANVAS} シェアラブルワークパッドランタイム、サンプル {HTML} ファイルを含む {link} を使用します。", + "xpack.canvas.shareWebsiteFlyout.flyoutTitle": "Web サイトで共有", + "xpack.canvas.shareWebsiteFlyout.runtimeStep.description": "共有可能なワークパッドをレンダリングするには、{CANVAS} シェアラブルワークパッドランタイムも含める必要があります。Web サイトに既にランタイムが含まれている場合、この手順をスキップすることができます。", + "xpack.canvas.shareWebsiteFlyout.runtimeStep.downloadLabel": "ダウンロードランタイム", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.addSnippetsTitle": "スナップショットを Web サイトに追加", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.autoplayParameterDescription": "ワークパッドのページ間で’ランタイムを自動的に移動させますか?", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.callRuntimeLabel": "ランタイムを呼び出す", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.description": "ワークパッドは {HTML} プレースホルダーでサイトの {HTML} 内に配置されますランタイムのパラメーターはインラインに含まれます。全パラメーターの一覧は以下をご覧ください。1 ページに複数のワークパッドを含めることができます。", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.downloadRuntimeTitle": "ダウンロードランタイム", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.downloadWorkpadTitle": "ワークパッドのダウンロード", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.heightParameterDescription": "ワークパッドの高さです。デフォルトはワークパッドの高さです。", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.includeRuntimeLabel": "ランタイムを含める", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.intervalParameterDescription": "時間フォーマットでのページが進む間隔です (例: {twoSeconds}、{oneMinute})", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.pageParameterDescription": "表示するページです。デフォルトはワークパッドに指定されたページになります。", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.parametersDescription": "シェアラブルワークパッドを構成するインラインパラメーターが多数あります。", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.parametersLabel": "パラメーター", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.placeholderLabel": "プレースホルダー", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.requiredLabel": "必要", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.shareableParameterDescription": "シェアラブルのタイプです。この場合、{CANVAS} ワークパッドです。", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.toolbarParameterDescription": "ツールバーを非表示にしますか?", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.urlParameterDescription": "シェアラブルワークパッド {JSON} ファイルの {URL} です。", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.widthParameterDescription": "ワークパッドの幅です。デフォルトはワークパッドの幅です。", + "xpack.canvas.shareWebsiteFlyout.workpadStep.description": "ワークパッドは別のサイトで共有できるように 1 つの {JSON} ファイルとしてエクスポートされます。", + "xpack.canvas.shareWebsiteFlyout.workpadStep.downloadLabel": "ワークパッドのダウンロード", + "xpack.canvas.shareWebsiteFlyout.zipDownloadLinkLabel": "サンプル {ZIP} ファイルをダウンロード", + "xpack.canvas.sidebarContent.groupedElementSidebarTitle": "グループ化されたエレメント", + "xpack.canvas.sidebarContent.multiElementSidebarTitle": "複数エレメント", + "xpack.canvas.sidebarContent.singleElementSidebarTitle": "選択されたエレメント", + "xpack.canvas.sidebarHeader.alignmentMenuItemLabel": "アラインメント", + "xpack.canvas.sidebarHeader.bottomAlignMenuItemLabel": "一番下", + "xpack.canvas.sidebarHeader.bringForwardArialLabel": "エレメントを 1 つ上のレイヤーに移動", + "xpack.canvas.sidebarHeader.bringToFrontArialLabel": "エレメントを一番上のレイヤーに移動", + "xpack.canvas.sidebarHeader.centerAlignMenuItemLabel": "中央", + "xpack.canvas.sidebarHeader.contextMenuAriaLabel": "エレメントオプション", + "xpack.canvas.sidebarHeader.createElementModalTitle": "新規エレメントの作成", + "xpack.canvas.sidebarHeader.distributionMenutItemLabel": "分布", + "xpack.canvas.sidebarHeader.groupMenuItemLabel": "グループ", + "xpack.canvas.sidebarHeader.horizontalDistributionMenutItemLabel": "横", + "xpack.canvas.sidebarHeader.leftAlignMenuItemLabel": "左", + "xpack.canvas.sidebarHeader.middleAlignMenuItemLabel": "真ん中", + "xpack.canvas.sidebarHeader.orderMenuItemLabel": "順序", + "xpack.canvas.sidebarHeader.rightAlignMenuItemLabel": "右", + "xpack.canvas.sidebarHeader.savedElementMenuItemLabel": "新規エレメントとして保存", + "xpack.canvas.sidebarHeader.sendBackwardArialLabel": "エレメントを 1 つ下のレイヤーに移動", + "xpack.canvas.sidebarHeader.sendToBackArialLabel": "エレメントを一番下のレイヤーに移動", + "xpack.canvas.sidebarHeader.topAlignMenuItemLabel": "一番上", + "xpack.canvas.sidebarHeader.ungroupMenuItemLabel": "グループ解除", + "xpack.canvas.sidebarHeader.verticalDistributionMenutItemLabel": "縦", + "xpack.canvas.tags.chartTag": "チャート", + "xpack.canvas.tags.filterTag": "フィルター", + "xpack.canvas.tags.graphicTag": "グラフィック", + "xpack.canvas.tags.presentationTag": "プレゼンテーション", + "xpack.canvas.tags.proportionTag": "比率", + "xpack.canvas.tags.reportTag": "レポート", + "xpack.canvas.tags.textTag": "テキスト", + "xpack.canvas.templates.darkHelp": "ダークカラーテーマのプレゼンテーションデッキです", + "xpack.canvas.templates.darkName": "ダーク", + "xpack.canvas.templates.lightHelp": "ライトカラーテーマのプレゼンテーションデッキです", + "xpack.canvas.templates.lightName": "ライト", + "xpack.canvas.templates.pitchHelp": "大きな写真でブランディングされたプレゼンテーションです", + "xpack.canvas.templates.pitchName": "ピッチ", + "xpack.canvas.templates.statusHelp": "ライブチャート付きのドキュメント式のレポートです", + "xpack.canvas.templates.statusName": "ステータス", + "xpack.canvas.templates.summaryDisplayName": "まとめ", + "xpack.canvas.templates.summaryHelp": "ライブチャート付きのインフォグラフィック式のレポートです", + "xpack.canvas.textStylePicker.alignCenterOption": "中央に合わせる", + "xpack.canvas.textStylePicker.alignLeftOption": "左に合わせる", + "xpack.canvas.textStylePicker.alignRightOption": "右に合わせる", + "xpack.canvas.textStylePicker.styleBoldOption": "太字", + "xpack.canvas.textStylePicker.styleItalicOption": "斜体", + "xpack.canvas.textStylePicker.styleUnderlineOption": "下線", + "xpack.canvas.timePicker.applyButtonLabel": "適用", + "xpack.canvas.toolbar.editorButtonLabel": "表現エディター", + "xpack.canvas.toolbar.nextPageAriaLabel": "次のページ", + "xpack.canvas.toolbar.pageButtonLabel": "ページ {pageNum}{rest}", + "xpack.canvas.toolbar.previousPageAriaLabel": "前のページ", + "xpack.canvas.toolbar.workpadManagerCloseButtonLabel": "閉じる", + "xpack.canvas.toolbarTray.closeTrayAriaLabel": "トレイのクローンを作成", + "xpack.canvas.transitions.fade.displayName": "フェード", + "xpack.canvas.transitions.fade.help": "ページからページへフェードします", + "xpack.canvas.transitions.rotate.displayName": "回転", + "xpack.canvas.transitions.rotate.help": "ページからページへ回転します", + "xpack.canvas.transitions.slide.displayName": "スライド", + "xpack.canvas.transitions.slide.help": "ページからページへスライドします", + "xpack.canvas.transitions.zoom.displayName": "ズーム:", + "xpack.canvas.transitions.zoom.help": "ページからページへズームします", + "xpack.canvas.uis.arguments.axisConfig.position.options.bottomDropDown": "一番下", + "xpack.canvas.uis.arguments.axisConfig.position.options.leftDropDown": "左", + "xpack.canvas.uis.arguments.axisConfig.position.options.rightDropDown": "右", + "xpack.canvas.uis.arguments.axisConfig.position.options.topDropDown": "トップ", + "xpack.canvas.uis.arguments.axisConfig.positionLabel": "配置", + "xpack.canvas.uis.arguments.axisConfigLabel": "ビジュアライゼーションの軸の構成", + "xpack.canvas.uis.arguments.axisConfigTitle": "軸の構成", + "xpack.canvas.uis.arguments.dataColumn.options.averageDropDown": "平均", + "xpack.canvas.uis.arguments.dataColumn.options.countDropDown": "カウント", + "xpack.canvas.uis.arguments.dataColumn.options.firstDropDown": "最初", + "xpack.canvas.uis.arguments.dataColumn.options.lastDropDown": "最後", + "xpack.canvas.uis.arguments.dataColumn.options.maxDropDown": "最高", + "xpack.canvas.uis.arguments.dataColumn.options.medianDropDown": "中央", + "xpack.canvas.uis.arguments.dataColumn.options.minDropDown": "最低", + "xpack.canvas.uis.arguments.dataColumn.options.sumDropDown": "合計", + "xpack.canvas.uis.arguments.dataColumn.options.uniqueDropDown": "固有", + "xpack.canvas.uis.arguments.dataColumn.options.valueDropDown": "値", + "xpack.canvas.uis.arguments.dataColumnLabel": "データ列を選択", + "xpack.canvas.uis.arguments.dataColumnTitle": "列", + "xpack.canvas.uis.arguments.dateFormatLabel": "{momentJS} フォーマットを選択または入力", + "xpack.canvas.uis.arguments.dateFormatTitle": "データフォーマット", + "xpack.canvas.uis.arguments.filterGroup.createNewGroupLinkText": "新規グループを作成", + "xpack.canvas.uis.arguments.filterGroupLabel": "フィルターグループを作成または入力", + "xpack.canvas.uis.arguments.filterGroupTitle": "フィルターグループ", + "xpack.canvas.uis.arguments.imageUpload.fileUploadPromptLabel": "画像を選択するかドラッグ &amp; ドロップしてください", + "xpack.canvas.uis.arguments.imageUpload.imageUploadingLabel": "画像をアップロード中", + "xpack.canvas.uis.arguments.imageUpload.urlFieldPlaceholder": "画像 {url}", + "xpack.canvas.uis.arguments.imageUpload.urlTypes.assetDropDown": "アセット", + "xpack.canvas.uis.arguments.imageUpload.urlTypes.fileDropDown": "インポート", + "xpack.canvas.uis.arguments.imageUpload.urlTypes.linkDropDown": "リンク", + "xpack.canvas.uis.arguments.imageUploadLabel": "画像を選択またはアップロード", + "xpack.canvas.uis.arguments.imageUploadTitle": "画像がアップロードされました", + "xpack.canvas.uis.arguments.numberFormat.format.bytesDropDown": "バイト", + "xpack.canvas.uis.arguments.numberFormat.format.currencyDropDown": "通貨", + "xpack.canvas.uis.arguments.numberFormat.format.durationDropDown": "期間", + "xpack.canvas.uis.arguments.numberFormat.format.numberDropDown": "数字", + "xpack.canvas.uis.arguments.numberFormat.format.percentDropDown": "パーセント", + "xpack.canvas.uis.arguments.numberFormatLabel": "有効な {numeralJS} フォーマットを選択または入力", + "xpack.canvas.uis.arguments.numberFormatTitle": "数字フォーマット", + "xpack.canvas.uis.arguments.numberLabel": "数字を入力", + "xpack.canvas.uis.arguments.numberTitle": "数字", + "xpack.canvas.uis.arguments.paletteLabel": "カラーパレットを選択", + "xpack.canvas.uis.arguments.paletteTitle": "カラーパレット", + "xpack.canvas.uis.arguments.percentageLabel": "パーセンテージのスライダー ", + "xpack.canvas.uis.arguments.percentageTitle": "パーセンテージ", + "xpack.canvas.uis.arguments.rangeLabel": "範囲内の値のスライダー", + "xpack.canvas.uis.arguments.rangeTitle": "範囲", + "xpack.canvas.uis.arguments.selectLabel": "ドロップダウンの複数オプションから選択", + "xpack.canvas.uis.arguments.selectTitle": "選択してください", + "xpack.canvas.uis.arguments.shapeLabel": "図形ピッカー", + "xpack.canvas.uis.arguments.shapeTitle": "図形", + "xpack.canvas.uis.arguments.stringLabel": "短い文字列を入力", + "xpack.canvas.uis.arguments.stringTitle": "文字列", + "xpack.canvas.uis.arguments.textareaLabel": "長い文字列を入力", + "xpack.canvas.uis.arguments.textareaTitle": "テキストエリア", + "xpack.canvas.uis.arguments.toggleLabel": "true/false トグルスイッチ", + "xpack.canvas.uis.arguments.toggleTitle": "切り替え", + "xpack.canvas.uis.dataSources.demoData.headingTitle": "デモデータを使用中です", + "xpack.canvas.uis.dataSources.demoDataLabel": "ユーザー名、価格、プロジェクト、国、フェーズを含む模擬データセット", + "xpack.canvas.uis.dataSources.demoDataTitle": "デモデータ", + "xpack.canvas.uis.dataSources.essqlLabel": "{elasticsearch} {sql} でデータ表を取得します", + "xpack.canvas.uis.dataSources.essqlTitle": "{elasticsearch} {sql}", + "xpack.canvas.uis.dataSources.timelion.intervalTitle": "間隔", + "xpack.canvas.uis.dataSources.timelion.queryLabel": "{lucene} クエリ文字列の構文", + "xpack.canvas.uis.dataSources.timelion.queryTitle": "クエリ", + "xpack.canvas.uis.dataSources.timelion.tips.functions": "{functionExample} などの一部 {timelion} 関数は {canvas} データ表に変換できません。データ操作に関する機能は正常に動作するはずです。", + "xpack.canvas.uis.dataSources.timelion.tips.time": "{timelion} には時間範囲が必要です。ページのどこかに時間フィルターを追加するか、コードエディターで時間フィルターを渡す必要があります。", + "xpack.canvas.uis.dataSources.timelionLabel": "{timelion} 構文で時系列を取得します", + "xpack.canvas.uis.models.math.args.valueLabel": "データソースから値を抽出する際に使用する関数と列", + "xpack.canvas.uis.models.math.args.valueTitle": "値", + "xpack.canvas.uis.models.mathTitle": "メジャー", + "xpack.canvas.uis.models.pointSeries.args.colorLabel": "マークまたは数列の色を決定します", + "xpack.canvas.uis.models.pointSeries.args.colorTitle": "色", + "xpack.canvas.uis.models.pointSeries.args.sizeLabel": "マークのサイズを決定します", + "xpack.canvas.uis.models.pointSeries.args.sizeTitle": "サイズ", + "xpack.canvas.uis.models.pointSeries.args.textLabel": "テキストをマークとして、またはマークの周りに使用するように設定", + "xpack.canvas.uis.models.pointSeries.args.textTitle": "テキスト", + "xpack.canvas.uis.models.pointSeries.args.xaxisLabel": "水平軸の周りのデータです。通常は数字、文字列、または日付です。", + "xpack.canvas.uis.models.pointSeries.args.xaxisTitle": "X 軸", + "xpack.canvas.uis.models.pointSeries.args.yaxisLabel": "垂直軸の周りのデータです。通常は数字です。", + "xpack.canvas.uis.models.pointSeries.args.yaxisTitle": "Y 軸", + "xpack.canvas.uis.models.pointSeriesTitle": "ディメンションとメジャー", + "xpack.canvas.uis.transforms.formatDate.args.formatTitle": "フォーマット", + "xpack.canvas.uis.transforms.formatDateTitle": "データフォーマット", + "xpack.canvas.uis.transforms.formatNumber.args.formatTitle": "フォーマット", + "xpack.canvas.uis.transforms.formatNumberTitle": "数字フォーマット", + "xpack.canvas.uis.transforms.roundDate.args.formatLabel": "日付の繰り上げ・繰り下げに使用する {momentJs} フォーマットを選択または入力", + "xpack.canvas.uis.transforms.roundDate.args.formatTitle": "フォーマット", + "xpack.canvas.uis.transforms.roundDateTitle": "日付の繰り上げ・繰り下げ", + "xpack.canvas.uis.transforms.sort.args.reverseToggleSwitch": "降順", + "xpack.canvas.uis.transforms.sort.args.sortFieldTitle": "ソートフィールド", + "xpack.canvas.uis.transforms.sortTitle": "データベースの並べ替え", + "xpack.canvas.uis.views.dropdownControl.args.filterColumnLabel": "ドロップダウンで選択された値を適用する列", + "xpack.canvas.uis.views.dropdownControl.args.filterColumnTitle": "フィルター列", + "xpack.canvas.uis.views.dropdownControl.args.filterGroupLabel": "選択されたグループ名をエレメントのフィルター関数に適用してこのフィルターをターゲットにする", + "xpack.canvas.uis.views.dropdownControl.args.filterGroupTitle": "フィルターグループ", + "xpack.canvas.uis.views.dropdownControl.args.valueColumnLabel": "ドロップダウンに表示する値を抽出する列", + "xpack.canvas.uis.views.dropdownControl.args.valueColumnTitle": "値列", + "xpack.canvas.uis.views.dropdownControlTitle": "ドロップダウンフィルター", + "xpack.canvas.uis.views.getCellLabel": "最初の行と列を使用", + "xpack.canvas.uis.views.getCellTitle": "ドロップダウンフィルター", + "xpack.canvas.uis.views.image.args.mode.containDropDown": "Contain", + "xpack.canvas.uis.views.image.args.mode.coverDropDown": "Cover", + "xpack.canvas.uis.views.image.args.mode.stretchDropDown": "Stretch", + "xpack.canvas.uis.views.image.args.modeLabel": "注:ストレッチ塗りつぶしはベクター画像には使用できない場合があります", + "xpack.canvas.uis.views.image.args.modeTitle": "塗りつぶしモード", + "xpack.canvas.uis.views.imageTitle": "画像", + "xpack.canvas.uis.views.markdown.args.contentLabel": "{markdown} フォーマットのテキスト", + "xpack.canvas.uis.views.markdown.args.contentTitle": "{markdown} コンテンツ", + "xpack.canvas.uis.views.markdownLabel": "{markdown} を使用してマークアップを生成", + "xpack.canvas.uis.views.markdownTitle": "{markdown}", + "xpack.canvas.uis.views.metric.args.labelArgLabel": "メトリックを説明します", + "xpack.canvas.uis.views.metric.args.labelArgTitle": "ラベル", + "xpack.canvas.uis.views.metric.args.labelFontLabel": "フォント、配置、色", + "xpack.canvas.uis.views.metric.args.labelFontTitle": "ラベルテキスト設定", + "xpack.canvas.uis.views.metric.args.metricFontLabel": "フォント、配置、色", + "xpack.canvas.uis.views.metric.args.metricFontTitle": "メトリックテキスト設定", + "xpack.canvas.uis.views.metric.args.metricFormatLabel": "フォント、配置、色", + "xpack.canvas.uis.views.metric.args.metricFormatTitle": "メトリックのフォーマット", + "xpack.canvas.uis.views.metricTitle": "メトリック", + "xpack.canvas.uis.views.numberArgTitle": "数字", + "xpack.canvas.uis.views.pie.args.holeLabel": "穴の半径", + "xpack.canvas.uis.views.pie.args.holeTitle": "内半径", + "xpack.canvas.uis.views.pie.args.labelRadiusLabel": "円グラフの中心からラベルまでの距離です", + "xpack.canvas.uis.views.pie.args.labelRadiusTitle": "ラベル半径", + "xpack.canvas.uis.views.pie.args.labelsTitle": "ラベル", + "xpack.canvas.uis.views.pie.args.labelsToggleSwitch": "ラベルの表示・非表示", + "xpack.canvas.uis.views.pie.args.legendLabel": "凡例の無効化・配置", + "xpack.canvas.uis.views.pie.args.legendTitle": "凡例の配置", + "xpack.canvas.uis.views.pie.args.radiusLabel": "円グラフの半径", + "xpack.canvas.uis.views.pie.args.radiusTitle": "半径", + "xpack.canvas.uis.views.pie.args.tiltLabel": "100 が完全に垂直、0 が完全に水平を表す傾きのパーセンテージです", + "xpack.canvas.uis.views.pie.args.tiltTitle": "傾斜角度", + "xpack.canvas.uis.views.pieTitle": "チャートスタイル", + "xpack.canvas.uis.views.plot.args.defaultStyleLabel": "上書きされない限りすべての数列にデフォルトで使用されるスタイルを設定します", + "xpack.canvas.uis.views.plot.args.defaultStyleTitle": "デフォルトのスタイル", + "xpack.canvas.uis.views.plot.args.legendLabel": "凡例の無効化・配置", + "xpack.canvas.uis.views.plot.args.legendTitle": "凡例の配置", + "xpack.canvas.uis.views.plot.args.xaxisLabel": "X 軸の構成・無効化", + "xpack.canvas.uis.views.plot.args.xaxisTitle": "X 軸", + "xpack.canvas.uis.views.plot.args.yaxisLabel": "Y 軸の構成・無効化", + "xpack.canvas.uis.views.plot.args.yaxisTitle": "Y 軸", + "xpack.canvas.uis.views.plotTitle": "チャートスタイル", + "xpack.canvas.uis.views.progress.args.barColorLabel": "HEX、RGB、または HTML カラーネームが使用できます", + "xpack.canvas.uis.views.progress.args.barColorTitle": "背景色", + "xpack.canvas.uis.views.progress.args.barWeightLabel": "背景バーの太さです", + "xpack.canvas.uis.views.progress.args.barWeightTitle": "背景重量", + "xpack.canvas.uis.views.progress.args.fontLabel": "ラベルのフォント設定です。技術的には他のスタイルを追加することもできます", + "xpack.canvas.uis.views.progress.args.fontTitle": "ラベル設定", + "xpack.canvas.uis.views.progress.args.labelArgLabel": "{true}/{false} でラベルの表示/非表示を設定するか、ラベルとして表示する文字列を指定します", + "xpack.canvas.uis.views.progress.args.labelArgTitle": "ラベル", + "xpack.canvas.uis.views.progress.args.maxLabel": "進捗エレメントの最高値です", + "xpack.canvas.uis.views.progress.args.maxTitle": "最高値", + "xpack.canvas.uis.views.progress.args.shapeLabel": "進捗インジケーターの形", + "xpack.canvas.uis.views.progress.args.shapeTitle": "図形", + "xpack.canvas.uis.views.progress.args.valueColorLabel": "{hex}、{rgb}、または {html} カラーネームが使用できます", + "xpack.canvas.uis.views.progress.args.valueColorTitle": "進捗の色", + "xpack.canvas.uis.views.progress.args.valueWeightLabel": "進捗バーの太さです", + "xpack.canvas.uis.views.progress.args.valueWeightTitle": "進捗の重量", + "xpack.canvas.uis.views.progressTitle": "進捗", + "xpack.canvas.uis.views.render.args.css.applyButtonLabel": "スタイルシートを適用", + "xpack.canvas.uis.views.render.args.cssLabel": "エレメントに合わせた {css} スタイルシート", + "xpack.canvas.uis.views.renderLabel": "エレメントの周りのコンテナーの設定です", + "xpack.canvas.uis.views.renderTitle": "エレメントスタイル", + "xpack.canvas.uis.views.repeatImage.args.emptyImageLabel": "値と最高値の間を埋める画像です", + "xpack.canvas.uis.views.repeatImage.args.emptyImageTitle": "空の部分の画像", + "xpack.canvas.uis.views.repeatImage.args.imageLabel": "繰り返す画像です", + "xpack.canvas.uis.views.repeatImage.args.imageTitle": "画像", + "xpack.canvas.uis.views.repeatImage.args.maxLabel": "画像を繰り返す最高回数", + "xpack.canvas.uis.views.repeatImage.args.maxTitle": "最高カウント", + "xpack.canvas.uis.views.repeatImage.args.sizeLabel": "画像寸法の最大値です。例: 画像が縦長の場合、高さになります", + "xpack.canvas.uis.views.repeatImage.args.sizeTitle": "画像サイズ", + "xpack.canvas.uis.views.repeatImageTitle": "繰り返しの画像", + "xpack.canvas.uis.views.revealImage.args.emptyImageLabel": "背景画像です。例: 空のグラス", + "xpack.canvas.uis.views.revealImage.args.emptyImageTitle": "背景画像", + "xpack.canvas.uis.views.revealImage.args.imageLabel": "関数インプットで徐々に表示される画像です。例: いっぱいのグラス", + "xpack.canvas.uis.views.revealImage.args.imageTitle": "画像", + "xpack.canvas.uis.views.revealImage.args.origin.bottomDropDown": "一番下", + "xpack.canvas.uis.views.revealImage.args.origin.leftDropDown": "左", + "xpack.canvas.uis.views.revealImage.args.origin.rightDropDown": "右", + "xpack.canvas.uis.views.revealImage.args.origin.topDropDown": "一番上", + "xpack.canvas.uis.views.revealImage.args.originLabel": "徐々に表示を開始する方向", + "xpack.canvas.uis.views.revealImage.args.originTitle": "徐々に表示を開始する場所", + "xpack.canvas.uis.views.revealImageTitle": "画像を徐々に表示", + "xpack.canvas.uis.views.shape.args.borderLabel": "HEX、RGB、または HTML カラーネームが使用できます", + "xpack.canvas.uis.views.shape.args.borderTitle": "境界", + "xpack.canvas.uis.views.shape.args.borderWidthLabel": "境界線の幅", + "xpack.canvas.uis.views.shape.args.borderWidthTitle": "境界線の幅", + "xpack.canvas.uis.views.shape.args.fillLabel": "HEX、RGB、または HTML カラーネームが使用できます", + "xpack.canvas.uis.views.shape.args.fillTitle": "塗りつぶし", + "xpack.canvas.uis.views.shape.args.maintainAspectTitle": "アスペクト比を維持", + "xpack.canvas.uis.views.shape.args.shapeTitle": "図形を選択", + "xpack.canvas.uis.views.shapeTitle": "図形", + "xpack.canvas.uis.views.table.args.paginateLabel": "ページ付けコントロールの表示・非表示を切り替えます。無効の場合、初めのページのみが表示されます", + "xpack.canvas.uis.views.table.args.paginateTitle": "ページ付け", + "xpack.canvas.uis.views.table.args.perPageLabel": "各表ページに表示される行数です", + "xpack.canvas.uis.views.table.args.perPageTitle": "ページごとの行数", + "xpack.canvas.uis.views.table.args.showHeaderLabel": "各列のタイトルを含むヘッダー列の表示・非表示を切り替えます", + "xpack.canvas.uis.views.table.args.showHeaderTitle": "ヘッダー", + "xpack.canvas.uis.views.tableLabel": "表エレメントのスタイルを設定します", + "xpack.canvas.uis.views.tableTitle": "表スタイル", + "xpack.canvas.uis.views.timefilter.args.columnConfirmButtonLabel": "設定", + "xpack.canvas.uis.views.timefilter.args.columnLabel": "選択された時間が適用される列です", + "xpack.canvas.uis.views.timefilter.args.columnTitle": "列", + "xpack.canvas.uis.views.timefilter.args.filterGroupLabel": "選択されたグループ名をエレメントのフィルター関数に適用してこのフィルターをターゲットにする", + "xpack.canvas.uis.views.timefilter.args.filterGroupTitle": "フィルターグループ名", + "xpack.canvas.uis.views.timefilterTitle": "時間フィルター", + "xpack.canvas.units.quickRange.dayBeforeYesterday": "一昨日", + "xpack.canvas.units.quickRange.last12Hours": "過去 12 時間", + "xpack.canvas.units.quickRange.last15Minutes": "過去 15 分間", + "xpack.canvas.units.quickRange.last1Hour": "過去 1 時間", + "xpack.canvas.units.quickRange.last1Year": "過去 1 年間", + "xpack.canvas.units.quickRange.last24Hours": "過去 24 時間", + "xpack.canvas.units.quickRange.last2Weeks": "過去 2 週間", + "xpack.canvas.units.quickRange.last2Years": "過去 2 年間", + "xpack.canvas.units.quickRange.last30Days": "過去 30 日間", + "xpack.canvas.units.quickRange.last30Minutes": "過去 30 分間", + "xpack.canvas.units.quickRange.last4Hours": "過去 4 時間", + "xpack.canvas.units.quickRange.last5Years": "過去 5 年間", + "xpack.canvas.units.quickRange.last60Days": "過去 60 日間", + "xpack.canvas.units.quickRange.last6Months": "過去 6 か月間", + "xpack.canvas.units.quickRange.last7Days": "過去 7 日間", + "xpack.canvas.units.quickRange.last90Days": "過去 90 日間", + "xpack.canvas.units.quickRange.monthToDate": "月初めから今日まで", + "xpack.canvas.units.quickRange.previousMonth": "先月", + "xpack.canvas.units.quickRange.previousWeek": "先週", + "xpack.canvas.units.quickRange.previousYear": "昨年", + "xpack.canvas.units.quickRange.theDaySoFar": "本日現在まで", + "xpack.canvas.units.quickRange.thisDayLastWeek": "先週のこの曜日", + "xpack.canvas.units.quickRange.thisMonth": "今月", + "xpack.canvas.units.quickRange.thisWeek": "今週", + "xpack.canvas.units.quickRange.thisYear": "今年", + "xpack.canvas.units.quickRange.today": "今日", + "xpack.canvas.units.quickRange.weekToDate": "週初めから今日まで", + "xpack.canvas.units.quickRange.yearToDate": "年度の頭から今日まで", + "xpack.canvas.units.quickRange.yesterday": "昨日", + "xpack.canvas.units.time.days": "{days, plural, one {# 日} other {# 日}}", + "xpack.canvas.units.time.hours": "{hours, plural, one {# 時間} other {# 時間}}", + "xpack.canvas.units.time.minutes": "{minutes, plural, one {# 分} other {# 分}}", + "xpack.canvas.units.time.seconds": "{seconds, plural, one {# 秒} other {# 秒}}", + "xpack.canvas.workpadConfig.applyStylesheetButtonLabel": "スタイルシートを適用", + "xpack.canvas.workpadConfig.globalCSSLabel": "グローバル CSS オーバーライド", + "xpack.canvas.workpadConfig.globalCSSTooltip": "このワークパッドのすべてのページにスタイルを適用します", + "xpack.canvas.workpadConfig.heightLabel": "高さ", + "xpack.canvas.workpadConfig.nameLabel": "名前", + "xpack.canvas.workpadConfig.pageSizeBadgeAriaLabel": "ページサイズを事前設定: {sizeName}", + "xpack.canvas.workpadConfig.pageSizeBadgeOnClickAriaLabel": "ページサイズを {sizeName} に設定", + "xpack.canvas.workpadConfig.swapDimensionsAriaLabel": "ページの幅と高さを入れ替えます", + "xpack.canvas.workpadConfig.swapDimensionsTooltip": "ページの幅と高さを入れ替える", + "xpack.canvas.workpadConfig.title": "ワークパッド", + "xpack.canvas.workpadConfig.USLetterButtonLabel": "US レター", + "xpack.canvas.workpadConfig.widthLabel": "幅", + "xpack.canvas.workpadCreate.createButtonLabel": "ワークパッドを作成", + "xpack.canvas.workpadHeader.addElementButtonLabel": "エレメントを追加", + "xpack.canvas.workpadHeader.addElementModalCloseButtonLabel": "閉じる", + "xpack.canvas.workpadHeader.cycleIntervalDaysText": "{days} {days, plural, one {日} other {日}}ごと", + "xpack.canvas.workpadHeader.cycleIntervalHoursText": "{hours} {hours, plural, one {時間} other {時間}}ごと", + "xpack.canvas.workpadHeader.cycleIntervalMinutesText": "{minutes} {minutes, plural, one {分} other {分}}ごと", + "xpack.canvas.workpadHeader.cycleIntervalSecondsText": "{seconds} {seconds, plural, one {秒} other {秒}}ごと", + "xpack.canvas.workpadHeader.embedObjectButtonLabel": "オブジェクトを埋め込む", + "xpack.canvas.workpadHeader.fullscreenButtonAriaLabel": "全画面表示", + "xpack.canvas.workpadHeader.fullscreenTooltip": "全画面モードを開始します", + "xpack.canvas.workpadHeader.hideEditControlTooltip": "編集コントロールを非表示にします", + "xpack.canvas.workpadHeader.noWritePermissionTooltip": "このワークパッドを編集するパーミッションがありません", + "xpack.canvas.workpadHeader.showEditControlTooltip": "編集コントロールを表示します", + "xpack.canvas.workpadHeaderAutoRefreshControls.disableTooltip": "自動更新を無効にします", + "xpack.canvas.workpadHeaderAutoRefreshControls.intervalFormLabel": "自動更新間隔を変更します", + "xpack.canvas.workpadHeaderAutoRefreshControls.refreshListDurationManualText": "手動で", + "xpack.canvas.workpadHeaderAutoRefreshControls.refreshListTitle": "エレメントを更新", + "xpack.canvas.workpadHeaderControlSettings.settingsTooltip": "設定をコントロールします", + "xpack.canvas.workpadHeaderCustomInterval.confirmButtonLabel": "設定", + "xpack.canvas.workpadHeaderCustomInterval.formDescription": "{secondsExample}、{minutesExample}、{hoursExample} のような短い表記を使用します", + "xpack.canvas.workpadHeaderCustomInterval.formLabel": "カスタム間隔を設定", + "xpack.canvas.workpadHeaderKioskControl.controlTitle": "全画面ページのサイクル", + "xpack.canvas.workpadHeaderKioskControl.cycleFormLabel": "サイクル間隔を変更", + "xpack.canvas.workpadHeaderKioskControl.cycleToggleSwitch": "スライドを自動的にサイクル", + "xpack.canvas.workpadHeaderRefreshControlSettings.refreshAriaLabel": "エレメントを更新", + "xpack.canvas.workpadHeaderRefreshControlSettings.refreshTooltip": "データを更新", + "xpack.canvas.workpadHeaderWorkpadExport.copyPDFMessage": "{PDF} 生成 {URL} がクリップボードにコピーされました。", + "xpack.canvas.workpadHeaderWorkpadExport.copyReportingConfigMessage": "レポート構成がクリップボードにコピーされました", + "xpack.canvas.workpadHeaderWorkpadExport.copyShareConfigMessage": "共有マークアップがクリップボードにコピーされました", + "xpack.canvas.workpadHeaderWorkpadExport.exportPDFErrorMessage": "「{workpadName}」の {PDF} の作成に失敗しました", + "xpack.canvas.workpadHeaderWorkpadExport.exportPDFMessage": "{PDF} をエクスポート中です。管理で進捗を確認できます。", + "xpack.canvas.workpadHeaderWorkpadExport.exportPDFTitle": "ワークパッド「{workpadName}」の {PDF} エクスポート", + "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelCopyAriaLabel": "この {URL} を使用してスクリプトから、または Watcher で {PDF} を生成することもできます。{URL} をクリップボードにコピーするにはエンターキーを押してください。", + "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelCopyButtonLabel": "{POST} {URL} をコピー", + "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelCopyDescription": "{POST} {URL} をコピーして {KIBANA} 外または ウォッチャー から生成することもできます。", + "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelDisabledDescription": "PDF へのエクスポートは無効になっています。Chromium ブラウザを使用するにはレポートの構成が必要です。これを {fileName} ファイルに追加します。", + "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelGenerateButtonLabel": "{PDF} を生成", + "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelGenerateDescription": "ワークパッドのサイズによって、{PDF} の生成には数分かかる場合があります。", + "xpack.canvas.workpadHeaderWorkpadExport.shareDownloadJSONTitle": "{JSON} をダウンロード", + "xpack.canvas.workpadHeaderWorkpadExport.shareDownloadPDFTitle": "{PDF} レポート", + "xpack.canvas.workpadHeaderWorkpadExport.shareWebsiteErrorTitle": "「{workpadName}」の {ZIP} ファイルの作成に失敗しました。ワークパッドが大きすぎる可能性があります。ファイルを別々にダウンロードする必要があります。", + "xpack.canvas.workpadHeaderWorkpadExport.shareWebsiteTitle": "Web サイトで共有", + "xpack.canvas.workpadHeaderWorkpadExport.shareWorkpadMessage": "このワークパッドを共有", + "xpack.canvas.workpadHeaderWorkpadExport.unknownExportErrorMessage": "未知のエクスポートタイプ: {type}", + "xpack.canvas.workpadHeaderWorkpadExport.unsupportedRendererWarning": "このワークパッドには {CANVAS} シェアラブルワークパッドランタイムがサポートしていないレンダリング関数が含まれています。これらのエレメントはレンダリングされません:", + "xpack.canvas.workpadHeaderWorkpadZoom.zoomControlsAriaLabel": "ズームコントロール", + "xpack.canvas.workpadHeaderWorkpadZoom.zoomControlsTooltip": "ズームコントロール", + "xpack.canvas.workpadHeaderWorkpadZoom.zoomFitToWindowText": "ウィンドウに合わせる", + "xpack.canvas.workpadHeaderWorkpadZoom.zoomInText": "ズームイン", + "xpack.canvas.workpadHeaderWorkpadZoom.zoomOutText": "ズームアウト", + "xpack.canvas.workpadHeaderWorkpadZoom.zoomPanelTitle": "ズーム:", + "xpack.canvas.workpadHeaderWorkpadZoom.zoomPrecentageValue": "リセット", + "xpack.canvas.workpadHeaderWorkpadZoom.zoomResetText": "{scalePercentage}%", + "xpack.canvas.workpadLoader.clonedWorkpadName": "{workpadName} のコピー", + "xpack.canvas.workpadLoader.cloneTooltip": "ワークパッドのクローンを作成します", + "xpack.canvas.workpadLoader.createWorkpadLoadingDescription": "ワークパッドを作成中...", + "xpack.canvas.workpadLoader.deleteButtonAriaLabel": "{numberOfWorkpads} 件のワークパッドを削除", + "xpack.canvas.workpadLoader.deleteButtonLabel": "({numberOfWorkpads}) 件を削除", + "xpack.canvas.workpadLoader.deleteModalConfirmButtonLabel": "削除", + "xpack.canvas.workpadLoader.deleteModalDescription": "削除されたワークパッドは復元できません。", + "xpack.canvas.workpadLoader.deleteMultipleWorkpadsModalTitle": "{numberOfWorkpads} 件のワークパッドを削除しますか?", + "xpack.canvas.workpadLoader.deleteSingleWorkpadModalTitle": "ワークパッド「{workpadName}」を削除しますか?", + "xpack.canvas.workpadLoader.emptyPromptGettingStartedDescription": "新規ワークパッドを作成、テンプレートで開始、またはワークパッド {JSON} ファイルをここにドロップしてインポートします。", + "xpack.canvas.workpadLoader.emptyPromptNewUserDescription": "{CANVAS} は初めてですか?", + "xpack.canvas.workpadLoader.emptyPromptTitle": "初の’ワークパッドを追加しましょう", + "xpack.canvas.workpadLoader.exportButtonAriaLabel": "{numberOfWorkpads} 件のワークパッドをエクスポート", + "xpack.canvas.workpadLoader.exportButtonLabel": "({numberOfWorkpads}) 件をエクスポート:", + "xpack.canvas.workpadLoader.exportTooltip": "ワークパッドをエクスポート", + "xpack.canvas.workpadLoader.fetchLoadingDescription": "ワークパッドを取得中...", + "xpack.canvas.workpadLoader.filePickerPlaceholder": "ワークパッド {JSON} ファイルをインポート", + "xpack.canvas.workpadLoader.loadWorkpadArialLabel": "ワークパッド「{workpadName}」を読み込む", + "xpack.canvas.workpadLoader.noPermissionToCloneToolTip": "ワークパッドのクローンを作成するパーミッションがありません", + "xpack.canvas.workpadLoader.noPermissionToCreateToolTip": "ワークパッドを作成するパーミッションがありません", + "xpack.canvas.workpadLoader.noPermissionToDeleteToolTip": "ワークパッドを削除するパーミッションがありません", + "xpack.canvas.workpadLoader.noPermissionToUploadToolTip": "ワークパッドを更新するパーミッションがありません", + "xpack.canvas.workpadLoader.sampleDataLinkLabel": "初の’ワークパッドを追加しましょう", + "xpack.canvas.workpadLoader.table.createdColumnTitle": "作成済み", + "xpack.canvas.workpadLoader.table.nameColumnTitle": "ワークパッド名", + "xpack.canvas.workpadLoader.table.updatedColumnTitle": "更新しました", + "xpack.canvas.workpadManager.modalTitle": "{CANVAS} ワークパッド", + "xpack.canvas.workpadManager.myWorkpadsTabLabel": "マイワークパッド", + "xpack.canvas.workpadManager.workpadTemplatesTabLabel": "テンプレート", + "xpack.canvas.workpadSearch.searchPlaceholder": "ワークパッドを検索", + "xpack.canvas.workpadTemplate.cloneTemplateLinkAriaLabel": "ワークパッドテンプレート「{templateName}」のクローンを作成", + "xpack.canvas.workpadTemplate.searchPlaceholder": "テンプレートを検索", + "xpack.canvas.workpadTemplates.table.descriptionColumnTitle": "説明", + "xpack.canvas.workpadTemplates.table.nameColumnTitle": "テンプレート名", + "xpack.canvas.workpadTemplates.table.tagsColumnTitle": "タグ", + "xpack.crossClusterReplication.addAutoFollowPatternButtonLabel": "自動フォローパターンを作成", + "xpack.crossClusterReplication.addBreadcrumbTitle": "追加", + "xpack.crossClusterReplication.addFollowerButtonLabel": "フォロワーインデックスを作成", + "xpack.crossClusterReplication.app.checkPermissionsFatalErrorTitle": "クラスター横断レプリケーションアプリ", + "xpack.crossClusterReplication.app.deniedPermissionDescription": "クラスター横断レプリケーションを使用するには、{clusterPrivilegesCount, plural, one {次のクラスター特権} other {次のクラスター特権}}が必要です: {clusterPrivileges}。", + "xpack.crossClusterReplication.app.deniedPermissionTitle": "クラスター特権が足りません", + "xpack.crossClusterReplication.app.permissionCheckErrorTitle": "パーミッションの確認中にエラーが発生", + "xpack.crossClusterReplication.app.permissionCheckTitle": "パーミッションを確認中…", + "xpack.crossClusterReplication.appTitle": "クラスター横断レプリケーション", + "xpack.crossClusterReplication.autoFollowPattern.addAction.successNotificationTitle": "自動フォローパターン「{name}」が追加されました", + "xpack.crossClusterReplication.autoFollowPattern.addTitle": "自動フォローパターンの追加", + "xpack.crossClusterReplication.autoFollowPattern.editTitle": "自動フォローパターンの編集", + "xpack.crossClusterReplication.autoFollowPattern.leaderIndexPatternValidation.illegalCharacters": "インデックスパターンから{characterListLength, plural, one {} other {}} {characterList} を削除してください。", + "xpack.crossClusterReplication.autoFollowPattern.leaderIndexPatternValidation.isEmpty": "リーダーインデックスパターンが最低 1 つ必要です。", + "xpack.crossClusterReplication.autoFollowPattern.leaderIndexPatternValidation.noEmptySpace": "インデックスパターンにスペースは使用できません。", + "xpack.crossClusterReplication.autoFollowPattern.nameValidation.errorComma": "名前にコンマは使用できません。", + "xpack.crossClusterReplication.autoFollowPattern.nameValidation.errorEmptyName": "名前が必要です。", + "xpack.crossClusterReplication.autoFollowPattern.nameValidation.errorSpace": "名前にスペースは使用できません。", + "xpack.crossClusterReplication.autoFollowPattern.nameValidation.errorUnderscore": "名前の頭にアンダーラインは使用できません。", + "xpack.crossClusterReplication.autoFollowPattern.prefixValidation.beginsWithPeriod": "接頭辞はピリオドで始めることはできません。", + "xpack.crossClusterReplication.autoFollowPattern.prefixValidation.illegalCharacters": "接頭辞から{characterListLength, plural, one {} other {}} {characterList} を削除してください。", + "xpack.crossClusterReplication.autoFollowPattern.prefixValidation.noEmptySpace": "接頭辞にスペースは使用できません。", + "xpack.crossClusterReplication.autoFollowPattern.removeAction.errorMultipleNotificationTitle": "{count} 自動フォローパターンの削除中にエラーが発生", + "xpack.crossClusterReplication.autoFollowPattern.removeAction.errorSingleNotificationTitle": "「「{name}」自動フォローパターンの削除中にエラーが発生", + "xpack.crossClusterReplication.autoFollowPattern.removeAction.successMultipleNotificationTitle": "{count} 自動フォローパターンが削除されました", + "xpack.crossClusterReplication.autoFollowPattern.removeAction.successSingleNotificationTitle": "「{name}」 自動フォローパターンが削除されました", + "xpack.crossClusterReplication.autoFollowPattern.suffixValidation.illegalCharacters": "接尾辞から{characterListLength, plural, one {} other {}} {characterList} 削除してください。", + "xpack.crossClusterReplication.autoFollowPattern.suffixValidation.noEmptySpace": "接尾辞にスペースは使用できません。", + "xpack.crossClusterReplication.autoFollowPattern.updateAction.successNotificationTitle": "自動フォローパターン「{name}」が更新されました", + "xpack.crossClusterReplication.autoFollowPatternCreateForm.loadingRemoteClustersMessage": "リモートクラスターを読み込み中…", + "xpack.crossClusterReplication.autoFollowPatternCreateForm.saveButtonLabel": "作成", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.closeButtonLabel": "閉じる", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.deleteButtonLabel": "削除", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.editButtonLabel": "編集", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.leaderPatternsLabel": "リーダーパターン", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.notFoundLabel": "自動フォローパターンが見つかりません", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.prefixEmptyValue": "接頭辞がありません", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.prefixLabel": "接頭辞", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.recentErrorsTitle": "最近のエラー", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.remoteClusterLabel": "リモートクラスター", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.statusTitle": "設定", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.suffixEmptyValue": "接尾辞がありません", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.suffixLabel": "接尾辞", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.viewIndicesLink": "インデックス管理でフォロワーインデックスを表示", + "xpack.crossClusterReplication.autoFollowPatternEditForm.loadingErrorMessage": "自動フォローパターン「{name}」は存在しません。", + "xpack.crossClusterReplication.autoFollowPatternEditForm.loadingErrorTitle": "自動フォローパターンの読み込み中にエラーが発生", + "xpack.crossClusterReplication.autoFollowPatternEditForm.loadingRemoteClustersMessage": "リモートクラスターを読み込み中…", + "xpack.crossClusterReplication.autoFollowPatternEditForm.loadingTitle": "自動フォローパターンを読み込み中…", + "xpack.crossClusterReplication.autoFollowPatternEditForm.saveButtonLabel": "更新", + "xpack.crossClusterReplication.autoFollowPatternEditForm.viewAutoFollowPatternsButtonLabel": "自動フォローパターンを表示", + "xpack.crossClusterReplication.autoFollowPatternForm.actions.savingText": "保存中", + "xpack.crossClusterReplication.autoFollowPatternForm.autoFollowPattern.fieldPrefixLabel": "接頭辞", + "xpack.crossClusterReplication.autoFollowPatternForm.autoFollowPattern.fieldSuffixLabel": "接尾辞", + "xpack.crossClusterReplication.autoFollowPatternForm.autoFollowPatternName.fieldNameLabel": "名前", + "xpack.crossClusterReplication.autoFollowPatternForm.cancelButtonLabel": "キャンセル", + "xpack.crossClusterReplication.autoFollowPatternForm.currentRemoteClusterNotConnectedCallOutDescription": "これはリモートクラスターを編集することで解決できます。", + "xpack.crossClusterReplication.autoFollowPatternForm.currentRemoteClusterNotConnectedCallOutTitle": "リモートクラスター「{name}」が接続されていないため、自動フォローパターンを編集できません", + "xpack.crossClusterReplication.autoFollowPatternForm.currentRemoteClusterNotFoundCallOutDescription": "この自動フォローパターンを編集するには、「{name}」というリモートクラスターの追加が必要です。", + "xpack.crossClusterReplication.autoFollowPatternForm.emptyRemoteClustersCallOutDescription": "自動フォローパターンはリモートクラスターのインデックスを捕捉します。", + "xpack.crossClusterReplication.autoFollowPatternForm.fieldFollowerIndicesHelpLabel": "スペースと {characterList} は使用できません。", + "xpack.crossClusterReplication.autoFollowPatternForm.fieldLeaderIndexPatternsHelpLabel": "スペースと {characterList} は使用できません。", + "xpack.crossClusterReplication.autoFollowPatternForm.fieldLeaderIndexPatternsLabel": "インデックスパターン", + "xpack.crossClusterReplication.autoFollowPatternForm.fieldLeaderIndexPatternsPlaceholder": "入力してエンターキーを押してください", + "xpack.crossClusterReplication.autoFollowPatternForm.hideRequestButtonLabel": "リクエストを非表示", + "xpack.crossClusterReplication.autoFollowPatternForm.indicesPreviewDescription": "上の設定は次のようなインデックス名を生成します:", + "xpack.crossClusterReplication.autoFollowPatternForm.indicesPreviewTitle": "インデックス名の例", + "xpack.crossClusterReplication.autoFollowPatternForm.leaderIndexPatternError.duplicateMessage": "リーダーインデックスパターンの複製はできません。", + "xpack.crossClusterReplication.autoFollowPatternForm.requestFlyout.closeButtonLabel": "閉じる", + "xpack.crossClusterReplication.autoFollowPatternForm.requestFlyout.createDescriptionText": "この Elasticsearch リクエストは、この自動フォローパターンを作成します。", + "xpack.crossClusterReplication.autoFollowPatternForm.requestFlyout.editDescriptionText": "この Elasticsearch リクエストは、この自動フォローパターンを更新します。", + "xpack.crossClusterReplication.autoFollowPatternForm.requestFlyout.namedTitle": "「{name}」のリクエスト", + "xpack.crossClusterReplication.autoFollowPatternForm.requestFlyout.unnamedTitle": "リクエスト", + "xpack.crossClusterReplication.autoFollowPatternForm.savingErrorTitle": "自動フォローパターンを作成できません", + "xpack.crossClusterReplication.autoFollowPatternForm.sectionAutoFollowPatternDescription": "カスタム接頭辞や接尾辞はフォロワーインデックス名に適用され、複製されたインデックスを見分けやすくします。デフォルトで、フォロワーインデックスにはリーダーインデックスと同じ名前が付きます。", + "xpack.crossClusterReplication.autoFollowPatternForm.sectionAutoFollowPatternNameDescription": "自動フォローパターンの固有の名前です。", + "xpack.crossClusterReplication.autoFollowPatternForm.sectionAutoFollowPatternNameTitle": "名前", + "xpack.crossClusterReplication.autoFollowPatternForm.sectionAutoFollowPatternTitle": "フォロワーインデックス (オプション)", + "xpack.crossClusterReplication.autoFollowPatternForm.sectionLeaderIndexPatternsDescription1": "リモートクラスターから複製するインデックスを識別する 1 つまたは複数のインデックスパターンです。これらのパターンと一致する新しいインデックスが作成される際、ローカルクラスターでフォロワーインデックスに複製されます。", + "xpack.crossClusterReplication.autoFollowPatternForm.sectionLeaderIndexPatternsDescription2": "{note} 既に存在するインデックスは複製されません。", + "xpack.crossClusterReplication.autoFollowPatternForm.sectionLeaderIndexPatternsDescription2.noteLabel": "注:", + "xpack.crossClusterReplication.autoFollowPatternForm.sectionLeaderIndexPatternsTitle": "リーダーインデックス", + "xpack.crossClusterReplication.autoFollowPatternForm.sectionRemoteClusterDescription": "リーダーインデックスに複製する元のリモートクラスター。", + "xpack.crossClusterReplication.autoFollowPatternForm.sectionRemoteClusterTitle": "リモートクラスター", + "xpack.crossClusterReplication.autoFollowPatternForm.validationErrorTitle": "続行する前にエラーを修正してください", + "xpack.crossClusterReplication.autoFollowPatternFormm.showRequestButtonLabel": "リクエストを表示", + "xpack.crossClusterReplication.autoFollowPatternList.addAutoFollowPatternButtonLabel": "新規自動フォローパターンを作成", + "xpack.crossClusterReplication.autoFollowPatternList.autoFollowPatternsDescription": "自動フォローパターンは、リモートクラスターからリーダーインデックスを複製し、ローカルクラスターでフォロワーインデックスにコピーします。", + "xpack.crossClusterReplication.autoFollowPatternList.autoFollowPatternsTitle": "自動フォローパターン", + "xpack.crossClusterReplication.autoFollowPatternList.crossClusterReplicationTitle": "クラスター横断レプリケーション", + "xpack.crossClusterReplication.autoFollowPatternList.emptyPromptDescription": "自動フォローパターンを使用して自動的にリモートクラスターからインデックスを複製します。", + "xpack.crossClusterReplication.autoFollowPatternList.emptyPromptTitle": "初めの自動フォローパターンの作成", + "xpack.crossClusterReplication.autoFollowPatternList.followerIndicesTitle": "フォロワーインデックス", + "xpack.crossClusterReplication.autoFollowPatternList.loadingErrorTitle": "自動フォローパターンの読み込み中にエラーが発生", + "xpack.crossClusterReplication.autoFollowPatternList.loadingTitle": "自動フォローパターンを読み込み中…", + "xpack.crossClusterReplication.autoFollowPatternList.noPermissionText": "自動フォローパターンの表示または追加パーミッションがありません。", + "xpack.crossClusterReplication.autoFollowPatternList.permissionErrorTitle": "パーミッションエラー", + "xpack.crossClusterReplication.autoFollowPatternList.table.actionDeleteDescription": "自動フォローパターンを削除", + "xpack.crossClusterReplication.autoFollowPatternList.table.actionEditDescription": "自動フォローパターンの編集", + "xpack.crossClusterReplication.autoFollowPatternList.table.actionsColumnTitle": "アクション", + "xpack.crossClusterReplication.autoFollowPatternList.table.clusterColumnTitle": "リモートクラスター", + "xpack.crossClusterReplication.autoFollowPatternList.table.leaderPatternsColumnTitle": "リーダーパターン", + "xpack.crossClusterReplication.autoFollowPatternList.table.nameColumnTitle": "名前", + "xpack.crossClusterReplication.autoFollowPatternList.table.prefixColumnTitle": "フォロワーインデックスの接頭辞", + "xpack.crossClusterReplication.autoFollowPatternList.table.suffixColumnTitle": "フォロワーインデックスの接尾辞", + "xpack.crossClusterReplication.checkLicense.errorExpiredMessage": "{licenseType} ライセンスが期限切れのため {pluginName} を使用できません", + "xpack.crossClusterReplication.checkLicense.errorUnavailableMessage": "現在ライセンス情報が利用できないため {pluginName} を使用できません。", + "xpack.crossClusterReplication.checkLicense.errorUnsupportedMessage": "ご使用の {licenseType} ライセンスは {pluginName} をサポートしていません。ライセンスをアップグレードしてください。", + "xpack.crossClusterReplication.deleteAutoFollowPattern.confirmModal.cancelButtonText": "キャンセル", + "xpack.crossClusterReplication.deleteAutoFollowPattern.confirmModal.confirmButtonText": "削除", + "xpack.crossClusterReplication.deleteAutoFollowPattern.confirmModal.deleteMultipleTitle": "{count} 個の自動フォローパターンを削除しますか?", + "xpack.crossClusterReplication.deleteAutoFollowPattern.confirmModal.deleteSingleTitle": "自動フォローパターン「{name}」を削除しますか?", + "xpack.crossClusterReplication.deleteAutoFollowPattern.confirmModal.multipleDeletionDescription": "これらの自動フォローパターンを削除しようとしています:", + "xpack.crossClusterReplication.deleteAutoFollowPatternButtonLabel": "自動フォロー{total, plural, one {パターン} other {パターン}}を削除", + "xpack.crossClusterReplication.editBreadcrumbTitle": "編集", + "xpack.crossClusterReplication.followerIndex.addAction.successNotificationTitle": "フォロワーインデックス「{name}」が追加されました", + "xpack.crossClusterReplication.followerIndex.addTitle": "フォロワーインデックスの追加", + "xpack.crossClusterReplication.followerIndex.advancedSettingsForm.showSwitchLabel": "高度な設定をカスタマイズ", + "xpack.crossClusterReplication.followerIndex.contextMenu.buttonLabel": "フォロワー{followerIndicesLength, plural, one {インデックス} other {インデックス}}の管理", + "xpack.crossClusterReplication.followerIndex.contextMenu.editLabel": "フォロワーインデックスを編集", + "xpack.crossClusterReplication.followerIndex.contextMenu.pauseLabel": "複製を中止", + "xpack.crossClusterReplication.followerIndex.contextMenu.resumeLabel": "複製を再開", + "xpack.crossClusterReplication.followerIndex.contextMenu.title": "フォロワー{followerIndicesLength, plural, one {インデックス} other {インデックス}}オプション", + "xpack.crossClusterReplication.followerIndex.contextMenu.unfollowLabel": "不明なリーダー{followerIndicesLength, plural, one {インデックス} other {インデックス}}", + "xpack.crossClusterReplication.followerIndex.editTitle": "フォロワーインデックスを編集します", + "xpack.crossClusterReplication.followerIndex.indexNameValidation.noEmptySpace": "名前にスペースは使用できません。", + "xpack.crossClusterReplication.followerIndex.leaderIndexValidation.noEmptySpace": "リーダーインデックスではスペースを使用できません。", + "xpack.crossClusterReplication.followerIndex.pauseAction.errorMultipleNotificationTitle": "{count} 件のフォロワーインデックスのパース中にエラーが発生", + "xpack.crossClusterReplication.followerIndex.pauseAction.errorSingleNotificationTitle": "フォロワーインデックス「{name}」のパース中にエラーが発生", + "xpack.crossClusterReplication.followerIndex.pauseAction.successMultipleNotificationTitle": "{count} 件のフォロワーインデックスがパースされました", + "xpack.crossClusterReplication.followerIndex.pauseAction.successSingleNotificationTitle": "フォロワーインデックス「{name}」がパースされました", + "xpack.crossClusterReplication.followerIndex.resumeAction.errorMultipleNotificationTitle": "{count} 件のフォロワーインデックスの再開中にエラーが発生", + "xpack.crossClusterReplication.followerIndex.resumeAction.errorSingleNotificationTitle": "フォロワーインデックス「{name}」の再開中にエラーが発生", + "xpack.crossClusterReplication.followerIndex.resumeAction.successMultipleNotificationTitle": "{count} 件のフォロワーインデックスが再開されました", + "xpack.crossClusterReplication.followerIndex.resumeAction.successSingleNotificationTitle": "フォロワーインデックス「{name}」が再開されました", + "xpack.crossClusterReplication.followerIndex.unfollowAction.errorMultipleNotificationTitle": "{count} 件のフォロワーインデックスの、リーダーインデックスのフォロー解除中にエラーが発生", + "xpack.crossClusterReplication.followerIndex.unfollowAction.errorSingleNotificationTitle": "フォロワーインデックス「{name}」の、リーダーインデックスのフォロー解除中にエラーが発生", + "xpack.crossClusterReplication.followerIndex.unfollowAction.notOpenWarningMultipleNotificationTitle": "{count} 件のインデックスを再度開けませんでした", + "xpack.crossClusterReplication.followerIndex.unfollowAction.notOpenWarningSingleNotificationTitle": "インデックス「{name}」を再度開けませんでした", + "xpack.crossClusterReplication.followerIndex.unfollowAction.successMultipleNotificationTitle": "{count} 件のフォロワーインデックスの、リーダーインデックスのフォローが解除されました", + "xpack.crossClusterReplication.followerIndex.unfollowAction.successSingleNotificationTitle": "フォロワーインデックス「{name}」の、リーダーインデックスのフォローが解除されました", + "xpack.crossClusterReplication.followerIndex.updateAction.successNotificationTitle": "フォロワーインデックス「{name}」が更新されました", + "xpack.crossClusterReplication.followerIndexCreateForm.loadingRemoteClustersMessage": "リモートクラスターを読み込み中…", + "xpack.crossClusterReplication.followerIndexCreateForm.saveButtonLabel": "作成", + "xpack.crossClusterReplication.followerIndexDetailPanel.activeStatus": "アクティブ", + "xpack.crossClusterReplication.followerIndexDetailPanel.closeButtonLabel": "閉じる", + "xpack.crossClusterReplication.followerIndexDetailPanel.leaderIndexLabel": "リーダーインデックス", + "xpack.crossClusterReplication.followerIndexDetailPanel.loadingLabel": "フォロワーインデックスを読み込み中…", + "xpack.crossClusterReplication.followerIndexDetailPanel.manageButtonLabel": "管理", + "xpack.crossClusterReplication.followerIndexDetailPanel.notFoundLabel": "フォロワーインデックスが見つかりません", + "xpack.crossClusterReplication.followerIndexDetailPanel.pausedFollowerCalloutTitle": "パースされたフォロワーインデックスに設定またはシャード統計がありません。", + "xpack.crossClusterReplication.followerIndexDetailPanel.pausedStatus": "一時停止中", + "xpack.crossClusterReplication.followerIndexDetailPanel.remoteClusterLabel": "リモートクラスター", + "xpack.crossClusterReplication.followerIndexDetailPanel.settingsTitle": "設定", + "xpack.crossClusterReplication.followerIndexDetailPanel.shardStatsTitle": "シャード {id} の統計", + "xpack.crossClusterReplication.followerIndexDetailPanel.statusLabel": "ステータス", + "xpack.crossClusterReplication.followerIndexDetailPanel.viewIndexLink": "インデックス管理で表示", + "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.cancelButtonText": "キャンセル", + "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.confirmAndResumeButtonText": "更新して再開", + "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.confirmButtonText": "更新", + "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.description": "フォロワーインデックスが一時停止し、再開しました。更新に失敗した場合、手動で複製を再開してみてください。", + "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.resumeDescription": "フォロワーインデックスを更新すると、リーダーインデックスの複製が再開されます。", + "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.title": "フォロワーインデックス「{id}」を更新しますか?", + "xpack.crossClusterReplication.followerIndexEditForm.loadingErrorMessage": "フォロワーインデックス「{name}」は存在しません。", + "xpack.crossClusterReplication.followerIndexEditForm.loadingErrorTitle": "フォロワーインデックスを読み込み中にエラーが発生", + "xpack.crossClusterReplication.followerIndexEditForm.loadingFollowerIndexTitle": "フォロワーインデックスを読み込み中…", + "xpack.crossClusterReplication.followerIndexEditForm.loadingRemoteClustersMessage": "リモートクラスターを読み込み中…", + "xpack.crossClusterReplication.followerIndexEditForm.saveButtonLabel": "更新", + "xpack.crossClusterReplication.followerIndexEditForm.viewFollowerIndicesButtonLabel": "フォロワーインデックスを表示", + "xpack.crossClusterReplication.followerIndexForm.actions.savingText": "保存中", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.byteUnitsHelpText": "値の例:10b、1024kb、1mb、5gb、2tb、1pb。{link}", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.byteUnitsHelpTextLinkMessage": "続きを読む", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingReadRequestsDescription": "リモートクラスターからの未了の読み込みリクエストの最高数です。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingReadRequestsLabel": "未了読み込みリクエストの最高数", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingReadRequestsTitle": "未了読み込みリクエストの最高数", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingWriteRequestsDescription": "フォロワーの未了の書き込みリクエストの最高数です", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingWriteRequestsLabel": "未了書き込みリクエストの最高数", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingWriteRequestsTitle": "未了書き込みリクエストの最高数", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestOperationCountDescription": "リモートクラスターからの読み込みごとのプーリングオペレーションの最高数です。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestOperationCountLabel": "読み込みリクエストオペレーションの最高数", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestOperationCountTitle": "読み込みリクエストオペレーションの最高数", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestSizeDescription": "リモートクラスターからプーリングされるオペレーションのバッチの読み込みごとのバイト単位の最大サイズです。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestSizeLabel": "最大読み込みリクエストサイズ", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestSizeTitle": "最大読み込みリクエストサイズ", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxRetryDelayDescription": "例外で失敗したオペレーションを再試行するまでの最長待ち時間です。再試行の際には指数バックオフの手段が取られます。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxRetryDelayLabel": "最長再試行遅延", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxRetryDelayTitle": "最長再試行遅延", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferCountDescription": "書き込み待ちにできるオペレーションの最高数です。この制限数に達すると、キューのオペレーション数が制限未満になるまで、リモートクラスターからの読み込みが延期されます。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferCountLabel": "最大書き込みバッファー数", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferCountTitle": "最大書き込みバッファー数", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferSizeDescription": "書き込み待ちにできるオペレーションの最高合計バイト数です。この制限数に達すると、キューのオペレーションの合計バイト数が制限未満になるまで、リモートクラスターからの読み込みが延期されます。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferSizeLabel": "最大書き込みバッファーサイズ", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferSizeTitle": "最大書き込みバッファーサイズ", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestOperationCountDescription": "フォロワーに実行される一斉書き込みリクエストごとのオペレーションの最高数です。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestOperationCountLabel": "書き込みリクエストオペレーションの最高数", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestOperationCountTitle": "書き込みリクエストオペレーションの最高数", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestSizeDescription": "フォロワーに実行される一斉書き込みリクエストごとのオペレーションの最高合計バイト数です。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestSizeLabel": "書き込みリクエストの最大サイズ", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestSizeTitle": "書き込みリクエストの最大サイズ", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.readPollTimeoutDescription": "フォロワーインデックスがリーダーインデックスと同期される際のリモートクラスターの新規オペレーションの最長待ち時間です。タイムアウトになった場合、統計を更新できるようオペレーションのポーリングがフォロワーに返され、フォロワーが直ちにリーダーから再度読み込みを試みます。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.readPollTimeoutLabel": "読み込みポーリングタイムアウト", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.readPollTimeoutTitle": "読み込みポーリングタイムアウト", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.timeUnitsHelpText": "値の例:2d、24h、20m、30s、500ms、10000micros、80000nanos。{link}", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.timeUnitsHelpTextLinkMessage": "続きを読む", + "xpack.crossClusterReplication.followerIndexForm.advancedSettingsDescription": "高度な設定は、複製のレートを管理します。これらの設定をカスタマイズするか、デフォルトの値を使用できます。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettingsTitle": "高度な設定 (任意)", + "xpack.crossClusterReplication.followerIndexForm.cancelButtonLabel": "キャンセル", + "xpack.crossClusterReplication.followerIndexForm.currentRemoteClusterNotConnectedCallOutDescription": "これはリモートクラスターを編集することで解決できます。", + "xpack.crossClusterReplication.followerIndexForm.currentRemoteClusterNotConnectedCallOutTitle": "リモートクラスター「{name}」が接続されていないため、フォロワーインデックスを編集できません", + "xpack.crossClusterReplication.followerIndexForm.currentRemoteClusterNotFoundCallOutDescription": "このフォロワーインデックスを編集するには、「{name}」というリモートクラスターの追加が必要です。", + "xpack.crossClusterReplication.followerIndexForm.emptyRemoteClustersCallOutDescription": "複製にはリモートクラスターのリーダーインデックスが必要です。", + "xpack.crossClusterReplication.followerIndexForm.errors.leaderIndexIllegalCharactersMessage": "リーダーインデックスから {characterList} を削除してください。", + "xpack.crossClusterReplication.followerIndexForm.errors.leaderIndexMissingMessage": "リーダーインデックスが必要です。", + "xpack.crossClusterReplication.followerIndexForm.errors.nameBeginsWithPeriodMessage": "名前はピリオドで始めることはできません。", + "xpack.crossClusterReplication.followerIndexForm.errors.nameIllegalCharactersMessage": "名前から {characterList} を削除してください。", + "xpack.crossClusterReplication.followerIndexForm.errors.nameMissingMessage": "名前が必要です。", + "xpack.crossClusterReplication.followerIndexForm.hideRequestButtonLabel": "リクエストを非表示", + "xpack.crossClusterReplication.followerIndexForm.indexAlreadyExistError": "同じ名前のインデックスが既に存在します。", + "xpack.crossClusterReplication.followerIndexForm.indexNameHelpLabel": "スペースと {characterList} は使用できません。", + "xpack.crossClusterReplication.followerIndexForm.indexNameValidatingLabel": "利用可能か確認中…", + "xpack.crossClusterReplication.followerIndexForm.indexNameValidationFatalErrorTitle": "フォロワーインデックスフォームのインデックス名の検証", + "xpack.crossClusterReplication.followerIndexForm.leaderIndexNotFoundError": "リーダーインデックス「{leaderIndex}」は存在しません。", + "xpack.crossClusterReplication.followerIndexForm.requestFlyout.closeButtonLabel": "閉じる", + "xpack.crossClusterReplication.followerIndexForm.requestFlyout.descriptionText": "この Elasticsearch リクエストは、このフォロワーインデックスを作成します。", + "xpack.crossClusterReplication.followerIndexForm.requestFlyout.title": "リクエスト", + "xpack.crossClusterReplication.followerIndexForm.resetFieldButtonLabel": "デフォルトにリセット", + "xpack.crossClusterReplication.followerIndexForm.savingErrorTitle": "フォロワーインデックスを作成できません", + "xpack.crossClusterReplication.followerIndexForm.sectionFollowerIndexNameDescription": "インデックスの固有の名前です。", + "xpack.crossClusterReplication.followerIndexForm.sectionFollowerIndexNameTitle": "フォロワーインデックス", + "xpack.crossClusterReplication.followerIndexForm.sectionLeaderIndexDescription": "フォロワーインデックスに複製するリモートクラスターのインデックスです。", + "xpack.crossClusterReplication.followerIndexForm.sectionLeaderIndexDescription2": "{note} リーダーインデックスが既に存在している必要があります。", + "xpack.crossClusterReplication.followerIndexForm.sectionLeaderIndexDescription2.noteLabel": "注:", + "xpack.crossClusterReplication.followerIndexForm.sectionLeaderIndexTitle": "リーダーインデックス", + "xpack.crossClusterReplication.followerIndexForm.sectionRemoteClusterDescription": "複製するインデックスを含むクラスターです。", + "xpack.crossClusterReplication.followerIndexForm.sectionRemoteClusterTitle": "リモートクラスター", + "xpack.crossClusterReplication.followerIndexForm.showRequestButtonLabel": "リクエストを表示", + "xpack.crossClusterReplication.followerIndexForm.validationErrorTitle": "続行する前にエラーを修正してください。", + "xpack.crossClusterReplication.followerIndexList.addFollowerButtonLabel": "フォロワーインデックスを作成", + "xpack.crossClusterReplication.followerIndexList.emptyPromptDescription": "フォロワーインデックスを使用してリモートクラスターのリーダーインデックスを複製します。", + "xpack.crossClusterReplication.followerIndexList.emptyPromptTitle": "最初のフォロワーインデックスの作成", + "xpack.crossClusterReplication.followerIndexList.followerIndicesDescription": "フォロワーインデックスはリモートクラスターのリーダーインデックスを複製します。", + "xpack.crossClusterReplication.followerIndexList.loadingErrorTitle": "フォロワーインデックスを読み込み中にエラーが発生", + "xpack.crossClusterReplication.followerIndexList.loadingTitle": "フォロワーインデックスを読み込み中…", + "xpack.crossClusterReplication.followerIndexList.noPermissionText": "フォロワーインデックスの表示または追加パーミッションがありません。", + "xpack.crossClusterReplication.followerIndexList.permissionErrorTitle": "パーミッションエラー", + "xpack.crossClusterReplication.followerIndexList.table.actionEditDescription": "フォロワーインデックスを編集します", + "xpack.crossClusterReplication.followerIndexList.table.actionPauseDescription": "複製を中止", + "xpack.crossClusterReplication.followerIndexList.table.actionResumeDescription": "複製を再開", + "xpack.crossClusterReplication.followerIndexList.table.actionsColumnTitle": "アクション", + "xpack.crossClusterReplication.followerIndexList.table.actionUnfollowDescription": "不明なリーダーインデックス", + "xpack.crossClusterReplication.followerIndexList.table.clusterColumnTitle": "リモートクラスター", + "xpack.crossClusterReplication.followerIndexList.table.leaderIndexColumnTitle": "リーダーインデックス", + "xpack.crossClusterReplication.followerIndexList.table.nameColumnTitle": "名前", + "xpack.crossClusterReplication.followerIndexList.table.statusColumn.activeLabel": "アクティブ", + "xpack.crossClusterReplication.followerIndexList.table.statusColumn.pausedLabel": "一時停止中", + "xpack.crossClusterReplication.followerIndexList.table.statusColumnTitle": "ステータス", + "xpack.crossClusterReplication.homeBreadcrumbTitle": "クラスター横断レプリケーション", + "xpack.crossClusterReplication.indexMgmtBadge.followerLabel": "フォロワー", + "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.cancelButtonText": "キャンセル", + "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.confirmButtonText": "複製を中止", + "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.multiplePauseDescription": "これらのフォロワーインデックスの複製が一時停止されます:", + "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.multiplePauseDescriptionWithSettingWarning": "フォロワーインデックスへの複製を一時停止することで、高度な設定のカスタマイズが消去されます。", + "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.pauseMultipleTitle": "{count} 件のフォロワーインデックスへの複製を一時停止しますか?", + "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.pauseSingleTitle": "フォロワーインデックス 「{name}」 への複製を一時停止しますか?", + "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.singlePauseDescriptionWithSettingWarning": "このフォロワーインデックスへの複製を一時停止することで、高度な設定のカスタマイズが消去されます。", + "xpack.crossClusterReplication.readDocsAutoFollowPatternButtonLabel": "自動フォローパターンドキュメント", + "xpack.crossClusterReplication.readDocsFollowerIndexButtonLabel": "フォロワーインデックスドキュメント", + "xpack.crossClusterReplication.remoteClustersFormField.addRemoteClusterButtonLabel": "リモートクラスターを追加", + "xpack.crossClusterReplication.remoteClustersFormField.currentRemoteClusterNotConnectedCallOutDescription": "リモートクラスターを編集するか、接続されているクラスターを選択します。", + "xpack.crossClusterReplication.remoteClustersFormField.currentRemoteClusterNotConnectedCallOutTitle": "リモートクラスター「{name}」が接続されていません", + "xpack.crossClusterReplication.remoteClustersFormField.emptyRemoteClustersCallOutDescription": "フォロワーインデックスを作成するには最低 1 つのリモートクラスターが必要です。", + "xpack.crossClusterReplication.remoteClustersFormField.emptyRemoteClustersCallOutTitle": "リモートクラスターがありません", + "xpack.crossClusterReplication.remoteClustersFormField.fieldClusterLabel": "リモートクラスター", + "xpack.crossClusterReplication.remoteClustersFormField.invalidRemoteClusterError": "無効なリモートクラスター", + "xpack.crossClusterReplication.remoteClustersFormField.remoteClusterDropdownNotConnected": "{name} (未接続)", + "xpack.crossClusterReplication.remoteClustersFormField.remoteClusterNotFoundTitle": "リモートクラスター「{name}」が見つかりませんでした", + "xpack.crossClusterReplication.remoteClustersFormField.validRemoteClusterRequired": "接続されたリモートクラスターが必要です。", + "xpack.crossClusterReplication.remoteClustersFormField.viewRemoteClusterButtonLabel": "リモートクラスターを編集", + "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.cancelButtonText": "キャンセル", + "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.confirmButtonText": "複製を再開", + "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.multipleResumeDescription": "これらのフォロワーインデックスの複製が再開されます:", + "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.multipleResumeDescriptionWithSettingWarning": "複製はデフォルトの高度な設定で再開されます。", + "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.resumeMultipleTitle": "{count} 件のフォロワーインデックスへの複製を再開しますか?", + "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.resumeSingleTitle": "フォロワーインデックス「{name}」への複製を再開しますか?", + "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.singleResumeDescription": "複製はデフォルトの高度な設定で再開されます。カスタマイズされた高度な設定を使用するには、{editLink}。", + "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.singleResumeEditLink": "フォロワーインデックスを編集", + "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.cancelButtonText": "キャンセル", + "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.confirmButtonText": "不明なリーダー", + "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.multipleUnfollowDescription": "フォロワーインデックスは標準のインデックスに変換されます。今後クラスター横断レプリケーションには表示されませんが、インデックス管理で管理できます。この操作は元に戻すことができません。", + "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.singleUnfollowDescription": "フォロワーインデックスは標準のインデックスに変換されます。今後クラスター横断レプリケーションには表示されませんが、インデックス管理で管理できます。この操作は元に戻すことができません。", + "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.unfollowMultipleTitle": "{count} 件のリーダーインデックスのフォローを解除しますか?", + "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.unfollowSingleTitle": "「{name}」のリーダーインデックスのフォローを解除しますか?", + "xpack.dashboardMode.dashboardViewer.dashboardDescription": "ダッシュボードビューアー", + "xpack.dashboardMode.dashboardViewer.dashboardTitle": "ダッシュボード", + "xpack.dashboardMode.dashboardViewerDescription": "ダッシュボードを表示", + "xpack.dashboardMode.dashboardViewerTitle": "ダッシュボードビューアー", + "xpack.dashboardMode.uiSettings.dashboardsOnlyRolesDescription": "ダッシュボード表示専用モードのロールです", + "xpack.dashboardMode.uiSettings.dashboardsOnlyRolesTitle": "ダッシュボード専用ロール", "xpack.features.advancedSettingsFeatureName": "高度な設定", "xpack.features.dashboardFeatureName": "ダッシュボード", "xpack.features.devToolsFeatureName": "開発ツール", @@ -12546,6 +5646,1158 @@ "xpack.features.indexPatternFeatureName": "インデックスパターン管理", "xpack.features.savedObjectsManagementFeatureName": "保存されたオブジェクトの管理", "xpack.features.visualizeFeatureName": "可視化", + "xpack.fileUpload.enterIndexName": "インデックス名を入力", + "xpack.fileUpload.fileParser.errorReadingFile": "ファイルの読み込み中にエラーが発生しました", + "xpack.fileUpload.fileParser.noFeaturesDetected": "エラー、機能が検出されませんでした", + "xpack.fileUpload.fileParser.noFileProvided": "エラー、ファイルが提供されていません", + "xpack.fileUpload.fileParser.transformDetailsNotDefined": "{transformDetails}のインデックスオプションが定義されていません", + "xpack.fileUpload.httpService.fetchError": "フェッチ実行エラー:{error}", + "xpack.fileUpload.httpService.noUrl": "URLが指定されていません", + "xpack.fileUpload.indexingService.errorCreatingIndex": "インデックスの作成中にエラーが発生しました", + "xpack.fileUpload.indexingService.noFileImported": "ファイルはインポートされていません。", + "xpack.fileUpload.indexingService.noHandlingForTransform": "変換の処理が定義されていません。{transform}", + "xpack.fileUpload.indexingService.noIndexingDetailsForDatatype": "データ型のインデックス詳細が定義されていません。{dataType}", + "xpack.fileUpload.indexingService.noTransformDefined": "変換が定義されていません", + "xpack.fileUpload.indexingService.transformResultError": "データの変換エラー:{error}", + "xpack.fileUpload.indexingService.unknownTransformError": "変換の実行中に不明なエラーが発生しました。{transform}", + "xpack.fileUpload.indexNameReqField": "インデックス名、必須フィールド", + "xpack.fileUpload.indexSettings.enterIndexNameLabel": "インデックス名", + "xpack.fileUpload.indexSettings.enterIndexTypeLabel": "インデックスタイプ", + "xpack.fileUpload.indexSettings.guidelines.cannotBe": ".または..にすることはできません。", + "xpack.fileUpload.indexSettings.guidelines.cannotInclude": "\\\\、/、*、?、\"、<、>、|、 \" \"(スペース文字)、,(カンマ)、#を使用することはできません。", + "xpack.fileUpload.indexSettings.guidelines.cannotStartWith": "-、_、+を先頭にすることはできません", + "xpack.fileUpload.indexSettings.guidelines.length": "256バイト以上にすることはできません(これはバイト数であるため、複数バイト文字では255文字の文字制限のカウントが速くなります)", + "xpack.fileUpload.indexSettings.guidelines.lowercaseOnly": "小文字のみ", + "xpack.fileUpload.indexSettings.guidelines.mustBeNewIndex": "新しいインデックスを作成する必要があります", + "xpack.fileUpload.indexSettings.indexNameAlreadyExistsErrorMessage": "インデックス名またはパターンは既に存在します。", + "xpack.fileUpload.indexSettings.indexNameContainsIllegalCharactersErrorMessage": "インデックス名に許可されていない文字が含まれています", + "xpack.fileUpload.indexSettings.indexNameGuidelines": "インデックス名ガイドライン", + "xpack.fileUpload.jsonImport.indexingResponse": "インデックス応答", + "xpack.fileUpload.jsonImport.indexingStatus": "インデックスステータス", + "xpack.fileUpload.jsonImport.indexMgmtLink": "インデックス管理", + "xpack.fileUpload.jsonImport.indexModsMsg": "次を使用すると、その他のインデックス修正を行うことができます。\n", + "xpack.fileUpload.jsonImport.indexPatternResponse": "インデックスパターン応答", + "xpack.fileUpload.jsonIndexFilePicker.acceptableFileSize": "ファイルサイズ {fileSize} は最大ファイルサイズの{maxFileSize} を超えています", + "xpack.fileUpload.jsonIndexFilePicker.acceptableTypesError": "ファイルは使用可能なタイプのいずれかではありません。{types}", + "xpack.fileUpload.jsonIndexFilePicker.fileParseError": "ファイル解析エラーが検出されました: {error}", + "xpack.fileUpload.jsonIndexFilePicker.filePicker": "ファイルをアップロード", + "xpack.fileUpload.jsonIndexFilePicker.filePickerLabel": "アップロードするファイルを選択", + "xpack.fileUpload.jsonIndexFilePicker.fileProcessingError": "ファイル処理エラー: {errorMessage}", + "xpack.fileUpload.jsonIndexFilePicker.fileSizeError": "ファイルサイズエラー: {errorMessage}", + "xpack.fileUpload.jsonIndexFilePicker.formatsAccepted": "許可されている形式:.json、.geojson", + "xpack.fileUpload.jsonIndexFilePicker.maxSize": "最大サイズ:{maxFileSize}", + "xpack.fileUpload.jsonIndexFilePicker.noFileNameError": "ファイル名が指定されていません", + "xpack.fileUpload.jsonIndexFilePicker.parsingFile": "{featuresProcessed} 件の機能が解析されました…", + "xpack.fileUpload.jsonIndexFilePicker.unableParseFile": "ファイルをパースできません。{error}", + "xpack.fileUpload.jsonUploadAndParse.creatingIndexPattern": "インデックスパターンを作成中です", + "xpack.fileUpload.jsonUploadAndParse.dataIndexingError": "データインデックスエラー", + "xpack.fileUpload.jsonUploadAndParse.dataIndexingStarted": "データインデックスが開始しました", + "xpack.fileUpload.jsonUploadAndParse.indexingComplete": "インデックス完了", + "xpack.fileUpload.jsonUploadAndParse.indexPatternComplete": "インデックスパターンの完了", + "xpack.fileUpload.jsonUploadAndParse.indexPatternError": "インデックスパターンエラー", + "xpack.fileUpload.jsonUploadAndParse.writingToIndex": "インデックスに書き込み中", + "xpack.fileUpload.noIndexSuppliedErrorMessage": "インデックスが指定されていません。", + "xpack.fileUpload.patternReader.featuresOmitted": "ジオメトリのない一部の機能は省略されました", + "xpack.graph.badge.readOnly.text": "読み込み専用", + "xpack.graph.badge.readOnly.tooltip": "Graph ワークスペースを保存できません", + "xpack.graph.bar.exploreLabel": "グラフ", + "xpack.graph.bar.pickFieldsLabel": "フィールドを追加", + "xpack.graph.bar.pickSourceLabel": "データソースを選択", + "xpack.graph.bar.pickSourceTooltip": "グラフの関係性を開始するデータソースを選択します。", + "xpack.graph.bar.searchFieldPlaceholder": "データを検索してグラフに追加", + "xpack.graph.blacklist.noEntriesDescription": "ブロックされた用語がありません。頂点を選択して、右側のコントロールパネルの {stopSign} をクリックしてブロックします。ブロックされた用語に一致するドキュメントは今後表示されず、関係性が非表示になります。", + "xpack.graph.blacklist.removeButtonAriaLabel": "削除", + "xpack.graph.clearWorkspace.confirmButtonLabel": "データソースを変更", + "xpack.graph.clearWorkspace.confirmText": "データソースを変更すると、現在のフィールドと頂点がリセットされます。", + "xpack.graph.clearWorkspace.modalTitle": "保存されていない変更", + "xpack.graph.drilldowns.description": "ドリルダウンで他のアプリケーションにリンクします。選択された頂点が URL の一部になります。", + "xpack.graph.errorToastTitle": "Graph エラー", + "xpack.graph.exploreGraph.timedOutWarningText": "閲覧がタイムアウトしました", + "xpack.graph.featureRegistry.graphFeatureName": "グラフ", + "xpack.graph.fieldManager.cancelLabel": "キャンセル", + "xpack.graph.fieldManager.colorLabel": "色", + "xpack.graph.fieldManager.deleteFieldLabel": "フィールドの選択を解除しました", + "xpack.graph.fieldManager.deleteFieldTooltipContent": "このフィールドの新規頂点は検出されなくなります。 既存の頂点はグラフに残されます。", + "xpack.graph.fieldManager.disabledFieldBadgeDescription": "無効なフィールド {field}:構成するにはクリックしてください。Shift+クリックで有効にします。", + "xpack.graph.fieldManager.disableFieldLabel": "フィールドを無効にする", + "xpack.graph.fieldManager.disableFieldTooltipContent": "このフィールドの頂点の検出をオフにします。フィールドを Shift+クリックしても無効にできます。", + "xpack.graph.fieldManager.enableFieldLabel": "フィールドを有効にする", + "xpack.graph.fieldManager.enableFieldTooltipContent": "このフィールドの頂点の検出をオンにします。フィールドを Shift+クリックしても有効にできます。", + "xpack.graph.fieldManager.fieldBadgeDescription": "フィールド {field}:構成するにはクリックしてください。Shift+クリックで無効にします", + "xpack.graph.fieldManager.fieldLabel": "フィールド", + "xpack.graph.fieldManager.fieldSearchPlaceholder": "フィルタリング条件:", + "xpack.graph.fieldManager.iconLabel": "アイコン", + "xpack.graph.fieldManager.maxTermsPerHopDescription": "各検索ステップで返されるアイテムの最大数をコントロールします。", + "xpack.graph.fieldManager.maxTermsPerHopLabel": "ホップごとの用語数", + "xpack.graph.fieldManager.settingsFormTitle": "編集", + "xpack.graph.fieldManager.settingsLabel": "設定の変更", + "xpack.graph.fieldManager.updateLabel": "変更を保存", + "xpack.graph.fillWorkspaceError": "トップアイテムの取得に失敗しました: {message}", + "xpack.graph.guidancePanel.datasourceItem.indexPatternButtonLabel": "データソースを選択", + "xpack.graph.guidancePanel.fieldsItem.fieldsButtonLabel": "フィールドを追加。", + "xpack.graph.guidancePanel.nodesItem.description": "閲覧を始めるには、検索バーにクエリを入力してください。どこから始めていいかわかりませんか?{topTerms}。", + "xpack.graph.guidancePanel.nodesItem.topTermsButtonLabel": "トップアイテムをグラフ化", + "xpack.graph.guidancePanel.title": "グラフ作成の 3 つのステップ", + "xpack.graph.home.breadcrumb": "グラフ", + "xpack.graph.icon.areaChart": "面グラフ", + "xpack.graph.icon.at": "に", + "xpack.graph.icon.automobile": "自動車", + "xpack.graph.icon.bank": "銀行", + "xpack.graph.icon.barChart": "棒グラフ", + "xpack.graph.icon.bolt": "ボルト", + "xpack.graph.icon.cube": "キューブ", + "xpack.graph.icon.desktop": "デスクトップ", + "xpack.graph.icon.exclamation": "感嘆符", + "xpack.graph.icon.externalLink": "外部リンク", + "xpack.graph.icon.eye": "目", + "xpack.graph.icon.file": "開いているファイル", + "xpack.graph.icon.fileText": "ファイル", + "xpack.graph.icon.flag": "旗", + "xpack.graph.icon.folderOpen": "開いているフォルダ", + "xpack.graph.icon.font": "フォント", + "xpack.graph.icon.globe": "球", + "xpack.graph.icon.google": "Google", + "xpack.graph.icon.heart": "ハート", + "xpack.graph.icon.home": "ホーム", + "xpack.graph.icon.industry": "業界", + "xpack.graph.icon.info": "情報", + "xpack.graph.icon.key": "キー", + "xpack.graph.icon.lineChart": "折れ線グラフ", + "xpack.graph.icon.list": "一覧", + "xpack.graph.icon.mapMarker": "マップマーカー", + "xpack.graph.icon.music": "音楽", + "xpack.graph.icon.phone": "電話", + "xpack.graph.icon.pieChart": "円グラフ", + "xpack.graph.icon.plane": "飛行機", + "xpack.graph.icon.question": "質問", + "xpack.graph.icon.shareAlt": "alt を共有", + "xpack.graph.icon.table": "表", + "xpack.graph.icon.tachometer": "タコメーター", + "xpack.graph.icon.user": "ユーザー", + "xpack.graph.icon.users": "ユーザー", + "xpack.graph.inspect.requestTabTitle": "リクエスト", + "xpack.graph.inspect.responseTabTitle": "応答", + "xpack.graph.inspect.title": "検査", + "xpack.graph.leaveWorkspace.confirmButtonLabel": "それでも移動", + "xpack.graph.leaveWorkspace.confirmText": "今移動すると、保存されていない変更が失われます。", + "xpack.graph.leaveWorkspace.modalTitle": "保存されていない変更", + "xpack.graph.listing.createNewGraph.combineDataViewFromKibanaAppDescription": "Elasticsearch インデックスのパターンと関係性を検出します。", + "xpack.graph.listing.createNewGraph.createButtonLabel": "グラフを作成", + "xpack.graph.listing.createNewGraph.newToKibanaDescription": "Kibana は初めてですか?{sampleDataInstallLink} で始めましょう。", + "xpack.graph.listing.createNewGraph.sampleDataInstallLinkText": "サンプルデータ", + "xpack.graph.listing.createNewGraph.title": "初めてのグラフを作成してみましょう。", + "xpack.graph.listing.graphsTitle": "グラフ", + "xpack.graph.listing.noDataSource.newToKibanaDescription": "Kibana は初めてですか?{sampleDataInstallLink} も使用できます。", + "xpack.graph.listing.noDataSource.sampleDataInstallLinkText": "サンプルデータ", + "xpack.graph.listing.noItemsMessage": "グラフがないようです。", + "xpack.graph.listing.table.descriptionColumnName": "説明", + "xpack.graph.listing.table.entityName": "グラフ", + "xpack.graph.listing.table.entityNamePlural": "グラフ", + "xpack.graph.listing.table.titleColumnName": "タイトル", + "xpack.graph.loadWorkspace.missingIndexPatternErrorMessage": "インデックスパターンが見つかりませんでした", + "xpack.graph.missingWorkspaceErrorMessage": "ワークスペースがありません", + "xpack.graph.newGraphTitle": "保存されていないグラフ", + "xpack.graph.noDataSourceNotificationMessageText": "データソースが見つかりませんでした。{managementIndexPatternsLink} に移動して Elasticsearch インデックスのインデックスパターンを作成してください。", + "xpack.graph.noDataSourceNotificationMessageText.managementIndexPatternLinkText": "管理>インデックスパターン", + "xpack.graph.noDataSourceNotificationMessageTitle": "データソースがありません", + "xpack.graph.outlinkEncoders.esqPlainDescription": "標準 URL エンコードの JSON", + "xpack.graph.outlinkEncoders.esqPlainTitle": "Elasticsearch クエリ (プレインエンコード)", + "xpack.graph.outlinkEncoders.esqRisonDescription": "Rison エンコードの JSON、minimum_should_match=2、ほとんどの Kibana URL に対応", + "xpack.graph.outlinkEncoders.esqRisonLooseDescription": "Rison エンコードの JSON、minimum_should_match=1、ほとんどの Kibana URL に対応", + "xpack.graph.outlinkEncoders.esqRisonLooseTitle": "Elasticsearch OR クエリ (Rison エンコード)", + "xpack.graph.outlinkEncoders.esqRisonTitle": "Elasticsearch AND クエリ (Rison エンコード)", + "xpack.graph.outlinkEncoders.esqSimilarRisonDescription": "Rison エンコードの JSON、欠けているドキュメントを検索するための「これに似ているがこれではない」といったタイプのクエリです", + "xpack.graph.outlinkEncoders.esqSimilarRisonTitle": "Elasticsearch more like this クエリ (Rison エンコード)", + "xpack.graph.outlinkEncoders.kqlLooseDescription": "KQL クエリ、ディスカバリ、可視化、ダッシュボードに対応", + "xpack.graph.outlinkEncoders.kqlLooseTitle": "KQL OR クエリ", + "xpack.graph.outlinkEncoders.kqlTitle": "KQL AND クエリ", + "xpack.graph.outlinkEncoders.textLuceneDescription": "選択された Lucene 特殊文字エンコードを含む頂点ラベルのテキストです", + "xpack.graph.outlinkEncoders.textLuceneTitle": "Lucene エスケープテキスト", + "xpack.graph.outlinkEncoders.textPlainDescription": "選択されたパス URL エンコード文字列としての頂点ラベル のテキストです", + "xpack.graph.outlinkEncoders.textPlainTitle": "プレインテキスト", + "xpack.graph.pluginDescription": "Elasticsearch データの関連性のある関係を浮上させ分析します。", + "xpack.graph.savedWorkspace.workspaceNameTitle": "新規グラフワークスペース", + "xpack.graph.savedWorkspaces.graphWorkspaceLabel": "グラフワークスペース", + "xpack.graph.savedWorkspaces.graphWorkspacesLabel": "グラフワークスペース", + "xpack.graph.saveWorkspace.savingErrorMessage": "ワークスペースの保存に失敗しました: {message}", + "xpack.graph.saveWorkspace.successNotification.noDataSavedText": "構成が保存されましたが、データは保存されませんでした", + "xpack.graph.saveWorkspace.successNotificationTitle": "「{workspaceTitle}」が保存されました", + "xpack.graph.serverSideErrors.unavailableGraphErrorMessage": "グラフを利用できません", + "xpack.graph.serverSideErrors.unavailableLicenseInformationErrorMessage": "グラフを利用できません。現在ライセンス情報が利用できません。", + "xpack.graph.settings.advancedSettings.certaintyInputHelpText": "関連用語が登録される前に証拠として必要なドキュメントの最低数です", + "xpack.graph.settings.advancedSettings.certaintyInputLabel": "確実性", + "xpack.graph.settings.advancedSettings.diversityFieldInputHelpText1": "ドキュメントのサンプルが 1 種類に偏らないように、バイアスの原因の認識に役立つフィールドを選択してください。", + "xpack.graph.settings.advancedSettings.diversityFieldInputHelpText2": "1 つの用語のフィールドを選択しないと、検索がエラーで拒否されます", + "xpack.graph.settings.advancedSettings.diversityFieldInputLabel": "多様性フィールド", + "xpack.graph.settings.advancedSettings.diversityFieldInputOptionLabel": "[多様化なし)", + "xpack.graph.settings.advancedSettings.maxValuesInputHelpText": "同じ値を含めることのできるサンプルのドキュメントの最大数です", + "xpack.graph.settings.advancedSettings.maxValuesInputHelpText.fieldText": "フィールド", + "xpack.graph.settings.advancedSettings.maxValuesInputLabel": "フィールドごとの最大ドキュメント数", + "xpack.graph.settings.advancedSettings.sampleSizeInputHelpText": "用語は最も関連性の高いドキュメントのサンプルから認識されます。サンプルは大きければ良いというものではありません。動作が遅くなり関連性が低くなる可能性があります。", + "xpack.graph.settings.advancedSettings.sampleSizeInputLabel": "サンプルサイズ", + "xpack.graph.settings.advancedSettings.significantLinksCheckboxHelpText": "ただ利用頻度が高いだけでなく「重要」な用語を認識します", + "xpack.graph.settings.advancedSettings.significantLinksCheckboxLabel": "重要なリンク", + "xpack.graph.settings.advancedSettings.timeoutInputHelpText": "リクエストが実行可能なミリ秒単位での最長時間です", + "xpack.graph.settings.advancedSettings.timeoutInputLabel": "タイムアウト (ms)", + "xpack.graph.settings.advancedSettings.timeoutUnit": "ms", + "xpack.graph.settings.advancedSettingsTitle": "高度な設定", + "xpack.graph.settings.blacklist.blacklistHelpText": "これらの用語は現在ワークスペースに再度表示されないようブラックリストに登録されています", + "xpack.graph.settings.blacklist.clearButtonLabel": "消去", + "xpack.graph.settings.blacklistTitle": "ブラックリスト", + "xpack.graph.settings.closeLabel": "閉じる", + "xpack.graph.settings.drillDowns.cancelButtonLabel": "キャンセル", + "xpack.graph.settings.drillDowns.defaultUrlTemplateTitle": "生ドキュメント", + "xpack.graph.settings.drillDowns.invalidUrlWarningText": "URL には {placeholder} 文字列を含める必要があります。", + "xpack.graph.settings.drillDowns.kibanaUrlWarningConvertOptionLinkText": "変換する。", + "xpack.graph.settings.drillDowns.kibanaUrlWarningText": "これは Kibana URL のようです。テンプレートに変換しますか?", + "xpack.graph.settings.drillDowns.newSaveButtonLabel": "ドリルダウンを保存", + "xpack.graph.settings.drillDowns.removeButtonLabel": "削除", + "xpack.graph.settings.drillDowns.resetButtonLabel": "リセット", + "xpack.graph.settings.drillDowns.toolbarIconPickerLabel": "ツールバーアイコン", + "xpack.graph.settings.drillDowns.updateSaveButtonLabel": "ドリルダウンを更新", + "xpack.graph.settings.drillDowns.urlDescriptionInputLabel": "タイトル", + "xpack.graph.settings.drillDowns.urlDescriptionInputPlaceholder": "Google で検索", + "xpack.graph.settings.drillDowns.urlEncoderInputLabel": "URL パラメータータイプ", + "xpack.graph.settings.drillDowns.urlInputHelpText": "選択された頂点用語が挿入された場所に {gquery} でテンプレート URL を定義してください", + "xpack.graph.settings.drillDowns.urlInputLabel": "URL", + "xpack.graph.settings.drillDownsTitle": "ドリルダウン", + "xpack.graph.settings.title": "設定", + "xpack.graph.sidebar.displayLabelHelpText": "この頂点の票を変更", + "xpack.graph.sidebar.displayLabelLabel": "ラベルを表示", + "xpack.graph.sidebar.drillDowns.noDrillDownsHelpText": "設定メニューからドリルダウンを構成します", + "xpack.graph.sidebar.drillDownsTitle": "ドリルダウン", + "xpack.graph.sidebar.groupButtonLabel": "グループ", + "xpack.graph.sidebar.groupButtonTooltip": "現在選択された項目を {latestSelectionLabel} にグループ分けします", + "xpack.graph.sidebar.linkSummary.bothTermsCountTooltip": "{count} 件のドキュメントに両方の用語があります", + "xpack.graph.sidebar.linkSummary.leftTermCountTooltip": "{count} 件のドキュメントに {term} があります", + "xpack.graph.sidebar.linkSummary.mergeTerm1ToTerm2ButtonTooltip": "{term1} を {term2} に結合します", + "xpack.graph.sidebar.linkSummary.mergeTerm2ToTerm1ButtonTooltip": "{term2} を {term1} に結合します", + "xpack.graph.sidebar.linkSummary.rightTermCountTooltip": "{count} 件のドキュメントに {term} があります", + "xpack.graph.sidebar.linkSummaryTitle": "リンクの概要", + "xpack.graph.sidebar.selections.invertSelectionButtonLabel": "反転", + "xpack.graph.sidebar.selections.invertSelectionButtonTooltip": "選択を反転させます", + "xpack.graph.sidebar.selections.noSelectionsHelpText": "選択項目がありません。頂点をクリックして追加します。", + "xpack.graph.sidebar.selections.selectAllButtonLabel": "すべて", + "xpack.graph.sidebar.selections.selectAllButtonTooltip": "すべて選択", + "xpack.graph.sidebar.selections.selectNeighboursButtonLabel": "リンク", + "xpack.graph.sidebar.selections.selectNeighboursButtonTooltip": "隣を選択します", + "xpack.graph.sidebar.selections.selectNoneButtonLabel": "なし", + "xpack.graph.sidebar.selections.selectNoneButtonTooltip": "どれも選択しません", + "xpack.graph.sidebar.selectionsTitle": "選択項目", + "xpack.graph.sidebar.styleVerticesTitle": "スタイルが選択された頂点", + "xpack.graph.sidebar.topMenu.addLinksButtonTooltip": "既存の用語の間にリンクを追加します", + "xpack.graph.sidebar.topMenu.blacklistButtonTooltip": "選択項目がワークスペースに戻らないようブラックリストに追加します", + "xpack.graph.sidebar.topMenu.customStyleButtonTooltip": "選択された頂点のカスタムスタイル", + "xpack.graph.sidebar.topMenu.drillDownButtonTooltip": "ドリルダウン", + "xpack.graph.sidebar.topMenu.expandSelectionButtonTooltip": "選択項目を拡張", + "xpack.graph.sidebar.topMenu.pauseLayoutButtonTooltip": "レイアウトを一時停止", + "xpack.graph.sidebar.topMenu.redoButtonTooltip": "やり直す", + "xpack.graph.sidebar.topMenu.removeVerticesButtonTooltip": "ワークスペースから頂点を削除", + "xpack.graph.sidebar.topMenu.runLayoutButtonTooltip": "レイアウトを実行", + "xpack.graph.sidebar.topMenu.undoButtonTooltip": "元に戻す", + "xpack.graph.sidebar.ungroupButtonLabel": "グループ解除", + "xpack.graph.sidebar.ungroupButtonTooltip": "{latestSelectionLabel} のグループを解除", + "xpack.graph.sourceModal.notFoundLabel": "データソースが見つかりませんでした。", + "xpack.graph.sourceModal.savedObjectType.indexPattern": "インデックスパターン", + "xpack.graph.sourceModal.title": "データソースを選択", + "xpack.graph.templates.addLabel": "新規ドリルダウン", + "xpack.graph.templates.newTemplateFormLabel": "ドリルダウンを追加", + "xpack.graph.topNavMenu.inspectAriaLabel": "検査", + "xpack.graph.topNavMenu.inspectLabel": "検査", + "xpack.graph.topNavMenu.newWorkspaceAriaLabel": "新規ワークスペース", + "xpack.graph.topNavMenu.newWorkspaceLabel": "新規", + "xpack.graph.topNavMenu.newWorkspaceTooltip": "新規ワークスペースを作成します", + "xpack.graph.topNavMenu.save.descriptionInputLabel": "説明", + "xpack.graph.topNavMenu.save.objectType": "グラフ", + "xpack.graph.topNavMenu.save.saveConfigurationOnlyText": "このワークスペースのデータは消去され、構成のみが保存されます", + "xpack.graph.topNavMenu.save.saveConfigurationOnlyWarning": "このワークスペースのデータは消去され、構成のみが保存されます", + "xpack.graph.topNavMenu.save.saveGraphContentCheckboxLabel": "Graph コンテンツを保存", + "xpack.graph.topNavMenu.saveWorkspace.disabledTooltip": "現在の保存ポリシーでは、保存されたワークスペースへの変更が許可されていません", + "xpack.graph.topNavMenu.saveWorkspace.enabledAriaLabel": "ワークスペースを保存", + "xpack.graph.topNavMenu.saveWorkspace.enabledLabel": "保存", + "xpack.graph.topNavMenu.saveWorkspace.enabledTooltip": "このワークスペースを保存します", + "xpack.graph.topNavMenu.settingsAriaLabel": "設定", + "xpack.graph.topNavMenu.settingsLabel": "設定", + "xpack.grokDebugger.customPatterns.callOutTitle": "1 行に付き 1 つのカスタムパターンを入力してください例:", + "xpack.grokDebugger.customPatternsButtonLabel": "カスタムパターン", + "xpack.grokDebugger.displayName": "Grok デバッガー", + "xpack.grokDebugger.grokPatternLabel": "Grok パターン", + "xpack.grokDebugger.licenseHasExpiredMessage": "{licenseType} ライセンスが期限切れのため {grokLogParsingTool} デバッガーを使用できません", + "xpack.grokDebugger.patternsErrorMessage": "提供された {grokLogParsingTool} パターンがインプットのデータと一致していません", + "xpack.grokDebugger.registryProviderDescription": "{grokLogParsingTool} パターンを、投入時にデータ変換用にシミュレートしデバッグします。", + "xpack.grokDebugger.registryProviderTitle": "{grokLogParsingTool} デバッガー", + "xpack.grokDebugger.sampleDataLabel": "サンプルデータ", + "xpack.grokDebugger.simulateButtonLabel": "シミュレート", + "xpack.grokDebugger.structuredDataLabel": "構造化データ", + "xpack.grokDebugger.unavailableLicenseInformationMessage": "現在ライセンス情報が利用できないため {grokLogParsingTool} デバッガーを使用できません。", + "xpack.idxMgmt.appTitle": "インデックス管理", + "xpack.idxMgmt.badgeAriaLabel": "{label}。これをフィルタリングするよう選択。", + "xpack.idxMgmt.breadcrumb.cloneTemplateLabel": "テンプレートのクローンを作成", + "xpack.idxMgmt.breadcrumb.createTemplateLabel": "テンプレートを作成", + "xpack.idxMgmt.breadcrumb.editTemplateLabel": "テンプレートを編集", + "xpack.idxMgmt.breadcrumb.homeLabel": "インデックス管理", + "xpack.idxMgmt.breadcrumb.templatesLabel": "テンプレート", + "xpack.idxMgmt.clearCacheIndicesAction.successMessage": "キャッシュ [{indexNames}] が削除されました:", + "xpack.idxMgmt.closeIndicesAction.successfullyClosedIndicesMessage": "[{indexNames}] がクローズされました", + "xpack.idxMgmt.createRoute.duplicateTemplateIdErrorMessage": "「{name}」という名前のテンプレートが既に存在します。", + "xpack.idxMgmt.createTemplate.cloneTemplatePageTitle": "テンプレート「{name}」のクローンの作成", + "xpack.idxMgmt.createTemplate.createTemplatePageTitle": "テンプレートを作成", + "xpack.idxMgmt.deleteIndicesAction.successfullyDeletedIndicesMessage": "[{indexNames}] が削除されました", + "xpack.idxMgmt.deleteTemplatesModal.cancelButtonLabel": "キャンセル", + "xpack.idxMgmt.deleteTemplatesModal.confirmButtonLabel": "{numTemplatesToDelete, plural, one {テンプレート} other {テンプレート} }を削除", + "xpack.idxMgmt.deleteTemplatesModal.confirmDeleteCheckboxLabel": "システムテンプレートを削除することの重大な影響を理解しています", + "xpack.idxMgmt.deleteTemplatesModal.deleteDescription": "{numTemplatesToDelete, plural, one {このテンプレート} other {これらのテンプレート} }を削除しようとしています:", + "xpack.idxMgmt.deleteTemplatesModal.errorNotificationMessageText": "テンプレート「{name}」の削除中にエラーが発生", + "xpack.idxMgmt.deleteTemplatesModal.modalTitleText": "{numTemplatesToDelete, plural, one {テンプレート} other {テンプレート}}の削除", + "xpack.idxMgmt.deleteTemplatesModal.multipleErrorsNotificationMessageText": "{count} 個のテンプレートの削除中にエラーが発生", + "xpack.idxMgmt.deleteTemplatesModal.proceedWithCautionCallOutDescription": "システムテンプレートは内部オペレーションに不可欠です。このテンプレートを削除すると、復元することはできません。", + "xpack.idxMgmt.deleteTemplatesModal.proceedWithCautionCallOutTitle": "システムテンプレートを削除することで、Kibana に重大な障害が生じる可能性があります", + "xpack.idxMgmt.deleteTemplatesModal.successDeleteMultipleNotificationMessageText": "{numSuccesses, plural, one {テンプレート} other {テンプレート}}を削除しました", + "xpack.idxMgmt.deleteTemplatesModal.successDeleteSingleNotificationMessageText": "テンプレート「{templateName}」を削除しました", + "xpack.idxMgmt.deleteTemplatesModal.systemTemplateLabel": "システムテンプレート", + "xpack.idxMgmt.detailPanel.manageContextMenuLabel": "管理", + "xpack.idxMgmt.detailPanel.missingIndexMessage": "このインデックスは存在しません。実行中のジョブや別のシステムにより削除された可能性があります。", + "xpack.idxMgmt.detailPanel.missingIndexTitle": "インデックスがありません", + "xpack.idxMgmt.detailPanel.tabEditSettingsLabel": "設定の変更", + "xpack.idxMgmt.detailPanel.tabMappingLabel": "マッピング", + "xpack.idxMgmt.detailPanel.tabSettingsLabel": "設定", + "xpack.idxMgmt.detailPanel.tabStatsLabel": "統計", + "xpack.idxMgmt.detailPanel.tabSummaryLabel": "まとめ", + "xpack.idxMgmt.editIndexSettingsAction.successfullySavedSettingsForIndicesMessage": "{indexName} の設定が保存されました", + "xpack.idxMgmt.editSettingsJSON.saveJSONButtonLabel": "保存", + "xpack.idxMgmt.editSettingsJSON.saveJSONDescription": "変更して JSON を保存します", + "xpack.idxMgmt.editSettingsJSON.settingsReferenceLinkText": "設定レファレンス", + "xpack.idxMgmt.editTemplate.editTemplatePageTitle": "テンプレート「{name}」を編集", + "xpack.idxMgmt.flushIndicesAction.successfullyFlushedIndicesMessage": "[{indexNames}] がフラッシュされました", + "xpack.idxMgmt.forceMergeIndicesAction.successfullyForceMergedIndicesMessage": "[{indexNames}] が強制結合されました", + "xpack.idxMgmt.freezeIndicesAction.successfullyFrozeIndicesMessage": "[{indexNames}] が凍結されました", + "xpack.idxMgmt.frozenBadgeLabel": "凍結", + "xpack.idxMgmt.home.appTitle": "インデックス管理", + "xpack.idxMgmt.home.idxMgmtDescription": "Elasticsearch インデックスを個々に、または一斉に更新します", + "xpack.idxMgmt.home.idxMgmtDocsLinkText": "インデックス管理ドキュメント", + "xpack.idxMgmt.home.indexTemplatesDescription": "テンプレートを使用して設定、マッピング、エイリアスをインデックスに自動的に適用します。", + "xpack.idxMgmt.home.indexTemplatesTabTitle": "インデックステンプレート", + "xpack.idxMgmt.home.indicesTabTitle": "インデックス", + "xpack.idxMgmt.indexActionsMenu.clearIndexCacheLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }のキャッシュを消去", + "xpack.idxMgmt.indexActionsMenu.closeIndex.checkboxLabel": "システムインデックスを閉じることの重大な影響を理解しています", + "xpack.idxMgmt.indexActionsMenu.closeIndex.closeDescription": "{selectedIndexCount, plural, one {このインデックス} other {これらのインデックス} }を閉じようとしています。", + "xpack.idxMgmt.indexActionsMenu.closeIndex.confirmModal.confirmButtonText": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }を閉じる", + "xpack.idxMgmt.indexActionsMenu.closeIndex.confirmModal.modalTitle": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }を閉じる", + "xpack.idxMgmt.indexActionsMenu.closeIndex.proceedWithCautionCallOutDescription": "システムインデックスは内部オペレーションに不可欠です。Open Index APIを使用して再オープンすることができます。", + "xpack.idxMgmt.indexActionsMenu.closeIndex.proceedWithCautionCallOutTitle": "システムインデックスを閉じることで、Kibanaに重大な障害が生じる可能性があります", + "xpack.idxMgmt.indexActionsMenu.closeIndex.systemIndexLabel": "システムインデックス", + "xpack.idxMgmt.indexActionsMenu.closeIndexLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }を閉じる", + "xpack.idxMgmt.indexActionsMenu.deleteIndex.checkboxLabel": "システムインデックスを削除することの重大な影響を理解しています", + "xpack.idxMgmt.indexActionsMenu.deleteIndex.confirmModal.cancelButtonText": "キャンセル", + "xpack.idxMgmt.indexActionsMenu.deleteIndex.confirmModal.confirmButtonText": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }を削除", + "xpack.idxMgmt.indexActionsMenu.deleteIndex.confirmModal.modalTitle": "{selectedIndexCount, plural, one {インデックス} other {インデックス} } の削除の確認", + "xpack.idxMgmt.indexActionsMenu.deleteIndex.deleteDescription": "{selectedIndexCount, plural, one {このインデックス} other {これらのインデックス} }を削除しようとしています:", + "xpack.idxMgmt.indexActionsMenu.deleteIndex.deleteWarningDescription": "この操作は元に戻すことができません。適切なバックアップがあることを確認してください。", + "xpack.idxMgmt.indexActionsMenu.deleteIndex.proceedWithCautionCallOutDescription": "システムインデックスは内部オペレーションに不可欠です。システムインデックスを削除すると、復元することはできません。適切なバックアップがあることを確認してください。", + "xpack.idxMgmt.indexActionsMenu.deleteIndex.proceedWithCautionCallOutTitle": "十分ご注意ください!", + "xpack.idxMgmt.indexActionsMenu.deleteIndex.systemIndexLabel": "システムインデックス", + "xpack.idxMgmt.indexActionsMenu.deleteIndexLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }を削除", + "xpack.idxMgmt.indexActionsMenu.editIndexSettingsLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }の設定を編集", + "xpack.idxMgmt.indexActionsMenu.flushIndexLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }をフラッシュ", + "xpack.idxMgmt.indexActionsMenu.forceMerge.confirmModal.cancelButtonText": "キャンセル", + "xpack.idxMgmt.indexActionsMenu.forceMerge.confirmModal.confirmButtonText": "強制結合", + "xpack.idxMgmt.indexActionsMenu.forceMerge.confirmModal.modalTitle": "強制結合", + "xpack.idxMgmt.indexActionsMenu.forceMerge.forceMergeDescription": "{selectedIndexCount, plural, one {このインデックス} other {これらのインデックス} }を強制結合しようとしています:", + "xpack.idxMgmt.indexActionsMenu.forceMerge.forceMergeSegmentsHelpText": "セグメントがこの数以下になるまでインデックスのセグメントを結合します。デフォルトは 1 です。", + "xpack.idxMgmt.indexActionsMenu.forceMerge.forceMergeWarningDescription": " 大きなインデックスや読み取り専用ではないインデックスの強制結合は、適切に実行 (読み取り専用ではないインデックスに対して実行) されないと、クラスターでパフォーマンスや安定性の問題を引き起こす可能性があります。", + "xpack.idxMgmt.indexActionsMenu.forceMerge.maximumNumberOfSegmentsFormRowLabel": "シャードごとの最大セグメント数", + "xpack.idxMgmt.indexActionsMenu.forceMerge.proceedWithCautionCallOutTitle": "十分ご注意ください!", + "xpack.idxMgmt.indexActionsMenu.forceMergeIndexLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }を強制結合", + "xpack.idxMgmt.indexActionsMenu.freezeEntity.confirmModal.cancelButtonText": "キャンセル", + "xpack.idxMgmt.indexActionsMenu.freezeEntity.freezeDescription": "{count, plural, one {このインデックス} other {これらのインデックス} }を凍結しようとしています。", + "xpack.idxMgmt.indexActionsMenu.freezeEntity.freezeEntityWarningDescription": " 凍結されたインデックスはクラスターにほとんどオーバーヘッドがなく、書き込みオペレーションがブロックされます。凍結されたインデックスは検索できますが、クエリが遅くなります。", + "xpack.idxMgmt.indexActionsMenu.freezeEntity.proceedWithCautionCallOutTitle": "十分ご注意ください", + "xpack.idxMgmt.indexActionsMenu.freezeIndexLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }を凍結", + "xpack.idxMgmt.indexActionsMenu.manageButtonAriaLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }オプション", + "xpack.idxMgmt.indexActionsMenu.manageButtonLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス}}の管理", + "xpack.idxMgmt.indexActionsMenu.openIndexLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }を開く", + "xpack.idxMgmt.indexActionsMenu.panelTitle": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }オプション", + "xpack.idxMgmt.indexActionsMenu.refreshIndexLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }を更新", + "xpack.idxMgmt.indexActionsMenu.segmentsNumberErrorMessage": "セグメント数は 0 より大きい値である必要があります。", + "xpack.idxMgmt.indexActionsMenu.showIndexMappingLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }のマッピングを表示", + "xpack.idxMgmt.indexActionsMenu.showIndexSettingsLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }の設定を表示", + "xpack.idxMgmt.indexActionsMenu.showIndexStatsLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }の統計を表示", + "xpack.idxMgmt.indexActionsMenu.unfreezeIndexLabel": "{selectedIndexCount, plural, one {インデックス} other {インデックス} }の凍結を解除", + "xpack.idxMgmt.indexStatusLabels.clearingCacheStatusLabel": "キャッシュを消去中...", + "xpack.idxMgmt.indexStatusLabels.closedStatusLabel": "クローズ済み", + "xpack.idxMgmt.indexStatusLabels.closingStatusLabel": "クローズ中...", + "xpack.idxMgmt.indexStatusLabels.flushingStatusLabel": "フラッシュ中...", + "xpack.idxMgmt.indexStatusLabels.forcingMergeStatusLabel": "強制結合中...", + "xpack.idxMgmt.indexStatusLabels.mergingStatusLabel": "結合中...", + "xpack.idxMgmt.indexStatusLabels.openingStatusLabel": "開いています...", + "xpack.idxMgmt.indexStatusLabels.refreshingStatusLabel": "更新中...", + "xpack.idxMgmt.indexTable.captionText": "以下は {total} 列中 {count, plural, one {# 列} other {# 列}} を含むインデックス表です。", + "xpack.idxMgmt.indexTable.headers.documentsHeader": "ドキュメント数", + "xpack.idxMgmt.indexTable.headers.healthHeader": "ヘルス", + "xpack.idxMgmt.indexTable.headers.nameHeader": "名前", + "xpack.idxMgmt.indexTable.headers.primaryHeader": "プライマリ", + "xpack.idxMgmt.indexTable.headers.replicaHeader": "複製", + "xpack.idxMgmt.indexTable.headers.statusHeader": "ステータス", + "xpack.idxMgmt.indexTable.headers.storageSizeHeader": "ストレージサイズ", + "xpack.idxMgmt.indexTable.invalidSearchErrorMessage": "無効な検索: {errorMessage}", + "xpack.idxMgmt.indexTable.reloadIndicesButton": "インデックスを再読み込み", + "xpack.idxMgmt.indexTable.selectAllIndicesAriaLabel": "すべての行を選択", + "xpack.idxMgmt.indexTable.selectIndexAriaLabel": "この行を選択", + "xpack.idxMgmt.indexTable.serverErrorTitle": "インデックスの読み込み中にエラーが発生", + "xpack.idxMgmt.indexTable.systemIndicesSearchIndicesAriaLabel": "インデックスの検索", + "xpack.idxMgmt.indexTable.systemIndicesSearchInputPlaceholder": "検索", + "xpack.idxMgmt.indexTable.systemIndicesSwitchLabel": "システムインデックスを含める", + "xpack.idxMgmt.indexTemplatesList.emptyPrompt.noIndexTemplatesTitle": "まだテンプレートがありません", + "xpack.idxMgmt.indexTemplatesList.loadingIndexTemplatesDescription": "テンプレートを読み込み中…", + "xpack.idxMgmt.indexTemplatesList.loadingIndexTemplatesErrorMessage": "テンプレートの読み込み中にエラーが発生", + "xpack.idxMgmt.indexTemplatesTable.systemIndexTemplatesSwitchLabel": "システムテンプレートを含める", + "xpack.idxMgmt.mappingsEditor.formatError": "JSON フォーマットエラー", + "xpack.idxMgmt.mappingsEditor.mappingsEditorAriaLabel": "インデックスマッピングエディター", + "xpack.idxMgmt.noMatch.noIndicesDescription": "表示するインデックスがありません", + "xpack.idxMgmt.openIndicesAction.successfullyOpenedIndicesMessage": "[{indexNames}] が開かれました", + "xpack.idxMgmt.pageErrorForbidden.title": "インデックス管理を使用するパーミッションがありません", + "xpack.idxMgmt.refreshIndicesAction.successfullyRefreshedIndicesMessage": "[{indexNames}] が更新されました", + "xpack.idxMgmt.reloadIndicesAction.indicesPageRefreshFailureMessage": "現在のインデックスページの更新に失敗しました。", + "xpack.idxMgmt.summary.headers.aliases": "エイリアス", + "xpack.idxMgmt.summary.headers.deletedDocumentsHeader": "ドキュメントが削除されました", + "xpack.idxMgmt.summary.headers.documentsHeader": "ドキュメント数", + "xpack.idxMgmt.summary.headers.healthHeader": "ヘルス", + "xpack.idxMgmt.summary.headers.primaryHeader": "プライマリ", + "xpack.idxMgmt.summary.headers.primaryStorageSizeHeader": "プライマリストレージサイズ", + "xpack.idxMgmt.summary.headers.replicaHeader": "複製", + "xpack.idxMgmt.summary.headers.statusHeader": "ステータス", + "xpack.idxMgmt.summary.headers.storageSizeHeader": "ストレージサイズ", + "xpack.idxMgmt.summary.summaryTitle": "一般", + "xpack.idxMgmt.templateCreate.loadingTemplateToCloneDescription": "クローンを作成するテンプレートを読み込み中…", + "xpack.idxMgmt.templateCreate.loadingTemplateToCloneErrorMessage": "クローンを作成するテンプレートを読み込み中にエラーが発生", + "xpack.idxMgmt.templateDetails.aliasesTab.noAliasesTitle": "エイリアスが定義されていません。", + "xpack.idxMgmt.templateDetails.aliasesTabTitle": "エイリアス", + "xpack.idxMgmt.templateDetails.cloneButtonLabel": "クローンを作成", + "xpack.idxMgmt.templateDetails.closeButtonLabel": "閉じる", + "xpack.idxMgmt.templateDetails.deleteButtonLabel": "削除", + "xpack.idxMgmt.templateDetails.editButtonLabel": "編集", + "xpack.idxMgmt.templateDetails.loadingIndexTemplateDescription": "テンプレートを読み込み中…", + "xpack.idxMgmt.templateDetails.loadingIndexTemplateErrorMessage": "テンプレートの読み込み中にエラーが発生", + "xpack.idxMgmt.templateDetails.manageButtonLabel": "管理", + "xpack.idxMgmt.templateDetails.manageContextMenuPanelTitle": "テンプレートオプション", + "xpack.idxMgmt.templateDetails.managedTemplateInfoDescription": "マネージドテンプレートは内部オペレーションに不可欠です。", + "xpack.idxMgmt.templateDetails.managedTemplateInfoTitle": "マネジドテンプレートの編集は許可されていません。", + "xpack.idxMgmt.templateDetails.mappingsTab.noMappingsTitle": "マッピングが定義されていません。", + "xpack.idxMgmt.templateDetails.mappingsTabTitle": "マッピング", + "xpack.idxMgmt.templateDetails.settingsTab.noSettingsTitle": "設定が定義されていません。", + "xpack.idxMgmt.templateDetails.settingsTabTitle": "設定", + "xpack.idxMgmt.templateDetails.summaryTab.ilmPolicyDescriptionListTitle": "ILM ポリシー", + "xpack.idxMgmt.templateDetails.summaryTab.indexPatternsDescriptionListTitle": "インデックス{numIndexPatterns, plural, one {パターン} other {パターン}}", + "xpack.idxMgmt.templateDetails.summaryTab.noneDescriptionText": "なし", + "xpack.idxMgmt.templateDetails.summaryTab.orderDescriptionListTitle": "順序", + "xpack.idxMgmt.templateDetails.summaryTab.versionDescriptionListTitle": "バージョン", + "xpack.idxMgmt.templateDetails.summaryTabTitle": "まとめ", + "xpack.idxMgmt.templateEdit.loadingIndexTemplateDescription": "テンプレートを読み込み中…", + "xpack.idxMgmt.templateEdit.loadingIndexTemplateErrorMessage": "テンプレートの読み込み中にエラーが発生", + "xpack.idxMgmt.templateEdit.managedTemplateWarningDescription": "管理されているテンプレートは内部オペレーションに不可欠です。", + "xpack.idxMgmt.templateEdit.managedTemplateWarningTitle": "マネジドテンプレートの編集は許可されていません。", + "xpack.idxMgmt.templateEdit.systemTemplateWarningDescription": "システムテンプレートは内部オペレーションに不可欠です。", + "xpack.idxMgmt.templateEdit.systemTemplateWarningTitle": "システムテンプレートを編集することで、Kibana に重大な障害が生じる可能性があります", + "xpack.idxMgmt.templateForm.backButtonLabel": "戻る", + "xpack.idxMgmt.templateForm.createButtonLabel": "テンプレートを作成", + "xpack.idxMgmt.templateForm.nextButtonLabel": "次へ", + "xpack.idxMgmt.templateForm.saveButtonLabel": "テンプレートを保存", + "xpack.idxMgmt.templateForm.saveTemplateError": "テンプレートを作成できません", + "xpack.idxMgmt.templateForm.savingButtonLabel": "保存中…", + "xpack.idxMgmt.templateForm.stepAliases.aliasesDescription": "エイリアスをセットアップして、インデックスに関連付けてください。", + "xpack.idxMgmt.templateForm.stepAliases.aliasesEditorHelpText": "JSON フォーマットを使用: {code}", + "xpack.idxMgmt.templateForm.stepAliases.docsButtonLabel": "インデックステンプレートドキュメント", + "xpack.idxMgmt.templateForm.stepAliases.fieldAliasesAriaLabel": "エイリアスコードエディター", + "xpack.idxMgmt.templateForm.stepAliases.fieldAliasesLabel": "エイリアス", + "xpack.idxMgmt.templateForm.stepAliases.stepTitle": "エイリアス (任意)", + "xpack.idxMgmt.templateForm.stepLogistics.docsButtonLabel": "インデックステンプレートドキュメント", + "xpack.idxMgmt.templateForm.stepLogistics.fieldIndexPatternsHelpText": "スペースと {invalidCharactersList} は使用できません。", + "xpack.idxMgmt.templateForm.stepLogistics.fieldIndexPatternsLabel": "インデックスパターン", + "xpack.idxMgmt.templateForm.stepLogistics.fieldNameLabel": "名前", + "xpack.idxMgmt.templateForm.stepLogistics.fieldOrderLabel": "その他 (任意)", + "xpack.idxMgmt.templateForm.stepLogistics.fieldVersionLabel": "バージョン (任意)", + "xpack.idxMgmt.templateForm.stepLogistics.indexPatternsDescription": "テンプレートに適用するインデックスパターンです。", + "xpack.idxMgmt.templateForm.stepLogistics.indexPatternsTitle": "インデックスパターン", + "xpack.idxMgmt.templateForm.stepLogistics.nameDescription": "このテンプレートの固有の識別子です。", + "xpack.idxMgmt.templateForm.stepLogistics.nameTitle": "名前", + "xpack.idxMgmt.templateForm.stepLogistics.orderDescription": "複数テンプレートがインデックスと一致した場合の結合順序です。", + "xpack.idxMgmt.templateForm.stepLogistics.orderTitle": "結合順序", + "xpack.idxMgmt.templateForm.stepLogistics.stepTitle": "ロジスティクス", + "xpack.idxMgmt.templateForm.stepLogistics.versionDescription": "テンプレートを外部管理システムで識別するための番号です。", + "xpack.idxMgmt.templateForm.stepLogistics.versionTitle": "バージョン", + "xpack.idxMgmt.templateForm.stepMappings.docsButtonLabel": "マッピングドキュメント", + "xpack.idxMgmt.templateForm.stepMappings.fieldMappingsAriaLabel": "マッピングエディター", + "xpack.idxMgmt.templateForm.stepMappings.fieldMappingsLabel": "マッピング", + "xpack.idxMgmt.templateForm.stepMappings.mappingsDescription": "ドキュメントの保存とインデックス方法を定義します。", + "xpack.idxMgmt.templateForm.stepMappings.mappingsEditorHelpText": "JSON フォーマットを使用: {code}", + "xpack.idxMgmt.templateForm.stepMappings.stepTitle": "マッピング (任意)", + "xpack.idxMgmt.templateForm.stepReview.requestTab.descriptionText": "このリクエストは次のインデックステンプレートを作成します。", + "xpack.idxMgmt.templateForm.stepReview.requestTabTitle": "リクエスト", + "xpack.idxMgmt.templateForm.stepReview.stepTitle": "「{templateName}」の詳細の確認", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.aliasesLabel": "エイリアス", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.indexPatternsLabel": "インデックス{numIndexPatterns, plural, one {パターン} other {パターン}}", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.indexPatternsWarningDescription": "作成するすべての新規インデックスにこのテンプレートが使用されます。", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.indexPatternsWarningLinkText": "インデックスパターンの編集。", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.indexPatternsWarningTitle": "このテンプレートはワイルドカード (*) をインデックスパターンとして使用します。", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.mappingLabel": "マッピング", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.noDescriptionText": "いいえ", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.noneDescriptionText": "なし", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.orderLabel": "順序", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.settingsLabel": "インデックス設定", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.versionLabel": "バージョン", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.yesDescriptionText": "はい", + "xpack.idxMgmt.templateForm.stepReview.summaryTabTitle": "まとめ", + "xpack.idxMgmt.templateForm.steps.aliasesStepName": "エイリアス", + "xpack.idxMgmt.templateForm.steps.logisticsStepName": "ロジスティクス", + "xpack.idxMgmt.templateForm.steps.mappingsStepName": "マッピング", + "xpack.idxMgmt.templateForm.steps.settingsStepName": "インデックス設定", + "xpack.idxMgmt.templateForm.steps.summaryStepName": "テンプレートのレビュー", + "xpack.idxMgmt.templateForm.stepSettings.docsButtonLabel": "インデックス設定ドキュメント", + "xpack.idxMgmt.templateForm.stepSettings.fieldIndexSettingsAriaLabel": "インデックス設定エディター", + "xpack.idxMgmt.templateForm.stepSettings.fieldIndexSettingsLabel": "インデックス設定", + "xpack.idxMgmt.templateForm.stepSettings.settingsDescription": "インデックスの動作を定義します。", + "xpack.idxMgmt.templateForm.stepSettings.settingsEditorHelpText": "JSON フォーマットを使用: {code}", + "xpack.idxMgmt.templateForm.stepSettings.stepTitle": "インデックス設定 (任意)", + "xpack.idxMgmt.templateList.table.actionCloneDescription": "このテンプレートのクローンを作成します", + "xpack.idxMgmt.templateList.table.actionCloneTitle": "クローンを作成", + "xpack.idxMgmt.templateList.table.actionColumnTitle": "アクション", + "xpack.idxMgmt.templateList.table.actionDeleteDecription": "このテンプレートを削除します", + "xpack.idxMgmt.templateList.table.actionDeleteText": "削除", + "xpack.idxMgmt.templateList.table.actionEditDecription": "このテンプレートを編集します", + "xpack.idxMgmt.templateList.table.actionEditText": "編集", + "xpack.idxMgmt.templateList.table.aliasesColumnTitle": "エイリアス", + "xpack.idxMgmt.templateList.table.createTemplatesButtonLabel": "テンプレートを作成", + "xpack.idxMgmt.templateList.table.deleteManagedTemplateTooltip": "管理されているテンプレートは削除できません。", + "xpack.idxMgmt.templateList.table.deleteTemplatesButtonLabel": "{count, plural, one {テンプレート} other {テンプレート} }を削除", + "xpack.idxMgmt.templateList.table.ilmPolicyColumnDescription": "インデックスライフサイクルポリシー「{policyName}」", + "xpack.idxMgmt.templateList.table.ilmPolicyColumnTitle": "ILM ポリシー", + "xpack.idxMgmt.templateList.table.indexPatternsColumnTitle": "インデックスパターン", + "xpack.idxMgmt.templateList.table.mappingsColumnTitle": "マッピング", + "xpack.idxMgmt.templateList.table.nameColumnTitle": "名前", + "xpack.idxMgmt.templateList.table.noIndexTemplatesMessage": "テンプレートが見つかりませんでした", + "xpack.idxMgmt.templateList.table.orderColumnTitle": "順序", + "xpack.idxMgmt.templateList.table.reloadTemplatesButtonLabel": "再読み込み", + "xpack.idxMgmt.templateList.table.settingsColumnTitle": "設定", + "xpack.idxMgmt.templateValidation.indexPatternsRequiredError": "インデックスパターンが最低 1 つ必要です。", + "xpack.idxMgmt.templateValidation.templateNameInvalidaCharacterError": "テンプレート名に「{invalidChar}」は使用できません", + "xpack.idxMgmt.templateValidation.templateNamePeriodError": "テンプレート名はピリオドで始めることはできません。", + "xpack.idxMgmt.templateValidation.templateNameRequiredError": "テンプレート名が必要です。", + "xpack.idxMgmt.templateValidation.templateNameSpacesError": "テンプレート名にスペースは使用できません。", + "xpack.idxMgmt.templateValidation.templateNameUnderscoreError": "テンプレート名はアンダーラインで始めることはできません。", + "xpack.idxMgmt.unfreezeIndicesAction.successfullyUnfrozeIndicesMessage": "[{indexNames}] の凍結が解除されました", + "xpack.idxMgmt.updateIndexSettingsAction.settingsSuccessUpdateMessage": "インデックス {indexName} の設定が更新されました", + "xpack.idxMgmt.validators.string.invalidJSONError": "無効な JSON フォーマット。", + "xpack.indexLifecycleMgmt.activePhaseMessage": "アクティブ", + "xpack.indexLifecycleMgmt.addLifecyclePolicyActionButtonLabel": "ライフサイクルポリシーを追加", + "xpack.indexLifecycleMgmt.appTitle": "インデックスライフサイクルポリシー", + "xpack.indexLifecycleMgmt.checkLicense.errorExpiredMessage": "{licenseType} ライセンスが期限切れのため {pluginName} を使用できません。", + "xpack.indexLifecycleMgmt.checkLicense.errorUnavailableMessage": "現在ライセンス情報が利用できないため {pluginName} を使用できません。", + "xpack.indexLifecycleMgmt.checkLicense.errorUnsupportedMessage": "ご使用の {licenseType} ライセンスは {pluginName} をサポートしていません。ライセンスをアップグレードしてください。", + "xpack.indexLifecycleMgmt.coldPhase.freezeIndexLabel": "インデックスを凍結", + "xpack.indexLifecycleMgmt.coldPhase.numberOfReplicasLabel": "複製の数", + "xpack.indexLifecycleMgmt.coldPhase.replicaCountHelpText": "デフォルトで、複製の数は同じままになります。", + "xpack.indexLifecycleMgmt.confirmDelete.cancelButton": "キャンセル", + "xpack.indexLifecycleMgmt.confirmDelete.deleteButton": "削除", + "xpack.indexLifecycleMgmt.confirmDelete.errorMessage": "ポリシー {policyName} の削除中にエラーが発生しました", + "xpack.indexLifecycleMgmt.confirmDelete.successMessage": "ポリシー {policyName} が削除されました", + "xpack.indexLifecycleMgmt.confirmDelete.title": "ポリシー「{name}」が削除されました", + "xpack.indexLifecycleMgmt.confirmDelete.undoneWarning": "削除されたポリシーは復元できません。", + "xpack.indexLifecycleMgmt.editPolicy.cancelButton": "キャンセル", + "xpack.indexLifecycleMgmt.editPolicy.coldPhase.activateWarmPhaseSwitchLabel": "コールドフェーズを有効にする", + "xpack.indexLifecycleMgmt.editPolicy.coldPhase.coldPhaseDescriptionText": "インデックスへのクエリの頻度を減らすことで、大幅に性能が低いハードウェアにシャードを割り当てることができます。クエリが遅いため、複製の数を減らすことができます。", + "xpack.indexLifecycleMgmt.editPolicy.coldPhase.coldPhaseLabel": "コールドフェーズ", + "xpack.indexLifecycleMgmt.editPolicy.coldPhase.freezeIndexExplanationText": "凍結されたインデックスはクラスターにほとんどオーバーヘッドがなく、書き込みオペレーションがブロックされます。凍結されたインデックスは検索できますが、クエリが遅くなります。", + "xpack.indexLifecycleMgmt.editPolicy.coldPhase.freezeText": "凍結", + "xpack.indexLifecycleMgmt.editPolicy.createdMessage": "作成されました", + "xpack.indexLifecycleMgmt.editPolicy.createPolicyMessage": "インデックスライフサイクルポリシーを作成します", + "xpack.indexLifecycleMgmt.editPolicy.creationDaysOptionLabel": "インデックスの作成からの経過日数", + "xpack.indexLifecycleMgmt.editPolicy.creationHoursOptionLabel": "インデックスの作成からの経過時間数", + "xpack.indexLifecycleMgmt.editPolicy.deletePhase.activateWarmPhaseSwitchLabel": "削除フェーズを有効にする", + "xpack.indexLifecycleMgmt.editPolicy.deletePhase.deletePhaseDescriptionText": "今後インデックスは必要ありません。 いつ安全に削除できるかを定義できます。", + "xpack.indexLifecycleMgmt.editPolicy.deletePhase.deletePhaseLabel": "削除フェーズ", + "xpack.indexLifecycleMgmt.editPolicy.differentPolicyNameRequiredError": "ポリシー名は異なるものである必要があります。", + "xpack.indexLifecycleMgmt.editPolicy.editingExistingPolicyExplanationMessage": "すべての変更はこのポリシーに関連付けられているインデックスに影響を及ぼします。代わりに、これらの変更を新規ポリシーに保存することもできます。", + "xpack.indexLifecycleMgmt.editPolicy.editingExistingPolicyMessage": "既存のポリシーを編集しています", + "xpack.indexLifecycleMgmt.editPolicy.editPolicyMessage": "インデックスライフサイクルポリシー {originalPolicyName} を編集します", + "xpack.indexLifecycleMgmt.editPolicy.formErrorsMessage": "このページのエラーを修正してください。", + "xpack.indexLifecycleMgmt.editPolicy.hidePolicyJsonButto": "リクエストを非表示", + "xpack.indexLifecycleMgmt.editPolicy.hotPhase.hotPhaseDescriptionMessage": "このフェーズは必須です。アクティブにクエリを実行しインデックスに書き込んでいます。 更新を高速化するため、大きくなりすぎたり古くなりすぎたりした際にインデックスをロールオーバーできます。", + "xpack.indexLifecycleMgmt.editPolicy.hotPhase.hotPhaseLabel": "ホットフェーズ", + "xpack.indexLifecycleMgmt.editPolicy.hotPhase.learnAboutRolloverLinkText": "ロールオーバーの詳細をご覧ください", + "xpack.indexLifecycleMgmt.editPolicy.hotPhase.rolloverDescriptionMessage": "ロールオーバーにより作成された新規インデックスは、インデックスエイリアスに追加され、書き込みインデックスとして指定されます。", + "xpack.indexLifecycleMgmt.editPolicy.indexPriorityText": "インデックスの優先順位", + "xpack.indexLifecycleMgmt.editPolicy.learnAboutIndexLifecycleManagementLinkText": "インデックスライフサイクルの詳細をご覧ください。", + "xpack.indexLifecycleMgmt.editPolicy.learnAboutIndexTemplatesLink": "インデックステンプレートの詳細をご覧ください", + "xpack.indexLifecycleMgmt.editPolicy.learnAboutShardAllocationLink": "シャード割り当ての詳細をご覧ください", + "xpack.indexLifecycleMgmt.editPolicy.learnAboutTimingText": "タイミングの詳細をご覧ください", + "xpack.indexLifecycleMgmt.editPolicy.lifecyclePolicyDescriptionText": "インデックスへのアクティブな書き込みから削除までの、インデックスライフサイクルの 4 つのフェーズを自動化するには、インデックスポリシーを使用します。", + "xpack.indexLifecycleMgmt.editPolicy.loadPolicyErrorMessage": "ポリシーの読み込み中にエラーが発生しました", + "xpack.indexLifecycleMgmt.editPolicy.maximumAgeMissingError": "最高年齢が必要です。", + "xpack.indexLifecycleMgmt.editPolicy.maximumDocumentsMissingError": "最高ドキュメント数が必要です。", + "xpack.indexLifecycleMgmt.editPolicy.maximumIndexSizeMissingError": "最大インデックスサイズが必要です。", + "xpack.indexLifecycleMgmt.editPolicy.nameLabel": "名前", + "xpack.indexLifecycleMgmt.editPolicy.nodeAllocationLabel": "シャードの割当をコントロールするノード属性を選択", + "xpack.indexLifecycleMgmt.editPolicy.nodeAttributesMissingDescription": "ノード属性なしではシャードの割り当てをコントロールできません。", + "xpack.indexLifecycleMgmt.editPolicy.nodeAttributesMissingLabel": "elasticsearch.yml でノード属性が構成されていません", + "xpack.indexLifecycleMgmt.editPolicy.nodeDetailErrorMessage": "ノード属性の詳細の読み込み中にエラーが発生しました", + "xpack.indexLifecycleMgmt.editPolicy.nodeInfoErrorMessage": "ノード属性の情報の読み込み中にエラーが発生しました", + "xpack.indexLifecycleMgmt.editPolicy.numberRequiredError": "数字が必要です。", + "xpack.indexLifecycleMgmt.editPolicy.phaseCold.minimumAgeLabel": "コールドフェーズのタイミング", + "xpack.indexLifecycleMgmt.editPolicy.phaseCold.minimumAgeUnitsAriaLabel": "コールドフェーズのタイミングの単位", + "xpack.indexLifecycleMgmt.editPolicy.phaseDelete.minimumAgeLabel": "削除フェーズのタイミング", + "xpack.indexLifecycleMgmt.editPolicy.phaseDelete.minimumAgeUnitsAriaLabel": "削除フェーズのタイミングの単位", + "xpack.indexLifecycleMgmt.editPolicy.phaseErrorMessage": "エラーを修正してください", + "xpack.indexLifecycleMgmt.editPolicy.phaseWarm.minimumAgeLabel": "ウォームフェーズのタイミング", + "xpack.indexLifecycleMgmt.editPolicy.phaseWarm.minimumAgeUnitsAriaLabel": "ウォームフェーズのタイミングの単位", + "xpack.indexLifecycleMgmt.editPolicy.policyNameAlreadyUsedError": "このポリシー名は既に使用されています。", + "xpack.indexLifecycleMgmt.editPolicy.policyNameContainsCommaError": "ポリシー名にはコンマを使用できません。", + "xpack.indexLifecycleMgmt.editPolicy.policyNameContainsSpaceError": "ポリシー名にはスペースを使用できません。", + "xpack.indexLifecycleMgmt.editPolicy.policyNameLabel": "ポリシー名", + "xpack.indexLifecycleMgmt.editPolicy.policyNameRequiredError": "ポリシー名が必要です。", + "xpack.indexLifecycleMgmt.editPolicy.policyNameStartsWithUnderscoreError": "ポリシー名の頭にアンダーラインを使用することはできません。", + "xpack.indexLifecycleMgmt.editPolicy.policyNameTooLongError": "ポリシー名は 255 バイト未満である必要があります。", + "xpack.indexLifecycleMgmt.editPolicy.positiveNumberAboveZeroRequiredError": "0 よりも大きい数字のみ使用できます。", + "xpack.indexLifecycleMgmt.editPolicy.positiveNumberRequiredError": "プラスの数字のみ使用できます。", + "xpack.indexLifecycleMgmt.editPolicy.rolloverDaysOptionLabel": "ロールオーバーからの経過日数", + "xpack.indexLifecycleMgmt.editPolicy.rolloverHoursOptionLabel": "ロールオーバーからの経過時間数", + "xpack.indexLifecycleMgmt.editPolicy.saveAsNewButton": "新規ポリシーとして保存します", + "xpack.indexLifecycleMgmt.editPolicy.saveAsNewPolicyMessage": "新規ポリシーとして保存します", + "xpack.indexLifecycleMgmt.editPolicy.saveButton": "ポリシーを保存", + "xpack.indexLifecycleMgmt.editPolicy.saveErrorMessage": "ライフサイクルポリシー {lifecycleName} の保存中にエラーが発生しました", + "xpack.indexLifecycleMgmt.editPolicy.showPolicyJsonButto": "リクエストを表示", + "xpack.indexLifecycleMgmt.editPolicy.successfulSaveMessage": "ライフサイクルポリシー「{lifecycleName}」を {verb}", + "xpack.indexLifecycleMgmt.editPolicy.updatedMessage": "更新しました", + "xpack.indexLifecycleMgmt.editPolicy.validPolicyNameMessage": "ポリシー名の頭にアンダーラインを使用することはできず、括弧やスペースを含めることもできません。", + "xpack.indexLifecycleMgmt.editPolicy.viewNodeDetailsButton": "この構成に関連付けられているインデックスのリストを表示", + "xpack.indexLifecycleMgmt.editPolicy.warmPhase.activateWarmPhaseSwitchLabel": "ウォームフェーズを有効にする", + "xpack.indexLifecycleMgmt.editPolicy.warmPhase.forceMergeDataExplanationText": "小さなファイルを結合して削除されたファイルを消去することで、シャードのセグメント数を減らします。", + "xpack.indexLifecycleMgmt.editPolicy.warmPhase.forceMergeDataText": "強制結合", + "xpack.indexLifecycleMgmt.editPolicy.warmPhase.indexPriorityExplanationText": "ノードの再起動後にインデックスを復元する優先順位を設定します。優先順位の高いインデックスは優先順位の低いインデックスよりも先に復元されます。", + "xpack.indexLifecycleMgmt.editPolicy.warmPhase.shrinkIndexExplanationText": "インデックス情報をプライマリシャードの少ない新規インデックスに縮小します。", + "xpack.indexLifecycleMgmt.editPolicy.warmPhase.shrinkText": "縮小", + "xpack.indexLifecycleMgmt.editPolicy.warmPhase.warmPhaseDescriptionMessage": "まだインデックスにクエリを実行中ですが、読み取り専用です。性能の低いハードウェアにシャードを割り当てることができます。検索を高速化するために、シャードの数を減らしセグメントを結合することができます。", + "xpack.indexLifecycleMgmt.editPolicy.warmPhase.warmPhaseLabel": "ウォームフェーズ", + "xpack.indexLifecycleMgmt.hotPhase.daysLabel": "日", + "xpack.indexLifecycleMgmt.hotPhase.enableRolloverLabel": "ロールオーバーを有効にする", + "xpack.indexLifecycleMgmt.hotPhase.gigabytesLabel": "ギガバイト", + "xpack.indexLifecycleMgmt.hotPhase.hoursLabel": "時間", + "xpack.indexLifecycleMgmt.hotPhase.maximumAgeLabel": "最高年齢", + "xpack.indexLifecycleMgmt.hotPhase.maximumAgeUnitsAriaLabel": "最高年齢の単位", + "xpack.indexLifecycleMgmt.hotPhase.maximumDocumentsLabel": "最高ドキュメント数", + "xpack.indexLifecycleMgmt.hotPhase.maximumIndexSizeLabel": "最大インデックスサイズ", + "xpack.indexLifecycleMgmt.hotPhase.maximumIndexSizeUnitsAriaLabel": "最大インデックスサイズの単位", + "xpack.indexLifecycleMgmt.hotPhase.megabytesLabel": "メガバイト", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.actionStatusTitle": "アクションステータス", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.headers.currentActionHeader": "現在のステータス", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.headers.currentActionTimeHeader": "現在のアクション時間", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.headers.currentPhaseHeader": "現在のフェーズ", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.headers.failedStepHeader": "失敗したステップ", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.headers.lifecyclePolicyHeader": "ライフサイクルポリシー", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.phaseDefinitionTitle": "フェーズ検知", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.showPhaseDefinitionButton": "フェーズ検知を表示", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.showPhaseDefinitionDescriptionTitle": "フェーズ検知", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.stackTraceButton": "スタックトレース", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.summaryErrorMessage": "インデックスライフサイクルエラー", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.summaryTitle": "インデックスライフサイクル管理", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.addPolicyButtonText": "ポリシーを追加", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.addPolicyToIndexError": "インデックスへのポリシーの追加中にエラーが発生しました", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.addPolicyToIndexSuccess": "インデックス {indexName} にポリシー {policyName} が追加されました。", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.cancelButtonText": "キャンセル", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.chooseAliasLabel": "インデックスロールオーバーエイリアス", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.chooseAliasMessage": "エイリアスを選択してください", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.choosePolicyLabel": "ライフサイクルポリシー", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.choosePolicyMessage": "ライフサイクルポリシーを選択してください", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.defineLifecyclePolicyLinkText": "ライフサイクルポリシーを追加", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.indexHasNoAliasesWarningMessage": "ポリシー {policyName} はロールオーバーするよう構成されていますが、インデックス {indexName} にデータがありません。ロールオーバーにはデータが必要です。", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.indexHasNoAliasesWarningTitle": "インデックスにエイリアスがありません", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.loadPolicyError": "ポリシーリストの読み込み中にエラーが発生しました", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.modalTitle": "「{indexName}」にライフサイクルポリシーを追加", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.noPoliciesWarningTitle": "インデックスライフサイクルポリシーが定義されていません", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.noPolicySelectedErrorMessage": "ポリシーの選択が必要です。", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyToTemplateConfirmModal.indexHasNoAliasesWarningMessage": "このインデックステンプレートには既にポリシー {existingPolicyName} が適用されています。このポリシーを追加するとこの構成が上書きされます。", + "xpack.indexLifecycleMgmt.indexManagementTable.removeLifecyclePolicyConfirmModal.cancelButtonText": "キャンセル", + "xpack.indexLifecycleMgmt.indexManagementTable.removeLifecyclePolicyConfirmModal.removePolicyButtonText": "ポリシーを削除", + "xpack.indexLifecycleMgmt.indexManagementTable.removeLifecyclePolicyConfirmModal.removePolicyToIndexError": "ポリシーの削除中にエラーが発生しました", + "xpack.indexLifecycleMgmt.indexMgmtBanner.errorMessage": "{ numIndicesWithLifecycleErrors, number}\n {numIndicesWithLifecycleErrors, plural, one {インデックスに} other {インデックスに} }\n インデックスライフサイクルエラー", + "xpack.indexLifecycleMgmt.indexMgmtBanner.filterLabel": "エラーを表示", + "xpack.indexLifecycleMgmt.indexMgmtFilter.lifecycleStatusLabel": "ライフサイクルステータス", + "xpack.indexLifecycleMgmt.indexMgmtFilter.managedLabel": "管理中", + "xpack.indexLifecycleMgmt.indexMgmtFilter.unmanagedLabel": "管理対象外", + "xpack.indexLifecycleMgmt.indexPriorityLabel": "インデックスの優先順位", + "xpack.indexLifecycleMgmt.learnMore": "その他のリソース", + "xpack.indexLifecycleMgmt.nodeAttrDetails.hostField": "ホスト", + "xpack.indexLifecycleMgmt.nodeAttrDetails.idField": "ID", + "xpack.indexLifecycleMgmt.nodeAttrDetails.nameField": "名前", + "xpack.indexLifecycleMgmt.nodeAttrDetails.title": "属性 {selectedNodeAttrs} を含むノード", + "xpack.indexLifecycleMgmt.noMatch.noPolicicesDescription": "表示するポリシーがありません", + "xpack.indexLifecycleMgmt.optionalMessage": " (オプション)", + "xpack.indexLifecycleMgmt.policyJsonFlyout.closeButtonLabel": "閉じる", + "xpack.indexLifecycleMgmt.policyJsonFlyout.descriptionText": "この Elasticsearch リクエストは、このインデックスライフサイクルポリシーを作成または更新します。", + "xpack.indexLifecycleMgmt.policyJsonFlyout.namedTitle": "「{policyName}」のリクエスト", + "xpack.indexLifecycleMgmt.policyJsonFlyout.unnamedTitle": "リクエスト", + "xpack.indexLifecycleMgmt.policyTable.actionsButtonText": "アクション", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.cancelButton": "キャンセル", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.chooseTemplateLabel": "インデックステンプレート", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.chooseTemplateMessage": "インデックステンプレートを選択してください", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.confirmButton": "ポリシーを追加", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.errorMessage": "インデックステンプレート {templateName} へのポリシー {policyName} の追加中にエラーが発生しました", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.explanationText": "これにより、インデックステンプレートと一致するすべてのインデックスにライフサイクルポリシーが適用されます。", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.noTemplateSelectedErrorMessage": "インデックステンプレートの選択が必要です。", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.rolloverAliasLabel": "ロールオーバーインデックスのエイリアス", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.successMessage": "インデックステンプレート {templateName} にポリシー {policyName} を追加しました", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.templateHasPolicyWarningTitle": "テンプレートに既にポリシーがあります", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.title": "インデックステンプレートにポリシー「{name}」 を追加", + "xpack.indexLifecycleMgmt.policyTable.addPolicyToTemplateButtonText": "インデックステンプレートにポリシーを追加", + "xpack.indexLifecycleMgmt.policyTable.captionText": "以下は {total} 列中 {count, plural, one {# 列} other {# 列}} を含むインデックスライフサイクルポリシー表です。", + "xpack.indexLifecycleMgmt.policyTable.deletedPoliciesText": "{numSelected} 件の{numSelected, plural, one {ポリシー} other {ポリシー}}が削除されました", + "xpack.indexLifecycleMgmt.policyTable.deletePolicyButtonDisabledTooltip": "インデックスが使用中のポリシーは削除できません", + "xpack.indexLifecycleMgmt.policyTable.deletePolicyButtonText": "ポリシーを削除", + "xpack.indexLifecycleMgmt.policyTable.emptyPrompt.createButtonLabel": "ポリシーを作成", + "xpack.indexLifecycleMgmt.policyTable.emptyPromptDescription": " ライフサイクルポリシーは、インデックスが古くなるにつれ管理しやすくなります。", + "xpack.indexLifecycleMgmt.policyTable.emptyPromptTitle": "初めのインデックスライフサイクルポリシーの作成", + "xpack.indexLifecycleMgmt.policyTable.headers.linkedIndicesHeader": "リンクされたインデクス", + "xpack.indexLifecycleMgmt.policyTable.headers.modifiedDateHeader": "変更日", + "xpack.indexLifecycleMgmt.policyTable.headers.nameHeader": "名前", + "xpack.indexLifecycleMgmt.policyTable.headers.versionHeader": "バージョン", + "xpack.indexLifecycleMgmt.policyTable.policyActionsMenu.panelTitle": "ポリシーオプション", + "xpack.indexLifecycleMgmt.policyTable.sectionDescription": "インデックスが古くなるにつれ管理します。 インデックスのライフサイクルにおける進捗のタイミングと方法を自動化するポリシーを設定します。", + "xpack.indexLifecycleMgmt.policyTable.sectionHeading": "インデックスライフサイクルポリシー", + "xpack.indexLifecycleMgmt.policyTable.systempoliciesSearchInputAriaLabel": "検索ポリシー", + "xpack.indexLifecycleMgmt.policyTable.systempoliciesSearchInputPlaceholder": "検索", + "xpack.indexLifecycleMgmt.policyTable.viewIndicesButtonText": "ポリシーにリンクされたインデックスを表示", + "xpack.indexLifecycleMgmt.removeIndexLifecycleActionButtonLabel": "ライフサイクルポリシーを削除", + "xpack.indexLifecycleMgmt.retryIndexLifecycleAction.retriedLifecycleMessage": "ライフサイクルのステップを再試行します {indexNames}", + "xpack.indexLifecycleMgmt.retryIndexLifecycleActionButtonLabel": "ライフサイクルのステップを再試行", + "xpack.indexLifecycleMgmt.warmPhase.forceMergeDataLabel": "データを強制結合", + "xpack.indexLifecycleMgmt.warmPhase.moveToWarmPhaseOnRolloverLabel": "ロールオーバー時にウォームフェーズに変更", + "xpack.indexLifecycleMgmt.warmPhase.numberOfPrimaryShardsLabel": "プライマリシャードの数", + "xpack.indexLifecycleMgmt.warmPhase.numberOfReplicasLabel": "レプリカの数", + "xpack.indexLifecycleMgmt.warmPhase.numberOfSegmentsLabel": "セグメントの数", + "xpack.indexLifecycleMgmt.warmPhase.replicaCountHelpText": "デフォルトで、レプリカの数は同じままになります。", + "xpack.indexLifecycleMgmt.warmPhase.shrinkIndexLabel": "インデックスを縮小", + "xpack.infra.analysisSetup.actionStepTitle": "MLジョブを作成", + "xpack.infra.analysisSetup.analysisSetupDescription": "機械学習を使用して自動的に異常ログレートカウントを検出します。", + "xpack.infra.analysisSetup.analysisSetupTitle": "機械学習分析を有効にする", + "xpack.infra.analysisSetup.configurationStepTitle": "構成", + "xpack.infra.analysisSetup.createMlJobButton": "ML ジョブを作成", + "xpack.infra.analysisSetup.deleteAnalysisResultsWarning": "これにより以前検出された異常が削除されます。", + "xpack.infra.analysisSetup.endTimeDefaultDescription": "永久", + "xpack.infra.analysisSetup.endTimeLabel": "終了時刻", + "xpack.infra.analysisSetup.indicesSelectionDescription": "既定では、機械学習は、ソースに対して構成されたすべてのログインデックスにあるログメッセージを分析します。インデックス名のサブセットのみを分析することを選択できます。すべての選択したインデックス名は、ログエントリを含む1つ以上のインデックスと一致する必要があります。", + "xpack.infra.analysisSetup.indicesSelectionLabel": "インデックス", + "xpack.infra.analysisSetup.indicesSelectionTitle": "インデックスを選択", + "xpack.infra.analysisSetup.indicesSelectionTooFewSelectedIndicesDescription": "1つ以上のインデックス名を選択してください。", + "xpack.infra.analysisSetup.recreateMlJobButton": "ML ジョブを再作成", + "xpack.infra.analysisSetup.startTimeDefaultDescription": "ログインデックスの開始地点です。", + "xpack.infra.analysisSetup.startTimeLabel": "開始時刻", + "xpack.infra.analysisSetup.steps.setupProcess.errorCalloutTitle": "エラーが発生しました", + "xpack.infra.analysisSetup.steps.setupProcess.failureText": "必要なMLジョブの作成中に問題が発生しました。すべての選択したログインデックスが存在していることを確認してください。", + "xpack.infra.analysisSetup.steps.setupProcess.loadingText": "ML ジョブを作成中…", + "xpack.infra.analysisSetup.steps.setupProcess.successText": "ML ジョブが正常に設定されました", + "xpack.infra.analysisSetup.steps.setupProcess.tryAgainButton": "再試行", + "xpack.infra.analysisSetup.steps.setupProcess.viewResultsButton": "結果を表示", + "xpack.infra.analysisSetup.timeRangeDescription": "デフォルトで、機械学習は 4 週間以内のログインデックスのログメッセージを分析し、永久に継続します。別の開始日、終了日、または両方を指定できます。", + "xpack.infra.analysisSetup.timeRangeTitle": "時間範囲の選択", + "xpack.infra.chartSection.missingMetricDataBody": "このチャートはデータが欠けています。", + "xpack.infra.chartSection.missingMetricDataText": "データが欠けています", + "xpack.infra.chartSection.notEnoughDataPointsToRenderText": "チャートのレンダリングに必要なデータポイントが足りません。時間範囲を広げてみてください。", + "xpack.infra.chartSection.notEnoughDataPointsToRenderTitle": "データが不十分です", + "xpack.infra.common.tabBetaBadgeLabel": "ベータ", + "xpack.infra.common.tabBetaBadgeTooltipContent": "この機能は現在開発中です。他にも機能が追加され、機能によっては変更されるものもあります。", + "xpack.infra.configureSourceActionLabel": "ソース構成を変更", + "xpack.infra.errorPage.errorOccurredTitle": "エラーが発生しました", + "xpack.infra.errorPage.tryAgainButtonLabel": "再試行", + "xpack.infra.errorPage.tryAgainDescription ": "戻るボタンをクリックして再試行してください。", + "xpack.infra.errorPage.unexpectedErrorTitle": "おっと!", + "xpack.infra.featureRegistry.linkInfrastructureTitle": "メトリック", + "xpack.infra.featureRegistry.linkLogsTitle": "ログ", + "xpack.infra.groupByDisplayNames.availabilityZone": "アベイラビリティゾーン", + "xpack.infra.groupByDisplayNames.hostName": "ホスト", + "xpack.infra.groupByDisplayNames.kubernetesNamespace": "ネームスペース", + "xpack.infra.groupByDisplayNames.kubernetesNodeName": "ノード", + "xpack.infra.groupByDisplayNames.machineType": "マシンタイプ", + "xpack.infra.groupByDisplayNames.projectID": "プロジェクト ID", + "xpack.infra.groupByDisplayNames.provider": "クラウドプロバイダー", + "xpack.infra.groupByDisplayNames.serviceType": "サービスタイプ", + "xpack.infra.header.badge.readOnly.text": "読み込み専用", + "xpack.infra.header.badge.readOnly.tooltip": "ソース構成を変更できません", + "xpack.infra.header.infrastructureTitle": "メトリック", + "xpack.infra.header.logsTitle": "ログ", + "xpack.infra.homePage.documentTitle": "メトリック", + "xpack.infra.homePage.inventoryTabTitle": "インベントリ", + "xpack.infra.homePage.metricsExplorerTabTitle": "メトリックエクスプローラー", + "xpack.infra.homePage.noMetricsIndicesDescription": "追加しましょう!", + "xpack.infra.homePage.noMetricsIndicesInstructionsActionLabel": "セットアップの手順を表示", + "xpack.infra.homePage.noMetricsIndicesTitle": "メトリックインデックスがないようです。", + "xpack.infra.homePage.settingsTabTitle": "設定", + "xpack.infra.homePage.toolbar.kqlSearchFieldPlaceholder": "インフラストラクチャーデータを検索… (例: host.name:host-1)", + "xpack.infra.infrastructureDescription": "インフラストラクチャーを閲覧します", + "xpack.infra.infrastructureMetricsExplorerPage.documentTitle": "{previousTitle} | メトリックエクスプローラー", + "xpack.infra.infrastructureSnapshotPage.documentTitle": "{previousTitle} | インベントリ", + "xpack.infra.infrastructureTitle": "メトリック", + "xpack.infra.kibanaMetrics.cloudIdMissingErrorMessage": "{metricId} のモデルには cloudId が必要ですが、{nodeId} に cloudId が指定されていません。", + "xpack.infra.kibanaMetrics.invalidInfraMetricErrorMessage": "{id} は有効な InfraMetric ではありません", + "xpack.infra.kibanaMetrics.nodeDoesNotExistErrorMessage": "{nodeId} が存在しません。", + "xpack.infra.legendControls.applyButton": "適用", + "xpack.infra.legendControls.buttonLabel": "凡例を校正", + "xpack.infra.legendControls.errorMessage": "最低値は最高値よりも低く設定する必要があります", + "xpack.infra.legendControls.maxLabel": "最高", + "xpack.infra.legendControls.minLabel": "最低", + "xpack.infra.legendControls.switchLabel": "自動計算範囲", + "xpack.infra.linkInfrastructureDescription": "インフラストラクチャーを閲覧します", + "xpack.infra.linkInfrastructureTitle": "メトリック", + "xpack.infra.linkLogsDescription": "ログを閲覧します", + "xpack.infra.linkLogsTitle": "ログ", + "xpack.infra.linkTo.hostWithIp.error": "IP アドレス「{hostIp}」でホストが見つかりません.", + "xpack.infra.linkTo.hostWithIp.loading": "IP アドレス「{hostIp}」のホストを読み込み中", + "xpack.infra.logEntryActionsMenu.apmActionLabel": "APMで表示", + "xpack.infra.logEntryActionsMenu.buttonLabel": "アクション", + "xpack.infra.logEntryActionsMenu.uptimeActionLabel": "監視ステータスを表示", + "xpack.infra.logEntryItemView.viewDetailsToolTip": "詳細を表示", + "xpack.infra.logFlyout.fieldColumnLabel": "フィールド", + "xpack.infra.logFlyout.filterAriaLabel": "フィルター", + "xpack.infra.logFlyout.flyoutTitle": "ログイベントドキュメントの詳細", + "xpack.infra.logFlyout.loadingMessage": "イベントを読み込み中", + "xpack.infra.logFlyout.setFilterTooltip": "フィルターでイベントを表示", + "xpack.infra.logFlyout.valueColumnLabel": "値", + "xpack.infra.logs.analysis.analyzeInMlButtonLabel": "ML で分析", + "xpack.infra.logs.analysis.anomaliesExpandedRowNumberOfLogEntriesDescription": "ログエントリーの数です", + "xpack.infra.logs.analysis.anomaliesSectionLineSeriesName": "15 分ごとのログエントリー (平均)", + "xpack.infra.logs.analysis.anomaliesSectionLoadingAriaLabel": "異常を読み込み中", + "xpack.infra.logs.analysis.anomaliesSectionTitle": "異常", + "xpack.infra.logs.analysis.anomaliesTableCollapseLabel": "縮小", + "xpack.infra.logs.analysis.anomaliesTableExpandLabel": "拡張", + "xpack.infra.logs.analysis.anomaliesTableMaxAnomalyScoreColumnName": "最高異常スコア", + "xpack.infra.logs.analysis.anomaliesTablePartitionColumnName": "パーティション", + "xpack.infra.logs.analysis.anomalySectionNoAnomaliesTitle": "異常が検出されませんでした。", + "xpack.infra.logs.analysis.anomalySectionNoDataBody": "時間範囲を調整する必要があるかもしれません。", + "xpack.infra.logs.analysis.anomalySectionNoDataTitle": "表示するデータがありません。", + "xpack.infra.logs.analysis.jobConfigurationOutdatedCalloutMessage": "異なるソース構成を使用して ML ジョブが作成されました。現在の構成を適用するにはジョブを再作成してください。これにより以前検出された異常が削除されます。", + "xpack.infra.logs.analysis.jobConfigurationOutdatedCalloutTitle": "古い ML ジョブ構成", + "xpack.infra.logs.analysis.jobDefinitionOutdatedCalloutMessage": "ML ジョブの新しいバージョンが利用可能です。新しいバージョンをデプロイするにはジョブを再作成してください。これにより以前検出された異常が削除されます。", + "xpack.infra.logs.analysis.jobDefinitionOutdatedCalloutTitle": "古い ML ジョブ定義", + "xpack.infra.logs.analysis.jobStoppedCalloutMessage": "ML ジョブが手動またはリソース不足により停止しました。新しいログエントリーはジョブが再起動するまで処理されません。", + "xpack.infra.logs.analysis.jobStoppedCalloutTitle": "ML ジョブが停止しました", + "xpack.infra.logs.analysis.logRateResultsToolbarText": "{startTime} から {endTime} までの {numberOfLogs} 件のログエントリーを分析しました", + "xpack.infra.logs.analysis.logRateSectionBucketSpanLabel": "バケットスパン:", + "xpack.infra.logs.analysis.logRateSectionBucketSpanValue": "15 分", + "xpack.infra.logs.analysis.logRateSectionLineSeriesName": "15 分ごとのログエントリー (平均)", + "xpack.infra.logs.analysis.logRateSectionLoadingAriaLabel": "ログレートの結果を読み込み中", + "xpack.infra.logs.analysis.logRateSectionNoDataBody": "時間範囲を調整する必要があるかもしれません。", + "xpack.infra.logs.analysis.logRateSectionNoDataTitle": "表示するデータがありません。", + "xpack.infra.logs.analysis.logRateSectionTitle": "ログレート", + "xpack.infra.logs.analysis.overallAnomaliesNumberOfLogEntriesDescription": "ログエントリーの数です", + "xpack.infra.logs.analysis.overallAnomaliesTopAnomalyScoreDescription": "最高異常スコア", + "xpack.infra.logs.analysis.overallAnomalyChartMaxScoresLabel": "最高異常スコア", + "xpack.infra.logs.analysis.partitionMaxAnomalyScoreAnnotationLabel": "最高異常スコア: {maxAnomalyScore}", + "xpack.infra.logs.analysis.recreateJobButtonLabel": "ML ジョブを再作成", + "xpack.infra.logs.analysisPage.loadingMessage": "分析ジョブのステータスを確認中…", + "xpack.infra.logs.analysisPage.unavailable.mlAppLink": "機械学習アプリ", + "xpack.infra.logs.customizeLogs.customizeButtonLabel": "カスタマイズ", + "xpack.infra.logs.customizeLogs.lineWrappingFormRowLabel": "改行", + "xpack.infra.logs.customizeLogs.minimapScaleFormRowLabel": "ミニマップスケール", + "xpack.infra.logs.customizeLogs.textSizeFormRowLabel": "テキストサイズ", + "xpack.infra.logs.customizeLogs.textSizeRadioGroup": "{textScale, select, small {小さい} 中くらい {Medium} 大きい {Large} その他の {{textScale}} }", + "xpack.infra.logs.customizeLogs.wrapLongLinesSwitchLabel": "長い行を改行", + "xpack.infra.logs.emptyView.checkForNewDataButtonLabel": "新規データを確認", + "xpack.infra.logs.emptyView.noLogMessageDescription": "フィルターを調整してみてください。", + "xpack.infra.logs.emptyView.noLogMessageTitle": "表示するログメッセージがありません。", + "xpack.infra.logs.highlights.clearHighlightTermsButtonLabel": "ハイライトする用語をクリア", + "xpack.infra.logs.highlights.goToNextHighlightButtonLabel": "次のハイライトにスキップ", + "xpack.infra.logs.highlights.goToPreviousHighlightButtonLabel": "前のハイライトにスキップ", + "xpack.infra.logs.highlights.highlightsPopoverButtonLabel": "ハイライト", + "xpack.infra.logs.highlights.highlightTermsFieldLabel": "ハイライトする用語", + "xpack.infra.logs.index.settingsTabTitle": "設定", + "xpack.infra.logs.index.streamTabTitle": "ストリーム", + "xpack.infra.logs.jumpToTailText": "最も新しいエントリーに移動", + "xpack.infra.logs.lastStreamingUpdateText": " 最終更新 {lastUpdateTime}", + "xpack.infra.logs.loadAgainButtonLabel": "再読み込み", + "xpack.infra.logs.loadingAdditionalEntriesText": "追加エントリーを読み込み中", + "xpack.infra.logs.noAdditionalEntriesFoundText": "追加エントリーが見つかりません", + "xpack.infra.logs.scrollableLogTextStreamView.loadingEntriesLabel": "エントリーを読み込み中", + "xpack.infra.logs.search.nextButtonLabel": "次へ", + "xpack.infra.logs.search.previousButtonLabel": "前へ", + "xpack.infra.logs.search.searchInLogsAriaLabel": "検索", + "xpack.infra.logs.search.searchInLogsPlaceholder": "検索", + "xpack.infra.logs.searchResultTooltip": "{bucketCount, plural, one {# 件のハイライトされたエントリー} other {# 件のハイライトされたエントリー}}", + "xpack.infra.logs.startStreamingButtonLabel": "ライブストリーム", + "xpack.infra.logs.stopStreamingButtonLabel": "ストリーム停止", + "xpack.infra.logs.streamingDescription": "新しいエントリーをストリーム中...", + "xpack.infra.logs.streamingNewEntriesText": "新しいエントリーをストリーム中", + "xpack.infra.logs.streamPage.documentTitle": "{previousTitle} | ストリーム", + "xpack.infra.logsPage.noLoggingIndicesDescription": "追加しましょう!", + "xpack.infra.logsPage.noLoggingIndicesInstructionsActionLabel": "セットアップの手順を表示", + "xpack.infra.logsPage.noLoggingIndicesTitle": "ログインデックスがないようです。", + "xpack.infra.logsPage.toolbar.kqlSearchFieldAriaLabel": "ログエントリーを検索", + "xpack.infra.logsPage.toolbar.kqlSearchFieldPlaceholder": "ログエントリーを検索中… (例: host.name:host-1)", + "xpack.infra.mapLogs.oneDayLabel": "1 日", + "xpack.infra.mapLogs.oneHourLabel": "1 時間", + "xpack.infra.mapLogs.oneMinuteLabel": "1 分", + "xpack.infra.mapLogs.oneMonthLabel": "1 か月", + "xpack.infra.mapLogs.oneWeekLabel": "1 週間", + "xpack.infra.mapLogs.oneYearLabel": "1 年", + "xpack.infra.metricDetailPage.awsMetricsLayout.cpuUtilSection.percentSeriesLabel": "パーセント", + "xpack.infra.metricDetailPage.awsMetricsLayout.cpuUtilSection.sectionLabel": "CPU 使用状況", + "xpack.infra.metricDetailPage.awsMetricsLayout.diskioBytesSection.readsSeriesLabel": "読み取り", + "xpack.infra.metricDetailPage.awsMetricsLayout.diskioBytesSection.sectionLabel": "ディスク I/O バイト", + "xpack.infra.metricDetailPage.awsMetricsLayout.diskioBytesSection.writesSeriesLabel": "書き込み", + "xpack.infra.metricDetailPage.awsMetricsLayout.diskioOperationsSection.readsSeriesLabel": "読み取り", + "xpack.infra.metricDetailPage.awsMetricsLayout.diskioOperationsSection.sectionLabel": "ディスク I/O オペレーション", + "xpack.infra.metricDetailPage.awsMetricsLayout.diskioOperationsSection.writesSeriesLabel": "書き込み", + "xpack.infra.metricDetailPage.awsMetricsLayout.networkBytesSection.rxSeriesLabel": "次に含まれる:", + "xpack.infra.metricDetailPage.awsMetricsLayout.networkBytesSection.sectionLabel": "ネットワークトラフィック", + "xpack.infra.metricDetailPage.awsMetricsLayout.networkBytesSection.txSeriesLabel": "出", + "xpack.infra.metricDetailPage.awsMetricsLayout.networkPacketsSection.packetsInSeriesLabel": "次に含まれる:", + "xpack.infra.metricDetailPage.awsMetricsLayout.networkPacketsSection.packetsOutSeriesLabel": "出", + "xpack.infra.metricDetailPage.awsMetricsLayout.networkPacketsSection.sectionLabel": "ネットワークパケット (平均)", + "xpack.infra.metricDetailPage.awsMetricsLayout.overviewSection.cpuUtilizationSeriesLabel": "CPU 使用状況", + "xpack.infra.metricDetailPage.awsMetricsLayout.overviewSection.networkPacketsInLabel": "パケット (受信)", + "xpack.infra.metricDetailPage.awsMetricsLayout.overviewSection.networkPacketsOutLabel": "パケット (送信)", + "xpack.infra.metricDetailPage.awsMetricsLayout.overviewSection.sectionLabel": "概要", + "xpack.infra.metricDetailPage.awsMetricsLayout.overviewSection.statusCheckFailedLabel": "ステータス確認失敗", + "xpack.infra.metricDetailPage.containerMetricsLayout.cpuUsageSection.sectionLabel": "CPU 使用状況", + "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoBytesSection.readRateSeriesLabel": "読み取り", + "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoBytesSection.sectionLabel": "ディスク IO (バイト)", + "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoBytesSection.writeRateSeriesLabel": "書き込み", + "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoOpsSection.readRateSeriesLabel": "読み取り", + "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoOpsSection.sectionLabel": "ディスク IO (Ops)", + "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoOpsSection.writeRateSeriesLabel": "書き込み", + "xpack.infra.metricDetailPage.containerMetricsLayout.layoutLabel": "コンテナー", + "xpack.infra.metricDetailPage.containerMetricsLayout.memoryUsageSection.sectionLabel": "メモリー使用状況", + "xpack.infra.metricDetailPage.containerMetricsLayout.networkTrafficSection.networkRxRateSeriesLabel": "入", + "xpack.infra.metricDetailPage.containerMetricsLayout.networkTrafficSection.networkTxRateSeriesLabel": "出", + "xpack.infra.metricDetailPage.containerMetricsLayout.networkTrafficSection.sectionLabel": "ネットワークトラフィック", + "xpack.infra.metricDetailPage.containerMetricsLayout.overviewSection.cpuUsageSeriesLabel": "CPU 使用状況", + "xpack.infra.metricDetailPage.containerMetricsLayout.overviewSection.inboundRXSeriesLabel": "受信 (RX)", + "xpack.infra.metricDetailPage.containerMetricsLayout.overviewSection.memoryUsageSeriesLabel": "メモリー使用状況", + "xpack.infra.metricDetailPage.containerMetricsLayout.overviewSection.outboundTXSeriesLabel": "送信 (TX)", + "xpack.infra.metricDetailPage.containerMetricsLayout.overviewSection.sectionLabel": "概要", + "xpack.infra.metricDetailPage.documentTitle": "インフラストラクチャー | メトリック | {name}", + "xpack.infra.metricDetailPage.documentTitleError": "{previousTitle} | おっと", + "xpack.infra.metricDetailPage.hostMetricsLayout.cpuUsageSection.sectionLabel": "CPU 使用状況", + "xpack.infra.metricDetailPage.hostMetricsLayout.layoutLabel": "ホスト", + "xpack.infra.metricDetailPage.hostMetricsLayout.loadSection.fifteenMinuteSeriesLabel": "15m", + "xpack.infra.metricDetailPage.hostMetricsLayout.loadSection.fiveMinuteSeriesLabel": "5分", + "xpack.infra.metricDetailPage.hostMetricsLayout.loadSection.oneMinuteSeriesLabel": "1m", + "xpack.infra.metricDetailPage.hostMetricsLayout.loadSection.sectionLabel": "読み込み", + "xpack.infra.metricDetailPage.hostMetricsLayout.memoryUsageSection.sectionLabel": "メモリー使用状況", + "xpack.infra.metricDetailPage.hostMetricsLayout.networkTrafficSection.networkRxRateSeriesLabel": "入", + "xpack.infra.metricDetailPage.hostMetricsLayout.networkTrafficSection.networkTxRateSeriesLabel": "出", + "xpack.infra.metricDetailPage.hostMetricsLayout.networkTrafficSection.sectionLabel": "ネットワークトラフィック", + "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.cpuUsageSeriesLabel": "CPU 使用状況", + "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.inboundRXSeriesLabel": "受信 (RX)", + "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.loadSeriesLabel": "読み込み (5m)", + "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.memoryCapacitySeriesLabel": "メモリー使用状況", + "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.outboundTXSeriesLabel": "送信 (TX)", + "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.sectionLabel": "概要", + "xpack.infra.metricDetailPage.kubernetesMetricsLayout.nodeCpuCapacitySection.sectionLabel": "ノード CPU 処理能力", + "xpack.infra.metricDetailPage.kubernetesMetricsLayout.nodeDiskCapacitySection.sectionLabel": "ノードディスク容量", + "xpack.infra.metricDetailPage.kubernetesMetricsLayout.nodeMemoryCapacitySection.sectionLabel": "ノードメモリー容量", + "xpack.infra.metricDetailPage.kubernetesMetricsLayout.nodePodCapacitySection.sectionLabel": "ノードポッド容量", + "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.cpuUsageSeriesLabel": "CPU 処理能力", + "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.diskCapacitySeriesLabel": "ディスク容量", + "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.loadSeriesLabel": "読み込み (5m)", + "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.memoryUsageSeriesLabel": "メモリー容量", + "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.podCapacitySeriesLabel": "ポッド容量", + "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.sectionLabel": "概要", + "xpack.infra.metricDetailPage.nginxMetricsLayout.activeConnectionsSection.sectionLabel": "アクティブな接続", + "xpack.infra.metricDetailPage.nginxMetricsLayout.hitsSection.sectionLabel": "ヒット", + "xpack.infra.metricDetailPage.nginxMetricsLayout.requestRateSection.sectionLabel": "リクエストレート", + "xpack.infra.metricDetailPage.nginxMetricsLayout.requestsPerConnectionsSection.reqsPerConnSeriesLabel": "接続あたりのリクエスト数", + "xpack.infra.metricDetailPage.nginxMetricsLayout.requestsPerConnectionsSection.sectionLabel": "接続あたりのリクエスト数", + "xpack.infra.metricDetailPage.podMetricsLayout.cpuUsageSection.sectionLabel": "CPU 使用状況", + "xpack.infra.metricDetailPage.podMetricsLayout.layoutLabel": "ポッド", + "xpack.infra.metricDetailPage.podMetricsLayout.memoryUsageSection.sectionLabel": "メモリー使用状況", + "xpack.infra.metricDetailPage.podMetricsLayout.networkTrafficSection.networkRxRateSeriesLabel": "入", + "xpack.infra.metricDetailPage.podMetricsLayout.networkTrafficSection.networkTxRateSeriesLabel": "出", + "xpack.infra.metricDetailPage.podMetricsLayout.networkTrafficSection.sectionLabel": "ネットワークトラフィック", + "xpack.infra.metricDetailPage.podMetricsLayout.overviewSection.cpuUsageSeriesLabel": "CPU 使用状況", + "xpack.infra.metricDetailPage.podMetricsLayout.overviewSection.inboundRXSeriesLabel": "受信 (RX)", + "xpack.infra.metricDetailPage.podMetricsLayout.overviewSection.memoryUsageSeriesLabel": "メモリー使用状況", + "xpack.infra.metricDetailPage.podMetricsLayout.overviewSection.outboundTXSeriesLabel": "送信 (TX)", + "xpack.infra.metricDetailPage.podMetricsLayout.overviewSection.sectionLabel": "概要", + "xpack.infra.metrics.emptyViewDescription": "期間またはフィルターを調整してみてください。", + "xpack.infra.metrics.emptyViewTitle": "表示するデータがありません。", + "xpack.infra.metrics.invalidNodeErrorDescription": "構成をよく確認してください", + "xpack.infra.metrics.invalidNodeErrorTitle": "{nodeName} がメトリックデータを収集していないようです", + "xpack.infra.metrics.loadingNodeDataText": "データを読み込み中", + "xpack.infra.metrics.refetchButtonLabel": "新規データを確認", + "xpack.infra.metricsExplorer.actionsLabel.aria": "{grouping} のアクション", + "xpack.infra.metricsExplorer.actionsLabel.button": "アクション", + "xpack.infra.metricsExplorer.aggregationLabel": "/", + "xpack.infra.metricsExplorer.aggregationLables.avg": "平均", + "xpack.infra.metricsExplorer.aggregationLables.cardinality": "基数", + "xpack.infra.metricsExplorer.aggregationLables.count": "ドキュメントカウント", + "xpack.infra.metricsExplorer.aggregationLables.max": "最高", + "xpack.infra.metricsExplorer.aggregationLables.min": "最低", + "xpack.infra.metricsExplorer.aggregationLables.rate": "レート", + "xpack.infra.metricsExplorer.aggregationSelectLabel": "集約を選択してください", + "xpack.infra.metricsExplorer.chartOptions.areaLabel": "エリア", + "xpack.infra.metricsExplorer.chartOptions.autoLabel": "自動 (最低 ~ 最高)", + "xpack.infra.metricsExplorer.chartOptions.barLabel": "バー", + "xpack.infra.metricsExplorer.chartOptions.fromZeroLabel": "ゼロから (0 ~ 最高)", + "xpack.infra.metricsExplorer.chartOptions.lineLabel": "折れ線", + "xpack.infra.metricsExplorer.chartOptions.stackLabel": "スタックシリーズ", + "xpack.infra.metricsExplorer.chartOptions.stackSwitchLabel": "スタック", + "xpack.infra.metricsExplorer.chartOptions.typeLabel": "チャートスタイル", + "xpack.infra.metricsExplorer.chartOptions.yAxisDomainLabel": "Y 軸ドメイン", + "xpack.infra.metricsExplorer.customizeChartOptions": "カスタマイズ", + "xpack.infra.metricsExplorer.emptyChart.body": "チャートをレンダリングできません。", + "xpack.infra.metricsExplorer.emptyChart.title": "チャートデータがありません", + "xpack.infra.metricsExplorer.errorMessage": "「{message}」によりリクエストは実行されませんでした", + "xpack.infra.metricsExplorer.filterByLabel": "フィルターを追加します", + "xpack.infra.metricsExplorer.footerPaginationMessage": "「{groupBy}」でグループ化された{total}件中{length}件のチャートを表示しています。", + "xpack.infra.metricsExplorer.groupByLabel": "すべて", + "xpack.infra.metricsExplorer.groupByToolbarLabel": "graph/", + "xpack.infra.metricsExplorer.loadingCharts": "チャートを読み込み中", + "xpack.infra.metricsExplorer.loadMoreChartsButton": "さらにチャートを読み込む", + "xpack.infra.metricsExplorer.metricComboBoxPlaceholder": "プロットするメトリックを選択してください", + "xpack.infra.metricsExplorer.noDataBodyText": "設定で時間、フィルター、またはグループを調整してみてください。", + "xpack.infra.metricsExplorer.noDataRefetchText": "新規データを確認", + "xpack.infra.metricsExplorer.noDataTitle": "表示するデータがありません。", + "xpack.infra.metricsExplorer.noMetrics.body": "上でメトリックを選択してください。", + "xpack.infra.metricsExplorer.noMetrics.title": "不足しているメトリック", + "xpack.infra.metricsExplorer.openInTSVB": "ビジュアライザーで開く", + "xpack.infra.metricsExplorer.viewNodeDetail": "{name} のメトリックを表示", + "xpack.infra.node.ariaLabel": "{nodeName}、クリックしてメニューを開きます", + "xpack.infra.nodeContextMenu.viewLogsName": "ログを表示", + "xpack.infra.nodeContextMenu.viewMetricsName": "メトリックを表示", + "xpack.infra.nodeDetails.labels.availabilityZone": "アベイラビリティゾーン", + "xpack.infra.nodeDetails.labels.cloudProvider": "クラウドプロバイダー", + "xpack.infra.nodeDetails.labels.containerized": "コンテナー化", + "xpack.infra.nodeDetails.labels.hostname": "ホスト名", + "xpack.infra.nodeDetails.labels.instanceId": "インスタンス ID", + "xpack.infra.nodeDetails.labels.instanceName": "インスタンス名", + "xpack.infra.nodeDetails.labels.kernelVersion": "カーネルバージョン", + "xpack.infra.nodeDetails.labels.machineType": "マシンタイプ", + "xpack.infra.nodeDetails.labels.operatinSystem": "オペレーティングシステム", + "xpack.infra.nodeDetails.labels.projectId": "プロジェクト ID", + "xpack.infra.nodeDetails.labels.showMoreDetails": "他の詳細を表示", + "xpack.infra.nodeDetails.no": "いいえ", + "xpack.infra.nodeDetails.yes": "はい", + "xpack.infra.nodesToWaffleMap.groupsWithGroups.allName": "すべて", + "xpack.infra.nodesToWaffleMap.groupsWithNodes.allName": "すべて", + "xpack.infra.notFoundPage.noContentFoundErrorTitle": "コンテンツがありません", + "xpack.infra.openView.actionNames.deleteConfirmation": "ビューを削除しますか?", + "xpack.infra.openView.cancelButton": "キャンセル", + "xpack.infra.openView.columnNames.actions": "アクション", + "xpack.infra.openView.columnNames.name": "名前", + "xpack.infra.openView.flyoutHeader": "ビューを読み込む", + "xpack.infra.redirectToNodeLogs.loadingNodeLogsMessage": "{nodeType} ログを読み込み中", + "xpack.infra.registerFeatures.infraOpsDescription": "共通のサーバー、コンテナー、サービスのインフラストラクチャーメトリックとログを閲覧します。", + "xpack.infra.registerFeatures.infraOpsTitle": "メトリック", + "xpack.infra.registerFeatures.logsDescription": "ログをリアルタイムでストリーするか、コンソール式の UI で履歴ビューをスクロールします。", + "xpack.infra.registerFeatures.logsTitle": "ログ", + "xpack.infra.sampleDataLinkLabel": "ログ", + "xpack.infra.savedView.defaultViewName": "デフォルト", + "xpack.infra.savedView.errorOnCreate.title": "ビューの保存中にエラーが発生しました。", + "xpack.infra.savedView.findError.title": "ビューの読み込み中にエラーが発生しました。", + "xpack.infra.sourceConfiguration.addLogColumnButtonLabel": "列を追加", + "xpack.infra.sourceConfiguration.applySettingsButtonLabel": "申し込む", + "xpack.infra.sourceConfiguration.containerFieldDescription": "Docker コンテナーの識別に使用されるフィールドです", + "xpack.infra.sourceConfiguration.containerFieldLabel": "コンテナー ID", + "xpack.infra.sourceConfiguration.containerFieldRecommendedValue": "推奨値は {defaultValue} です", + "xpack.infra.sourceConfiguration.discardSettingsButtonLabel": "破棄", + "xpack.infra.sourceConfiguration.fieldEmptyErrorMessage": "このフィールドは未入力のままにできません。", + "xpack.infra.sourceConfiguration.fieldLogColumnTitle": "フィールド", + "xpack.infra.sourceConfiguration.fieldsSectionTitle": "フィールド", + "xpack.infra.sourceConfiguration.hostFieldDescription": "推奨値は {defaultValue} です", + "xpack.infra.sourceConfiguration.hostFieldLabel": "ホスト名", + "xpack.infra.sourceConfiguration.hostNameFieldDescription": "ホストの識別に使用されるフィールドです", + "xpack.infra.sourceConfiguration.hostNameFieldLabel": "ホスト名", + "xpack.infra.sourceConfiguration.indicesSectionTitle": "インデックス", + "xpack.infra.sourceConfiguration.logColumnListEmptyErrorMessage": "ログ列リストは未入力のままにできません。", + "xpack.infra.sourceConfiguration.logColumnsSectionTitle": "ログ列", + "xpack.infra.sourceConfiguration.logIndicesDescription": "ログデータを含む一致するインデックスのインデックスパターンです", + "xpack.infra.sourceConfiguration.logIndicesLabel": "ログインデックス", + "xpack.infra.sourceConfiguration.logIndicesRecommendedValue": "推奨値は {defaultValue} です", + "xpack.infra.sourceConfiguration.logIndicesTitle": "ログインデックス", + "xpack.infra.sourceConfiguration.messageLogColumnDescription": "このシステムフィールドは、ドキュメントフィールドから取得されたログエントリーメッセージを表示します。", + "xpack.infra.sourceConfiguration.metricIndicesDescription": "Metricbeat データを含む一致するインデックスのインデックスパターンです", + "xpack.infra.sourceConfiguration.metricIndicesLabel": "メトリックインデックス", + "xpack.infra.sourceConfiguration.metricIndicesRecommendedValue": "推奨値は {defaultValue} です", + "xpack.infra.sourceConfiguration.metricIndicesTitle": "メトリックインデックス", + "xpack.infra.sourceConfiguration.nameDescription": "ソース構成を説明する名前です", + "xpack.infra.sourceConfiguration.nameLabel": "名前", + "xpack.infra.sourceConfiguration.nameSectionTitle": "名前", + "xpack.infra.sourceConfiguration.noLogColumnsDescription": "上のボタンでこのリストに列を追加します。", + "xpack.infra.sourceConfiguration.noLogColumnsTitle": "列がありません", + "xpack.infra.sourceConfiguration.podFieldDescription": "Kubernetes ポッドの識別に使用されるフィールドです", + "xpack.infra.sourceConfiguration.podFieldLabel": "ポッド ID", + "xpack.infra.sourceConfiguration.podFieldRecommendedValue": "推奨値は {defaultValue} です", + "xpack.infra.sourceConfiguration.removeLogColumnButtonLabel": "{columnDescription} 列を削除", + "xpack.infra.sourceConfiguration.systemColumnBadgeLabel": "システム", + "xpack.infra.sourceConfiguration.tiebreakerFieldDescription": "同じタイムスタンプの 2 つのエントリーを識別するのに使用されるフィールドです", + "xpack.infra.sourceConfiguration.tiebreakerFieldLabel": "タイブレーカー", + "xpack.infra.sourceConfiguration.tiebreakerFieldRecommendedValue": "推奨値は {defaultValue} です", + "xpack.infra.sourceConfiguration.timestampFieldDescription": "ログエントリーの並べ替えに使用されるタイムスタンプです", + "xpack.infra.sourceConfiguration.timestampFieldLabel": "タイムスタンプ", + "xpack.infra.sourceConfiguration.timestampFieldRecommendedValue": "推奨値は {defaultValue} です", + "xpack.infra.sourceConfiguration.timestampLogColumnDescription": "このシステムフィールドは、{timestampSetting} フィールド設定から判断されたログエントリーの時刻を表示します。", + "xpack.infra.sourceConfiguration.unsavedFormPrompt": "終了してよろしいですか?変更内容は失われます", + "xpack.infra.sourceErrorPage.failedToLoadDataSourcesMessage": "データソースの読み込みに失敗しました。", + "xpack.infra.sourceLoadingPage.loadingDataSourcesMessage": "データソースを読み込み中", + "xpack.infra.tableView.columnName.avg": "平均", + "xpack.infra.tableView.columnName.last1m": "過去 1m", + "xpack.infra.tableView.columnName.max": "最高", + "xpack.infra.tableView.columnName.name": "名前", + "xpack.infra.useHTTPRequest.error.status": "エラー", + "xpack.infra.useHTTPRequest.error.title": "リソースの取得中にエラーが発生しました", + "xpack.infra.useHTTPRequest.error.url": "URL", + "xpack.infra.viewSwitcher.lenged": "表とマップビューを切り替えます", + "xpack.infra.viewSwitcher.mapViewLabel": "マップビュー", + "xpack.infra.viewSwitcher.tableViewLabel": "表ビュー", + "xpack.infra.waffle.checkNewDataButtonLabel": "新規データを確認", + "xpack.infra.waffle.customGroupByDropdownPlacehoder": "1 つ選択してください", + "xpack.infra.waffle.customGroupByFieldLabel": "フィールド", + "xpack.infra.waffle.customGroupByHelpText": "これは用語集約に使用されるフィールドです。", + "xpack.infra.waffle.customGroupByOptionName": "カスタムフィールド", + "xpack.infra.waffle.customGroupByPanelTitle": "カスタムフィールドでグループ分け", + "xpack.infra.waffle.groupByAllTitle": "すべて", + "xpack.infra.waffle.groupByButtonLabel": "グループ分けの条件:", + "xpack.infra.waffle.inventoryButtonLabel": "ビュー: {selectedText}", + "xpack.infra.waffle.loadingDataText": "データを読み込み中", + "xpack.infra.waffle.metricButtonLabel": "メトリック: {selectedMetric}", + "xpack.infra.waffle.metricOptions.countText": "カウント", + "xpack.infra.waffle.metricOptions.cpuUsageText": "CPU 使用状況", + "xpack.infra.waffle.metricOptions.hostLogRateText": "ログレート", + "xpack.infra.waffle.metricOptions.inboundTrafficText": "受信トラフィック", + "xpack.infra.waffle.metricOptions.loadText": "読み込み", + "xpack.infra.waffle.metricOptions.memoryUsageText": "メモリー使用状況", + "xpack.infra.waffle.metricOptions.outboundTrafficText": "送信トラフィック", + "xpack.infra.waffle.noDataDescription": "期間またはフィルターを調整してみてください。", + "xpack.infra.waffle.noDataTitle": "表示するデータがありません。", + "xpack.infra.waffle.savedView.createHeader": "ビューを保存", + "xpack.infra.waffle.savedViews.cancel": "キャンセル", + "xpack.infra.waffle.savedViews.cancelButton": "キャンセル", + "xpack.infra.waffle.savedViews.includeTimeFilterLabel": "ビューに時刻を保存", + "xpack.infra.waffle.savedViews.includeTimeHelpText": "ビューが読み込まれるごとに現在選択された時刻の時間フィルターが変更されます。", + "xpack.infra.waffle.savedViews.loadViewsLabel": "読み込み", + "xpack.infra.waffle.savedViews.saveButton": "保存", + "xpack.infra.waffle.savedViews.saveViewLabel": "保存", + "xpack.infra.waffle.savedViews.viewNamePlaceholder": "名前", + "xpack.infra.waffle.selectTwoGroupingsTitle": "最大 2 つのグループ分けを選択してください", + "xpack.infra.waffle.unableToSelectGroupErrorMessage": "{nodeType} のオプションでグループを選択できません", + "xpack.infra.waffle.unableToSelectMetricErrorTitle": "メトリックのオプションまたは値を選択できません", + "xpack.infra.waffleTime.autoRefreshButtonLabel": "自動更新", + "xpack.infra.waffleTime.stopRefreshingButtonLabel": "更新中止", + "xpack.kueryAutocomplete.andOperatorDescription": "{bothArguments}がtrueであることを条件とする", + "xpack.kueryAutocomplete.andOperatorDescription.bothArgumentsText": "両方の引数", + "xpack.kueryAutocomplete.equalOperatorDescription": "一部の値に{equals}", + "xpack.kueryAutocomplete.equalOperatorDescription.equalsText": "一致する", + "xpack.kueryAutocomplete.existOperatorDescription": "いずれかの形式中に{exists}", + "xpack.kueryAutocomplete.existOperatorDescription.existsText": "存在する", + "xpack.kueryAutocomplete.filterResultsDescription": "{fieldName}を含む結果をフィルタリング", + "xpack.kueryAutocomplete.greaterThanOperatorDescription": "が一部の値{greaterThan}", + "xpack.kueryAutocomplete.greaterThanOperatorDescription.greaterThanText": "より大きい", + "xpack.kueryAutocomplete.greaterThanOrEqualOperatorDescription": "が一部の値{greaterThanOrEqualTo}", + "xpack.kueryAutocomplete.greaterThanOrEqualOperatorDescription.greaterThanOrEqualToText": "よりも大きいまたは等しい", + "xpack.kueryAutocomplete.lessThanOperatorDescription": "が一部の値{lessThan}", + "xpack.kueryAutocomplete.lessThanOperatorDescription.lessThanText": "より小さい", + "xpack.kueryAutocomplete.lessThanOrEqualOperatorDescription": "が一部の値{lessThanOrEqualTo}", + "xpack.kueryAutocomplete.lessThanOrEqualOperatorDescription.lessThanOrEqualToText": "より小さいまたは等しい", + "xpack.kueryAutocomplete.orOperatorDescription": "{oneOrMoreArguments}がtrueであることを条件とする", + "xpack.kueryAutocomplete.orOperatorDescription.oneOrMoreArgumentsText": "1つ以上の引数", "xpack.lens.app.docLoadingError": "保存されたドキュメントの保存中にエラーが発生", "xpack.lens.app.docSavingError": "ドキュメントの保存中にエラーが発生", "xpack.lens.app.indexPatternLoadingError": "インデックスパターンの読み込み中にエラーが発生", @@ -12556,6 +6808,7 @@ "xpack.lens.breadcrumbsTitle": "可視化", "xpack.lens.chartSwitch.dataLossDescription": "このチャートに切り替えると構成の一部が失われます", "xpack.lens.chartSwitch.dataLossLabel": "データ喪失", + "xpack.lens.configPanel.selectVisualization": "ビジュアライゼーションを選択してください", "xpack.lens.configure.addConfig": "構成を追加", "xpack.lens.configure.editConfig": "構成の編集", "xpack.lens.configure.emptyConfig": "ここにフィールドをドロップ", @@ -12572,9 +6825,12 @@ "xpack.lens.datatypes.date": "日付", "xpack.lens.datatypes.ipAddress": "IP", "xpack.lens.datatypes.number": "数字", + "xpack.lens.datatypes.record": "レコード", "xpack.lens.datatypes.string": "文字列", + "xpack.lens.editorFrame.dataFailure": "データの読み込み中にエラーが発生しました。", "xpack.lens.editorFrame.emptyWorkspace": "開始するにはここにフィールドをドロップしてください", "xpack.lens.editorFrame.emptyWorkspaceHeading": "レンズはビジュアライゼーションを作成するための新しいツールです", + "xpack.lens.editorFrame.expandRenderingErrorButton": "エラーの詳細を表示", "xpack.lens.editorFrame.expressionFailure": "表現を正常に実行できませんでした", "xpack.lens.editorFrame.goToForums": "リクエストとフィードバック", "xpack.lens.editorFrame.previewErrorLabel": "レンダリングのプレビューに失敗しました", @@ -12589,16 +6845,29 @@ "xpack.lens.indexPattern.avgOf": "{name} の平均", "xpack.lens.indexPattern.cardinality": "ユニークカウント", "xpack.lens.indexPattern.cardinalityOf": "{name} のユニークカウント", + "xpack.lens.indexPattern.changeIndexPatternTitle": "インデックスパターンを変更", "xpack.lens.indexPattern.columnLabel": "ラベル", "xpack.lens.indexPattern.count": "カウント", "xpack.lens.indexPattern.countOf": "ドキュメント数", - "xpack.lens.indexPattern.dateHistogram": "Date histogram", + "xpack.lens.indexPattern.dateHistogram": "日付ヒストグラム", "xpack.lens.indexPattern.dateHistogram.autoInterval": "時間範囲のカスタマイズ", + "xpack.lens.indexPattern.dateHistogram.days": "日", + "xpack.lens.indexPattern.dateHistogram.hours": "時間", + "xpack.lens.indexPattern.dateHistogram.milliseconds": "ミリ秒", + "xpack.lens.indexPattern.dateHistogram.minimumInterval": "最低間隔", + "xpack.lens.indexPattern.dateHistogram.minutes": "分", + "xpack.lens.indexPattern.dateHistogram.month": "月", "xpack.lens.indexPattern.dateHistogram.restrictedInterval": "集約の制限により間隔は {intervalValue} に固定されています。", + "xpack.lens.indexPattern.dateHistogram.seconds": "秒", + "xpack.lens.indexPattern.dateHistogram.week": "週", + "xpack.lens.indexPattern.dateHistogram.year": "年", + "xpack.lens.indexpattern.emptyTextColumnValue": "(空)", "xpack.lens.indexPattern.fieldDistributionLabel": "分布", + "xpack.lens.indexPattern.fieldItemTooltip": "可視化するには、ドラッグアンドドロップします。", "xpack.lens.indexPattern.fieldlessOperationLabel": "この関数を使用するには、フィールドを選択してください。", "xpack.lens.indexPattern.fieldPanelEmptyStringValue": "空の文字列", "xpack.lens.indexPattern.fieldPlaceholder": "フィールド", + "xpack.lens.indexPattern.fieldStatsButtonLabel": "フィールドプレビューを表示するには、クリックします。可視化するには、ドラッグアンドドロップします。", "xpack.lens.indexPattern.fieldStatsCountLabel": "カウント", "xpack.lens.indexPattern.fieldStatsDisplayToggle": "次のどちらかを切り替えます:", "xpack.lens.indexPattern.fieldStatsNoData": "表示するデータがありません", @@ -12612,6 +6881,7 @@ "xpack.lens.indexPattern.groupingSecondTerms": "各 {target} のトップの値", "xpack.lens.indexPattern.indexPatternLoadError": "インデックスパターンの読み込み中にエラーが発生", "xpack.lens.indexPattern.individualFieldsLabel": "個々のフィールド", + "xpack.lens.indexPattern.invalidInterval": "無効な間隔値", "xpack.lens.indexPattern.invalidOperationLabel": "この関数を使用するには、別のフィールドを選択してください。", "xpack.lens.indexPattern.max": "最高", "xpack.lens.indexPattern.maxOf": "{name} お最高値", @@ -12622,6 +6892,7 @@ "xpack.lens.indexPattern.ofDocumentsLabel": "ドキュメント", "xpack.lens.indexPattern.otherDocsLabel": "その他", "xpack.lens.indexPattern.percentageOfLabel": "の {percentage}%", + "xpack.lens.indexPattern.records": "記録", "xpack.lens.indexPattern.removeColumnLabel": "構成を削除", "xpack.lens.indexpattern.suggestions.nestingChangeLabel": "各 {outerOperation} の {innerOperation}", "xpack.lens.indexpattern.suggestions.overallLabel": "全体の {operation}", @@ -12638,14 +6909,22 @@ "xpack.lens.indexPattern.termsOf": "{name} のトップの値", "xpack.lens.indexPattern.uniqueLabel": "{label} [{num}]", "xpack.lens.indexPatterns.clearFiltersLabel": "名前とタイプフィルターを消去", + "xpack.lens.indexPatterns.emptyFieldsWithDataLabel": "現在のフィルターと時間範囲に一致するデータがあるフィールドはありません。フィルターまたは時間範囲を変更してください。", "xpack.lens.indexPatterns.filterByNameAriaLabel": "検索フィールド", "xpack.lens.indexPatterns.filterByNameLabel": "フィールドを検索", "xpack.lens.indexPatterns.filterByTypeLabel": "タイプでフィルタリング", + "xpack.lens.indexPatterns.noFieldsLabel": "このインデックスパターンにはフィールドがありません。", + "xpack.lens.indexPatterns.noFilteredFieldsLabel": "現在のフィルターと一致するフィールドはありません。フィルターまたは時間範囲を変更してください。", + "xpack.lens.indexPatterns.showAllFields.buttonText": "すべてのフィールドを表示", "xpack.lens.indexPatterns.toggleEmptyFieldsSwitch": "データがあるフィールドだけを表示", "xpack.lens.indexPatterns.toggleFiltersPopover": "フィルタリングされたフィールド", + "xpack.lens.indexPatternSuggestion.removeLayerLabel": "{indexPatternTitle}のみを表示", + "xpack.lens.indexPatternSuggestion.removeLayerPositionLabel": "レイヤー{layerNumber}のみを表示", "xpack.lens.lensSavedObjectLabel": "レンズビジュアライゼーション", "xpack.lens.metric.label": "メトリック", "xpack.lens.metric.valueLabel": "値", + "xpack.lens.sugegstion.refreshSuggestionLabel": "更新", + "xpack.lens.suggestion.refreshSuggestionTooltip": "選択したビジュアライゼーションに基づいて、候補を更新します。", "xpack.lens.suggestions.currentVisLabel": "現在", "xpack.lens.visTypeAlias.description": "レンズは基本的なビジュアライゼーションを作成するシンプルな方法です", "xpack.lens.visTypeAlias.promotion.buttonText": "レンズに移動", @@ -12653,6 +6932,7 @@ "xpack.lens.visTypeAlias.title": "レンズビジュアライゼーション", "xpack.lens.visTypeAlias.type": "レンズ", "xpack.lens.xyChart.addLayerButton": "レイヤーを追加", + "xpack.lens.xyChart.addLayerTooltip": "複数のレイヤーを使用すると、グラフタイプを組み合わせたり、別のインデックスパターンを可視化したりすることができます。", "xpack.lens.xyChart.chartTypeLabel": "チャートタイプ", "xpack.lens.xyChart.chartTypeLegend": "チャートタイプ", "xpack.lens.xyChart.deleteLayer": "レイヤーを削除", @@ -12687,11 +6967,6312 @@ "xpack.lens.xyVisualization.stackedBarHorizontalLabel": "スタックされた横棒", "xpack.lens.xyVisualization.stackedBarLabel": "スタックされたバー", "xpack.lens.xyVisualization.xyLabel": "XY", + "xpack.licenseMgmt.app.checkingPermissionsErrorMessage": "パーミッションの確認中にエラーが発生", + "xpack.licenseMgmt.app.deniedPermissionDescription": "ライセンス管理を使用するには、{permissionType}権限が必要です", + "xpack.licenseMgmt.app.deniedPermissionTitle": "クラスター特権が足りません", + "xpack.licenseMgmt.app.loadingPermissionsDescription": "パーミッションを確認中…", + "xpack.licenseMgmt.dashboard.breadcrumb": "ライセンス管理", + "xpack.licenseMgmt.licenseDashboard.addLicense.updateLicenseButtonLabel": "ライセンスを更新", + "xpack.licenseMgmt.licenseDashboard.addLicense.updateLicenseTitle": "ライセンスの更新", + "xpack.licenseMgmt.licenseDashboard.addLicense.useAvailableLicenseDescription": "既に新しいライセンスがある場合は、今すぐアップロードしてください。", + "xpack.licenseMgmt.licenseDashboard.licenseStatus.activeLicenseStatusDescription": "ライセンスは {expiryDate} に期限切れになります", + "xpack.licenseMgmt.licenseDashboard.licenseStatus.activeLicenseStatusText": "アクティブ", + "xpack.licenseMgmt.licenseDashboard.licenseStatus.activeLicenseStatusTitle": "ご使用の {typeTitleCase} ライセンスは {status} です", + "xpack.licenseMgmt.licenseDashboard.licenseStatus.expiredLicenseStatusDescription": "ご使用のライセンスは {expiryDate} に期限切れになりました", + "xpack.licenseMgmt.licenseDashboard.licenseStatus.expiredLicenseStatusTitle": "ご使用の {typeTitleCase} ライセンスは期限切れです", + "xpack.licenseMgmt.licenseDashboard.licenseStatus.inactiveLicenseStatusText": "非アクティブ", + "xpack.licenseMgmt.licenseDashboard.licenseStatus.permanentActiveLicenseStatusDescription": "ご使用のライセンスには有効期限がありません。", + "xpack.licenseMgmt.licenseDashboard.requestTrialExtension.extendTrialButtonLabel": "トライアルを延長", + "xpack.licenseMgmt.licenseDashboard.requestTrialExtension.extendYourTrialTitle": "トライアルの延長", + "xpack.licenseMgmt.licenseDashboard.requestTrialExtension.howToContinueUsingPluginsDescription": "機械学習、高度なセキュリティ、その他の素晴らしい {platinumLicenseFeaturesLinkText} の使用を続けるには、今すぐ延長をお申し込みください。", + "xpack.licenseMgmt.licenseDashboard.requestTrialExtension.platinumLicenseFeaturesLinkText": "プラチナ機能", + "xpack.licenseMgmt.licenseDashboard.revertToBasic.acknowledgeModal.revertToBasicButtonLabel": "ベーシックに戻す", + "xpack.licenseMgmt.licenseDashboard.revertToBasic.acknowledgeModalTitle": "ベーシックライセンスに戻す", + "xpack.licenseMgmt.licenseDashboard.revertToBasic.confirmModal.cancelButtonLabel": "キャンセル", + "xpack.licenseMgmt.licenseDashboard.revertToBasic.confirmModal.confirmButtonLabel": "確認", + "xpack.licenseMgmt.licenseDashboard.revertToBasic.confirmModalTitle": "ベーシックライセンスに戻す確認", + "xpack.licenseMgmt.licenseDashboard.revertToBasic.platinumLicenseFeaturesLinkText": "プラチナ機能", + "xpack.licenseMgmt.licenseDashboard.revertToBasic.revertToFreeFeaturesDescription": "無料の機能に戻すと、セキュリティ、機械学習、その他 {platinumLicenseFeaturesLinkText} が利用できなくなります。", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModal.cancelButtonLabel": "キャンセル", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModal.startTrialButtonLabel": "トライアルを開始", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription": "このトライアルは、Elastic Stack の {platinumLicenseFeaturesLinkText} のフルセットが使えます。次の機能に直ちにアクセスできるようになります:", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.alertingFeatureTitle": "アラート", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.dataBaseConnectivityFeatureTitle": "{sqlDataBase} の {jdbcStandard} および {odbcStandard} 接続", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.graphCapabilitiesFeatureTitle": "グラフ機能", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.mashingLearningFeatureTitle": "機械学習", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.platinumLicenseFeaturesLinkText": "プラチナ機能", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.securityDocumentationLinkText": "ドキュメンテーション", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.securityFeaturesConfigurationDescription": "認証 ({authenticationTypeList})、フィールドとドキュメントレベルのセキュリティ、監査などの高度なセキュリティ機能には構成が必要です。手順は {securityDocumentationLinkText} をご覧ください。", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.termsAndConditionsDescription": "このトライアルを開始することで、これらの {termsAndConditionsLinkText} が適用されることに同意したものとみなされます。", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.termsAndConditionsLinkText": "諸条件", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalTitle": "30 日間の無料トライアルの開始", + "xpack.licenseMgmt.licenseDashboard.startTrial.platinumFeaturesExperienceDescription": "機械学習、高度なセキュリティ、その他 {platinumLicenseFeaturesLinkText} をご体験ください。", + "xpack.licenseMgmt.licenseDashboard.startTrial.platinumLicenseFeaturesLinkText": "プラチナ機能", + "xpack.licenseMgmt.licenseDashboard.startTrial.startTrialButtonLabel": "トライアルを開始", + "xpack.licenseMgmt.licenseDashboard.startTrialTitle": "30 日間のトライアルの開始", + "xpack.licenseMgmt.managementSectionDisplayName": "ライセンス管理", + "xpack.licenseMgmt.replacingCurrentLicenseWithBasicLicenseWarningMessage": "{currentLicenseType} ライセンスからベーシックライセンスにすると、一部機能が使えなくなります。下の機能のリストをご確認ください。", + "xpack.licenseMgmt.telemetryOptIn.customersHelpSupportDescription": "Elastic Support のサービス改善にご協力ください", + "xpack.licenseMgmt.telemetryOptIn.exampleLinkText": "例", + "xpack.licenseMgmt.telemetryOptIn.featureUsageWarningMessage": "この機能は定期的に基本的な機能利用に関する統計情報を送信します。この情報は Elastic 社外には共有されません。{exampleLink} をご覧いただくか、{telemetryPrivacyStatementLink} をお読みください。この機能はいつでも無効にできます。", + "xpack.licenseMgmt.telemetryOptIn.readMoreLinkText": "続きを読む", + "xpack.licenseMgmt.telemetryOptIn.sendBasicFeatureStatisticsLabel": "定期的に基本的な機能利用に関する統計情報を Elastic に送信します。{popover}", + "xpack.licenseMgmt.telemetryOptIn.telemetryPrivacyStatementLinkText": "遠隔測定に関するプライバシーステートメント", + "xpack.licenseMgmt.upload.breadcrumb": "アップロード", + "xpack.licenseMgmt.uploadLicense.cancelButtonLabel": "キャンセル", + "xpack.licenseMgmt.uploadLicense.checkLicenseFileErrorMessage": "{genericUploadError} ライセンスファイルを確認してください。", + "xpack.licenseMgmt.uploadLicense.confirmModal.cancelButtonLabel": "キャンセル", + "xpack.licenseMgmt.uploadLicense.confirmModal.confirmButtonLabel": "確認", + "xpack.licenseMgmt.uploadLicense.confirmModalTitle": "ライセンスのアップロードの確認", + "xpack.licenseMgmt.uploadLicense.expiredLicenseErrorMessage": "提供されたライセンスは期限切れです。", + "xpack.licenseMgmt.uploadLicense.genericUploadErrorMessage": "ライセンスのアップロード中にエラーが発生しました:", + "xpack.licenseMgmt.uploadLicense.invalidLicenseErrorMessage": "提供されたライセンスはこの製品に有効ではありません。", + "xpack.licenseMgmt.uploadLicense.licenseFileNotSelectedErrorMessage": "ライセンスファイルの選択が必要です。", + "xpack.licenseMgmt.uploadLicense.licenseKeyTypeDescription": "ライセンスキーは署名付きの JSON ファイルです。", + "xpack.licenseMgmt.uploadLicense.problemWithUploadedLicenseDescription": "{currentLicenseType} ライセンスから {newLicenseType} ライセンスにすると、一部機能が使えなくなります。下の機能のリストをご確認ください。", + "xpack.licenseMgmt.uploadLicense.replacingCurrentLicenseWarningMessage": "ライセンスを更新することにより、現在の {currentLicenseType} ライセンスが置き換えられます。", + "xpack.licenseMgmt.uploadLicense.selectLicenseFileDescription": "ライセンスファイルを選択するかドラッグしてください", + "xpack.licenseMgmt.uploadLicense.unknownErrorErrorMessage": "不明なエラー。", + "xpack.licenseMgmt.uploadLicense.uploadButtonLabel": "アップロード", + "xpack.licenseMgmt.uploadLicense.uploadingButtonLabel": "アップロード中…", + "xpack.licenseMgmt.uploadLicense.uploadLicenseTitle": "ライセンスのアップロード", "xpack.licensing.check.errorExpiredMessage": "{licenseType} ライセンスが期限切れのため {pluginName} を使用できません。", "xpack.licensing.check.errorUnavailableMessage": "現在ライセンス情報が利用できないため {pluginName} を使用できません。", "xpack.licensing.check.errorUnsupportedMessage": "ご使用の {licenseType} ライセンスは {pluginName} をサポートしていません。ライセンスをアップグレードしてください。", - "xpack.licensing.welcomeBanner.licenseIsExpiredDescription": "管理者または {updateYourLicenseLinkText} に直接お問い合わせください。", - "xpack.licensing.welcomeBanner.licenseIsExpiredDescription.updateYourLicenseLinkText": "ライセンスを更新", - "xpack.licensing.welcomeBanner.licenseIsExpiredTitle": "ご使用の {licenseType} ライセンスは期限切れです" + "xpack.logstash.addRoleAlert.grantAdditionalPrivilegesDescription": "Kibana の管理で、Kibana ユーザーに {role} ロールを割り当ててください。", + "xpack.logstash.addRoleAlert.grantAdditionalPrivilegesTitle": "追加権限の授与。", + "xpack.logstash.alertCallOut.howToSeeAdditionalPipelinesDescription": "追加パイプラインを表示させる方法", + "xpack.logstash.confirmDeleteModal.cancelButtonLabel": "キャンセル", + "xpack.logstash.confirmDeleteModal.deletedPipelineConfirmButtonLabel": "パイプラインを削除", + "xpack.logstash.confirmDeleteModal.deletedPipelinesConfirmButtonLabel": "{numPipelinesSelected} パイプラインを削除", + "xpack.logstash.confirmDeleteModal.deletedPipelinesTitle": "{numPipelinesSelected} パイプラインを削除", + "xpack.logstash.confirmDeleteModal.deletedPipelinesWarningMessage": "削除されたパイプラインは復元できません。", + "xpack.logstash.confirmDeleteModal.deletedPipelineTitle": "パイプライン「{id}」の削除", + "xpack.logstash.confirmDeleteModal.deletedPipelineWarningMessage": "削除されたパイプラインは復元できません。", + "xpack.logstash.confirmDeletePipelineModal.cancelButtonText": "キャンセル", + "xpack.logstash.confirmDeletePipelineModal.confirmButtonText": "パイプラインを削除", + "xpack.logstash.confirmDeletePipelineModal.deletePipelineTitle": "パイプライン「{id}」の削除", + "xpack.logstash.couldNotLoadPipelineErrorNotification": "パイプラインを読み込めませんでした。エラー「{errStatusText}」。", + "xpack.logstash.deletePipelineModalMessage": "削除されたパイプラインは復元できません。", + "xpack.logstash.enableMonitoringAlert.enableMonitoringDescription": "{configFileName} ファイルで、{monitoringConfigParam} と {monitoringUiConfigParam} を {trueValue} に設定します。", + "xpack.logstash.enableMonitoringAlert.enableMonitoringTitle": "監視を有効にする。", + "xpack.logstash.homeFeature.logstashPipelinesDescription": "データ投入パイプラインの作成、削除、更新、クローンの作成を行います。", + "xpack.logstash.homeFeature.logstashPipelinesTitle": "Logstash パイプライン", + "xpack.logstash.idFormatErrorMessage": "パイプライン ID は文字またはアンダーラインで始まる必要があり、文字、アンダーライン、ハイフン、数字のみ使用できます", + "xpack.logstash.insufficientUserPermissionsDescription": "Logstash パイプラインの管理に必要なユーザーパーミッションがありません", + "xpack.logstash.kibanaManagementPipelinesTitle": "Kibana の管理で作成されたパイプラインだけがここに表示されます", + "xpack.logstash.managementSection.createPipelineTitle": "パイプラインの作成", + "xpack.logstash.managementSection.editPipelineTitle": "パイプラインの編集", + "xpack.logstash.managementSection.enableSecurityDescription": "Logstash パイプライン管理機能を使用するには、セキュリティを有効にする必要があります。elasticsearch.yml で xpack.security.enabled: true に設定してください。", + "xpack.logstash.managementSection.licenseDoesNotSupportDescription": "ご使用の {licenseType} ライセンスは Logstash パイプライン管理をサポートしていません。ライセンスをアップグレードしてください。", + "xpack.logstash.managementSection.notPossibleToManagePipelinesMessage": "現在ライセンス情報が利用できないため Logstash パイプラインを使用できません。", + "xpack.logstash.managementSection.pipelineCrudOperationsNotAllowedDescription": "ご使用の {licenseType} ライセンスは期限切れのため、Logstash パイプラインの編集、作成、削除ができません。", + "xpack.logstash.managementSection.pipelinesTitle": "パイプライン", + "xpack.logstash.manualUpgradeButtonLabel": "再試行", + "xpack.logstash.newPipelineMessage": "パイプラインを追加する前に、構成をアップグレードする必要があります。", + "xpack.logstash.notManualUpgradeButtonLabel": "アップグレード", + "xpack.logstash.notManualUpgradeTitle": "アップグレードの時がやってきました!", + "xpack.logstash.notNewPipelineMessage": "このパイプラインを編集する前に、構成をアップグレードする必要があります。", + "xpack.logstash.pipelineBatchDelayTooltip": "パイプラインイベントバッチを作成する際、それぞれのイベントでパイプラインワーカーにサイズの小さなバッチを送る前に何ミリ秒間待つかです。\n\nデフォルト値:50ms", + "xpack.logstash.pipelineBatchSizeTooltip": "フィルターとアウトプットをを実行する前に各ワーカースレッドがインプットから収集するイベントの最低数です。基本的にバッチサイズが大きくなるほど効率が上がりますが、メモリーオーバーヘッドも大きくなります。このオプションを効率的に使用するには、LS_HEAP_SIZE 変数を設定して JVM のヒープサイズを増やす必要があるかもしれません。\n\nデフォルト値:125", + "xpack.logstash.pipelineEditor.cancelButtonLabel": "キャンセル", + "xpack.logstash.pipelineEditor.clonePipelineTitle": "「{id}」のクローンの作成", + "xpack.logstash.pipelineEditor.createAndDeployButtonLabel": "作成して導入", + "xpack.logstash.pipelineEditor.createPipelineTitle": "パイプラインの作成", + "xpack.logstash.pipelineEditor.deletePipelineButtonLabel": "パイプラインを削除", + "xpack.logstash.pipelineEditor.descriptionFormRowLabel": "説明", + "xpack.logstash.pipelineEditor.editPipelineTitle": "パイプライン「{id}」の編集", + "xpack.logstash.pipelineEditor.errorHandlerToastTitle": "パイプラインエラー", + "xpack.logstash.pipelineEditor.pipelineBatchDelayFormRowLabel": "パイプラインバッチの遅延", + "xpack.logstash.pipelineEditor.pipelineBatchSizeFormRowLabel": "パイプラインバッチのサイズ", + "xpack.logstash.pipelineEditor.pipelineFormRowLabel": "パイプライン", + "xpack.logstash.pipelineEditor.pipelineIdFormRowLabel": "パイプライン ID", + "xpack.logstash.pipelineEditor.pipelineSuccessfullyDeletedMessage": "「{id}」が削除されました", + "xpack.logstash.pipelineEditor.pipelineSuccessfullySavedMessage": "「{id}」が保存されました", + "xpack.logstash.pipelineEditor.pipelineWorkersFormRowLabel": "パイプラインワーカー", + "xpack.logstash.pipelineEditor.queueCheckpointWritesFormRowLabel": "キューチェックポイントの書き込み", + "xpack.logstash.pipelineEditor.queueMaxBytesFormRowLabel": "キューの最大バイト数", + "xpack.logstash.pipelineEditor.queueTypeFormRowLabel": "キュータイプ", + "xpack.logstash.pipelineIdRequiredMessage": "パイプライン ID が必要です", + "xpack.logstash.pipelineList.couldNotDeletePipelinesNotification": "{numErrors, plural, one {# パイプライン} other {# パイプライン}}の削除に失敗しました", + "xpack.logstash.pipelineList.head": "パイプライン", + "xpack.logstash.pipelineList.noPermissionToManageDescription": "管理者にお問い合わせください。", + "xpack.logstash.pipelineList.noPermissionToManageTitle": "Logstash パイプラインを変更するパーミッションがありません。", + "xpack.logstash.pipelineList.noPipelinesDescription": "パイプラインが定義されていません。", + "xpack.logstash.pipelineList.noPipelinesTitle": "パイプラインがありません", + "xpack.logstash.pipelineList.pipelineLoadingErrorNotification": "パイプラインを読み込めませんでした。エラー「{errStatusText}」。", + "xpack.logstash.pipelineList.pipelinesCouldNotBeDeletedDescription": "しかし {numErrors, plural, one {# パイプライン} other {# パイプライン}}を削除できませんでした。", + "xpack.logstash.pipelineList.pipelinesLoadingErrorDescription": "パイプラインの読み込み中にエラーが発生しました。", + "xpack.logstash.pipelineList.pipelinesLoadingErrorTitle": "エラー", + "xpack.logstash.pipelineList.pipelinesLoadingMessage": "パイプラインを読み込み中…", + "xpack.logstash.pipelineList.pipelinesSuccessfullyDeletedNotification": "「{id}」が削除されました", + "xpack.logstash.pipelineList.subhead": "Logstash イベントの処理を管理して結果を表示", + "xpack.logstash.pipelineList.successfullyDeletedPipelinesNotification": "{numPipelinesSelected, plural, one {# 本中} other {# 本中}}{numSuccesses} 本のパイプラインが削除されました", + "xpack.logstash.pipelineNotCentrallyManagedTooltip": "このパイプラインは集中構成管理で作成されませんでした。ここで管理または編集できません。", + "xpack.logstash.pipelines.createBreadcrumb": "作成", + "xpack.logstash.pipelines.listBreadcrumb": "パイプライン", + "xpack.logstash.pipelinesTable.cloneButtonLabel": "クローンを作成", + "xpack.logstash.pipelinesTable.createPipelineButtonLabel": "パイプラインの作成", + "xpack.logstash.pipelinesTable.deleteButtonLabel": "削除", + "xpack.logstash.pipelinesTable.descriptionColumnLabel": "説明", + "xpack.logstash.pipelinesTable.filterByIdLabel": "ID でフィルタリング", + "xpack.logstash.pipelinesTable.idColumnLabel": "Id", + "xpack.logstash.pipelinesTable.lastModifiedColumnLabel": "最終更新:", + "xpack.logstash.pipelinesTable.modifiedByColumnLabel": "変更者:", + "xpack.logstash.pipelinesTable.selectablePipelineMessage": "パイプライン「{id}」を選択します", + "xpack.logstash.queueCheckpointWritesTooltip": "永続キューが有効な場合にチェックポイントを強制する前に書き込むイベントの最大数です。無制限にするには 0 を指定します。\n\nデフォルト値:1024", + "xpack.logstash.queueMaxBytesTooltip": "バイト単位でのキューの合計容量です。ディスクドライブの容量がここで指定する値よりも大きいことを確認してください。\n\nデフォルト値:1024mb (1g)", + "xpack.logstash.queueTypes.memoryLabel": "メモリー", + "xpack.logstash.queueTypes.persistedLabel": "永続", + "xpack.logstash.queueTypeTooltip": "イベントのバッファーに使用する内部キューモデルです。レガシーインメモリ―ベースのキュー、または現存のディスクベースの ACK キューに使用するメモリーを指定します\n\nデフォルト値: メモリー", + "xpack.logstash.units.bytesLabel": "バイト", + "xpack.logstash.units.gigabytesLabel": "ギガバイト", + "xpack.logstash.units.kilobytesLabel": "キロバイト", + "xpack.logstash.units.megabytesLabel": "メガバイト", + "xpack.logstash.units.petabytesLabel": "ペタバイト", + "xpack.logstash.units.terabytesLabel": "テラバイト", + "xpack.logstash.upgradeFailedTitle": "アップグレード失敗", + "xpack.logstash.upgradeFailureActions.goBackButtonLabel": "戻る", + "xpack.logstash.upstreamPipelineArgumentMustContainAnIdPropertyErrorMessage": "upstreamPipeline 引数には id プロパティを含める必要があります", + "xpack.logstash.workersTooltip": "パイプラインのフィルターとアウトプットステージを同時に実行するワーカーの数です。イベントが詰まってしまう場合や CPU が飽和状態ではない場合は、マシンの処理能力をより有効に活用するため、この数字を上げてみてください。\n\nデフォルト値:ホストの CPU コア数です", + "xpack.maps.addLayerPanel.addLayer": "レイヤーを追加", + "xpack.maps.addLayerPanel.changeDataSourceButtonLabel": "データソースを変更", + "xpack.maps.addLayerPanel.chooseDataSourceTitle": "データソースの選択", + "xpack.maps.addLayerPanel.footer.cancelButtonLabel": "キャンセル", + "xpack.maps.addLayerPanel.importFile": "ファイルのインポート", + "xpack.maps.addLayerPanel.selectSource": "ソースを選択", + "xpack.maps.appDescription": "マップアプリケーション", + "xpack.maps.appTitle": "マップ", + "xpack.maps.badge.readOnly.text": "読み込み専用", + "xpack.maps.badge.readOnly.tooltip": "マップを保存できませんで", + "xpack.maps.common.esSpatialRelation.containsLabel": "contains", + "xpack.maps.common.esSpatialRelation.disjointLabel": "disjoint", + "xpack.maps.common.esSpatialRelation.intersectsLabel": "intersects", + "xpack.maps.common.esSpatialRelation.withinLabel": "within", + "xpack.maps.drawTooltip.boundsInstructions": "クリックして四角形を開始します。もう一度クリックして終了します。", + "xpack.maps.drawTooltip.polygonInstructions": "クリックして頂点を追加します。ダブルクリックして終了します。", + "xpack.maps.embeddableDisplayName": "マップ", + "xpack.maps.es_geo_utils.convert.unsupportedGeometryTypeErrorMessage": "{geometryType} ジオメトリから Geojson に変換できません。サポートされていません", + "xpack.maps.es_geo_utils.shapeFilter.geoPointRelationLabel": "次に含まれる:", + "xpack.maps.es_geo_utils.unsupportedFieldTypeErrorMessage": "サポートされていないフィールドタイプ、期待値: {expectedTypes}、提供された値: {fieldType}", + "xpack.maps.es_geo_utils.unsupportedGeometryTypeErrorMessage": "サポートされていないジオメトリタイプ、期待値: {expectedTypes}、提供された値: {geometryType}", + "xpack.maps.es_geo_utils.wkt.invalidWKTErrorMessage": "{wkt} を Geojson に変換できません。有効な WKT が必要です。", + "xpack.maps.esSearch.featureCountMsg": "{count} 件のドキュメントが見つかりました。", + "xpack.maps.esSearch.resultsTrimmedMsg": "結果は初めの {count} 件のドキュメントに制限されています。", + "xpack.maps.esSearch.topHitsEntitiesCountMsg": "{entityCount} 件のエントリーを発見.", + "xpack.maps.feature.appDescription": "Elasticsearch と Elastic Maps Service の地理空間データを閲覧します", + "xpack.maps.featureRegistry.mapsFeatureName": "マップ", + "xpack.maps.geoGrid.resolutionLabel": "グリッド解像度", + "xpack.maps.geometryFilterForm.geoFieldLabel": "フィルタリングされたフィールド", + "xpack.maps.geometryFilterForm.geometryLabelLabel": "ジオメトリラベル", + "xpack.maps.geometryFilterForm.relationLabel": "空間関係", + "xpack.maps.heatmap.colorRampLabel": "色の範囲", + "xpack.maps.heatmapLegend.coldLabel": "コールド", + "xpack.maps.heatmapLegend.hotLabel": "ホット", + "xpack.maps.inspector.centerLatLabel": "中央緯度", + "xpack.maps.inspector.centerLonLabel": "中央経度", + "xpack.maps.inspector.mapboxStyleTitle": "マップボックススタイル", + "xpack.maps.inspector.mapDetailsTitle": "マップの詳細", + "xpack.maps.inspector.mapDetailsViewHelpText": "マップステータスを表示します", + "xpack.maps.inspector.mapDetailsViewTitle": "マップの詳細", + "xpack.maps.inspector.zoomLabel": "ズーム:", + "xpack.maps.layer.isUsingSearchMsg": "検索バーにより絞られた結果", + "xpack.maps.layer.layerHiddenTooltip": "レイヤーが非表示になっています。", + "xpack.maps.layer.loadWarningAriaLabel": "警告を読み込む", + "xpack.maps.layer.zoomFeedbackTooltip": "レイヤーはズームレベル {minZoom} から {maxZoom} の間で表示されます。", + "xpack.maps.layerControl.addLayerButtonLabel": "レイヤーを追加", + "xpack.maps.layerControl.closeLayerTOCButtonAriaLabel": "レイヤーパネルを畳む", + "xpack.maps.layerControl.layersTitle": "レイヤー", + "xpack.maps.layerControl.openLayerTOCButtonAriaLabel": "レイヤーパネルを拡張", + "xpack.maps.layerControl.tocEntry.editButtonAriaLabel": "レイヤーを編集", + "xpack.maps.layerControl.tocEntry.editButtonTitle": "レイヤーを編集", + "xpack.maps.layerControl.tocEntry.grabButtonAriaLabel": "レイヤーの並べ替え", + "xpack.maps.layerControl.tocEntry.grabButtonTitle": "レイヤーの並べ替え", + "xpack.maps.layerControl.tocEntry.hideDetailsButtonAriaLabel": "レイヤー詳細を非表示", + "xpack.maps.layerControl.tocEntry.hideDetailsButtonTitle": "レイヤー詳細を非表示", + "xpack.maps.layerControl.tocEntry.showDetailsButtonAriaLabel": "レイヤー詳細を表示", + "xpack.maps.layerControl.tocEntry.showDetailsButtonTitle": "レイヤー詳細を表示", + "xpack.maps.layerPanel.filterEditor.addFilterButtonLabel": "フィルターを追加します", + "xpack.maps.layerPanel.filterEditor.editFilterButtonLabel": "フィルターを編集", + "xpack.maps.layerPanel.filterEditor.emptyState.description": "フィルターを追加してレイヤーデータを絞ります。", + "xpack.maps.layerPanel.filterEditor.queryBarSubmitButtonLabel": "フィルターを設定", + "xpack.maps.layerPanel.filterEditor.title": "フィルター", + "xpack.maps.layerPanel.fitToBoundsAriaLabel": "境界に合わせる", + "xpack.maps.layerPanel.fitToBoundsButtonLabel": "合わせる", + "xpack.maps.layerPanel.footer.cancelButtonLabel": "キャンセル", + "xpack.maps.layerPanel.footer.closeButtonLabel": "閉じる", + "xpack.maps.layerPanel.footer.removeLayerButtonLabel": "レイヤーを削除", + "xpack.maps.layerPanel.footer.saveAndCloseButtonLabel": "保存して閉じる", + "xpack.maps.layerPanel.join.deleteJoinAriaLabel": "ジョブを削除", + "xpack.maps.layerPanel.join.deleteJoinTitle": "ジョブの削除", + "xpack.maps.layerPanel.join.noIndexPatternErrorMessage": "インデックスパターン {indexPatternId} が見つかりません", + "xpack.maps.layerPanel.joinEditor.addJoinAriaLabel": "結合を追加", + "xpack.maps.layerPanel.joinEditor.addJoinButtonLabel": "結合を追加", + "xpack.maps.layerPanel.joinEditor.termJoinsTitle": "用語結合", + "xpack.maps.layerPanel.joinEditor.termJoinTooltip": "用語結合を使用すると、データに基づくスタイル設定のプロパティでこのレイヤーを強化します。", + "xpack.maps.layerPanel.joinExpression.helpText": "共有キーを構成します。", + "xpack.maps.layerPanel.joinExpression.joinPopoverTitle": "結合", + "xpack.maps.layerPanel.joinExpression.leftFieldLabel": "左のフィールド", + "xpack.maps.layerPanel.joinExpression.leftSourceLabel": "左のソース", + "xpack.maps.layerPanel.joinExpression.leftSourceLabelHelpText": "共有キーを含む左のソースフィールド。", + "xpack.maps.layerPanel.joinExpression.rightFieldLabel": "右のフィールド", + "xpack.maps.layerPanel.joinExpression.rightSourceLabel": "右のソース", + "xpack.maps.layerPanel.joinExpression.rightSourceLabelHelpText": "共有キーを含む右のソースフィールド。", + "xpack.maps.layerPanel.joinExpression.selectFieldPlaceholder": "フィールドを選択", + "xpack.maps.layerPanel.joinExpression.selectIndexPatternPlaceholder": "インデックスパターンを選択", + "xpack.maps.layerPanel.joinExpression.selectPlaceholder": "-- 選択 --", + "xpack.maps.layerPanel.layerSettingsTitle": "レイヤー設定", + "xpack.maps.layerPanel.metricsExpression.helpText": "右のソースのメトリックを構成します。これらの値はレイヤー機能に追加されます。", + "xpack.maps.layerPanel.metricsExpression.joinMustBeSetErrorMessage": "JOIN の設定が必要です", + "xpack.maps.layerPanel.metricsExpression.metricsPopoverTitle": "メトリック", + "xpack.maps.layerPanel.metricsExpression.useMetricsDescription": "{metricsLength, plural, one {してメトリックを使用します} other {してメトリックを使用します}}", + "xpack.maps.layerPanel.settingsPanel.layerNameLabel": "名前", + "xpack.maps.layerPanel.settingsPanel.layerTransparencyLabel": "レイヤーの透明度", + "xpack.maps.layerPanel.settingsPanel.percentageLabel": "%", + "xpack.maps.layerPanel.settingsPanel.unableToLoadTitle": "レイヤーを読み込めません", + "xpack.maps.layerPanel.settingsPanel.visibleZoom": "ズームレベル", + "xpack.maps.layerPanel.settingsPanel.visibleZoomLabel": "レイヤー表示のズーム範囲", + "xpack.maps.layerPanel.sourceDetailsLabel": "ソースの詳細", + "xpack.maps.layerPanel.styleSettingsTitle": "レイヤースタイル", + "xpack.maps.layerPanel.whereExpression.expressionDescription": "where", + "xpack.maps.layerPanel.whereExpression.expressionValuePlaceholder": "--フィルターを追加--", + "xpack.maps.layerPanel.whereExpression.helpText": "右のソースを絞り込むには、クエリを使用します。", + "xpack.maps.layerPanel.whereExpression.queryBarSubmitButtonLabel": "フィルターを設定", + "xpack.maps.layerTocActions.cloneLayerTitle": "レイヤーおクローンを作成", + "xpack.maps.layerTocActions.editLayerTitle": "レイヤーを編集", + "xpack.maps.layerTocActions.fitToDataTitle": "データに合わせる", + "xpack.maps.layerTocActions.hideLayerTitle": "レイヤーの非表示", + "xpack.maps.layerTocActions.layerActionsTitle": "レイヤー操作", + "xpack.maps.layerTocActions.noFitSupportTooltip": "レイヤーが「データに合わせる」をサポートしていません", + "xpack.maps.layerTocActions.showLayerTitle": "レイヤーの表示", + "xpack.maps.map.initializeErrorTitle": "マップを初期化できません", + "xpack.maps.mapController.fullScreenButtonLabel": "全画面", + "xpack.maps.mapController.fullScreenDescription": "全画面", + "xpack.maps.mapController.mapsBreadcrumbLabel": "マップ", + "xpack.maps.mapController.openInspectorButtonLabel": "検査", + "xpack.maps.mapController.openInspectorDescription": "インスペクターを開きます", + "xpack.maps.mapController.saveErrorMessage": "「{title}」の保存中にエラーが発生しました", + "xpack.maps.mapController.saveMapButtonLabel": "保存", + "xpack.maps.mapController.saveMapDescription": "マップを保存", + "xpack.maps.mapController.saveMapDisabledButtonTooltip": "保存する前に、レイヤーの変更を保存するか、キャンセルしてください", + "xpack.maps.mapController.saveSuccessMessage": "「{title}」が保存されました", + "xpack.maps.mapController.unsavedChangesWarning": "保存されていない変更は保存されない可能性があります", + "xpack.maps.mapEmbeddableFactory.invalidLayerList": "不正な形式のレイヤーリストによりマップを読み込めません", + "xpack.maps.mapEmbeddableFactory.invalidSavedObject": "不正な形式の保存済みオブジェクトによりマップを読み込めません", + "xpack.maps.mapListing.advancedSettingsLinkText": "高度な設定", + "xpack.maps.mapListing.cancelTitle": "キャンセル", + "xpack.maps.mapListing.createMapButtonLabel": "マップを作成", + "xpack.maps.mapListing.deleteSelectedButtonLabel": "選択項目を削除", + "xpack.maps.mapListing.deleteSelectedItemsTitle": "選択項目を削除しますか?", + "xpack.maps.mapListing.deleteTitle": "削除", + "xpack.maps.mapListing.deleteWarning": "削除されたアイテムは復元できません。", + "xpack.maps.mapListing.descriptionFieldTitle": "説明", + "xpack.maps.mapListing.limitExceededTitle": "リスティング制限超過", + "xpack.maps.mapListing.limitHelpDescription": "{totalItems} 個のアイテムがありますが、listingLimit の設定により {listingLimit} 個までしか下の表に表示できません。この設定は次の場所で変更できます ", + "xpack.maps.mapListing.listingTableTitle": "マップ", + "xpack.maps.mapListing.noItemsDescription": "マップがないようです。作成ボタンをクリックして作成してください。", + "xpack.maps.mapListing.noMatchDescription": "検索に一致するアイテムがありません。", + "xpack.maps.mapListing.searchAriaLabel": "フィルターアイテム", + "xpack.maps.mapListing.searchPlaceholder": "検索…", + "xpack.maps.mapListing.titleFieldTitle": "タイトル", + "xpack.maps.mapListing.unableToDeleteToastTitle": "マップを削除できません", + "xpack.maps.mapSavedObjectLabel": "マップ", + "xpack.maps.metricsEditor.addMetricButtonLabel": "メトリックを追加", + "xpack.maps.metricsEditor.aggregationLabel": "集約", + "xpack.maps.metricsEditor.customLabel": "カスタムラベル", + "xpack.maps.metricsEditor.deleteMetricAriaLabel": "メトリックを削除", + "xpack.maps.metricsEditor.deleteMetricButtonLabel": "メトリックを削除", + "xpack.maps.metricsEditor.selectFieldLabel": "フィールド", + "xpack.maps.metricsEditor.selectFieldPlaceholder": "フィールドを選択", + "xpack.maps.metricSelect.averageDropDownOptionLabel": "平均", + "xpack.maps.metricSelect.countDropDownOptionLabel": "カウント", + "xpack.maps.metricSelect.maxDropDownOptionLabel": "最高", + "xpack.maps.metricSelect.minDropDownOptionLabel": "最低", + "xpack.maps.metricSelect.selectAggregationPlaceholder": "集約を選択", + "xpack.maps.metricSelect.sumDropDownOptionLabel": "合計", + "xpack.maps.noIndexPattern.doThisLinkTextDescription": "インデックスパターンを作成します", + "xpack.maps.noIndexPattern.doThisPrefixDescription": "次のことが必要です ", + "xpack.maps.noIndexPattern.doThisSuffixDescription": " 地理空間フィールドを含む", + "xpack.maps.noIndexPattern.getStartedLinkText": "サンプルデータセットで始めましょう。", + "xpack.maps.noIndexPattern.hintDescription": "地理空間データセットがありませんか?", + "xpack.maps.noIndexPattern.messageTitle": "地理空間フィールドを含むインデックスパターンが見つかりませんでした", + "xpack.maps.sampleData.ecommerceSpec.mapsTitle": "[e コマース] 国別の注文", + "xpack.maps.sampleData.flightaSpec.logsTitle": "[ログ ] 合計リクエスト数とバイト数", + "xpack.maps.sampleData.flightaSpec.mapsTitle": "[フライト] 出発地と目的地の飛行時間", + "xpack.maps.sampleDataLinkLabel": "マップ", + "xpack.maps.setViewControl.goToButtonLabel": "移動:", + "xpack.maps.setViewControl.latitudeLabel": "緯度", + "xpack.maps.setViewControl.longitudeLabel": "経度", + "xpack.maps.setViewControl.submitButtonLabel": "Go", + "xpack.maps.setViewControl.zoomLabel": "ズーム:", + "xpack.maps.source.dataSourceLabel": "データソース", + "xpack.maps.source.ems_xyzDescription": "XYZ 座標を含む URL からのマップタイルです", + "xpack.maps.source.ems_xyzTitle": "URL からのタイルマップサービス", + "xpack.maps.source.ems.disabledDescription": "Elastic Maps Service へのアクセスが無効になっています。システム管理者に問い合わせるか、kibana.yml で「map.includeElasticMapsService」を設定してください。", + "xpack.maps.source.ems.noAccessDescription": "Kibana が Elastic Maps Service にアクセスできません。システム管理者にお問い合わせください", + "xpack.maps.source.emsFile.layerLabel": "レイヤー", + "xpack.maps.source.emsFile.selectPlaceholder": "EMS ベクターシェイプを選択", + "xpack.maps.source.emsFile.unableToFindIdErrorMessage": "ID {id} の EMS ベクターシェイプが見つかりません", + "xpack.maps.source.emsFileDescription": "Elastic Maps Service の行政区画のベクターシェイプ", + "xpack.maps.source.emsFileTitle": "ベクターシェイプ", + "xpack.maps.source.emsTile.autoLabel": "Kibana テーマに基づき自動選択", + "xpack.maps.source.emsTile.errorMessage": "ID {id} の EMS タイル構成が見つかりません", + "xpack.maps.source.emsTile.isAutoSelectLabel": "Kibana テーマに基づき自動選択", + "xpack.maps.source.emsTile.label": "タイルサービス", + "xpack.maps.source.emsTile.serviceId": "タイルサービス", + "xpack.maps.source.emsTileDescription": "Elastic Maps Service のマップタイル", + "xpack.maps.source.emsTileTitle": "タイル", + "xpack.maps.source.esGeoGrid.geofieldLabel": "地理空間フィールド", + "xpack.maps.source.esGeoGrid.geofieldPlaceholder": "ジオフィールドを選択", + "xpack.maps.source.esGeoGrid.gridRectangleDropdownOption": "グリッド四角", + "xpack.maps.source.esGeoGrid.heatmapDropdownOption": "ヒートマップ", + "xpack.maps.source.esGeoGrid.indexPatternLabel": "インデックスパターン", + "xpack.maps.source.esGeoGrid.indexPatternPlaceholder": "インデックスパターンを選択", + "xpack.maps.source.esGeoGrid.pointsDropdownOption": "点", + "xpack.maps.source.esGeoGrid.showAsLabel": "表示形式", + "xpack.maps.source.esGeoGrid.showAsPlaceholder": "1 つのオプションを選択", + "xpack.maps.source.esGrid.coarseDropdownOption": "粗い", + "xpack.maps.source.esGrid.fineDropdownOption": "細かい", + "xpack.maps.source.esGrid.finestDropdownOption": "最も細かい", + "xpack.maps.source.esGrid.geospatialFieldLabel": "地理空間フィールド", + "xpack.maps.source.esGrid.indexPatternLabel": "インデックスパターン", + "xpack.maps.source.esGrid.inspectorDescription": "Elasticsearch ジオグリッド集約リクエスト", + "xpack.maps.source.esGrid.metricsLabel": "メトリック", + "xpack.maps.source.esGrid.noIndexPatternErrorMessage": "インデックスパターン {id} が見つかりません", + "xpack.maps.source.esGrid.resolutionParamErrorMessage": "グリッド解像度パラメーターが認識されません: {resolution}", + "xpack.maps.source.esGrid.showasFieldLabel": "表示形式", + "xpack.maps.source.esGridDescription": "それぞれのグリッド付きセルのメトリックでグリッドにグループ分けされた地理空間データです。", + "xpack.maps.source.esGridTitle": "グリッド集約", + "xpack.maps.source.esJoin.joinDescription": "{description} の Elasticsearch 用語集約リクエストです", + "xpack.maps.source.esJoin.joinLeftDescription": "{leftSourceName}:{leftFieldName} を次と結合:", + "xpack.maps.source.esJoin.joinMetricsDescription": "メトリック {metrics} の", + "xpack.maps.source.esSearch.convertToGeoJsonErrorMsg": "検索への応答を geoJson 機能コレクションに変換できません。エラー: {errorMsg}", + "xpack.maps.source.esSearch.disableFilterByMapBoundsExplainMsg": "インデックス「{indexPatternTitle}」はドキュメント数が少なく、ダイナミックフィルターが必要ありません。", + "xpack.maps.source.esSearch.disableFilterByMapBoundsTitle": "ダイナミックデータフィルターは無効です", + "xpack.maps.source.esSearch.disableFilterByMapBoundsTurnOnMsg": "ドキュメント数が増えると思われる場合はダイナミックフィルターをオンにしてください。", + "xpack.maps.source.esSearch.extentFilterLabel": "マップの表示範囲でデータを動的にフィルタリング", + "xpack.maps.source.esSearch.geofieldLabel": "地理空間フィールド", + "xpack.maps.source.esSearch.geoFieldLabel": "地理空間フィールド", + "xpack.maps.source.esSearch.geoFieldTypeLabel": "地理空間フィールドタイプ", + "xpack.maps.source.esSearch.indexPatternLabel": "インデックスパターン", + "xpack.maps.source.esSearch.loadErrorMessage": "インデックスパターン {id} が見つかりません", + "xpack.maps.source.esSearch.loadTooltipPropertiesErrorMsg": "ドキュメントが見つかりません。_id: {docId}", + "xpack.maps.source.esSearch.selectIndexPatternPlaceholder": "インデックスパターンを選択", + "xpack.maps.source.esSearch.selectLabel": "ジオフィールドを選択", + "xpack.maps.source.esSearch.sortFieldSelectPlaceholder": "ソートフィールドを選択", + "xpack.maps.source.esSearch.topHitsSizeLabel": "エンティティごとのドキュメント数", + "xpack.maps.source.esSearch.topHitsSplitFieldLabel": "エンティティ", + "xpack.maps.source.esSearch.topHitsSplitFieldSelectPlaceholder": "エンティティフィールドを選択", + "xpack.maps.source.esSearch.useTopHitsLabel": "エンティティによる最も最近のドキュメントを表示", + "xpack.maps.source.esSearchDescription": "Kibana インデックスパターンの地理空間データ", + "xpack.maps.source.esSearchTitle": "ドキュメント", + "xpack.maps.source.esSource.noGeoFieldErrorMessage": "インデックスパターン {indexPatternTitle} には現在ジオフィールド {geoField} が含まれていません", + "xpack.maps.source.esSource.noIndexPatternErrorMessage": "ID {indexPatternId} のインデックスパターンが見つかりません", + "xpack.maps.source.esSource.requestFailedErrorMessage": "Elasticsearch 検索リクエストに失敗。エラー: {message}", + "xpack.maps.source.geojsonFileDescription": "GeoJSON ファイルをアップデートして Elasticsearch にインデックス", + "xpack.maps.source.geojsonFileTitle": "GeoJSON ベクトルファイルのアップロード", + "xpack.maps.source.kbnRegionMap.noConfigErrorMessage": "{name} の map.regionmap 構成が見つかりません", + "xpack.maps.source.kbnRegionMap.noLayerAvailableHelptext": "ベクターレイヤーが利用できません。システム管理者に、kibana.yml で「map.regionmap」を設定するよう依頼してください。", + "xpack.maps.source.kbnRegionMap.vectorLayerLabel": "ベクターレイヤー", + "xpack.maps.source.kbnRegionMapDescription": "kibana.yml で構成された静的ファイルのベクターシェイプです", + "xpack.maps.source.kbnRegionMapTitle": "カスタムベクターシェイプ", + "xpack.maps.source.kbnTMS.kbnTMS.urlLabel": "タイルマップ URL", + "xpack.maps.source.kbnTMS.noConfigErrorMessage": "kibana.yml に map.tilemap.url 構成が見つかりません", + "xpack.maps.source.kbnTMS.noLayerAvailableHelptext": "タイルマップレイヤーが利用できません。システム管理者に、kibana.yml で「map.tilemap.url」を設定するよう依頼してください。", + "xpack.maps.source.kbnTMS.urlLabel": "タイルマップ URL", + "xpack.maps.source.kbnTMSDescription": "kibana.yml で構成されたマップタイルです", + "xpack.maps.source.kbnTMSTitle": "カスタムタイルマップサービス", + "xpack.maps.source.pewPew.destGeoFieldLabel": "送信先", + "xpack.maps.source.pewPew.destGeoFieldPlaceholder": "デスティネーション地理情報フィールドを選択", + "xpack.maps.source.pewPew.indexPatternLabel": "インデックスパターン", + "xpack.maps.source.pewPew.indexPatternPlaceholder": "インデックスパターンを選択", + "xpack.maps.source.pewPew.inspectorDescription": "ソースとデスティネーションの接続リクエスト", + "xpack.maps.source.pewPew.metricsLabel": "メトリック", + "xpack.maps.source.pewPew.noIndexPatternErrorMessage": "インデックスパターン {id} が見つかりません", + "xpack.maps.source.pewPew.noSourceAndDestDetails": "選択されたインデックスパターンにはソースとデスティネーションのフィールドが含まれていません。", + "xpack.maps.source.pewPew.sourceGeoFieldLabel": "送信元", + "xpack.maps.source.pewPew.sourceGeoFieldPlaceholder": "ソース地理情報フィールドを選択", + "xpack.maps.source.pewPewDescription": "ソースとデスティネーションの間の集約データパスです。", + "xpack.maps.source.pewPewTitle": "ソースとデスティネーションの接続", + "xpack.maps.source.urlLabel": "URL", + "xpack.maps.source.vetorSource.formatErrorMessage": "URL からベクターシェイプを取得できません: {format}", + "xpack.maps.source.vetorSource.requestFailedErrorMessage": "URL からベクターシェイプを取得できません: {fetchUrl}", + "xpack.maps.source.wms.attributionLink": "属性テキストにはリンクが必要です", + "xpack.maps.source.wms.attributionText": "属性 URL にはテキストが必要です", + "xpack.maps.source.wms.getCapabilitiesButtonText": "負荷容量", + "xpack.maps.source.wms.getCapabilitiesErrorCalloutTitle": "サービスメタデータを読み込めません", + "xpack.maps.source.wms.layersHelpText": "レイヤー名のコンマ区切りのリストを使用します", + "xpack.maps.source.wms.layersLabel": "レイヤー", + "xpack.maps.source.wms.stylesHelpText": "スタイル名のコンマ区切りのリストを使用します", + "xpack.maps.source.wms.stylesLabel": "スタイル", + "xpack.maps.source.wms.urlLabel": "URL", + "xpack.maps.source.wmsDescription": "OGC スタンダード WMS のマップ", + "xpack.maps.source.wmsTitle": "ウェブマップサービス", + "xpack.maps.style.customColorRampLabel": "カスタマカラーランプ", + "xpack.maps.style.heatmap.displayNameLabel": "ヒートマップスタイル", + "xpack.maps.style.heatmap.resolutionStyleErrorMessage": "解像度パラメーターが認識されません: {resolution}", + "xpack.maps.styles.vector.borderColorLabel": "境界線の色", + "xpack.maps.styles.vector.borderWidthLabel": "境界線の幅", + "xpack.maps.styles.vector.fillColorLabel": "塗りつぶす色", + "xpack.maps.styles.vector.orientationLabel": "記号の向き", + "xpack.maps.styles.vector.selectFieldPlaceholder": "フィールドを選択", + "xpack.maps.styles.vector.symbolSizeLabel": "シンボルのサイズ", + "xpack.maps.toolbarOverlay.drawBounds.initialGeometryLabel": "境界", + "xpack.maps.toolbarOverlay.drawBoundsLabel": "境界を描いてデータをフィルタリング", + "xpack.maps.toolbarOverlay.drawBoundsLabelShort": "境界を描く", + "xpack.maps.toolbarOverlay.drawShape.initialGeometryLabel": "図形", + "xpack.maps.toolbarOverlay.drawShapeLabel": "シェイプを描いてデータをフィルタリング", + "xpack.maps.toolbarOverlay.drawShapeLabelShort": "図形を描く", + "xpack.maps.toolbarOverlay.tools.toolbarTitle": "ツール", + "xpack.maps.toolbarOverlay.toolsControlTitle": "ツール", + "xpack.maps.tooltip.allLayersLabel": "すべてのレイヤー", + "xpack.maps.tooltip.closeAriaLabel": "ツールヒントを閉じる", + "xpack.maps.tooltip.filterOnPropertyAriaLabel": "プロパティのフィルター", + "xpack.maps.tooltip.filterOnPropertyTitle": "プロパティのフィルター", + "xpack.maps.tooltip.geometryFilterForm.createFilterButtonLabel": "フィルターを作成", + "xpack.maps.tooltip.geometryFilterForm.filterTooLargeMessage": "フィルターを作成できません。フィルターがURLに追加されました。この形状には頂点が多すぎるため、URLに合いません。", + "xpack.maps.tooltip.layerFilterLabel": "レイヤー別に結果をフィルタリング", + "xpack.maps.tooltip.loadingMsg": "読み込み中", + "xpack.maps.tooltip.pageNumerText": "{pageNumber} / {total}", + "xpack.maps.tooltip.showGeometryFilterViewLinkLabel": "ジオメトリでフィルタリング", + "xpack.maps.tooltip.toolsControl.cancelDrawButtonLabel": "キャンセル", + "xpack.maps.tooltip.unableToLoadContentTitle": "ツールヒントのコンテンツを読み込めません", + "xpack.maps.tooltipSelector.addLabelWithCount": "{count} を追加", + "xpack.maps.tooltipSelector.addLabelWithoutCount": "追加", + "xpack.maps.tooltipSelector.grabButtonAriaLabel": "プロパティを並べ替える", + "xpack.maps.tooltipSelector.grabButtonTitle": "プロパティを並べ替える", + "xpack.maps.tooltipSelector.togglePopoverLabel": "追加", + "xpack.maps.tooltipSelector.trashButtonAriaLabel": "プロパティを削除", + "xpack.maps.tooltipSelector.trashButtonTitle": "プロパティを削除", + "xpack.maps.validatedRange.rangeErrorMessage": "{min} と {max} の間でなければなりません", + "xpack.maps.vector.dualSize.unitLabel": "px", + "xpack.maps.vector.size.unitLabel": "px", + "xpack.maps.vector.symbolAs.circleLabel": "円", + "xpack.maps.vector.symbolAs.IconLabel": "アイコン", + "xpack.maps.vector.symbolLabel": "マーク", + "xpack.maps.vectorLayer.noResultsFoundInJoinTooltip": "用語結合には一致する結果が見つかりません", + "xpack.maps.vectorLayer.noResultsFoundTooltip": "結果が見つかりませんでした。", + "xpack.maps.vectorStyleEditor.featureTypeButtonGroupLegend": "ベクター機能ボタングループ", + "xpack.maps.vectorStyleEditor.lineLabel": "行", + "xpack.maps.vectorStyleEditor.pointLabel": "ポイント", + "xpack.maps.vectorStyleEditor.polygonLabel": "多角形", + "xpack.maps.viewControl.latLabel": "緯度:", + "xpack.maps.viewControl.lonLabel": "経度:", + "xpack.maps.viewControl.zoomLabel": "ズーム:", + "xpack.maps.visTypeAlias.description": "マップを作成し、複数のレイヤーとインデックスを使用して、スタイルを設定します。\n座標マップと地域マップの代わりに、マップアプリを使用します。\nマップアプリはより機能が豊富で、使いやすくなっています。", + "xpack.maps.visTypeAlias.title": "マップ", + "xpack.maps.xyztmssource.attributionLink": "属性テキストにはリンクが必要です", + "xpack.maps.xyztmssource.attributionText": "属性 URL にはテキストが必要です", + "xpack.ml.accessDenied.description": "ML プラグインへのアクセスパーミッションがありません", + "xpack.ml.accessDenied.label": "パーミッションがありません", + "xpack.ml.annotationsTable.actionsColumnName": "アクション", + "xpack.ml.annotationsTable.annotationColumnName": "注釈", + "xpack.ml.annotationsTable.annotationsNotCreatedTitle": "このジョブには注釈が作成されていません", + "xpack.ml.annotationsTable.editAnnotationsTooltip": "注釈を編集します", + "xpack.ml.annotationsTable.editAnnotationsTooltipAriaLabel": "注釈を編集します", + "xpack.ml.annotationsTable.fromColumnName": "開始値:", + "xpack.ml.annotationsTable.howToCreateAnnotationDescription": "注釈を作成するには、{linkToSingleMetricView} を開きます", + "xpack.ml.annotationsTable.howToCreateAnnotationDescription.singleMetricViewerLinkText": "シングルメトリックビューアー", + "xpack.ml.annotationsTable.jobConfigurationNotSupportedInSingleMetricViewerAriaLabel": "シングルメトリックビューアーでジョブ構成がサポートされていません", + "xpack.ml.annotationsTable.jobConfigurationNotSupportedInSingleMetricViewerTooltip": "シングルメトリックビューアーでジョブ構成がサポートされていません", + "xpack.ml.annotationsTable.jobIdColumnName": "ジョブ ID", + "xpack.ml.annotationsTable.labelColumnName": "ラベル", + "xpack.ml.annotationsTable.lastModifiedByColumnName": "最終更新者", + "xpack.ml.annotationsTable.lastModifiedDateColumnName": "最終更新日", + "xpack.ml.annotationsTable.openInSingleMetricViewerAriaLabel": "シングルメトリックビューアーで開く", + "xpack.ml.annotationsTable.openInSingleMetricViewerTooltip": "シングルメトリックビューアーで開く", + "xpack.ml.annotationsTable.toColumnName": "To", + "xpack.ml.anomaliesTable.actionsColumnName": "アクション", + "xpack.ml.anomaliesTable.actualSortColumnName": "実際", + "xpack.ml.anomaliesTable.anomalyDetails.actualTitle": "実際", + "xpack.ml.anomaliesTable.anomalyDetails.anomalyDescriptionListMoreLinkText": "他 {othersCount} 件", + "xpack.ml.anomaliesTable.anomalyDetails.anomalyDescriptionShowLessLinkText": "縮小表示", + "xpack.ml.anomaliesTable.anomalyDetails.anomalyDetailsTitle": "異常の詳細", + "xpack.ml.anomaliesTable.anomalyDetails.anomalyInLabel": "{anomalyDetector} の {anomalySeverity} の異常", + "xpack.ml.anomaliesTable.anomalyDetails.anomalyTimeRangeLabel": "{anomalyTime} から {anomalyEndTime}", + "xpack.ml.anomaliesTable.anomalyDetails.categoryExamplesTitle": "カテゴリーの例", + "xpack.ml.anomaliesTable.anomalyDetails.causeValuesDescription": "{causeEntityValue} (実際値 {actualValue}、通常値 {typicalValue}、確率 {probabilityValue})", + "xpack.ml.anomaliesTable.anomalyDetails.causeValuesTitle": "{causeEntityName} の値", + "xpack.ml.anomaliesTable.anomalyDetails.descriptionTitle": "説明", + "xpack.ml.anomaliesTable.anomalyDetails.detailsOnHighestSeverityAnomalyTitle": "深刻度が高い異常の詳細", + "xpack.ml.anomaliesTable.anomalyDetails.detailsTitle": "詳細", + "xpack.ml.anomaliesTable.anomalyDetails.detectedInLabel": " {sourcePartitionFieldName} {sourcePartitionFieldValue} で検知", + "xpack.ml.anomaliesTable.anomalyDetails.examplesTitle": "例", + "xpack.ml.anomaliesTable.anomalyDetails.fieldNameTitle": "fieldName", + "xpack.ml.anomaliesTable.anomalyDetails.foundForLabel": " {anomalyEntityName} {anomalyEntityValue} で発見", + "xpack.ml.anomaliesTable.anomalyDetails.functionTitle": "関数", + "xpack.ml.anomaliesTable.anomalyDetails.influencersTitle": "影響", + "xpack.ml.anomaliesTable.anomalyDetails.interimResultLabel": "中間結果", + "xpack.ml.anomaliesTable.anomalyDetails.jobIdTitle": "ジョブ ID", + "xpack.ml.anomaliesTable.anomalyDetails.multiBucketImpactTitle": "複数バケットの影響", + "xpack.ml.anomaliesTable.anomalyDetails.multivariateDescription": "{sourceByFieldName} で多変量相関が見つかりました; {sourceByFieldValue} は {sourceCorrelatedByFieldValue} のため異例とみなされます", + "xpack.ml.anomaliesTable.anomalyDetails.probabilityTitle": "確率", + "xpack.ml.anomaliesTable.anomalyDetails.regexDescriptionAriaLabel": "説明", + "xpack.ml.anomaliesTable.anomalyDetails.regexDescriptionTooltip": "カテゴリーが一致する値を検索するのに使用される正規表現です ({maxChars} 文字の制限で切り捨てられている可能性があります)", + "xpack.ml.anomaliesTable.anomalyDetails.regexTitle": "正規表現", + "xpack.ml.anomaliesTable.anomalyDetails.termsDescriptionAriaLabel": "説明", + "xpack.ml.anomaliesTable.anomalyDetails.termsDescriptionTooltip": "カテゴリーの値で一致している共通のトークンのスペース区切りのリストです (({maxChars} 文字の制限で切り捨てられている可能性があります)", + "xpack.ml.anomaliesTable.anomalyDetails.termsTitle": "用語", + "xpack.ml.anomaliesTable.anomalyDetails.timeTitle": "時間", + "xpack.ml.anomaliesTable.anomalyDetails.typicalTitle": "通常", + "xpack.ml.anomaliesTable.categoryExamplesColumnName": "カテゴリーの例", + "xpack.ml.anomaliesTable.detectorCell.rulesConfiguredTooltip": "この検知器にはルールが構成されています", + "xpack.ml.anomaliesTable.detectorColumnName": "検知器", + "xpack.ml.anomaliesTable.entityCell.addFilterAriaLabel": "フィルターを追加", + "xpack.ml.anomaliesTable.entityCell.addFilterTooltip": "フィルターを追加します", + "xpack.ml.anomaliesTable.entityCell.removeFilterAriaLabel": "フィルターを削除", + "xpack.ml.anomaliesTable.entityCell.removeFilterTooltip": "フィルターを削除します", + "xpack.ml.anomaliesTable.entityValueColumnName": "検索条件:", + "xpack.ml.anomaliesTable.hideDetailsAriaLabel": "詳細を非表示", + "xpack.ml.anomaliesTable.influencersCell.addFilterAriaLabel": "フィルターを追加します", + "xpack.ml.anomaliesTable.influencersCell.addFilterTooltip": "フィルターを追加します", + "xpack.ml.anomaliesTable.influencersCell.moreInfluencersLinkText": "他 {othersCount} 件", + "xpack.ml.anomaliesTable.influencersCell.removeFilterAriaLabel": "フィルターを削除します", + "xpack.ml.anomaliesTable.influencersCell.removeFilterTooltip": "フィルターを削除します", + "xpack.ml.anomaliesTable.influencersCell.showLessInfluencersLinkText": "縮小表示", + "xpack.ml.anomaliesTable.influencersColumnName": "影響元", + "xpack.ml.anomaliesTable.jobIdColumnName": "ジョブ ID", + "xpack.ml.anomaliesTable.linksMenu.configureRulesLabel": "ルールを構成", + "xpack.ml.anomaliesTable.linksMenu.loadingDetailsErrorMessage": "カテゴリー ID {categoryId} の詳細の読み込み中にエラーが発生したため例を表示できません", + "xpack.ml.anomaliesTable.linksMenu.noMappingCouldBeFoundErrorMessage": "カテゴリー分けフィールド {categorizationFieldName} のマッピングが見つからなかったため、ML カテゴリー {categoryId} のドキュメントの例を表示できません", + "xpack.ml.anomaliesTable.linksMenu.selectActionAriaLabel": "{time} の異常のアクションを選択", + "xpack.ml.anomaliesTable.linksMenu.unableToOpenLinkErrorMessage": "カテゴリー ID {categoryId} の詳細の読み込み中にエラーが発生したためリンクを開けません", + "xpack.ml.anomaliesTable.linksMenu.unableToViewExamplesErrorMessage": "ジョブ ID {jobId} の詳細が見つからなかったため例を表示できません", + "xpack.ml.anomaliesTable.linksMenu.viewExamplesLabel": "例を表示", + "xpack.ml.anomaliesTable.linksMenu.viewSeriesLabel": "数列を表示", + "xpack.ml.anomaliesTable.metricDescriptionSortColumnName": "説明", + "xpack.ml.anomaliesTable.noMatchingAnomaliesFoundTitle": "一致する注釈が見つかりません", + "xpack.ml.anomaliesTable.severityColumnName": "深刻度", + "xpack.ml.anomaliesTable.showDetailsAriaLabel": "詳細を表示", + "xpack.ml.anomaliesTable.timeColumnName": "時間", + "xpack.ml.anomaliesTable.typicalSortColumnName": "通常", + "xpack.ml.anomalyDetection.anomalyExplorerLabel": "異常エクスプローラー", + "xpack.ml.anomalyDetection.jobManagementLabel": "ジョブ管理", + "xpack.ml.anomalyDetection.singleMetricViewerLabel": "シングルメトリックビューアー", + "xpack.ml.anomalyDetectionBreadcrumbLabel": "異常検知", + "xpack.ml.anomalyExplorerPageLabel": "異常エクスプローラー", + "xpack.ml.anomalyUtils.multiBucketImpact.highLabel": "高", + "xpack.ml.anomalyUtils.multiBucketImpact.lowLabel": "低", + "xpack.ml.anomalyUtils.multiBucketImpact.mediumLabel": "中", + "xpack.ml.anomalyUtils.multiBucketImpact.noneLabel": "なし", + "xpack.ml.anomalyUtils.severity.criticalLabel": "致命的", + "xpack.ml.anomalyUtils.severity.majorLabel": "メジャー", + "xpack.ml.anomalyUtils.severity.minorLabel": "マイナー", + "xpack.ml.anomalyUtils.severity.unknownLabel": "不明", + "xpack.ml.anomalyUtils.severity.warningLabel": "警告", + "xpack.ml.anomalyUtils.severityWithLow.lowLabel": "低", + "xpack.ml.calendarsEdit.calendarForm.allowedCharactersDescription": "アルファベットの小文字 (a-z と 0-9)、ハイフンまたはアンダーラインを使用し、最初と最後を英数字にする必要があります", + "xpack.ml.calendarsEdit.calendarForm.calendarIdLabel": "カレンダー ID", + "xpack.ml.calendarsEdit.calendarForm.calendarTitle": "カレンダー {calendarId}", + "xpack.ml.calendarsEdit.calendarForm.cancelButtonLabel": "キャンセル", + "xpack.ml.calendarsEdit.calendarForm.createCalendarTitle": "新規カレンダーの作成", + "xpack.ml.calendarsEdit.calendarForm.descriptionLabel": "説明", + "xpack.ml.calendarsEdit.calendarForm.eventsLabel": "イベント", + "xpack.ml.calendarsEdit.calendarForm.groupsLabel": "グループ", + "xpack.ml.calendarsEdit.calendarForm.jobsLabel": "ジョブ", + "xpack.ml.calendarsEdit.calendarForm.saveButtonLabel": "保存", + "xpack.ml.calendarsEdit.calendarForm.savingButtonLabel": "保存中…", + "xpack.ml.calendarsEdit.canNotCreateCalendarWithExistingIdErrorMessag": "ID [{formCalendarId}] は既に存在するため、この ID でカレンダーを作成できません。", + "xpack.ml.calendarsEdit.errorWithCreatingCalendarErrorMessage": "カレンダー {calendarId} の作成中にエラーが発生しました", + "xpack.ml.calendarsEdit.errorWithFetchingJobSummariesErrorMessage": "ジョブ概要の取得中にエラーが発生しました: {err}", + "xpack.ml.calendarsEdit.errorWithLoadingCalendarFromDataErrorMessage": "データからカレンダーを読み込み中にエラーが発生しました。ページを更新してみてください。", + "xpack.ml.calendarsEdit.errorWithLoadingCalendarsErrorMessage": "カレンダーの読み込み中にエラーが発生しました: {err}", + "xpack.ml.calendarsEdit.errorWithLoadingGroupsErrorMessage": "グループの読み込み中にエラーが発生しました: {err}", + "xpack.ml.calendarsEdit.errorWithUpdatingCalendarErrorMessage": "カレンダー {calendarId} の保存中にエラーが発生しました。ページを更新してみてください。", + "xpack.ml.calendarsEdit.eventsTable.cancelButtonLabel": "キャンセル", + "xpack.ml.calendarsEdit.eventsTable.deleteButtonLabel": "削除", + "xpack.ml.calendarsEdit.eventsTable.descriptionColumnName": "説明", + "xpack.ml.calendarsEdit.eventsTable.endColumnName": "終了", + "xpack.ml.calendarsEdit.eventsTable.importButtonLabel": "インポート", + "xpack.ml.calendarsEdit.eventsTable.importEventsButtonLabel": "イベントをインポート", + "xpack.ml.calendarsEdit.eventsTable.importEventsDescription": "ICS ファイルからイベントをインポートします。", + "xpack.ml.calendarsEdit.eventsTable.importEventsTitle": "イベントのインポート", + "xpack.ml.calendarsEdit.eventsTable.newEventButtonLabel": "新規イベント", + "xpack.ml.calendarsEdit.eventsTable.startColumnName": "開始", + "xpack.ml.calendarsEdit.importedEvents.eventsToImportTitle": "インポートするイベント: {eventsCount}", + "xpack.ml.calendarsEdit.importedEvents.includePastEventsLabel": "過去のイベントを含める", + "xpack.ml.calendarsEdit.importedEvents.recurringEventsNotSupportedDescription": "定期イベントはサポートされていません。初めのイベントのみがインポートされます。", + "xpack.ml.calendarsEdit.importModal.couldNotParseICSFileErrorMessage": "ICS ファイルをパースできませんでした。", + "xpack.ml.calendarsEdit.importModal.selectOrDragAndDropFilePromptText": "ファイルを選択するかドラッグ & ドロップしてください", + "xpack.ml.calendarsEdit.newEventModal.addButtonLabel": "追加", + "xpack.ml.calendarsEdit.newEventModal.cancelButtonLabel": "キャンセル", + "xpack.ml.calendarsEdit.newEventModal.createNewEventTitle": "新規イベントの作成", + "xpack.ml.calendarsEdit.newEventModal.descriptionLabel": "説明", + "xpack.ml.calendarsEdit.newEventModal.endDateAriaLabel": "終了日", + "xpack.ml.calendarsEdit.newEventModal.fromLabel": "開始:", + "xpack.ml.calendarsEdit.newEventModal.startDateAriaLabel": "開始日", + "xpack.ml.calendarsEdit.newEventModal.toLabel": "終了:", + "xpack.ml.calendarsList.deleteCalendars.calendarsLabel": "{calendarsToDeleteCount} 件のカレンダー", + "xpack.ml.calendarsList.deleteCalendars.deletingCalendarErrorMessage": "カレンダー {calendarId} の削除中にエラーが発生しました: {errorMessage}", + "xpack.ml.calendarsList.deleteCalendars.deletingCalendarsNotificationMessage": "{messageId} を削除中", + "xpack.ml.calendarsList.deleteCalendars.deletingCalendarSuccessNotificationMessage": "{messageId} が選択されました", + "xpack.ml.calendarsList.deleteCalendarsModal.cancelButtonLabel": "キャンセル", + "xpack.ml.calendarsList.deleteCalendarsModal.deleteButtonLabel": "削除", + "xpack.ml.calendarsList.deleteCalendarsModal.deleteCalendarsDescription": "{calendarsCount, plural, one {このカレンダー} other {これらのカレンダー}}を削除しますか?{calendarsList}", + "xpack.ml.calendarsList.deleteCalendarsModal.deleteCalendarTitle": "カレンダーの削除", + "xpack.ml.calendarsList.errorWithLoadingListOfCalendarsErrorMessage": "カレンダーのリストの読み込み中にエラーが発生しました。", + "xpack.ml.calendarsList.table.deleteButtonLabel": "削除", + "xpack.ml.calendarsList.table.eventsColumnName": "イベント", + "xpack.ml.calendarsList.table.eventsCountLabel": "{eventsLength, plural, one {# イベント} other {# イベント}}", + "xpack.ml.calendarsList.table.idColumnName": "ID", + "xpack.ml.calendarsList.table.jobsColumnName": "ジョブ", + "xpack.ml.calendarsList.table.newButtonLabel": "新規", + "xpack.ml.checkLicense.licenseHasExpiredMessage": "{licenseTypeName} 機械学習ライセンスが期限切れになりました。", + "xpack.ml.checkLicense.licenseInformationNotAvailableThisTimeMessage": "現在ライセンス情報が利用できないため機械学習を使用できません。", + "xpack.ml.checkLicense.mlIsUnavailableMessage": "機械学習が利用できません", + "xpack.ml.controls.checkboxShowCharts.showChartsCheckboxLabel": "チャートを表示", + "xpack.ml.controls.selectInterval.autoLabel": "自動", + "xpack.ml.controls.selectInterval.dayLabel": "1 日", + "xpack.ml.controls.selectInterval.hourLabel": "1 時間", + "xpack.ml.controls.selectInterval.showAllLabel": "すべて表示", + "xpack.ml.controls.selectSeverity.criticalLabel": "致命的", + "xpack.ml.controls.selectSeverity.majorLabel": "メジャー", + "xpack.ml.controls.selectSeverity.minorLabel": "マイナー", + "xpack.ml.controls.selectSeverity.scoreDetailsDescription": "スコア {value} 以上", + "xpack.ml.controls.selectSeverity.warningLabel": "警告", + "xpack.ml.customUrlEditor.discoverLabel": "ディスカバリ", + "xpack.ml.customUrlEditor.kibanaDashboardLabel": "Kibana ダッシュボード", + "xpack.ml.customUrlEditor.otherLabel": "その他", + "xpack.ml.customUrlEditorList.deleteCustomUrlAriaLabel": "カスタム URL を削除", + "xpack.ml.customUrlEditorList.deleteCustomUrlTooltip": "カスタム URL を削除します", + "xpack.ml.customUrlEditorList.invalidTimeRangeFormatErrorMessage": "無効なフォーマット", + "xpack.ml.customUrlEditorList.labelIsNotUniqueErrorMessage": "固有のラベルが供給されました", + "xpack.ml.customUrlEditorList.labelLabel": "ラベル", + "xpack.ml.customUrlEditorList.obtainingUrlToTestConfigurationErrorMessage": "構成をテストするための URL の取得中にエラーが発生しました", + "xpack.ml.customUrlEditorList.testCustomUrlAriaLabel": "カスタム URL をテスト", + "xpack.ml.customUrlEditorList.testCustomUrlTooltip": "カスタム URL をテストします", + "xpack.ml.customUrlEditorList.timeRangeLabel": "時間範囲", + "xpack.ml.customUrlEditorList.urlLabel": "URL", + "xpack.ml.customUrlsEditor.createNewCustomUrlTitle": "新規カスタム URL の作成", + "xpack.ml.customUrlsEditor.dashboardNameLabel": "ダッシュボード名", + "xpack.ml.customUrlsEditor.indexPatternLabel": "インデックスパターン", + "xpack.ml.customUrlsEditor.intervalLabel": "間隔", + "xpack.ml.customUrlsEditor.invalidLabelErrorMessage": "固有のラベルが供給されました", + "xpack.ml.customUrlsEditor.labelLabel": "ラベル", + "xpack.ml.customUrlsEditor.linkToLabel": "リンク先", + "xpack.ml.customUrlsEditor.queryEntitiesLabel": "エントリーをクエリ", + "xpack.ml.customUrlsEditor.selectEntitiesPlaceholder": "エントリーを選択", + "xpack.ml.customUrlsEditor.timeRangeLabel": "時間範囲", + "xpack.ml.customUrlsEditor.urlLabel": "URL", + "xpack.ml.customUrlsList.invalidIntervalFormatErrorMessage": "無効な間隔のフォーマット", + "xpack.ml.dataframe.analytics.create.advancedEditor.codeEditorAriaLabel": "高度な分析ジョブエディター", + "xpack.ml.dataframe.analytics.create.advancedEditor.configRequestBody": "構成リクエスト本文", + "xpack.ml.dataframe.analytics.create.advancedEditor.jobIdExistsError": "このIDの分析ジョブが既に存在します。", + "xpack.ml.dataframe.analytics.create.advancedEditor.jobIdInputAriaLabel": "固有の分析ジョブIDを選択してください。", + "xpack.ml.dataframe.analytics.create.advancedEditor.jobIdInvalidError": "小文字のアルファベットと数字(a-zと0-9)、ハイフンまたはアンダーラインのみ使用でき、最初と最後を英数字にする必要があります。", + "xpack.ml.dataframe.analytics.create.advancedEditor.jobIdLabel": "分析ジョブID", + "xpack.ml.dataframe.analytics.create.advancedEditorMessage.dependentVariableEmpty": "従属変数フィールドは未入力のままにできません。", + "xpack.ml.dataframe.analytics.create.advancedEditorMessage.destinationIndexNameEmpty": "デスティネーションインデックス名は未入力のままにできません。", + "xpack.ml.dataframe.analytics.create.advancedEditorMessage.destinationIndexNameValid": "無効なデスティネーションインデックス名。", + "xpack.ml.dataframe.analytics.create.advancedEditorMessage.sourceIndexNameEmpty": "ソースインデックス名は未入力のままにできません。", + "xpack.ml.dataframe.analytics.create.advancedEditorMessage.sourceIndexNameValid": "無効なソースインデックス名。", + "xpack.ml.dataframe.analytics.create.createIndexPatternErrorMessage": "Kibanaインデックスパターンの作成中にエラーが発生しました。", + "xpack.ml.dataframe.analytics.create.createIndexPatternLabel": "インデックスパターンを作成", + "xpack.ml.dataframe.analytics.create.createIndexPatternSuccessMessage": "Kibanaインデックスパターン{indexPatternName}が作成されました。", + "xpack.ml.dataframe.analytics.create.dependentVariableInputAriaLabel": "従属変数として使用するフィールドを入力してください。", + "xpack.ml.dataframe.analytics.create.dependentVariableLabel": "従属変数", + "xpack.ml.dataframe.analytics.create.dependentVariableOptionsFetchError": "フィールドの取得中にエラーが発生しました。ページを更新して再起動してください。", + "xpack.ml.dataframe.analytics.create.dependentVariableOptionsNoNumericalFields": "このインデックスパターンの数値型フィールドが見つかりませんでした。", + "xpack.ml.dataframe.analytics.create.dependentVariablePlaceholder": "従属変数", + "xpack.ml.dataframe.analytics.create.destinationIndexHelpText": "この名前のインデックスが既に存在します。この分析ジョブを実行すると、デスティネーションインデックスが変更されます。", + "xpack.ml.dataframe.analytics.create.destinationIndexInputAriaLabel": "固有の宛先インデックス名を選択してください。", + "xpack.ml.dataframe.analytics.create.destinationIndexInvalidError": "無効なデスティネーションインデックス名。", + "xpack.ml.dataframe.analytics.create.destinationIndexLabel": "デスティネーションインデックス", + "xpack.ml.dataframe.analytics.create.duplicateIndexPatternErrorMessage": "Kibanaインデックスパターンの作成中にエラーが発生しました。", + "xpack.ml.dataframe.analytics.create.duplicateIndexPatternErrorMessageError": "インデックスパターン{indexPatternName}はすでに作成されています。", + "xpack.ml.dataframe.analytics.create.enableAdvancedEditorHelpText": "高度なエディターからこのフォームには戻れません。", + "xpack.ml.dataframe.analytics.create.enableAdvancedEditorSwitch": "詳細エディターを有効にする", + "xpack.ml.dataframe.analytics.create.errorCreatingDataFrameAnalyticsJob": "データフレーム分析ジョブの作成中にエラーが発生しました。", + "xpack.ml.dataframe.analytics.create.errorGettingDataFrameAnalyticsList": "既存のデータフレーム分析ジョブIDの取得中にエラーが発生しました。", + "xpack.ml.dataframe.analytics.create.errorGettingDataFrameIndexNames": "既存のインデックス名の取得中にエラーが発生しました。", + "xpack.ml.dataframe.analytics.create.errorGettingIndexPatternTitles": "既存のインデックスパターンのタイトルの取得中にエラーが発生しました。", + "xpack.ml.dataframe.analytics.create.errorStartingDataFrameAnalyticsJob": "データフレーム分析ジョブの開始中にエラーが発生しました。", + "xpack.ml.dataframe.analytics.create.flyoutCancelButton": "キャンセル", + "xpack.ml.dataframe.analytics.create.flyoutCloseButton": "閉じる", + "xpack.ml.dataframe.analytics.create.flyoutCreateButton": "作成", + "xpack.ml.dataframe.analytics.create.flyoutHeaderTitle": "分析ジョブの作成", + "xpack.ml.dataframe.analytics.create.flyoutStartButton": "開始", + "xpack.ml.dataframe.analytics.create.indexPatternAlreadyExistsError": "このタイトルのインデックスパターンが既に存在します。", + "xpack.ml.dataframe.analytics.create.indexPatternExistsError": "このタイトルのインデックスパターンが既に存在します。", + "xpack.ml.dataframe.analytics.create.jobIdExistsError": "このIDの分析ジョブが既に存在します。", + "xpack.ml.dataframe.analytics.create.jobIdInputAriaLabel": "固有の分析ジョブIDを選択してください。", + "xpack.ml.dataframe.analytics.create.jobIdInvalidError": "小文字のアルファベットと数字(a-zと0-9)、ハイフンまたはアンダーラインのみ使用でき、最初と最後を英数字にする必要があります。", + "xpack.ml.dataframe.analytics.create.jobIdInvalidMaxLengthErrorMessage": "ジョブ ID は {maxLength, plural, one {# 文字} other {# 文字}} 以内でなければなりません。", + "xpack.ml.dataframe.analytics.create.jobIdLabel": "ジョブID", + "xpack.ml.dataframe.analytics.create.jobIdPlaceholder": "ジョブID", + "xpack.ml.dataframe.analytics.create.jobTypeLabel": "ジョブタイプ", + "xpack.ml.dataframe.analytics.create.outlierDetectionHelpText": "外れ値検出ジョブには表のようなデータストラクチャでマッピングされたソースインデックスが必要で、数字とブールフィールドのみ分析されます。モデルメモリー制限や分析タイプなどのカスタムオプションを適用するには、詳細エディターを使用してください。", + "xpack.ml.dataframe.analytics.create.outlierRegressionHelpText": "リグレッションジョブは数値フィールドのみを分析します。モデルメモリー制限や予測フィールド名などのカスタムオプションを適用するには、詳細エディターを使用してください。", + "xpack.ml.dataframe.analytics.create.sourceIndexFieldCheckError": "数値フィールドの確認中に問題が発生しました。ページを更新して再起動してください。", + "xpack.ml.dataframe.analytics.create.sourceIndexHelpText": "このインデックスパターンには数字タイプのフィールドが含まれていません。分析ジョブで外れ値が検出されない可能性があります。", + "xpack.ml.dataframe.analytics.create.sourceIndexInputAriaLabel": "ソースインデックスパターンまたは検索。", + "xpack.ml.dataframe.analytics.create.sourceIndexInvalidError": "無効なソースインデックス名。スペースや{characterList}を含めることはできません", + "xpack.ml.dataframe.analytics.create.sourceIndexLabel": "ソースインデックス", + "xpack.ml.dataframe.analytics.create.sourceIndexPlaceholder": "ソースインデックスパターンまたは保存された検索を選択してください。", + "xpack.ml.dataframe.analytics.create.startDataFrameAnalyticsSuccessMessage": "データフレーム分析 {jobId} の開始リクエストが受け付けられました。", + "xpack.ml.dataframe.analytics.create.trainingPercentLabel": "トレーニングパーセンテージ", + "xpack.ml.dataframe.analytics.exploration.experimentalBadgeLabel": "実験的", + "xpack.ml.dataframe.analytics.exploration.experimentalBadgeTooltipContent": "データフレーム分析は実験段階の機能です。フィードバックをお待ちしています。", + "xpack.ml.dataframe.analytics.exploration.fieldSelection": "{docFieldsCount, number} 件中 showing {selectedFieldsLength, number} 件の{docFieldsCount, plural, one {フィールド} other {フィールド}}", + "xpack.ml.dataframe.analytics.exploration.indexArrayBadgeContent": "配列", + "xpack.ml.dataframe.analytics.exploration.indexArrayToolTipContent": "この配列ベースの列の完全なコンテンツは表示できません。", + "xpack.ml.dataframe.analytics.exploration.indexError": "インデックスデータの読み込み中にエラーが発生しました。", + "xpack.ml.dataframe.analytics.exploration.indexObjectBadgeContent": "オブジェクト", + "xpack.ml.dataframe.analytics.exploration.indexObjectToolTipContent": "このオブジェクトベースの列の完全なコンテンツは表示できません。", + "xpack.ml.dataframe.analytics.exploration.jobIdTitle": "ジョブID {jobId}", + "xpack.ml.dataframe.analytics.exploration.noDataCalloutBody": "インデックスのクエリが結果を返しませんでした。インデックスにドキュメントが含まれていて、クエリ要件が妥当であることを確認してください。", + "xpack.ml.dataframe.analytics.exploration.selectColumnsAriaLabel": "列を選択", + "xpack.ml.dataframe.analytics.exploration.selectFieldsPopoverTitle": "フィールドを選択", + "xpack.ml.dataframe.analytics.exploration.title": "分析の探索", + "xpack.ml.dataframe.analytics.regressionExploration.evaluateError": "データの読み込み中にエラーが発生しました。", + "xpack.ml.dataframe.analytics.regressionExploration.generalError": "データの読み込み中にエラーが発生しました。", + "xpack.ml.dataframe.analytics.regressionExploration.generalizationErrorTitle": "一般化エラー", + "xpack.ml.dataframe.analytics.regressionExploration.meanSquaredErrorText": "平均二乗エラー", + "xpack.ml.dataframe.analytics.regressionExploration.noDataCalloutBody": "インデックスのクエリが結果を返しませんでした。ジョブが完了済みで、インデックスにドキュメントがあることを確認してください。", + "xpack.ml.dataframe.analytics.regressionExploration.noDataCalloutTitle": "空のインデックスクエリ結果。", + "xpack.ml.dataframe.analytics.regressionExploration.noIndexCalloutBody": "インデックスのクエリが結果を返しませんでした。デスティネーションインデックスが存在し、ドキュメントがあることを確認してください。", + "xpack.ml.dataframe.analytics.regressionExploration.rSquaredText": "R の二乗", + "xpack.ml.dataframe.analytics.regressionExploration.trainingErrorTitle": "トレーニングエラー", + "xpack.ml.dataframe.analyticsList.completeBatchAnalyticsToolTip": "{analyticsId}は完了済みの分析ジョブで、再度開始できません。", + "xpack.ml.dataframe.analyticsList.createDataFrameAnalyticsButton": "分析ジョブの作成", + "xpack.ml.dataframe.analyticsList.deleteActionDisabledToolTipContent": "削除するにはデータフレーム分析を停止してください。", + "xpack.ml.dataframe.analyticsList.deleteActionName": "削除", + "xpack.ml.dataframe.analyticsList.deleteAnalyticsErrorMessage": "データフレーム分析{analyticsId}の削除中にエラーが発生しました。{error}", + "xpack.ml.dataframe.analyticsList.deleteAnalyticsSuccessMessage": "データフレーム分析 {analyticsId} の削除リクエストが受け付けられました。", + "xpack.ml.dataframe.analyticsList.deleteModalBody": "この分析ジョブを削除してよろしいですか?この分析ジョブのデスティネーションインデックスとオプションのKibanaインデックスパターンは削除されません。", + "xpack.ml.dataframe.analyticsList.deleteModalCancelButton": "キャンセル", + "xpack.ml.dataframe.analyticsList.deleteModalDeleteButton": "削除", + "xpack.ml.dataframe.analyticsList.deleteModalTitle": "{analyticsId}の削除", + "xpack.ml.dataframe.analyticsList.destinationIndex": "デスティネーションインデックス", + "xpack.ml.dataFrame.analyticsList.emptyPromptButtonText": "最初のデータフレーム分析ジョブを作成", + "xpack.ml.dataFrame.analyticsList.emptyPromptTitle": "データフレーム分析ジョブが見つかりませんでした", + "xpack.ml.dataFrame.analyticsList.errorPromptTitle": "データフレーム分析リストの取得中にエラーが発生しました。", + "xpack.ml.dataframe.analyticsList.expandedRow.tabs.jobSettings.progress": "進捗", + "xpack.ml.dataframe.analyticsList.expandedRow.tabs.jobSettings.state": "ステータス", + "xpack.ml.dataframe.analyticsList.expandedRow.tabs.jobSettings.stats": "統計", + "xpack.ml.dataframe.analyticsList.expandedRow.tabs.jobSettingsLabel": "ジョブの詳細", + "xpack.ml.dataframe.analyticsList.experimentalBadgeLabel": "実験的", + "xpack.ml.dataframe.analyticsList.experimentalBadgeTooltipContent": "データフレーム分析は実験段階の機能です。フィードバックをお待ちしています。", + "xpack.ml.dataframe.analyticsList.progress": "進捗", + "xpack.ml.dataframe.analyticsList.refreshButtonLabel": "更新", + "xpack.ml.dataframe.analyticsList.rowCollapse": "{analyticsId}の詳細を非表示", + "xpack.ml.dataframe.analyticsList.rowExpand": "{analyticsId}の詳細を表示", + "xpack.ml.dataframe.analyticsList.sourceIndex": "ソースインデックス", + "xpack.ml.dataframe.analyticsList.startActionName": "開始", + "xpack.ml.dataframe.analyticsList.startAnalyticsErrorMessage": "データフレーム分析{analyticsId}の開始中にエラーが発生しました。{error}", + "xpack.ml.dataframe.analyticsList.startAnalyticsSuccessMessage": "データフレーム分析 {analyticsId} の開始リクエストが受け付けられました。", + "xpack.ml.dataframe.analyticsList.startModalBody": "データフレーム分析ジョブは、クラスターの検索とインデックスによる負荷を増やします。過剰な負荷が生じた場合は分析ジョブを停止してください。この分析ジョブを開始してよろしいですか?", + "xpack.ml.dataframe.analyticsList.startModalCancelButton": "キャンセル", + "xpack.ml.dataframe.analyticsList.startModalStartButton": "開始", + "xpack.ml.dataframe.analyticsList.startModalTitle": "{analyticsId}の開始", + "xpack.ml.dataframe.analyticsList.status": "ステータス", + "xpack.ml.dataframe.analyticsList.statusFilter": "ステータス", + "xpack.ml.dataframe.analyticsList.stopActionName": "停止", + "xpack.ml.dataframe.analyticsList.stopAnalyticsErrorMessage": "データフレーム分析{analyticsId}の停止中にエラーが発生しました。{error}", + "xpack.ml.dataframe.analyticsList.stopAnalyticsSuccessMessage": "データフレーム分析 {analyticsId} の停止リクエストが受け付けられました。", + "xpack.ml.dataframe.analyticsList.tableActionLabel": "アクション", + "xpack.ml.dataframe.analyticsList.title": "分析ジョブ", + "xpack.ml.dataframe.analyticsList.type": "タイプ", + "xpack.ml.dataframe.analyticsList.viewActionName": "表示", + "xpack.ml.dataframe.analyticsList.viewAriaLabel": "表示", + "xpack.ml.dataframe.stepCreateForm.createDataFrameAnalyticsSuccessMessage": "データフレーム分析 {jobId} の作成リクエストが受け付けられました。", + "xpack.ml.dataframe.stepDetailsForm.destinationIndexInvalidErrorLink": "インデックス名の制限に関する詳細。", + "xpack.ml.dataFrameAnalyticsBreadcrumbs.indexLabel": "インデックス", + "xpack.ml.datavisualizer.actionsPanel.advancedDescription": "より高度なユースケースでは、ジョブの作成にすべてのオプションを使用します", + "xpack.ml.datavisualizer.actionsPanel.advancedTitle": "高度な設定", + "xpack.ml.datavisualizer.actionsPanel.createJobDescription": "高度なジョブウィザードでジョブを作成し、このデータの異常を検出します:", + "xpack.ml.datavisualizer.actionsPanel.createJobTitle": "ジョブの作成", + "xpack.ml.datavisualizer.actionsPanel.selectKnownConfigurationDescription": "認識されたデータの既知の構成を選択します:", + "xpack.ml.datavisualizer.dataLoader.internalServerErrorMessage": "インデックス {index} のデータの読み込み中にエラーが発生。{message}。リクエストがタイムアウトした可能性があります。小さなサンプルサイズを使うか、時間範囲を狭めてみてください。", + "xpack.ml.datavisualizer.fieldsPanel.fieldsCountDescription": "ドキュメントに {wrappedCardsCount} {cardsCount, plural, one {個のフィールドが存在します} other {個のフィールドが存在します}} (合計 {wrappedTotalFieldCount} 個)", + "xpack.ml.datavisualizer.fieldsPanel.filterFieldsPlaceholder": "フィルター", + "xpack.ml.datavisualizer.fieldsPanel.searchBarError": "検索の実行中にエラーが発生。{message}。", + "xpack.ml.datavisualizer.fieldsPanel.showAllCountDescription": "{wrappedCardsCount} {cardsCount, plural, one {field} other {fields}} ({wrappedPopulatedFieldCount} {populatedFieldCount, plural, one {exists} other {exist}}ドキュメントに)", + "xpack.ml.datavisualizer.fieldsPanel.showEmptyFieldsLabel": "空のフィールドを表示", + "xpack.ml.datavisualizer.fieldTypesSelect.allFieldsTypeOptionLabel": "すべてのフィールドタイプ", + "xpack.ml.datavisualizer.fieldTypesSelect.selectAriaLabel": "表示するフィールドタイプを選択してください", + "xpack.ml.datavisualizer.fieldTypesSelect.typeOptionLabel": "{fieldType} タイプ", + "xpack.ml.dataVisualizer.fileBasedLabel": "ファイル", + "xpack.ml.datavisualizer.page.errorLoadingDataMessage": "インデックス {index} のデータの読み込み中にエラーが発生。{message}。", + "xpack.ml.datavisualizer.page.fieldsPanelTitle": "フィールド", + "xpack.ml.datavisualizer.page.metricsPanelTitle": "メトリック", + "xpack.ml.datavisualizer.searchPanel.allOptionLabel": "すべて", + "xpack.ml.datavisualizer.searchPanel.documentsPerShardLabel": "合計 {wrappedTotalCount} {totalCount, plural, one {document} other {documents}}からのシャードごとのドキュメント数", + "xpack.ml.datavisualizer.searchPanel.kqlEditOnlyLabel": "現在 KQAL で保存された検索のみ編集できます。", + "xpack.ml.datavisualizer.searchPanel.queryBarPlaceholder": "小さいサンプルサイズを選択することで、クエリの実行時間を短縮しクラスターへの負荷を軽減できます。", + "xpack.ml.datavisualizer.searchPanel.queryBarPlaceholderText": "検索… (例: status:200 AND extension:\"PHP\")", + "xpack.ml.datavisualizer.searchPanel.sampleLabel": "サンプル", + "xpack.ml.datavisualizer.searchPanel.sampleSizeAriaLabel": "サンプリングするドキュメント数を選択してください", + "xpack.ml.datavisualizer.selector.dataVisualizerDescription": "機械学習データビジュアライザーツールは、ログファイルのメトリックとフィールド、または既存の Elasticsearch インデックスを分析し、データの理解を助けます。", + "xpack.ml.datavisualizer.selector.dataVisualizerTitle": "データビジュアライザー", + "xpack.ml.datavisualizer.selector.experimentalBadgeLabel": "実験的", + "xpack.ml.datavisualizer.selector.experimentalBadgeTooltipLabel": "実験的機能。フィードバックをお待ちしています。", + "xpack.ml.datavisualizer.selector.importDataDescription": "ログファイルからデータをインポートします。最大 100 MB のファイルをアップロードできます。", + "xpack.ml.datavisualizer.selector.importDataTitle": "データのインポート", + "xpack.ml.datavisualizer.selector.selectIndexButtonLabel": "インデックスを選択", + "xpack.ml.datavisualizer.selector.selectIndexPatternDescription": "既存の Elasticsearch インデックスのデータを可視化します。", + "xpack.ml.datavisualizer.selector.selectIndexPatternTitle": "インデックスパターンの選択", + "xpack.ml.datavisualizer.selector.startTrialButtonLabel": "トライアルを開始", + "xpack.ml.datavisualizer.selector.startTrialTitle": "トライアルを開始", + "xpack.ml.datavisualizer.selector.uploadFileButtonLabel": "ファイルをアップロード", + "xpack.ml.datavisualizerBreadcrumbLabel": "データビジュアライザー", + "xpack.ml.dataVisualizerPageLabel": "データビジュアライザー", + "xpack.ml.dfAnalyticsList.analyticsDetails.messagesPane.errorMessage": "メッセージを読み込めませんでした", + "xpack.ml.explorer.annotationsTitle": "注釈", + "xpack.ml.explorer.anomaliesTitle": "異常", + "xpack.ml.explorer.anomalyTimelineTitle": "異常のタイムライン", + "xpack.ml.explorer.charts.detectorLabel": "「{fieldName}」で分割された {detectorLabel}{br} Y 軸イベントの分布", + "xpack.ml.explorer.charts.infoTooltip.aggregationIntervalTitle": "集約間隔", + "xpack.ml.explorer.charts.infoTooltip.chartEventDistributionDescription": "グレーの点は、{byFieldValuesParam} のサンプルの一定期間のオカレンスのおおよその分布を示しており、より頻繁なイベントタイプが上に、頻繁ではないものが下に表示されます。", + "xpack.ml.explorer.charts.infoTooltip.chartFunctionTitle": "チャート関数", + "xpack.ml.explorer.charts.infoTooltip.chartPopulationDistributionDescription": "グレーの点は、{overFieldValuesParam} のサンプルの一定期間の値のおおよその分布を示しています。", + "xpack.ml.explorer.charts.infoTooltip.jobIdTitle": "ジョブ ID", + "xpack.ml.explorer.charts.openInSingleMetricViewerButtonLabel": "シングルメトリックビューアーで開く", + "xpack.ml.explorer.charts.tooManyBucketsDescription": "この選択は、表示するバケット数が多すぎます。ダッシュボードは短い時間範囲で表示するのが最適です。", + "xpack.ml.explorer.charts.viewLabel": "表示", + "xpack.ml.explorer.createNewJobLinkText": "新規ジョブを作成", + "xpack.ml.explorer.distributionChart.anomalyScoreLabel": "異常スコア", + "xpack.ml.explorer.distributionChart.entityLabel": "エンティティ", + "xpack.ml.explorer.distributionChart.typicalLabel": "通常", + "xpack.ml.explorer.distributionChart.unusualByFieldValuesLabel": "{ numberOfCauses, plural, one {# 個の異常な {byFieldName} 値 } other {#{plusSign}異常な{byFieldName}値}}", + "xpack.ml.explorer.distributionChart.valueLabel": "値", + "xpack.ml.explorer.distributionChart.valueWithoutAnomalyScoreLabel": "値", + "xpack.ml.explorer.fetchingSuggestionsErrorMessage": "提案の取得中にエラーが発生しました", + "xpack.ml.explorer.intervalLabel": "間隔", + "xpack.ml.explorer.invalidKuerySyntaxErrorMessage": "無効な Kuery 構文", + "xpack.ml.explorer.invalidKuerySyntaxErrorMessageFromTable": "クエリバーに無効な構文。インプットは有効な Kibana クエリ言語 (KQL) でなければなりません", + "xpack.ml.explorer.jobIdLabel": "ジョブ ID", + "xpack.ml.explorer.jobScoreAcrossAllInfluencersLabel": "(すべての影響因子のジョブスコア)", + "xpack.ml.explorer.kueryBar.filterPlaceholder": "影響因子フィールドでフィルタリング… ({queryExample})", + "xpack.ml.explorer.limitLabel": "制限", + "xpack.ml.explorer.loadingLabel": "読み込み中", + "xpack.ml.explorer.noConfiguredInfluencersTooltip": "選択されたジョブに影響因子が構成されていないため、トップインフルエンスリストは非表示になっています。", + "xpack.ml.explorer.noJobsFoundLabel": "ジョブが見つかりません", + "xpack.ml.explorer.noResultsFoundLabel": "結果が見つかりませんでした", + "xpack.ml.explorer.overallLabel": "全体", + "xpack.ml.explorer.overallSwimlaneUnfilteredLabel": "{label} (フィルタリングなし)", + "xpack.ml.explorer.severityThresholdLabel": "深刻度のしきい値", + "xpack.ml.explorer.singleMetricChart.actualLabel": "実際", + "xpack.ml.explorer.singleMetricChart.anomalyScoreLabel": "異常スコア", + "xpack.ml.explorer.singleMetricChart.multiBucketImpactLabel": "複数バケットの影響", + "xpack.ml.explorer.singleMetricChart.scheduledEventsLabel": "予定イベント", + "xpack.ml.explorer.singleMetricChart.typicalLabel": "通常", + "xpack.ml.explorer.singleMetricChart.valueLabel": "値", + "xpack.ml.explorer.singleMetricChart.valueWithoutAnomalyScoreLabel": "値", + "xpack.ml.explorer.sortedByMaxAnomalyScoreForTimeFormattedLabel": "({viewByLoadedForTimeFormatted} の最高異常スコアで分類)", + "xpack.ml.explorer.sortedByMaxAnomalyScoreLabel": "(最高異常スコアで分類)", + "xpack.ml.explorer.swimlane.maxAnomalyScoreLabel": "最高異常スコア", + "xpack.ml.explorer.topInfuencersTitle": "トップ影響因子", + "xpack.ml.explorer.tryWideningTimeSelectionLabel": "時間範囲を広げるか、さらに過去に遡ってみてください", + "xpack.ml.explorer.viewByLabel": "表示方式", + "xpack.ml.feature.reserved.description": "ユーザーアクセスを許可するには、machine_learning_user か machine_learning_admin ロールのどちらかを割り当てる必要があります。", + "xpack.ml.featureRegistry.mlFeatureName": "機械学習", + "xpack.ml.fieldDataCard.cardBoolean.documentsCountDescription": "{count, plural, zero {# document} one {# document} other {# documents}} ({docsPercent}%)", + "xpack.ml.fieldDataCard.cardBoolean.valuesLabel": "値", + "xpack.ml.fieldDataCard.cardDate.documentsCountDescription": "{count, plural, zero {# document} one {# document} other {# documents}} ({docsPercent}%)", + "xpack.ml.fieldDataCard.cardDate.earliestDescription": "最も古い {earliestFormatted}", + "xpack.ml.fieldDataCard.cardDate.latestDescription": "最近の {latestFormatted}", + "xpack.ml.fieldDataCard.cardDocumentCount.calculatedOverAllDocumentsLabel": "全ドキュメントで計算", + "xpack.ml.fieldDataCard.cardGeoPoint.distinctCountDescription": "{cardinality} 個の特徴的な {cardinality, plural, zero {value} one {value} other {values}}", + "xpack.ml.fieldDataCard.cardGeoPoint.documentsCountDescription": "{count, plural, zero {# document} one {# document} other {# documents}} ({docsPercent}%)", + "xpack.ml.fieldDataCard.cardIp.distinctCountDescription": "{cardinality} 個の特徴的な {cardinality, plural, zero {value} one {value} other {values}}", + "xpack.ml.fieldDataCard.cardIp.documentsCountDescription": "{count, plural, zero {# document} one {# document} other {# documents}} ({docsPercent}%)", + "xpack.ml.fieldDataCard.cardIp.topValuesLabel": "トップの値", + "xpack.ml.fieldDataCard.cardKeyword.distinctCountDescription": "{cardinality} 個の特徴的な {cardinality, plural, zero {value} one {value} other {values}}", + "xpack.ml.fieldDataCard.cardKeyword.documentsCountDescription": "{count, plural, zero {# document} one {# document} other {# documents}} ({docsPercent}%)", + "xpack.ml.fieldDataCard.cardKeyword.topValuesLabel": "トップの値", + "xpack.ml.fieldDataCard.cardNumber.details.distributionOfValuesLabel": "値の分布", + "xpack.ml.fieldDataCard.cardNumber.details.topValuesLabel": "トップの値", + "xpack.ml.fieldDataCard.cardNumber.displayingPercentilesLabel": "{minPercent} - {maxPercent} パーセンタイルを表示中", + "xpack.ml.fieldDataCard.cardNumber.distinctCountDescription": "{cardinality} 個の特徴的な {cardinality, plural, zero {value} one {value} other {values}}", + "xpack.ml.fieldDataCard.cardNumber.documentsCountDescription": "{count, plural, zero {# document} one {# document} other {# documents}} ({docsPercent}%)", + "xpack.ml.fieldDataCard.cardNumber.maxLabel": "最高", + "xpack.ml.fieldDataCard.cardNumber.medianLabel": "中間", + "xpack.ml.fieldDataCard.cardNumber.minLabel": "最低", + "xpack.ml.fieldDataCard.cardNumber.selectMetricDetailsDisplayAriaLabel": "メトリック詳細の表示オプションを選択してください", + "xpack.ml.fieldDataCard.cardOther.cardTypeLabel": "{cardType} タイプ", + "xpack.ml.fieldDataCard.cardOther.distinctCountDescription": "{cardinality} 個の特徴的な {cardinality, plural, zero {value} one {value} other {values}}", + "xpack.ml.fieldDataCard.cardOther.documentsCountDescription": "{count, plural, zero {# document} one {# document} other {# documents}} ({docsPercent}%)", + "xpack.ml.fieldDataCard.cardText.examplesTitle": "{numExamples, plural, one {値} other {例}}", + "xpack.ml.fieldDataCard.cardText.fieldMayBePopulatedDescription": "たとえば、ドキュメントマッピングで {copyToParam} パラメーターを使ったり、{includesParam} と {excludesParam} パラメーターを使用してインデックスした後に {sourceParam} フィールドから切り取ったりして入力される場合があります。", + "xpack.ml.fieldDataCard.cardText.fieldNotPresentDescription": "このフィールドはクエリが実行されたドキュメントの {sourceParam} フィールドにありませんでした。", + "xpack.ml.fieldDataCard.cardText.noExamplesForFieldsTitle": "このフィールドの例が取得されませんでした", + "xpack.ml.fieldDataCard.documentCountChart.seriesLabel": "ドキュメントカウント", + "xpack.ml.fieldDataCard.fieldNotInDocsLabel": "このフィールドは選択された時間範囲のドキュメントにありません", + "xpack.ml.fieldDataCard.loadingLabel": "読み込み中", + "xpack.ml.fieldDataCard.metricDistributionChart.seriesName": "分布", + "xpack.ml.fieldDataCard.metricDistributionChart.tooltipValueBetweenLabel": "{percent}% のドキュメントに {minValFormatted} から {maxValFormatted} の間の値があります", + "xpack.ml.fieldDataCard.metricDistributionChart.tooltipValueEqualLabel": "{percent}% のドキュメントに {valFormatted} の値があります", + "xpack.ml.fieldDataCard.topValues.calculatedFromSampleDescription": "1 つのシャードにつき {topValuesSamplerShardSize} のドキュメントのサンプルで計算されています", + "xpack.ml.fieldTitleBar.documentCountLabel": "ドキュメントカウント", + "xpack.ml.fieldTypeIcon.booleanTypeAriaLabel": "ブールタイプ", + "xpack.ml.fieldTypeIcon.dateTypeAriaLabel": "日付タイプ", + "xpack.ml.fieldTypeIcon.fieldTypeTooltip": "{type} タイプ", + "xpack.ml.fieldTypeIcon.geoPointTypeAriaLabel": "{geoPointParam} タイプ", + "xpack.ml.fieldTypeIcon.ipTypeAriaLabel": "IP タイプ", + "xpack.ml.fieldTypeIcon.keywordTypeAriaLabel": "キーワードタイプ", + "xpack.ml.fieldTypeIcon.numberTypeAriaLabel": "数字タイプ", + "xpack.ml.fieldTypeIcon.textTypeAriaLabel": "テキストタイプ", + "xpack.ml.fieldTypeIcon.unknownTypeAriaLabel": "不明なタイプ", + "xpack.ml.fileDatavisualizer.aboutPanel.analyzingDataTitle": "データを分析中", + "xpack.ml.fileDatavisualizer.aboutPanel.selectOrDragAndDropFileDescription": "ファイルを選択するかドラッグ & ドロップしてください", + "xpack.ml.fileDatavisualizer.advancedImportSettings.createIndexPatternLabel": "インデックスパターンを作成", + "xpack.ml.fileDatavisualizer.advancedImportSettings.indexNameAriaLabel": "インデックス名、必須フィールド", + "xpack.ml.fileDatavisualizer.advancedImportSettings.indexNameLabel": "インデックス名", + "xpack.ml.fileDatavisualizer.advancedImportSettings.indexNamePlaceholder": "インデックス名", + "xpack.ml.fileDatavisualizer.advancedImportSettings.indexPatternNameLabel": "インデックスパターン名", + "xpack.ml.fileDatavisualizer.advancedImportSettings.indexSettingsLabel": "インデックス設定", + "xpack.ml.fileDatavisualizer.advancedImportSettings.ingestPipelineLabel": "パイプラインを投入", + "xpack.ml.fileDatavisualizer.advancedImportSettings.mappingsLabel": "マッピング", + "xpack.ml.fileDatavisualizer.analysisSummary.analyzedLinesNumberTitle": "分析した行数", + "xpack.ml.fileDatavisualizer.analysisSummary.delimiterTitle": "区切り記号", + "xpack.ml.fileDatavisualizer.analysisSummary.formatTitle": "フォーマット", + "xpack.ml.fileDatavisualizer.analysisSummary.grokPatternTitle": "Grok パターン", + "xpack.ml.fileDatavisualizer.analysisSummary.hasHeaderRowTitle": "ヘッダー行があります", + "xpack.ml.fileDatavisualizer.analysisSummary.summaryTitle": "概要", + "xpack.ml.fileDatavisualizer.analysisSummary.timeFieldTitle": "時間フィールド", + "xpack.ml.fileDatavisualizer.analysisSummary.timeFormatTitle": "時間 {timestampFormats, plural, zero {format} one {format} other {formats}}", + "xpack.ml.fileDatavisualizer.bottomBar.backButtonLabel": "戻る", + "xpack.ml.fileDatavisualizer.bottomBar.cancelButtonLabel": "キャンセル", + "xpack.ml.fileDatavisualizer.bottomBar.readMode.cancelButtonLabel": "キャンセル", + "xpack.ml.fileDatavisualizer.bottomBar.readMode.importButtonLabel": "インポート", + "xpack.ml.fileDatavisualizer.editFlyout.applyOverrideSettingsButtonLabel": "適用", + "xpack.ml.fileDatavisualizer.editFlyout.closeOverrideSettingsButtonLabel": "閉じる", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.customDelimiterFormRowLabel": "カスタム区切り記号", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.customTimestampFormatErrorMessage": "タイムスタンプのフォーマットは、これらの Java 日付/時刻フォーマットの組み合わせでなければなりません:\n yy, yyyy, M, MM, MMM, MMMM, d, dd, EEE, EEEE, H, HH, h, mm, ss, S through SSSSSSSSS, a, XX, XXX, zzz", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.customTimestampFormatFormRowLabel": "カスタムタイムスタンプフォーマット", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.dataFormatFormRowLabel": "データフォーマット", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.delimiterFormRowLabel": "区切り記号", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.editFieldNamesTitle": "フィールド名の編集", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.grokPatternFormRowLabel": "Grok パターン", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.hasHeaderRowLabel": "ヘッダー行があります", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.linesToSampleErrorMessage": "値は {min} よりも大きく {max} 以下でなければなりません", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.linesToSampleFormRowLabel": "サンプルする行数", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.quoteCharacterFormRowLabel": "引用符", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.timeFieldFormRowLabel": "時間フィールド", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampEmptyValidationErrorMessage": "タイムスタンプフォーマットにタイムフォーマット文字グループがありません {timestampFormat}", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampFormatFormRowLabel": "タイムスタンプフォーマット", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampFormatHelpText": "対応フォーマットの詳細をご覧ください", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampLetterSValidationErrorMessage": "{format} の文字 { length, plural, one { {lg} } other { グループ {lg} } } は、ss と {sep} からの区切りで始まっていないため、サポートされていません", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampLetterValidationErrorMessage": "{format} の文字 { length, plural, one { {lg} } other { グループ {lg} } } はサポートされていません", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampQuestionMarkValidationErrorMessage": "タイムスタンプフォーマット {timestampFormat} は、疑問符 ({fieldPlaceholder}) が含まれているためサポートされていません", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.trimFieldsLabel": "フィールドを切り抜く", + "xpack.ml.fileDatavisualizer.editFlyout.overrideSettingsTitle": "上書き設定", + "xpack.ml.fileDatavisualizer.experimentalBadge.experimentalLabel": "実験的", + "xpack.ml.fileDatavisualizer.fieldStatsCard.distinctCountDescription": "{fieldCardinality} 個の特徴的な {fieldCardinality, plural, zero {value} one {value} other {values}}", + "xpack.ml.fileDatavisualizer.fieldStatsCard.documentsCountDescription": "{fieldCount, plural, zero {# document} one {# document} other {# documents}} ({fieldPercent}%)", + "xpack.ml.fileDatavisualizer.fieldStatsCard.maxTitle": "最高", + "xpack.ml.fileDatavisualizer.fieldStatsCard.medianTitle": "中間", + "xpack.ml.fileDatavisualizer.fieldStatsCard.minTitle": "最低", + "xpack.ml.fileDatavisualizer.fieldStatsCard.noFieldInformationAvailableDescription": "フィールド情報がありません", + "xpack.ml.fileDatavisualizer.fieldStatsCard.topStatsValuesDescription": "トップの値", + "xpack.ml.fileDatavisualizer.fileContents.fileContentsTitle": "ファイルコンテンツ", + "xpack.ml.fileDatavisualizer.fileContents.firstLinesDescription": "初めの {numberOfLines, plural, zero {# 行} 1 {# 行} other {# 行}}", + "xpack.ml.fileDatavisualizer.fileDatavisualizerView.xmlNotCurrentlySupportedErrorMessage": "XML は現在サポートされていません", + "xpack.ml.fileDatavisualizer.fileErrorCallouts.fileCouldNotBeReadTitle": "ファイルを読み込めませんでした", + "xpack.ml.fileDatavisualizer.fileErrorCallouts.fileSizeExceedsAllowedSizeByDiffFormatErrorMessage": "アップロードするよう選択されたファイルのサイズが {diffFormatted} に許可された最大サイズの {maxFileSizeFormatted} を超えています", + "xpack.ml.fileDatavisualizer.fileErrorCallouts.fileSizeExceedsAllowedSizeErrorMessage": "アップロードするよう選択されたファイルのサイズは {fileSizeFormatted} で、許可された最大サイズの {maxFileSizeFormatted} を超えています。", + "xpack.ml.fileDatavisualizer.fileErrorCallouts.fileSizeTooLargeTitle": "ファイルサイズが大きすぎます。", + "xpack.ml.fileDatavisualizer.fileErrorCallouts.revertingToPreviousSettingsDescription": "以前の設定に戻しています。", + "xpack.ml.fileDatavisualizer.importErrors.checkingPermissionErrorMessage": "パーミッションエラーをインポートします", + "xpack.ml.fileDatavisualizer.importErrors.creatingIndexErrorMessage": "インデックスの作成中にエラーが発生しました", + "xpack.ml.fileDatavisualizer.importErrors.creatingIndexPatternErrorMessage": "インデックスパターンの作成中にエラーが発生しました", + "xpack.ml.fileDatavisualizer.importErrors.creatingIngestPipelineErrorMessage": "投入パイプラインの作成中にエラーが発生しました", + "xpack.ml.fileDatavisualizer.importErrors.defaultErrorMessage": "エラー", + "xpack.ml.fileDatavisualizer.importErrors.moreButtonLabel": "もっと", + "xpack.ml.fileDatavisualizer.importErrors.parsingJSONErrorMessage": "JSON のパース中にエラーが発生しました", + "xpack.ml.fileDatavisualizer.importErrors.readingFileErrorMessage": "ファイルの読み込み中にエラーが発生しました", + "xpack.ml.fileDatavisualizer.importErrors.unknownErrorMessage": "不明なエラー", + "xpack.ml.fileDatavisualizer.importErrors.uploadingDataErrorMessage": "データのアップロード中にエラーが発生しました", + "xpack.ml.fileDatavisualizer.importProgress.createIndexPatternTitle": "インデックスパターンの作成", + "xpack.ml.fileDatavisualizer.importProgress.createIndexTitle": "インデックスの作成", + "xpack.ml.fileDatavisualizer.importProgress.createIngestPipelineTitle": "投入パイプラインの作成", + "xpack.ml.fileDatavisualizer.importProgress.creatingIndexPatternDescription": "インデックスパターンを作成中です", + "xpack.ml.fileDatavisualizer.importProgress.creatingIndexPatternTitle": "インデックスパターンを作成中", + "xpack.ml.fileDatavisualizer.importProgress.creatingIndexTitle": "インデックスを作成中", + "xpack.ml.fileDatavisualizer.importProgress.creatingIngestPipelineTitle": "投入パイプラインを作成中", + "xpack.ml.fileDatavisualizer.importProgress.dataUploadedTitle": "データがアップロードされました", + "xpack.ml.fileDatavisualizer.importProgress.fileProcessedTitle": "ファイルが処理されました", + "xpack.ml.fileDatavisualizer.importProgress.indexCreatedTitle": "インデックスが作成されました", + "xpack.ml.fileDatavisualizer.importProgress.indexPatternCreatedTitle": "インデックスパターンが作成されました", + "xpack.ml.fileDatavisualizer.importProgress.ingestPipelineCreatedTitle": "投入パイプラインが作成されました", + "xpack.ml.fileDatavisualizer.importProgress.processFileTitle": "ファイルの処理", + "xpack.ml.fileDatavisualizer.importProgress.processingFileTitle": "ファイルを処理中", + "xpack.ml.fileDatavisualizer.importProgress.processingImportedFileDescription": "インポートするファイルを処理中", + "xpack.ml.fileDatavisualizer.importProgress.stepTwoCreatingIndexDescription": "インデックスを作成中です", + "xpack.ml.fileDatavisualizer.importProgress.stepTwoCreatingIndexIngestPipelineDescription": "インデックスと投入パイプラインを作成中です", + "xpack.ml.fileDatavisualizer.importProgress.uploadDataTitle": "データのアップロード", + "xpack.ml.fileDatavisualizer.importProgress.uploadingDataDescription": "データをアップロード中です", + "xpack.ml.fileDatavisualizer.importProgress.uploadingDataTitle": "データをアップロード中", + "xpack.ml.fileDatavisualizer.importSettings.advancedTabName": "高度な設定", + "xpack.ml.fileDatavisualizer.importSettings.simpleTabName": "シンプル", + "xpack.ml.fileDatavisualizer.importSummary.documentsCouldNotBeImportedDescription": "{docCount} 件中 {importFailuresLength} 件のドキュメントをインポートできません。行が Grok パターンと一致していないことが原因の可能性があります。", + "xpack.ml.fileDatavisualizer.importSummary.documentsCouldNotBeImportedTitle": "ドキュメントの一部をインポートできませんでした。", + "xpack.ml.fileDatavisualizer.importSummary.documentsIngestedTitle": "ドキュメントが投入されました", + "xpack.ml.fileDatavisualizer.importSummary.failedDocumentsButtonLabel": "失敗したドキュメント", + "xpack.ml.fileDatavisualizer.importSummary.failedDocumentsTitle": "失敗したドキュメント", + "xpack.ml.fileDatavisualizer.importSummary.importCompleteTitle": "インポート完了", + "xpack.ml.fileDatavisualizer.importSummary.indexPatternTitle": "インデックスパターン", + "xpack.ml.fileDatavisualizer.importSummary.indexTitle": "インデックス", + "xpack.ml.fileDatavisualizer.importSummary.ingestPipelineTitle": "パイプラインを投入", + "xpack.ml.fileDatavisualizer.importView.experimentalFeatureTooltip": "実験的機能。フィードバックをお待ちしています。", + "xpack.ml.fileDatavisualizer.importView.importButtonLabel": "インポート", + "xpack.ml.fileDatavisualizer.importView.importDataTitle": "データのインポート", + "xpack.ml.fileDatavisualizer.importView.importPermissionError": "インデックス {index} にデータを作成またはインポートするパーミッションがありません。", + "xpack.ml.fileDatavisualizer.importView.indexNameAlreadyExistsErrorMessage": "インデックス名が既に存在します", + "xpack.ml.fileDatavisualizer.importView.indexNameContainsIllegalCharactersErrorMessage": "インデックス名に許可されていない文字が含まれています", + "xpack.ml.fileDatavisualizer.importView.indexPatternDoesNotMatchIndexNameErrorMessage": "インデックスパターンがインデックス名と一致しません", + "xpack.ml.fileDatavisualizer.importView.indexPatternNameAlreadyExistsErrorMessage": "インデックスパターン名が既に存在します", + "xpack.ml.fileDatavisualizer.importView.noIdOrIndexSuppliedErrorMessage": "ID またはインデックスが提供されていません", + "xpack.ml.fileDatavisualizer.importView.parseMappingsError": "マッピングのパース中にエラーが発生しました:", + "xpack.ml.fileDatavisualizer.importView.parsePipelineError": "投入パイプラインのパース中にエラーが発生しました:", + "xpack.ml.fileDatavisualizer.importView.parseSettingsError": "設定のパース中にエラーが発生しました:", + "xpack.ml.fileDatavisualizer.importView.resetButtonLabel": "リセット", + "xpack.ml.fileDatavisualizer.resultsLinks.createNewMLJobTitle": "新規 ML ジョブの作成", + "xpack.ml.fileDatavisualizer.resultsLinks.indexManagementTitle": "インデックス管理", + "xpack.ml.fileDatavisualizer.resultsLinks.indexPatternManagementTitle": "インデックスパターン管理", + "xpack.ml.fileDatavisualizer.resultsLinks.openInDataVisualizerTitle": "データビジュアライザーを開く", + "xpack.ml.fileDatavisualizer.resultsLinks.viewIndexInDiscoverTitle": "インデックスをディスカバリで表示", + "xpack.ml.fileDatavisualizer.resultsView.fileStatsTabName": "ファイル統計", + "xpack.ml.fileDatavisualizer.resultsView.overrideSettingsButtonLabel": "上書き設定", + "xpack.ml.fileDatavisualizer.simpleImportSettings.createIndexPatternLabel": "インデックスパターンを作成", + "xpack.ml.fileDatavisualizer.simpleImportSettings.indexNameAriaLabel": "インデックス名、必須フィールド", + "xpack.ml.fileDatavisualizer.simpleImportSettings.indexNameFormRowLabel": "インデックス名", + "xpack.ml.fileDatavisualizer.simpleImportSettings.indexNamePlaceholder": "インデックス名", + "xpack.ml.fileDatavisualizer.welcomeContent.delimitedTextFilesDescription": "CSV や TSV などの区切られたテキストファイル", + "xpack.ml.fileDatavisualizer.welcomeContent.experimentalFeatureDescription": "これは実験的な機能です。フィードバックがありますか?{githubLink} で問題を報告してください。", + "xpack.ml.fileDatavisualizer.welcomeContent.experimentalFeatureTooltip": "実験的機能。フィードバックをお待ちしています。", + "xpack.ml.fileDatavisualizer.welcomeContent.logFilesWithCommonFormatDescription": "タイムスタンプの一般的フォーマットのログファイル", + "xpack.ml.fileDatavisualizer.welcomeContent.newlineDelimitedJsonDescription": "改行区切りの JSON", + "xpack.ml.fileDatavisualizer.welcomeContent.supportedFileFormatDescription": "ファイルデータビジュアライザーはこれらのファイル形式をサポートしています:", + "xpack.ml.fileDatavisualizer.welcomeContent.uploadedFilesAllowedSizeDescription": "最大 100 MB のファイルをアップロードできます。", + "xpack.ml.fileDatavisualizer.welcomeContent.visualizeDataFromLogFileDescription": "ファイルデータビジュアライザーは、ログファイルのフィールドとメトリックの理解に役立ちます。ファイルをアップロードして、データを分析し、 Elasticsearch インデックスにインポートするか選択できます。", + "xpack.ml.fileDatavisualizer.welcomeContent.visualizeDataFromLogFileTitle": "ログファイルのデータを可視化 {experimentalBadge}", + "xpack.ml.formatters.metricChangeDescription.actualSameAsTypicalDescription": "実際値が通常値と同じ", + "xpack.ml.formatters.metricChangeDescription.moreThan100xHigherDescription": "100x よりも高い", + "xpack.ml.formatters.metricChangeDescription.moreThan100xLowerDescription": "100x よりも低い", + "xpack.ml.formatters.metricChangeDescription.moreThanOneAndFiveHundredthsxHigherDescription": "{factor}x 高い", + "xpack.ml.formatters.metricChangeDescription.moreThanOneAndFiveHundredthsxLowerDescription": "{factor}x 低い", + "xpack.ml.formatters.metricChangeDescription.moreThanOneAndHalfxHigherDescription": "{factor}x 高い", + "xpack.ml.formatters.metricChangeDescription.moreThanOneAndHalfxLowerDescription": "{factor}x 低い", + "xpack.ml.formatters.metricChangeDescription.unexpectedNonZeroValueDescription": "予期せぬ 0 以外の値", + "xpack.ml.formatters.metricChangeDescription.unexpectedZeroValueDescription": "予期せぬ 0 の値", + "xpack.ml.formatters.metricChangeDescription.unusuallyHighDescription": "異常に高い", + "xpack.ml.formatters.metricChangeDescription.unusuallyLowDescription": "異常に低い", + "xpack.ml.formatters.metricChangeDescription.unusualValuesDescription": "異常な値", + "xpack.ml.fullTimeRangeSelector.errorSettingTimeRangeNotification": "時間範囲の設定中にエラーが発生しました。", + "xpack.ml.fullTimeRangeSelector.useFullDataButtonLabel": "完全な {indexPatternTitle} データを使用", + "xpack.ml.indexPatternNotBasedOnTimeSeriesNotificationDescription": "異常検知は時間ベースのインデックスでのみ実行されます", + "xpack.ml.indexPatternNotBasedOnTimeSeriesNotificationTitle": "インデックスパターン {indexPatternTitle} は時系列に基づくものではありません", + "xpack.ml.influencersList.maxAnomalyScoreTooltipDescription": "最高異常スコア: {maxScoreLabel}", + "xpack.ml.influencersList.noInfluencersFoundTitle": "影響因子が見つかりません", + "xpack.ml.influencersList.totalAnomalyScoreTooltipDescription": "合計異常スコア: {totalScoreLabel}", + "xpack.ml.itemsGrid.itemsCountLabel": "{pageSize} 個の項目", + "xpack.ml.itemsGrid.itemsPerPageButtonLabel": "ページごとの項目数: {itemsPerPage}", + "xpack.ml.itemsGrid.noItemsAddedTitle": "項目が追加されていません", + "xpack.ml.itemsGrid.noMatchingItemsTitle": "一致する項目が見つかりません。", + "xpack.ml.jobsBreadcrumbs.advancedConfigurationLabel": "高度な構成", + "xpack.ml.jobsBreadcrumbs.createJobLabel": "ジョブを作成", + "xpack.ml.jobsBreadcrumbs.multiMetricLabel": "マルチメトリック", + "xpack.ml.jobsBreadcrumbs.populationLabel": "集団", + "xpack.ml.jobsBreadcrumbs.selectIndexOrSearchLabel": "インデックスまたは検索を選択", + "xpack.ml.jobsBreadcrumbs.singleMetricLabel": "シングルメトリック", + "xpack.ml.jobSelect.noJobsSelectedWarningMessage": "ジョブが選択されていません。初めのジョブを自動選択します", + "xpack.ml.jobSelect.requestedJobsDoesNotExistWarningMessage": "リクエストされました\n{invalidIdsLength, plural, one {job {invalidIds} does not exist} other {jobs {invalidIds} do not exist}}", + "xpack.ml.jobSelectList.groupTimeRangeLabel": "{fromString} ~ {toString}", + "xpack.ml.jobSelector.applyFlyoutButton": "適用", + "xpack.ml.jobSelector.applyTimerangeSwitchLabel": "時間範囲を適用", + "xpack.ml.jobSelector.clearAllFlyoutButton": "すべて消去", + "xpack.ml.jobSelector.closeFlyoutButton": "閉じる", + "xpack.ml.jobSelector.customTable.searchBarPlaceholder": "検索…", + "xpack.ml.jobSelector.customTable.selectAllCheckboxLabel": "すべて選択", + "xpack.ml.jobSelector.filterBar.groupLabel": "グループ", + "xpack.ml.jobSelector.filterBar.invalidSearchErrorMessage": "無効な検索: {errorMessage}", + "xpack.ml.jobSelector.filterBar.jobGroupTitle": "({jobsCount, plural, one {# ジョブ} other {# 件のジョブ}})", + "xpack.ml.jobSelector.flyoutTitle": "ジョブの選択", + "xpack.ml.jobSelector.groupsTab": "グループ", + "xpack.ml.jobSelector.hideBarBadges": "を非表示", + "xpack.ml.jobSelector.hideFlyoutBadges": "を非表示", + "xpack.ml.jobSelector.jobFetchErrorMessage": "ジョブの取得中にエラーが発生しました。更新して再試行してください。", + "xpack.ml.jobSelector.jobSelectionButton": "他のジョブを選択", + "xpack.ml.jobSelector.jobsTab": "ジョブ", + "xpack.ml.jobSelector.jobTimeRangeLabel": "{fromString} ~ {toString}", + "xpack.ml.jobSelector.noResultsForJobLabel": "成果がありません", + "xpack.ml.jobSelector.selectedGroupJobs": "({jobsCount, plural, one {# ジョブ} other {# 件のジョブ}})", + "xpack.ml.jobSelector.showBarBadges": "その他 {overFlow} 件", + "xpack.ml.jobSelector.showFlyoutBadges": "その他 {overFlow} 件", + "xpack.ml.jobService.activeDatafeedsLabel": "アクティブなデータフィード", + "xpack.ml.jobService.activeMLNodesLabel": "アクティブな ML ノード", + "xpack.ml.jobService.closedJobsLabel": "ジョブを作成", + "xpack.ml.jobService.couldNotStartDatafeedErrorMessage": "{jobId} のデータフィードを開始できませんでした", + "xpack.ml.jobService.couldNotStopDatafeedErrorMessage": "{jobId} のデータフィードを停止できませんでした", + "xpack.ml.jobService.couldNotUpdateDatafeedErrorMessage": "データフィードを更新できませんでした: {datafeedId}", + "xpack.ml.jobService.couldNotUpdateJobErrorMessage": "ジョブを更新できませんでした: {jobId}", + "xpack.ml.jobService.datafeedsListCouldNotBeRetrievedErrorMessage": "データフィードリストを取得できませんでした", + "xpack.ml.jobService.failedJobsLabel": "失敗したジョブ", + "xpack.ml.jobService.jobsListCouldNotBeRetrievedErrorMessage": "ジョブリストを取得できませんでした", + "xpack.ml.jobService.jobValidationErrorMessage": "ジョブ検証エラー: {errorMessage}", + "xpack.ml.jobService.openJobsLabel": "ジョブを開く", + "xpack.ml.jobService.requestMayHaveTimedOutErrorMessage": "リクエストがタイムアウトし、まだバックグラウンドで実行中の可能性があります。", + "xpack.ml.jobService.totalJobsLabel": "合計ジョブ数", + "xpack.ml.jobsList.actionExecuteSuccessfullyNotificationMessage": "{successesJobsCount, plural, one{{successJob}} other{# 件のジョブ}} {actionTextPT}成功", + "xpack.ml.jobsList.actionFailedNotificationMessage": "{failureId} が {actionText} に失敗しました", + "xpack.ml.jobsList.actionsLabel": "アクション", + "xpack.ml.jobsList.analyticsSpacesLabel": "Space", + "xpack.ml.jobsList.breadcrumb": "ジョブ", + "xpack.ml.jobsList.cannotSelectRowForJobMessage": "ジョブID {jobId}を選択できません", + "xpack.ml.jobsList.cloneJobErrorMessage": "{jobId} のクローンを作成できませんでした。ジョブが見つかりませんでした", + "xpack.ml.jobsList.closeActionStatusText": "閉じる", + "xpack.ml.jobsList.closedActionStatusText": "クローズ済み", + "xpack.ml.jobsList.closeJobErrorMessage": "ジョブをクローズできませんでした", + "xpack.ml.jobsList.collapseJobDetailsAriaLabel": "{itemId} の詳細を非表示", + "xpack.ml.jobsList.createNewJobButtonLabel": "新規ジョブを作成", + "xpack.ml.jobsList.createWatchFlyout.closeButtonLabel": "閉じる", + "xpack.ml.jobsList.createWatchFlyout.editWatchButtonLabel": "ウォッチを編集", + "xpack.ml.jobsList.createWatchFlyout.pageTitle": "{jobId} のウォッチを作成", + "xpack.ml.jobsList.createWatchFlyout.saveButtonLabel": "保存", + "xpack.ml.jobsList.createWatchFlyout.watchCreatedSuccessfullyNotificationMessage": "ウォッチ {id} が作成されました", + "xpack.ml.jobsList.createWatchFlyout.watchNotSavedErrorNotificationMessage": "ウォッチを保存できませんでした", + "xpack.ml.jobsList.datafeedStateLabel": "データフィード状態", + "xpack.ml.jobsList.deleteActionStatusText": "削除", + "xpack.ml.jobsList.deletedActionStatusText": "削除されました", + "xpack.ml.jobsList.deleteJobErrorMessage": "ジョブの削除に失敗しました", + "xpack.ml.jobsList.deleteJobModal.cancelButtonLabel": "キャンセル", + "xpack.ml.jobsList.deleteJobModal.closeButtonLabel": "閉じる", + "xpack.ml.jobsList.deleteJobModal.deleteButtonLabel": "削除", + "xpack.ml.jobsList.deleteJobModal.deleteJobsDescription": "{jobsCount, plural, one {このジョブ} other {これらのジョブ}}を削除してよろしいですか?", + "xpack.ml.jobsList.deleteJobModal.deleteJobsTitle": "{jobsCount, plural, one {{jobId}} other {# 件のジョブ}}を削除", + "xpack.ml.jobsList.deleteJobModal.deleteMultipleJobsDescription": "{jobsCount, plural, one {ジョブ} other {複数ジョブ}}の削除には時間がかかる場合があります。{jobsCount, plural, one {} other {}}バックグラウンドで削除され、ジョブリストからすぐに消えない場合があります", + "xpack.ml.jobsList.deleteJobModal.deletingJobsStatusLabel": "ジョブを削除中", + "xpack.ml.jobsList.descriptionLabel": "説明", + "xpack.ml.jobsList.editJobFlyout.changesNotSavedNotificationMessage": "{jobId} への変更を保存できませんでした", + "xpack.ml.jobsList.editJobFlyout.changesSavedNotificationMessage": "{jobId} への変更が保存されました", + "xpack.ml.jobsList.editJobFlyout.closeButtonLabel": "閉じる", + "xpack.ml.jobsList.editJobFlyout.customUrls.addButtonLabel": "追加", + "xpack.ml.jobsList.editJobFlyout.customUrls.addCustomUrlButtonLabel": "カスタム URL を追加", + "xpack.ml.jobsList.editJobFlyout.customUrls.addNewUrlErrorNotificationMessage": "提供された設定から新規カスタム URL を作成中にエラーが発生しました", + "xpack.ml.jobsList.editJobFlyout.customUrls.buildUrlErrorNotificationMessage": "提供された設定からテスト用のカスタム URL を作成中にエラーが発生しました", + "xpack.ml.jobsList.editJobFlyout.customUrls.closeEditorAriaLabel": "カスタム URL エディターを閉じる", + "xpack.ml.jobsList.editJobFlyout.customUrls.getTestUrlErrorNotificationMessage": "構成をテストするための URL の取得中にエラーが発生しました", + "xpack.ml.jobsList.editJobFlyout.customUrls.loadIndexPatternsErrorNotificationMessage": "保存されたインデックスパターンのリストの読み込み中にエラーが発生しました", + "xpack.ml.jobsList.editJobFlyout.customUrls.loadSavedDashboardsErrorNotificationMessage": "保存された Kibana ダッシュボードのリストの読み込み中にエラーが発生しました", + "xpack.ml.jobsList.editJobFlyout.customUrls.testButtonLabel": "テスト", + "xpack.ml.jobsList.editJobFlyout.customUrlsTitle": "カスタム URL", + "xpack.ml.jobsList.editJobFlyout.datafeed.frequencyLabel": "頻度", + "xpack.ml.jobsList.editJobFlyout.datafeed.queryDelayLabel": "クエリの遅延", + "xpack.ml.jobsList.editJobFlyout.datafeed.queryLabel": "クエリ", + "xpack.ml.jobsList.editJobFlyout.datafeed.scrollSizeLabel": "スクロールサイズ", + "xpack.ml.jobsList.editJobFlyout.datafeedTitle": "データフィード", + "xpack.ml.jobsList.editJobFlyout.detectorsTitle": "検知器", + "xpack.ml.jobsList.editJobFlyout.groupsAndJobsHasSameIdErrorMessage": "この ID のジョブが既に存在します。グループとジョブは同じ ID を共有できません。", + "xpack.ml.jobsList.editJobFlyout.jobDetails.jobDescriptionLabel": "ジョブの説明", + "xpack.ml.jobsList.editJobFlyout.jobDetails.jobGroupsLabel": "ジョブグループ", + "xpack.ml.jobsList.editJobFlyout.jobDetails.jobGroupsPlaceholder": "ジョブを選択または作成", + "xpack.ml.jobsList.editJobFlyout.jobDetails.modelMemoryLimitLabel": "モデルメモリー制限", + "xpack.ml.jobsList.editJobFlyout.jobDetailsTitle": "ジョブの詳細", + "xpack.ml.jobsList.editJobFlyout.leaveAnywayButtonLabel": "それでも移動", + "xpack.ml.jobsList.editJobFlyout.pageTitle": "{jobId} の編集", + "xpack.ml.jobsList.editJobFlyout.saveButtonLabel": "保存", + "xpack.ml.jobsList.editJobFlyout.saveChangesButtonLabel": "変更を保存", + "xpack.ml.jobsList.editJobFlyout.unsavedChangesDialogMessage": "保存しないと、変更が失われます。", + "xpack.ml.jobsList.editJobFlyout.unsavedChangesDialogTitle": "閉じる前に変更を保存しますか?", + "xpack.ml.jobsList.expandJobDetailsAriaLabel": "{itemId} の詳細を表示", + "xpack.ml.jobsList.idLabel": "ID", + "xpack.ml.jobsList.jobDetails.analysisConfigTitle": "分析の構成", + "xpack.ml.jobsList.jobDetails.analysisLimitsTitle": "分析制限", + "xpack.ml.jobsList.jobDetails.calendarsTitle": "カレンダー", + "xpack.ml.jobsList.jobDetails.countsTitle": "カウント", + "xpack.ml.jobsList.jobDetails.customUrlsTitle": "カスタム URL", + "xpack.ml.jobsList.jobDetails.dataDescriptionTitle": "データの説明", + "xpack.ml.jobsList.jobDetails.datafeedTimingStatsTitle": "タイミング統計", + "xpack.ml.jobsList.jobDetails.datafeedTitle": "データフィード", + "xpack.ml.jobsList.jobDetails.detectorsTitle": "検知器", + "xpack.ml.jobsList.jobDetails.forecastsTable.createdLabel": "作成済み", + "xpack.ml.jobsList.jobDetails.forecastsTable.expiresLabel": "有効期限", + "xpack.ml.jobsList.jobDetails.forecastsTable.fromLabel": "開始:", + "xpack.ml.jobsList.jobDetails.forecastsTable.loadingErrorMessage": "このジョブに実行された予測のリストの読み込み中にエラーが発生しました", + "xpack.ml.jobsList.jobDetails.forecastsTable.memorySizeLabel": "メモリーサイズ", + "xpack.ml.jobsList.jobDetails.forecastsTable.messagesLabel": "メッセージ", + "xpack.ml.jobsList.jobDetails.forecastsTable.msTimeUnitLabel": "{ms} ms", + "xpack.ml.jobsList.jobDetails.forecastsTable.noForecastsDescription": "予測を実行するには、{singleMetricViewerLink} を開きます", + "xpack.ml.jobsList.jobDetails.forecastsTable.noForecastsDescription.linkText": "シングルメトリックビューアー", + "xpack.ml.jobsList.jobDetails.forecastsTable.noForecastsTitle": "このジョブには予測が実行されていません", + "xpack.ml.jobsList.jobDetails.forecastsTable.processingTimeLabel": "処理時間", + "xpack.ml.jobsList.jobDetails.forecastsTable.statusLabel": "ステータス", + "xpack.ml.jobsList.jobDetails.forecastsTable.toLabel": "To", + "xpack.ml.jobsList.jobDetails.forecastsTable.viewAriaLabel": "{createdDate} に作成された予測を表示", + "xpack.ml.jobsList.jobDetails.forecastsTable.viewLabel": "表示", + "xpack.ml.jobsList.jobDetails.generalTitle": "一般", + "xpack.ml.jobsList.jobDetails.influencersTitle": "影響", + "xpack.ml.jobsList.jobDetails.modelSizeStatsTitle": "モデルサイズ統計", + "xpack.ml.jobsList.jobDetails.nodeTitle": "ノード", + "xpack.ml.jobsList.jobDetails.noPermissionToViewDatafeedPreviewTitle": "データフィードのプレビューを表示するパーミッションがありません", + "xpack.ml.jobsList.jobDetails.pleaseContactYourAdministratorLabel": "管理者にお問い合わせください", + "xpack.ml.jobsList.jobDetails.tabs.annotationsLabel": "注釈", + "xpack.ml.jobsList.jobDetails.tabs.countsLabel": "カウント", + "xpack.ml.jobsList.jobDetails.tabs.datafeedLabel": "データフィード", + "xpack.ml.jobsList.jobDetails.tabs.datafeedPreviewLabel": "データフィードのプレビュー", + "xpack.ml.jobsList.jobDetails.tabs.forecastsLabel": "予測", + "xpack.ml.jobsList.jobDetails.tabs.jobConfigLabel": "ジョブ構成", + "xpack.ml.jobsList.jobDetails.tabs.jobMessagesLabel": "ジョブメッセージ", + "xpack.ml.jobsList.jobDetails.tabs.jobSettingsLabel": "ジョブ設定", + "xpack.ml.jobsList.jobDetails.tabs.jsonLabel": "JSON", + "xpack.ml.jobsList.jobFilterBar.closedLabel": "クローズ済み", + "xpack.ml.jobsList.jobFilterBar.failedLabel": "失敗", + "xpack.ml.jobsList.jobFilterBar.groupLabel": "グループ", + "xpack.ml.jobsList.jobFilterBar.invalidSearchErrorMessage": "無効な検索: {errorMessage}", + "xpack.ml.jobsList.jobFilterBar.jobGroupTitle": "({jobsCount, plural, one {# ジョブ} other {# 件のジョブ}})", + "xpack.ml.jobsList.jobFilterBar.openedLabel": "オープン", + "xpack.ml.jobsList.jobFilterBar.startedLabel": "開始済み", + "xpack.ml.jobsList.jobFilterBar.stoppedLabel": "停止中", + "xpack.ml.jobsList.jobStateLabel": "ジョブ状態", + "xpack.ml.jobsList.latestTimestampLabel": "最新タイムスタンプ", + "xpack.ml.jobsList.loadingJobsLabel": "ジョブを読み込み中…", + "xpack.ml.jobsList.managementActions.cloneJobDescription": "ジョブのクローンを作成します", + "xpack.ml.jobsList.managementActions.cloneJobLabel": "ジョブのクローンを作成", + "xpack.ml.jobsList.managementActions.closeJobDescription": "ジョブを閉じます", + "xpack.ml.jobsList.managementActions.closeJobLabel": "ジョブを閉じる", + "xpack.ml.jobsList.managementActions.deleteJobDescription": "ジョブを削除します", + "xpack.ml.jobsList.managementActions.deleteJobLabel": "ジョブを削除", + "xpack.ml.jobsList.managementActions.editJobDescription": "ジョブを編集します", + "xpack.ml.jobsList.managementActions.editJobLabel": "ジョブを編集", + "xpack.ml.jobsList.managementActions.startDatafeedDescription": "データフィードを開始します", + "xpack.ml.jobsList.managementActions.startDatafeedLabel": "データフィードを開始", + "xpack.ml.jobsList.managementActions.stopDatafeedDescription": "データフィードを停止します", + "xpack.ml.jobsList.managementActions.stopDatafeedLabel": "データフィードを停止", + "xpack.ml.jobsList.memoryStatusLabel": "メモリー状態", + "xpack.ml.jobsList.multiJobActions.groupSelector.addButtonAriaLabel": "追加", + "xpack.ml.jobsList.multiJobActions.groupSelector.addNewGroupPlaceholder": "新規グループを追加", + "xpack.ml.jobsList.multiJobActions.groupSelector.applyButtonLabel": "適用", + "xpack.ml.jobsList.multiJobActions.groupSelector.applyGroupsToJobTitle": "{jobsCount, plural, one {ジョブ} other {件のジョブ}}にグループを適用", + "xpack.ml.jobsList.multiJobActions.groupSelector.editJobGroupsButtonAriaLabel": "ジョブグループを編集", + "xpack.ml.jobsList.multiJobActions.groupSelector.editJobGroupsButtonTooltip": "ジョブグループを編集します", + "xpack.ml.jobsList.multiJobActions.groupSelector.groupsAndJobsCanNotUseSameIdErrorMessage": "この ID のジョブが既に存在します。グループとジョブは同じ ID を共有できません。", + "xpack.ml.jobsList.multiJobActionsMenu.managementActionsAriaLabel": "管理アクション", + "xpack.ml.jobsList.multiJobsActions.closeJobsLabel": "{jobsCount, plural, one {ジョブ} other {件のジョブ}}を閉じる", + "xpack.ml.jobsList.multiJobsActions.deleteJobsLabel": "{jobsCount, plural, one {ジョブ} other {件のジョブ}}を削除", + "xpack.ml.jobsList.multiJobsActions.jobsSelectedLabel": "{selectedJobsCount, plural, one {# 件のジョブ} other {# 件のジョブ}} を選択済み", + "xpack.ml.jobsList.multiJobsActions.startDatafeedsLabel": "{jobsCount, plural, one {データフィード} other {データフィード}}を開始", + "xpack.ml.jobsList.multiJobsActions.stopDatafeedsLabel": "{jobsCount, plural, one {データフィード} other {データフィード}}を停止", + "xpack.ml.jobsList.nodeAvailableWarning.linkToCloud.hereLinkText": "こちら", + "xpack.ml.jobsList.nodeAvailableWarning.linkToCloudDescription": "{link}を編集してください1GBの空き機械学習ノードを有効にするか、既存のML構成を拡張することができます。", + "xpack.ml.jobsList.nodeAvailableWarning.noMLNodesAvailableDescription": "利用可能な ML ノードがありません。", + "xpack.ml.jobsList.nodeAvailableWarning.noMLNodesAvailableTitle": "利用可能な ML ノードがありません", + "xpack.ml.jobsList.nodeAvailableWarning.unavailableCreateOrRunJobsDescription": "ジョブの作成または実行はできません。", + "xpack.ml.jobsList.noJobsFoundLabel": "ジョブが見つかりません", + "xpack.ml.jobsList.processedRecordsLabel": "処理済みレコード", + "xpack.ml.jobsList.refreshButtonLabel": "更新", + "xpack.ml.jobsList.resultActions.openJobsInAnomalyExplorerText": "{jobsCount, plural, one {{jobId}} other {# 件のジョブ}} を異常エクスプローラーで開く", + "xpack.ml.jobsList.resultActions.openJobsInSingleMetricViewerText": "シングルメトリックビューアーで {jobsCount, plural, one {{jobId}} other {# 件のジョブ}} を開く", + "xpack.ml.jobsList.selectRowForJobMessage": "ジョブID {jobId}の行を選択", + "xpack.ml.jobsList.spacesLabel": "Space", + "xpack.ml.jobsList.startActionStatusText": "開始", + "xpack.ml.jobsList.startDatafeedModal.cancelButtonLabel": "キャンセル", + "xpack.ml.jobsList.startDatafeedModal.continueFromNowLabel": "今から続行", + "xpack.ml.jobsList.startDatafeedModal.continueFromSpecifiedTimeLabel": "特定の時刻から続行", + "xpack.ml.jobsList.startDatafeedModal.continueFromStartTimeLabel": "{formattedStartTime} から続行", + "xpack.ml.jobsList.startDatafeedModal.createWatchDescription": "データフィードの開始後ウォッチを作成します", + "xpack.ml.jobsList.startDatafeedModal.noEndTimeLabel": "終了時刻が指定されていません (リアルタイム検索)", + "xpack.ml.jobsList.startDatafeedModal.searchEndTimeTitle": "検索終了時刻", + "xpack.ml.jobsList.startDatafeedModal.searchStartTimeTitle": "検索開始時刻", + "xpack.ml.jobsList.startDatafeedModal.specifyEndTimeLabel": "終了時刻を指定", + "xpack.ml.jobsList.startDatafeedModal.specifyStartTimeLabel": "開始時刻を指定", + "xpack.ml.jobsList.startDatafeedModal.startAtBeginningOfDataLabel": "データの初めから開始", + "xpack.ml.jobsList.startDatafeedModal.startButtonLabel": "開始", + "xpack.ml.jobsList.startDatafeedModal.startFromNowLabel": "今から開始", + "xpack.ml.jobsList.startDatafeedModal.startJobsTitle": "{jobsCount, plural, one {{jobId}} other {# 件のジョブ}}を開始", + "xpack.ml.jobsList.startedActionStatusText": "開始済み", + "xpack.ml.jobsList.startJobErrorMessage": "ジョブの開始に失敗しました", + "xpack.ml.jobsList.statsBar.activeDatafeedsLabel": "アクティブなデータフィード", + "xpack.ml.jobsList.statsBar.activeMLNodesLabel": "アクティブな ML ノード", + "xpack.ml.jobsList.statsBar.closedJobsLabel": "ジョブを作成", + "xpack.ml.jobsList.statsBar.failedJobsLabel": "失敗したジョブ", + "xpack.ml.jobsList.statsBar.openJobsLabel": "ジョブを開く", + "xpack.ml.jobsList.statsBar.totalJobsLabel": "合計ジョブ数", + "xpack.ml.jobsList.stopActionStatusText": "停止", + "xpack.ml.jobsList.stopJobErrorMessage": "ジョブの停止に失敗しました", + "xpack.ml.jobsList.stoppedActionStatusText": "停止中", + "xpack.ml.machineLearningBreadcrumbLabel": "機械学習", + "xpack.ml.machineLearningDescription": "時系列データから通常の動作を自動的に学習し、異常を検知します。", + "xpack.ml.machineLearningTitle": "機械学習", + "xpack.ml.management.jobsList.accessDeniedTitle": "アクセスが拒否されました", + "xpack.ml.management.jobsList.analyticsDocsLabel": "分析ジョブドキュメント", + "xpack.ml.management.jobsList.analyticsTab": "分析", + "xpack.ml.management.jobsList.anomalyDetectionDocsLabel": "異常検知ジョブドキュメント", + "xpack.ml.management.jobsList.anomalyDetectionTab": "異常検知", + "xpack.ml.management.jobsList.jobsListTagline": "機械学習分析と異常検知ジョブを表示。", + "xpack.ml.management.jobsList.jobsListTitle": "機械学習ジョブ", + "xpack.ml.management.jobsList.noGrantedPrivilegesDescription": "ML ジョブを管理するパーミッションがありません", + "xpack.ml.management.jobsList.noPermissionToAccessLabel": "ML ジョブへのアクセスにはパーミッションが必要です", + "xpack.ml.management.jobsListTitle": "ジョブリスト", + "xpack.ml.management.mlTitle": "機械学習", + "xpack.ml.messagebarService.errorTitle": "エラーが発生しました", + "xpack.ml.mlNavDescription": "Elastic Stack 用の機械学習", + "xpack.ml.mlNavTitle": "機械学習", + "xpack.ml.models.jobService.allOtherRequestsCancelledDescription": " 他のすべてのリクエストはキャンセルされました。", + "xpack.ml.models.jobService.deletingJob": "削除中", + "xpack.ml.models.jobService.jobHasNoDatafeedErrorMessage": "ジョブにデータフィードがありません", + "xpack.ml.models.jobService.requestToActionTimedOutErrorMessage": "「{id}」を{action}するリクエストがタイムアウトしました。{extra}", + "xpack.ml.models.jobValidation.analysisConfigIsNotObjectErrorMessage": "無効な {invalidParamName}:オブジェクトでなければなりません。", + "xpack.ml.models.jobValidation.detectorsAreNotArrayErrorMessage": "無効な {invalidParamName}:配列でなければなりません。", + "xpack.ml.models.jobValidation.jobIsNotObjectErrorMessage": "無効な {invalidParamName}:オブジェクトでなければなりません。", + "xpack.ml.models.jobValidation.messages.bucketSpanEmptyMessage": "バケットスパンフィールドを指定する必要があります。", + "xpack.ml.models.jobValidation.messages.bucketSpanEstimationMismatchHeading": "バケットスパン", + "xpack.ml.models.jobValidation.messages.bucketSpanEstimationMismatchMessage": "現在のバケットスパンは {currentBucketSpan} ですが、バケットスパンの予測からは {estimateBucketSpan} が返されました。", + "xpack.ml.models.jobValidation.messages.bucketSpanHighHeading": "バケットスパン", + "xpack.ml.models.jobValidation.messages.bucketSpanHighMessage": "バケットスパンは 1 日かそれ以上です。日数は現地日数ではなく UTC での日数が適用されるのでご注意ください。", + "xpack.ml.models.jobValidation.messages.bucketSpanInvalidHeading": "バケットスパン", + "xpack.ml.models.jobValidation.messages.bucketSpanInvalidMessage": "指定されたバケットスパンは有効な間隔のフォーマット (例: 10m、1h) ではありません。また、0 よりも大きい数字である必要があります。", + "xpack.ml.models.jobValidation.messages.bucketSpanValidHeading": "バケットスパン", + "xpack.ml.models.jobValidation.messages.bucketSpanValidMessage": "{bucketSpan} のフォーマットは有効です。", + "xpack.ml.models.jobValidation.messages.cardinalityByFieldMessage": "{fieldName} の基数が 1000 を超えているため、メモリーの使用量が大きくなる可能性があります。", + "xpack.ml.models.jobValidation.messages.cardinalityModelPlotHighMessage": "モデルプロットの作成に関連したフィールドの予測基数 {modelPlotCardinality} は、ジョブが大量のリソースを消費する原因となる可能性があります。", + "xpack.ml.models.jobValidation.messages.cardinalityOverFieldHighMessage": "{fieldName} の基数が 1000000 を超えているため、メモリーの使用量が大きくなる可能性があります。", + "xpack.ml.models.jobValidation.messages.cardinalityOverFieldLowMessage": "{fieldName} の基数が 10 未満のため、人口分析に不適切な可能性があります。", + "xpack.ml.models.jobValidation.messages.cardinalityPartitionFieldMessage": "{fieldName} の基数が 1000 を超えているため、メモリーの使用量が大きくなる可能性があります。", + "xpack.ml.models.jobValidation.messages.categorizationFiltersInvalidMessage": "カテゴリー分けフィルターの構成が無効です。フィルターが有効な正規表現で {categorizationFieldName} が設定されていることを確認してください。", + "xpack.ml.models.jobValidation.messages.categorizationFiltersValidMessage": "カテゴリー分けフィルターチェックが合格しました。", + "xpack.ml.models.jobValidation.messages.detectorsDuplicatesMessage": "重複する検知器が検出されました。{functionParam}、{fieldNameParam}、{byFieldNameParam}、{overFieldNameParam}、{partitionFieldNameParam} の構成の組み合わせが同じ検知器は、同じジョブで使用できません。", + "xpack.ml.models.jobValidation.messages.detectorsEmptyMessage": "重複する検知器は検出されませんでした。検知器を少なくとも 1 つ指定する必要があります。", + "xpack.ml.models.jobValidation.messages.detectorsFunctionEmptyMessage": "検知器の関数が 1 つも入力されていません。", + "xpack.ml.models.jobValidation.messages.detectorsFunctionNotEmptyHeading": "検知器関数", + "xpack.ml.models.jobValidation.messages.detectorsFunctionNotEmptyMessage": "すべての検知器で検知器関数の存在が確認されました。", + "xpack.ml.models.jobValidation.messages.estimatedMmlGreaterThanMaxMmlMessage": "予測モデルメモリー制限が、このクラスターに構成された最大モデルメモリー制限を超えています。", + "xpack.ml.models.jobValidation.messages.estimatedMmlGreaterThanMmlMessage": "この予測モデルメモリー制限は、構成されたモデルメモリー制限を超えています。", + "xpack.ml.models.jobValidation.messages.fieldNotAggregatableMessage": "ディテクターフィールド {fieldName} が集約フィールドではありません。", + "xpack.ml.models.jobValidation.messages.fieldsNotAggregatableMessage": "検知器フィールドの 1 つがアグリゲーションフィールドではありません。", + "xpack.ml.models.jobValidation.messages.halfEstimatedMmlGreaterThanMmlMessage": "指定されたモデルメモリー制限は、予測モデルメモリー制限の半分未満で、ハードリミットに達する可能性が高いです。", + "xpack.ml.models.jobValidation.messages.indexFieldsInvalidMessage": "インデックスからフィールドを読み込めませんでした。", + "xpack.ml.models.jobValidation.messages.indexFieldsValidMessage": "データフィードにインデックスフィールドがあります。", + "xpack.ml.models.jobValidation.messages.influencerHighMessage": "ジョブの構成に 3 つを超える影響因子が含まれています。影響因子の数を減らすか、複数ジョブの作成をお勧めします。", + "xpack.ml.models.jobValidation.messages.influencerLowMessage": "影響因子が構成されていません。影響因子の構成を強くお勧めします。", + "xpack.ml.models.jobValidation.messages.influencerLowSuggestionMessage": "影響因子が構成されていません。{influencerSuggestion} を影響因子として使用することをお勧めします。", + "xpack.ml.models.jobValidation.messages.influencerLowSuggestionsMessage": "影響因子が構成されていません。{influencerSuggestion} を 1 つまたは複数使用することをお勧めします。", + "xpack.ml.models.jobValidation.messages.jobGroupIdInvalidMaxLengthErrorMessage": "ジョブグループ名は {maxLength, plural, one {# 文字} other {# 文字}} 以内でなければなりません。", + "xpack.ml.models.jobValidation.messages.jobGroupIdInvalidMessage": "ジョブグループ名の 1 つが無効です。アルファベットの小文字 (a-z と 0-9)、ハイフンまたはアンダーラインが使用でき、最初と最後を英数字にする必要があります。", + "xpack.ml.models.jobValidation.messages.jobGroupIdValidHeading": "ジョブグループ ID のフォーマットは有効です。", + "xpack.ml.models.jobValidation.messages.jobGroupIdValidMessage": "アルファベットの小文字 (a-z と 0-9)、ハイフンまたはアンダーライン、最初と最後を英数字にし、{maxLength, plural, one {# 文字} other {# 文字}}以内にする必要があります。", + "xpack.ml.models.jobValidation.messages.jobIdEmptyMessage": "ジョブ名フィールドは未入力のままにできません。", + "xpack.ml.models.jobValidation.messages.jobIdInvalidMaxLengthErrorMessage": "ジョブ ID は {maxLength, plural, one {# 文字} other {# 文字}} 以内でなければなりません。", + "xpack.ml.models.jobValidation.messages.jobIdInvalidMessage": "ジョブ ID が無効です。アルファベットの小文字 (a-z と 0-9)、ハイフンまたはアンダーラインが使用でき、最初と最後を英数字にする必要があります。", + "xpack.ml.models.jobValidation.messages.jobIdValidHeading": "ジョブ ID のフォーマットは有効です。", + "xpack.ml.models.jobValidation.messages.jobIdValidMessage": "アルファベットの小文字 (a-z と 0-9)、ハイフンまたはアンダーライン、最初と最後を英数字にし、{maxLength, plural, one {# 文字} other {# 文字}}以内にする必要があります。", + "xpack.ml.models.jobValidation.messages.mmlGreaterThanMaxMmlMessage": "モデルメモリー制限が、このクラスターに構成された最大モデルメモリー制限を超えています。", + "xpack.ml.models.jobValidation.messages.mmlValueInvalidMessage": "{mml} はモデルメモリー制限の有効な値ではありません。この値は最低 1MB で、バイト (例: 10MB) で指定する必要があります。", + "xpack.ml.models.jobValidation.messages.skippedExtendedTestsMessage": "ジョブの構成の基本要件が満たされていないため、他のチェックをスキップしました。", + "xpack.ml.models.jobValidation.messages.successBucketSpanHeading": "バケットスパン", + "xpack.ml.models.jobValidation.messages.successBucketSpanMessage": "{bucketSpan} のフォーマットは有効で、検証に合格しました。", + "xpack.ml.models.jobValidation.messages.successCardinalityHeading": "基数", + "xpack.ml.models.jobValidation.messages.successCardinalityMessage": "検知器フィールドの基数は推奨バウンド内です。", + "xpack.ml.models.jobValidation.messages.successInfluencersMessage": "影響因子の構成は検証に合格しました。", + "xpack.ml.models.jobValidation.messages.successMmlHeading": "モデルメモリー制限", + "xpack.ml.models.jobValidation.messages.successMmlMessage": "有効で予測モデルメモリー制限内です。", + "xpack.ml.models.jobValidation.messages.successTimeRangeHeading": "時間範囲", + "xpack.ml.models.jobValidation.messages.successTimeRangeMessage": "有効で、データのパターンのモデリングに十分な長さです。", + "xpack.ml.models.jobValidation.messages.timeFieldInvalidMessage": "{timeField} は「date」タイプの有効なフィールドではないため、時間フィールドとして使用できません。", + "xpack.ml.models.jobValidation.messages.timeRangeBeforeEpochHeading": "時間範囲", + "xpack.ml.models.jobValidation.messages.timeRangeBeforeEpochMessage": "選択された、または利用可能な時間範囲には、UNIX 時間の開始以前のタイムスタンプのデータが含まれています。01/01/1970 00:00:00 (UTC) よりも前のタイムスタンプは機械学習ジョブでサポートされていません。", + "xpack.ml.models.jobValidation.messages.timeRangeShortHeading": "時間範囲", + "xpack.ml.models.jobValidation.messages.timeRangeShortMessage": "選択された、または利用可能な時間範囲が短すぎます。推奨最低時間範囲は {minTimeSpanReadable} で、バケットスパンの {bucketSpanCompareFactor} 倍です。", + "xpack.ml.models.jobValidation.payloadIsNotObjectErrorMessage": "無効な {invalidParamName}:オブジェクトでなければなりません。", + "xpack.ml.models.jobValidation.unknownMessageIdErrorMessage": "{messageId} (不明なメッセージ ID)", + "xpack.ml.models.jobValidation.validateJobObject.analysisConfigIsNotObjectErrorMessage": "無効な {invalidParamName}:オブジェクトでなければなりません。", + "xpack.ml.models.jobValidation.validateJobObject.dataDescriptionIsNotObjectErrorMessage": "無効な {invalidParamName}:オブジェクトでなければなりません。", + "xpack.ml.models.jobValidation.validateJobObject.datafeedConfigIsNotObjectErrorMessage": "無効な {invalidParamName}:オブジェクトでなければなりません。", + "xpack.ml.models.jobValidation.validateJobObject.detectorsAreNotArrayErrorMessage": "無効な {invalidParamName}:配列でなければなりません。", + "xpack.ml.models.jobValidation.validateJobObject.indicesAreNotArrayErrorMessage": "無効な {invalidParamName}:配列でなければなりません。", + "xpack.ml.models.jobValidation.validateJobObject.influencersAreNotArrayErrorMessage": "無効な {invalidParamName}:配列でなければなりません。", + "xpack.ml.models.jobValidation.validateJobObject.jobIsNotObjectErrorMessage": "無効な {invalidParamName}:オブジェクトでなければなりません。", + "xpack.ml.models.jobValidation.validateJobObject.timeFieldIsNotStringErrorMessage": "無効な {invalidParamName}:文字列でなければなりません。", + "xpack.ml.navMenu.anomalyDetectionTabLinkText": "異常検知", + "xpack.ml.navMenu.anomalyExplorerTabLinkText": "異常エクスプローラー", + "xpack.ml.navMenu.dataFrameAnalyticsTabLinkText": "分析", + "xpack.ml.navMenu.dataVisualizerTabLinkText": "データビジュアライザー", + "xpack.ml.navMenu.jobManagementTabLinkText": "ジョブ管理", + "xpack.ml.navMenu.overviewTabLinkText": "概要", + "xpack.ml.navMenu.settingsTabLinkText": "設定", + "xpack.ml.navMenu.singleMetricViewerTabLinkText": "シングルメトリックビューアー", + "xpack.ml.newJi18n(ob.recognize.jobsCreationFailed.resetButtonAriaLabel": "リセット", + "xpack.ml.newJob.recognize.advancedLabel": "高度な設定", + "xpack.ml.newJob.recognize.advancedSettingsAriaLabel": "高度な設定", + "xpack.ml.newJob.recognize.alreadyExistsLabel": "(既に存在します)", + "xpack.ml.newJob.recognize.analysisRunningLabel": "分析を実行中", + "xpack.ml.newJob.recognize.createJobButtonAriaLabel": "ジョブの作成", + "xpack.ml.newJob.recognize.createJobButtonLabel": "{numberOfJobs, plural, zero {Job} one {Job} other {Jobs}} を作成", + "xpack.ml.newJob.recognize.dashboardsLabel": "ダッシュボード", + "xpack.ml.newJob.recognize.datafeed.savedAriaLabel": "保存されました", + "xpack.ml.newJob.recognize.datafeed.saveFailedAriaLabel": "保存に失敗", + "xpack.ml.newJob.recognize.datafeedLabel": "データフィード", + "xpack.ml.newJob.recognize.indexPatternPageTitle": "インデックスパターン {indexPatternTitle}", + "xpack.ml.newJob.recognize.job.savedAriaLabel": "保存されました", + "xpack.ml.newJob.recognize.job.saveFailedAriaLabel": "保存に失敗", + "xpack.ml.newJob.recognize.jobGroupAllowedCharactersDescription": "ジョブグループ名にはアルファベットの小文字 (a-z と 0-9)、ハイフンまたはアンダーラインが使用でき、最初と最後を英数字にする必要があります", + "xpack.ml.newJob.recognize.jobIdPrefixLabel": "ジョブ ID の接頭辞", + "xpack.ml.newJob.recognize.jobLabel": "ジョブ名", + "xpack.ml.newJob.recognize.jobLabelAllowedCharactersDescription": "ジョブラベルにはアルファベットの小文字 (a-z と 0-9)、ハイフンまたはアンダーラインが使用でき、最初と最後を英数字にする必要があります", + "xpack.ml.newJob.recognize.jobPrefixInvalidMaxLengthErrorMessage": "ジョブ ID 接頭辞は {maxLength, plural, one {# 文字} other {# 文字}}以内でなければなりません。", + "xpack.ml.newJob.recognize.jobsCreatedTitle": "ジョブが作成されました", + "xpack.ml.newJob.recognize.jobSettingsTitle": "ジョブ設定", + "xpack.ml.newJob.recognize.jobsTitle": "ジョブ", + "xpack.ml.newJob.recognize.moduleCheckJobsExistWarningDescription": "モジュールのジョブがクラッシュしたか確認する際にエラーが発生しました。", + "xpack.ml.newJob.recognize.moduleCheckJobsExistWarningTitle": "モジュール {moduleId} の確認中にエラーが発生", + "xpack.ml.newJob.recognize.moduleSetupFailedWarningDescription": "モジュールでの{count, plural, one { 件のジョブ} other { 件のジョブ}}の作成中にエラーが発生しました。", + "xpack.ml.newJob.recognize.moduleSetupFailedWarningTitle": "モジュール {moduleId} のセットアップ中にエラーが発生", + "xpack.ml.newJob.recognize.newJobFromTitle": "{pageTitle} からの新規ジョブ", + "xpack.ml.newJob.recognize.results.savedAriaLabel": "保存されました", + "xpack.ml.newJob.recognize.results.saveFailedAriaLabel": "保存に失敗", + "xpack.ml.newJob.recognize.running.startedAriaLabel": "開始済み", + "xpack.ml.newJob.recognize.running.startFailedAriaLabel": "開始に失敗", + "xpack.ml.newJob.recognize.runningLabel": "実行中", + "xpack.ml.newJob.recognize.savedSearchPageTitle": "保存検索 {savedSearchTitle}", + "xpack.ml.newJob.recognize.searchesLabel": "検索", + "xpack.ml.newJob.recognize.searchWillBeOverwrittenLabel": "検索は上書きされます", + "xpack.ml.newJob.recognize.someJobsCreationFailed.resetButtonLabel": "リセット", + "xpack.ml.newJob.recognize.someJobsCreationFailedTitle": "一部のジョブの作成に失敗しました", + "xpack.ml.newJob.recognize.startDatafeedAfterSaveLabel": "保存後データフィードを開始", + "xpack.ml.newJob.recognize.useDedicatedIndexLabel": "専用インデックスを使用", + "xpack.ml.newJob.recognize.useFullDataLabel": "完全な {indexPatternTitle} データを使用", + "xpack.ml.newJob.recognize.usingSavedSearchDescription": "保存検索を使用すると、データフィードで使用されるクエリが、{moduleId} モジュールでデフォルトで提供されるものと異なるものになります。", + "xpack.ml.newJob.recognize.viewResultsAriaLabel": "結果を表示", + "xpack.ml.newJob.recognize.viewResultsLinkText": "結果を表示", + "xpack.ml.newJob.recognize.visualizationsLabel": "ビジュアライゼーション", + "xpack.ml.newJob.simple.createWatchView.emailAddressPlaceholder": "メールアドレス", + "xpack.ml.newJob.simple.createWatchView.nowLabel": "今 - {selectInterval}", + "xpack.ml.newJob.simple.createWatchView.sendEmailLabel": "メールを送信", + "xpack.ml.newJob.simple.createWatchView.severityThresholdLabel": "深刻度のしきい値", + "xpack.ml.newJob.simple.createWatchView.successLabel": "成功", + "xpack.ml.newJob.simple.createWatchView.timeRangeLabel": "時間範囲", + "xpack.ml.newJob.simple.createWatchView.watchAlreadyExistsWarningMessage": "警告、ウォッチ mi-{jobId} は既に存在します。適用をクリックするとオリジナルが上書きされます。", + "xpack.ml.newJob.simple.createWatchView.watchEmailAddressAriaLabel": "ウォッチのメールアドレス", + "xpack.ml.newJob.simple.recognize.jobsCreationFailedTitle": "ジョブの作成に失敗", + "xpack.ml.newJob.simple.watcher.email.anomalyScoreLabel": "異常スコア", + "xpack.ml.newJob.simple.watcher.email.elasticStackMachineLearningAlertLabel": "Elastic Stack 機械学習アラート", + "xpack.ml.newJob.simple.watcher.email.jobLabel": "ジョブ", + "xpack.ml.newJob.simple.watcher.email.mlWatcherAlertSubjectTitle": "ML Watcher アラート", + "xpack.ml.newJob.simple.watcher.email.openInAnomalyExplorerLinkText": "異常エクスプローラーを開くにはここをクリックしてください。", + "xpack.ml.newJob.simple.watcher.email.timeLabel": "時間", + "xpack.ml.newJob.simple.watcher.email.topInfluencersLabel": "トップ影響因子:", + "xpack.ml.newJob.simple.watcher.email.topRecordsLabel": "トップの記録:", + "xpack.ml.newJob.wizard.autoSetJobCreatorTimeRange.error": "インデックスの開始時刻と終了時刻の取得中にエラーが発生しました", + "xpack.ml.newJob.wizard.datafeedPreviewFlyout.closeButton": "閉じる", + "xpack.ml.newJob.wizard.datafeedPreviewFlyout.datafeedDoesNotExistLabel": "データフィードが存在しません", + "xpack.ml.newJob.wizard.datafeedPreviewFlyout.showButton": "データフィードのプレビュー", + "xpack.ml.newJob.wizard.datafeedPreviewFlyout.title": "データフィードのプレビュー", + "xpack.ml.newJob.wizard.datafeedStep.frequency.description": "検索の間隔。", + "xpack.ml.newJob.wizard.datafeedStep.frequency.title": "頻度", + "xpack.ml.newJob.wizard.datafeedStep.query.title": "Elasticsearch クエリ", + "xpack.ml.newJob.wizard.datafeedStep.queryDelay.description": "現在の時刻と最新のインプットデータ時刻の間の秒単位での遅延です。", + "xpack.ml.newJob.wizard.datafeedStep.queryDelay.title": "クエリの遅延", + "xpack.ml.newJob.wizard.datafeedStep.scrollSize.description": "検索ごとにリクエストするドキュメントの最高数です。", + "xpack.ml.newJob.wizard.datafeedStep.scrollSize.title": "スクロールサイズ", + "xpack.ml.newJob.wizard.datafeedStep.timeField.description": "インデックスパターンのデフォルトの時間フィールドは自動的に選択されますが、上書きできます。", + "xpack.ml.newJob.wizard.datafeedStep.timeField.title": "時間フィールド", + "xpack.ml.newJob.wizard.editJsonButton": "JSON を編集", + "xpack.ml.newJob.wizard.jobDetailsStep.additionalSection.calendarsSelection.title": "カレンダー", + "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.enableModelPlot.description": "モデルバウンドのプロットに使用される他のモデル情報を格納するには選択してください。これにより、システムのパフォーマンスにオーバーヘッドが追加されるため、基数の高いデータにはお勧めしません。", + "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.enableModelPlot.title": "モデルプロットを有効にする", + "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.modelMemoryLimit.description": "分析モデルが使用するメモリー容量の上限を設定します。", + "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.modelMemoryLimit.title": "モデルメモリー制限", + "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.useDedicatedIndex.description": "選択すると、このジョブの結果が別のインデックスに格納されます。", + "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.useDedicatedIndex.title": "専用インデックスを使用", + "xpack.ml.newJob.wizard.jobDetailsStep.advancedSectionButton": "高度な設定", + "xpack.ml.newJob.wizard.jobDetailsStep.jobDescription.description": "オプションの説明テキストです", + "xpack.ml.newJob.wizard.jobDetailsStep.jobDescription.title": "ジョブの説明", + "xpack.ml.newJob.wizard.jobDetailsStep.jobGroupSelect.description": " ジョブのオプションのグループ分けです。新規グループを作成するか、既存のグループのリストから選択できます。", + "xpack.ml.newJob.wizard.jobDetailsStep.jobGroupSelect.placeholder": "ジョブを選択または作成", + "xpack.ml.newJob.wizard.jobDetailsStep.jobGroupSelect.title": "グループ", + "xpack.ml.newJob.wizard.jobDetailsStep.jobId.description": "ジョブの固有の識別子です。スペースと / ? , \" < > | * は使用できません", + "xpack.ml.newJob.wizard.jobDetailsStep.jobId.title": "ジョブ ID", + "xpack.ml.newJob.wizard.jobType.advancedAriaLabel": "高度なジョブ", + "xpack.ml.newJob.wizard.jobType.advancedDescription": "より高度なユースケースでは、ジョブの作成にすべてのオプションを使用します。", + "xpack.ml.newJob.wizard.jobType.advancedTitle": "高度な設定", + "xpack.ml.newJob.wizard.jobType.createJobFromTitle": "{pageTitleLabel} からジョブを作成", + "xpack.ml.newJob.wizard.jobType.dataVisualizerAriaLabel": "データビジュアライザー", + "xpack.ml.newJob.wizard.jobType.dataVisualizerDescription": "機械学習により、データのより詳しい特徴や、分析するフィールドを把握できます。", + "xpack.ml.newJob.wizard.jobType.dataVisualizerTitle": "データビジュアライザー", + "xpack.ml.newJob.wizard.jobType.howToRunAnomalyDetectionDescription": "異常検知は時間ベースのインデックスのみに実行できます。", + "xpack.ml.newJob.wizard.jobType.indexPatternFromSavedSearchNotTimeBasedMessage": "{savedSearchTitle} は時間ベースではないインデックスパターン {indexPatternTitle} を使用します", + "xpack.ml.newJob.wizard.jobType.indexPatternNotTimeBasedMessage": "インデックスパターン {indexPatternTitle} は時間ベースではありません", + "xpack.ml.newJob.wizard.jobType.indexPatternPageTitleLabel": "インデックスパターン {indexPatternTitle}", + "xpack.ml.newJob.wizard.jobType.learnMoreAboutDataDescription": "作成するジョブのタイプがわからない場合は、まず初めにデータのフィールドとメトリックを見てみましょう。", + "xpack.ml.newJob.wizard.jobType.learnMoreAboutDataTitle": "データに関する詳細", + "xpack.ml.newJob.wizard.jobType.multiMetricAriaLabel": "マルチメトリックジョブ", + "xpack.ml.newJob.wizard.jobType.multiMetricDescription": "カテゴリーフィールドで時系列を分割して複数メトリックの異常を検知します。", + "xpack.ml.newJob.wizard.jobType.multiMetricTitle": "マルチメトリック", + "xpack.ml.newJob.wizard.jobType.populationAriaLabel": "集団", + "xpack.ml.newJob.wizard.jobType.populationDescription": "集団の挙動に比較して普通ではないアクティビティを検知します。", + "xpack.ml.newJob.wizard.jobType.populationTitle": "集団", + "xpack.ml.newJob.wizard.jobType.savedSearchPageTitleLabel": "保存された検索 {savedSearchTitle}", + "xpack.ml.newJob.wizard.jobType.selectDifferentIndexLinkText": "別のインデックスを選択", + "xpack.ml.newJob.wizard.jobType.singleMetricAriaLabel": "シングルメトリックジョブ", + "xpack.ml.newJob.wizard.jobType.singleMetricDescription": "単独の時系列の異常を検知します。", + "xpack.ml.newJob.wizard.jobType.singleMetricTitle": "シングルメトリック", + "xpack.ml.newJob.wizard.jobType.useSuppliedConfigurationDescription": "データのフィールドが既知のカテゴリーと一致することが認識されました。選択して一連の機械学習ジョブと関連ダッシュボードを作成します。", + "xpack.ml.newJob.wizard.jobType.useSuppliedConfigurationTitle": "提供された構成を使用", + "xpack.ml.newJob.wizard.jobType.useWizardDescription": "ウィザードの 1 つを使用し、データの異常を検知する機械学習ジョブを作成します。", + "xpack.ml.newJob.wizard.jobType.useWizardTitle": "ウィザードを使用", + "xpack.ml.newJob.wizard.jsonFlyout.closeButton": "閉じる", + "xpack.ml.newJob.wizard.jsonFlyout.datafeed.title": "データフィード構成 JSON", + "xpack.ml.newJob.wizard.jsonFlyout.job.title": "ジョブ構成 JSON", + "xpack.ml.newJob.wizard.jsonFlyout.saveButton": "保存", + "xpack.ml.newJob.wizard.nextStepButton": "次へ", + "xpack.ml.newJob.wizard.pickFieldsStep.addDetectorButton": "ディテクターを追加", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorList.deleteButton": "削除", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorList.editButton": "編集", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorList.title": "検知器", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.aggSelect.description": "実行される分析機能です (例: sum、count)。", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.aggSelect.title": "関数", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.byFieldSelect.description": "エンティティ自体の過去の動作と比較し異常が検出された個々の分析に必要です。", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.byFieldSelect.title": "フィールド別", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.cancelButton": "キャンセル", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.description.description": "デフォルトのディテクターの説明で、ディテクターの分析内容を説明します。", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.description.title": "説明", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.excludeFrequent.description": "true の場合、頻繁に発生するエンティティを自動的に認識し除外し、結果の大部分を占めるのを防ぎます。", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.excludeFrequent.title": "頻繁なものを除外", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.fieldSelect.description": "関数 sum、mean、median、max、min、info_content、distinct_count に必要です。", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.fieldSelect.title": "フィールド", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.overFieldSelect.description": "集団の動きと比較して異常が検出された部分の集団分析に必要です。", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.overFieldSelect.title": "オーバーフィールド", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.partitionFieldSelect.description": "モデリングの論理グループへの分裂を可能にします。", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.partitionFieldSelect.title": "パーティションフィールド", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.saveButton": "保存", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.title": "ディテクターの作成", + "xpack.ml.newJob.wizard.pickFieldsStep.bucketSpan.description": "時系列分析の間隔を設定します。通常 15m ~ 1h です。", + "xpack.ml.newJob.wizard.pickFieldsStep.bucketSpan.placeholder": "バケットスパン", + "xpack.ml.newJob.wizard.pickFieldsStep.bucketSpan.title": "バケットスパン", + "xpack.ml.newJob.wizard.pickFieldsStep.bucketSpanEstimatorButton": "バケットスパンを推定", + "xpack.ml.newJob.wizard.pickFieldsStep.categorizationField.description": "オプション。非構造化ログデータの場合使用。テキストデータタイプの使用をお勧めします。", + "xpack.ml.newJob.wizard.pickFieldsStep.categorizationField.title": "カテゴリー分けフィールド", + "xpack.ml.newJob.wizard.pickFieldsStep.detectorTitle.placeholder": "{field} で分割された {title}", + "xpack.ml.newJob.wizard.pickFieldsStep.influencers.description": "どのカテゴリーフィールドが結果に影響を与えるか選択します。異常の原因は誰または何だと思いますか?1-3 個の影響因子をお勧めします。", + "xpack.ml.newJob.wizard.pickFieldsStep.influencers.title": "影響因子", + "xpack.ml.newJob.wizard.pickFieldsStep.multiMetricView.addMetric": "メトリックを追加", + "xpack.ml.newJob.wizard.pickFieldsStep.noDetectorsCallout.message": "ジョブを作成するには最低 1 つのディテクターが必要です。", + "xpack.ml.newJob.wizard.pickFieldsStep.noDetectorsCallout.title": "ディテクターがありません", + "xpack.ml.newJob.wizard.pickFieldsStep.populationField.description": "選択されたフィールドのすべての値が集団として一緒にモデリングされます。この分析タイプは基数の高いデータにお勧めです。", + "xpack.ml.newJob.wizard.pickFieldsStep.populationField.placeholder": "データを分割", + "xpack.ml.newJob.wizard.pickFieldsStep.populationField.title": "集団フィールド", + "xpack.ml.newJob.wizard.pickFieldsStep.populationView.addMetric": "メトリックを追加", + "xpack.ml.newJob.wizard.pickFieldsStep.populationView.splitFieldTitle": "{field} で分割された集団", + "xpack.ml.newJob.wizard.pickFieldsStep.singleMetricView.convertToMultiMetricButton": "マルチメトリックジョブに変換", + "xpack.ml.newJob.wizard.pickFieldsStep.sparseData.description": "空のバケットを異常とみなさず無視するには選択します。カウントと合計分析に利用できます。", + "xpack.ml.newJob.wizard.pickFieldsStep.sparseData.title": "まばらなデータ", + "xpack.ml.newJob.wizard.pickFieldsStep.splitCards.dataSplitBy": "{field} で分割されたデータ", + "xpack.ml.newJob.wizard.pickFieldsStep.splitField.description": "分析のパーティションに使用するフィールドを選択します。このフィールドのそれぞれの値は、個々に独立してモデリングされます。", + "xpack.ml.newJob.wizard.pickFieldsStep.splitField.title": "フィールドの分割", + "xpack.ml.newJob.wizard.pickFieldsStep.summaryCountField.description": "オプション。インプットデータが事前にまとめられている場合に使用、例: \\{docCountParam\\}。", + "xpack.ml.newJob.wizard.pickFieldsStep.summaryCountField.title": "サマリーカウントフィールド", + "xpack.ml.newJob.wizard.previewJsonButton": "JSON をプレビュー", + "xpack.ml.newJob.wizard.previousStepButton": "前へ", + "xpack.ml.newJob.wizard.searchSelection.notFoundLabel": "一致するインデックスまたは保存検索が見つかりませんでした。", + "xpack.ml.newJob.wizard.searchSelection.savedObjectType.indexPattern": "インデックスパターン", + "xpack.ml.newJob.wizard.searchSelection.savedObjectType.search": "保存検索", + "xpack.ml.newJob.wizard.selectIndexPatternOrSavedSearch": "インデックスパターンまたは保存検索を選択してください", + "xpack.ml.newJob.wizard.step.configureDatafeedTitle": "データフィードの構成", + "xpack.ml.newJob.wizard.step.jobDetailsTitle": "ジョブの詳細", + "xpack.ml.newJob.wizard.step.pickFieldsTitle": "フィールドの選択", + "xpack.ml.newJob.wizard.step.summaryTitle": "まとめ", + "xpack.ml.newJob.wizard.step.timeRangeTitle": "時間範囲", + "xpack.ml.newJob.wizard.step.validationTitle": "検証", + "xpack.ml.newJob.wizard.stepComponentWrapper.configureDatafeedTitle": "データフィードの構成", + "xpack.ml.newJob.wizard.stepComponentWrapper.jobDetailsTitle": "ジョブの詳細", + "xpack.ml.newJob.wizard.stepComponentWrapper.pickFieldsTitle": "フィールドの選択", + "xpack.ml.newJob.wizard.stepComponentWrapper.summaryTitleIndexPattern": "インデックスパターン {title} からの新規ジョブ", + "xpack.ml.newJob.wizard.stepComponentWrapper.summaryTitleSavedSearch": "保存された検索 {title} からの新規ジョブ", + "xpack.ml.newJob.wizard.stepComponentWrapper.timeRangeTitle": "時間範囲", + "xpack.ml.newJob.wizard.stepComponentWrapper.validationTitle": "検証", + "xpack.ml.newJob.wizard.summaryStep.convertToAdvancedButton": "高度なジョブに変換", + "xpack.ml.newJob.wizard.summaryStep.createJobButton": "ジョブを作成", + "xpack.ml.newJob.wizard.summaryStep.createJobError": "ジョブの作成エラー", + "xpack.ml.newJob.wizard.summaryStep.datafeedConfig.title": "データフィードの構成", + "xpack.ml.newJob.wizard.summaryStep.datafeedDetails.frequency.title": "頻度", + "xpack.ml.newJob.wizard.summaryStep.datafeedDetails.query.title": "スクロールサイズ", + "xpack.ml.newJob.wizard.summaryStep.datafeedDetails.queryDelay.title": "クエリの遅延", + "xpack.ml.newJob.wizard.summaryStep.datafeedDetails.scrollSize.title": "スクロールサイズ", + "xpack.ml.newJob.wizard.summaryStep.datafeedDetails.timeField.title": "時間フィールド", + "xpack.ml.newJob.wizard.summaryStep.defaultString": "デフォルト", + "xpack.ml.newJob.wizard.summaryStep.falseLabel": "False", + "xpack.ml.newJob.wizard.summaryStep.jobConfig.title": "ジョブの構成", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.bucketSpan.title": "バケットスパン", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.categorizationField.title": "カテゴリー分けフィールド", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.enableModelPlot.title": "モデルプロットを有効にする", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.groups.placeholder": "グループが選択されていません", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.groups.title": "グループ", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.influencers.placeholder": "影響因子が選択されていません", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.influencers.title": "影響因子", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.jobDescription.placeholder": "説明が入力されていません", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.jobDescription.title": "ジョブの説明", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.jobDetails.title": "ジョブ ID", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.modelMemoryLimit.title": "モデルメモリー制限", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.populationField.placeholder": "集団フィールドが選択されていません", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.populationField.title": "集団フィールド", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.splitField.placeholder": "分割フィールドが選択されていません", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.splitField.title": "分割フィールド", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.summaryCountField.title": "サマリーカウントフィールド", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.useDedicatedIndex.title": "専用インデックスを使用", + "xpack.ml.newJob.wizard.summaryStep.postSaveOptions.createWatch": "ウォッチを作成", + "xpack.ml.newJob.wizard.summaryStep.postSaveOptions.startJobInRealTime": "リアルタイムで実行中のジョブを開始", + "xpack.ml.newJob.wizard.summaryStep.postSaveOptions.startJobInRealTimeError": "ジョブの開始エラー", + "xpack.ml.newJob.wizard.summaryStep.postSaveOptions.startJobInRealTimeSuccess": "ジョブ {jobId} が開始しました", + "xpack.ml.newJob.wizard.summaryStep.resetJobButton": "ジョブをリセット", + "xpack.ml.newJob.wizard.summaryStep.timeRange.end.title": "終了", + "xpack.ml.newJob.wizard.summaryStep.timeRange.start.title": "開始", + "xpack.ml.newJob.wizard.summaryStep.trueLabel": "True", + "xpack.ml.newJob.wizard.summaryStep.viewResultsButton": "結果を表示", + "xpack.ml.newJob.wizard.timeRangeStep.timeRangePicker.endDateLabel": "終了日", + "xpack.ml.newJob.wizard.timeRangeStep.timeRangePicker.startDateLabel": "開始日", + "xpack.ml.newJob.wizard.validateJob.bucketSpanMustBeSetErrorMessage": "バケットスパンを設定する必要があります", + "xpack.ml.newJob.wizard.validateJob.duplicatedDetectorsErrorMessage": "重複する検知器が検出されました。", + "xpack.ml.newJob.wizard.validateJob.frequencyInvalidTimeIntervalFormatErrorMessage": "{value} は有効な時間間隔のフォーマット (例: {tenMinutes}、{oneHour}) ではありません。また、0 よりも大きい数字である必要があります。", + "xpack.ml.newJob.wizard.validateJob.groupNameAlreadyExists": "グループ ID が既に存在します。グループ ID は既存のジョブやグループと同じにできません。", + "xpack.ml.newJob.wizard.validateJob.jobGroupAllowedCharactersDescription": "ジョブグループ名にはアルファベットの小文字 (a-z と 0-9)、ハイフンまたはアンダーラインが使用でき、最初と最後を英数字にする必要があります", + "xpack.ml.newJob.wizard.validateJob.jobGroupMaxLengthDescription": "ジョブグループ名は {maxLength, plural, one {# 文字} other {# 文字}} 以内でなければなりません。", + "xpack.ml.newJob.wizard.validateJob.jobIdInvalidMaxLengthErrorMessage": "ジョブ ID は {maxLength, plural, one {# 文字} other {# 文字}} 以内でなければなりません。", + "xpack.ml.newJob.wizard.validateJob.jobNameAllowedCharactersDescription": "ジョブ名にはアルファベットの小文字 (a-z と 0-9)、ハイフンまたはアンダーラインが使用でき、最初と最後を英数字にする必要があります", + "xpack.ml.newJob.wizard.validateJob.jobNameAlreadyExists": "ジョブ ID が既に存在しますジョブ ID は既存のジョブやグループと同じにできません。", + "xpack.ml.newJob.wizard.validateJob.modelMemoryLimitRangeInvalidErrorMessage": "モデルメモリー制限は最高値の {maxModelMemoryLimit} よりも高くできません", + "xpack.ml.newJob.wizard.validateJob.modelMemoryLimitUnitsInvalidErrorMessage": "モデルメモリー制限のデータユニットが認識されません。{str} でなければなりません", + "xpack.ml.newJob.wizard.validateJob.queryCannotBeEmpty": "データフィードクエリは未入力のままにできません。", + "xpack.ml.newJob.wizard.validateJob.queryIsInvalidEsQuery": "データフィードクエリは有効な Elasticsearch クエリでなければなりません。", + "xpack.ml.overview.analyticsList.createFirstJobMessage": "初めての分析ジョブを作ってみましょう。", + "xpack.ml.overview.analyticsList.createJobButtonText": "ジョブを作成", + "xpack.ml.overview.analyticsList.emptyPromptText": "データフレーム分析は、様々なデータ分析を行い結果と共に注釈に追加することができます。分析ジョブは注釈付きデータと共に、ソースデータのコピーを新規インデックスに保存します。", + "xpack.ml.overview.analyticsList.errorPromptTitle": "データフレーム分析リストの取得中にエラーが発生しました。", + "xpack.ml.overview.analyticsList.id": "ID", + "xpack.ml.overview.analyticsList.manageJobsButtonText": "ジョブの管理", + "xpack.ml.overview.analyticsList.PanelTitle": "分析", + "xpack.ml.overview.analyticsList.reatedTimeColumnName": "作成時刻", + "xpack.ml.overview.analyticsList.refreshJobsButtonText": "更新", + "xpack.ml.overview.analyticsList.status": "ステータス", + "xpack.ml.overview.analyticsList.tableActionLabel": "アクション", + "xpack.ml.overview.analyticsList.type": "タイプ", + "xpack.ml.overview.anomalyDetection.createFirstJobMessage": "初めての異常検知ジョブを作成しましょう。", + "xpack.ml.overview.anomalyDetection.createJobButtonText": "ジョブを作成", + "xpack.ml.overview.anomalyDetection.emptyPromptText": "機械学習により、Elasticsearch に格納された時系列データの異常検知が容易になります。1 つのメトリックを 1 台のマシンから確認したり、何百ものメトリックを何千台ものマシンから確認したりできます。データに隠れた異常を自動的に検出して問題をより素早く解決しましょう。", + "xpack.ml.overview.anomalyDetection.errorPromptTitle": "異常検出ジョブリストの取得中にエラーが発生しました。", + "xpack.ml.overview.anomalyDetection.errorWithFetchingAnomalyScoreNotificationErrorMessage": "異常スコアの取得中にエラーが発生しました: {error}", + "xpack.ml.overview.anomalyDetection.exploreActionName": "探索", + "xpack.ml.overview.anomalyDetection.manageJobsButtonText": "ジョブの管理", + "xpack.ml.overview.anomalyDetection.panelTitle": "異常検知", + "xpack.ml.overview.anomalyDetection.refreshJobsButtonText": "更新", + "xpack.ml.overview.anomalyDetection.resultActions.openJobsInAnomalyExplorerText": "{jobsCount, plural, one {{jobId}} other {# 件のジョブ}} を異常エクスプローラーで開く", + "xpack.ml.overview.anomalyDetection.tableActionLabel": "アクション", + "xpack.ml.overview.anomalyDetection.tableDocsProcessed": "処理されたドキュメント", + "xpack.ml.overview.anomalyDetection.tableId": "グループ ID", + "xpack.ml.overview.anomalyDetection.tableLatestTimestamp": "最新タイムスタンプ", + "xpack.ml.overview.anomalyDetection.tableMaxScore": "最高異常スコア", + "xpack.ml.overview.anomalyDetection.tableMaxScoreErrorTooltip": "最高異常スコアの読み込み中に問題が発生しました", + "xpack.ml.overview.anomalyDetection.tableMaxScoreTooltip": "グループ内の 24 時間以内のすべてのジョブの最高スコアです", + "xpack.ml.overview.anomalyDetection.tableNumJobs": "グループのジョブ", + "xpack.ml.overview.feedbackSectionLink": "オンラインでのフィードバック", + "xpack.ml.overview.feedbackSectionText": "機械学習に関するご意見やご提案は、お気軽に {feedbackLink} にお寄せください。", + "xpack.ml.overview.feedbackSectionTitle": "フィードバック", + "xpack.ml.overview.gettingStartedSectionCreateJob": "新規ジョブを作成中", + "xpack.ml.overview.gettingStartedSectionDocs": "ドキュメンテーション", + "xpack.ml.overview.gettingStartedSectionText": "機械学習へようこそ。はじめに{docs}や{createJob}をご参照ください。Elastic Stackの機械学習の詳細については、{whatIsMachineLearning}をご覧ください。{transforms}を使用して、分析ジョブの機能インデックスを作成することをお勧めします。", + "xpack.ml.overview.gettingStartedSectionTitle": "はじめて使う", + "xpack.ml.overview.gettingStartedSectionTransforms": "Elasticsearchの変換", + "xpack.ml.overview.gettingStartedSectionWhatIsMachineLearning": "こちら", + "xpack.ml.overview.statsBar.failedAnalyticsLabel": "失敗", + "xpack.ml.overview.statsBar.runningAnalyticsLabel": "実行中", + "xpack.ml.overview.statsBar.stoppedAnalyticsLabel": "停止中", + "xpack.ml.overview.statsBar.totalAnalyticsLabel": "分析ジョブ合計", + "xpack.ml.overviewJobsList.statsBar.activeMLNodesLabel": "アクティブな ML ノード", + "xpack.ml.overviewJobsList.statsBar.closedJobsLabel": "ジョブを作成", + "xpack.ml.overviewJobsList.statsBar.failedJobsLabel": "失敗したジョブ", + "xpack.ml.overviewJobsList.statsBar.openJobsLabel": "ジョブを開く", + "xpack.ml.overviewJobsList.statsBar.totalJobsLabel": "合計ジョブ数", + "xpack.ml.privilege.licenseHasExpiredTooltip": "ご使用のライセンスは期限切れです。", + "xpack.ml.privilege.noPermission.createCalendarsTooltip": "カレンダーを作成するパーミッションがありません。", + "xpack.ml.privilege.noPermission.createMLJobsTooltip": "機械学習ジョブを作成するパーミッションがありません。", + "xpack.ml.privilege.noPermission.deleteCalendarsTooltip": "カレンダーを削除するパーミッションがありません。", + "xpack.ml.privilege.noPermission.deleteJobsTooltip": "ジョブを削除するパーミッションがありません。", + "xpack.ml.privilege.noPermission.editJobsTooltip": "ジョブを編集するパーミッションがありません。", + "xpack.ml.privilege.noPermission.runForecastsTooltip": "予測を実行するパーミッションがありません。", + "xpack.ml.privilege.noPermission.startOrStopDatafeedsTooltip": "データフィードを開始・停止するパーミッションがありません。", + "xpack.ml.privilege.pleaseContactAdministratorTooltip": "{message} 管理者にお問い合わせください。", + "xpack.ml.routes.annotations.annotationsFeatureUnavailableErrorMessage": "注釈機能に必要なインデックスとエイリアスが作成されていないか、現在のユーザーがアクセスできません。", + "xpack.ml.ruleEditor.actionsSection.chooseActionsDescription": "ルールが異常と一致した際のアクションを選択します。", + "xpack.ml.ruleEditor.actionsSection.resultWillNotBeCreatedTooltip": "結果は作成されません。", + "xpack.ml.ruleEditor.actionsSection.skipModelUpdateLabel": "モデルの更新をスキップ", + "xpack.ml.ruleEditor.actionsSection.skipResultLabel": "結果をスキップ (推奨)", + "xpack.ml.ruleEditor.actionsSection.valueWillNotBeUsedToUpdateModelTooltip": "その数列の値はモデルの更新に使用されなくなります。", + "xpack.ml.ruleEditor.actualAppliesTypeText": "実際", + "xpack.ml.ruleEditor.addValueToFilterListLinkText": "{fieldValue} を {filterId} に追加", + "xpack.ml.ruleEditor.conditionExpression.appliesToButtonLabel": "タイミング", + "xpack.ml.ruleEditor.conditionExpression.appliesToPopoverTitle": "タイミング", + "xpack.ml.ruleEditor.conditionExpression.deleteConditionButtonAriaLabel": "条件を削除", + "xpack.ml.ruleEditor.conditionExpression.operatorValueButtonLabel": "は {operator}", + "xpack.ml.ruleEditor.conditionExpression.operatorValuePopoverTitle": "が", + "xpack.ml.ruleEditor.conditionsSection.addNewConditionButtonLabel": "新規条件を追加", + "xpack.ml.ruleEditor.deleteJobRule.ruleNoLongerExistsErrorMessage": "ジョブ {jobId} の検知器インデックス {detectorIndex} のルールが現在存在しません", + "xpack.ml.ruleEditor.deleteRuleModal.cancelButtonLabel": "キャンセル", + "xpack.ml.ruleEditor.deleteRuleModal.deleteButtonLabel": "削除", + "xpack.ml.ruleEditor.deleteRuleModal.deleteRuleDescription": "このルールを削除してよろしいですか?", + "xpack.ml.ruleEditor.deleteRuleModal.deleteRuleLinkText": "ルールを削除", + "xpack.ml.ruleEditor.deleteRuleModal.deleteRuleTitle": "ルールの削除", + "xpack.ml.ruleEditor.detectorDescriptionList.detectorTitle": "検知器", + "xpack.ml.ruleEditor.detectorDescriptionList.jobIdTitle": "ジョブ ID", + "xpack.ml.ruleEditor.detectorDescriptionList.selectedAnomalyDescription": "実際値 {actual}、通常値 {typical}", + "xpack.ml.ruleEditor.detectorDescriptionList.selectedAnomalyTitle": "選択された異常", + "xpack.ml.ruleEditor.diffFromTypicalAppliesTypeText": "通常の diff", + "xpack.ml.ruleEditor.editConditionLink.enterNumericValueForConditionAriaLabel": "条件の数値を入力", + "xpack.ml.ruleEditor.editConditionLink.enterValuePlaceholder": "値を入力", + "xpack.ml.ruleEditor.editConditionLink.updateLinkText": "アップデート", + "xpack.ml.ruleEditor.editConditionLink.updateRuleConditionFromText": "ルールの条件を {conditionValue} から次の条件に更新します:", + "xpack.ml.ruleEditor.excludeFilterTypeText": "次に含まれない:", + "xpack.ml.ruleEditor.greaterThanOperatorTypeText": "より大きい", + "xpack.ml.ruleEditor.greaterThanOrEqualToOperatorTypeText": "よりも大きいまたは等しい", + "xpack.ml.ruleEditor.includeFilterTypeText": "次に含まれる:", + "xpack.ml.ruleEditor.lessThanOperatorTypeText": "より小さい", + "xpack.ml.ruleEditor.lessThanOrEqualToOperatorTypeText": "より小さいまたは等しい", + "xpack.ml.ruleEditor.ruleActionPanel.editRuleLinkText": "ルールを編集", + "xpack.ml.ruleEditor.ruleActionPanel.ruleTitle": "ルール", + "xpack.ml.ruleEditor.ruleDescription": "{conditions}{filters} の場合 {actions} をスキップ", + "xpack.ml.ruleEditor.ruleDescription.conditionsText": "{appliesTo} が {operator} {value}", + "xpack.ml.ruleEditor.ruleDescription.filtersText": "{fieldName} が {filterType} {filterId}", + "xpack.ml.ruleEditor.ruleDescription.modelUpdateActionTypeText": "モデルを更新", + "xpack.ml.ruleEditor.ruleDescription.resultActionTypeText": "結果", + "xpack.ml.ruleEditor.ruleEditorFlyout.actionTitle": "アクション", + "xpack.ml.ruleEditor.ruleEditorFlyout.addedItemToFilterListNotificationMessageDescription": "変更は新しい結果のみに適用されます。", + "xpack.ml.ruleEditor.ruleEditorFlyout.addedItemToFilterListNotificationMessageTitle": "{item} が {filterId} に追加されました", + "xpack.ml.ruleEditor.ruleEditorFlyout.changesToJobDetectorRulesSavedNotificationMessageDescription": "変更は新しい結果のみに適用されます。", + "xpack.ml.ruleEditor.ruleEditorFlyout.changesToJobDetectorRulesSavedNotificationMessageTitle": "{jobId} 検知器ルールへの変更が保存されました", + "xpack.ml.ruleEditor.ruleEditorFlyout.closeButtonLabel": "閉じる", + "xpack.ml.ruleEditor.ruleEditorFlyout.conditionsDescription": "ルールが適用される際に数値的条件を追加します。AND を使用して複数条件を組み合わせます。", + "xpack.ml.ruleEditor.ruleEditorFlyout.conditionsNotSupportedTitle": "{functionName} 関数を使用する検知器では条件がサポートされていません。", + "xpack.ml.ruleEditor.ruleEditorFlyout.conditionsTitle": "条件", + "xpack.ml.ruleEditor.ruleEditorFlyout.createRuleTitle": "ルールの作成", + "xpack.ml.ruleEditor.ruleEditorFlyout.editRulesTitle": "ルールの編集", + "xpack.ml.ruleEditor.ruleEditorFlyout.editRuleTitle": "ルールの編集", + "xpack.ml.ruleEditor.ruleEditorFlyout.errorWithAddingItemToFilterListNotificationMessage": "フィルター {filterId} に {item} を追加中にエラーが発生しました", + "xpack.ml.ruleEditor.ruleEditorFlyout.errorWithDeletingRuleFromJobDetectorNotificationMessage": "{jobId} 検知器からルールを削除中にエラーが発生しました", + "xpack.ml.ruleEditor.ruleEditorFlyout.errorWithLoadingFilterListsNotificationMesssage": "ルール範囲に使用されるフィルターリストの読み込み中にエラーが発生しました", + "xpack.ml.ruleEditor.ruleEditorFlyout.errorWithSavingChangesToJobDetectorRulesNotificationMessage": "{jobId} 検知器ルールへの変更の保存中にエラーが発生しました", + "xpack.ml.ruleEditor.ruleEditorFlyout.howToApplyChangesToExistingResultsDescription": "これらの変更を既存の結果に適用するには、ジョブのクローンを作成して再度実行する必要があります。ジョブを再度実行するには時間がかかる可能性があるため、このジョブのルールへの変更がすべて完了してから行ってください。", + "xpack.ml.ruleEditor.ruleEditorFlyout.rerunJobTitle": "ジョブを再度実行", + "xpack.ml.ruleEditor.ruleEditorFlyout.ruleDeletedFromJobDetectorNotificationMessage": "{jobId} 検知器からルールが検知されました", + "xpack.ml.ruleEditor.ruleEditorFlyout.rulesDescription": "ルールにより、異常検知器がユーザーに提供されたドメインごとの知識に基づき動作を変更するよう指示されています。ルールを作成すると、条件、範囲、アクションを指定できます。ルールの条件が満たされた時、アクションが実行されます。{learnMoreLink}", + "xpack.ml.ruleEditor.ruleEditorFlyout.rulesDescription.learnMoreLinkText": "詳細", + "xpack.ml.ruleEditor.ruleEditorFlyout.saveButtonLabel": "保存", + "xpack.ml.ruleEditor.ruleEditorFlyout.unableToConfigureRulesNotificationMesssage": "ジョブ ID {jobId} の詳細の取得中にエラーが発生したためルールを構成できませんでした", + "xpack.ml.ruleEditor.ruleEditorFlyout.whenChangesTakeEffectDescription": "ルールへの変更は新しい結果のみに適用されます。", + "xpack.ml.ruleEditor.scopeExpression.scopeFieldWhenLabel": "タイミング", + "xpack.ml.ruleEditor.scopeExpression.scopeFilterTypeButtonLabel": "は {filterType}", + "xpack.ml.ruleEditor.scopeExpression.scopeFilterTypePopoverTitle": "が", + "xpack.ml.ruleEditor.scopeSection.addFilterListLabel": "フィルターリストを追加してルールの適用範囲を制限。", + "xpack.ml.ruleEditor.scopeSection.createFilterListsDescription": "範囲を構成するには、まず初めに {filterListsLink} 設定ページでルールの対象と対象外の値のリストを作成する必要があります。", + "xpack.ml.ruleEditor.scopeSection.createFilterListsDescription.filterListsLinkText": "フィルターリスト", + "xpack.ml.ruleEditor.scopeSection.noFilterListsConfiguredTitle": "フィルターリストが構成されていません", + "xpack.ml.ruleEditor.scopeSection.noPermissionToViewFilterListsTitle": "フィルターリストを表示するパーミッションがありません", + "xpack.ml.ruleEditor.scopeSection.scopeTitle": "範囲", + "xpack.ml.ruleEditor.selectRuleAction.createRuleLinkText": "ルールを作成", + "xpack.ml.ruleEditor.selectRuleAction.orText": "または ", + "xpack.ml.ruleEditor.typicalAppliesTypeText": "通常", + "xpack.ml.sampleDataLinkLabel": "ML ジョブ", + "xpack.ml.settings.breadcrumbs.calendarManagement.createLabel": "作成", + "xpack.ml.settings.breadcrumbs.calendarManagement.editLabel": "編集", + "xpack.ml.settings.breadcrumbs.calendarManagementLabel": "カレンダー管理", + "xpack.ml.settings.breadcrumbs.filterLists.createLabel": "作成", + "xpack.ml.settings.breadcrumbs.filterLists.editLabel": "編集", + "xpack.ml.settings.breadcrumbs.filterListsLabel": "フィルターリスト", + "xpack.ml.settings.calendarManagementButtonLabel": "カレンダー管理", + "xpack.ml.settings.calendars.listHeader.calendarsDescription": "カレンダーにはシステム停止日や祝日などの予定を含むことができ、異常検知から除外します。カレンダーは複数のジョブに割り当てることができます。{br}{learnMoreLink}", + "xpack.ml.settings.calendars.listHeader.calendarsDescription.learnMoreLinkText": "詳細", + "xpack.ml.settings.calendars.listHeader.calendarsListTotalCount": "合計 {totalCount}", + "xpack.ml.settings.calendars.listHeader.calendarsTitle": "カレンダー", + "xpack.ml.settings.calendars.listHeader.refreshButtonLabel": "更新", + "xpack.ml.settings.filterLists.addItemPopover.addButtonLabel": "追加", + "xpack.ml.settings.filterLists.addItemPopover.addItemButtonLabel": "アイテムを追加", + "xpack.ml.settings.filterLists.addItemPopover.enterItemPerLineDescription": "1 行につき 1 つアイテムを追加します", + "xpack.ml.settings.filterLists.addItemPopover.itemsLabel": "アイテム", + "xpack.ml.settings.filterLists.deleteFilterListModal.cancelButtonLabel": "キャンセル", + "xpack.ml.settings.filterLists.deleteFilterListModal.confirmButtonLabel": "削除", + "xpack.ml.settings.filterLists.deleteFilterListModal.deleteButtonLabel": "削除", + "xpack.ml.settings.filterLists.deleteFilterListModal.deleteWarningMessage": "{selectedFilterListsLength, plural, one {このフィルダー} other {これらのフィルター}}を削除してよろしいですか?", + "xpack.ml.settings.filterLists.deleteFilterListModal.modalTitle": "{selectedFilterListsLength, plural, one {{selectedFilterId}} other {# フィルターリスト}}の削除", + "xpack.ml.settings.filterLists.deleteFilterLists.deletingErrorMessage": "フィルターリスト {filterListId} の削除中にエラーが発生しました。{respMessage}", + "xpack.ml.settings.filterLists.deleteFilterLists.deletingNotificationMessage": "{filterListsToDeleteLength, plural, one {{filterListToDeleteId}} other {# フィルターリスト}}を削除しています", + "xpack.ml.settings.filterLists.deleteFilterLists.filtersSuccessfullyDeletedNotificationMessage": "{filterListsToDeleteLength, plural, one {{filterListToDeleteId}} other {# フィルターリスト}} が削除されました", + "xpack.ml.settings.filterLists.editDescriptionPopover.editDescriptionAriaLabel": "説明を編集", + "xpack.ml.settings.filterLists.editDescriptionPopover.filterListDescriptionAriaLabel": "フィルターリストの説明", + "xpack.ml.settings.filterLists.editFilterHeader.allowedCharactersDescription": "アルファベットの小文字 (a-z と 0-9)、ハイフンまたはアンダーラインを使用し、最初と最後を英数字にする必要があります", + "xpack.ml.settings.filterLists.editFilterHeader.createFilterListTitle": "新規フィルターリストの作成", + "xpack.ml.settings.filterLists.editFilterHeader.filterListIdAriaLabel": "フィルターリスト ID", + "xpack.ml.settings.filterLists.editFilterHeader.filterListTitle": "フィルターリスト {filterId}", + "xpack.ml.settings.filterLists.editFilterList.acrossText": "すべてを対象にする", + "xpack.ml.settings.filterLists.editFilterList.addDescriptionText": "説明を追加", + "xpack.ml.settings.filterLists.editFilterList.cancelButtonLabel": "キャンセル", + "xpack.ml.settings.filterLists.editFilterList.duplicatedItemsInFilterListWarningMessage": "次のアイテムはフィルターリストに既に存在します: {alreadyInFilter}", + "xpack.ml.settings.filterLists.editFilterList.filterIsNotUsedInJobsDescription": "このフィルターリストはどのジョブにも使用されていません。", + "xpack.ml.settings.filterLists.editFilterList.filterIsUsedInJobsDescription": "このフィルターリストは次のジョブに使用されています:", + "xpack.ml.settings.filterLists.editFilterList.loadingDetailsOfFilterErrorMessage": "フィルター {filterId} の詳細の読み込み中にエラーが発生しました", + "xpack.ml.settings.filterLists.editFilterList.saveButtonLabel": "保存", + "xpack.ml.settings.filterLists.editFilterList.savingFilterErrorMessage": "フィルター {filterId} の保存中にエラーが発生しました", + "xpack.ml.settings.filterLists.editFilterList.totalItemsDescription": "合計{totalItemCount, plural, one {# 個のアイテム} other {# 個のアイテム}}", + "xpack.ml.settings.filterLists.filterLists.loadingFilterListsErrorMessage": "フィルターリストの読み込み中にエラーが発生しました", + "xpack.ml.settings.filterLists.filterWithIdExistsErrorMessage": "ID {filterId} のフィルターが既に存在します", + "xpack.ml.settings.filterLists.listHeader.filterListsContainsNotAllowedValuesDescription": "フィルターリストには、イベントを機械学習分析に含める、または除外するのに使用する値が含まれています。同じフィルターリストを複数ジョブに使用できます。{br}{learnMoreLink}", + "xpack.ml.settings.filterLists.listHeader.filterListsContainsNotAllowedValuesDescription.learnMoreLinkText": "詳細", + "xpack.ml.settings.filterLists.listHeader.filterListsDescription": "合計 {totalCount}", + "xpack.ml.settings.filterLists.listHeader.filterListsTitle": "フィルターリスト", + "xpack.ml.settings.filterLists.listHeader.refreshButtonLabel": "更新", + "xpack.ml.settings.filterLists.table.descriptionColumnName": "説明", + "xpack.ml.settings.filterLists.table.idColumnName": "ID", + "xpack.ml.settings.filterLists.table.inUseAriaLabel": "使用中", + "xpack.ml.settings.filterLists.table.inUseColumnName": "使用中", + "xpack.ml.settings.filterLists.table.itemCountColumnName": "アイテムカウント", + "xpack.ml.settings.filterLists.table.newButtonLabel": "新規", + "xpack.ml.settings.filterLists.table.noFiltersCreatedTitle": "フィルターが 1 つも作成されていません", + "xpack.ml.settings.filterLists.table.notInUseAriaLabel": "使用されていません", + "xpack.ml.settings.filterLists.toolbar.deleteItemButtonLabel": "アイテムを削除", + "xpack.ml.settings.filterListsButtonLabel": "フィルターリスト", + "xpack.ml.settings.jobManagementTitle": "ジョブ管理", + "xpack.ml.settingsBreadcrumbLabel": "設定", + "xpack.ml.singleMetricViewerPageLabel": "シングルメトリックビューアー", + "xpack.ml.timeSeriesExplorer.allPartitionValuesLabel": "すべて", + "xpack.ml.timeSeriesExplorer.annotationDescriptionList.createdByTitle": "作成者", + "xpack.ml.timeSeriesExplorer.annotationDescriptionList.createdTitle": "作成済み", + "xpack.ml.timeSeriesExplorer.annotationDescriptionList.endTitle": "終了", + "xpack.ml.timeSeriesExplorer.annotationDescriptionList.jobIdTitle": "ジョブ ID", + "xpack.ml.timeSeriesExplorer.annotationDescriptionList.lastModifiedTitle": "最終更新:", + "xpack.ml.timeSeriesExplorer.annotationDescriptionList.modifiedByTitle": "変更者:", + "xpack.ml.timeSeriesExplorer.annotationDescriptionList.startTitle": "開始", + "xpack.ml.timeSeriesExplorer.annotationFlyout.addAnnotationTitle": "注釈の追加", + "xpack.ml.timeSeriesExplorer.annotationFlyout.annotationTextLabel": "注釈テキスト", + "xpack.ml.timeSeriesExplorer.annotationFlyout.approachingMaxLengthWarning": "残り {charsRemaining, number} {charsRemaining, plural, one {文字} other {文字}}", + "xpack.ml.timeSeriesExplorer.annotationFlyout.cancelButtonLabel": "キャンセル", + "xpack.ml.timeSeriesExplorer.annotationFlyout.createButtonLabel": "作成", + "xpack.ml.timeSeriesExplorer.annotationFlyout.deleteButtonLabel": "削除", + "xpack.ml.timeSeriesExplorer.annotationFlyout.editAnnotationTitle": "注釈を編集します", + "xpack.ml.timeSeriesExplorer.annotationFlyout.maxLengthError": "最長 {maxChars} 文字を {charsOver, number} {charsOver, plural, one {文字} other {文字}} 超過", + "xpack.ml.timeSeriesExplorer.annotationFlyout.noAnnotationTextError": "注釈テキストを入力してください", + "xpack.ml.timeSeriesExplorer.annotationFlyout.updateButtonLabel": "更新", + "xpack.ml.timeSeriesExplorer.annotationsLabel": "注釈", + "xpack.ml.timeSeriesExplorer.annotationsTitle": "注釈", + "xpack.ml.timeSeriesExplorer.anomaliesTitle": "異常", + "xpack.ml.timeSeriesExplorer.autoSelectingFirstJobText": "、初めのジョブを自動選択します", + "xpack.ml.timeSeriesExplorer.canNotViewRequestedJobsWarningMessage": "リクエストされた‘{invalidIdsCount, plural, one {ジョブ} other {件のジョブ}} {invalidIds} をこのダッシュボードで表示できません", + "xpack.ml.timeSeriesExplorer.countDataInChartDetailsDescription": "{openBrace}{cardinalityValue} 特徴的な {fieldName} {cardinality, plural, one {} other { 値}}{closeBrace}", + "xpack.ml.timeSeriesExplorer.createNewSingleMetricJobLinkText": "新規シングルメトリックジョブを作成", + "xpack.ml.timeSeriesExplorer.dataNotChartableDescription": "選択された{entityCount, plural, one {エンティティ} other {エンティティ}}のモデルプロットは収集されていません。\nこのディテクターのソースデータはプロットできません。", + "xpack.ml.timeSeriesExplorer.deleteAnnotationModal.cancelButtonLabel": "キャンセル", + "xpack.ml.timeSeriesExplorer.deleteAnnotationModal.deleteAnnotationTitle": "この注釈を削除しますか?", + "xpack.ml.timeSeriesExplorer.deleteAnnotationModal.deleteButtonLabel": "削除", + "xpack.ml.timeSeriesExplorer.detectorLabel": "検知器", + "xpack.ml.timeSeriesExplorer.enterValuePlaceholder": "値を入力", + "xpack.ml.timeSeriesExplorer.forecastingModal.closeButtonLabel": "閉じる", + "xpack.ml.timeSeriesExplorer.forecastingModal.closingJobTitle": "ジョブをクローズ中...", + "xpack.ml.timeSeriesExplorer.forecastingModal.dataContainsMorePartitionsMessage": "このデータには {warnNumPartitions} 個以上のパーティションが含まれているため、予測の実行に時間がかかり、多くのリソースを消費する可能性があります", + "xpack.ml.timeSeriesExplorer.forecastingModal.errorWithClosingJobAfterRunningForecastErrorMessage": "予測の実行後にジョブを閉じる際にエラーが発生しました", + "xpack.ml.timeSeriesExplorer.forecastingModal.errorWithClosingJobErrorMessage": "ジョブをの取得中にエラーが発生しました", + "xpack.ml.timeSeriesExplorer.forecastingModal.errorWithLoadingStatsOfRunningForecastErrorMessage": "実行中の予測の統計の読み込み中にエラーが発生しました。", + "xpack.ml.timeSeriesExplorer.forecastingModal.errorWithObtainingListOfPreviousForecastsErrorMessage": "以前の予測のリストを取得中にエラーが発生しました", + "xpack.ml.timeSeriesExplorer.forecastingModal.errorWithOpeningJobBeforeRunningForecastErrorMessage": "予測の実行前にジョブを開く際にエラーが発生しました", + "xpack.ml.timeSeriesExplorer.forecastingModal.forecastButtonLabel": "予測", + "xpack.ml.timeSeriesExplorer.forecastingModal.forecastDurationMustNotBeGreaterThanMaximumErrorMessage": "{maximumForecastDurationDays} 日を超える予想期間は使用できません", + "xpack.ml.timeSeriesExplorer.forecastingModal.forecastDurationMustNotBeZeroErrorMessage": "予測期間は 0 にできません", + "xpack.ml.timeSeriesExplorer.forecastingModal.forecastingNotAvailableForPopulationDetectorsMessage": "オーバーフィールドでは集団検知器に予測機能を使用できません。", + "xpack.ml.timeSeriesExplorer.forecastingModal.forecastingOnlyAvailableForJobsCreatedInSpecifiedVersionMessage": "予測はバージョン{minVersion} 以降で作成されたジョブでのみ利用できます", + "xpack.ml.timeSeriesExplorer.forecastingModal.forecastingTitle": "予測を行う", + "xpack.ml.timeSeriesExplorer.forecastingModal.invalidDurationFormatErrorMessage": "無効な期間フォーマット", + "xpack.ml.timeSeriesExplorer.forecastingModal.noProgressReportedForNewForecastErrorMessage": "{WarnNoProgressMs}ms の新規予測の進捗が報告されていません。予測の実行中にエラーが発生した可能性があります。", + "xpack.ml.timeSeriesExplorer.forecastingModal.openingJobTitle": "ジョブを開いています...", + "xpack.ml.timeSeriesExplorer.forecastingModal.runningForecastTitle": "予測を実行中…", + "xpack.ml.timeSeriesExplorer.forecastingModal.unexpectedResponseFromRunningForecastErrorMessage": "予測の実行中に予期せぬ応答が返されました。リクエストに失敗した可能性があります。", + "xpack.ml.timeSeriesExplorer.forecastsList.createdColumnName": "作成済み", + "xpack.ml.timeSeriesExplorer.forecastsList.fromColumnName": "開始:", + "xpack.ml.timeSeriesExplorer.forecastsList.listsOfFiveRecentlyRunForecastsTooltip": "最も最近実行された予測を最大 5 件リストアップします。", + "xpack.ml.timeSeriesExplorer.forecastsList.previousForecastsTitle": "以前の予測", + "xpack.ml.timeSeriesExplorer.forecastsList.toColumnName": "終了:", + "xpack.ml.timeSeriesExplorer.forecastsList.viewColumnName": "表示", + "xpack.ml.timeSeriesExplorer.forecastsList.viewForecastAriaLabel": "{createdDate} に作成された予測を表示", + "xpack.ml.timeSeriesExplorer.intervalLabel": "間隔", + "xpack.ml.timeSeriesExplorer.loadingLabel": "読み込み中", + "xpack.ml.timeSeriesExplorer.noResultsFoundLabel": "結果が見つかりませんでした", + "xpack.ml.timeSeriesExplorer.noSingleMetricJobsFoundLabel": "シングルメトリックジョブが見つかりませんでした", + "xpack.ml.timeSeriesExplorer.requestedDetectorIndexNotValidWarningMessage": "リクエストされた検知器インデックス {detectorIndex} はジョブ {jobId} に有効ではありません", + "xpack.ml.timeSeriesExplorer.runControls.durationLabel": "期間", + "xpack.ml.timeSeriesExplorer.runControls.forecastMaximumLengthHelpText": "予想の長さで、最長 {maximumForecastDurationDays} 日です。秒には s、分には m、時間には h、日には d、週には w を使います。", + "xpack.ml.timeSeriesExplorer.runControls.forecastsCanNotBeRunOnJobsTooltip": "予測は {jobState} のジョブには利用できません。", + "xpack.ml.timeSeriesExplorer.runControls.noMLNodesAvailableTooltip": "利用可能な ML ノードがありません。", + "xpack.ml.timeSeriesExplorer.runControls.runButtonLabel": "実行", + "xpack.ml.timeSeriesExplorer.runControls.runNewForecastTitle": "新規予測の実行", + "xpack.ml.timeSeriesExplorer.severityThresholdLabel": "深刻度のしきい値", + "xpack.ml.timeSeriesExplorer.showForecastLabel": "予測を表示", + "xpack.ml.timeSeriesExplorer.showModelBoundsLabel": "モデルバウンドを表示", + "xpack.ml.timeSeriesExplorer.singleTimeSeriesAnalysisTitle": "{functionLabel} の単独時系列分析", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.actualLabel": "実際", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.addedAnnotationNotificationMessage": "ID {jobId} のジョブに注釈が追加されました。", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.anomalyScoreLabel": "異常スコア", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.deletedAnnotationNotificationMessage": "ID {jobId} のジョブの注釈が削除されました。", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.errorWithCreatingAnnotationNotificationErrorMessage": "ID {jobId} のジョブの注釈を作成中にエラーが発生しました: {error}", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.errorWithDeletingAnnotationNotificationErrorMessage": "ID {jobId} のジョブの注釈を削除中にエラーが発生しました: {error}", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.errorWithUpdatingAnnotationNotificationErrorMessage": "ID {jobId} のジョブの注釈を更新中にエラーが発生しました: {error}", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.modelBoundsNotAvailableLabel": "モデルバウンドが利用できません", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.modelPlotEnabled.lowerBoundsLabel": "下の境界", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.modelPlotEnabled.upperBoundsLabel": "上の境界", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.moreThanOneUnusualByFieldValuesLabel": "{numberOfCauses} 個の {plusSign}異常な{byFieldName}値", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.multiBucketImpactLabel": "複数バケットの影響", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.scheduledEventsLabel": "予定イベント {counter}", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.typicalLabel": "通常", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.updatedAnnotationNotificationMessage": "ID {jobId} のジョブの注釈が更新されました。", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.valueLabel": "値", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.withoutAnomalyScore.predictionLabel": "予測", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.withoutAnomalyScore.valueLabel": "値", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.withoutAnomalyScoreAndModelPlotEnabled.lowerBoundsLabel": "下の境界", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.withoutAnomalyScoreAndModelPlotEnabled.upperBoundsLabel": "上の境界", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.zoomAggregationIntervalLabel": "(集約間隔: {focusAggInt}、バケットスパン: {bucketSpan})", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.zoomGroupAggregationIntervalLabel": "(集約間隔: 、バケットスパン: )", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.zoomLabel": "ズーム:", + "xpack.ml.timeSeriesExplorer.tryWideningTheTimeSelectionDescription": "時間範囲を広げるか、さらに過去に遡ってみてください。", + "xpack.ml.timeSeriesExplorer.youCanViewOneJobAtTimeWarningMessage": "このダッシュボードでは 1 度に 1 つのジョブしか表示できません", + "xpack.ml.tooltips.newJobDedicatedIndexTooltip": "選択すると、このジョブの結果が別のインデックスに格納されます。", + "xpack.ml.tooltips.newJobRecognizerJobPrefixTooltip": "それぞれのジョブ ID の頭に付ける接頭辞です。", + "xpack.ml.upgrade.upgradeWarning.upgradeInProgressWarningDescription": "機械学習に関連したインデックスは現在アップグレード中です。", + "xpack.ml.upgrade.upgradeWarning.upgradeInProgressWarningDescriptionExtra": "現在いくつかのアクションが利用できません。", + "xpack.ml.upgrade.upgradeWarning.upgradeInProgressWarningTitle": "インデックスの移行が進行中です", + "xpack.ml.validateJob.allPassed": "すべてのチェックに合格しました", + "xpack.ml.validateJob.learnMoreLinkText": "その他のリソース", + "xpack.ml.validateJob.modal.closeButtonLabel": "閉じる", + "xpack.ml.validateJob.modal.jobValidationDescriptionText": "ジョブ検証は、ジョブの構成と使用されるソースデータに一定のチェックを行い、役立つ結果が得られるよう設定を調整する方法に関する具体的なアドバイスを提供します。", + "xpack.ml.validateJob.modal.linkToJobTipsText": "詳細は {mlJobTipsLink} をご覧ください。", + "xpack.ml.validateJob.modal.linkToJobTipsText.mlJobTipsLinkText": "機械学習ジョブのヒント", + "xpack.ml.validateJob.modal.validateJobTitle": "ジョブ {title} の検証", + "xpack.ml.validateJob.validateJobButtonLabel": "ジョブを検証", + "xpack.monitoring.accessDenied.backToKibanaButtonLabel": "Kibana に戻る", + "xpack.monitoring.accessDenied.clusterNotConfiguredDescription": "専用の監視クラスターへのアクセスを試みている場合、監視クラスターで構成されていないユーザーとしてログインしていることが原因である可能性があります。", + "xpack.monitoring.accessDenied.notAuthorizedDescription": "監視アクセスが許可されていません。監視を利用するには、「{kibanaUser}」と「{monitoringUser}」の両方のロールからの権限が必要です。", + "xpack.monitoring.accessDeniedTitle": "アクセス拒否", + "xpack.monitoring.ajaxErrorHandler.httpErrorMessage": "HTTP {errStatus}", + "xpack.monitoring.ajaxErrorHandler.requestErrorNotificationTitle": "監視リクエストエラー", + "xpack.monitoring.ajaxErrorHandler.requestFailedNotification.retryButtonLabel": "再試行", + "xpack.monitoring.ajaxErrorHandler.requestFailedNotificationTitle": "監視リクエスト失敗", + "xpack.monitoring.alerts.categoryColumn.generalLabel": "一般", + "xpack.monitoring.alerts.categoryColumnTitle": "カテゴリー", + "xpack.monitoring.alerts.clusterAlertsTitle": "クラスターアラート", + "xpack.monitoring.alerts.clusterOverviewLinkLabel": "« クラスターの概要", + "xpack.monitoring.alerts.filterAlertsPlaceholder": "フィルターアラート…", + "xpack.monitoring.alerts.highSeverityName": "高", + "xpack.monitoring.alerts.lastCheckedColumnTitle": "最終確認", + "xpack.monitoring.alerts.lowSeverityName": "低", + "xpack.monitoring.alerts.mediumSeverityName": "中", + "xpack.monitoring.alerts.messageColumnTitle": "メッセージ", + "xpack.monitoring.alerts.notResolvedDescription": "未解決", + "xpack.monitoring.alerts.resolvedAgoDescription": "{duration} 前", + "xpack.monitoring.alerts.resolvedColumnTitle": "解決済み", + "xpack.monitoring.alerts.severityTitle": "{severity}深刻度アラート", + "xpack.monitoring.alerts.statusColumnTitle": "ステータス", + "xpack.monitoring.alerts.triggeredColumnTitle": "実行済み", + "xpack.monitoring.alerts.triggeredColumnValue": "{timestamp} 前", + "xpack.monitoring.apm.healthStatusLabel": "ヘルス: {status}", + "xpack.monitoring.apm.instance.routeTitle": "{apm} - インスタンス", + "xpack.monitoring.apm.instance.status.lastEventDescription": "{timeOfLastEvent} 前", + "xpack.monitoring.apm.instance.status.lastEventLabel": "最後のイベント", + "xpack.monitoring.apm.instance.status.nameLabel": "名前", + "xpack.monitoring.apm.instance.status.outputLabel": "アウトプット", + "xpack.monitoring.apm.instance.status.uptimeLabel": "起動時間", + "xpack.monitoring.apm.instance.status.versionLabel": "バージョン", + "xpack.monitoring.apm.instance.statusDescription": "ステータス: {apmStatusIcon}", + "xpack.monitoring.apm.instances.allocatedMemoryTitle": "割当メモリー", + "xpack.monitoring.apm.instances.bytesSentRateTitle": "送信バイトレート", + "xpack.monitoring.apm.instances.filterInstancesPlaceholder": "フィルターインスタンス…", + "xpack.monitoring.apm.instances.lastEventTitle": "最後のイベント", + "xpack.monitoring.apm.instances.lastEventValue": "{timeOfLastEvent} 前", + "xpack.monitoring.apm.instances.nameTitle": "名前", + "xpack.monitoring.apm.instances.outputEnabledTitle": "アウトプットが有効です", + "xpack.monitoring.apm.instances.outputErrorsTitle": "アウトプットエラー", + "xpack.monitoring.apm.instances.routeTitle": "{apm} - インスタンス", + "xpack.monitoring.apm.instances.status.lastEventDescription": "{timeOfLastEvent} 前", + "xpack.monitoring.apm.instances.status.lastEventLabel": "最後のイベント", + "xpack.monitoring.apm.instances.status.serversLabel": "サーバー", + "xpack.monitoring.apm.instances.status.totalEventsLabel": "合計イベント数", + "xpack.monitoring.apm.instances.statusDescription": "ステータス: {apmStatusIcon}", + "xpack.monitoring.apm.instances.totalEventsRateTitle": "合計イベントレート", + "xpack.monitoring.apm.instances.versionFilter": "バージョン", + "xpack.monitoring.apm.instances.versionTitle": "バージョン", + "xpack.monitoring.apmNavigation.instancesLinkText": "インスタンス", + "xpack.monitoring.apmNavigation.overviewLinkText": "概要", + "xpack.monitoring.beats.filterBeatsPlaceholder": "ビートをフィルタリング…", + "xpack.monitoring.beats.instance.bytesSentLabel": "送信バイト", + "xpack.monitoring.beats.instance.configReloadsLabel": "構成の再読み込み", + "xpack.monitoring.beats.instance.eventsDroppedLabel": "ドロップイベント", + "xpack.monitoring.beats.instance.eventsEmittedLabel": "送信イベント", + "xpack.monitoring.beats.instance.eventsTotalLabel": "イベント合計", + "xpack.monitoring.beats.instance.handlesLimitHardLabel": "ハンドル制限 (ハード)", + "xpack.monitoring.beats.instance.handlesLimitSoftLabel": "ハンドル制限 (ソフト)", + "xpack.monitoring.beats.instance.hostLabel": "ホスト", + "xpack.monitoring.beats.instance.nameLabel": "名前", + "xpack.monitoring.beats.instance.outputLabel": "アウトプット", + "xpack.monitoring.beats.instance.routeTitle": "ビート - {instanceName} - 概要", + "xpack.monitoring.beats.instance.typeLabel": "タイプ", + "xpack.monitoring.beats.instance.uptimeLabel": "起動時間", + "xpack.monitoring.beats.instance.versionLabel": "バージョン", + "xpack.monitoring.beats.instances.allocatedMemoryTitle": "割当メモリー", + "xpack.monitoring.beats.instances.bytesSentRateTitle": "送信バイトレート", + "xpack.monitoring.beats.instances.nameTitle": "名前", + "xpack.monitoring.beats.instances.outputEnabledTitle": "アウトプットが有効です", + "xpack.monitoring.beats.instances.outputErrorsTitle": "アウトプットエラー", + "xpack.monitoring.beats.instances.totalEventsRateTitle": "合計イベントレート", + "xpack.monitoring.beats.instances.typeFilter": "タイプ", + "xpack.monitoring.beats.instances.typeTitle": "タイプ", + "xpack.monitoring.beats.instances.versionFilter": "バージョン", + "xpack.monitoring.beats.instances.versionTitle": "バージョン", + "xpack.monitoring.beats.overview.activeBeatsInLastDayTitle": "最終日のアクティブなビート", + "xpack.monitoring.beats.overview.bytesSentLabel": "送信バイト数", + "xpack.monitoring.beats.overview.latestActive.last1DayLabel": "過去 1 日", + "xpack.monitoring.beats.overview.latestActive.last1HourLabel": "過去 1 時間", + "xpack.monitoring.beats.overview.latestActive.last1MinuteLabel": "過去 1 か月", + "xpack.monitoring.beats.overview.latestActive.last20MinutesLabel": "過去 20 分間", + "xpack.monitoring.beats.overview.latestActive.last5MinutesLabel": "過去 5 分間", + "xpack.monitoring.beats.overview.noActivityDescription": "こんにちは!ここには最新のビートアクティビティが表示されますが、1 日以内にアクティビティがないようです。", + "xpack.monitoring.beats.overview.routeTitle": "ビート - 概要", + "xpack.monitoring.beats.overview.top5BeatTypesInLastDayTitle": "最終日のトップ 5 のビートタイプ", + "xpack.monitoring.beats.overview.top5VersionsInLastDayTitle": "最終日のトップ 5 のバージョン", + "xpack.monitoring.beats.overview.totalBeatsLabel": "合計ビート数", + "xpack.monitoring.beats.overview.totalEventsLabel": "合計イベント数", + "xpack.monitoring.beats.routeTitle": "ビート", + "xpack.monitoring.beatsNavigation.instance.overviewLinkText": "概要", + "xpack.monitoring.beatsNavigation.instancesLinkText": "インスタンス", + "xpack.monitoring.beatsNavigation.overviewLinkText": "概要", + "xpack.monitoring.breadcrumbs.apm.instancesLabel": "インスタンス", + "xpack.monitoring.breadcrumbs.apmLabel": "APM", + "xpack.monitoring.breadcrumbs.beats.instancesLabel": "インスタンス", + "xpack.monitoring.breadcrumbs.beatsLabel": "ビート", + "xpack.monitoring.breadcrumbs.clustersLabel": "クラスター", + "xpack.monitoring.breadcrumbs.es.ccrLabel": "CCR", + "xpack.monitoring.breadcrumbs.es.indicesLabel": "インデックス", + "xpack.monitoring.breadcrumbs.es.jobsLabel": "ジョブ", + "xpack.monitoring.breadcrumbs.es.nodesLabel": "ノード", + "xpack.monitoring.breadcrumbs.kibana.instancesLabel": "インスタンス", + "xpack.monitoring.breadcrumbs.logstash.nodesLabel": "ノード", + "xpack.monitoring.breadcrumbs.logstash.pipelinesLabel": "パイプライン", + "xpack.monitoring.breadcrumbs.logstashLabel": "Logstash", + "xpack.monitoring.chart.horizontalLegend.notAvailableLabel": "N/A", + "xpack.monitoring.chart.horizontalLegend.toggleButtonAriaLabel": "トグルボタン", + "xpack.monitoring.chart.infoTooltip.intervalLabel": "間隔", + "xpack.monitoring.chart.screenReaderUnaccessibleTitle": "このチャートはスクリーンリーダーではアクセスできません", + "xpack.monitoring.chart.seriesScreenReaderListDescription": "間隔: {bucketSize}", + "xpack.monitoring.chart.timeSeries.zoomOut": "ズームアウト", + "xpack.monitoring.cluster.listing.alertsInticator.alertsTooltip": "アラート", + "xpack.monitoring.cluster.listing.alertsInticator.clearStatusTooltip": "クラスターステータスはクリアです!", + "xpack.monitoring.cluster.listing.alertsInticator.clearTooltip": "クリア", + "xpack.monitoring.cluster.listing.alertsInticator.highSeverityTooltip": "クラスターにすぐに対処が必要な致命的な問題があります!", + "xpack.monitoring.cluster.listing.alertsInticator.lowSeverityTooltip": "クラスターに低深刻度の問題があります", + "xpack.monitoring.cluster.listing.alertsInticator.mediumSeverityTooltip": "クラスターに影響を及ぼす可能性がある問題があります。", + "xpack.monitoring.cluster.listing.dataColumnTitle": "データ", + "xpack.monitoring.cluster.listing.incompatibleLicense.getLicenseLinkLabel": "全機能を利用できるライセンスを取得", + "xpack.monitoring.cluster.listing.incompatibleLicense.infoMessage": "複数クラスターの監視が必要ですか?{getLicenseInfoLink} して、複数クラスターの監視をご利用ください。", + "xpack.monitoring.cluster.listing.incompatibleLicense.noMultiClusterSupportMessage": "ベーシックライセンスは複数クラスターの監視をサポートしていません。", + "xpack.monitoring.cluster.listing.incompatibleLicense.warningMessageTitle": "{clusterName} クラスターを表示できません。", + "xpack.monitoring.cluster.listing.indicesColumnTitle": "インデックス", + "xpack.monitoring.cluster.listing.invalidLicense.getBasicLicenseLinkLabel": "無料のベーシックライセンスを取得", + "xpack.monitoring.cluster.listing.invalidLicense.getLicenseLinkLabel": "全機能を利用できるライセンスを取得", + "xpack.monitoring.cluster.listing.invalidLicense.infoMessage": "ライセンスが必要ですか?{getBasicLicenseLink}、または {getLicenseInfoLink} して、複数クラスターの監視をご利用ください。", + "xpack.monitoring.cluster.listing.invalidLicense.invalidInfoMessage": "ライセンス情報が無効です。", + "xpack.monitoring.cluster.listing.invalidLicense.warningMessageTitle": "{clusterName} クラスターを表示できません。", + "xpack.monitoring.cluster.listing.kibanaColumnTitle": "Kibana", + "xpack.monitoring.cluster.listing.licenseColumnTitle": "ライセンス", + "xpack.monitoring.cluster.listing.logstashColumnTitle": "Logstash", + "xpack.monitoring.cluster.listing.nameColumnTitle": "名前", + "xpack.monitoring.cluster.listing.nodesColumnTitle": "ノード", + "xpack.monitoring.cluster.listing.standaloneClusterCallOutDismiss": "閉じる", + "xpack.monitoring.cluster.listing.standaloneClusterCallOutLink": "これらのインスタンスを表示。", + "xpack.monitoring.cluster.listing.standaloneClusterCallOutText": "または、下の表のスタンドアローンクラスターをクリックしてください", + "xpack.monitoring.cluster.listing.standaloneClusterCallOutTitle": "Elasticsearch クラスターに接続されていないインスタンスがあるようです。", + "xpack.monitoring.cluster.listing.statusColumnTitle": "ステータス", + "xpack.monitoring.cluster.overview.alertsPanel.lastCheckedTimeText": "最終確認 {updateDateTime} ({duration} 前に実行)", + "xpack.monitoring.cluster.overview.alertsPanel.severityIconTitle": "{severityIconTitle} ({time} 前に解決)", + "xpack.monitoring.cluster.overview.alertsPanel.topClusterTitle": "トップクラスターアラート", + "xpack.monitoring.cluster.overview.alertsPanel.viewAllButtonLabel": "すべてのアラートを表示", + "xpack.monitoring.cluster.overview.apmPanel.apmTitle": "APM", + "xpack.monitoring.cluster.overview.apmPanel.instancesTotalLinkAriaLabel": "APM インスタンス: {apmsTotal}", + "xpack.monitoring.cluster.overview.apmPanel.lastEventDescription": "{timeOfLastEvent} 前", + "xpack.monitoring.cluster.overview.apmPanel.lastEventLabel": "最後のイベント", + "xpack.monitoring.cluster.overview.apmPanel.memoryUsageLabel": "メモリー使用状況", + "xpack.monitoring.cluster.overview.apmPanel.overviewLinkAriaLabel": "APM の概要", + "xpack.monitoring.cluster.overview.apmPanel.overviewLinkLabel": "概要", + "xpack.monitoring.cluster.overview.apmPanel.processedEventsLabel": "処理済みのイベント", + "xpack.monitoring.cluster.overview.apmPanel.serversTotalLinkLabel": "APM Server: {apmsTotal}", + "xpack.monitoring.cluster.overview.beatsPanel.beatsTitle": "ビート", + "xpack.monitoring.cluster.overview.beatsPanel.beatsTotalLinkLabel": "ビート: {beatsTotal}", + "xpack.monitoring.cluster.overview.beatsPanel.bytesSentLabel": "送信バイト数", + "xpack.monitoring.cluster.overview.beatsPanel.instancesTotalLinkAriaLabel": "ビートインスタンス: {beatsTotal}", + "xpack.monitoring.cluster.overview.beatsPanel.overviewLinkAriaLabel": "ビートの概要", + "xpack.monitoring.cluster.overview.beatsPanel.overviewLinkLabel": "概要", + "xpack.monitoring.cluster.overview.beatsPanel.totalEventsLabel": "合計イベント数", + "xpack.monitoring.cluster.overview.esPanel.debugLogsTooltipText": "デバッグログの数です", + "xpack.monitoring.cluster.overview.esPanel.diskAvailableLabel": "利用可能なディスク容量", + "xpack.monitoring.cluster.overview.esPanel.diskUsageLabel": "ディスク使用量", + "xpack.monitoring.cluster.overview.esPanel.documentsLabel": "ドキュメント", + "xpack.monitoring.cluster.overview.esPanel.errorLogsTooltipText": "エラーログの数です", + "xpack.monitoring.cluster.overview.esPanel.fatalLogsTooltipText": "致命的ログの数です", + "xpack.monitoring.cluster.overview.esPanel.indicesCountLinkAriaLabel": "Elasticsearch インデックス: {indicesCount}", + "xpack.monitoring.cluster.overview.esPanel.indicesCountLinkLabel": "インデックス: {indicesCount}", + "xpack.monitoring.cluster.overview.esPanel.infoLogsTooltipText": "情報ログの数です", + "xpack.monitoring.cluster.overview.esPanel.jobsLabel": "ジョブ", + "xpack.monitoring.cluster.overview.esPanel.jvmHeapLabel": "{javaVirtualMachine} ヒープ", + "xpack.monitoring.cluster.overview.esPanel.logsLinkAriaLabel": "Elasticsearch ログ", + "xpack.monitoring.cluster.overview.esPanel.logsLinkLabel": "ログ", + "xpack.monitoring.cluster.overview.esPanel.nodesTotalLinkLabel": "ノード: {nodesTotal}", + "xpack.monitoring.cluster.overview.esPanel.overviewLinkAriaLabel": "Elasticsearch の概要", + "xpack.monitoring.cluster.overview.esPanel.overviewLinkLabel": "概要", + "xpack.monitoring.cluster.overview.esPanel.primaryShardsLabel": "プライマリシャード", + "xpack.monitoring.cluster.overview.esPanel.replicaShardsLabel": "レプリカシャード", + "xpack.monitoring.cluster.overview.esPanel.uptimeLabel": "起動時間", + "xpack.monitoring.cluster.overview.esPanel.versionLabel": "バージョン", + "xpack.monitoring.cluster.overview.esPanel.versionNotAvailableDescription": "N/A", + "xpack.monitoring.cluster.overview.esPanel.warnLogsTooltipText": "警告ログの数です", + "xpack.monitoring.cluster.overview.healthStatusDescription": "ヘルス: {status}", + "xpack.monitoring.cluster.overview.kibanaPanel.connectionsLabel": "接続", + "xpack.monitoring.cluster.overview.kibanaPanel.instancesCountLinkAriaLabel": "Kibana インスタンス: {instancesCount}", + "xpack.monitoring.cluster.overview.kibanaPanel.instancesCountLinkLabel": "インスタンス: {instancesCount}", + "xpack.monitoring.cluster.overview.kibanaPanel.kibanaTitle": "Kibana", + "xpack.monitoring.cluster.overview.kibanaPanel.maxResponseTimeDescription": "{maxTime} ms", + "xpack.monitoring.cluster.overview.kibanaPanel.maxResponseTimeLabel": "最高応答時間", + "xpack.monitoring.cluster.overview.kibanaPanel.memoryUsageLabel": "メモリー使用状況", + "xpack.monitoring.cluster.overview.kibanaPanel.overviewLinkAriaLabel": "Kibana の概要", + "xpack.monitoring.cluster.overview.kibanaPanel.overviewLinkLabel": "概要", + "xpack.monitoring.cluster.overview.kibanaPanel.requestsLabel": "リクエスト", + "xpack.monitoring.cluster.overview.licenseText.expireDateText": "の有効期限は {expiryDate} です", + "xpack.monitoring.cluster.overview.licenseText.toLicensePageLinkLabel": "{licenseType} ライセンス {willExpireOn}", + "xpack.monitoring.cluster.overview.logsPanel.logTypeTitle": "{type}", + "xpack.monitoring.cluster.overview.logsPanel.noLogsFound": "ログが見つかりませんでした。", + "xpack.monitoring.cluster.overview.logstashPanel.betaFeatureTooltip": "ベータ機能", + "xpack.monitoring.cluster.overview.logstashPanel.eventsEmittedLabel": "送信イベント", + "xpack.monitoring.cluster.overview.logstashPanel.eventsReceivedLabel": "受信イベント", + "xpack.monitoring.cluster.overview.logstashPanel.jvmHeapLabel": "{javaVirtualMachine} ヒープ", + "xpack.monitoring.cluster.overview.logstashPanel.logstashTitle": "Logstash", + "xpack.monitoring.cluster.overview.logstashPanel.nodesCountLinkAriaLabel": "Logstash ノード: {nodesCount}", + "xpack.monitoring.cluster.overview.logstashPanel.nodesCountLinkLabel": "ノード: {nodesCount}", + "xpack.monitoring.cluster.overview.logstashPanel.overviewLinkAriaLabel": "Logstash の概要", + "xpack.monitoring.cluster.overview.logstashPanel.overviewLinkLabel": "概要", + "xpack.monitoring.cluster.overview.logstashPanel.pipelineCountLinkAriaLabel": "Logstash パイプライン (ベータ機能): {pipelineCount}", + "xpack.monitoring.cluster.overview.logstashPanel.pipelinesCountLinkLabel": "パイプライン: {pipelineCount}", + "xpack.monitoring.cluster.overview.logstashPanel.uptimeLabel": "起動時間", + "xpack.monitoring.cluster.overview.logstashPanel.withMemoryQueuesLabel": "メモリーキューあり", + "xpack.monitoring.cluster.overview.logstashPanel.withPersistentQueuesLabel": "永続キューあり", + "xpack.monitoring.cluster.overviewTitle": "概要", + "xpack.monitoring.clusterAlerts.checkLicense.licenseIsBasicDescription": "Watcher が無効になっているか、[{clusterSource}] クラスターの現在のライセンスがベーシックの場合、クラスターアラートは表示されません。", + "xpack.monitoring.clusterAlerts.checkLicense.licenseNotActiveDescription": "[{clusterSource}] クラスターの現在のライセンス [{type}] がアクティブでないため、クラスターアラートは表示されません。", + "xpack.monitoring.clusterAlerts.checkLicense.licenseNotDeterminedDescription": "[{clusterSource}] クラスターのライセンスが確認できなかったため、クラスターアラートは表示されません。", + "xpack.monitoring.clusterAlerts.checkLicense.watcherIsDisabledDescription": "Watcher が無効なため、クラスターアラートを利用できません。", + "xpack.monitoring.clusterAlerts.clusterNeedsTSLEnabledDescription": "セキュリティが有効な場合、ゴールドまたはプラチナライセンスの適用に TLS の構成が必要です。", + "xpack.monitoring.clusterAlerts.disabledLicenseDescription": "クラスターアラート機能は無効になっています。", + "xpack.monitoring.clusterAlerts.notDeterminedLicenseDescription": "クラスターアラート機能のステータスが確認できませんでした。", + "xpack.monitoring.clusterAlerts.seeDocumentationDescription": "詳細はドキュメンテーションをご覧ください。", + "xpack.monitoring.clusterAlerts.unsupportedClusterAlertsDescription": "クラスター [{clusterName}] ライセンスタイプ [{licenseType}] はクラスターアラートをサポートしていません", + "xpack.monitoring.clusterAlertsNavigation.clusterAlertsLinkText": "クラスターアラート", + "xpack.monitoring.clustersNavigation.clustersLinkText": "クラスター", + "xpack.monitoring.clusterStats.uuidNotFoundErrorMessage": "選択された時間範囲にクラスターが見つかりませんでした。UUID: {clusterUuid}", + "xpack.monitoring.clusterStats.uuidNotSpecifiedErrorMessage": "{clusterUuid} が指定されていません", + "xpack.monitoring.elasticsearch.ccr.ccrListingTable.errorColumnTitle": "エラー", + "xpack.monitoring.elasticsearch.ccr.ccrListingTable.followsColumnTitle": "フォロー", + "xpack.monitoring.elasticsearch.ccr.ccrListingTable.indexColumnTitle": "インデックス", + "xpack.monitoring.elasticsearch.ccr.ccrListingTable.lastFetchTimeColumnTitle": "最終取得時刻", + "xpack.monitoring.elasticsearch.ccr.ccrListingTable.opsSyncedColumnTitle": "同期されたオペレーション", + "xpack.monitoring.elasticsearch.ccr.ccrListingTable.syncLagOpsColumnTitle": "同期の遅延 (オペレーション数)", + "xpack.monitoring.elasticsearch.ccr.routeTitle": "Elasticsearch - CCR", + "xpack.monitoring.elasticsearch.ccr.shard.instanceTitle": "インデックス{followerIndex} シャード: {shardId}", + "xpack.monitoring.elasticsearch.ccr.shard.routeTitle": "Elasticsearch - CCR - シャード", + "xpack.monitoring.elasticsearch.ccr.shardsTable.errorColumnTitle": "エラー", + "xpack.monitoring.elasticsearch.ccr.shardsTable.lastFetchTimeColumnTitle": "最終取得時刻", + "xpack.monitoring.elasticsearch.ccr.shardsTable.opsSyncedColumnTitle": "同期されたオペレーション", + "xpack.monitoring.elasticsearch.ccr.shardsTable.shardColumnTitle": "シャード", + "xpack.monitoring.elasticsearch.ccr.shardsTable.syncLagOpsColumn.followerLagTooltip": "フォロワーラグ: {syncLagOpsFollower}", + "xpack.monitoring.elasticsearch.ccr.shardsTable.syncLagOpsColumn.leaderLagTooltip": "リーダーラグ: {syncLagOpsLeader}", + "xpack.monitoring.elasticsearch.ccr.shardsTable.syncLagOpsColumnTitle": "同期の遅延 (オペレーション数)", + "xpack.monitoring.elasticsearch.ccrShard.errorsTable.reasonColumnTitle": "理由", + "xpack.monitoring.elasticsearch.ccrShard.errorsTable.typeColumnTitle": "タイプ", + "xpack.monitoring.elasticsearch.ccrShard.errorsTableTitle": "エラー", + "xpack.monitoring.elasticsearch.ccrShard.latestStateAdvancedButtonLabel": "高度な設定", + "xpack.monitoring.elasticsearch.ccrShard.status.failedFetchesLabel": "失敗した取得", + "xpack.monitoring.elasticsearch.ccrShard.status.followerIndexLabel": "フォロワーインデックス", + "xpack.monitoring.elasticsearch.ccrShard.status.leaderIndexLabel": "リーダーインデックス", + "xpack.monitoring.elasticsearch.ccrShard.status.opsSyncedLabel": "同期されたオペレーション", + "xpack.monitoring.elasticsearch.ccrShard.status.shardIdLabel": "シャード ID", + "xpack.monitoring.elasticsearch.clusterStatus.dataLabel": "データ", + "xpack.monitoring.elasticsearch.clusterStatus.documentsLabel": "ドキュメント", + "xpack.monitoring.elasticsearch.clusterStatus.indicesLabel": "インデックス", + "xpack.monitoring.elasticsearch.clusterStatus.memoryLabel": "メモリー", + "xpack.monitoring.elasticsearch.clusterStatus.nodesLabel": "ノード", + "xpack.monitoring.elasticsearch.clusterStatus.totalShardsLabel": "合計シャード数", + "xpack.monitoring.elasticsearch.clusterStatus.unassignedShardsLabel": "未割り当てシャード", + "xpack.monitoring.elasticsearch.healthStatusLabel": "ヘルス: {status}", + "xpack.monitoring.elasticsearch.indexDetailStatus.documentsTitle": "ドキュメント", + "xpack.monitoring.elasticsearch.indexDetailStatus.iconStatusLabel": "ヘルス: {elasticsearchStatusIcon}", + "xpack.monitoring.elasticsearch.indexDetailStatus.primariesTitle": "プライマリ", + "xpack.monitoring.elasticsearch.indexDetailStatus.totalShardsTitle": "合計シャード数", + "xpack.monitoring.elasticsearch.indexDetailStatus.totalTitle": "合計", + "xpack.monitoring.elasticsearch.indexDetailStatus.unassignedShardsTitle": "未割り当てシャード", + "xpack.monitoring.elasticsearch.indices.advanced.routeTitle": "Elasticsearch - インデックス - {indexName} - 高度な設定", + "xpack.monitoring.elasticsearch.indices.dataTitle": "データ", + "xpack.monitoring.elasticsearch.indices.documentCountTitle": "ドキュメントカウント", + "xpack.monitoring.elasticsearch.indices.howToShowSystemIndicesDescription": "システムインデックス (例: Kibana) をご希望の場合は、「システムインデックスを表示」にチェックを入れてみてください。", + "xpack.monitoring.elasticsearch.indices.indexRateTitle": "インデックスレート", + "xpack.monitoring.elasticsearch.indices.monitoringTablePlaceholder": "インデックスのフィルタリング…", + "xpack.monitoring.elasticsearch.indices.nameTitle": "名前", + "xpack.monitoring.elasticsearch.indices.noIndicesMatchYourSelectionDescription": "選択項目に一致するインデックスがありません。時間範囲を変更してみてください。", + "xpack.monitoring.elasticsearch.indices.overview.routeTitle": "Elasticsearch - インデックス - {indexName} - 概要", + "xpack.monitoring.elasticsearch.indices.routeTitle": "Elasticsearch - インデックス", + "xpack.monitoring.elasticsearch.indices.searchRateTitle": "検索レート", + "xpack.monitoring.elasticsearch.indices.statusTitle": "ステータス", + "xpack.monitoring.elasticsearch.indices.systemIndicesLabel": "システムインデックス", + "xpack.monitoring.elasticsearch.indices.unassignedShardsTitle": "未割り当てシャード", + "xpack.monitoring.elasticsearch.mlJobListing.filterJobsPlaceholder": "ジョブをフィルタリング…", + "xpack.monitoring.elasticsearch.mlJobListing.forecastsTitle": "予測", + "xpack.monitoring.elasticsearch.mlJobListing.jobIdTitle": "ジョブ ID", + "xpack.monitoring.elasticsearch.mlJobListing.modelSizeTitle": "モデルサイズ", + "xpack.monitoring.elasticsearch.mlJobListing.noDataLabel": "N/A", + "xpack.monitoring.elasticsearch.mlJobListing.nodeTitle": "ノード", + "xpack.monitoring.elasticsearch.mlJobListing.noJobsDescription": "クエリに一致する機械学習ジョブがありません。時間範囲を変更してみてください。", + "xpack.monitoring.elasticsearch.mlJobListing.processedRecordsTitle": "処理済みレコード", + "xpack.monitoring.elasticsearch.mlJobListing.stateTitle": "ステータス", + "xpack.monitoring.elasticsearch.mlJobListing.statusIconLabel": "ジョブ状態: {status}", + "xpack.monitoring.elasticsearch.mlJobs.routeTitle": "Elasticsearch - 機械学習ジョブ", + "xpack.monitoring.elasticsearch.node.advanced.routeTitle": "Elasticsearch - ノード - {nodeSummaryName} - 高度な設定", + "xpack.monitoring.elasticsearch.node.overview.routeTitle": "Elasticsearch - ノード - {nodeName} - 概要", + "xpack.monitoring.elasticsearch.node.statusIconLabel": "ステータス: {status}", + "xpack.monitoring.elasticsearch.nodeDetailStatus.dataLabel": "データ", + "xpack.monitoring.elasticsearch.nodeDetailStatus.documentsLabel": "ドキュメント", + "xpack.monitoring.elasticsearch.nodeDetailStatus.freeDiskSpaceLabel": "空きディスク容量", + "xpack.monitoring.elasticsearch.nodeDetailStatus.indicesLabel": "インデックス", + "xpack.monitoring.elasticsearch.nodeDetailStatus.jvmHeapLabel": "{javaVirtualMachine} ヒープ", + "xpack.monitoring.elasticsearch.nodeDetailStatus.shardsLabel": "シャード", + "xpack.monitoring.elasticsearch.nodeDetailStatus.transportAddress": "トランスポートアドレス", + "xpack.monitoring.elasticsearch.nodeDetailStatus.typeLabel": "タイプ", + "xpack.monitoring.elasticsearch.nodes.cells.maxText": "最高 {metric}", + "xpack.monitoring.elasticsearch.nodes.cells.minText": "最低 {metric}", + "xpack.monitoring.elasticsearch.nodes.cpuThrottlingColumnTitle": "CPU スロットル", + "xpack.monitoring.elasticsearch.nodes.cpuUsageColumnTitle": "CPU 使用状況", + "xpack.monitoring.elasticsearch.nodes.diskFreeSpaceColumnTitle": "ディスクの空き容量", + "xpack.monitoring.elasticsearch.nodes.jvmMemoryColumnTitle": "{javaVirtualMachine} メモリー", + "xpack.monitoring.elasticsearch.nodes.loadAverageColumnTitle": "平均負荷", + "xpack.monitoring.elasticsearch.nodes.metricbeatMigration.detectedNodeDescription": "次のインデックスは監視されていません。下の「Metricbeat で監視」をクリックして、監視を開始してください。", + "xpack.monitoring.elasticsearch.nodes.metricbeatMigration.detectedNodeTitle": "Elasticsearch ノードが検出されました", + "xpack.monitoring.elasticsearch.nodes.metricbeatMigration.disableInternalCollectionDescription": "移行を完了させるには、自己監視を無効にしてください。", + "xpack.monitoring.elasticsearch.nodes.metricbeatMigration.disableInternalCollectionMigrationButtonLabel": "自己監視を無効にする", + "xpack.monitoring.elasticsearch.nodes.metricbeatMigration.disableInternalCollectionTitle": "Metricbeat による Elasticsearch ノードの監視が開始されました", + "xpack.monitoring.elasticsearch.nodes.monitoringTablePlaceholder": "ノードをフィルタリング…", + "xpack.monitoring.elasticsearch.nodes.nameColumnTitle": "名前", + "xpack.monitoring.elasticsearch.nodes.routeTitle": "Elasticsearch - ノード", + "xpack.monitoring.elasticsearch.nodes.shardsColumnTitle": "シャード", + "xpack.monitoring.elasticsearch.nodes.statusColumn.offlineLabel": "オフライン", + "xpack.monitoring.elasticsearch.nodes.statusColumn.onlineLabel": "オンライン", + "xpack.monitoring.elasticsearch.nodes.statusColumnTitle": "ステータス", + "xpack.monitoring.elasticsearch.shardActivity.completedRecoveriesLabel": "完了済みの復元", + "xpack.monitoring.elasticsearch.shardActivity.noActiveShardRecoveriesMessage.completedRecoveriesLinkText": "完了済みの復元", + "xpack.monitoring.elasticsearch.shardActivity.noActiveShardRecoveriesMessage.completedRecoveriesLinkTextProblem": "このクラスターにはアクティブなシャードの復元がありません。", + "xpack.monitoring.elasticsearch.shardActivity.noActiveShardRecoveriesMessage.completedRecoveriesLinkTextSolution": "{shardActivityHistoryLink} を試してみてください。", + "xpack.monitoring.elasticsearch.shardActivity.noDataMessage": "選択された時間範囲には過去のシャードアクティビティ記録がありません。", + "xpack.monitoring.elasticsearch.shardActivity.progress.noTranslogProgressLabel": "n/a", + "xpack.monitoring.elasticsearch.shardActivity.recoveryIndex.recoveryTypeDescription": "復元タイプ: {relocationType}", + "xpack.monitoring.elasticsearch.shardActivity.recoveryIndex.shardDescription": "シャード: {shard}", + "xpack.monitoring.elasticsearch.shardActivity.snapshotTitle": "レポジトリ: {repo} / スナップショット: {snapshot}", + "xpack.monitoring.elasticsearch.shardActivity.sourceTooltip": "{copiedFrom} シャードからコピーされました", + "xpack.monitoring.elasticsearch.shardActivity.sourceTooltip.primarySourceText": "プライマリ", + "xpack.monitoring.elasticsearch.shardActivity.sourceTooltip.replicaSourceText": "レプリカ", + "xpack.monitoring.elasticsearch.shardActivity.totalTimeTooltip": "開始: {startTime}", + "xpack.monitoring.elasticsearch.shardActivityTitle": "シャードアクティビティ", + "xpack.monitoring.elasticsearch.shardAllocation.clusterViewDisplayName": "ClusterView", + "xpack.monitoring.elasticsearch.shardAllocation.decorateShards.relocatingFromTextMessage": "{nodeName} から移動しています", + "xpack.monitoring.elasticsearch.shardAllocation.decorateShards.relocatingToTextMessage": "{nodeName} に移動しています", + "xpack.monitoring.elasticsearch.shardAllocation.initializingLabel": "初期化中", + "xpack.monitoring.elasticsearch.shardAllocation.labels.indicesLabel": "インデックス", + "xpack.monitoring.elasticsearch.shardAllocation.labels.nodesLabel": "ノード", + "xpack.monitoring.elasticsearch.shardAllocation.labels.unassignedLabel": "割り当てなし", + "xpack.monitoring.elasticsearch.shardAllocation.labels.unassignedNodesLabel": "ノード", + "xpack.monitoring.elasticsearch.shardAllocation.primaryLabel": "プライマリ", + "xpack.monitoring.elasticsearch.shardAllocation.relocatingLabel": "移動中", + "xpack.monitoring.elasticsearch.shardAllocation.replicaLabel": "レプリカ", + "xpack.monitoring.elasticsearch.shardAllocation.shardDisplayName": "シャード", + "xpack.monitoring.elasticsearch.shardAllocation.shardLegendTitle": "シャードの凡例", + "xpack.monitoring.elasticsearch.shardAllocation.tableBody.noShardsAllocatedDescription": "シャードが割り当てられていません。", + "xpack.monitoring.elasticsearch.shardAllocation.tableBodyDisplayName": "TableBody", + "xpack.monitoring.elasticsearch.shardAllocation.tableHead.indicesLabel": "インデックス", + "xpack.monitoring.elasticsearch.shardAllocation.unassignedDisplayName": "割り当てなし", + "xpack.monitoring.elasticsearch.shardAllocation.unassignedPrimaryLabel": "未割り当てプライマリ", + "xpack.monitoring.elasticsearch.shardAllocation.unassignedReplicaLabel": "未割り当てレプリカ", + "xpack.monitoring.errors.connectionFaultErrorMessage": "Elasticsearch 監視クラスターのネットワーク接続を確認し、詳細は Kibana のログをご覧ください。", + "xpack.monitoring.errors.insufficientUserErrorMessage": "データの監視に必要なユーザーパーミッションがありません", + "xpack.monitoring.errors.invalidAuthErrorMessage": "クラスターの監視に無効な認証です", + "xpack.monitoring.errors.monitoringLicenseErrorDescription": "クラスター = 「{clusterId}」のライセンス情報が見つかりませんでした。クラスターのマスターノードサーバーログにエラーや警告がないか確認してください。", + "xpack.monitoring.errors.monitoringLicenseErrorTitle": "監視ライセンスエラー", + "xpack.monitoring.errors.noConnectionsErrorMessage": "Elasticsearch 監視クラスターのネットワーク接続を確認し、詳細は Kibana のログをご覧ください。", + "xpack.monitoring.errors.statusCodeErrorMessage": "Elasticsearch 監視クラスターのネットワーク接続、またはノードの負荷レベルを確認してください。", + "xpack.monitoring.es.indices.deletedClosedStatusLabel": "削除済み / クローズ済み", + "xpack.monitoring.es.indices.notAvailableStatusLabel": "利用不可", + "xpack.monitoring.es.indices.unknownStatusLabel": "不明", + "xpack.monitoring.es.nodes.offlineNodeStatusLabel": "オフラインノード", + "xpack.monitoring.es.nodes.offlineStatusLabel": "オフライン", + "xpack.monitoring.es.nodes.onlineStatusLabel": "オンライン", + "xpack.monitoring.es.nodeType.clientNodeLabel": "クライアントノード", + "xpack.monitoring.es.nodeType.dataOnlyNodeLabel": "データ専用ノード", + "xpack.monitoring.es.nodeType.invalidNodeLabel": "無効なノード", + "xpack.monitoring.es.nodeType.masterNodeLabel": "マスターノード", + "xpack.monitoring.es.nodeType.masterOnlyNodeLabel": "マスター専用ノード", + "xpack.monitoring.es.nodeType.nodeLabel": "ノード", + "xpack.monitoring.esNavigation.ccrLinkText": "CCR", + "xpack.monitoring.esNavigation.indicesLinkText": "インデックス", + "xpack.monitoring.esNavigation.instance.advancedLinkText": "高度な設定", + "xpack.monitoring.esNavigation.instance.overviewLinkText": "概要", + "xpack.monitoring.esNavigation.jobsLinkText": "ジョブ", + "xpack.monitoring.esNavigation.nodesLinkText": "ノード", + "xpack.monitoring.esNavigation.overviewLinkText": "概要", + "xpack.monitoring.euiSSPTable.setupNewButtonLabel": "新規 {identifier} の監視を設定", + "xpack.monitoring.euiTable.isFullyMigratedLabel": "Metricbeat 収集", + "xpack.monitoring.euiTable.isInternalCollectorLabel": "内部収集", + "xpack.monitoring.euiTable.isPartiallyMigratedLabel": "内部収集と Metricbeat 収集", + "xpack.monitoring.euiTable.setupNewButtonLabel": "Metricbeat で別の {identifier} を監視", + "xpack.monitoring.feature.reserved.description": "ユーザーアクセスを許可するには、monitoring_user ロールも割り当てる必要があります。", + "xpack.monitoring.featureRegistry.monitoringFeatureName": "スタック監視", + "xpack.monitoring.formatNumbers.notAvailableLabel": "N/A", + "xpack.monitoring.kibana.clusterStatus.connectionsLabel": "接続", + "xpack.monitoring.kibana.clusterStatus.instancesLabel": "インスタンス", + "xpack.monitoring.kibana.clusterStatus.maxResponseTimeLabel": "最高応答時間", + "xpack.monitoring.kibana.clusterStatus.memoryLabel": "メモリー", + "xpack.monitoring.kibana.clusterStatus.requestsLabel": "リクエスト", + "xpack.monitoring.kibana.detailStatus.osFreeMemoryLabel": "OS の空きメモリー", + "xpack.monitoring.kibana.detailStatus.transportAddressLabel": "トランスポートアドレス", + "xpack.monitoring.kibana.detailStatus.uptimeLabel": "起動時間", + "xpack.monitoring.kibana.detailStatus.versionLabel": "バージョン", + "xpack.monitoring.kibana.instances.metricbeatMigration.detectedNodeDescription": "次のインスタンスは監視されていません。\n 下の「Metricbeat で監視」をクリックして、監視を開始してください。", + "xpack.monitoring.kibana.instances.metricbeatMigration.detectedNodeTitle": "Kibana インスタンスが検出されました", + "xpack.monitoring.kibana.listing.filterInstancesPlaceholder": "フィルターインスタンス…", + "xpack.monitoring.kibana.listing.instanceStatus.offlineLabel": "オフライン", + "xpack.monitoring.kibana.listing.instanceStatusTitle": "インスタンスステータス: {kibanaStatus}", + "xpack.monitoring.kibana.listing.loadAverageColumnTitle": "平均負荷", + "xpack.monitoring.kibana.listing.memorySizeColumnTitle": "メモリーサイズ", + "xpack.monitoring.kibana.listing.nameColumnTitle": "名前", + "xpack.monitoring.kibana.listing.requestsColumnTitle": "リクエスト", + "xpack.monitoring.kibana.listing.responseTimeColumnTitle": "応答時間", + "xpack.monitoring.kibana.listing.statusColumnTitle": "ステータス", + "xpack.monitoring.kibana.shardActivity.bytesTitle": "バイト", + "xpack.monitoring.kibana.shardActivity.filesTitle": "ファイル", + "xpack.monitoring.kibana.shardActivity.indexTitle": "インデックス", + "xpack.monitoring.kibana.shardActivity.sourceDestinationTitle": "ソース / 行先", + "xpack.monitoring.kibana.shardActivity.stageTitle": "ステージ", + "xpack.monitoring.kibana.shardActivity.totalTimeTitle": "合計時間", + "xpack.monitoring.kibana.shardActivity.translogTitle": "Translog", + "xpack.monitoring.kibana.statusIconLabel": "ヘルス: {status}", + "xpack.monitoring.kibanaNavigation.instancesLinkText": "インスタンス", + "xpack.monitoring.kibanaNavigation.overviewLinkText": "概要", + "xpack.monitoring.license.howToUpdateLicenseDescription": "このクラスターのライセンスを更新するには、Elasticsearch {apiText}でライセンスファイルを提供してください:", + "xpack.monitoring.license.licenseRouteTitle": "ライセンス", + "xpack.monitoring.logs.listing.calloutLinkText": "ログ", + "xpack.monitoring.logs.listing.calloutTitle": "他のログを表示する場合", + "xpack.monitoring.logs.listing.clusterPageDescription": "このクラスターの最も新しいログを最高合計 {limit} 件まで表示しています。", + "xpack.monitoring.logs.listing.componentTitle": "コンポーネント", + "xpack.monitoring.logs.listing.indexPageDescription": "このインデックスの最も新しいログを最高合計 {limit} 件まで表示しています。", + "xpack.monitoring.logs.listing.levelTitle": "レベル", + "xpack.monitoring.logs.listing.linkText": "詳細は {link} をご覧ください。", + "xpack.monitoring.logs.listing.messageTitle": "メッセージ", + "xpack.monitoring.logs.listing.nodePageDescription": "このノードの最も新しいログを最高合計 {limit} 件まで表示しています。", + "xpack.monitoring.logs.listing.nodeTitle": "ノード", + "xpack.monitoring.logs.listing.pageTitle": "最近のログ", + "xpack.monitoring.logs.listing.timestampTitle": "タイムスタンプ", + "xpack.monitoring.logs.listing.typeTitle": "タイプ", + "xpack.monitoring.logs.reason.correctIndexNameLink": "詳細はここをクリックしてください。", + "xpack.monitoring.logs.reason.correctIndexNameMessage": "これはFilebeatインデックスから読み取る問題です。{link}", + "xpack.monitoring.logs.reason.correctIndexNameTitle": "破損したFilebeatインデックス", + "xpack.monitoring.logs.reason.defaultMessage": "ログデータが見つからず、理由を診断することができません。{link}", + "xpack.monitoring.logs.reason.defaultMessageLink": "正しくセットアップされていることを確認してください。", + "xpack.monitoring.logs.reason.defaultTitle": "ログデータが見つかりませんでした", + "xpack.monitoring.logs.reason.noClusterLink": "セットアップ", + "xpack.monitoring.logs.reason.noClusterMessage": "{link} が正しいことを確認してください。", + "xpack.monitoring.logs.reason.noClusterTitle": "このクラスターにはログがありません", + "xpack.monitoring.logs.reason.noIndexLink": "セットアップ", + "xpack.monitoring.logs.reason.noIndexMessage": "ログが見つかりましたが、このインデックスのものはありません。この問題が解決されない場合は、{link} が正しいことを確認してください。", + "xpack.monitoring.logs.reason.noIndexPatternInTimePeriodMessage": "時間フィルターでタイムフレームを調整してください。", + "xpack.monitoring.logs.reason.noIndexPatternInTimePeriodTitle": "選択された時間にログはありません", + "xpack.monitoring.logs.reason.noIndexPatternLink": "Filebeat", + "xpack.monitoring.logs.reason.noIndexPatternMessage": "{link} をセットアップして、監視クラスターへの Elasticsearch アウトプットを構成してください。", + "xpack.monitoring.logs.reason.noIndexPatternTitle": "ログデータが見つかりませんでした", + "xpack.monitoring.logs.reason.noIndexTitle": "このインデックスにはログがありません", + "xpack.monitoring.logs.reason.noNodeLink": "セットアップ", + "xpack.monitoring.logs.reason.noNodeMessage": "{link} が正しいことを確認してください。", + "xpack.monitoring.logs.reason.noNodeTitle": "この Elasticsearch ノードにはログがありません", + "xpack.monitoring.logs.reason.notUsingStructuredLogsLink": "JSONログを参照します", + "xpack.monitoring.logs.reason.notUsingStructuredLogsMessage": "{varPaths}設定{link}かどうかを確認", + "xpack.monitoring.logs.reason.notUsingStructuredLogsTitle": "構造化されたログが見つかりません", + "xpack.monitoring.logs.reason.noTypeLink": "これらの方向", + "xpack.monitoring.logs.reason.noTypeMessage": "{link} に従って Elasticsearch をセットアップしてください。", + "xpack.monitoring.logs.reason.noTypeTitle": "Elasticsearch のログがありません", + "xpack.monitoring.logstash.clusterStatus.eventsEmittedLabel": "送信イベント", + "xpack.monitoring.logstash.clusterStatus.eventsReceivedLabel": "受信イベント", + "xpack.monitoring.logstash.clusterStatus.memoryLabel": "メモリー", + "xpack.monitoring.logstash.clusterStatus.nodesLabel": "ノード", + "xpack.monitoring.logstash.detailStatus.batchSizeLabel": "バッチサイズ", + "xpack.monitoring.logstash.detailStatus.configReloadsLabel": "構成の再読み込み", + "xpack.monitoring.logstash.detailStatus.eventsEmittedLabel": "送信イベント", + "xpack.monitoring.logstash.detailStatus.eventsReceivedLabel": "受信イベント", + "xpack.monitoring.logstash.detailStatus.pipelineWorkersLabel": "パイプラインワーカー", + "xpack.monitoring.logstash.detailStatus.queueTypeLabel": "キュータイプ", + "xpack.monitoring.logstash.detailStatus.transportAddressLabel": "トランスポートアドレス", + "xpack.monitoring.logstash.detailStatus.uptimeLabel": "起動時間", + "xpack.monitoring.logstash.detailStatus.versionLabel": "バージョン", + "xpack.monitoring.logstash.filterNodesPlaceholder": "ノードをフィルタリング…", + "xpack.monitoring.logstash.filterPipelinesPlaceholder": "パイプラインのフィルタリング…", + "xpack.monitoring.logstash.node.advanced.routeTitle": "Logstash - {nodeName} - 高度な設定", + "xpack.monitoring.logstash.node.pipelines.notAvailableDescription": "パイプラインの監視は Logstash バージョン 6.0.0 以降でのみ利用できます。このノードはバージョン {logstashVersion} を実行しています。", + "xpack.monitoring.logstash.node.pipelines.routeTitle": "Logstash - {nodeName} - パイプライン", + "xpack.monitoring.logstash.node.routeTitle": "Logstash - {nodeName}", + "xpack.monitoring.logstash.nodes.configReloadsFailuresCountLabel": "{reloadsFailures} 失敗", + "xpack.monitoring.logstash.nodes.configReloadsSuccessCountLabel": "{reloadsSuccesses} 成功", + "xpack.monitoring.logstash.nodes.configReloadsTitle": "構成の再読み込み", + "xpack.monitoring.logstash.nodes.cpuUsageTitle": "CPU 使用状況", + "xpack.monitoring.logstash.nodes.eventsIngestedTitle": "イベントが投入されました", + "xpack.monitoring.logstash.nodes.jvmHeapUsedTitle": "{javaVirtualMachine} ヒープを使用中", + "xpack.monitoring.logstash.nodes.loadAverageTitle": "平均負荷", + "xpack.monitoring.logstash.nodes.nameTitle": "名前", + "xpack.monitoring.logstash.nodes.versionTitle": "バージョン", + "xpack.monitoring.logstash.pipeline.detailDrawer.conditionalStatementDescription": "これはパイプラインのコンディションのステートメントです。", + "xpack.monitoring.logstash.pipeline.detailDrawer.eventsEmittedLabel": "送信イベント", + "xpack.monitoring.logstash.pipeline.detailDrawer.eventsEmittedRateLabel": "イベント送信レート", + "xpack.monitoring.logstash.pipeline.detailDrawer.eventsLatencyLabel": "イベントレイテンシ", + "xpack.monitoring.logstash.pipeline.detailDrawer.eventsReceivedLabel": "受信イベント", + "xpack.monitoring.logstash.pipeline.detailDrawer.noMetricsForIfDescription": "現在この if 条件で表示するメトリックがありません。", + "xpack.monitoring.logstash.pipeline.detailDrawer.noMetricsForQueueDescription": "現在このキューに表示するメトリックがありません。", + "xpack.monitoring.logstash.pipeline.detailDrawer.specifyVertexIdDescription": "この {vertexType} には指定された ID がありません。ID を指定することで、パイプラインの変更時にその差をトラッキングできます。このプラグインの ID を次のように指定できます:", + "xpack.monitoring.logstash.pipeline.detailDrawer.structureDescription": "これは Logstash でインプットと残りのパイプラインの間のイベントのバッファリングに使用される内部構造です。", + "xpack.monitoring.logstash.pipeline.detailDrawer.vertexIdDescription": "この {vertexType} の ID は {vertexId} です。", + "xpack.monitoring.logstash.pipeline.queue.noMetricsDescription": "キューメトリックが利用できません", + "xpack.monitoring.logstash.pipeline.relativeFirstSeenAgoLabel": "{relativeFirstSeen} 前", + "xpack.monitoring.logstash.pipeline.relativeLastSeenAgoLabel": "{relativeLastSeen} 前まで", + "xpack.monitoring.logstash.pipeline.relativeLastSeenNowLabel": "今", + "xpack.monitoring.logstash.pipeline.routeTitle": "Logstash - パイプライン", + "xpack.monitoring.logstash.pipelines.eventsEmittedRateTitle": "イベント送信レート", + "xpack.monitoring.logstash.pipelines.idTitle": "ID", + "xpack.monitoring.logstash.pipelines.numberOfNodesTitle": "ノード数", + "xpack.monitoring.logstash.pipelineStatement.viewDetailsAriaLabel": "詳細を表示", + "xpack.monitoring.logstash.pipelineViewer.filtersTitle": "フィルター", + "xpack.monitoring.logstash.pipelineViewer.inputsTitle": "インプット", + "xpack.monitoring.logstash.pipelineViewer.outputsTitle": "アウトプット", + "xpack.monitoring.logstashNavigation.instance.advancedLinkText": "高度な設定", + "xpack.monitoring.logstashNavigation.instance.overviewLinkText": "概要", + "xpack.monitoring.logstashNavigation.instance.pipelinesLinkText": "パイプライン", + "xpack.monitoring.logstashNavigation.nodesLinkText": "ノード", + "xpack.monitoring.logstashNavigation.overviewLinkText": "概要", + "xpack.monitoring.logstashNavigation.pipelinesLinkText": "パイプライン", + "xpack.monitoring.logstashNavigation.pipelineVersionDescription": "バージョンは {relativeLastSeen} 時点でアクティブ、初回検知 {relativeFirstSeen}", + "xpack.monitoring.metricbeatMigration.apmInstructions.configureMetricbeatDescription": "{file} にこれらの変更を加えます。", + "xpack.monitoring.metricbeatMigration.apmInstructions.configureMetricbeatTitle": "Metricbeat を構成して監視クラスターに送ります", + "xpack.monitoring.metricbeatMigration.apmInstructions.disableInternalCollection.description": "APM サーバーの構成ファイル ({file}) に次の設定を追加します:", + "xpack.monitoring.metricbeatMigration.apmInstructions.disableInternalCollection.note": "この変更後、APM サーバーの再起動が必要です。", + "xpack.monitoring.metricbeatMigration.apmInstructions.disableInternalCollection.title": "APM サーバーの監視メトリックの内部収集を無効にする", + "xpack.monitoring.metricbeatMigration.apmInstructions.enableMetricbeatModuleDescription": "モジュールはデフォルトで http://localhost:5066 から APM サーバーの監視メトリックを収集します。ローカル APM サーバーのアドレスが異なる場合は、{file} ファイルの {hosts} 設定で指定する必要があります。", + "xpack.monitoring.metricbeatMigration.apmInstructions.enableMetricbeatModuleTitle": "Metricbeat の Beat X-Pack モジュールの有効化と構成", + "xpack.monitoring.metricbeatMigration.apmInstructions.installMetricbeatLinkText": "こちらの手順に従ってください", + "xpack.monitoring.metricbeatMigration.apmInstructions.installMetricbeatTitle": "Metricbeat を APM サーバーと同じサーバーにインストール", + "xpack.monitoring.metricbeatMigration.apmInstructions.startMetricbeatLinkText": "こちらの手順に従ってください", + "xpack.monitoring.metricbeatMigration.apmInstructions.startMetricbeatTitle": "Metricbeat を起動します", + "xpack.monitoring.metricbeatMigration.beatsInstructions.configureMetricbeatDescription": "{file} にこれらの変更を加えます。", + "xpack.monitoring.metricbeatMigration.beatsInstructions.configureMetricbeatTitle": "Metricbeat を構成して監視クラスターに送ります", + "xpack.monitoring.metricbeatMigration.beatsInstructions.disableInternalCollection.description": "{beatType} の構成ファイル ({file}) に次の設定を追加します:", + "xpack.monitoring.metricbeatMigration.beatsInstructions.disableInternalCollection.note": "この変更後、{beatType} の再起動が必要です。", + "xpack.monitoring.metricbeatMigration.beatsInstructions.disableInternalCollection.title": "{beatType} の監視メトリックの自己監視を無効にする", + "xpack.monitoring.metricbeatMigration.beatsInstructions.enableMetricbeatModuleDescription": "モジュールはデフォルトで http://localhost:5066 から {beatType} 監視メトリックを収集します。監視されている {beatType} インスタンスのアドレスが異なる場合は、{file} ファイルの {hosts} 設定で指定する必要があります。", + "xpack.monitoring.metricbeatMigration.beatsInstructions.enableMetricbeatModuleHttpEnabledDirections": "Metricbeat が実行中の {beatType} からメトリックを収集するには、{link} 必要があります。", + "xpack.monitoring.metricbeatMigration.beatsInstructions.enableMetricbeatModuleHttpEnabledDirectionsLinkText": "監視されている {beatType} の HTTP エンドポイントを有効にする", + "xpack.monitoring.metricbeatMigration.beatsInstructions.enableMetricbeatModuleTitle": "Metricbeat の Beat X-Pack モジュールの有効化と構成", + "xpack.monitoring.metricbeatMigration.beatsInstructions.installMetricbeatLinkText": "こちらの手順に従ってください", + "xpack.monitoring.metricbeatMigration.beatsInstructions.installMetricbeatTitle": "Metricbeat を {beatType} と同じサーバーにインストール", + "xpack.monitoring.metricbeatMigration.beatsInstructions.startMetricbeatLinkText": "こちらの手順に従ってください", + "xpack.monitoring.metricbeatMigration.beatsInstructions.startMetricbeatTitle": "Metricbeat を起動します", + "xpack.monitoring.metricbeatMigration.disableInternalCollection.fullyMigratedStatusDescription": "自己監視からのドキュメントがありません。移行完了!", + "xpack.monitoring.metricbeatMigration.disableInternalCollection.fullyMigratedStatusTitle": "おめでとうございます!", + "xpack.monitoring.metricbeatMigration.disableInternalCollection.partiallyMigratedStatusDescription": "最後の自己監視は {secondsSinceLastInternalCollectionLabel} 前です。", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.configureMetricbeatDescription": "{file} を変更して接続情報を設定します。:", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.configureMetricbeatTitle": "Metricbeat を構成して監視クラスターに送ります", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.disableInternalCollectionDescription": "Elasticsearch 監視メトリックの自己監視を無効にする本番クラスターの各サーバーの {monospace} を false に設定します。", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.disableInternalCollectionTitle": "Elasticsearch 監視メトリックの内部収集を無効にする", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.enableMetricbeatModuleDescription": "デフォルトで、モジュールは {url} から Elasticsearch メトリックを収集します。ローカルサーバーのアドレスが異なる場合は、{module} のホスト設定に追加します。", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.enableMetricbeatModuleInstallDirectory": "インストールディレクトリから次のファイルを実行します:", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.enableMetricbeatModuleTitle": "Metricbeat の Elasticsearch X-Pack モジュールの有効化と構成", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.installMetricbeatLinkText": "こちらの手順に従ってください", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.installMetricbeatTitle": "Metricbeat を Elasticsearch と同じサーバーにインストール", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.startMetricbeatLinkText": "こちらの手順に従ってください", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.startMetricbeatTitle": "Metricbeat を起動します", + "xpack.monitoring.metricbeatMigration.flyout.closeButtonLabel": "閉じる", + "xpack.monitoring.metricbeatMigration.flyout.doneButtonLabel": "完了", + "xpack.monitoring.metricbeatMigration.flyout.flyoutTitle": "Metricbeat で「{instanceName}」の {instanceIdentifier} を監視", + "xpack.monitoring.metricbeatMigration.flyout.flyoutTitleNewUser": "Metricbeat で「{instanceName}」の {instanceIdentifier} を監視", + "xpack.monitoring.metricbeatMigration.flyout.learnMore": "詳細な理由", + "xpack.monitoring.metricbeatMigration.flyout.nextButtonLabel": "次へ", + "xpack.monitoring.metricbeatMigration.flyout.noClusterUuidCheckboxLabel": "はい、\n この {productName} {instanceIdentifier} スタンドアロンクラスターを調べる必要があることを理解しています。", + "xpack.monitoring.metricbeatMigration.flyout.noClusterUuidDescription": "この {productName} {instanceIdentifier} は Elasticsearch クラスターに接続されていないため、完全に移行された時点で、この {productName} {instanceIdentifier} はこのクラスターではなくスタンドアロンクラスターに表示されます。 {link}", + "xpack.monitoring.metricbeatMigration.flyout.noClusterUuidTitle": "クラスターが検出されてませんでした", + "xpack.monitoring.metricbeatMigration.flyout.step1.monitoringUrlHelpText": "通常 1 つの URL です。複数 URL の場合、コンマで区切ります。\n 実行中の Metricbeat インスタンスは、これらの Elasticsearch サーバーとの通信が必要です。", + "xpack.monitoring.metricbeatMigration.flyout.step1.monitoringUrlLabel": "監視クラスター URL", + "xpack.monitoring.metricbeatMigration.fullyMigratedStatusDescription": "Metricbeat は監視データを送信しています。", + "xpack.monitoring.metricbeatMigration.fullyMigratedStatusTitle": "おめでとうございます!", + "xpack.monitoring.metricbeatMigration.isInternalCollectorStatusTitle": "監視データは検出されませんでしたが、引き続き確認します。", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.configureMetricbeatDescription": "{file} にこれらの変更を加えます。", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.configureMetricbeatTitle": "Metricbeat を構成して監視クラスターに送ります", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.disableInternalCollection.description": "この設定を {file} に追加します。", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.disableInternalCollection.note": "{config} ではデフォルト値 ({defaultValue}) のままにしてください。", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.disableInternalCollection.restartNote": "このステップには Kibana サーバーの再起動が必要です。サーバーの再起動が完了するまでエラーが表示されます。", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.disableInternalCollection.restartWarningTitle": "警告", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.disableInternalCollection.title": "Kibana 監視メトリックの内部収集を無効にする", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.enableMetricbeatModuleDescription": "モジュールはデフォルトで http://localhost:5601 から Kibana 監視メトリックを収集します。ローカル Kibana インスタンスのアドレスが異なる場合は、{file} ファイルの {hosts} 設定で指定する必要があります。", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.enableMetricbeatModuleTitle": "Metricbeat の Kibana X-Pack もウールの有効化と構成", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.installMetricbeatLinkText": "こちらの手順に従ってください", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.installMetricbeatTitle": "Metricbeat を Kibana と同じサーバーにインストール", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.startMetricbeatLinkText": "こちらの手順に従ってください", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.startMetricbeatTitle": "Metricbeat を起動します", + "xpack.monitoring.metricbeatMigration.logstashInstructions.configureMetricbeatDescription": "{file} にこれらの変更を加えます。", + "xpack.monitoring.metricbeatMigration.logstashInstructions.configureMetricbeatTitle": "Metricbeat を構成して監視クラスターに送ります", + "xpack.monitoring.metricbeatMigration.logstashInstructions.disableInternalCollection.description": "Logstash 構成ファイル ({file}) に次の設定を追加します:", + "xpack.monitoring.metricbeatMigration.logstashInstructions.disableInternalCollection.note": "この変更後、Logstash の再起動が必要です。", + "xpack.monitoring.metricbeatMigration.logstashInstructions.disableInternalCollection.title": "Logstash 監視メトリックの内部収集を無効にする", + "xpack.monitoring.metricbeatMigration.logstashInstructions.enableMetricbeatModuleDescription": "モジュールはデフォルトで http://localhost:9600 から Logstash 監視メトリックを収集します。ローカル Logstash インスタンスのアドレスが異なる場合は、{file} ファイルの {hosts} 設定で指定する必要があります。", + "xpack.monitoring.metricbeatMigration.logstashInstructions.enableMetricbeatModuleTitle": "Metricbeat の Logstash X-Pack もウールの有効化と構成", + "xpack.monitoring.metricbeatMigration.logstashInstructions.installMetricbeatLinkText": "こちらの手順に従ってください", + "xpack.monitoring.metricbeatMigration.logstashInstructions.installMetricbeatTitle": "Metricbeat を Logstash と同じサーバーにインストール", + "xpack.monitoring.metricbeatMigration.logstashInstructions.startMetricbeatLinkText": "こちらの手順に従ってください", + "xpack.monitoring.metricbeatMigration.logstashInstructions.startMetricbeatTitle": "Metricbeat を起動します", + "xpack.monitoring.metricbeatMigration.migrationStatus": "移行ステータス", + "xpack.monitoring.metricbeatMigration.monitoringStatus": "監視ステータス", + "xpack.monitoring.metricbeatMigration.partiallyMigratedStatusDescription": "データの検出には最長 {secondsAgo} 秒かかる場合があります。", + "xpack.monitoring.metricbeatMigration.partiallyMigratedStatusTitle": "まだ自己監視からのデータが届いています", + "xpack.monitoring.metricbeatMigration.securitySetup": "セキュリティが有効の場合、{link} が必要な可能性があります。", + "xpack.monitoring.metricbeatMigration.securitySetupLinkText": "追加設定", + "xpack.monitoring.metrics.apm.outputAckedEventsRate.ackedDescription": "アウトプットにより処理されたイベントです (再試行を含む)", + "xpack.monitoring.metrics.apm.outputAckedEventsRate.ackedLabel": "承認済み", + "xpack.monitoring.metrics.apm.outputAckedEventsRateTitle": "アウトプット承認イベントレート", + "xpack.monitoring.metrics.apm.outputActiveEventsRate.activeDescription": "アウトプットにより処理されたイベントです (再試行を含む)", + "xpack.monitoring.metrics.apm.outputActiveEventsRate.activeLabel": "アクティブ", + "xpack.monitoring.metrics.apm.outputActiveEventsRateTitle": "アウトプットアクティブイベントレート", + "xpack.monitoring.metrics.apm.outputDroppedEventsRate.droppedDescription": "アウトプットにより処理されたイベントです (再試行を含む)", + "xpack.monitoring.metrics.apm.outputDroppedEventsRate.droppedLabel": "ドロップ", + "xpack.monitoring.metrics.apm.outputDroppedEventsRateTitle": "アウトプットのイベントドロップレート", + "xpack.monitoring.metrics.apm.outputEventsRate.totalDescription": "アウトプットにより処理されたイベントです (再試行を含む)", + "xpack.monitoring.metrics.apm.outputEventsRate.totalLabel": "合計", + "xpack.monitoring.metrics.apm.outputEventsRateTitle": "アウトプットイベントレート", + "xpack.monitoring.metrics.apm.outputFailedEventsRate.failedDescription": "アウトプットにより処理されたイベントです (再試行を含む)", + "xpack.monitoring.metrics.apm.outputFailedEventsRate.failedLabel": "失敗", + "xpack.monitoring.metrics.apm.outputFailedEventsRateTitle": "アウトプットイベント失敗率", + "xpack.monitoring.metrics.apm.perMinuteUnitLabel": "/m", + "xpack.monitoring.metrics.apm.processedEvents.transactionDescription": "処理されたトランザクションイベントです", + "xpack.monitoring.metrics.apm.processedEvents.transactionLabel": "トランザクション", + "xpack.monitoring.metrics.apm.processedEventsTitle": "処理済みのイベント", + "xpack.monitoring.metrics.apm.requests.requestedDescription": "サーバーから受信した HTTP リクエストです", + "xpack.monitoring.metrics.apm.requests.requestedLabel": "リクエストされました", + "xpack.monitoring.metrics.apm.requestsTitle": "リクエストカウントインテーク API", + "xpack.monitoring.metrics.apm.response.acceptedDescription": "新規イベントを正常にレポートしている HTTP リクエストです", + "xpack.monitoring.metrics.apm.response.acceptedLabel": "受領", + "xpack.monitoring.metrics.apm.response.acceptedTitle": "受領", + "xpack.monitoring.metrics.apm.response.okDescription": "200 OK 応答カウント", + "xpack.monitoring.metrics.apm.response.okLabel": "OK", + "xpack.monitoring.metrics.apm.response.okTitle": "OK", + "xpack.monitoring.metrics.apm.responseCount.totalDescription": "サーバーにより応答された HTTP リクエストです", + "xpack.monitoring.metrics.apm.responseCount.totalLabel": "合計", + "xpack.monitoring.metrics.apm.responseCountTitle": "レスポンスカウントインテーク API", + "xpack.monitoring.metrics.apm.responseErrors.closedDescription": "サーバーのシャットダウン中に拒否された HTTP リクエストです", + "xpack.monitoring.metrics.apm.responseErrors.closedLabel": "クローズ済み", + "xpack.monitoring.metrics.apm.responseErrors.closedTitle": "クローズ済み", + "xpack.monitoring.metrics.apm.responseErrors.concurrencyDescription": "全体的な同時実行制限を超えたため拒否された HTTP リクエストです", + "xpack.monitoring.metrics.apm.responseErrors.concurrencyLabel": "同時実行", + "xpack.monitoring.metrics.apm.responseErrors.concurrencyTitle": "同時実行", + "xpack.monitoring.metrics.apm.responseErrors.decodeDescription": "デコードエラーのため拒否された HTTP リクエストです - 無効な JSON、エンティティに対し誤った接続データタイプ", + "xpack.monitoring.metrics.apm.responseErrors.decodeLabel": "デコード", + "xpack.monitoring.metrics.apm.responseErrors.decodeTitle": "デコード", + "xpack.monitoring.metrics.apm.responseErrors.forbiddenDescription": "禁止されていて拒否された HTTP リクエストです - CORS 違反、無効なエンドポイント", + "xpack.monitoring.metrics.apm.responseErrors.forbiddenLabel": "禁止", + "xpack.monitoring.metrics.apm.responseErrors.forbiddenTitle": "禁止", + "xpack.monitoring.metrics.apm.responseErrors.internalDescription": "様々な内部エラーのため拒否された HTTP リクエストです", + "xpack.monitoring.metrics.apm.responseErrors.internalLabel": "内部", + "xpack.monitoring.metrics.apm.responseErrors.internalTitle": "内部", + "xpack.monitoring.metrics.apm.responseErrors.methodDescription": "HTTP メソドが正しくなかったため拒否された HTTP リクエストです", + "xpack.monitoring.metrics.apm.responseErrors.methodLabel": "メソド", + "xpack.monitoring.metrics.apm.responseErrors.methodTitle": "メソド", + "xpack.monitoring.metrics.apm.responseErrors.queueDescription": "内部キューが貯まっていたため拒否された HTTP リクエストです", + "xpack.monitoring.metrics.apm.responseErrors.queueLabel": "キュー", + "xpack.monitoring.metrics.apm.responseErrors.queueTitle": "キュー", + "xpack.monitoring.metrics.apm.responseErrors.rateLimitDescription": "過剰なレート制限のため拒否された HTTP リクエストです", + "xpack.monitoring.metrics.apm.responseErrors.rateLimitLabel": "レート制限", + "xpack.monitoring.metrics.apm.responseErrors.rateLimitTitle": "レート制限", + "xpack.monitoring.metrics.apm.responseErrors.tooLargeLabelDescription": "過剰なペイロードサイズのため拒否された HTTP リクエストです", + "xpack.monitoring.metrics.apm.responseErrors.tooLargeLabelTitle": "サイズ超過", + "xpack.monitoring.metrics.apm.responseErrors.unauthorizedDescription": "無効な秘密トークンのため拒否された HTTP リクエストです", + "xpack.monitoring.metrics.apm.responseErrors.unauthorizedLabel": "不正", + "xpack.monitoring.metrics.apm.responseErrors.unauthorizedTitle": "不正", + "xpack.monitoring.metrics.apm.responseErrors.validateDescription": "ペイロード違反エラーのため拒否された HTTP リクエストです", + "xpack.monitoring.metrics.apm.responseErrors.validateLabel": "検証", + "xpack.monitoring.metrics.apm.responseErrors.validateTitle": "検証", + "xpack.monitoring.metrics.apm.responseErrorsTitle": "レスポンスエラーインテーク API", + "xpack.monitoring.metrics.apm.transformations.errorDescription": "処理されたエラーイベントです", + "xpack.monitoring.metrics.apm.transformations.errorLabel": "エラー", + "xpack.monitoring.metrics.apm.transformations.metricDescription": "処理されたメトリックイベントです", + "xpack.monitoring.metrics.apm.transformations.metricLabel": "メトリック", + "xpack.monitoring.metrics.apm.transformations.spanDescription": "処理されたスパンイベントです", + "xpack.monitoring.metrics.apm.transformations.spanLabel": "スパン", + "xpack.monitoring.metrics.apm.transformationsTitle": "変換", + "xpack.monitoring.metrics.apmInstance.cpuUtilization.totalDescription": "APM プロセスに使用された CPU 時間のパーセンテージです (user+kernel モード)", + "xpack.monitoring.metrics.apmInstance.cpuUtilization.totalLabel": "合計", + "xpack.monitoring.metrics.apmInstance.cpuUtilizationTitle": "CPU 使用状況", + "xpack.monitoring.metrics.apmInstance.memory.allocatedMemoryDescription": "割当メモリー", + "xpack.monitoring.metrics.apmInstance.memory.allocatedMemoryLabel": "割当メモリー", + "xpack.monitoring.metrics.apmInstance.memory.gcNextDescription": "ガーベージコレクションが行われるメモリー割当の制限です", + "xpack.monitoring.metrics.apmInstance.memory.gcNextLabel": "GC Next", + "xpack.monitoring.metrics.apmInstance.memory.processTotalDescription": "APM サービスにより OS から確保されたメモリーの RSS です", + "xpack.monitoring.metrics.apmInstance.memory.processTotalLabel": "プロセス合計", + "xpack.monitoring.metrics.apmInstance.memoryTitle": "メモリー", + "xpack.monitoring.metrics.apmInstance.systemLoad.last15MinutesDescription": "過去 15 分間の平均負荷です", + "xpack.monitoring.metrics.apmInstance.systemLoad.last15MinutesLabel": "15m", + "xpack.monitoring.metrics.apmInstance.systemLoad.last1MinuteDescription": "過去 1 分間の平均負荷です", + "xpack.monitoring.metrics.apmInstance.systemLoad.last1MinuteLabel": "1m", + "xpack.monitoring.metrics.apmInstance.systemLoad.last5MinutesDescription": "過去 5 分間の平均負荷です", + "xpack.monitoring.metrics.apmInstance.systemLoad.last5MinutesLabel": "5m", + "xpack.monitoring.metrics.apmInstance.systemLoadTitle": "システム負荷", + "xpack.monitoring.metrics.beats.eventsRate.acknowledgedDescription": "インプットに認識されたイベントです (アウトプットにドロップされたイベントを含む)", + "xpack.monitoring.metrics.beats.eventsRate.acknowledgedLabel": "認識", + "xpack.monitoring.metrics.beats.eventsRate.emittedDescription": "アウトプットにより処理されたイベントです (再試行を含む)", + "xpack.monitoring.metrics.beats.eventsRate.emittedLabel": "送信", + "xpack.monitoring.metrics.beats.eventsRate.queuedDescription": "イベントパイプラインキューに追加されたイベントです", + "xpack.monitoring.metrics.beats.eventsRate.queuedLabel": "キュー", + "xpack.monitoring.metrics.beats.eventsRate.totalDescription": "パブリッシュするパイプラインで新規作成されたすべてのイベントです", + "xpack.monitoring.metrics.beats.eventsRate.totalLabel": "合計", + "xpack.monitoring.metrics.beats.eventsRateTitle": "イベントレート", + "xpack.monitoring.metrics.beats.failRates.droppedInOutputDescription": "(致命的なドロップ) アウトプットに「無効」としてドロップされたイベントです。 この場合もアウトプットはビートがキューから削除できるようイベントを認識します。", + "xpack.monitoring.metrics.beats.failRates.droppedInOutputLabel": "アウトプットでドロップ", + "xpack.monitoring.metrics.beats.failRates.droppedInPipelineDescription": "N 回の試行後ドロップされたtイベントです (N = max_retries 設定)", + "xpack.monitoring.metrics.beats.failRates.droppedInPipelineLabel": "パイプラインでドロップ", + "xpack.monitoring.metrics.beats.failRates.failedInPipelineDescription": "イベントがパブリッシュするパイプラインに追加される前の失敗です (アウトプットが無効またはパブリッシャークライアントがクローズ)", + "xpack.monitoring.metrics.beats.failRates.failedInPipelineLabel": "パイプラインで失敗", + "xpack.monitoring.metrics.beats.failRates.retryInPipelineDescription": "アウトプットへの送信を再試行中のパイプライン内のイベントです", + "xpack.monitoring.metrics.beats.failRates.retryInPipelineLabel": "パイプラインで再試行", + "xpack.monitoring.metrics.beats.failRatesTitle": "失敗率", + "xpack.monitoring.metrics.beats.outputErrors.receivingDescription": "アウトプットからの応答の読み込み中のエラーです", + "xpack.monitoring.metrics.beats.outputErrors.receivingLabel": "受信", + "xpack.monitoring.metrics.beats.outputErrors.sendingDescription": "アウトプットからの応答の書き込み中のエラーです", + "xpack.monitoring.metrics.beats.outputErrors.sendingLabel": "送信", + "xpack.monitoring.metrics.beats.outputErrorsTitle": "アウトプットエラー", + "xpack.monitoring.metrics.beats.perSecondUnitLabel": "/s", + "xpack.monitoring.metrics.beats.throughput.bytesReceivedDescription": "アウトプットからの応答から読み込まれたバイト数です", + "xpack.monitoring.metrics.beats.throughput.bytesReceivedLabel": "受信イベント", + "xpack.monitoring.metrics.beats.throughput.bytesSentDescription": "アウトプットに書き込まれたバイト数です (ネットワークヘッダーと圧縮されたペイロードのサイズで構成されています)", + "xpack.monitoring.metrics.beats.throughput.bytesSentLabel": "送信バイト数", + "xpack.monitoring.metrics.beats.throughputTitle": "スループット", + "xpack.monitoring.metrics.beatsInstance.cpuUtilization.totalDescription": "ビートプロセスに使用された CPU 時間のパーセンテージです (user+kernel モード)", + "xpack.monitoring.metrics.beatsInstance.cpuUtilization.totalLabel": "合計", + "xpack.monitoring.metrics.beatsInstance.cpuUtilizationTitle": "CPU 使用状況", + "xpack.monitoring.metrics.beatsInstance.eventsRate.acknowledgedDescription": "インプットに認識されたイベントです (アウトプットにドロップされたイベントを含む)", + "xpack.monitoring.metrics.beatsInstance.eventsRate.acknowledgedLabel": "認識", + "xpack.monitoring.metrics.beatsInstance.eventsRate.emittedDescription": "アウトプットにより処理されたイベントです (再試行を含む)", + "xpack.monitoring.metrics.beatsInstance.eventsRate.emittedLabel": "送信", + "xpack.monitoring.metrics.beatsInstance.eventsRate.newDescription": "パブリッシュするパイプラインに送信された新規イベントです", + "xpack.monitoring.metrics.beatsInstance.eventsRate.newLabel": "新規", + "xpack.monitoring.metrics.beatsInstance.eventsRate.queuedDescription": "イベントパイプラインキューに追加されたイベントです", + "xpack.monitoring.metrics.beatsInstance.eventsRate.queuedLabel": "キュー", + "xpack.monitoring.metrics.beatsInstance.eventsRateTitle": "イベントレート", + "xpack.monitoring.metrics.beatsInstance.failRates.droppedInOutputDescription": "(致命的なドロップ) アウトプットに「無効」としてドロップされたイベントです。 この場合もアウトプットはビートがキューから削除できるようイベントを認識します。", + "xpack.monitoring.metrics.beatsInstance.failRates.droppedInOutputLabel": "アウトプットでドロップ", + "xpack.monitoring.metrics.beatsInstance.failRates.droppedInPipelineDescription": "N 回の試行後ドロップされたtイベントです (N = max_retries 設定)", + "xpack.monitoring.metrics.beatsInstance.failRates.droppedInPipelineLabel": "パイプラインでドロップ", + "xpack.monitoring.metrics.beatsInstance.failRates.failedInPipelineDescription": "イベントがパブリッシュするパイプラインに追加される前の失敗です (アウトプットが無効またはパブリッシャークライアントがクローズ)", + "xpack.monitoring.metrics.beatsInstance.failRates.failedInPipelineLabel": "パイプラインで失敗", + "xpack.monitoring.metrics.beatsInstance.failRates.retryInPipelineDescription": "アウトプットへの送信を再試行中のパイプライン内のイベントです", + "xpack.monitoring.metrics.beatsInstance.failRates.retryInPipelineLabel": "パイプラインで再試行", + "xpack.monitoring.metrics.beatsInstance.failRatesTitle": "失敗率", + "xpack.monitoring.metrics.beatsInstance.memory.activeDescription": "ビートによりアクティブに使用されているプライベートメモリーです", + "xpack.monitoring.metrics.beatsInstance.memory.activeLabel": "アクティブ", + "xpack.monitoring.metrics.beatsInstance.memory.gcNextDescription": "ガーベージコレクションが行われるメモリー割当の制限です", + "xpack.monitoring.metrics.beatsInstance.memory.gcNextLabel": "GC Next", + "xpack.monitoring.metrics.beatsInstance.memory.processTotalDescription": "ビートにより OS から確保されたメモリーの RSS です", + "xpack.monitoring.metrics.beatsInstance.memory.processTotalLabel": "プロセス合計", + "xpack.monitoring.metrics.beatsInstance.memoryTitle": "メモリー", + "xpack.monitoring.metrics.beatsInstance.openHandlesDescription": "オープンのファイルハンドラーのカウントです", + "xpack.monitoring.metrics.beatsInstance.openHandlesLabel": "オープンハンドラー", + "xpack.monitoring.metrics.beatsInstance.openHandlesTitle": "オープンハンドラー", + "xpack.monitoring.metrics.beatsInstance.outputErrors.receivingDescription": "アウトプットからの応答の読み込み中のエラーです", + "xpack.monitoring.metrics.beatsInstance.outputErrors.receivingLabel": "受信", + "xpack.monitoring.metrics.beatsInstance.outputErrors.sendingDescription": "アウトプットからの応答の書き込み中のエラーです", + "xpack.monitoring.metrics.beatsInstance.outputErrors.sendingLabel": "送信", + "xpack.monitoring.metrics.beatsInstance.outputErrorsTitle": "アウトプットエラー", + "xpack.monitoring.metrics.beatsInstance.systemLoad.last15MinutesDescription": "過去 15 分間の平均負荷です", + "xpack.monitoring.metrics.beatsInstance.systemLoad.last15MinutesLabel": "15m", + "xpack.monitoring.metrics.beatsInstance.systemLoad.last1MinuteDescription": "過去 1 分間の平均負荷です", + "xpack.monitoring.metrics.beatsInstance.systemLoad.last1MinuteLabel": "1m", + "xpack.monitoring.metrics.beatsInstance.systemLoad.last5MinutesDescription": "過去 5 分間の平均負荷です", + "xpack.monitoring.metrics.beatsInstance.systemLoad.last5MinutesLabel": "5m", + "xpack.monitoring.metrics.beatsInstance.systemLoadTitle": "システム負荷", + "xpack.monitoring.metrics.beatsInstance.throughput.bytesReceivedDescription": "アウトプットからの応答から読み込まれたバイト数です", + "xpack.monitoring.metrics.beatsInstance.throughput.bytesReceivedLabel": "受信イベント", + "xpack.monitoring.metrics.beatsInstance.throughput.bytesSentDescription": "アウトプットに書き込まれたバイト数です (ネットワークヘッダーと圧縮されたペイロードのサイズで構成されています)", + "xpack.monitoring.metrics.beatsInstance.throughput.bytesSentLabel": "送信バイト数", + "xpack.monitoring.metrics.beatsInstance.throughputTitle": "スループット", + "xpack.monitoring.metrics.es.indexingLatencyDescription": "ドキュメントのインデックスの平均レイテンシです。ドキュメントのインデックスの所要時間をインデックス数で割った時間です。プライマリシャードのみが含まれています。", + "xpack.monitoring.metrics.es.indexingLatencyLabel": "インデックスレイテンシ", + "xpack.monitoring.metrics.es.indexingRate.primaryShardsDescription": "プライマリシャードにインデックスされたドキュメントの数です。", + "xpack.monitoring.metrics.es.indexingRate.primaryShardsLabel": "プライマリシャード", + "xpack.monitoring.metrics.es.indexingRate.totalShardsDescription": "プライマリとレプリカシャードにインデックスされたドキュメントの数です。", + "xpack.monitoring.metrics.es.indexingRate.totalShardsLabel": "合計シャード", + "xpack.monitoring.metrics.es.indexingRateTitle": "インデックスレート", + "xpack.monitoring.metrics.es.latencyMetricParamErrorMessage": "レイテンシメトリックパラメーターは「index」または「query」と等しい文字列でなければなりません", + "xpack.monitoring.metrics.es.msTimeUnitLabel": "ms", + "xpack.monitoring.metrics.es.nsTimeUnitLabel": "ナノ秒", + "xpack.monitoring.metrics.es.perSecondsUnitLabel": "/秒", + "xpack.monitoring.metrics.es.perSecondTimeUnitLabel": "/s", + "xpack.monitoring.metrics.es.searchLatencyDescription": "検索の平均レイテンシです。検索の実行に所要した時間を送信された検索数で割った時間です。プライマリとレプリカシャードが含まれています。", + "xpack.monitoring.metrics.es.searchLatencyLabel": "検索レイテンシ", + "xpack.monitoring.metrics.es.searchRate.totalShardsDescription": "プライマリとレプリカシャードで実行されている検索リクエストの数です。1 つの検索を複数シャードに対して実行することができます!", + "xpack.monitoring.metrics.es.searchRate.totalShardsLabel": "合計シャード", + "xpack.monitoring.metrics.es.searchRateTitle": "検索レート", + "xpack.monitoring.metrics.es.secondsUnitLabel": "s", + "xpack.monitoring.metrics.esCcr.fetchDelayDescription": "フォロワーインデックスがリーダーから遅れている時間です。", + "xpack.monitoring.metrics.esCcr.fetchDelayLabel": "取得遅延", + "xpack.monitoring.metrics.esCcr.fetchDelayTitle": "取得遅延", + "xpack.monitoring.metrics.esCcr.opsDelayDescription": "フォロワーインデックスがリーダーから遅れているオペレーションの数です。", + "xpack.monitoring.metrics.esCcr.opsDelayLabel": "オペレーション遅延", + "xpack.monitoring.metrics.esCcr.opsDelayTitle": "オペレーション遅延", + "xpack.monitoring.metrics.esIndex.disk.mergesDescription": "プライマリとレプリカシャードの結合サイズです。", + "xpack.monitoring.metrics.esIndex.disk.mergesLabel": "結合", + "xpack.monitoring.metrics.esIndex.disk.mergesPrimariesDescription": "プライマリシャードの結合サイズです。", + "xpack.monitoring.metrics.esIndex.disk.mergesPrimariesLabel": "結合 (プライマリ)", + "xpack.monitoring.metrics.esIndex.disk.storeDescription": "ディスク上のプライマリとレプリカシャードのサイズです。", + "xpack.monitoring.metrics.esIndex.disk.storeLabel": "格納サイズ", + "xpack.monitoring.metrics.esIndex.disk.storePrimariesDescription": "ディスク上のプライマリシャードのサイズです。", + "xpack.monitoring.metrics.esIndex.disk.storePrimariesLabel": "格納サイズ (プライマリ)", + "xpack.monitoring.metrics.esIndex.diskTitle": "ディスク", + "xpack.monitoring.metrics.esIndex.docValuesDescription": "ドキュメント値が使用中のヒープ領域です。Lucene の一部です。", + "xpack.monitoring.metrics.esIndex.docValuesLabel": "ドキュメント値", + "xpack.monitoring.metrics.esIndex.fielddataDescription": "フィールドデータ (例: グローバル序数またはテキストフィールドで特別に有効化されたフィールドデータ) が使用中のヒープ領域です同じシャードのものですが、Lucene 合計には含まれません。", + "xpack.monitoring.metrics.esIndex.fielddataLabel": "フィールドデータ", + "xpack.monitoring.metrics.esIndex.fixedBitsetsDescription": "固定ビットセット (例: ディープネスト構造のドキュメント) が使用中のヒープ領域です。Lucene の一部です。", + "xpack.monitoring.metrics.esIndex.fixedBitsetsLabel": "固定ビットセット", + "xpack.monitoring.metrics.esIndex.indexingRate.primaryShardsDescription": "プライマリシャードにインデックスされたドキュメントの数です。", + "xpack.monitoring.metrics.esIndex.indexingRate.primaryShardsLabel": "プライマリシャード", + "xpack.monitoring.metrics.esIndex.indexingRate.totalShardsDescription": "プライマリとレプリカシャードにインデックスされたドキュメントの数です。", + "xpack.monitoring.metrics.esIndex.indexingRate.totalShardsLabel": "合計シャード", + "xpack.monitoring.metrics.esIndex.indexingRateTitle": "インデックスレート", + "xpack.monitoring.metrics.esIndex.indexMemoryEs.queryCacheDescription": "クエリキャッシュ (例: キャッシュされたフィルター) が使用中のヒープ領域です。同じシャードのものですが、Lucene 合計には含まれません。", + "xpack.monitoring.metrics.esIndex.indexMemoryEs.queryCacheLabel": "クエリキャッシュ", + "xpack.monitoring.metrics.esIndex.indexMemoryEsTitle": "インデックスメモリー - {elasticsearch}", + "xpack.monitoring.metrics.esIndex.indexMemoryLucene1.luceneTotalDescription": "Lucene が現在のインデックスに使用中の合計ヒープ領域です。これはプライマリとレプリカシャードの他のフィールドの合計です。", + "xpack.monitoring.metrics.esIndex.indexMemoryLucene1.luceneTotalLabel": "Lucene 合計", + "xpack.monitoring.metrics.esIndex.indexMemoryLucene1Title": "インデックスメモリー - Lucene 1", + "xpack.monitoring.metrics.esIndex.indexMemoryLucene2.luceneTotalDescription": "Lucene が現在のインデックスに使用中の合計ヒープ領域です。これはプライマリとレプリカシャードの他のフィールドの合計です。", + "xpack.monitoring.metrics.esIndex.indexMemoryLucene2.luceneTotalLabel": "Lucene 合計", + "xpack.monitoring.metrics.esIndex.indexMemoryLucene2Title": "インデックスメモリー - Lucene 2", + "xpack.monitoring.metrics.esIndex.indexMemoryLucene3.luceneTotalDescription": "Lucene が現在のインデックスに使用中の合計ヒープ領域です。これはプライマリとレプリカシャードの他のフィールドの合計です。", + "xpack.monitoring.metrics.esIndex.indexMemoryLucene3.luceneTotalLabel": "Lucene 合計", + "xpack.monitoring.metrics.esIndex.indexMemoryLucene3Title": "インデックスメモリー - Lucene 3", + "xpack.monitoring.metrics.esIndex.indexWriterDescription": "Index Writer が使用中のヒープ領域です。Lucene 合計の一部ではありません。", + "xpack.monitoring.metrics.esIndex.indexWriterLabel": "Index Writer", + "xpack.monitoring.metrics.esIndex.latency.indexingLatencyDescription": "ドキュメントのインデックスの平均レイテンシです。ドキュメントのインデックスの所要時間をインデックス数で割った時間です。プライマリシャードのみが含まれています。", + "xpack.monitoring.metrics.esIndex.latency.indexingLatencyLabel": "インデックスレイテンシ", + "xpack.monitoring.metrics.esIndex.latency.searchLatencyDescription": "検索の平均レイテンシです。検索の実行に所要した時間を送信された検索数で割った時間です。プライマリとレプリカシャードが含まれています。", + "xpack.monitoring.metrics.esIndex.latency.searchLatencyLabel": "検索レイテンシ", + "xpack.monitoring.metrics.esIndex.latencyTitle": "レイテンシ", + "xpack.monitoring.metrics.esIndex.luceneTotalDescription": "Lucene が現在のインデックスに使用中の合計ヒープ領域です。これはプライマリとレプリカシャードの他のフィールドの合計です。", + "xpack.monitoring.metrics.esIndex.luceneTotalLabel": "Lucene 合計", + "xpack.monitoring.metrics.esIndex.normsDescription": "Norms (クエリ時間、テキストスコアリングの規格化因子) が使用中のヒープ領域です。Lucene の一部です。", + "xpack.monitoring.metrics.esIndex.normsLabel": "Norms", + "xpack.monitoring.metrics.esIndex.pointsDescription": "ポイント (例: 数字、IP、地理データ) が使用中のヒープ領域です。Lucene の一部です。", + "xpack.monitoring.metrics.esIndex.pointsLabel": "ポイント", + "xpack.monitoring.metrics.esIndex.refreshTime.primariesDescription": "プライマリシャードの更新オペレーションの所要時間です。", + "xpack.monitoring.metrics.esIndex.refreshTime.primariesLabel": "プライマリ", + "xpack.monitoring.metrics.esIndex.refreshTime.totalDescription": "プライマリとレプリカシャードの更新オペレーションの所要時間です。", + "xpack.monitoring.metrics.esIndex.refreshTime.totalLabel": "合計", + "xpack.monitoring.metrics.esIndex.refreshTimeTitle": "更新時間", + "xpack.monitoring.metrics.esIndex.requestCacheDescription": "リクエストキャッシュ (例: 瞬間集約) が使用中のヒープ領域です。同じシャードのものですが、Lucene 合計には含まれません。", + "xpack.monitoring.metrics.esIndex.requestCacheLabel": "リクエストキャッシュ", + "xpack.monitoring.metrics.esIndex.requestRate.indexTotalDescription": "インデックスオペレーションの数です。", + "xpack.monitoring.metrics.esIndex.requestRate.indexTotalLabel": "インデックス合計", + "xpack.monitoring.metrics.esIndex.requestRate.searchTotalDescription": "検索オペレーションの数です (シャードごと)。", + "xpack.monitoring.metrics.esIndex.requestRate.searchTotalLabel": "検索合計", + "xpack.monitoring.metrics.esIndex.requestRateTitle": "リクエストレート", + "xpack.monitoring.metrics.esIndex.requestTime.indexingDescription": "プライマリとレプリカシャードのインデックスオペレーションの所要時間です。", + "xpack.monitoring.metrics.esIndex.requestTime.indexingLabel": "インデックス", + "xpack.monitoring.metrics.esIndex.requestTime.indexingPrimariesDescription": "プライマリシャードのみのインデックスオペレーションの所要時間です。", + "xpack.monitoring.metrics.esIndex.requestTime.indexingPrimariesLabel": "インデックス (プライマリ)", + "xpack.monitoring.metrics.esIndex.requestTime.searchDescription": "検索オペレーションの所要時間です (シャードごと)。", + "xpack.monitoring.metrics.esIndex.requestTime.searchLabel": "検索", + "xpack.monitoring.metrics.esIndex.requestTimeTitle": "リクエスト時間", + "xpack.monitoring.metrics.esIndex.searchRate.totalShardsDescription": "プライマリとレプリカシャードで実行されている検索リクエストの数です。1 つの検索を複数シャードに対して実行することができます!", + "xpack.monitoring.metrics.esIndex.searchRate.totalShardsLabel": "合計シャード", + "xpack.monitoring.metrics.esIndex.searchRateTitle": "検索レート", + "xpack.monitoring.metrics.esIndex.segmentCount.primariesDescription": "プライマリシャードのセグメント数です。", + "xpack.monitoring.metrics.esIndex.segmentCount.primariesLabel": "プライマリ", + "xpack.monitoring.metrics.esIndex.segmentCount.totalDescription": "プライマリとレプリカシャードのセグメント数です。", + "xpack.monitoring.metrics.esIndex.segmentCount.totalLabel": "合計", + "xpack.monitoring.metrics.esIndex.segmentCountTitle": "セグメントカウント", + "xpack.monitoring.metrics.esIndex.storedFieldsDescription": "格納フィールド (例: _source) が使用中のヒープ領域です。Lucene の一部です。", + "xpack.monitoring.metrics.esIndex.storedFieldsLabel": "格納フィールド", + "xpack.monitoring.metrics.esIndex.termsDescription": "用語が使用中のヒープ領域です (例: テキスト)。Lucene の一部です。", + "xpack.monitoring.metrics.esIndex.termsLabel": "用語", + "xpack.monitoring.metrics.esIndex.termVectorsDescription": "用語ベクトルが使用中のヒープ領域です。Lucene の一部です。", + "xpack.monitoring.metrics.esIndex.termVectorsLabel": "用語ベクトル", + "xpack.monitoring.metrics.esIndex.throttleTime.indexingDescription": "プライマリとレプリカシャードのインデックスオペレーションのスロットリングの所要時間です。", + "xpack.monitoring.metrics.esIndex.throttleTime.indexingLabel": "インデックス", + "xpack.monitoring.metrics.esIndex.throttleTime.indexingPrimariesDescription": "プライマリシャードのインデックスオペレーションのスロットリングの所要時間です。", + "xpack.monitoring.metrics.esIndex.throttleTime.indexingPrimariesLabel": "インデックス (プライマリ)", + "xpack.monitoring.metrics.esIndex.throttleTimeTitle": "スロットル時間", + "xpack.monitoring.metrics.esIndex.versionMapDescription": "バージョニング (例: 更新、削除) が使用中のヒープ領域です。Lucene 合計の一部ではありません。", + "xpack.monitoring.metrics.esIndex.versionMapLabel": "バージョンマップ", + "xpack.monitoring.metrics.esNode.cgroupCfsStats.cgroupElapsedPeriodsDescription": "Completely Fair Scheduler (CFS) からのサンプリング期間の数です。スロットル回数と比較します。", + "xpack.monitoring.metrics.esNode.cgroupCfsStats.cgroupElapsedPeriodsLabel": "Cgroup 経過時間", + "xpack.monitoring.metrics.esNode.cgroupCfsStats.cgroupThrottledCountDescription": "Cgroup により CPU がスロットリングされた回数です。", + "xpack.monitoring.metrics.esNode.cgroupCfsStats.cgroupThrottledCountLabel": "Cgroup スロットルカウント", + "xpack.monitoring.metrics.esNode.cgroupCfsStatsTitle": "Cgroup CFS 統計", + "xpack.monitoring.metrics.esNode.cgroupCpuPerformance.cgroupThrottlingDescription": "Cgroup のナノ秒単位で報告されたスロットル時間です。", + "xpack.monitoring.metrics.esNode.cgroupCpuPerformance.cgroupThrottlingLabel": "Cgroup スロットリング", + "xpack.monitoring.metrics.esNode.cgroupCpuPerformance.cgroupUsageDescription": "Cgroup のナノ秒単位で報告された使用状況です。スロットリングと比較して問題を発見します。", + "xpack.monitoring.metrics.esNode.cgroupCpuPerformance.cgroupUsageLabel": "Cgroup の使用状況", + "xpack.monitoring.metrics.esNode.cgroupCpuPerformanceTitle": "Cgroup CPU パフォーマンス", + "xpack.monitoring.metrics.esNode.cpuUtilization.cgroupCpuUtilizationDescription": "CPU クォータに対する CPU 使用時間のパーセンテージです。CPU クォータが設定されていない場合、データは表示されません。", + "xpack.monitoring.metrics.esNode.cpuUtilization.cgroupCpuUtilizationLabel": "Cgroup CPU 活用状況", + "xpack.monitoring.metrics.esNode.cpuUtilizationDescription": "Elasticsearch プロセスの CPU 使用量のパーセンテージです。", + "xpack.monitoring.metrics.esNode.cpuUtilizationLabel": "CPU 使用状況", + "xpack.monitoring.metrics.esNode.cpuUtilizationTitle": "CPU 使用状況", + "xpack.monitoring.metrics.esNode.diskFreeSpaceDescription": "ノードで利用可能な空きディスク容量です。", + "xpack.monitoring.metrics.esNode.diskFreeSpaceLabel": "ディスクの空き容量", + "xpack.monitoring.metrics.esNode.documentCountDescription": "プライマリシャードのみのドキュメントの合計数です。", + "xpack.monitoring.metrics.esNode.documentCountLabel": "ドキュメントカウント", + "xpack.monitoring.metrics.esNode.docValuesDescription": "ドキュメント値が使用中のヒープ領域です。Lucene の一部です。", + "xpack.monitoring.metrics.esNode.docValuesLabel": "ドキュメント値", + "xpack.monitoring.metrics.esNode.fielddataDescription": "フィールドデータ (例: グローバル序数またはテキストフィールドで特別に有効化されたフィールドデータ) が使用中のヒープ領域です同じシャードのものですが、Lucene 合計には含まれません。", + "xpack.monitoring.metrics.esNode.fielddataLabel": "フィールドデータ", + "xpack.monitoring.metrics.esNode.fixedBitsetsDescription": "固定ビットセット (例: ディープネスト構造のドキュメント) が使用中のヒープ領域です。Lucene の一部です。", + "xpack.monitoring.metrics.esNode.fixedBitsetsLabel": "固定ビットセット", + "xpack.monitoring.metrics.esNode.gcCount.oldDescription": "古いガーベージコレクションの数です。", + "xpack.monitoring.metrics.esNode.gcCount.oldLabel": "古", + "xpack.monitoring.metrics.esNode.gcCount.youngDescription": "新しいガーベージコレクションの数です。", + "xpack.monitoring.metrics.esNode.gcCount.youngLabel": "新", + "xpack.monitoring.metrics.esNode.gcDuration.oldDescription": "古いガーベージコレクションの所要時間です。", + "xpack.monitoring.metrics.esNode.gcDuration.oldLabel": "古", + "xpack.monitoring.metrics.esNode.gcDuration.youngDescription": "新しいガーベージコレクションの所要時間です。", + "xpack.monitoring.metrics.esNode.gcDuration.youngLabel": "新", + "xpack.monitoring.metrics.esNode.gsCountTitle": "GC カウント", + "xpack.monitoring.metrics.esNode.gsDurationTitle": "GC 時間", + "xpack.monitoring.metrics.esNode.indexingThreads.searchRejectionsDescription": "キューがいっぱいの時に拒否された検索オペレーションの数です。", + "xpack.monitoring.metrics.esNode.indexingThreads.searchRejectionsLabel": "検索拒否", + "xpack.monitoring.metrics.esNode.indexingThreads.writeQueueDescription": "キューにあるインデックス、一斉、書き込みオペレーションの数です。6.3 では一斉スレッドプールが書き込みになり、インデックススレッドプールが廃止されました。", + "xpack.monitoring.metrics.esNode.indexingThreads.writeQueueLabel": "書き込みキュー", + "xpack.monitoring.metrics.esNode.indexingThreads.writeRejectionsDescription": "キューがいっぱいの時に拒否されたインデックス、一斉、書き込みオペレーションの数です。6.3 では一斉スレッドプールが書き込みになり、インデックススレッドプールが廃止されました。", + "xpack.monitoring.metrics.esNode.indexingThreads.writeRejectionsLabel": "書き込み拒否", + "xpack.monitoring.metrics.esNode.indexingThreadsTitle": "インデックススレッド", + "xpack.monitoring.metrics.esNode.indexingTime.indexThrottlingTimeDescription": "インデックススロットリングの所要時間です。ノードのディスクが遅いことを示します。", + "xpack.monitoring.metrics.esNode.indexingTime.indexThrottlingTimeLabel": "インデックススロットリング時間", + "xpack.monitoring.metrics.esNode.indexingTime.indexTimeDescription": "インデックスオペレーションの所要時間です。", + "xpack.monitoring.metrics.esNode.indexingTime.indexTimeLabel": "インデックス時間", + "xpack.monitoring.metrics.esNode.indexingTimeTitle": "インデックス時間", + "xpack.monitoring.metrics.esNode.indexMemoryEs.queryCacheDescription": "クエリキャッシュ (例: キャッシュされたフィルター) が使用中のヒープ領域です。同じシャードのものですが、Lucene 合計には含まれません。", + "xpack.monitoring.metrics.esNode.indexMemoryEs.queryCacheLabel": "クエリキャッシュ", + "xpack.monitoring.metrics.esNode.indexMemoryEsTitle": "インデックスメモリー - {elasticsearch}", + "xpack.monitoring.metrics.esNode.indexMemoryLucene1.lucenceTotalDescription": "Lucene が現在のインデックスに使用中の合計ヒープ領域です。これはノードのプライマリとレプリカシャードの他のフィールドの合計です。", + "xpack.monitoring.metrics.esNode.indexMemoryLucene1.lucenceTotalLabel": "Lucene 合計", + "xpack.monitoring.metrics.esNode.indexMemoryLucene1Title": "インデックスメモリー - Lucene 1", + "xpack.monitoring.metrics.esNode.indexMemoryLucene2.lucenceTotalDescription": "Lucene が現在のインデックスに使用中の合計ヒープ領域です。これはノードのプライマリとレプリカシャードの他のフィールドの合計です。", + "xpack.monitoring.metrics.esNode.indexMemoryLucene2.lucenceTotalLabel": "Lucene 合計", + "xpack.monitoring.metrics.esNode.indexMemoryLucene2Title": "インデックスメモリー - Lucene 2", + "xpack.monitoring.metrics.esNode.indexMemoryLucene3.lucenceTotalDescription": "Lucene が現在のインデックスに使用中の合計ヒープ領域です。これはノードのプライマリとレプリカシャードの他のフィールドの合計です。", + "xpack.monitoring.metrics.esNode.indexMemoryLucene3.lucenceTotalLabel": "Lucene 合計", + "xpack.monitoring.metrics.esNode.indexMemoryLucene3Title": "インデックスメモリー - Lucene 3", + "xpack.monitoring.metrics.esNode.indexThrottlingTimeDescription": "インデックススロットリングの所要時間です。結合に時間がかかっていることを示します。", + "xpack.monitoring.metrics.esNode.indexThrottlingTimeLabel": "インデックススロットリング時間", + "xpack.monitoring.metrics.esNode.indexWriterDescription": "Index Writer が使用中のヒープ領域です。Lucene 合計の一部ではありません。", + "xpack.monitoring.metrics.esNode.indexWriterLabel": "Index Writer", + "xpack.monitoring.metrics.esNode.ioRateTitle": "I/O オペレーションレート", + "xpack.monitoring.metrics.esNode.jvmHeap.maxHeapDescription": "JVM で実行中の Elasticsearch が利用できるヒープの合計です。", + "xpack.monitoring.metrics.esNode.jvmHeap.maxHeapLabel": "最大ヒープ", + "xpack.monitoring.metrics.esNode.jvmHeap.usedHeapDescription": "JVM で実行中の Elasticsearch が使用中のヒープの合計です。", + "xpack.monitoring.metrics.esNode.jvmHeap.usedHeapLabel": "使用ヒープ", + "xpack.monitoring.metrics.esNode.jvmHeapTitle": "{javaVirtualMachine} ヒープ", + "xpack.monitoring.metrics.esNode.latency.indexingDescription": "ドキュメントのインデックスの平均レイテンシです。ドキュメントのインデックスの所要時間をインデックス数で割った時間です。これにはレプリカを含む、このノードにあるすべてのシャードが含まれます。", + "xpack.monitoring.metrics.esNode.latency.indexingLabel": "インデックス", + "xpack.monitoring.metrics.esNode.latency.searchDescription": "検索の平均レイテンシです。検索の実行に所要した時間を送信された検索数で割った時間です。プライマリとレプリカシャードが含まれています。", + "xpack.monitoring.metrics.esNode.latency.searchLabel": "検索", + "xpack.monitoring.metrics.esNode.latencyTitle": "レイテンシ", + "xpack.monitoring.metrics.esNode.luceneTotalDescription": "Lucene が現在のインデックスに使用中の合計ヒープ領域です。これはノードのプライマリとレプリカシャードの他のフィールドの合計です。", + "xpack.monitoring.metrics.esNode.luceneTotalLabel": "Lucene 合計", + "xpack.monitoring.metrics.esNode.mergeRateDescription": "結合されたセグメントのバイト数です。この数字が大きいほどディスクアクティビティが多いことを示します。", + "xpack.monitoring.metrics.esNode.mergeRateLabel": "結合レート", + "xpack.monitoring.metrics.esNode.normsDescription": "Norms (クエリ時間、テキストスコアリングの規格化因子) が使用中のヒープ領域です。Lucene の一部です。", + "xpack.monitoring.metrics.esNode.normsLabel": "Norms", + "xpack.monitoring.metrics.esNode.pointsDescription": "ポイント (例: 数字、IP、地理データ) が使用中のヒープ領域です。Lucene の一部です。", + "xpack.monitoring.metrics.esNode.pointsLabel": "ポイント", + "xpack.monitoring.metrics.esNode.readThreads.getQueueDescription": "キューにある GET オペレーションの数です。", + "xpack.monitoring.metrics.esNode.readThreads.getQueueLabel": "GET キュー", + "xpack.monitoring.metrics.esNode.readThreads.getRejectionsDescription": "キューがいっぱいの時に拒否された GET オペレーションの数です。", + "xpack.monitoring.metrics.esNode.readThreads.getRejectionsLabel": "GET 拒否", + "xpack.monitoring.metrics.esNode.readThreads.searchQueueDescription": "キューにある検索オペレーション (例: シャードレベル検索) の数です。", + "xpack.monitoring.metrics.esNode.readThreads.searchQueueLabel": "検索キュー", + "xpack.monitoring.metrics.esNode.readThreadsTitle": "読み込みスレッド", + "xpack.monitoring.metrics.esNode.requestCacheDescription": "リクエストキャッシュ (例: 瞬間集約) が使用中のヒープ領域です。同じシャードのものですが、Lucene 合計には含まれません。", + "xpack.monitoring.metrics.esNode.requestCacheLabel": "リクエストキャッシュ", + "xpack.monitoring.metrics.esNode.requestRate.indexingTotalDescription": "インデックスオペレーションの数です。", + "xpack.monitoring.metrics.esNode.requestRate.indexingTotalLabel": "インデックス合計", + "xpack.monitoring.metrics.esNode.requestRate.searchTotalDescription": "検索オペレーションの数です (シャードごと)。", + "xpack.monitoring.metrics.esNode.requestRate.searchTotalLabel": "検索合計", + "xpack.monitoring.metrics.esNode.requestRateTitle": "リクエストレート", + "xpack.monitoring.metrics.esNode.searchRate.totalShardsDescription": "プライマリとレプリカシャードで実行されている検索リクエストの数です。1 つの検索を複数シャードに対して実行することができます!", + "xpack.monitoring.metrics.esNode.searchRate.totalShardsLabel": "合計シャード", + "xpack.monitoring.metrics.esNode.searchRateTitle": "検索レート", + "xpack.monitoring.metrics.esNode.segmentCountDescription": "このノードのプライマリとレプリカシャードの最大セグメントカウントです。", + "xpack.monitoring.metrics.esNode.segmentCountLabel": "セグメントカウント", + "xpack.monitoring.metrics.esNode.storedFieldsDescription": "格納フィールド (例: _source) が使用中のヒープ領域です。Lucene の一部です。", + "xpack.monitoring.metrics.esNode.storedFieldsLabel": "格納フィールド", + "xpack.monitoring.metrics.esNode.systemLoad.last1MinuteDescription": "過去 1 分間の平均負荷です。", + "xpack.monitoring.metrics.esNode.systemLoad.last1MinuteLabel": "1m", + "xpack.monitoring.metrics.esNode.systemLoadTitle": "システム負荷", + "xpack.monitoring.metrics.esNode.termsDescription": "用語が使用中のヒープ領域です (例: テキスト)。Lucene の一部です。", + "xpack.monitoring.metrics.esNode.termsLabel": "用語", + "xpack.monitoring.metrics.esNode.termVectorsDescription": "用語ベクトルが使用中のヒープ領域です。Lucene の一部です。", + "xpack.monitoring.metrics.esNode.termVectorsLabel": "用語ベクトル", + "xpack.monitoring.metrics.esNode.threadQueue.getDescription": "このノードでプロセス待ちの Get オペレーションの数です。", + "xpack.monitoring.metrics.esNode.threadQueue.getLabel": "Get", + "xpack.monitoring.metrics.esNode.threadQueueTitle": "スレッドキュー", + "xpack.monitoring.metrics.esNode.threadsQueued.bulkDescription": "このノードでプロセス待ちの一斉インデックスオペレーションの数です。1 つの一斉リクエストが複数の一斉オペレーションを作成します。", + "xpack.monitoring.metrics.esNode.threadsQueued.bulkLabel": "一斉", + "xpack.monitoring.metrics.esNode.threadsQueued.genericDescription": "このノードでプロセス待ちのジェネリック (内部) オペレーションの数です。", + "xpack.monitoring.metrics.esNode.threadsQueued.genericLabel": "ジェネリック", + "xpack.monitoring.metrics.esNode.threadsQueued.indexDescription": "このノードでプロセス待ちの非一斉インデックスオペレーションの数です。", + "xpack.monitoring.metrics.esNode.threadsQueued.indexLabel": "インデックス", + "xpack.monitoring.metrics.esNode.threadsQueued.managementDescription": "このノードでプロセス待ちの管理 (内部) オペレーションの数です。", + "xpack.monitoring.metrics.esNode.threadsQueued.managementLabel": "管理", + "xpack.monitoring.metrics.esNode.threadsQueued.searchDescription": "このノードでプロセス待ちの検索オペレーションの数です。1 つの検索リクエストが複数の検索オペレーションを作成します。", + "xpack.monitoring.metrics.esNode.threadsQueued.searchLabel": "検索", + "xpack.monitoring.metrics.esNode.threadsQueued.watcherDescription": "このノードでプロセス待ちの Watcher オペレーションの数です。", + "xpack.monitoring.metrics.esNode.threadsQueued.watcherLabel": "Watcher", + "xpack.monitoring.metrics.esNode.threadsRejected.bulkDescription": "一斉拒否です。キューがいっぱいの時に起こります。", + "xpack.monitoring.metrics.esNode.threadsRejected.bulkLabel": "一斉", + "xpack.monitoring.metrics.esNode.threadsRejected.genericDescription": "ジェネリック (内部) オペレーションキューがいっぱいの時に起こります。", + "xpack.monitoring.metrics.esNode.threadsRejected.genericLabel": "ジェネリック", + "xpack.monitoring.metrics.esNode.threadsRejected.getDescription": "Get の拒否です。キューがいっぱいの時に起こります。", + "xpack.monitoring.metrics.esNode.threadsRejected.getLabel": "Get", + "xpack.monitoring.metrics.esNode.threadsRejected.indexDescription": "インデックスの拒否です。キューがいっぱいの時に起こります。一斉インデックスを確認してください。", + "xpack.monitoring.metrics.esNode.threadsRejected.indexLabel": "インデックス", + "xpack.monitoring.metrics.esNode.threadsRejected.managementDescription": "Get (内部) 拒否です。キューがいっぱいの時に起こります。", + "xpack.monitoring.metrics.esNode.threadsRejected.managementLabel": "管理", + "xpack.monitoring.metrics.esNode.threadsRejected.searchDescription": "検索拒否です。キューがいっぱいの時に起こります。オーバーシャードを示している可能性があります。", + "xpack.monitoring.metrics.esNode.threadsRejected.searchLabel": "検索", + "xpack.monitoring.metrics.esNode.threadsRejected.watcherDescription": "ウォッチの拒否です。キューがいっぱいの時に起こります。ウォッチのスタックを示している可能性があります。", + "xpack.monitoring.metrics.esNode.threadsRejected.watcherLabel": "Watcher", + "xpack.monitoring.metrics.esNode.totalIoDescription": "I/O 合計。(このメトリックはすべてのプラットフォームでサポートされておらず、I/O が利用できない場合 N/A が表示されることがあります。)", + "xpack.monitoring.metrics.esNode.totalIoLabel": "I/O 合計", + "xpack.monitoring.metrics.esNode.totalIoReadDescription": "読み込み I/O 合計。(このメトリックはすべてのプラットフォームでサポートされておらず、I/O が利用できない場合 N/A が表示されることがあります。)", + "xpack.monitoring.metrics.esNode.totalIoReadLabel": "読み込み I/O 合計", + "xpack.monitoring.metrics.esNode.totalIoWriteDescription": "書き込み I/O 合計。(このメトリックはすべてのプラットフォームでサポートされておらず、I/O が利用できない場合 N/A が表示されることがあります。)", + "xpack.monitoring.metrics.esNode.totalIoWriteLabel": "書き込み I/O 合計", + "xpack.monitoring.metrics.esNode.totalRefreshTimeDescription": "プライマリとレプリカシャードの Elasticsearch の更新所要時間です。", + "xpack.monitoring.metrics.esNode.totalRefreshTimeLabel": "合計更新時間", + "xpack.monitoring.metrics.esNode.versionMapDescription": "バージョニング (例: 更新、削除) が使用中のヒープ領域です。Lucene 合計の一部ではありません。", + "xpack.monitoring.metrics.esNode.versionMapLabel": "バージョンマップ", + "xpack.monitoring.metrics.kibana.clientRequestsDescription": "Kibana インスタンスが受信したクライアントリクエストの合計数です。", + "xpack.monitoring.metrics.kibana.clientRequestsLabel": "クライアントリクエスト", + "xpack.monitoring.metrics.kibana.clientResponseTime.averageDescription": "Kibana インスタンスへのクライアントリクエストの平均応答時間です。", + "xpack.monitoring.metrics.kibana.clientResponseTime.averageLabel": "平均", + "xpack.monitoring.metrics.kibana.clientResponseTime.maxDescription": "Kibana インスタンスへのクライアントリクエストの最長応答時間です。", + "xpack.monitoring.metrics.kibana.clientResponseTime.maxLabel": "最高", + "xpack.monitoring.metrics.kibana.clientResponseTimeTitle": "クライアント応答時間", + "xpack.monitoring.metrics.kibana.httpConnectionsDescription": "Kibana へのオープンソケット接続の数です。", + "xpack.monitoring.metrics.kibana.httpConnectionsLabel": "HTTP 接続", + "xpack.monitoring.metrics.kibana.msTimeUnitLabel": "ms", + "xpack.monitoring.metrics.kibanaInstance.clientRequestsDescription": "Kibana インスタンスが受信したクライアントリクエストの合計数です。", + "xpack.monitoring.metrics.kibanaInstance.clientRequestsLabel": "クライアントリクエスト", + "xpack.monitoring.metrics.kibanaInstance.clientResponseTime.averageDescription": "Kibana インスタンスへのクライアントリクエストの平均応答時間です。", + "xpack.monitoring.metrics.kibanaInstance.clientResponseTime.averageLabel": "平均", + "xpack.monitoring.metrics.kibanaInstance.clientResponseTime.maxDescription": "Kibana インスタンスへのクライアントリクエストの最長応答時間です。", + "xpack.monitoring.metrics.kibanaInstance.clientResponseTime.maxLabel": "最高", + "xpack.monitoring.metrics.kibanaInstance.clientResponseTimeTitle": "クライアント応答時間", + "xpack.monitoring.metrics.kibanaInstance.eventLoopDelayDescription": "Kibana サーバーイベントループの遅延です。長い遅延は、同時機能が多くの CPU 時間を取るなど、サーバースレッドのイベントのブロックを示している可能性があります。", + "xpack.monitoring.metrics.kibanaInstance.eventLoopDelayLabel": "イベントループの遅延", + "xpack.monitoring.metrics.kibanaInstance.memorySize.heapSizeLimitDescription": "ガーベージコレクション前のメモリー使用量の制限です。", + "xpack.monitoring.metrics.kibanaInstance.memorySize.heapSizeLimitLabel": "ヒープサイズ制限", + "xpack.monitoring.metrics.kibanaInstance.memorySizeDescription": "Node.js で実行中の Kibana によるヒープの合計使用量です。", + "xpack.monitoring.metrics.kibanaInstance.memorySizeLabel": "メモリーサイズ", + "xpack.monitoring.metrics.kibanaInstance.memorySizeTitle": "メモリーサイズ", + "xpack.monitoring.metrics.kibanaInstance.systemLoad.last15MinutesDescription": "過去 15 分間の平均負荷です。", + "xpack.monitoring.metrics.kibanaInstance.systemLoad.last15MinutesLabel": "15m", + "xpack.monitoring.metrics.kibanaInstance.systemLoad.last1MinuteDescription": "過去 1 分間の平均負荷です。", + "xpack.monitoring.metrics.kibanaInstance.systemLoad.last1MinuteLabel": "1m", + "xpack.monitoring.metrics.kibanaInstance.systemLoad.last5MinutesDescription": "過去 5 分間の平均負荷です。", + "xpack.monitoring.metrics.kibanaInstance.systemLoad.last5MinutesLabel": "5m", + "xpack.monitoring.metrics.kibanaInstance.systemLoadTitle": "システム負荷", + "xpack.monitoring.metrics.logstash.eventLatencyDescription": "フィルターとアウトプットステージのイベントの平均所要時間です。イベントの処理に所要した合計時間を送信イベント数で割った時間です。", + "xpack.monitoring.metrics.logstash.eventLatencyLabel": "イベントレイテンシ", + "xpack.monitoring.metrics.logstash.eventsEmittedRateDescription": "すべての Logstash ノードによりアウトプットステージで 1 秒間に送信されたイベント数です。", + "xpack.monitoring.metrics.logstash.eventsEmittedRateLabel": "イベント送信レート", + "xpack.monitoring.metrics.logstash.eventsPerSecondUnitLabel": "e/s", + "xpack.monitoring.metrics.logstash.eventsReceivedRateDescription": "すべての Logstash ノードによりアウトプットステージで 1 秒間に受信されたイベント数です。", + "xpack.monitoring.metrics.logstash.eventsReceivedRateLabel": "イベント受信レート", + "xpack.monitoring.metrics.logstash.msTimeUnitLabel": "ms", + "xpack.monitoring.metrics.logstash.nsTimeUnitLabel": "ナノ秒", + "xpack.monitoring.metrics.logstash.perSecondUnitLabel": "/s", + "xpack.monitoring.metrics.logstash.systemLoadTitle": "システム負荷", + "xpack.monitoring.metrics.logstashInstance.cgroupCfsStats.cgroupElapsedPeriodsDescription": "Completely Fair Scheduler (CFS) からのサンプリング期間の数です。スロットル回数と比較します。", + "xpack.monitoring.metrics.logstashInstance.cgroupCfsStats.cgroupElapsedPeriodsLabel": "Cgroup 経過時間", + "xpack.monitoring.metrics.logstashInstance.cgroupCfsStats.cgroupThrottledCountDescription": "Cgroup により CPU がスロットリングされた回数です。", + "xpack.monitoring.metrics.logstashInstance.cgroupCfsStats.cgroupThrottledCountLabel": "Cgroup スロットルカウント", + "xpack.monitoring.metrics.logstashInstance.cgroupCfsStatsTitle": "Cgroup CFS 統計", + "xpack.monitoring.metrics.logstashInstance.cgroupCpuPerformance.cgroupThrottlingDescription": "Cgroup のナノ秒単位で報告されたスロットル時間です。", + "xpack.monitoring.metrics.logstashInstance.cgroupCpuPerformance.cgroupThrottlingLabel": "Cgroup スロットリング", + "xpack.monitoring.metrics.logstashInstance.cgroupCpuPerformance.cgroupUsageDescription": "Cgroup のナノ秒単位で報告された使用状況です。スロットリングと比較して問題を発見します。", + "xpack.monitoring.metrics.logstashInstance.cgroupCpuPerformance.cgroupUsageLabel": "Cgroup の使用状況", + "xpack.monitoring.metrics.logstashInstance.cgroupCpuPerformanceTitle": "Cgroup CPU パフォーマンス", + "xpack.monitoring.metrics.logstashInstance.cgroupCpuUtilizationDescription": "CPU クォータに対する CPU 使用時間のパーセンテージです。CPU クォータが設定されていない場合、データは表示されません。", + "xpack.monitoring.metrics.logstashInstance.cpuUtilization.cgroupCpuUtilizationLabel": "Cgroup CPU 活用状況", + "xpack.monitoring.metrics.logstashInstance.cpuUtilizationDescription": "OS により報告された CPU 使用量のパーセンテージです (最大 100%)。", + "xpack.monitoring.metrics.logstashInstance.cpuUtilizationLabel": "CPU 使用状況", + "xpack.monitoring.metrics.logstashInstance.cpuUtilizationTitle": "CPU 使用状況", + "xpack.monitoring.metrics.logstashInstance.eventLatencyDescription": "フィルターとアウトプットステージのイベントの平均所要時間です。イベントの処理に所要した合計時間を送信イベント数で割った時間です。", + "xpack.monitoring.metrics.logstashInstance.eventLatencyLabel": "イベントレイテンシ", + "xpack.monitoring.metrics.logstashInstance.eventsEmittedRateDescription": "Logstash ノードによりアウトプットステージで 1 秒間に送信されたイベント数です。", + "xpack.monitoring.metrics.logstashInstance.eventsEmittedRateLabel": "イベント送信レート", + "xpack.monitoring.metrics.logstashInstance.eventsQueuedDescription": "フィルターとアウトプットステージによる処理待ちの、永続キューのイベントの平均数です。", + "xpack.monitoring.metrics.logstashInstance.eventsQueuedLabel": "キューのイベント", + "xpack.monitoring.metrics.logstashInstance.eventsReceivedRateDescription": "Logstash ノードによりアウトプットステージで 1 秒間に受信されたイベント数です。", + "xpack.monitoring.metrics.logstashInstance.eventsReceivedRateLabel": "イベント受信レート", + "xpack.monitoring.metrics.logstashInstance.jvmHeap.maxHeapDescription": "JVM で実行中の Logstash が利用できるヒープの合計です。", + "xpack.monitoring.metrics.logstashInstance.jvmHeap.maxHeapLabel": "最大ヒープ", + "xpack.monitoring.metrics.logstashInstance.jvmHeap.usedHeapDescription": "JVM で実行中の Logstash が使用しているヒープの合計です。", + "xpack.monitoring.metrics.logstashInstance.jvmHeap.usedHeapLabel": "使用ヒープ", + "xpack.monitoring.metrics.logstashInstance.jvmHeapTitle": "{javaVirtualMachine} ヒープ", + "xpack.monitoring.metrics.logstashInstance.maxQueueSizeDescription": "このノードの永続キューに設定された最大サイズです。", + "xpack.monitoring.metrics.logstashInstance.maxQueueSizeLabel": "最大キューサイズ", + "xpack.monitoring.metrics.logstashInstance.persistentQueueEventsTitle": "永続キューイベント", + "xpack.monitoring.metrics.logstashInstance.persistentQueueSizeTitle": "永続キューサイズ", + "xpack.monitoring.metrics.logstashInstance.pipelineNodeCountDescription": "Logstash パイプラインが実行されているノードの数です。", + "xpack.monitoring.metrics.logstashInstance.pipelineNodeCountLabel": "パイプラインノードカウント", + "xpack.monitoring.metrics.logstashInstance.pipelineThroughputDescription": "Logstash パイプラインによりアウトプットステージで 1 秒間に送信されたイベント数です。", + "xpack.monitoring.metrics.logstashInstance.pipelineThroughputLabel": "パイプラインスループット", + "xpack.monitoring.metrics.logstashInstance.queueSizeDescription": "このノードの Logstash パイプラインのすべての永続キューの現在のサイズです。", + "xpack.monitoring.metrics.logstashInstance.queueSizeLabel": "キューサイズ", + "xpack.monitoring.metrics.logstashInstance.systemLoad.last15MinutesDescription": "過去 15 分間の平均負荷です。", + "xpack.monitoring.metrics.logstashInstance.systemLoad.last15MinutesLabel": "15m", + "xpack.monitoring.metrics.logstashInstance.systemLoad.last1MinuteDescription": "過去 1 分間の平均負荷です。", + "xpack.monitoring.metrics.logstashInstance.systemLoad.last1MinuteLabel": "1m", + "xpack.monitoring.metrics.logstashInstance.systemLoad.last5MinutesDescription": "過去 5 分間の平均負荷です。", + "xpack.monitoring.metrics.logstashInstance.systemLoad.last5MinutesLabel": "5m", + "xpack.monitoring.monitoringDescription": "Elastic Stack のリアルタイムのヘルスとパフォーマンスをトラッキングします。", + "xpack.monitoring.monitoringTitle": "Monitoring", + "xpack.monitoring.noData.blurbs.changesNeededDescription": "監視を実行するには、次の手順に従います", + "xpack.monitoring.noData.blurbs.changesNeededTitle": "調整が必要です", + "xpack.monitoring.noData.blurbs.cloudDeploymentDescription": "次の場所に戻ってください: ", + "xpack.monitoring.noData.blurbs.cloudDeploymentDescriptionMore": "Elastic Cloud での監視の詳細は、 ", + "xpack.monitoring.noData.blurbs.cloudDeploymentTitle": "監視データはこちらに表示されません。", + "xpack.monitoring.noData.blurbs.lookingForMonitoringDataDescription": "監視は、ハードウェアパフォーマンスと負荷の情報を提供します。", + "xpack.monitoring.noData.blurbs.lookingForMonitoringDataTitle": "監視データを検索中です", + "xpack.monitoring.noData.blurbs.monitoringIsOffDescription": "監視は、ハードウェアパフォーマンスと負荷の情報を提供します。", + "xpack.monitoring.noData.blurbs.monitoringIsOffTitle": "監視は現在オフになっています", + "xpack.monitoring.noData.checkerErrors.checkEsSettingsErrorMessage": "Elasticsearch の設定の確認中にエラーが発生しました。設定の確認には管理者権限が必要で、必要に応じて監視収集設定を有効にする必要があります。", + "xpack.monitoring.noData.collectionInterval.turnOnMonitoringButtonLabel": "Metricbeat で監視を設定", + "xpack.monitoring.noData.defaultLoadingMessage": "読み込み中、お待ちください", + "xpack.monitoring.noData.explanations.collectionEnabled.monitoringTurnedOnDescription": "データがクラスターにある場合、ここに監視ダッシュボードが表示されます。これには数秒かかる場合があります。", + "xpack.monitoring.noData.explanations.collectionEnabled.monitoringTurnedOnTitle": "成功!監視データを取得中です。", + "xpack.monitoring.noData.explanations.collectionEnabled.stillWaitingLinkText": "まだ待っていますか?", + "xpack.monitoring.noData.explanations.collectionEnabled.turnItOnDescription": "オンにしますか?", + "xpack.monitoring.noData.explanations.collectionEnabled.turnOnMonitoringButtonLabel": "監視をオンにする", + "xpack.monitoring.noData.explanations.collectionEnabledDescription": "{context} 設定を確認し、 {property} が {data} に設定されていることが判明しました。", + "xpack.monitoring.noData.explanations.collectionInterval.changeIntervalDescription": "この設定を変更して監視を有効にしますか?", + "xpack.monitoring.noData.explanations.collectionInterval.monitoringTurnedOnDescription": "クラスターに監視データが現れ次第、ページが自動的に監視ダッシュボードと共に更新されます。これにはたった数秒しかかかりません。", + "xpack.monitoring.noData.explanations.collectionInterval.monitoringTurnedOnTitle": "成功!少々お待ちください。", + "xpack.monitoring.noData.explanations.collectionInterval.turnOnMonitoringButtonLabel": "監視をオンにする", + "xpack.monitoring.noData.explanations.collectionInterval.wrongIntervalValueDescription": "収集エージェントをアクティブにするには、収集間隔設定がプラスの整数 (推奨: 10s) でなければなりません。", + "xpack.monitoring.noData.explanations.collectionIntervalDescription": "{context} 設定を確認し、 {property} が {data} に設定されていることが判明しました。", + "xpack.monitoring.noData.explanations.exporters.checkConfigDescription": "この Kibana のインスタンスで監視データを表示するには、意図されたエクスポーターの監視クラスターへの統計の送信が有効になっていて、監視クラスターのホストが {kibanaConfig} の {monitoringEs} 設定と一致していることを確認してください。", + "xpack.monitoring.noData.explanations.exporters.problemWithConfigDescription": "監視エクスポーターを使用し監視データをリモート監視クラスターに送信することで、本番クラスターの状態にかかわらず監視データが安全に保管されるため、強くお勧めします。但し、この Kibana のインスタンスは監視データを見つけられませんでした。{property} 構成または {kibanaConfig} の {monitoringEs} 設定に問題があるようです。", + "xpack.monitoring.noData.explanations.exportersCloudDescription": "Elastic Cloud では、監視データが専用の監視クラスターに格納されます。", + "xpack.monitoring.noData.explanations.exportersDescription": "{property} の {context} 設定を確認し理由が判明しました: {data}。", + "xpack.monitoring.noData.explanations.pluginEnabledDescription": "{context} 設定を確認し、 {property} が {data} に設定されていることが判明しました。これにより監視が無効になっています。構成から {monitoringEnableFalse} 設定を削除することで、デフォルトの設定になり監視が有効になります。", + "xpack.monitoring.noData.noMonitoringDataFound": "既に監視を設定済みですか?その場合、右上に選択された期間に監視データが含まれていることを確認してください。", + "xpack.monitoring.noData.noMonitoringDetected": "監視データが見つかりません。", + "xpack.monitoring.noData.reasons.couldNotActivateMonitoringTitle": "監視を有効にできませんでした", + "xpack.monitoring.noData.reasons.explainWhyNoDataDescription": "{context} 設定で {property} が {data} に設定されています。", + "xpack.monitoring.noData.reasons.ifDataInClusterDescription": "クラスターにデータがある場合、ここに監視ダッシュボードが表示されます。", + "xpack.monitoring.noData.reasons.noMonitoringDataFoundDescription": "監視データが見つかりません。時間フィルターを「過去 1 時間」に設定するか、別の期間にデータがあるか確認してください。", + "xpack.monitoring.noData.routeTitle": "監視の設定", + "xpack.monitoring.noData.setupInternalInstead": "または、自己監視で設定", + "xpack.monitoring.noData.setupMetricbeatInstead": "または、Metricbeat で設定 (推奨)", + "xpack.monitoring.pageLoadingTitle": "読み込み中…", + "xpack.monitoring.requestedClusters.uuidNotFoundErrorMessage": "選択された時間範囲にクラスターが見つかりませんでした。UUID: {clusterUuid}", + "xpack.monitoring.setupMode.clickToDisableInternalCollection": "自己監視を無効にする", + "xpack.monitoring.setupMode.clickToMonitorWithMetricbeat": "Metricbeat で監視", + "xpack.monitoring.setupMode.description": "現在設定モードです。({flagIcon}) アイコンは構成オプションを意味します。", + "xpack.monitoring.setupMode.detectedNodeDescription": "下の「監視を設定」をクリックしてこの {identifier} の監視を開始します。", + "xpack.monitoring.setupMode.detectedNodeTitle": "{product} {identifier} が検出されました", + "xpack.monitoring.setupMode.disableInternalCollectionDescription": "Metricbeat による {product} {identifier} の監視が開始されました。移行を完了させるには、自己監視を無効にしてください。", + "xpack.monitoring.setupMode.disableInternalCollectionTitle": "自己監視を無効にする", + "xpack.monitoring.setupMode.enter": "設定モードにする", + "xpack.monitoring.setupMode.exit": "設定モードを修了", + "xpack.monitoring.setupMode.instance": "インスタンス", + "xpack.monitoring.setupMode.instances": "インスタンス", + "xpack.monitoring.setupMode.metricbeatAllNodes": "Metricbeat がすべての {identifier} を監視しています。", + "xpack.monitoring.setupMode.migrateSomeToMetricbeatDescription": "{product} {identifier} の一部は自己監視で監視されています。Metricbeat での監視に移行してください。", + "xpack.monitoring.setupMode.migrateToMetricbeat": "Metricbeat で監視", + "xpack.monitoring.setupMode.migrateToMetricbeatDescription": "これらの {product} {identifier} は自己監視されています。\n 移行するには「Metricbeat で監視」をクリックしてください。", + "xpack.monitoring.setupMode.monitorAllNodes": "ノードの一部は自己監視のみ使用できます。", + "xpack.monitoring.setupMode.netNewUserDescription": "「監視を設定」をクリックして監視を開始します。", + "xpack.monitoring.setupMode.node": "ノード", + "xpack.monitoring.setupMode.nodes": "ノード", + "xpack.monitoring.setupMode.noMonitoringDataFound": "{product} {identifier} が検出されませんでした", + "xpack.monitoring.setupMode.notAvailableCloud": "この機能はクラウドで使用できません。", + "xpack.monitoring.setupMode.notAvailablePermissions": "これを実行するために必要な権限がありません。", + "xpack.monitoring.setupMode.notAvailableTitle": "設定モードは使用できません", + "xpack.monitoring.setupMode.server": "サーバー", + "xpack.monitoring.setupMode.servers": "サーバー", + "xpack.monitoring.setupMode.tooltip.allSet": "Metricbeat がすべての {identifierPlural} を監視しています。", + "xpack.monitoring.setupMode.tooltip.detected": "監視なし", + "xpack.monitoring.setupMode.tooltip.disableInternal": "Metricbeat がすべての {identifierPlural} を監視しています。クリックして {identifierPlural} を表示し、自己監視を無効にしてください。", + "xpack.monitoring.setupMode.tooltip.mightExist": "この製品の使用が検出されました。クリックして監視を開始してください。", + "xpack.monitoring.setupMode.tooltip.noUsage": "使用なし", + "xpack.monitoring.setupMode.tooltip.noUsageDetected": "使用が検出されませんでした。{identifier} を表示するにはクリックしてください。", + "xpack.monitoring.setupMode.tooltip.oneInternal": "少なくとも 1 つの {identifier} が Metricbeat によって監視されていません。ステータスを表示するにはクリックしてください。", + "xpack.monitoring.setupMode.unknown": "N/A", + "xpack.monitoring.setupMode.usingMetricbeatCollection": "Metricbeat で監視", + "xpack.monitoring.stackMonitoringDocTitle": "スタック監視 {clusterName} {suffix}", + "xpack.monitoring.stackMonitoringTitle": "スタック監視", + "xpack.monitoring.summaryStatus.statusDescription": "ステータス", + "xpack.monitoring.summaryStatus.statusIconLabel": "ステータス: {status}", + "xpack.monitoring.summaryStatus.statusIconTitle": "ステータス: {statusIcon}", + "xpack.monitoring.uiExportsDescription": "Elastic Stack の監視です", + "xpack.remoteClusters.addAction.clusterNameAlreadyExistsErrorMessage": "「{clusterName}」という名前のクラスターが既に存在します。", + "xpack.remoteClusters.addAction.errorTitle": "クラスターの追加中にエラーが発生", + "xpack.remoteClusters.addAction.failedDefaultErrorMessage": "{statusCode} エラーでリクエスト失敗: {message}", + "xpack.remoteClusters.addAction.successTitle": "リモートクラスター「{name}」が追加されました", + "xpack.remoteClusters.addBreadcrumbTitle": "追加", + "xpack.remoteClusters.addTitle": "リモートクラスターを追加", + "xpack.remoteClusters.appName": "リモートクラスター", + "xpack.remoteClusters.appTitle": "リモートクラスター", + "xpack.remoteClusters.configuredByNodeWarningTitle": "このリモートクラスターはノードの elasticsearch.yml 構成ファイルで定義されているため、編集または削除できません。", + "xpack.remoteClusters.connectedStatus.connectedAriaLabel": "接続済み", + "xpack.remoteClusters.connectedStatus.notConnectedAriaLabel": "未接続", + "xpack.remoteClusters.connectedStatus.notConnectedToolTip": "シードノードが HTTP ポートではなくリモートクラスターのトランスポートポートで構成されていることを確認してください。", + "xpack.remoteClusters.detailPanel.closeButtonLabel": "閉じる", + "xpack.remoteClusters.detailPanel.connectedLabel": "接続", + "xpack.remoteClusters.detailPanel.connectedNodesLabel": "接続済みのノード", + "xpack.remoteClusters.detailPanel.editButtonLabel": "編集", + "xpack.remoteClusters.detailPanel.initialConnectTimeoutLabel": "初期接続タイムアウト", + "xpack.remoteClusters.detailPanel.maxConnectionsPerClusterLabel": "最大接続数", + "xpack.remoteClusters.detailPanel.notFoundLabel": "リモートクラスターが見つかりません", + "xpack.remoteClusters.detailPanel.removeButtonLabel": "削除", + "xpack.remoteClusters.detailPanel.seedsLabel": "シード", + "xpack.remoteClusters.detailPanel.skipUnavailableFalseValue": "いいえ", + "xpack.remoteClusters.detailPanel.skipUnavailableLabel": "利用不可のものをスキップ", + "xpack.remoteClusters.detailPanel.skipUnavailableNullValue": "デフォルト", + "xpack.remoteClusters.detailPanel.skipUnavailableTrueValue": "はい", + "xpack.remoteClusters.detailPanel.statusTitle": "ステータス", + "xpack.remoteClusters.edit.backToRemoteClustersButtonLabel": "リモートクラスターに戻る", + "xpack.remoteClusters.edit.loadingErrorMessage": "リモートクラスター「{name}」が存在しません。", + "xpack.remoteClusters.edit.loadingErrorTitle": "リモートクラスターの読み込み中にエラーが発生", + "xpack.remoteClusters.edit.loadingLabel": "リモートクラスターを読み込み中…", + "xpack.remoteClusters.edit.viewRemoteClustersButtonLabel": "リモートクラスターを表示", + "xpack.remoteClusters.editAction.errorTitle": "クラスターの編集中にエラーが発生", + "xpack.remoteClusters.editAction.failedDefaultErrorMessage": "{statusCode} エラーでリクエスト失敗: {message}", + "xpack.remoteClusters.editAction.successTitle": "リモートクラスター「{name}」が編集されました", + "xpack.remoteClusters.editBreadcrumbTitle": "編集", + "xpack.remoteClusters.editTitle": "リモートクラスターを編集", + "xpack.remoteClusters.form.errors.illegalCharacters": "名前から {characterListLength, plural, one {文字} other {文字}} {characterList} を削除してください。", + "xpack.remoteClusters.form.errors.illegalSpace": "名前にスペースは使用できません。", + "xpack.remoteClusters.form.errors.nameMissing": "名前が必要です。", + "xpack.remoteClusters.form.errors.seedMissing": "シードノードが最低 1 つ必要です。", + "xpack.remoteClusters.listBreadcrumbTitle": "リモートクラスター", + "xpack.remoteClusters.loadAction.errorTitle": "リモートクラスターの読み込み中にエラーが発生", + "xpack.remoteClusters.readDocsButtonLabel": "リモートクラスタードキュメント", + "xpack.remoteClusters.refreshAction.errorTitle": "リモートクラスターの更新中にエラーが発生", + "xpack.remoteClusters.remoteClusterForm.actions.savingText": "保存中", + "xpack.remoteClusters.remoteClusterForm.cancelButtonLabel": "キャンセル", + "xpack.remoteClusters.remoteClusterForm.errorTitle": "続行する前にエラーを修正してください", + "xpack.remoteClusters.remoteClusterForm.fieldNameLabel": "名前", + "xpack.remoteClusters.remoteClusterForm.fieldNameLabelHelpText": "名前には文字、数字、アンダーライン、ハイフンのみ使用できます。", + "xpack.remoteClusters.remoteClusterForm.fieldSeedsLabel": "シードノード", + "xpack.remoteClusters.remoteClusterForm.fieldSeedsPlaceholder": "ホストポート", + "xpack.remoteClusters.remoteClusterForm.hideRequestButtonLabel": "リクエストを非表示", + "xpack.remoteClusters.remoteClusterForm.inputLocalSeedErrorMessage": "「シードノード」フィールドが無効です。", + "xpack.remoteClusters.remoteClusterForm.inputNameErrorMessage": "「名前」フィールドが無効です。", + "xpack.remoteClusters.remoteClusterForm.inputSeedsErrorMessage": "「シードノード」フィールドが無効です。", + "xpack.remoteClusters.remoteClusterForm.localSeedError.duplicateMessage": "重複シードノードは使用できません。", + "xpack.remoteClusters.remoteClusterForm.localSeedError.invalidCharactersMessage": "シードノードはホストポートのフォーマットを使用する必要があります。例:127.0.0.1:9400、localhost:9400.ホストには文字、数字、ハイフンのみが使用できます。", + "xpack.remoteClusters.remoteClusterForm.localSeedError.invalidPortMessage": "ポートが必要です。", + "xpack.remoteClusters.remoteClusterForm.saveButtonLabel": "保存", + "xpack.remoteClusters.remoteClusterForm.sectionNameDescription": "リモートクラスターの固有の名前です。", + "xpack.remoteClusters.remoteClusterForm.sectionNameTitle": "名前", + "xpack.remoteClusters.remoteClusterForm.sectionSeedsDescription1": "クラスターステータスのクエリを実行するリモートクラスターノードのリストです。1 つのノードが利用できない場合にディスカバリが失敗しないよう、複数シードノードを指定してください。", + "xpack.remoteClusters.remoteClusterForm.sectionSeedsHelpText": "リモートクラスターの {transportPort} の前にくる IP アドレスまたはホスト名です。", + "xpack.remoteClusters.remoteClusterForm.sectionSeedsHelpText.transportPortLinkText": "トランスポートポート", + "xpack.remoteClusters.remoteClusterForm.sectionSeedsTitle": "クラスターディスカバリのシードノード", + "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableDescription": "デフォルトで、リクエストのリモートクラスターのどれかが利用できないと、リクエストは失敗となります。このクラスターが利用できない場合にリクエストを他のリモートクラスターに送信し続けるには、{optionName} を有効にします。{learnMoreLink}", + "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableDescription.learnMoreLinkLabel": "詳細", + "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableDescription.optionNameLabel": "利用不可の場合スキップ", + "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableLabel": "利用不可の場合スキップ", + "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableResetLabel": "デフォルトにリセット", + "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableTitle": "リモートクラスターをオプションにする", + "xpack.remoteClusters.remoteClusterForm.showRequestButtonLabel": "リクエストを表示", + "xpack.remoteClusters.remoteClusterList.connectButtonLabel": "リモートクラスターを追加", + "xpack.remoteClusters.remoteClusterList.emptyPrompt.connectButtonLabel": "リモートクラスターを追加", + "xpack.remoteClusters.remoteClusterList.emptyPromptDescription": "リモートクラスターは、ローカルクラスターから他のクラスターへの一方行接続を作成します。", + "xpack.remoteClusters.remoteClusterList.emptyPromptTitle": "初めのリモートクラスターの追加", + "xpack.remoteClusters.remoteClusterList.loadingErrorTitle": "リモートクラスターの読み込み中にエラーが発生", + "xpack.remoteClusters.remoteClusterList.loadingTitle": "リモートクラスターを読み込み中", + "xpack.remoteClusters.remoteClusterList.noPermissionText": "リモートクラスターの表示または追加パーミッションがありません。", + "xpack.remoteClusters.remoteClusterList.noPermissionTitle": "パーミッションエラー", + "xpack.remoteClusters.remoteClusterList.table.actionBlockedDeleteDescription": "elasticsearch.yml で定義されたリモートクラスターは削除できません", + "xpack.remoteClusters.remoteClusterList.table.actionBlockedEditDescription": "elasticsearch.yml で定義されたリモートクラスターは編集できません", + "xpack.remoteClusters.remoteClusterList.table.actionDeleteDescription": "リモートクラスターを削除します", + "xpack.remoteClusters.remoteClusterList.table.actionEditDescription": "リモートクラスターを編集します", + "xpack.remoteClusters.remoteClusterList.table.actionsColumnTitle": "アクション", + "xpack.remoteClusters.remoteClusterList.table.connectedColumnTitle": "接続", + "xpack.remoteClusters.remoteClusterList.table.connectedNodesColumnTitle": "接続済みのノード", + "xpack.remoteClusters.remoteClusterList.table.isConfiguredByNodeMessage": "elasticsearch.yml で定義されています", + "xpack.remoteClusters.remoteClusterList.table.nameColumnTitle": "名前", + "xpack.remoteClusters.remoteClusterList.table.removeButtonLabel": "{count, plural, one {リモートクラスター} other {{count}リモートクラスター}}を削除", + "xpack.remoteClusters.remoteClusterList.table.seedsColumnTitle": "シード", + "xpack.remoteClusters.remoteClusterListTitle": "リモートクラスター", + "xpack.remoteClusters.removeAction.errorMultipleNotificationTitle": "「{count}」リモートクラスターの削除中にエラーが発生", + "xpack.remoteClusters.removeAction.errorSingleNotificationTitle": "リモートクラスター「{name}」の削除中にエラーが発生", + "xpack.remoteClusters.removeAction.successMultipleNotificationTitle": "{count} 個のリモートクラスターが削除されました", + "xpack.remoteClusters.removeAction.successSingleNotificationTitle": "リモートクラスター「{name}」が削除されました", + "xpack.remoteClusters.removeButton.confirmModal.cancelButtonText": "キャンセル", + "xpack.remoteClusters.removeButton.confirmModal.confirmButtonText": "削除", + "xpack.remoteClusters.removeButton.confirmModal.deleteSingleClusterTitle": "リモートクラスター「{name}」を削除しますか?", + "xpack.remoteClusters.removeButton.confirmModal.multipleDeletionDescription": "これらのリモートクラスターを削除しようとしています。", + "xpack.remoteClusters.removeButton.confirmModal.multipleDeletionTitle": "{count} 個のリモートクラスターを削除しますか?", + "xpack.remoteClusters.requestFlyout.closeButtonLabel": "閉じる", + "xpack.remoteClusters.requestFlyout.descriptionText": "この Elasticsearch リクエストは、このリモートクラスターを作成または更新します。", + "xpack.remoteClusters.requestFlyout.namedTitle": "「{name}」のリクエスト", + "xpack.remoteClusters.requestFlyout.unnamedTitle": "リクエスト", + "xpack.reporting.breadcrumb": "レポート", + "xpack.reporting.dashboard.csvDownloadStartedMessage": "間もなく CSV がダウンロードされます。", + "xpack.reporting.dashboard.csvDownloadStartedTitle": "CSV のダウンロードが開始しました", + "xpack.reporting.dashboard.downloadCsvPanelTitle": "CSV をダウンロード", + "xpack.reporting.dashboard.failedCsvDownloadMessage": "現在 CSV を生成できません。", + "xpack.reporting.dashboard.failedCsvDownloadTitle": "CSV のダウンロードに失敗", + "xpack.reporting.errorButton.showReportErrorAriaLabel": "レポートエラーを表示", + "xpack.reporting.errorButton.unableToFetchReportContentTitle": "レポートのコンテンツを取得できません", + "xpack.reporting.errorButton.unableToGenerateReportTitle": "レポートを生成できません", + "xpack.reporting.exportTypes.csv_from_savedobject.executeJob.failedToDecryptReportJobDataErrorMessage": "レポートジョブデータの解読に失敗しました{encryptionKey} が設定されていることを確認してこのレポートを再生成してください。{err}", + "xpack.reporting.exportTypes.csv.executeJob.failedToDecryptReportJobDataErrorMessage": "レポートジョブデータの解読に失敗しました{encryptionKey} が設定されていることを確認してこのレポートを再生成してください。{err}", + "xpack.reporting.exportTypes.csv.hitIterator.expectedHitsErrorMessage": "次の Elasticsearch からの応答で期待される {hits}: {response}", + "xpack.reporting.exportTypes.csv.hitIterator.expectedScrollIdErrorMessage": "次の Elasticsearch からの応答で期待される {scrollId}: {response}", + "xpack.reporting.exportTypes.printablePdf.documentStreamIsNotgeneratedErrorMessage": "ドキュメントストリームが生成されていません。", + "xpack.reporting.exportTypes.printablePdf.logoDescription": "Elastic 提供", + "xpack.reporting.exportTypes.printablePdf.pagingDescription": "{pageCount} ページ中 {currentPage} ページ目", + "xpack.reporting.exportTypes.printablePdf.screenshots.unexpectedErrorMessage": "ページで予期せぬメッセージが発生しました: {toastHeaderText}", + "xpack.reporting.jobStatuses.cancelledText": "キャンセル済み", + "xpack.reporting.jobStatuses.completedText": "完了", + "xpack.reporting.jobStatuses.failedText": "失敗", + "xpack.reporting.jobStatuses.pendingText": "保留中", + "xpack.reporting.jobStatuses.processingText": "処理中", + "xpack.reporting.listing.reports.subtitle": "Kibana アプリケーションで生成されたレポートがここに表示されます", + "xpack.reporting.listing.reportstitle": "レポート", + "xpack.reporting.listing.table.csvContainsFormulas": "CSVには、スプレッドシートアプリケーションで式と解釈される可能性のある文字が含まれています。", + "xpack.reporting.listing.table.downloadReportAriaLabel": "レポートをダウンロード", + "xpack.reporting.listing.table.loadingReportsDescription": "レポートを読み込み中です", + "xpack.reporting.listing.table.maxSizeReachedTooltip": "最大サイズに達成、部分データが含まれています。", + "xpack.reporting.listing.table.noCreatedReportsDescription": "レポートが作成されていません", + "xpack.reporting.listing.table.requestFailedErrorMessage": "リクエストに失敗しました", + "xpack.reporting.listing.tableColumns.actionsTitle": "アクション", + "xpack.reporting.listing.tableColumns.createdAtTitle": "作成日時:", + "xpack.reporting.listing.tableColumns.reportTitle": "レポート", + "xpack.reporting.listing.tableColumns.statusTitle": "ステータス", + "xpack.reporting.listing.tableValue.createdAtDetail.maxSizeReachedText": " - 最大サイズに達成", + "xpack.reporting.listing.tableValue.createdAtDetail.pendingStatusReachedText": "保留中 - ジョブの処理持ち", + "xpack.reporting.listing.tableValue.createdAtDetail.statusTimestampText": "{statusTimestamp} 時点で {statusLabel}", + "xpack.reporting.management.reportingTitle": "レポート", + "xpack.reporting.panelContent.copyUrlButtonLabel": "POST URL をコピー", + "xpack.reporting.panelContent.generateButtonLabel": "{reportingType} を生成", + "xpack.reporting.panelContent.generationTimeDescription": "{objectType} のサイズによって、{reportingType} の作成には数分かかる場合があります。", + "xpack.reporting.panelContent.howToCallGenerationDescription": "POST URL をコピーして Kibana 外または ウォッチャー から生成を実行することもできます。", + "xpack.reporting.panelContent.noPermissionToGenerateReportDescription": "このレポートを生成するパーミッションがありません。", + "xpack.reporting.panelContent.notification.cantReachServerDescription": "サーバーと通信できません。再試行してください。", + "xpack.reporting.panelContent.notification.reportingErrorTitle": "レポートエラー", + "xpack.reporting.panelContent.saveWorkDescription": "レポートの生成前に変更内容を保存してください。", + "xpack.reporting.panelContent.successfullyQueuedReportNotificationDescription": "管理で進捗を確認できます", + "xpack.reporting.panelContent.successfullyQueuedReportNotificationTitle": "{objectType} のレポートキュー", + "xpack.reporting.panelContent.whatCanBeExportedWarningDescription": "初めに変更内容を保存してください", + "xpack.reporting.panelContent.whatCanBeExportedWarningTitle": "保存された {objectType} のみエクスポートできます", + "xpack.reporting.pdfFooterImageDescription": "PDF のフッターに使用するカスタム画像です", + "xpack.reporting.pdfFooterImageLabel": "PDF フッター画像", + "xpack.reporting.registerFeature.reportingDescription": "ディスカバリ、可視化、ダッシュボードから生成されたレポートを管理します。", + "xpack.reporting.registerFeature.reportingTitle": "レポート", + "xpack.reporting.screenCapturePanelContent.optimizeForPrintingLabel": "印刷用に最適化", + "xpack.reporting.shareContextMenu.csvReportsButtonLabel": "CSV レポート", + "xpack.reporting.shareContextMenu.pdfReportsButtonLabel": "PDF レポート", + "xpack.rollupJobs.appTitle": "ロールアップジョブ", + "xpack.rollupJobs.checkLicense.errorExpiredMessage": "{licenseType} ライセンスが期限切れのため {pluginName} を使用できません", + "xpack.rollupJobs.checkLicense.errorUnavailableMessage": "現在ライセンス情報が利用できないため {pluginName} を使用できません。", + "xpack.rollupJobs.checkLicense.errorUnsupportedMessage": "ご使用の {licenseType} ライセンスは {pluginName} をサポートしていません。ライセンスをアップグレードしてください。", + "xpack.rollupJobs.create.backButton.label": "戻る", + "xpack.rollupJobs.create.dateTypeField": "日付", + "xpack.rollupJobs.create.errors.dateHistogramFieldMissing": "日付フィールドが必要です。", + "xpack.rollupJobs.create.errors.dateHistogramIntervalInvalidCalendarInterval": "「{unit}」単位には 1 の値しか使用できません。{suggestion} を試してみてください。", + "xpack.rollupJobs.create.errors.dateHistogramIntervalInvalidCalendarIntervalSuggestion": "1{unit}", + "xpack.rollupJobs.create.errors.dateHistogramIntervalInvalidFormat": "無効な間隔フォーマット。", + "xpack.rollupJobs.create.errors.dateHistogramIntervalMissing": "間隔が必要です。", + "xpack.rollupJobs.create.errors.histogramIntervalMissing": "これらのヒストグラムフィールドのロールアップには間隔が必要です。", + "xpack.rollupJobs.create.errors.histogramIntervalWholeNumber": "間隔は整数でなければなりません。", + "xpack.rollupJobs.create.errors.histogramIntervalZero": "間隔は 0 よりも大きい値でなければなりません。", + "xpack.rollupJobs.create.errors.idMissing": "名前が必要です。", + "xpack.rollupJobs.create.errors.idSameAsCloned": "名前はクローン名「{clonedId}」と同じにできません。", + "xpack.rollupJobs.create.errors.indexPatternIllegalCharacters": "インデックスパターンから {characterList} を削除してください。", + "xpack.rollupJobs.create.errors.indexPatternMatchesRollupIndices": "インデックスパターンはロールアップインデックスと一致させることができません。", + "xpack.rollupJobs.create.errors.indexPatternMissing": "インデックスパターンが必要です。", + "xpack.rollupJobs.create.errors.indexPatternNoMatchingIndices": "インデックスパターンがどのインデックスとも一致していません。", + "xpack.rollupJobs.create.errors.indexPatternNoTimeFields": "インデックスパターンは時間フィールドを含むインデックスと一致している必要があります。", + "xpack.rollupJobs.create.errors.indexPatternSameAsRollupIndex": "インデックスパターンはロールアップインデックスと同じにできません。", + "xpack.rollupJobs.create.errors.indexPatternSpaces": "インデックスパターンからスペースを削除してください。", + "xpack.rollupJobs.create.errors.indexPatternValidationError": "インデックスパターンの検証中に問題が発生しました: {statusCode} {error}", + "xpack.rollupJobs.create.errors.indexPatternValidationFatalErrorTitle": "ロールアップジョブウィザード、インデックスパターンの検証", + "xpack.rollupJobs.create.errors.metricsTypesMissing": "これらのフィールドのメトリックタイプを選択するか、削除してください: {allMissingTypes}.", + "xpack.rollupJobs.create.errors.rollupCronMissing": "Cron パターンまたは基本間隔が必要です。", + "xpack.rollupJobs.create.errors.rollupDelayInvalidCalendarInterval": "「{unit}」単位には 1 の値しか使用できません。{suggestion} を試してみてください。", + "xpack.rollupJobs.create.errors.rollupDelayInvalidCalendarIntervalSuggestion": "1{unit}", + "xpack.rollupJobs.create.errors.rollupDelayInvalidFormat": "無効な遅延フォーマット。", + "xpack.rollupJobs.create.errors.rollupIndexBeginningPeriod": "インデックス名はピリオドで始めることができません。", + "xpack.rollupJobs.create.errors.rollupIndexCommas": "ロールアップインデックス名からコンマを削除してください。", + "xpack.rollupJobs.create.errors.rollupIndexIllegalCharacters": "ロールアップインデックス名から {characterList} を削除してください。", + "xpack.rollupJobs.create.errors.rollupIndexMissing": "ロールアップインデックスが必要です。", + "xpack.rollupJobs.create.errors.rollupIndexSameAsIndexPattern": "ロールアップインデックスはインデックスパターンと同じにできません。", + "xpack.rollupJobs.create.errors.rollupIndexSpaces": "ロールアップインデックス名からスペースを削除してください。", + "xpack.rollupJobs.create.errors.rollupPageSizeGreaterThanZero": "ページサイズは 0 よりも大きい値でなければなりません。", + "xpack.rollupJobs.create.errors.rollupPageSizeMissing": "ページサイズが必要です。", + "xpack.rollupJobs.create.jobDetails.tabHistogramLabel": "ヒストグラム", + "xpack.rollupJobs.create.jobDetails.tabJsonLabel": "JSON", + "xpack.rollupJobs.create.jobDetails.tabMetricsLabel": "メトリック", + "xpack.rollupJobs.create.jobDetails.tabRequestLabel": "リクエスト", + "xpack.rollupJobs.create.jobDetails.tabSummaryLabel": "概要", + "xpack.rollupJobs.create.jobDetails.tabTermsLabel": "用語", + "xpack.rollupJobs.create.keywordTypeField": "キーワード", + "xpack.rollupJobs.create.navigation.savingText": "保存中", + "xpack.rollupJobs.create.nextButton.label": "次へ", + "xpack.rollupJobs.create.numericTypeField": "数字", + "xpack.rollupJobs.create.saveButton.label": "保存", + "xpack.rollupJobs.create.startJobLabel": "今すぐジョブを開始", + "xpack.rollupJobs.create.stepDateHistogram.fieldDateFieldLabel": "日付フィールド", + "xpack.rollupJobs.create.stepDateHistogram.fieldDelay.helpExampleLabel": "値の例:30s、20m、24h、2d、1w、1M", + "xpack.rollupJobs.create.stepDateHistogram.fieldDelayLabel": "レイテンシバッファー (オプション)", + "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.helpExampleLabel": "サイズの例:1000ms、30s、20m、24h、2d、1w、1M、1y", + "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.preferFixedWarningDayLabel": "1d の代わりに 24h を使うことをお勧めします。そうすることでより柔軟なクエリが可能になります。", + "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.preferFixedWarningHourLabel": "1h の代わりに 60m を使うことをお勧めします。そうすることでより柔軟なクエリが可能になります。", + "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.preferFixedWarningMonthLabel": "M ではなく d 単位の使用をお勧めします。そうすることでより柔軟なクエリが可能です。", + "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.preferFixedWarningWeekLabel": "w ではなく d 単位の使用をお勧めします。そうすることでより柔軟なクエリが可能になります。", + "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.preferFixedWarningYearLabel": "y ではなく d 単位の使用をお勧めします。そうすることでより柔軟なクエリが可能になります。", + "xpack.rollupJobs.create.stepDateHistogram.fieldIntervalLabel": "時間バケットサイズ", + "xpack.rollupJobs.create.stepDateHistogram.fieldTimeZoneLabel": "タイムゾーン", + "xpack.rollupJobs.create.stepDateHistogram.readDocsButtonLabel": "日付ヒストグラムドキュメント", + "xpack.rollupJobs.create.stepDateHistogram.sectionDataSourceDescription": "小さな時間バケットはそれに比例しより多くのスペースを使用します。", + "xpack.rollupJobs.create.stepDateHistogramDescription": "ロールアップデータでの {link} のオペレーションを定義してください。", + "xpack.rollupJobs.create.stepDateHistogramDescription.aggregationsLinkLabel": "日付ヒストグラムの集約", + "xpack.rollupJobs.create.stepDateHistogramTitle": "日付ヒストグラム", + "xpack.rollupJobs.create.stepErrorTitle": "続行する前にエラーを修正してください", + "xpack.rollupJobs.create.stepHistogram.fieldHistogramIntervalLabel": "間隔", + "xpack.rollupJobs.create.stepHistogram.fieldsChooserLabel": "ヒストグラムフィールドを追加", + "xpack.rollupJobs.create.stepHistogram.histogramDescription": "数字の間隔でバケットするフィールドを選択してください。", + "xpack.rollupJobs.create.stepHistogram.readDocsButtonLabel": "ヒストグラムドキュメント", + "xpack.rollupJobs.create.stepHistogram.sectionHistogramIntervalDescription": "これはロールアップ時にヒストグラムバケットが作成される間隔です (例: 5 に設定すると 5 単位 (0-5、5-10 など) のバケットが作成されます)。ヒストグラムグループに対し1 つの間隔しか指定できないため、ヒストグラムでグループ分けされているフィールドには同じ間隔が適用されます。", + "xpack.rollupJobs.create.stepHistogram.sectionHistogramIntervalTitle": "ヒストグラムの間隔", + "xpack.rollupJobs.create.stepHistogramTitle": "ヒストグラム (オプション)", + "xpack.rollupJobs.create.stepLogistics.fieldCron.helpReferenceLinkLabel": "Cron expression の詳細", + "xpack.rollupJobs.create.stepLogistics.fieldCronLabel": "Cron式", + "xpack.rollupJobs.create.stepLogistics.fieldIdLabel": "名前", + "xpack.rollupJobs.create.stepLogistics.fieldIndexPattern.helpAllowLabel": "複数インデックスの一致にワイルドカード ({asterisk}) を使用。", + "xpack.rollupJobs.create.stepLogistics.fieldIndexPattern.helpDisallowLabel": "スペースと {characterList} は使用できません。", + "xpack.rollupJobs.create.stepLogistics.fieldIndexPattern.helpHasMatchesLabel": "成功!インデックスパターンに一致するインデックスがあります。", + "xpack.rollupJobs.create.stepLogistics.fieldIndexPattern.helpMustMatchLabel": "インデックスパターンは、最低 1 つのロールアップ以外のインデックスと一致している必要があります。", + "xpack.rollupJobs.create.stepLogistics.fieldIndexPattern.helpSearchingLabel": "一致するインデックスを検索中…", + "xpack.rollupJobs.create.stepLogistics.fieldIndexPatternLabel": "インデックスパターン", + "xpack.rollupJobs.create.stepLogistics.fieldPageSizeLabel": "ページサイズ", + "xpack.rollupJobs.create.stepLogistics.fieldRollupIndex.helpDisallowLabel": "スペース、コンマ、{characterList} は使用できません。", + "xpack.rollupJobs.create.stepLogistics.fieldRollupIndexLabel": "ロールアップインデックス名", + "xpack.rollupJobs.create.stepLogistics.logisticsDescription": "ロールアップジョブの実行方法とドキュメントのインデックスのタイミングを定義します。", + "xpack.rollupJobs.create.stepLogistics.readDocsButtonLabel": "ロジスティクスドキュメント", + "xpack.rollupJobs.create.stepLogistics.sectionDataFlowDescription": "どのインデックスをロールアップし、いつデータを格納しますか?", + "xpack.rollupJobs.create.stepLogistics.sectionDataFlowTitle": "データフロー", + "xpack.rollupJobs.create.stepLogistics.sectionDelayDescription": "レイテンシバッファーは、データのロールアップを遅らせます。これにより様々な投入レイテンシが可能になり、より忠実性の高いロールアップとなります。デフォルトで、ロールアップジョブは利用可能なすべてのデータのロールアップを試みます。", + "xpack.rollupJobs.create.stepLogistics.sectionDelayTitle": "ロールアップジョブは新しいデータをロールアップするまでどのくらい待ちますか?", + "xpack.rollupJobs.create.stepLogistics.sectionIdDescription": "この名前はロールアップジョブの固有の識別子として使用されます。", + "xpack.rollupJobs.create.stepLogistics.sectionIdTitle": "名前", + "xpack.rollupJobs.create.stepLogistics.sectionPageSizeDescription": "ページサイズが大きいとデータのロールアップが速くなりますが、より多くのメモリーを必要とします。", + "xpack.rollupJobs.create.stepLogistics.sectionPageSizeTitle": "一度にいくつのドキュメントをロールアップしますか?", + "xpack.rollupJobs.create.stepLogistics.sectionSchedule.buttonAdvancedLabel": "Cron expression を作成", + "xpack.rollupJobs.create.stepLogistics.sectionSchedule.buttonBasicLabel": "基本間隔を作成", + "xpack.rollupJobs.create.stepLogistics.sectionScheduleDescription": "データをどの程度の頻度でロールアップしますか?", + "xpack.rollupJobs.create.stepLogistics.sectionScheduleTitle": "スケジュール", + "xpack.rollupJobs.create.stepLogisticsTitle": "ロジスティクス", + "xpack.rollupJobs.create.stepMetrics.allCheckbox": "すべて", + "xpack.rollupJobs.create.stepMetrics.checkboxAverageLabel": "平均", + "xpack.rollupJobs.create.stepMetrics.checkboxMaxLabel": "最高", + "xpack.rollupJobs.create.stepMetrics.checkboxMinLabel": "最低", + "xpack.rollupJobs.create.stepMetrics.checkboxSumLabel": "合計", + "xpack.rollupJobs.create.stepMetrics.checkboxValueCountLabel": "値カウント", + "xpack.rollupJobs.create.stepMetrics.emptyListLabel": "メトリックフィールドが追加されていません", + "xpack.rollupJobs.create.stepMetrics.fieldColumnLabel": "フィールド", + "xpack.rollupJobs.create.stepMetrics.fieldsChooserLabel": "メトリックフィールドを追加", + "xpack.rollupJobs.create.stepMetrics.metricsColumnHeader": "メトリック", + "xpack.rollupJobs.create.stepMetrics.readDocsButtonLabel": "メトリックドキュメント", + "xpack.rollupJobs.create.stepMetrics.selectAllPopoverButtonLabel": "メトリックを選択", + "xpack.rollupJobs.create.stepMetrics.selectAllRowLabel": "すべて", + "xpack.rollupJobs.create.stepMetrics.typeColumnLabel": "タイプ", + "xpack.rollupJobs.create.stepMetricsDescription": "データのロールアップ時に収集するメトリックを選択します。デフォルトでは各グループの doc_counts のみが収集されます。", + "xpack.rollupJobs.create.stepMetricsTitle": "メトリック (オプション)", + "xpack.rollupJobs.create.stepReviewTitle": "「{jobId}」の詳細の確認", + "xpack.rollupJobs.create.steps.stepDateHistogramTitle": "日付ヒストグラム", + "xpack.rollupJobs.create.steps.stepHistogramTitle": "ヒストグラム", + "xpack.rollupJobs.create.steps.stepLogisticsTitle": "ロジスティクス", + "xpack.rollupJobs.create.steps.stepMetricsTitle": "メトリック", + "xpack.rollupJobs.create.steps.stepReviewTitle": "確認して保存", + "xpack.rollupJobs.create.steps.stepTermsTitle": "用語", + "xpack.rollupJobs.create.stepTerms.fieldsChooserLabel": "アイテムフィールドを追加", + "xpack.rollupJobs.create.stepTerms.readDocsButtonLabel": "用語ドキュメント", + "xpack.rollupJobs.create.stepTermsDescription": "用語集約でバケットするフィールドを選択してください。IP アドレスなどの基数の高いフィールドで時間バケットが限られている場合、コストが高くなる可能性があります。", + "xpack.rollupJobs.create.stepTermsTitle": "用語 (オプション)", + "xpack.rollupJobs.createAction.errorTitle": "ロールアップジョブの作成中にエラーが発生", + "xpack.rollupJobs.createAction.failedDefaultErrorMessage": "{statusCode} エラーでリクエスト失敗: {message}", + "xpack.rollupJobs.createAction.jobIdAlreadyExistsErrorMessage": "ID「{jobConfigId}」のジョブが既に存在します。", + "xpack.rollupJobs.createBreadcrumbTitle": "作成", + "xpack.rollupJobs.createTitle": "ロールアップジョブを作成", + "xpack.rollupJobs.deleteAction.errorTitle": "ロールアップジョブの削除中にエラーが発生", + "xpack.rollupJobs.deleteAction.successMultipleNotificationTitle": "{count} 件のロールアップジョブが削除されました", + "xpack.rollupJobs.deleteAction.successSingleNotificationTitle": "ロールアップジョブ「{jobId}」が削除されました", + "xpack.rollupJobs.detailPanel.jobActionMenu.buttonLabel": "管理", + "xpack.rollupJobs.detailPanel.loadingLabel": "ロールアップジョブを読み込み中…", + "xpack.rollupJobs.detailPanel.notFoundLabel": "ロールアップジョブが見つかりません", + "xpack.rollupJobs.editorConfig.dateHistogram.customInterval.helpText": "ロールアップ構成の間隔の倍数でなければなりません: {interval}", + "xpack.rollupJobs.editorConfig.histogram.interval.helpText": "ロールアップ構成の間隔の倍数でなければなりません: {interval}", + "xpack.rollupJobs.editRollupIndexPattern.createIndex.defaultButtonDescription": "要約データに制限された集約を実行します。", + "xpack.rollupJobs.editRollupIndexPattern.createIndex.defaultButtonText": "ロールアップインデックスパターン", + "xpack.rollupJobs.editRollupIndexPattern.createIndex.defaultTypeName": "ロールアップインデックスパターン", + "xpack.rollupJobs.editRollupIndexPattern.createIndex.indexLabel": "ロールアップ", + "xpack.rollupJobs.editRollupIndexPattern.createIndex.noMatchError": "ロールアップインデックスパターンエラー: ロールアップインデックスの 1 つと一致している必要があります", + "xpack.rollupJobs.editRollupIndexPattern.createIndex.tooManyMatchesError": "ロールアップインデックスパターンエラー: 一致できるロールアップインデックスは 1 つだけです", + "xpack.rollupJobs.editRollupIndexPattern.createIndex.uncaughtError": "ロールアップインデックスパターンエラー: {error}", + "xpack.rollupJobs.featureCatalogueDescription": "今後の分析用に履歴データを小さなインデックスに要約して格納します。", + "xpack.rollupJobs.indexMgmtBadge.rollupLabel": "ロールアップ", + "xpack.rollupJobs.indexMgmtToggle.toggleLabel": "ロールアップインデックスを含める", + "xpack.rollupJobs.jobActionMenu.buttonLabel": "{jobCount, plural, one {ジョブ} other {件のジョブ}}の管理", + "xpack.rollupJobs.jobActionMenu.cloneJobLabel": "ジョブのクローンを作成します", + "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.cancelButtonText": "キャンセル", + "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.confirmButtonText": "削除", + "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.deleteSingleJobDescription": "このジョブは開始しました。", + "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.deleteSingleJobTitle": "ロールアップジョブ「{id}」を削除しますか?", + "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.multipleDeletionDescription": "{isSingleSelection, plural, one {このジョブ} other {これらのジョブ}}を削除しようとしています", + "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.multipleDeletionTitle": "{count} 件のロールアップジョブを削除しますか?", + "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.startedMessage": "開始済み", + "xpack.rollupJobs.jobActionMenu.deleteJobLabel": "{isSingleSelection, plural, one {ジョブ} other {件のジョブ}}を削除", + "xpack.rollupJobs.jobActionMenu.jobActionMenuButtonAriaLabel": "ジョブオプション", + "xpack.rollupJobs.jobActionMenu.panelTitle": "ジョブオプション", + "xpack.rollupJobs.jobActionMenu.startJobLabel": "{isSingleSelection, plural, one {ジョブ} other {件のジョブ}}を開始", + "xpack.rollupJobs.jobActionMenu.stopJobLabel": "{isSingleSelection, plural, one {ジョブ} other {件のジョブ}}を停止", + "xpack.rollupJobs.jobActionMenu.updatingText": "更新中", + "xpack.rollupJobs.jobDetails.tabHistogram.intervalLabel": "ヒストグラムの間隔", + "xpack.rollupJobs.jobDetails.tabHistogram.nameColumnLabel": "フィールド", + "xpack.rollupJobs.jobDetails.tabMetrics.nameColumnLabel": "フィールド", + "xpack.rollupJobs.jobDetails.tabMetrics.typesColumnLabel": "タイプ", + "xpack.rollupJobs.jobDetails.tabRequest.descriptionText": "この Elasticsearch リクエストは、このロールアップジョブを作成します。", + "xpack.rollupJobs.jobDetails.tabSummary.itemCronLabel": "Cron", + "xpack.rollupJobs.jobDetails.tabSummary.itemCronTip": "データをロールアップする頻度です", + "xpack.rollupJobs.jobDetails.tabSummary.itemDelay.none": "なし", + "xpack.rollupJobs.jobDetails.tabSummary.itemDelayLabel": "遅延", + "xpack.rollupJobs.jobDetails.tabSummary.itemDocumentsProcessedLabel": "処理されたドキュメント", + "xpack.rollupJobs.jobDetails.tabSummary.itemIndexPatternLabel": "インデックスパターン", + "xpack.rollupJobs.jobDetails.tabSummary.itemIntervalLabel": "間隔", + "xpack.rollupJobs.jobDetails.tabSummary.itemIntervalTip": "データがロールアップされる時間バケットの間隔です", + "xpack.rollupJobs.jobDetails.tabSummary.itemPagesProcessedLabel": "処理されたページ", + "xpack.rollupJobs.jobDetails.tabSummary.itemRollupIndexLabel": "ロールアップインデックス", + "xpack.rollupJobs.jobDetails.tabSummary.itemRollupsIndexedLabel": "インデックスされたロールアップ", + "xpack.rollupJobs.jobDetails.tabSummary.itemTimeFieldLabel": "時間フィールド", + "xpack.rollupJobs.jobDetails.tabSummary.itemTimezoneLabel": "タイムゾーン", + "xpack.rollupJobs.jobDetails.tabSummary.itemTriggerCountLabel": "トリガーカウント", + "xpack.rollupJobs.jobDetails.tabSummary.sectionDateHistogramLabel": "日付ヒストグラム", + "xpack.rollupJobs.jobDetails.tabSummary.sectionLogisticsLabel": "ロジスティクス", + "xpack.rollupJobs.jobDetails.tabSummary.sectionStatsTitle": "統計", + "xpack.rollupJobs.jobList.createButtonLabel": "ロールアップジョブを作成", + "xpack.rollupJobs.jobList.emptyPrompt.createButtonLabel": "ロールアップジョブの作成", + "xpack.rollupJobs.jobList.emptyPromptDescription": "ロールアップジョブは、今後の分析用に履歴データを小さなインデックスに要約して格納します。", + "xpack.rollupJobs.jobList.emptyPromptTitle": "初めてのロールアップジョブの作成", + "xpack.rollupJobs.jobList.loadingErrorTitle": "ロールアップジョブを読み込み中にエラーが発生", + "xpack.rollupJobs.jobList.loadingTitle": "ロールアップジョブを読み込み中…", + "xpack.rollupJobs.jobList.noPermissionText": "ロールアップジョブの表示または追加パーミッションがありません。", + "xpack.rollupJobs.jobList.noPermissionTitle": "パーミッションエラー", + "xpack.rollupJobs.jobListTitle": "ロールアップジョブ", + "xpack.rollupJobs.jobStatus.abortingLabel": "中断中", + "xpack.rollupJobs.jobStatus.indexingLabel": "インデックス", + "xpack.rollupJobs.jobStatus.startedLabel": "開始済み", + "xpack.rollupJobs.jobStatus.stoppedLabel": "停止中", + "xpack.rollupJobs.jobStatus.stoppingLabel": "停止中", + "xpack.rollupJobs.jobStatus.unknownLabel": "不明", + "xpack.rollupJobs.jobTable.headers.delayHeader": "遅延", + "xpack.rollupJobs.jobTable.headers.groupsHeader": "グループ", + "xpack.rollupJobs.jobTable.headers.indexPatternHeader": "インデックスパターン", + "xpack.rollupJobs.jobTable.headers.intervalHeader": "間隔", + "xpack.rollupJobs.jobTable.headers.metricsHeader": "メトリック", + "xpack.rollupJobs.jobTable.headers.nameHeader": "ID", + "xpack.rollupJobs.jobTable.headers.rollupIndexHeader": "ロールアップインデックス", + "xpack.rollupJobs.jobTable.headers.statusHeader": "ステータス", + "xpack.rollupJobs.jobTable.noJobsMatchSearchMessage": "検索条件に一致するロールアップジョブがありません", + "xpack.rollupJobs.jobTable.searchInputPlaceholder": "検索", + "xpack.rollupJobs.listBreadcrumbTitle": "ロールアップジョブ", + "xpack.rollupJobs.loadAction.errorTitle": "ロールアップジョブを読み込み中にエラーが発生", + "xpack.rollupJobs.refreshAction.errorTitle": "ロールアップジョブの更新中にエラーが発生", + "xpack.rollupJobs.rollupIndexPatternsDescription": "ロールアップインデックスを捕捉するインデックスパターンの作成を有効にします。\n それによりロールアップデータに基づくビジュアライゼーションが可能になります。更新\n 変更を適用するにはページ。", + "xpack.rollupJobs.rollupIndexPatternsTitle": "ロールアップインデックスパターンを有効にする", + "xpack.rollupJobs.startJobsAction.errorTitle": "ロールアップジョブの開始中にエラーが発生", + "xpack.rollupJobs.stopJobsAction.errorTitle": "ロールアップジョブの停止中にエラーが発生", + "xpack.searchProfiler.aggregationProfileTabTitle": "集約プロフィール", + "xpack.searchProfiler.basicLicenseTitle": "ベーシック", + "xpack.searchProfiler.errorToastTitle": "JSON 解析エラー", + "xpack.searchProfiler.formIndexLabel": "インデックス", + "xpack.searchProfiler.formProfileButtonLabel": "プロフィール", + "xpack.searchProfiler.goldLicenseTitle": "ゴールド", + "xpack.searchProfiler.highlightDetails.descriptionTitle": "説明", + "xpack.searchProfiler.highlightDetails.selfTimeTitle": "セルフタイム", + "xpack.searchProfiler.highlightDetails.selfTimeTooltip": "子を除き、このクエリコンポーネントだけに使用された時間です", + "xpack.searchProfiler.highlightDetails.timingBreakdownTitle": "時間の内訳", + "xpack.searchProfiler.highlightDetails.totalTimeTitle": "合計時間", + "xpack.searchProfiler.highlightDetails.totalTimeTooltip": "子を除き、このクエリコンポーネントだけに使用された合計時間です", + "xpack.searchProfiler.highlightDetails.typeTitle": "タイプ", + "xpack.searchProfiler.licenseErrorMessageDescription": "さらに可視化するには有効なライセンス ({licenseTypeList} または {platinumLicenseType}), が必要ですが、クラスターに見つかりませんでした。", + "xpack.searchProfiler.licenseHasExpiredMessage": "検索プロフィールを利用できません。ライセンスが期限切れです。", + "xpack.searchProfiler.pageDisplayName": "検索プロファイラー", + "xpack.searchProfiler.platinumLicenseTitle": "プラチナ", + "xpack.searchProfiler.profileTree.cumulativeTimeTitle": "累積時間:", + "xpack.searchProfiler.profileTree.cumulativeTimeTooltip": "インデックス内のすべてのシャードの累積時間です。注: シャードは並行実行が可能なため、実時間ではありません。", + "xpack.searchProfiler.profileTree.header.selfTimeTitle": "セルフタイム", + "xpack.searchProfiler.profileTree.header.totalTimeTitle": "合計時間", + "xpack.searchProfiler.profileTree.header.typeTitle": "タイプと説明", + "xpack.searchProfiler.profileTree.indexTitle": "インデックス", + "xpack.searchProfiler.queryProfileTabTitle": "クエリプロフィール", + "xpack.searchProfiler.registerLicenseDescription": "検索プロファイラーの使用を続けるには、{registerLicenseLink}してください", + "xpack.searchProfiler.registerLicenseLinkLabel": "ライセンスを登録", + "xpack.searchProfiler.registryProviderDescription": "Elasticsearch クエリのパフォーマンスを素早く確認します.", + "xpack.searchProfiler.registryProviderTitle": "検索プロファイラー", + "xpack.searchProfiler.trialLicenseTitle": "トライアル", + "xpack.searchProfiler.unavailableLicenseInformationMessage": "検索プロファイラーを利用できません。現在ライセンス情報が利用できません。", + "xpack.searchProfiler.upgradeLicenseMessage": "現在の {licenseInfo} ライセンスでは検索プロファイラーを利用できません。ライセンスをアップグレードしてください。", + "xpack.security.account.breadcrumb": "アカウント管理", + "xpack.security.account.changePasswordDescription": "アカウントのパスワードを変更します。", + "xpack.security.account.changePasswordForm.cancelButtonLabel": "リセット", + "xpack.security.account.changePasswordForm.confirmPasswordLabel": "新しいパスワードの再入力", + "xpack.security.account.changePasswordForm.currentPasswordLabel": "現在のパスワード", + "xpack.security.account.changePasswordForm.invalidPassword": "現在のパスワードが正しくありません。", + "xpack.security.account.changePasswordForm.newPasswordLabel": "新しいパスワード", + "xpack.security.account.changePasswordForm.passwordRequirements": "6 文字以上使用してください。", + "xpack.security.account.changePasswordForm.saveChangesButtonLabel": "パスワードを変更", + "xpack.security.account.changePasswordNotSupportedText": "このアカウントのパスワードは変更できません。", + "xpack.security.account.changePasswordSuccess": "パスワードが変更されました。", + "xpack.security.account.changePasswordTitle": "パスワード", + "xpack.security.account.currentPasswordRequired": "現在のパスワードが必要です。", + "xpack.security.account.noEmailMessage": "メールアドレスがありません", + "xpack.security.account.passwordLengthDescription": "パスワードが短すぎます。", + "xpack.security.account.passwordsDoNotMatch": "パスワードが一致していません。", + "xpack.security.account.usernameGroupDescription": "この情報は変更できません。", + "xpack.security.account.usernameGroupTitle": "ユーザー名とメールアドレス", + "xpack.security.apiKeys.breadcrumb": "API キー", + "xpack.security.loggedOut.login": "ログイン", + "xpack.security.loggedOut.title": "ログアウト完了", + "xpack.security.login.basicLoginForm.invalidUsernameOrPasswordErrorMessage": "無効なユーザー名またはパスワード再試行してください。", + "xpack.security.login.basicLoginForm.logInButtonLabel": "ログイン", + "xpack.security.login.basicLoginForm.passwordFormRowLabel": "パスワード", + "xpack.security.login.basicLoginForm.unknownErrorMessage": "おっと!エラー。再試行してください。", + "xpack.security.login.basicLoginForm.usernameFormRowLabel": "ユーザー名", + "xpack.security.login.loggedOutDescription": "Kibana からログアウトしました。", + "xpack.security.login.sessionExpiredDescription": "セッションがタイムアウトしました。再試行してください。", + "xpack.security.loginPage.esUnavailableMessage": "詳細は Kibana ログを確認し、このページを再度読み込んでみてください。", + "xpack.security.loginPage.esUnavailableTitle": "Elasticsearch クラスターに接続できません", + "xpack.security.loginPage.requiresSecureConnectionMessage": "システム管理者にお問い合わせください。", + "xpack.security.loginPage.requiresSecureConnectionTitle": "ログインにはセキュアな接続が必要です", + "xpack.security.loginPage.unknownLayoutMessage": "詳細は Kibana ログを確認し、ページを更新して再試行してください。", + "xpack.security.loginPage.unknownLayoutTitle": "サポートされていないログインフォームレイアウト。", + "xpack.security.loginPage.welcomeDescription": "Elastic Stack への入口", + "xpack.security.loginPage.welcomeTitle": "Kibana へようこそ", + "xpack.security.loginPage.xpackUnavailableMessage": "この Kibana ディストリビューションの無料の機能をすべて使用するには、デフォルトの Elasticsearch をアップデートしてください。", + "xpack.security.loginPage.xpackUnavailableTitle": "現在 Kibana に構成されている Elasticsearch クラスターへの接続をキャンセルします。", + "xpack.security.management.apiKeys.deniedPermissionTitle": "API キーを管理するにはパーミッションが必要です", + "xpack.security.management.apiKeys.invalidateApiKey.confirmModal.cancelButtonLabel": "キャンセル", + "xpack.security.management.apiKeys.invalidateApiKey.confirmModal.confirmButtonLabel": "{count, plural, one {API キー} other {API キー}}の無効化", + "xpack.security.management.apiKeys.invalidateApiKey.confirmModal.invalidateMultipleListDescription": "これらの API キーを無効化しようとしています:", + "xpack.security.management.apiKeys.invalidateApiKey.confirmModal.invalidateMultipleTitle": "{count}API キーを無効にしますか?", + "xpack.security.management.apiKeys.invalidateApiKey.confirmModal.invalidateSingleTitle": "API キー「{name}」を無効にしますか?", + "xpack.security.management.apiKeys.invalidateApiKey.errorMultipleNotificationTitle": "{count} 個の API キーの削除中にエラーが発生", + "xpack.security.management.apiKeys.invalidateApiKey.errorSingleNotificationTitle": "API キー「{name}」の削除中にエラーが発生", + "xpack.security.management.apiKeys.invalidateApiKey.successMultipleNotificationTitle": "{count} 個の API キーが無効になりました", + "xpack.security.management.apiKeys.invalidateApiKey.successSingleNotificationTitle": "API キー「{name}」を無効にしますか?", + "xpack.security.management.apiKeys.noPermissionToManageRolesDescription": "システム管理者にお問い合わせください。", + "xpack.security.management.apiKeys.table.actionDeleteAriaLabel": "「{name}」を無効にする", + "xpack.security.management.apiKeys.table.actionDeleteTooltip": "無効にする", + "xpack.security.management.apiKeys.table.actionsColumnName": "アクション", + "xpack.security.management.apiKeys.table.adminText": "あなたは API キー管理者です。", + "xpack.security.management.apiKeys.table.apiKeysAllDescription": "API キーを表示して無効にします。API キーはユーザーの代わりにリクエストを送信します。", + "xpack.security.management.apiKeys.table.apiKeysDisabledErrorDescription": "システム管理者に連絡し、{link} を伝えて API キーを有効にしてください。", + "xpack.security.management.apiKeys.table.apiKeysDisabledErrorLinkText": "ドキュメント", + "xpack.security.management.apiKeys.table.apiKeysDisabledErrorTitle": "Elasticsearch で API キーが有効ではありません", + "xpack.security.management.apiKeys.table.apiKeysOwnDescription": "API キーを表示して無効にします。API キーはユーザーの代わりにリクエストを送信します。", + "xpack.security.management.apiKeys.table.apiKeysTableLoadingMessage": "API キーを読み込み中…", + "xpack.security.management.apiKeys.table.apiKeysTitle": "API キー", + "xpack.security.management.apiKeys.table.creationDateColumnName": "作成済み", + "xpack.security.management.apiKeys.table.emptyPromptAdminTitle": "API キーがありません", + "xpack.security.management.apiKeys.table.emptyPromptConsoleButtonMessage": "コンソールに移動してください", + "xpack.security.management.apiKeys.table.emptyPromptDescription": "コンソールで {link} を作成できます。", + "xpack.security.management.apiKeys.table.emptyPromptDocsLinkMessage": "API キー", + "xpack.security.management.apiKeys.table.emptyPromptNonAdminTitle": "まだ API キーがありません", + "xpack.security.management.apiKeys.table.expirationDateColumnName": "有効期限", + "xpack.security.management.apiKeys.table.expirationDateNeverMessage": "無し", + "xpack.security.management.apiKeys.table.invalidateApiKeyButton": "{count, plural, one {API キー} other {API キー}}を無効にする", + "xpack.security.management.apiKeys.table.loadingApiKeysDescription": "API キーを読み込み中…", + "xpack.security.management.apiKeys.table.loadingApiKeysErrorTitle": "API キーを読み込み中にエラーが発生", + "xpack.security.management.apiKeys.table.nameColumnName": "名前", + "xpack.security.management.apiKeys.table.realmColumnName": "レルム", + "xpack.security.management.apiKeys.table.realmFilterLabel": "レルム", + "xpack.security.management.apiKeys.table.reloadApiKeysButton": "再読み込み", + "xpack.security.management.apiKeys.table.statusColumnName": "ステータス", + "xpack.security.management.apiKeys.table.userFilterLabel": "ユーザー", + "xpack.security.management.apiKeys.table.userNameColumnName": "ユーザー", + "xpack.security.management.apiKeysTitle": "API キー", + "xpack.security.management.changePasswordForm.cancelButtonLabel": "キャンセル", + "xpack.security.management.changePasswordForm.changePasswordLinkLabel": "パスワードを変更", + "xpack.security.management.changePasswordForm.confirmPasswordLabel": "パスワードの確認", + "xpack.security.management.changePasswordForm.currentPasswordLabel": "現在のパスワード", + "xpack.security.management.changePasswordForm.incorrectPasswordDescription": "入力された現在のパスワードが正しくありません。", + "xpack.security.management.changePasswordForm.newPasswordLabel": "新しいパスワード", + "xpack.security.management.changePasswordForm.passwordDontMatchDescription": "パスワードが一致しません", + "xpack.security.management.changePasswordForm.passwordLabel": "パスワード", + "xpack.security.management.changePasswordForm.passwordLengthDescription": "パスワードは最低 6 文字必要です", + "xpack.security.management.changePasswordForm.saveChangesButtonLabel": "変更を保存", + "xpack.security.management.changePasswordForm.updateAndRestartKibanaDescription": "Kibana ユーザーのパスワードを変更後、kibana.yml ファイルを更新し Kibana を再起動する必要があります。", + "xpack.security.management.editRole.cancelButtonLabel": "キャンセル", + "xpack.security.management.editRole.changeAllPrivilegesLink": "(すべて変更)", + "xpack.security.management.editRole.collapsiblePanel.hideLinkText": "非表示", + "xpack.security.management.editRole.collapsiblePanel.showLinkText": "表示", + "xpack.security.management.editRole.createRoleText": "ロールを作成", + "xpack.security.management.editRole.createRoleTitle": "ロールを作成", + "xpack.security.management.editRole.deleteRoleButton.cancelButtonLabel": "いいえ、削除しません", + "xpack.security.management.editRole.deleteRoleButton.confirmButtonLabel": "はい、削除します", + "xpack.security.management.editRole.deleteRoleButton.deleteRoleButtonLabel": "ロールを削除", + "xpack.security.management.editRole.deleteRoleButton.deleteRoleTitle": "ロールの削除", + "xpack.security.management.editRole.deleteRoleButton.deletingRoleConfirmationText": "このロールを削除してよろしいですか?", + "xpack.security.management.editRole.deleteRoleButton.deletingRoleWarningText": "この操作は元に戻すことができません!", + "xpack.security.management.editRole.editRoleTitle": "ロールの編集", + "xpack.security.management.editRole.elasticSearchPrivileges.addIndexPrivilegesButtonLabel": "インデックスの権限を追加", + "xpack.security.management.editRole.elasticSearchPrivileges.addUserTitle": "ユーザーの追加…", + "xpack.security.management.editRole.elasticSearchPrivileges.clusterPrivilegesTitle": "クラスターの権限", + "xpack.security.management.editRole.elasticSearchPrivileges.controlAccessToClusterDataDescription": "クラスターのデータへのアクセスを管理します。", + "xpack.security.management.editRole.elasticSearchPrivileges.howToBeSubmittedOnBehalfOfOtherUsersDescription": "他のユーザーの代理でのリクエストの送信を許可します。", + "xpack.security.management.editRole.elasticSearchPrivileges.indexPrivilegesTitle": "インデックスの権限", + "xpack.security.management.editRole.elasticSearchPrivileges.learnMoreLinkText": "詳細", + "xpack.security.management.editRole.elasticSearchPrivileges.manageRoleActionsDescription": "このロールがクラスターに対して実行できる操作を管理します。", + "xpack.security.management.editRole.elasticSearchPrivileges.runAsPrivilegesTitle": "権限として実行", + "xpack.security.management.editRole.featureTable.enabledRoleFeaturesEnabledColumnTitle": "権限", + "xpack.security.management.editRole.featureTable.enabledRoleFeaturesFeatureColumnTitle": "機能", + "xpack.security.management.editRole.featureTable.excludedFromBasePrivilegsTooltip": "アクセスを許可するには、「カスタム」特権を使用します。{featureName} は基本権限の一部ではありません。", + "xpack.security.management.editRole.indexPrivilegeForm.deleteSpacePrivilegeAriaLabel": "インデックスの権限を削除", + "xpack.security.management.editRole.indexPrivilegeForm.grantedDocumentsQueryFormRowLabel": "提供されたドキュメントのクエリ", + "xpack.security.management.editRole.indexPrivilegeForm.grantReadPrivilegesLabel": "特定のドキュメントの読み込み権限を提供", + "xpack.security.management.editRole.indexPrivilegeForm.indicesFormRowLabel": "インデックス", + "xpack.security.management.editRole.indexPrivilegeForm.privilegesFormRowLabel": "権限", + "xpack.security.management.editRole.modifyingReversedRolesDescription": "リザーブされたロールはビルトインのため削除または変更できません。", + "xpack.security.management.editRole.returnToRoleListButtonLabel": "ロールリストに戻る", + "xpack.security.management.editRole.reversedRoleBadge.reservedRolesCanNotBeModifiedTooltip": "リザーブされたロールはビルトインのため削除または変更できません。", + "xpack.security.management.editRole.roleNameFormRowHelpText": "ロール名は作成後変更できません。", + "xpack.security.management.editRole.roleNameFormRowTitle": "ロール名", + "xpack.security.management.editRole.roleSuccessfullyDeletedNotificationMessage": "ロールを削除しました", + "xpack.security.management.editRole.roleSuccessfullySavedNotificationMessage": "ロールを保存しました", + "xpack.security.management.editRole.setPrivilegesToKibanaDescription": "Elasticsearch データの権限を設定し、Kibana へのアクセスを管理します。", + "xpack.security.management.editRole.setPrivilegesToKibanaSpacesDescription": "Elasticsearch データの権限を設定し、Kibana スペースへのアクセスを管理します。", + "xpack.security.management.editRole.simplePrivilegeForm.allPrivilegeDropdown": "すべて", + "xpack.security.management.editRole.simplePrivilegeForm.allPrivilegeDropdownDescription": "Kibana 全体への完全アクセスを許可します", + "xpack.security.management.editRole.simplePrivilegeForm.allPrivilegeInput": "すべて", + "xpack.security.management.editRole.simplePrivilegeForm.customPrivilegeDropdown": "カスタム", + "xpack.security.management.editRole.simplePrivilegeForm.customPrivilegeDropdownDescription": "Kibana へのアクセスをカスタマイズします", + "xpack.security.management.editRole.simplePrivilegeForm.customPrivilegeInput": "カスタム", + "xpack.security.management.editRole.simplePrivilegeForm.kibanaPrivilegesTitle": "Kibana の権限", + "xpack.security.management.editRole.simplePrivilegeForm.noPrivilegeDropdown": "なし", + "xpack.security.management.editRole.simplePrivilegeForm.noPrivilegeDropdownDescription": "Kibana へのアクセス不可", + "xpack.security.management.editRole.simplePrivilegeForm.noPrivilegeInput": "なし", + "xpack.security.management.editRole.simplePrivilegeForm.readPrivilegeDropdown": "読み込み", + "xpack.security.management.editRole.simplePrivilegeForm.readPrivilegeDropdownDescription": "Kibana 全体への読み込み専用アクセスを許可します", + "xpack.security.management.editRole.simplePrivilegeForm.readPrivilegeInput": "読み込み", + "xpack.security.management.editRole.simplePrivilegeForm.specifyPrivilegeForRoleDescription": "このロールの Kibana の権限を指定します。", + "xpack.security.management.editRole.simplePrivilegeForm.unsupportedSpacePrivilegesWarning": "このロールはスペースへの権限が定義されていますが、Kibana でスペースが有効ではありません。このロールを保存するとこれらの権限が削除されます。", + "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.effectivePrivilegeMessage": "{source} で許可されています。", + "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.globalBasePrivilegeSource": "グローバルベース権限", + "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.globalFeaturePrivilegeSource": "グローバル機能権限", + "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.privilegeSupercededMessage": "{supersededPrivilege} のオリジナルの権限は {actualPrivilegeSource} により上書きされています", + "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.spaceBasePrivilegeSource": "スペースベース権限", + "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.spaceFeaturePrivilegeSource": "スペース機能権限", + "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.unknownPrivilegeSource": "**不明**", + "xpack.security.management.editRole.spaceAwarePrivilegeForm.ensureAccountHasAllPrivilegesGrantedDescription": "{kibanaUser} ロールによりアカウントにすべての権限が提供されていることを確認し、再試行してください。", + "xpack.security.management.editRole.spaceAwarePrivilegeForm.globalSpacesName": "* グローバル (すべてのスペース)", + "xpack.security.management.editRole.spaceAwarePrivilegeForm.howToViewAllAvailableSpacesDescription": "利用可能なすべてのスペースを表示する権限がありません。", + "xpack.security.management.editRole.spaceAwarePrivilegeForm.insufficientPrivilegesDescription": "権限が不十分です", + "xpack.security.management.editRole.spaceAwarePrivilegeForm.kibanaUserTitle": "kibana_user", + "xpack.security.management.editRole.spacePrivilegeForm.allPrivilegeDetails": "選択されたスペースの全機能への完全アクセスを許可します。", + "xpack.security.management.editRole.spacePrivilegeForm.allPrivilegeDisplay": "すべて", + "xpack.security.management.editRole.spacePrivilegeForm.allPrivilegeDropdownDisplay": "すべて", + "xpack.security.management.editRole.spacePrivilegeForm.customizeFeaturePrivilegeDescription": "機能ごとに権限のレベルを上げます。機能によってはスペースごとに非表示になっているか、グローバルスペース権限による影響を受けているものもあります。", + "xpack.security.management.editRole.spacePrivilegeForm.customizeFeaturePrivileges": "機能ごとにカスタマイズ", + "xpack.security.management.editRole.spacePrivilegeForm.customPrivilegeDetails": "選択されたスペースの機能ごとにアクセスをカスタマイズします", + "xpack.security.management.editRole.spacePrivilegeForm.customPrivilegeDisplay": "カスタム", + "xpack.security.management.editRole.spacePrivilegeForm.customPrivilegeDropdownDisplay": "カスタム", + "xpack.security.management.editRole.spacePrivilegeForm.featurePrivilegeSummaryDescription": "機能によってはスペースごとに非表示になっているか、グローバルスペース権限による影響を受けているものもあります。", + "xpack.security.management.editRole.spacePrivilegeForm.globalPrivilegeNotice": "これらの権限はすべての現在および未来のスペースに適用されます。", + "xpack.security.management.editRole.spacePrivilegeForm.globalPrivilegeWarning": "グローバル権限の作成は他のスペース権限に影響を与える可能性があります。", + "xpack.security.management.editRole.spacePrivilegeForm.modalTitle": "スペース権限", + "xpack.security.management.editRole.spacePrivilegeForm.privilegeSelectorFormLabel": "権限", + "xpack.security.management.editRole.spacePrivilegeForm.readPrivilegeDetails": "選択されたスペースの全機能への読み込み専用アクセスを許可します。", + "xpack.security.management.editRole.spacePrivilegeForm.readPrivilegeDisplay": "読み込み", + "xpack.security.management.editRole.spacePrivilegeForm.readPrivilegeDropdownDisplay": "読み込み", + "xpack.security.management.editRole.spacePrivilegeForm.spaceSelectorFormLabel": "スペース", + "xpack.security.management.editRole.spacePrivilegeForm.summaryOfFeaturePrivileges": "機能権限のサマリー", + "xpack.security.management.editRole.spacePrivilegeMatrix.basePrivilegeText": "ベース権限", + "xpack.security.management.editRole.spacePrivilegeMatrix.basePrivilegeTooltip": "基本権限は自動的にすべての機能に与えられます。", + "xpack.security.management.editRole.spacePrivilegeMatrix.closeButton": "閉じる", + "xpack.security.management.editRole.spacePrivilegeMatrix.featureColumnTitle": "機能", + "xpack.security.management.editRole.spacePrivilegeMatrix.globalSpaceName": "グローバル", + "xpack.security.management.editRole.spacePrivilegeMatrix.modalTitle": "権限のサマリー", + "xpack.security.management.editRole.spacePrivilegeMatrix.showAllSpacesLink": "(すべてのスペース)", + "xpack.security.management.editRole.spacePrivilegeMatrix.showNMoreSpacesLink": "他 {count} 件", + "xpack.security.management.editRole.spacePrivilegeMatrix.showSummaryText": "権限サマリーを表示", + "xpack.security.management.editRole.spacePrivilegeSection.addSpacePrivilegeButton": "スペース権限を追加", + "xpack.security.management.editRole.spacePrivilegeSection.noAccessToKibanaTitle": "このロールは Kibana へのアクセスを許可しません", + "xpack.security.management.editRole.spacePrivilegeTable.deletePrivilegesLabel": "次のスペースの権限を削除: {spaceNames}", + "xpack.security.management.editRole.spacePrivilegeTable.editPrivilegesLabel": "次のスペースの権限を編集: {spaceNames}", + "xpack.security.management.editRole.spacePrivilegeTable.showAllSpacesLink": "スペースを表示", + "xpack.security.management.editRole.spacePrivilegeTable.showLessSpacesLink": "縮小表示", + "xpack.security.management.editRole.spacePrivilegeTable.showNMoreSpacesLink": "他 {count} 件", + "xpack.security.management.editRole.spaceSelectorLabel": "スペース", + "xpack.security.management.editRole.spacesPopoverList.findSpacePlaceholder": "スペースを検索", + "xpack.security.management.editRole.spacesPopoverList.noSpacesFoundTitle": " スペースが見つかりません ", + "xpack.security.management.editRole.spacesPopoverList.popoverTitle": "スペース", + "xpack.security.management.editRole.transformErrorSectionDescription": "このロール定義は無効です。この画面では編集できません。", + "xpack.security.management.editRole.transformErrorSectionTitle": "不正形式のロール", + "xpack.security.management.editRole.updateRoleText": "ロールを更新", + "xpack.security.management.editRole.validateRole.indicesTypeErrorMessage": "{elasticIndices} は数列でなければなりません", + "xpack.security.management.editRole.validateRole.nameAllowedCharactersWarningMessage": "名前は文字またはアンダーラインで始まり、文字、アンダーライン、数字のみ使用できます。", + "xpack.security.management.editRole.validateRole.nameLengthWarningMessage": "名前は 1024 文字以内でなければなりません", + "xpack.security.management.editRole.validateRole.onePrivilegeRequiredWarningMessage": "権限が最低 1 つ必要です", + "xpack.security.management.editRole.validateRole.oneSpaceRequiredWarningMessage": "スペースが最低 1 つ必要です", + "xpack.security.management.editRole.validateRole.privilegeRequiredWarningMessage": "権限が必要です", + "xpack.security.management.editRole.validateRole.provideRoleNameWarningMessage": "ロール名を入力してください", + "xpack.security.management.editRole.viewingRoleTitle": "ロールを閲覧中", + "xpack.security.management.editRoles.indexPrivilegeForm.deniedFieldsFormRowLabel": "拒否されたフィールド", + "xpack.security.management.editRoles.indexPrivilegeForm.grantedFieldsFormRowHelpText": "フィールドが提供されていない場合、このロールのユーザーはこのインデックスのデータを表示できません。", + "xpack.security.management.editRoles.indexPrivilegeForm.grantedFieldsFormRowLabel": "許可されたフィールド", + "xpack.security.management.editRoles.indexPrivilegeForm.grantFieldPrivilegesLabel": "特定のフィールドへのアクセスを許可", + "xpack.security.management.editRolespacePrivilegeForm.cancelButton": "キャンセル", + "xpack.security.management.editRolespacePrivilegeForm.createGlobalPrivilegeButton": "グローバル権限を作成", + "xpack.security.management.editRolespacePrivilegeForm.createPrivilegeButton": "スペース権限を作成", + "xpack.security.management.editRolespacePrivilegeForm.updateGlobalPrivilegeButton": "グローバル特権を更新", + "xpack.security.management.editRolespacePrivilegeForm.updatePrivilegeButton": "スペース権限を更新", + "xpack.security.management.passwordForm.confirmPasswordLabel": "パスワードの確認", + "xpack.security.management.passwordForm.passwordDontMatchDescription": "パスワードが一致しません", + "xpack.security.management.passwordForm.passwordLabel": "パスワード", + "xpack.security.management.passwordForm.passwordLengthDescription": "パスワードは最低 6 文字必要です", + "xpack.security.management.roles.actionsColumnName": "アクション", + "xpack.security.management.roles.cloneRoleActionName": "{roleName} を複製", + "xpack.security.management.roles.confirmDelete.cancelButtonLabel": "キャンセル", + "xpack.security.management.roles.confirmDelete.deleteButtonLabel": "削除", + "xpack.security.management.roles.confirmDelete.removingRolesDescription": "これらのロールを削除しようとしています:", + "xpack.security.management.roles.confirmDelete.roleDeletingErrorNotificationMessage": "ロール {roleName} の削除中にエラーが発生しました", + "xpack.security.management.roles.confirmDelete.roleSuccessfullyDeletedNotificationMessage": "ロール {roleName} を削除しました", + "xpack.security.management.roles.createRoleButtonLabel": "ロールを作成", + "xpack.security.management.roles.deleteRoleTitle": "ロール {value, plural, one {{roleName}} other {}} を削除しました", + "xpack.security.management.roles.deleteSelectedRolesButtonLabel": "ロール {numSelected} {numSelected, plural, one { } other {}} を削除しました", + "xpack.security.management.roles.deletingRolesWarningMessage": "この操作は元に戻すことができません。", + "xpack.security.management.roles.deniedPermissionTitle": "ロールを管理するにはパーミッションが必要です", + "xpack.security.management.roles.disabledTooltip": " (無効)", + "xpack.security.management.roles.editRoleActionName": "{roleName} を編集", + "xpack.security.management.roles.fetchingRolesErrorMessage": "ロールの取得中にエラーが発生: {message}", + "xpack.security.management.roles.nameColumnName": "ロール", + "xpack.security.management.roles.noPermissionToManageRolesDescription": "システム管理者にお問い合わせください。", + "xpack.security.management.roles.reservedColumnDescription": "リザーブされたロールはビルトインのため削除または変更できません。", + "xpack.security.management.roles.reservedColumnName": "リザーブ", + "xpack.security.management.roles.reservedRoleIconLabel": "指定済みロール", + "xpack.security.management.roles.roleNotFound": "「{roleName}」ロールが見つかりません。", + "xpack.security.management.roles.roleTitle": "ロール", + "xpack.security.management.roles.subtitle": "ユーザーのグループにロールを適用してスタック全体のパーミッションを管理", + "xpack.security.management.rolesTitle": "ロール", + "xpack.security.management.securityTitle": "セキュリティ", + "xpack.security.management.users.confirmDelete.cancelButtonLabel": "キャンセル", + "xpack.security.management.users.confirmDelete.confirmButtonLabel": "削除", + "xpack.security.management.users.confirmDelete.deleteMultipleUsersTitle": "{userLength} ユーザーの削除", + "xpack.security.management.users.confirmDelete.deleteOneUserTitle": "ユーザー {userLength} の削除", + "xpack.security.management.users.confirmDelete.removingUsersDescription": "これらのユーザーを削除しようとしています:", + "xpack.security.management.users.confirmDelete.removingUsersWarningMessage": "この操作は元に戻すことができません。", + "xpack.security.management.users.confirmDelete.userDeletingErrorNotificationMessage": "ユーザー {username} の削除中にエラーが発生しました", + "xpack.security.management.users.confirmDelete.userSuccessfullyDeletedNotificationMessage": "ユーザー {username} が削除されました", + "xpack.security.management.users.createNewUserButtonLabel": "ユーザーを作成", + "xpack.security.management.users.deleteUsersButtonLabel": "{numSelected} 人のユーザー{numSelected, plural, one { } other {s}} 削除", + "xpack.security.management.users.deniedPermissionTitle": "ユーザーを管理するにはパーミッションが必要です", + "xpack.security.management.users.editUser.addRolesPlaceholder": "ロールを追加", + "xpack.security.management.users.editUser.cancelButtonLabel": "キャンセル", + "xpack.security.management.users.editUser.changePasswordButtonLabel": "パスワードを変更", + "xpack.security.management.users.editUser.changePasswordExtraStepTitle": "追加ステップが必要です", + "xpack.security.management.users.editUser.changePasswordUpdateKibanaTitle": "Kibana ユーザーのパスワードを変更後、{kibana} ファイルを更新し Kibana を再起動する必要があります。", + "xpack.security.management.users.editUser.changingUserNameAfterCreationDescription": "ユーザー名は作成後変更できません。", + "xpack.security.management.users.editUser.confirmPasswordFormRowLabel": "パスワードの確認", + "xpack.security.management.users.editUser.createUserButtonLabel": "ユーザーを作成", + "xpack.security.management.users.editUser.deleteUserButtonLabel": "ユーザーを削除", + "xpack.security.management.users.editUser.editUserTitle": "ユーザー {userName} の編集", + "xpack.security.management.users.editUser.emailAddressFormRowLabel": "メールアドレス", + "xpack.security.management.users.editUser.errorLoadingRolesTitle": "ロールの読み込み中にエラーが発生", + "xpack.security.management.users.editUser.errorLoadingUserTitle": "ユーザーの読み込み中にエラーが発生", + "xpack.security.management.users.editUser.fullNameFormRowLabel": "フルネーム", + "xpack.security.management.users.editUser.modifyingReservedUsersDescription": "リザーブされたユーザーはビルトインのため削除または変更できません。パスワードのみ変更できます。", + "xpack.security.management.users.editUser.newUserTitle": "新規ユーザー", + "xpack.security.management.users.editUser.passwordDoNotMatchErrorMessage": "パスワードが一致しません", + "xpack.security.management.users.editUser.passwordFormRowLabel": "パスワード", + "xpack.security.management.users.editUser.passwordLengthErrorMessage": "パスワードは最低 6 文字必要です", + "xpack.security.management.users.editUser.requiredUsernameErrorMessage": "ユーザー名が必要です。", + "xpack.security.management.users.editUser.returnToUserListButtonLabel": "ユーザーリストに戻る", + "xpack.security.management.users.editUser.rolesFormRowLabel": "ロール", + "xpack.security.management.users.editUser.savingUserErrorMessage": "ユーザーの保存中にエラーが発生しました: {message}", + "xpack.security.management.users.editUser.settingPasswordErrorMessage": "パスワードの設定中にエラーが発生しました: {message}", + "xpack.security.management.users.editUser.updateUserButtonLabel": "ユーザーを更新", + "xpack.security.management.users.editUser.usernameAllowedCharactersErrorMessage": "ユーザー名は文字またはアンダーラインで始まり、文字、アンダーライン、数字のみ使用できます", + "xpack.security.management.users.editUser.usernameFormRowLabel": "ユーザー名", + "xpack.security.management.users.editUser.userSuccessfullySavedNotificationMessage": "保存されたユーザー {message}", + "xpack.security.management.users.editUser.validEmailRequiredErrorMessage": "メールアドレスが無効です", + "xpack.security.management.users.emailAddressColumnName": "メールアドレス", + "xpack.security.management.users.fetchingUsersErrorMessage": "ユーザーの取得中にエラーが発生: {message}", + "xpack.security.management.users.fullNameColumnName": "フルネーム", + "xpack.security.management.users.permissionDeniedToManageUsersDescription": "システム管理者にお問い合わせください。", + "xpack.security.management.users.reservedColumnDescription": "リザーブされたユーザーはビルトインのため削除できません。パスワードのみ変更できます。", + "xpack.security.management.users.reservedColumnName": "リザーブ", + "xpack.security.management.users.rolesColumnName": "ロール", + "xpack.security.management.users.userNameColumnName": "ユーザー名", + "xpack.security.management.users.usersTitle": "ユーザー", + "xpack.security.management.usersTitle": "ユーザー", + "xpack.security.navControlComponent.accountMenuAriaLabel": "アカウントメニュー", + "xpack.security.navControlComponent.editProfileLinkText": "プロフィールを編集", + "xpack.security.navControlComponent.logoutLinkText": "ログアウト", + "xpack.security.overwrittenSession.continueAsUserText": "{username} として続行", + "xpack.security.overwrittenSession.title": "以前別のユーザー名でログインしました。", + "xpack.security.registerFeature.securitySettingsDescription": "ユーザーとロールでデータを保護し、誰が何にアクセスできるのか簡単に管理できます。", + "xpack.security.registerFeature.securitySettingsTitle": "セキュリティ設定", + "xpack.security.roles.breadcrumb": "ロール", + "xpack.security.roles.createBreadcrumb": "作成", + "xpack.security.users.breadcrumb": "ユーザー", + "xpack.security.users.createBreadcrumb": "作成", + "xpack.server.checkLicense.errorExpiredMessage": "{licenseType} ライセンスが期限切れのため {pluginName} を使用できません", + "xpack.server.checkLicense.errorUnavailableMessage": "現在ライセンス情報が利用できないため {pluginName} を使用できません。", + "xpack.server.checkLicense.errorUnsupportedMessage": "ご使用の {licenseType} ライセンスは {pluginName} をサポートしていません。ライセンスをアップグレードしてください。", + "xpack.siem.add_filter_to_global_search_bar.filterForValueHoverAction": "値でフィルターします", + "xpack.siem.andOrBadge.and": "AND", + "xpack.siem.andOrBadge.or": "OR", + "xpack.siem.anomaliesTable.table.anomaliesDescription": "異常", + "xpack.siem.anomaliesTable.table.anomaliesTooltip": "異常表は SIEM グローバル KQL 検索でフィルタリングできません。", + "xpack.siem.anomaliesTable.table.showingDescription": "表示中", + "xpack.siem.anomaliesTable.table.unit": "{totalCount, plural, =1 {anomaly} other {anomalies}}", + "xpack.siem.auditd.abortedAuditStartupDescription": "中断された監査のスタートアップ", + "xpack.siem.auditd.accessErrorDescription": "アクセスエラー", + "xpack.siem.auditd.accessPermissionDescription": "アクセス権限", + "xpack.siem.auditd.accessResultDescription": "アクセス結果", + "xpack.siem.auditd.acquiredCredentialsDescription": "認証情報を取得しました:", + "xpack.siem.auditd.adddedGroupAccountUsingDescription": "以下を使用してグループアカウントを追加:", + "xpack.siem.auditd.addedUserAccountDescription": "ユーザーアカウントを追加しました", + "xpack.siem.auditd.allocatedMemoryForDescription": "割当メモリー", + "xpack.siem.auditd.asDescription": "as", + "xpack.siem.auditd.assignedUserRoleToDescription": "ユーザーロールをアサインしました:", + "xpack.siem.auditd.assignedVmIdDescription": "vm id が割り当てられました", + "xpack.siem.auditd.assignedVMResourceDescription": "割り当てられた vm リソース", + "xpack.siem.auditd.attemptedLoginDescription": "以下を経由してログインを試行しました:", + "xpack.siem.auditd.attemptedLoginFromUnusalPlaceDescription": "通常と異なる場所からログインを試行しました", + "xpack.siem.auditd.attemptedLoginFromUnusualHourDescription": "通常と異なる時間にログインを試行しました", + "xpack.siem.auditd.auditErrorDescription": "監査エラー", + "xpack.siem.auditd.authenticatedToGroupDescription": "グループに認証しました", + "xpack.siem.auditd.authenticatedUsingDescription": "次の手段で認証しました:", + "xpack.siem.auditd.bootedSystemDescription": "システムを起動しました", + "xpack.siem.auditd.boundSocketFromDescription": "次からソケットをバインドしました:", + "xpack.siem.auditd.causedMacPolicyErrorDescription": "がmacポリシーエラーを発生させました", + "xpack.siem.auditd.changedAuditConfigurationDescription": "監査設定を変更しました", + "xpack.siem.auditd.changedAuditFeatureDescription": "監査機能を変更しました", + "xpack.siem.auditd.changedConfigurationWIthDescription": "次の設定を変更しました:", + "xpack.siem.auditd.ChangedFileAttributesOfDescription": "次のファイル属性を変更しました:", + "xpack.siem.auditd.changedFilePermissionOfDescription": "次のファイル権限を変更しました:", + "xpack.siem.auditd.changedGroupDescription": "グループを変更しました", + "xpack.siem.auditd.changedGroupPasswordDescription": "グループのパスワードを変更しました", + "xpack.siem.auditd.changedIdentityUsingDescription": "以下を使用してIDを変更しました:", + "xpack.siem.auditd.changedLoginIdToDescription": "ログインIDを次に変更しました:", + "xpack.siem.auditd.changedMacConfigurationDescription": "mac構成を変更しました", + "xpack.siem.auditd.changedPasswordWithDescription": "次のパスワードを変更しました:", + "xpack.siem.auditd.changedRoleUsingDescription": "以下を使用してロールを変更しました:", + "xpack.siem.auditd.changedSeLinuxBooleanDescription": "selinuxブールを変更しました", + "xpack.siem.auditd.changedSelinuxEnforcementDescription": "selinux執行を変更しました", + "xpack.siem.auditd.changedSystemNameDescription": "システム名を変更しました", + "xpack.siem.auditd.changedSystemTimeWithDescription": "次のシステム時刻を変更しました:", + "xpack.siem.auditd.changedTimeStampOfDescription": "次のタイムスタンプを変更しました:", + "xpack.siem.auditd.changedToRunLevelWithDescription": "次の実行レベルを変更しました:", + "xpack.siem.auditd.changedUserIdDescription": "ユーザー ID が変更されました", + "xpack.siem.auditd.changeidleOwernshipOfDescription": "次のファイルの所有者を変更:", + "xpack.siem.auditd.checkedFileSystemMetadataOfDescription": "次のファイルシステムメタデータを確認しました:", + "xpack.siem.auditd.checkedIntegrityOfDescription": "次の整合性を確認しました:", + "xpack.siem.auditd.chedckedMetaDataOfDescription": "次のメタデータを確認しました:", + "xpack.siem.auditd.connectedUsingDescription": "以下を使用して接続しました:", + "xpack.siem.auditd.crashedProgramDescription": "がプログラムをクラッシュさせました", + "xpack.siem.auditd.createdDirectoryDescription": "ディレクトリを作成しました", + "xpack.siem.auditd.createdVmImageDescription": "仮想マシンイメージを作成しました", + "xpack.siem.auditd.cryptoOfficerLoggedInDescription": "クリプトオフィサーがログイン", + "xpack.siem.auditd.cryptoOfficerLoggedOutDescription": "クリプトオフィサーがログアウト", + "xpack.siem.auditd.deletedDescription": "削除されました", + "xpack.siem.auditd.deletedGroupAccountUsingDescription": "次の手段でグループアカウントを削除", + "xpack.siem.auditd.deletedUserAccountUsingDescription": "以下を使用してユーザーアカウントを削除しました:", + "xpack.siem.auditd.deletedVmImageDescription": "仮想マシンイメージを削除しました", + "xpack.siem.auditd.disposedCredentialsDescription": "次のアカウント認証情報を処理しました:", + "xpack.siem.auditd.endedFromDescription": "終了:", + "xpack.siem.auditd.errorFromDescription": "エラー:", + "xpack.siem.auditd.executedDescription": "実行", + "xpack.siem.auditd.executionOfForbiddenProgramDescription": "禁止されたプログラムの実行", + "xpack.siem.auditd.failedLoginTooManyTimesDescription": "ログイン回数超過によりログインに失敗", + "xpack.siem.auditd.inDescription": "次に含まれる:", + "xpack.siem.auditd.initializedAuditSubsystemDescription": "監査サブシステムを初期化しました", + "xpack.siem.auditd.issuedVmControlDescription": "仮想マシンコントロールを発行しました", + "xpack.siem.auditd.killedProcessIdDescription": "プロセスIDを強制終了しました:", + "xpack.siem.auditd.ListeningForConnectionsUsingDescription": "以下を使用して接続をlistenしています:", + "xpack.siem.auditd.loadedFirewallRuleDescription": "ファイアウォールルールを読み込みました", + "xpack.siem.auditd.loadedMacPolicyDescription": "macポリシーを読み込みました", + "xpack.siem.auditd.loadedSeLinuxPolicyDescription": "selinuxポリシーを読み込みました", + "xpack.siem.auditd.loaedKernelModuleOfDescription": "次のカーネルモジュールを読み込みました:", + "xpack.siem.auditd.lockedAccountDescription": "アカウントをロック", + "xpack.siem.auditd.loggedOutDescription": "ログアウト", + "xpack.siem.auditd.macPermissionDescription": "mac権限", + "xpack.siem.auditd.madeDeviceWithDescription": "デバイスを作成しました:", + "xpack.siem.auditd.migratedVmFromDescription": "仮想マシンを以下から移行しました:", + "xpack.siem.auditd.migratedVmToDescription": "仮想マシンを以下に移行しました:", + "xpack.siem.auditd.modifiedGroupAccountDescription": "グループアカウントを修正", + "xpack.siem.auditd.modifiedLevelOfDescription": "次のレベルを修正:", + "xpack.siem.auditd.modifiedRoleDescription": "ロールを修正:", + "xpack.siem.auditd.modifiedUserAccountDescription": "ユーザーアカウントを修正", + "xpack.siem.auditd.mountedDescription": "マウントしました", + "xpack.siem.auditd.negotiatedCryptoKeyDescription": "暗号キーを交渉しました", + "xpack.siem.auditd.nonExistentDescription": "不明なプロセスに", + "xpack.siem.auditd.OpenedFileDescription": "ファイルを開きました", + "xpack.siem.auditd.openedTooManySessionsDescription": "開いたセッション数が多すぎました", + "xpack.siem.auditd.overrodeLabelOfDescription": "次のラベルを上書き:", + "xpack.siem.auditd.promiscuousModeDescription": "以下を使用してデバイスの無差別モードを変更しました:", + "xpack.siem.auditd.ranCommandDescription": "コマンドを実行しました", + "xpack.siem.auditd.receivedFromDescription": "以下より受信しました:", + "xpack.siem.auditd.reconfiguredAuditDescription": "監査を再構成しました", + "xpack.siem.auditd.refreshedCredentialsForDescription": "認証情報をリフレッシュしました", + "xpack.siem.auditd.relabeledFileSystemDescription": "ファイルシステムのラベルを変更しました", + "xpack.siem.auditd.remoteAuditConnectedDescription": "リモート監査を接続", + "xpack.siem.auditd.remoteAuditDisconnectedDescription": "リモート監査を切断", + "xpack.siem.auditd.removedUserRoleFromDescription": "以下からユーザーロールを削除しました:", + "xpack.siem.auditd.renamedDescription": "名前を変更しました", + "xpack.siem.auditd.resumedAuditLoggingDescription": "監査ログを再開しました", + "xpack.siem.auditd.rotatedAuditLogsDescription": "rotated-audit-logs", + "xpack.siem.auditd.scheduledPolicyOFDescription": "次のポリシーをスケジュール設定しました:", + "xpack.siem.auditd.sentMessageDescription": "メッセージを送信しました", + "xpack.siem.auditd.sentTestDescription": "テストを送信しました", + "xpack.siem.auditd.sentToDescription": "送信先:", + "xpack.siem.auditd.sessionDescription": "セッション", + "xpack.siem.auditd.shutDownAuditDescription": "監査をシャットダウン", + "xpack.siem.auditd.shutdownSystemDescription": "システムをシャットダウン", + "xpack.siem.auditd.startedAtDescription": "開始済み", + "xpack.siem.auditd.startedAuditDescription": "監査を開始", + "xpack.siem.auditd.startedCryptoSessionDescription": "暗号セッションを開始しました", + "xpack.siem.auditd.startedServiceDescription": "サービスを開始しました", + "xpack.siem.auditd.stoppedServiceDescription": "サービスを停止しました", + "xpack.siem.auditd.suspiciousProgramDescription": "不審なプログラムを使用しました", + "xpack.siem.auditd.symLinkedDescription": "シンボルでリンクしました", + "xpack.siem.auditd.testedFileSystemIntegrityDescription": "ファイルシステムの完全性をテスト", + "xpack.siem.auditd.unknownDescription": "不明", + "xpack.siem.auditd.unloadedKernelModuleOfDescription": "次のカーネルモジュールをアンロードしました:", + "xpack.siem.auditd.unlockedAccountDescription": "アカウントのロックを解除しました:", + "xpack.siem.auditd.unmountedDescription": "マウント解除しました", + "xpack.siem.auditd.usingDescription": "using", + "xpack.siem.auditd.violatedAppArmorPolicyFromDescription": "以下からのAppArmorポリシーに違反しました:", + "xpack.siem.auditd.violatedSeccompPolicyWithDescription": "以下からのseccompポリシーに違反しました:", + "xpack.siem.auditd.violatedSeLinuxPolicyDescription": "selinuxポリシーに違反しました", + "xpack.siem.auditd.wasAuthorizedToUseDescription": "が以下の使用を承認されました:", + "xpack.siem.auditd.withResultDescription": "結果付き", + "xpack.siem.authenticationsOverTime.authenticationCountTitle": "認証カウント", + "xpack.siem.authenticationsOverTime.unit": "{totalCount, plural, =1 {authentication} other {authentications}}", + "xpack.siem.authenticationsTable.authenticationFailures": "認証", + "xpack.siem.authenticationsTable.failures": "失敗", + "xpack.siem.authenticationsTable.lastFailedDestination": "前回失敗したデスティネーション", + "xpack.siem.authenticationsTable.lastFailedSource": "前回失敗したソース", + "xpack.siem.authenticationsTable.lastFailedTime": "前回の失敗", + "xpack.siem.authenticationsTable.lastSuccessfulDestination": "前回成功したデスティネーション", + "xpack.siem.authenticationsTable.lastSuccessfulSource": "前回成功したソース", + "xpack.siem.authenticationsTable.lastSuccessfulTime": "前回の成功", + "xpack.siem.authenticationsTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", + "xpack.siem.authenticationsTable.successes": "成功", + "xpack.siem.authenticationsTable.uncommonProcessTable": "非共通プロセス", + "xpack.siem.authenticationsTable.unit": "{totalCount, plural, =1 {user} other {users}}", + "xpack.siem.authenticationsTable.user": "ユーザー", + "xpack.siem.certificate.fingerprint.clientCertLabel": "クライアント証明書", + "xpack.siem.certificate.fingerprint.serverCertLabel": "サーバー証明書", + "xpack.siem.chart.dataAllValuesZerosTitle": "すべての値はゼロを返します", + "xpack.siem.chart.dataNotAvailableTitle": "チャートデータが利用できません", + "xpack.siem.clipboard.copied": "コピー完了", + "xpack.siem.clipboard.copy": "コピー", + "xpack.siem.clipboard.copy.to.the.clipboard": "クリップボードにコピー", + "xpack.siem.clipboard.to.the.clipboard": "クリップボードに", + "xpack.siem.components.embeddables.embeddedMap.destinationLayerLabel": "デスティネーションポイント", + "xpack.siem.components.embeddables.embeddedMap.embeddableHeaderHelp": "マップ構成ヘルプ", + "xpack.siem.components.embeddables.embeddedMap.embeddableHeaderTitle": "ネットワーク マップ", + "xpack.siem.components.embeddables.embeddedMap.embeddablePanelTitle": "ソース -> デスティネーション ポイントツーポイントマップ", + "xpack.siem.components.embeddables.embeddedMap.errorConfiguringEmbeddableApiTitle": "埋め込み可能な API の構成中にエラーが発生", + "xpack.siem.components.embeddables.embeddedMap.errorCreatingMapEmbeddableTitle": "マップに’埋め込み可能なアイテムの作成中にエラーが発生", + "xpack.siem.components.embeddables.embeddedMap.lineLayerLabel": "折れ線", + "xpack.siem.components.embeddables.embeddedMap.sourceLayerLabel": "ソースポイント", + "xpack.siem.components.embeddables.indexPatternsMissingPrompt.errorButtonLabel": "インデックスパターンを編集", + "xpack.siem.components.embeddables.indexPatternsMissingPrompt.errorDescription2": "Kibanaで手動で構成することもできます。", + "xpack.siem.components.embeddables.indexPatternsMissingPrompt.errorTitle": "必要なインデックスパターンが構成されていません", + "xpack.siem.components.embeddables.mapToolTip.errorTitle": "マップ機能の読み込み中にエラーが発生", + "xpack.siem.components.embeddables.mapToolTip.filterForValueHoverAction": "値でフィルターします", + "xpack.siem.components.embeddables.mapToolTip.footerLabel": "{totalFeatures} 件中 {currentFeature} 件 {totalFeatures, plural, =1 {feature} other {features}}", + "xpack.siem.components.embeddables.mapToolTip.lineContent.destinationLabel": "送信先", + "xpack.siem.components.embeddables.mapToolTip.lineContent.sourceLabel": "送信元", + "xpack.siem.components.embeddables.mapToolTip.pointContent.asnTitle": "ASN", + "xpack.siem.components.embeddables.mapToolTip.pointContent.destinationDomainTitle": "デスティネーションドメイン", + "xpack.siem.components.embeddables.mapToolTip.pointContent.destinationIPTitle": "デスティネーション IP", + "xpack.siem.components.embeddables.mapToolTip.pointContent.hostTitle": "ホスト", + "xpack.siem.components.embeddables.mapToolTip.pointContent.locationTitle": "場所", + "xpack.siem.components.embeddables.mapToolTip.pointContent.sourceDomainTitle": "ソースドメイン", + "xpack.siem.components.embeddables.mapToolTip.pointContent.sourceIPTitle": "ソース IP", + "xpack.siem.components.flowControls.selectFlowDirection.bidirectionalButtonLabel": "双方向", + "xpack.siem.components.flowControls.selectFlowDirection.unidirectionalButtonLabel": "一方向", + "xpack.siem.components.flowControls.selectFlowTarget.clientDropDownOptionLabel": "クライアント", + "xpack.siem.components.flowControls.selectFlowTarget.destinationDropDownOptionLabel": "送信先", + "xpack.siem.components.flowControls.selectFlowTarget.serverDropDownOptionLabel": "サーバー", + "xpack.siem.components.flowControls.selectFlowTarget.sourceDropDownOptionLabel": "送信元", + "xpack.siem.components.ml.anomaly.errors.anomaliesTableFetchFailureTitle": "異常表の取得に失敗", + "xpack.siem.components.ml.api.errors.networkErrorFailureTitle": "ネットワークエラー", + "xpack.siem.components.ml.api.errors.statusCodeFailureTitle": "ステータスコード:", + "xpack.siem.components.ml.permissions.errors.machineLearningPermissionsFailureTitle": "機械学習パーミッションエラー", + "xpack.siem.components.mlPopover.jobsTable.filters.groupsLabel": "グループ", + "xpack.siem.components.mlPopover.jobsTable.filters.noGroupsAvailableDescription": "利用可能なグループがありません", + "xpack.siem.components.mlPopover.jobsTable.filters.searchFilterPlaceholder": "例: rare_process_linux", + "xpack.siem.components.mlPopover.jobsTable.filters.showAllJobsLabel": "Elastic ジョブ", + "xpack.siem.components.mlPopover.jobsTable.filters.showSiemJobsLabel": "カスタムジョブ", + "xpack.siem.components.mlPopup.anomalyDetectionButtonLabel": "異常検知", + "xpack.siem.components.mlPopup.anomalyDetectionDescription": "下のいずれかの機械学習ジョブを実行して、SIEM アプリケーション全体の異常イベントを表示することができます。始めに使えるように、いくつかの一般的な検出ジョブが提供されています。独自のカスタムジョブを追加する場合は、{machineLearning} アプリケーションでジョブを作成して「SIEM」でタグ付けすると、ここに追加されます。", + "xpack.siem.components.mlPopup.anomalyDetectionTitle": "異常検知設定", + "xpack.siem.components.mlPopup.cloudLink": "クラウド展開", + "xpack.siem.components.mlPopup.errors.createJobFailureTitle": "ジョブ作成エラー", + "xpack.siem.components.mlPopup.errors.startJobFailureTitle": "ジョブ開始エラー", + "xpack.siem.components.mlPopup.hooks.errors.indexPatternFetchFailureTitle": "インデックスパターン取得エラー", + "xpack.siem.components.mlPopup.hooks.errors.siemJobFetchFailureTitle": "SIEM ジョブ取得エラー", + "xpack.siem.components.mlPopup.jobsTable.createCustomJobButtonLabel": "カスタムジョブを作成", + "xpack.siem.components.mlPopup.jobsTable.jobNameColumn": "ジョブ名", + "xpack.siem.components.mlPopup.jobsTable.noItemsDescription": "SIEM 機械学習ジョブが見つかりませんでした", + "xpack.siem.components.mlPopup.jobsTable.runJobColumn": "ジョブを実行", + "xpack.siem.components.mlPopup.jobsTable.tagsColumn": "グループ", + "xpack.siem.components.mlPopup.licenseButtonLabel": "ライセンスの管理", + "xpack.siem.components.mlPopup.machineLearningLink": "機械学習", + "xpack.siem.components.mlPopup.moduleNotCompatibleDescription": "データが見つかりませんでした。機械学習ジョブ要件の詳細については、{mlDocs}を参照してください。", + "xpack.siem.components.mlPopup.moduleNotCompatibleTitle": "{incompatibleJobCount} 件が {incompatibleJobCount, plural, =1 {job} other {jobs}} 現在利用できません", + "xpack.siem.components.mlPopup.showingLabel": "{filterResultsLength} 件の{filterResultsLength, plural, one {ジョブ} other {ジョブ}}を表示中", + "xpack.siem.components.mlPopup.upgradeButtonLabel": "サブスクリプションオプション", + "xpack.siem.components.mlPopup.upgradeDescription": "SIEM の異常検出機能にアクセスするには、ライセンスをプラチナに更新するか、30 日間の無料トライアルを開始するか、AWS、GCP、または Azure で{cloudLink} にサインアップしてください。その後、機械学習ジョブを実行して異常を表示できます。", + "xpack.siem.components.mlPopup.upgradeTitle": "E lastic Platinum へのアップグレード", + "xpack.siem.containers.errors.dataFetchFailureTitle": "データの取得に失敗", + "xpack.siem.containers.errors.networkFailureTitle": "ネットワーク障害", + "xpack.siem.containers.errors.stopJobFailureTitle": "ジョブ停止エラー", + "xpack.siem.dataProviders.and": "AND", + "xpack.siem.dataProviders.deleteDataProvider": "削除", + "xpack.siem.dataProviders.dropAnything": "何でもドロップできます", + "xpack.siem.dataProviders.dropHere": "ここにドロップしてください", + "xpack.siem.dataProviders.dropHereToAddAnLabel": "ここにドロップして追加します", + "xpack.siem.dataProviders.editMenuItem": "フィルターを編集", + "xpack.siem.dataProviders.editTitle": "フィルターの編集", + "xpack.siem.dataProviders.excludeDataProvider": "結果を除外", + "xpack.siem.dataProviders.existsLabel": "存在する", + "xpack.siem.dataProviders.filterForFieldPresentLabel": "現在のフィールドのフィルター", + "xpack.siem.dataProviders.hereToBuildAn": "して開発", + "xpack.siem.dataProviders.highlighted": "ハイライト", + "xpack.siem.dataProviders.includeDataProvider": "結果を含める", + "xpack.siem.dataProviders.not": "NOT", + "xpack.siem.dataProviders.or": "または", + "xpack.siem.dataProviders.query": "クエリ", + "xpack.siem.dataProviders.reEnableDataProvider": "再度有効にする", + "xpack.siem.dataProviders.removeDataProvider": "データプロバイダーを削除", + "xpack.siem.dataProviders.showOptionsDataProvider": "次のオプションを表示:", + "xpack.siem.dataProviders.temporaryDisableDataProvider": "一時的に無効にする", + "xpack.siem.dataProviders.toBuildAn": "して開発", + "xpack.siem.dataProviders.toggle": "切り替え", + "xpack.siem.dataProviders.valueAriaLabel": "値", + "xpack.siem.dataProviders.valuePlaceholder": "値", + "xpack.siem.draggables.field.categoryLabel": "カテゴリー", + "xpack.siem.draggables.field.fieldLabel": "フィールド", + "xpack.siem.draggables.field.typeLabel": "タイプ", + "xpack.siem.draggables.field.viewCategoryTooltip": "カテゴリーを表示します", + "xpack.siem.editDataProvider.doesNotExistLabel": "存在しません", + "xpack.siem.editDataProvider.existsLabel": "存在する", + "xpack.siem.editDataProvider.fieldLabel": "フィールド", + "xpack.siem.editDataProvider.fieldPlaceholder": "フィールドを選択", + "xpack.siem.editDataProvider.isLabel": "が", + "xpack.siem.editDataProvider.isNotLabel": "is not", + "xpack.siem.editDataProvider.operatorLabel": "演算子", + "xpack.siem.editDataProvider.saveButton": "保存", + "xpack.siem.editDataProvider.selectAnOperatorPlaceholder": "演算子を選択", + "xpack.siem.editDataProvider.valueLabel": "値", + "xpack.siem.editDataProvider.valuePlaceholder": "値", + "xpack.siem.emptyString.emptyStringDescription": "空の文字列", + "xpack.siem.eventDetails.blank": " ", + "xpack.siem.eventDetails.copyToClipboard": "クリップボードにコピー", + "xpack.siem.eventDetails.copyToClipboardTooltip": "クリップボードにコピー", + "xpack.siem.eventDetails.description": "説明", + "xpack.siem.eventDetails.field": "フィールド", + "xpack.siem.eventDetails.filter.placeholder": "フィールド、値、または説明でフィルター…", + "xpack.siem.eventDetails.jsonView": "JSON ビュー", + "xpack.siem.eventDetails.table": "表", + "xpack.siem.eventDetails.toggleColumnTooltip": "列を切り替えます", + "xpack.siem.eventDetails.value": "値", + "xpack.siem.eventsOverTime.eventCountFrequencyByActionTitle": "アクション別のイベントカウント", + "xpack.siem.eventsOverTime.showing": "表示中", + "xpack.siem.eventsOverTime.unit": "{totalCount, plural, =1 {event} other {events}}", + "xpack.siem.eventsViewer.eventsLabel": "イベント", + "xpack.siem.eventsViewer.showingLabel": "表示中", + "xpack.siem.eventsViewer.unit": "{totalCount, plural, =1 {event} other {events}}", + "xpack.siem.featureRegistry.linkSiemTitle": "SIEM", + "xpack.siem.fieldBrowser.categoriesCountTitle": "{totalCount} {totalCount, plural, =1 {category} other {categories}}", + "xpack.siem.fieldBrowser.categoriesTitle": "カテゴリー", + "xpack.siem.fieldBrowser.categoryLabel": "カテゴリー", + "xpack.siem.fieldBrowser.copyToClipboard": "クリップボードにコピー", + "xpack.siem.fieldBrowser.customizeColumnsTitle": "列のカスタマイズ", + "xpack.siem.fieldBrowser.descriptionLabel": "説明", + "xpack.siem.fieldBrowser.fieldLabel": "フィールド", + "xpack.siem.fieldBrowser.fieldsCountTitle": "{totalCount} {totalCount, plural, =1 {field} other {fields}}", + "xpack.siem.fieldBrowser.fieldsTitle": "フィールド", + "xpack.siem.fieldBrowser.filterPlaceholder": "フィールド名", + "xpack.siem.fieldBrowser.noFieldsMatchInputLabel": "{searchInput} に一致するフィールドがありません", + "xpack.siem.fieldBrowser.noFieldsMatchLabel": "一致するフィールドがありません", + "xpack.siem.fieldBrowser.resetFieldsLink": "フィールドをリセット", + "xpack.siem.fieldBrowser.toggleColumnTooltip": "列を切り替えます", + "xpack.siem.fieldBrowser.viewCategoryTooltip": "すべての {categoryId} フィールドを表示します", + "xpack.siem.fieldRenderers.moreLabel": "もっと", + "xpack.siem.flyout.button.text": "タイムライン", + "xpack.siem.flyout.button.timeline": "タイムライン", + "xpack.siem.footer.autoRefreshActiveDescription": "自動更新アクション", + "xpack.siem.footer.autoRefreshActiveTooltip": "自動更新が有効な間、タイムラインはクエリに一致する最新の {numberOfItems} 件のイベントを表示します。", + "xpack.siem.footer.data": "データ", + "xpack.siem.footer.events": "イベント", + "xpack.siem.footer.live": "ライブ", + "xpack.siem.footer.loadingLabel": "読み込み中", + "xpack.siem.footer.loadingTimelineData": "タイムラインデータを読み込み中", + "xpack.siem.footer.loadMoreLabel": "さらに読み込む", + "xpack.siem.footer.of": "/", + "xpack.siem.footer.rows": "行", + "xpack.siem.footer.totalCountOfEvents": "イベントが検索条件に一致します", + "xpack.siem.footer.updated": "更新しました", + "xpack.siem.formatted.duration.aFewMillisecondsTooltip": "数ミリ秒", + "xpack.siem.formatted.duration.aFewNanosecondsTooltip": "数ナノ秒", + "xpack.siem.formatted.duration.aMillisecondTooltip": "1 ミリ秒", + "xpack.siem.formatted.duration.aNanosecondTooltip": "1 ナノ秒", + "xpack.siem.formatted.duration.aSecondTooltip": "1 秒", + "xpack.siem.formatted.duration.invalidDurationTooltip": "無効な期間", + "xpack.siem.formatted.duration.noDurationTooltip": "期間がありません", + "xpack.siem.formatted.duration.zeroNanosecondsTooltip": "0ナノ秒", + "xpack.siem.formattedDuration.tooltipLabel": "生", + "xpack.siem.headerPage.pageSubtitle": "前回のイベント: {beat}", + "xpack.siem.host.details.architectureLabel": "アーキテクチャー", + "xpack.siem.host.details.firstSeenTitle": "初回の認識", + "xpack.siem.host.details.lastSeenTitle": "前回の認識", + "xpack.siem.host.details.overview.cloudProviderTitle": "クラウドプロバイダー", + "xpack.siem.host.details.overview.familyTitle": "ファミリー", + "xpack.siem.host.details.overview.hostIdTitle": "ホスト ID", + "xpack.siem.host.details.overview.inspectTitle": "ホスト概要", + "xpack.siem.host.details.overview.instanceIdTitle": "インスタンス ID", + "xpack.siem.host.details.overview.ipAddressesTitle": "IP アドレス", + "xpack.siem.host.details.overview.macAddressesTitle": "MAC アドレス", + "xpack.siem.host.details.overview.machineTypeTitle": "マシンタイプ", + "xpack.siem.host.details.overview.maxAnomalyScoreByJobTitle": "ジョブ別の最高異常スコア", + "xpack.siem.host.details.overview.osTitle": "オペレーティングシステム", + "xpack.siem.host.details.overview.platformTitle": "プラットフォーム", + "xpack.siem.host.details.overview.regionTitle": "地域", + "xpack.siem.host.details.versionLabel": "バージョン", + "xpack.siem.hosts.emptyActionPrimary": "セットアップの手順を表示", + "xpack.siem.hosts.emptyActionSecondary": "ドキュメントに移動", + "xpack.siem.hosts.emptyTitle": "SIEM アプリケーションのホストに関連したインデックスがないようです", + "xpack.siem.hosts.kqlPlaceholder": "例: host.name: \"foo\"", + "xpack.siem.hosts.navigation.allHostsTitle": "すべてのホスト", + "xpack.siem.hosts.navigation.anomaliesTitle": "異常", + "xpack.siem.hosts.navigation.authenticationsTitle": "認証", + "xpack.siem.hosts.navigation.eventsTitle": "イベント", + "xpack.siem.hosts.navigation.uncommonProcessesTitle": "非共通プロセス", + "xpack.siem.hosts.pageTitle": "すべてのホスト", + "xpack.siem.hostsTable.firstLastSeenToolTip": "選択された日付範囲との相関付けです", + "xpack.siem.hostsTable.hostsTitle": "すべてのホスト", + "xpack.siem.hostsTable.lastSeenTitle": "前回の認識", + "xpack.siem.hostsTable.nameTitle": "名前", + "xpack.siem.hostsTable.osTitle": "オペレーティングシステム", + "xpack.siem.hostsTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", + "xpack.siem.hostsTable.unit": "{totalCount, plural, =1 {host} other {hosts}}", + "xpack.siem.hostsTable.versionTitle": "バージョン", + "xpack.siem.inspect.modal.closeTitle": "閉じる", + "xpack.siem.inspect.modal.indexPatternDescription": "Elasticsearch インデックスに接続したインデックスパターンです。これらのインデックスは Kibana > 高度な設定で構成できます。", + "xpack.siem.inspect.modal.indexPatternLabel": "インデックスパターン", + "xpack.siem.inspect.modal.queryTimeDescription": "クエリの処理の所要時間です。リクエストの送信やブラウザでのパースの時間は含まれません。", + "xpack.siem.inspect.modal.queryTimeLabel": "クエリ時間", + "xpack.siem.inspect.modal.reqTimestampDescription": "リクエストの開始が記録された時刻です", + "xpack.siem.inspect.modal.reqTimestampLabel": "リクエストのタイムスタンプ", + "xpack.siem.inspect.modal.somethingWentWrongDescription": "申し訳ございませんが、何か問題が発生しました。", + "xpack.siem.inspectDescription": "検査", + "xpack.siem.ja3.fingerprint.ja3.fingerprintLabel": "ja3", + "xpack.siem.kpiHosts.hosts.title": "すべてのホスト", + "xpack.siem.kpiHosts.uniqueIps.destinationChartLabel": "Dest.", + "xpack.siem.kpiHosts.uniqueIps.destinationUnitLabel": "デスティネーション", + "xpack.siem.kpiHosts.uniqueIps.sourceChartLabel": "Src.", + "xpack.siem.kpiHosts.uniqueIps.sourceUnitLabel": "ソース", + "xpack.siem.kpiHosts.uniqueIps.title": "固有の IP", + "xpack.siem.kpiHosts.userAuthentications.failChartLabel": "失敗", + "xpack.siem.kpiHosts.userAuthentications.failUnitLabel": "失敗", + "xpack.siem.kpiHosts.userAuthentications.successChartLabel": "成功", + "xpack.siem.kpiHosts.userAuthentications.successUnitLabel": "成功", + "xpack.siem.kpiHosts.userAuthentications.title": "ユーザー認証", + "xpack.siem.kpiNetwork.dnsQueries.title": "DNS クエリ", + "xpack.siem.kpiNetwork.networkEvents.title": "ネットワークイベント", + "xpack.siem.kpiNetwork.tlsHandshakes.title": "TLSハンドシェイク", + "xpack.siem.kpiNetwork.uniqueFlowIds.title": "固有のフロー ID", + "xpack.siem.kpiNetwork.uniquePrivateIps.destinationChartLabel": "Dest.", + "xpack.siem.kpiNetwork.uniquePrivateIps.destinationUnitLabel": "デスティネーション", + "xpack.siem.kpiNetwork.uniquePrivateIps.sourceChartLabel": "Src.", + "xpack.siem.kpiNetwork.uniquePrivateIps.sourceUnitLabel": "ソース", + "xpack.siem.kpiNetwork.uniquePrivateIps.title": "固有のプライベート IP", + "xpack.siem.linkSecurityDescription": "SIEM アプリを閲覧します", + "xpack.siem.markdown.hint.boldLabel": "**太字**", + "xpack.siem.markdown.hint.bulletLabel": "* ビュレット", + "xpack.siem.markdown.hint.codeLabel": "「コード」", + "xpack.siem.markdown.hint.headingLabel": "# 見出し", + "xpack.siem.markdown.hint.imageUrlLabel": "![image](url)", + "xpack.siem.markdown.hint.italicsLabel": "_斜体_", + "xpack.siem.markdown.hint.preformattedLabel": "```プリフォーマット```", + "xpack.siem.markdown.hint.quoteLabel": ">引用", + "xpack.siem.markdown.hint.strikethroughLabel": "取り消し線", + "xpack.siem.markdown.hint.urlLabel": "[link](url)", + "xpack.siem.ml.score.anomalousEntityTitle": "異常エンティティ", + "xpack.siem.ml.score.anomalyJobTitle": "ジョブ", + "xpack.siem.ml.score.detectedTitle": "検出", + "xpack.siem.ml.score.influencedByTitle": "影響因子", + "xpack.siem.ml.score.maxAnomalyScoreTitle": "最高異常スコア", + "xpack.siem.ml.score.narrowToThisDateRangeLink": "この日付範囲に絞り込む", + "xpack.siem.ml.score.viewInMachineLearningLink": "機械学習で表示", + "xpack.siem.ml.table.detectorTitle": "ジョブ名", + "xpack.siem.ml.table.entityTitle": "エンティティ", + "xpack.siem.ml.table.hostNameTitle": "ホスト名", + "xpack.siem.ml.table.influencedByTitle": "影響因子:", + "xpack.siem.ml.table.networkNameTitle": "ネットワークIP", + "xpack.siem.ml.table.scoreTitle": "異常スコア", + "xpack.siem.ml.table.timestampTitle": "タイムスタンプ", + "xpack.siem.modalAllErrors.close.button": "閉じる", + "xpack.siem.modalAllErrors.seeAllErrors.button": "完全なエラーを表示", + "xpack.siem.modalAllErrors.title": "ビジュアライゼーションにエラーがあります", + "xpack.siem.navigation.hosts": "すべてのホスト", + "xpack.siem.navigation.network": "ネットワーク", + "xpack.siem.navigation.overview": "概要", + "xpack.siem.navigation.timelines": "タイムライン", + "xpack.siem.network.emptyActionPrimary": "セットアップの手順を表示", + "xpack.siem.network.emptyActionSecondary": "ドキュメントに移動", + "xpack.siem.network.emptyTitle": "SIEM アプリケーションのネットワークに関連したインデックスがないようです", + "xpack.siem.network.ipDetails.ipOverview.asDestinationDropDownOptionLabel": "送信先として", + "xpack.siem.network.ipDetails.ipOverview.asSourceDropDownOptionLabel": "送信元として", + "xpack.siem.network.ipDetails.ipOverview.autonomousSystemTitle": "自動システム", + "xpack.siem.network.ipDetails.ipOverview.firstSeenTitle": "初回の認識", + "xpack.siem.network.ipDetails.ipOverview.hostIdTitle": "ホスト ID", + "xpack.siem.network.ipDetails.ipOverview.hostNameTitle": "ホスト名", + "xpack.siem.network.ipDetails.ipOverview.inspectTitle": "IP概要", + "xpack.siem.network.ipDetails.ipOverview.ipReputationTitle": "評判", + "xpack.siem.network.ipDetails.ipOverview.lastSeenTitle": "前回の認識", + "xpack.siem.network.ipDetails.ipOverview.locationTitle": "場所", + "xpack.siem.network.ipDetails.ipOverview.maxAnomalyScoreByJobTitle": "ジョブ別の最高異常スコア", + "xpack.siem.network.ipDetails.ipOverview.viewTalosIntelligenceTitle": "talosIntelligence.com", + "xpack.siem.network.ipDetails.ipOverview.viewVirusTotalTitle.": "virustotal.com", + "xpack.siem.network.ipDetails.ipOverview.viewWhoisTitle": "iana.org", + "xpack.siem.network.ipDetails.ipOverview.whoIsTitle": "WhoIs", + "xpack.siem.network.ipDetails.tlsTable.columns.issuerTitle": "発行者", + "xpack.siem.network.ipDetails.tlsTable.columns.ja3FingerPrintTitle": "JA3 フィンガープリント", + "xpack.siem.network.ipDetails.tlsTable.columns.sha1FingerPrintTitle": "SHA1フィンガープリント", + "xpack.siem.network.ipDetails.tlsTable.columns.subjectTitle": "件名", + "xpack.siem.network.ipDetails.tlsTable.columns.validUntilTitle": "有効期限:", + "xpack.siem.network.ipDetails.tlsTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", + "xpack.siem.network.ipDetails.tlsTable.transportLayerSecurityTitle": "トランスポートレイヤーセキュリティ", + "xpack.siem.network.ipDetails.tlsTable.unit": "{totalCount, plural, =1 {issuer} other {issuers}}", + "xpack.siem.network.ipDetails.usersTable.columns.documentCountTitle": "ドキュメントカウント", + "xpack.siem.network.ipDetails.usersTable.columns.groupIdTitle": "グループ ID", + "xpack.siem.network.ipDetails.usersTable.columns.groupNameTitle": "グループ名", + "xpack.siem.network.ipDetails.usersTable.columns.userIdTitle": "ID", + "xpack.siem.network.ipDetails.usersTable.columns.userNameTitle": "ユーザー", + "xpack.siem.network.ipDetails.usersTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", + "xpack.siem.network.ipDetails.usersTable.unit": "{totalCount, plural, =1 {user} other {users}}", + "xpack.siem.network.ipDetails.usersTable.usersTitle": "ユーザー", + "xpack.siem.network.kqlPlaceholder": "例: source.ip: \"foo\"", + "xpack.siem.network.navigation.anomaliesTitle": "異常", + "xpack.siem.network.navigation.dnsTitle": "DNS", + "xpack.siem.network.navigation.flowsTitle": "Flow", + "xpack.siem.network.navigation.tlsTitle": "TLS", + "xpack.siem.network.pageTitle": "ネットワーク", + "xpack.siem.networkDnsTable.column.bytesInTitle": "受信 DNS バイト", + "xpack.siem.networkDnsTable.column.bytesOutTitle": "送信 DNS バイト", + "xpack.siem.networkDnsTable.column.registeredDomain": "登録ドメイン", + "xpack.siem.networkDnsTable.column.TotalQueriesTitle": "クエリ合計", + "xpack.siem.networkDnsTable.column.uniqueDomainsTitle": "固有のドメイン", + "xpack.siem.networkDnsTable.helperTooltip": "これは DNS プロトコルトラフィックのみを示しており、DNS データ逆浸出に使用されたドメインの調査に役立ちます。", + "xpack.siem.networkDnsTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", + "xpack.siem.networkDnsTable.select.includePtrRecords": "PTR 記録を含める", + "xpack.siem.networkDnsTable.title": "トップ DNS ドメイン", + "xpack.siem.networkDnsTable.unit": "{totalCount, plural, =1 {domain} other {domains}}", + "xpack.siem.networkTopCountriesTable.column.bytesInTitle": "受信バイト", + "xpack.siem.networkTopCountriesTable.column.bytesOutTitle": "送信バイト", + "xpack.siem.networkTopCountriesTable.column.countryTitle": "国", + "xpack.siem.networkTopCountriesTable.column.destinationIps": "デスティネーション IP", + "xpack.siem.networkTopCountriesTable.column.flows": "Flow", + "xpack.siem.networkTopCountriesTable.column.sourceIps": "ソース IP", + "xpack.siem.networkTopCountriesTable.heading.destinationCountries": "デスティネーションの国", + "xpack.siem.networkTopCountriesTable.heading.sourceCountries": "ソースの国", + "xpack.siem.networkTopCountriesTable.heading.unit": "{totalCount, plural, =1 {Country} other {Countries}}", + "xpack.siem.networkTopCountriesTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", + "xpack.siem.networkTopNFlowTable.column.asTitle": "自動システム", + "xpack.siem.networkTopNFlowTable.column.bytesInTitle": "受信バイト", + "xpack.siem.networkTopNFlowTable.column.bytesOutTitle": "送信バイト", + "xpack.siem.networkTopNFlowTable.column.destinationIpTitle": "デスティネーション IP", + "xpack.siem.networkTopNFlowTable.column.domainTitle": "ドメイン", + "xpack.siem.networkTopNFlowTable.column.IpTitle": "IP", + "xpack.siem.networkTopNFlowTable.column.sourceIpTitle": "ソース IP", + "xpack.siem.networkTopNFlowTable.destinationIps": "デスティネーション IP", + "xpack.siem.networkTopNFlowTable.flows": "Flow", + "xpack.siem.networkTopNFlowTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", + "xpack.siem.networkTopNFlowTable.sourceIps": "ソース IP", + "xpack.siem.networkTopNFlowTable.unit": "{totalCount, plural, =1 {IP} other {IPs}}", + "xpack.siem.notes.addANotePlaceholder": "メモを追加", + "xpack.siem.notes.addedANoteLabel": "メモを追加しました", + "xpack.siem.notes.addNoteButtonLabel": "メモを追加", + "xpack.siem.notes.cancelButtonLabel": "キャンセル", + "xpack.siem.notes.copyToClipboardButtonLabel": "クリップボードにコピー", + "xpack.siem.notes.noteLabel": "注", + "xpack.siem.notes.notesTitle": "メモ", + "xpack.siem.notes.previewMarkdownTitle": "プレビュー(マークダウン)", + "xpack.siem.notes.search.FilterByUserOrNotePlaceholder": "ユーザーまたはメモでフィルター", + "xpack.siem.open.timeline.cancelButton": "キャンセル", + "xpack.siem.open.timeline.collapseButton": "縮小", + "xpack.siem.open.timeline.deleteButton": "削除", + "xpack.siem.open.timeline.deleteSelectedButton": "選択項目を削除", + "xpack.siem.open.timeline.deleteTimelineModalTitle": "「{title}」を削除しますか?", + "xpack.siem.open.timeline.deleteWarningLabel": "削除すると、このタイムライン自体またはそのメモを復元することはできません。", + "xpack.siem.open.timeline.descriptionTableHeader": "説明", + "xpack.siem.open.timeline.expandButton": "拡張", + "xpack.siem.open.timeline.favoriteSelectedButton": "選択中のお気に入り", + "xpack.siem.open.timeline.favoritesTooltip": "お気に入り", + "xpack.siem.open.timeline.lastModifiedTableHeader": "最終更新:", + "xpack.siem.open.timeline.missingSavedObjectIdTooltip": "savedObjectId がありません", + "xpack.siem.open.timeline.modifiedByTableHeader": "変更者:", + "xpack.siem.open.timeline.notesTooltip": "メモ", + "xpack.siem.open.timeline.onlyFavoritesButtonLabel": "お気に入りのみ", + "xpack.siem.open.timeline.openAsDuplicateTooltip": "重複タイムラインとして開く", + "xpack.siem.open.timeline.openTimelineButton": "タイムラインを開く…", + "xpack.siem.open.timeline.openTimelineTitle": "タイムラインを開く", + "xpack.siem.open.timeline.pinnedEventsTooltip": "ピン付けされたイベント", + "xpack.siem.open.timeline.postedLabel": "投稿:", + "xpack.siem.open.timeline.searchPlaceholder": "例:タイムライン名、または説明", + "xpack.siem.open.timeline.showingNTimelinesLabel": "{totalSearchResultsCount} 件の{totalSearchResultsCount, plural, one {タイムライン} other {タイムライン}}{with}を表示中", + "xpack.siem.open.timeline.timelineNameTableHeader": "タイムライン名", + "xpack.siem.open.timeline.untitledTimelineLabel": "無題のタイムライン", + "xpack.siem.open.timeline.withLabel": "With", + "xpack.siem.open.timeline.zeroTimelinesMatchLabel": "0 件のタイムラインが検索条件に一致", + "xpack.siem.overview.auditBeatAuditTitle": "Auditbeat監査", + "xpack.siem.overview.auditBeatFimTitle": "Auditbeat File Integrityモジュール", + "xpack.siem.overview.auditBeatLoginTitle": "Auditbeatログイン", + "xpack.siem.overview.auditBeatPackageTitle": "Auditbeatパッケージ", + "xpack.siem.overview.auditBeatProcessTitle": "Auditbeatプロセス", + "xpack.siem.overview.auditBeatSocketTitle": "Auditbeatソケット", + "xpack.siem.overview.auditBeatUserTitle": "Auditbeatユーザー", + "xpack.siem.overview.emptyActionPrimary": "セットアップの手順を表示", + "xpack.siem.overview.emptyActionSecondary": "ドキュメントに移動", + "xpack.siem.overview.emptyTitle": "SIEM アプリケーションに関連したインデックスがないようです", + "xpack.siem.overview.endgameDnsTitle": "Endgame DNS", + "xpack.siem.overview.endgameFileTitle": "Endgame ファイル", + "xpack.siem.overview.endgameImageLoadTitle": "Endgame 画像の読み込み", + "xpack.siem.overview.endgameNetworkTitle": "Endgame ネットワーク", + "xpack.siem.overview.endgameProcessTitle": "Endgame プロセス", + "xpack.siem.overview.endgameRegistryTitle": "Endgame レジストリ", + "xpack.siem.overview.endgameSecurityTitle": "Endgame セキュリティ", + "xpack.siem.overview.feedbackText": "Elastic SIEM に関するご意見やご提案は、お気軽に {feedback}", + "xpack.siem.overview.feedbackText.feedbackLinkText": "フィードバックをオンラインで送信", + "xpack.siem.overview.feedbackTitle": "フィードバック", + "xpack.siem.overview.filebeatCiscoTitle": "Filebeat Cisco", + "xpack.siem.overview.filebeatNetflowTitle": "Filebeat Netflow", + "xpack.siem.overview.filebeatPanwTitle": "Filebeat Palo Alto Network", + "xpack.siem.overview.fileBeatSuricataTitle": "Filebeat Suricata", + "xpack.siem.overview.filebeatSystemModuleTitle": "Filebeat システムモジュール", + "xpack.siem.overview.fileBeatZeekTitle": "Filebeat Zeek", + "xpack.siem.overview.hostsAction": "ホストを表示", + "xpack.siem.overview.hostsSubtitle": "表示中:過去 24 時間", + "xpack.siem.overview.hostsTitle": "ホストイベント", + "xpack.siem.overview.networkAction": "ネットワークを表示", + "xpack.siem.overview.networkSubtitle": "表示中:過去 24 時間", + "xpack.siem.overview.networkTitle": "ネットワークイベント", + "xpack.siem.overview.packetBeatDnsTitle": "Packetbeat DNS", + "xpack.siem.overview.packetBeatFlowTitle": "Packetbeatフロー", + "xpack.siem.overview.packetbeatTLSTitle": "Packetbeat TLS", + "xpack.siem.overview.pageBadgeLabel": "ベータ", + "xpack.siem.overview.pageBadgeTooltip": "SIEM は現在ベータ段階です。Kibana repo で問題やバグを報告して、製品の改善にご協力ください。", + "xpack.siem.overview.pageSubtitle": "Elastic Stackによるセキュリティ情報とイベント管理", + "xpack.siem.overview.pageTitle": "SIEM", + "xpack.siem.overview.startedText": "セキュリティ情報およびイベント管理(SIEM)へようこそ。はじめに{docs}や{data}をご参照ください。今後の機能に関する情報やチュートリアルは、{siemSolution} ページをお見逃しなく。", + "xpack.siem.overview.startedText.dataLinkText": "投入データ", + "xpack.siem.overview.startedText.docsLinkText": "ドキュメンテーション", + "xpack.siem.overview.startedText.siemSolutionLinkText": "SIEM ソリューション", + "xpack.siem.overview.startedTitle": "はじめて使う", + "xpack.siem.overview.winlogbeatTitle": "Winlogbeat", + "xpack.siem.pages.fourohfour.noContentFoundDescription": "コンテンツがありません", + "xpack.siem.paginatedTable.rowsButtonLabel": "ページごとの行数", + "xpack.siem.paginatedTable.showingSubtitle": "表示中", + "xpack.siem.paginatedTable.tooManyResultsToastText": "クエリ範囲を縮めて結果をさらにフィルタリングしてください", + "xpack.siem.paginatedTable.tooManyResultsToastTitle": " - 結果が多すぎます", + "xpack.siem.securityDescription": "SIEM アプリを閲覧します", + "xpack.siem.source.destination.packetsLabel": "パケット", + "xpack.siem.system.acceptedAConnectionViaDescription": "次の手段で接続を受け付けました:", + "xpack.siem.system.acceptedDescription": "以下を経由してユーザーを受け入れました:", + "xpack.siem.system.attemptedLoginDescription": "以下を経由してログインを試行しました:", + "xpack.siem.system.createdFileDescription": "ファイルを作成しました", + "xpack.siem.system.deletedFileDescription": "ファイルを削除しました", + "xpack.siem.system.disconnectedViaDescription": "次の手段で接続を解除しました", + "xpack.siem.system.errorDescription": "以下でエラーが生じました:", + "xpack.siem.system.existingPackageDescription": "は既存のパッケージを使用しています", + "xpack.siem.system.existingProcessDescription": "がプロセスを実行しています", + "xpack.siem.system.existingSocketDescription": "が以下から既存のソケットを使用しています:", + "xpack.siem.system.existingUserDescription": "は既存のユーザーです", + "xpack.siem.system.hostDescription": "ホスト情報", + "xpack.siem.system.invalidDescription": "以下を使用しようとする無効な試み:", + "xpack.siem.system.loggedOutDescription": "以下を経由してログアウト:", + "xpack.siem.system.packageInstalledDescription": "パッケージをインストールしました", + "xpack.siem.system.packageRemovedDescription": "パッケージを削除しました", + "xpack.siem.system.packageSystemStartedDescription": "システムを開始しました", + "xpack.siem.system.packageUpdatedDescription": "パッケージを更新しました", + "xpack.siem.system.processErrorDescription": "次に関するプロセスエラーが発生:", + "xpack.siem.system.processStartedDescription": "プロセスを開始しました", + "xpack.siem.system.processStoppedDescription": "プロセスを停止しました", + "xpack.siem.system.socketClosedDescription": "以下とのソケットをクローズしました:", + "xpack.siem.system.socketOpenedDescription": "以下とソケットを開きました:", + "xpack.siem.system.systemDescription": "システム", + "xpack.siem.system.terminatedProcessDescription": "プロセスを中断しました", + "xpack.siem.system.userAddedDescription": "ユーザーが追加されました", + "xpack.siem.system.userChangedDescription": "ユーザーが変更されました", + "xpack.siem.system.userRemovedDescription": "が削除されました", + "xpack.siem.system.usingDescription": "using", + "xpack.siem.system.viaDescription": "経由", + "xpack.siem.system.viaParentProcessDescription": "親プロセスで", + "xpack.siem.system.wasAuthorizedToUseDescription": "が以下の使用を承認されました:", + "xpack.siem.system.withExitCodeDescription": "終了コードで", + "xpack.siem.system.withResultDescription": "結果付き", + "xpack.siem.tables.rowItemHelper.moreDescription": "行は表示されていません", + "xpack.siem.timeline.autosave.warning.description": "別のユーザーがこのタイムラインに変更を加えました。このタイムラインを更新してこれらの変更を取り入れるまで、ユーザーによる変更は自動的に保存されません。", + "xpack.siem.timeline.autosave.warning.refresh.title": "タイムラインを更新", + "xpack.siem.timeline.autosave.warning.title": "更新されるまで自動保存は無効です", + "xpack.siem.timeline.body.actions.collapseAriaLabel": "縮小", + "xpack.siem.timeline.body.actions.expandAriaLabel": "拡張", + "xpack.siem.timeline.body.copyToClipboardButtonLabel": "クリップボードにコピー", + "xpack.siem.timeline.body.notes.addOrViewNotesForThisEventTooltip": "このイベントのメモを追加または表示します", + "xpack.siem.timeline.body.pinning.pinnedTooltip": "イベントはこのタイムラインで継続しています", + "xpack.siem.timeline.body.pinning.pinnnedWithNotesTooltip": "イベントにメモがあり、ピンを外すことができません", + "xpack.siem.timeline.body.pinning.unpinnedTooltip": "このイベントはタイムラインと共に継続していません", + "xpack.siem.timeline.body.renderers.dns.askedForDescription": "要求された", + "xpack.siem.timeline.body.renderers.dns.responseCodeDescription": "応答コード", + "xpack.siem.timeline.body.renderers.dns.viaDescription": "経由", + "xpack.siem.timeline.body.renderers.dns.whichResolvedToDescription": "で解決する", + "xpack.siem.timeline.body.renderers.dns.withQuestionTypeDescription": "質問タイプで", + "xpack.siem.timeline.body.renderers.endgame.aLoginWasAttemptedUsingExplicitCredentialsDescription": "明示認証情報でログインが試みられました", + "xpack.siem.timeline.body.renderers.endgame.asRequestedBySubjectDescription": "サブジェクトにリクエストされた通り", + "xpack.siem.timeline.body.renderers.endgame.loggedOffDescription": "ログオフ", + "xpack.siem.timeline.body.renderers.endgame.logonTypeBatchDescription": "一斉", + "xpack.siem.timeline.body.renderers.endgame.logonTypeCachedInteractiveDescription": "キャッシュインタラクティブ", + "xpack.siem.timeline.body.renderers.endgame.logonTypeInteractiveDescription": "インタラクティブ", + "xpack.siem.timeline.body.renderers.endgame.logonTypeNetworkCleartextDescription": "ネットワーククリアテキスト", + "xpack.siem.timeline.body.renderers.endgame.logonTypeNetworkDescription": "ネットワーク", + "xpack.siem.timeline.body.renderers.endgame.logonTypeNewCredentialsDescription": "新規認証情報", + "xpack.siem.timeline.body.renderers.endgame.logonTypeRemoteInteractiveDescription": "リモートインタラクティブ", + "xpack.siem.timeline.body.renderers.endgame.logonTypeServiceDescription": "サービス", + "xpack.siem.timeline.body.renderers.endgame.logonTypeUnlockDescription": "ロック解除", + "xpack.siem.timeline.body.renderers.endgame.subjectLogonIdDescription": "サブジェクトログオン ID", + "xpack.siem.timeline.body.renderers.endgame.successfullyLoggedInDescription": "正常にログイン", + "xpack.siem.timeline.body.renderers.endgame.targetLogonIdDescription": "ターゲットログオン ID", + "xpack.siem.timeline.body.renderers.endgame.toDescription": "に", + "xpack.siem.timeline.body.renderers.endgame.usingLogonTypeDescription": "ログオンタイプを使用して", + "xpack.siem.timeline.body.renderers.endgame.viaDescription": "経由", + "xpack.siem.timeline.body.renderers.endgame.withSpecialPrivilegesDescription": "割り当てられた特別な権限", + "xpack.siem.timeline.callOut.unauthorized.message.description": "SIEM アプリケーションでタイムラインを自動保存するにはパーミッションが必要ですが、引き続きタイムラインを使用してセキュリティイベントの検索とフィルタリングを行うことはできます。", + "xpack.siem.timeline.categoryTooltip": "カテゴリー", + "xpack.siem.timeline.descriptionTooltip": "説明", + "xpack.siem.timeline.destination": "送信先", + "xpack.siem.timeline.eventsSelect.actions.pinSelected": "選択項目にピン付け", + "xpack.siem.timeline.eventsSelect.actions.selectAll": "すべて", + "xpack.siem.timeline.eventsSelect.actions.selectNone": "なし", + "xpack.siem.timeline.eventsSelect.actions.selectPinned": "ピン付け済み", + "xpack.siem.timeline.eventsSelect.actions.selectUnpinned": "ピンが外されました", + "xpack.siem.timeline.eventsSelect.actions.unpinSelected": "選択項目のピンを外す", + "xpack.siem.timeline.expandableEvent.copyToClipboardToolTip": "クリップボードにコピー", + "xpack.siem.timeline.expandableEvent.eventToolTipTitle": "イベント", + "xpack.siem.timeline.fieldTooltip": "フィールド", + "xpack.siem.timeline.flyout.pane.closeTimelineButtonLabel": "タイムラインを閉じる", + "xpack.siem.timeline.flyout.pane.removeColumnButtonLabel": "列を削除", + "xpack.siem.timeline.flyout.pane.timelinePropertiesAriaLabel": "タイムラインのプロパティ", + "xpack.siem.timeline.properties.descriptionPlaceholder": "説明", + "xpack.siem.timeline.properties.descriptionTooltip": "このタイムラインのイベントのサマリーとメモ", + "xpack.siem.timeline.properties.favoriteTooltip": "お気に入り", + "xpack.siem.timeline.properties.historyLabel": "履歴", + "xpack.siem.timeline.properties.historyToolTip": "このタイムラインに関連したアクションの履歴", + "xpack.siem.timeline.properties.inspectTimelineTitle": "Timeline", + "xpack.siem.timeline.properties.isViewingTooltip": "がこのタイムラインを表示しています", + "xpack.siem.timeline.properties.lockDatePickerDescription": "日付ピッカーをグローバル日付ピッカーにロック", + "xpack.siem.timeline.properties.lockDatePickerTooltip": "現在表示中のページとタイムラインの間の日付/時刻範囲の同期を無効にします", + "xpack.siem.timeline.properties.newTimelineButtonLabel": "新規タイムラインを作成", + "xpack.siem.timeline.properties.notAFavoriteTooltip": "お気に入りではありません", + "xpack.siem.timeline.properties.notesButtonLabel": "メモ", + "xpack.siem.timeline.properties.notesToolTip": "このタイムラインに関するメモを追加して確認します。メモはイベントにも追加できます。", + "xpack.siem.timeline.properties.streamLiveButtonLabel": "ライブストリーム", + "xpack.siem.timeline.properties.streamLiveToolTip": "新しいデータが利用可能になるにつれタイムラインを更新します", + "xpack.siem.timeline.properties.timelineDescription": "タイムラインの説明", + "xpack.siem.timeline.properties.timelineTitleAriaLabel": "タイムラインのタイトル", + "xpack.siem.timeline.properties.titleTitle": "タイトル", + "xpack.siem.timeline.properties.unlockDatePickerDescription": "日付ピッカーのグローバル日付ピッカーへのロックを解除", + "xpack.siem.timeline.properties.unlockDatePickerTooltip": "現在表示中のページとタイムラインの間の日付/時刻範囲の同期を有効にします", + "xpack.siem.timeline.properties.untitledTimelinePlaceholder": "無題のタイムライン", + "xpack.siem.timeline.protocol": "プロトコル", + "xpack.siem.timeline.rangePicker.oneDay": "1 日", + "xpack.siem.timeline.rangePicker.oneMonth": "1 か月", + "xpack.siem.timeline.rangePicker.oneWeek": "1 週間", + "xpack.siem.timeline.rangePicker.oneYear": "1 年", + "xpack.siem.timeline.searchOrFilter.filterDescription": "上のデータプロバイダーからのイベントは、隣接の KQL でフィルターされます", + "xpack.siem.timeline.searchOrFilter.filterKqlPlaceholder": "イベントをフィルター", + "xpack.siem.timeline.searchOrFilter.filterKqlSelectedText": "フィルター", + "xpack.siem.timeline.searchOrFilter.filterKqlTooltip": "上のデータプロバイダーからのイベントは、この KQL でフィルターされます", + "xpack.siem.timeline.searchOrFilter.filterOrSearchWithKql": "KQLでフィルターまたは検索", + "xpack.siem.timeline.searchOrFilter.searchDescription": "上のデータプロバイダーからのイベントは、隣接のKQLからの結果と組み合わされます。", + "xpack.siem.timeline.searchOrFilter.searchKqlPlaceholder": "イベントを検索", + "xpack.siem.timeline.searchOrFilter.searchKqlSelectedText": "検索", + "xpack.siem.timeline.searchOrFilter.searchKqlTooltip": "上のデータプロバイダーからのイベントは、この KQL からの結果と組み合わされます。", + "xpack.siem.timeline.source": "送信元", + "xpack.siem.timeline.tcp": "TCP", + "xpack.siem.timeline.typeTooltip": "タイプ", + "xpack.siem.timelines.allTimelines.panelTitle": "すべてのタイムライン", + "xpack.siem.timelines.pageTitle": "タイムライン", + "xpack.siem.uiSettings.defaultAnomalyScoreDescription": "

機械学習ジョブの異常がこの値を超えると SIEM アプリに表示されます。

有効な値:0 ~ 100。

", + "xpack.siem.uiSettings.defaultAnomalyScoreLabel": "デフォルトの異常しきい値", + "xpack.siem.uiSettings.defaultIndexDescription": "

SIEM アプリがイベントを収集する Elasticsearch インデックスのコンマ区切りのリストです。

", + "xpack.siem.uiSettings.defaultIndexLabel": "デフォルトのインデックス", + "xpack.siem.uiSettings.defaultRefreshIntervalDescription": "

SIEM 時間フィルターのミリ単位のデフォルトの更新間隔です。

", + "xpack.siem.uiSettings.defaultRefreshIntervalLabel": "タイムピッカーの更新間隔", + "xpack.siem.uiSettings.defaultTimeRangeDescription": "

SIEM 時間フィルダーのデフォルトの期間です。

", + "xpack.siem.uiSettings.defaultTimeRangeLabel": "デフォルトのタイムピッカー", + "xpack.siem.uncommonProcessTable.hostsTitle": "すべてのホスト", + "xpack.siem.uncommonProcessTable.lastCommandTitle": "前回のコマンド", + "xpack.siem.uncommonProcessTable.lastUserTitle": "前回のユーザー", + "xpack.siem.uncommonProcessTable.nameTitle": "名前", + "xpack.siem.uncommonProcessTable.numberOfHostsTitle": "ホスト数", + "xpack.siem.uncommonProcessTable.numberOfInstances": "インスタンス", + "xpack.siem.uncommonProcessTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", + "xpack.siem.uncommonProcessTable.unit": "{totalCount, plural, =1 {process} other {processes}}", + "xpack.siem.zeek.othDescription": "SYNが検出されません。ミッドストリームトラフィックのみです", + "xpack.siem.zeek.rejDescription": "接続試行が拒否されました", + "xpack.siem.zeek.rstoODescription": "接続が確立され、接続元が中断しました(RSTを送信)", + "xpack.siem.zeek.rstosoDescription": "接続元がRSTに続きSYNを送信しました。レスポンダーからSYN-ACKはありません", + "xpack.siem.zeek.rstrDescription": "確立され、レスポンダーが中断しました", + "xpack.siem.zeek.rstrhDescription": "レスポンダーがRSTに続き SYNを送信しました。接続元(推定)からSYN-ACKはありません", + "xpack.siem.zeek.s0Description": "接続試行を検出し、返答はありません", + "xpack.siem.zeek.s1Description": "接続が確立され、中断されていません", + "xpack.siem.zeek.s2Description": "接続が確立され、接続元からの終了試行が検出されました(レスポンダーからの返答はありません)", + "xpack.siem.zeek.s3Description": "接続が確立され、レスポンダーからの終了試行が検出されました(接続元からの返答はありません)", + "xpack.siem.zeek.sfDescription": "通常のSYN/FIN完了", + "xpack.siem.zeek.shDescription": "接続元がFINに続きSYNを送信しました。レスポンダーからSYN-ACKはありません", + "xpack.siem.zeek.shrDescription": "レスポンダーがFINに続きSYNを送信しました。接続元からSYN-ACKはありません", + "xpack.snapshotRestore.addPolicy.breadcrumbTitle": "ポリシーを追加", + "xpack.snapshotRestore.addPolicy.loadingIndicesDescription": "利用可能なインデックスを読み込み中…", + "xpack.snapshotRestore.addPolicy.LoadingIndicesErrorMessage": "利用可能なインデックスを読み込み中にエラーが発生", + "xpack.snapshotRestore.addPolicy.savingPolicyErrorTitle": "新規ポリシーを作成できません", + "xpack.snapshotRestore.addPolicyTitle": "ポリシーを作成", + "xpack.snapshotRestore.addRepository.breadcrumbTitle": "レポジトリの追加", + "xpack.snapshotRestore.addRepository.savingRepositoryErrorTitle": "新規レポジトリを登録できません", + "xpack.snapshotRestore.addRepositoryButtonLabel": "レポジトリを登録", + "xpack.snapshotRestore.addRepositoryTitle": "レポジトリの登録", + "xpack.snapshotRestore.app.checkingPrivilegesDescription": "権限を確認中…", + "xpack.snapshotRestore.app.checkingPrivilegesErrorMessage": "サーバーからユーザー特権を取得中にエラーが発生。", + "xpack.snapshotRestore.app.deniedPrivilegeDescription": "スナップショットと復元を使用するには、{privilegesCount, plural, one {このクラスター特権} other {これらのクラスター特権}}が必要です: {missingPrivileges}。", + "xpack.snapshotRestore.app.deniedPrivilegeTitle": "クラスター特権が足りません", + "xpack.snapshotRestore.appName": "スナップショットリポジドリ", + "xpack.snapshotRestore.createPolicyButton": "ポリシーを作成", + "xpack.snapshotRestore.dataPlaceholderLabel": "-", + "xpack.snapshotRestore.deletePolicy.confirmModal.cancelButtonLabel": "キャンセル", + "xpack.snapshotRestore.deletePolicy.confirmModal.confirmButtonLabel": "{count, plural, one {ポリシー} other {ポリシー}}を削除", + "xpack.snapshotRestore.deletePolicy.confirmModal.deleteMultipleListDescription": "これらのポリシーを削除しようとしています:", + "xpack.snapshotRestore.deletePolicy.confirmModal.deleteMultipleTitle": "{count} 件のポリシーを削除しますか?", + "xpack.snapshotRestore.deletePolicy.confirmModal.deleteSingleTitle": "ポリシー「{name}」を削除しますか?", + "xpack.snapshotRestore.deletePolicy.errorMultipleNotificationTitle": "{count} 件のポリシーの削除中にエラーが発生", + "xpack.snapshotRestore.deletePolicy.errorSingleNotificationTitle": "ポリシー {name} の削除中にエラーが発生", + "xpack.snapshotRestore.deletePolicy.successMultipleNotificationTitle": "{count} 件のポリシーが削除されました", + "xpack.snapshotRestore.deletePolicy.successSingleNotificationTitle": "ポリシー「{name}」が削除されました", + "xpack.snapshotRestore.deleteRepository.confirmModal.cancelButtonLabel": "キャンセル", + "xpack.snapshotRestore.deleteRepository.confirmModal.confirmMultipleButtonLabel": "レポジトリを削除", + "xpack.snapshotRestore.deleteRepository.confirmModal.confirmSingleButtonLabel": "レポジトリを削除", + "xpack.snapshotRestore.deleteRepository.confirmModal.deleteMultipleDescription": "これらのレポジトリのスナップショットは現在も存在しますが、Elasticsearch はこれらにアクセスできません。スケジュールされたスナップショットがエラーにならないように、これらのレポジトリを使用するポリシーを調整してください。", + "xpack.snapshotRestore.deleteRepository.confirmModal.deleteMultipleListDescription": "これらのリモートクラスターを削除しようとしています:", + "xpack.snapshotRestore.deleteRepository.confirmModal.deleteMultipleTitle": "{count} 件のレポジトリを削除しますか?", + "xpack.snapshotRestore.deleteRepository.confirmModal.deleteSingleDescription": "これらのレポジトリのスナップショットは現在も存在しますが、Elasticsearch はこれらにアクセスできません。スケジュールされたスナップショットがエラーにならないように、このレポジトリを使用するポリシーを調整してください。", + "xpack.snapshotRestore.deleteRepository.confirmModal.deleteSingleTitle": "レポジトリ「{name}」を削除しますか?", + "xpack.snapshotRestore.deleteRepository.errorMultipleNotificationTitle": "{count} 件のレポジトリの削除中にエラーが発生", + "xpack.snapshotRestore.deleteRepository.errorSingleNotificationTitle": "{name} 件のレポジトリの削除中にエラーが発生", + "xpack.snapshotRestore.deleteRepository.successMultipleNotificationTitle": "{count} 件のレポジトリが削除されました", + "xpack.snapshotRestore.deleteRepository.successSingleNotificationTitle": "レポジトリ「{name}」が削除されました", + "xpack.snapshotRestore.deleteSnapshot.confirmModal.cancelButtonLabel": "キャンセル", + "xpack.snapshotRestore.deleteSnapshot.confirmModal.confirmButtonLabel": "{count, plural, one {スナップショット} other {スナップショット}}を削除", + "xpack.snapshotRestore.deleteSnapshot.confirmModal.deleteMultipleDescription": "{count, plural, one {このスナップショット} other {これらのスナップショット}}に関連付けられた復元処理は停止します。", + "xpack.snapshotRestore.deleteSnapshot.confirmModal.deleteMultipleListDescription": "次のスナップショットを削除しようとしています。", + "xpack.snapshotRestore.deleteSnapshot.confirmModal.deleteMultipleTitle": "{count}件のスナップショットを削除しますか?", + "xpack.snapshotRestore.deleteSnapshot.confirmModal.deleteSingleTitle": "スナップショット'{name}'を削除しますか?", + "xpack.snapshotRestore.deleteSnapshot.confirmModal.deletingCalloutDescription": "これには数分かかる場合があります。", + "xpack.snapshotRestore.deleteSnapshot.confirmModal.deletingCalloutTitle": "スナップショットを削除中", + "xpack.snapshotRestore.deleteSnapshot.errorMultipleNotificationTitle": "{count}件のスナップショットの削除中のエラー", + "xpack.snapshotRestore.deleteSnapshot.errorSingleNotificationTitle": "スナップショット'{name}'の削除中のエラー", + "xpack.snapshotRestore.deleteSnapshot.successMultipleNotificationTitle": "{count}件のスナップショットを削除しました", + "xpack.snapshotRestore.deleteSnapshot.successSingleNotificationTitle": "スナップショット'{name}'を削除しました", + "xpack.snapshotRestore.editPolicy.breadcrumbTitle": "ポリシーの編集", + "xpack.snapshotRestore.editPolicy.loadingIndicesDescription": "利用可能なインデックスを読み込み中…", + "xpack.snapshotRestore.editPolicy.LoadingIndicesErrorMessage": "利用可能なインデックスを読み込み中にエラーが発生", + "xpack.snapshotRestore.editPolicy.loadingPolicyDescription": "ポリシー詳細を読み込み中…", + "xpack.snapshotRestore.editPolicy.loadingPolicyErrorTitle": "ポリシー詳細の読み込み中にエラーが発生", + "xpack.snapshotRestore.editPolicy.policyNotFoundErrorMessage": "ポリシー「{name}」が存在しません。", + "xpack.snapshotRestore.editPolicy.savingPolicyErrorTitle": "ポリシーを保存できません", + "xpack.snapshotRestore.editPolicyTitle": "ポリシーの編集", + "xpack.snapshotRestore.editRepository.breadcrumbTitle": "レポジトリの編集", + "xpack.snapshotRestore.editRepository.loadingRepositoryDescription": "レポジトリ情報を読み込み中…", + "xpack.snapshotRestore.editRepository.loadingRepositoryErrorTitle": "レポジトリ情報の読み込み中にエラーが発生", + "xpack.snapshotRestore.editRepository.managedRepositoryWarningTitle": "これは管理されているレポジトリです。このレポジトリを変更すると、他に使用しているクエリに影響が及ぶ可能性があります。ご注意ください。", + "xpack.snapshotRestore.editRepository.repositoryNotFoundErrorMessage": "レポジトリ「{name}」は存在しません。", + "xpack.snapshotRestore.editRepository.savingRepositoryErrorTitle": "レポジトリを保存できません", + "xpack.snapshotRestore.editRepositoryTitle": "レポジトリの編集", + "xpack.snapshotRestore.emptyPrompt.noSnapshotsDocLinkText": "スナップショットの作成方法をご覧ください", + "xpack.snapshotRestore.emptyPrompt.usePolicyDocLinkText": "Elasticsearch API", + "xpack.snapshotRestore.executePolicy.confirmModal.cancelButtonLabel": "キャンセル", + "xpack.snapshotRestore.executePolicy.confirmModal.confirmButtonLabel": "ポリシーを実行", + "xpack.snapshotRestore.executePolicy.confirmModal.executePolicyTitle": "今すぐ「{name}」を実行しますか?", + "xpack.snapshotRestore.executePolicy.errorNotificationTitle": "ポリシー「{name}」の実行中にエラーが発生", + "xpack.snapshotRestore.executePolicy.successNotificationTitle": "ポリシー「{name}」は実行中です", + "xpack.snapshotRestore.executeRetention.confirmModal.cancelButtonLabel": "キャンセル", + "xpack.snapshotRestore.executeRetention.confirmModal.confirmButtonLabel": "保存を実行", + "xpack.snapshotRestore.executeRetention.confirmModal.executeRetentionTitle": "今すぐスナップショットの保存を実行しますか?", + "xpack.snapshotRestore.executeRetention.errorMessage": "保存の実行中にエラーが発生しました", + "xpack.snapshotRestore.executeRetention.successMessage": "保存を実行中です", + "xpack.snapshotRestore.home.breadcrumbTitle": "スナップショットリポジドリ", + "xpack.snapshotRestore.home.policiesTabTitle": "ポリシー", + "xpack.snapshotRestore.home.repositoriesTabTitle": "レポジトリ", + "xpack.snapshotRestore.home.restoreTabTitle": "ステータスの復元", + "xpack.snapshotRestore.home.snapshotRestoreDescription": "レポジトリを使用して Elasticsearch のインデックスとクラスターのバックアップを保管します。", + "xpack.snapshotRestore.home.snapshotRestoreDocsLinkText": "ドキュメントのスナップショット", + "xpack.snapshotRestore.home.snapshotRestoreTitle": "スナップショットリポジドリ", + "xpack.snapshotRestore.home.snapshotsTabTitle": "スナップショット", + "xpack.snapshotRestore.policies.breadcrumbTitle": "ポリシー", + "xpack.snapshotRestore.policyDetails.allIndicesLabel": "すべてのインデックス", + "xpack.snapshotRestore.policyDetails.closeButtonLabel": "閉じる", + "xpack.snapshotRestore.policyDetails.deleteButtonLabel": "削除", + "xpack.snapshotRestore.policyDetails.editButtonLabel": "編集", + "xpack.snapshotRestore.policyDetails.executeButtonLabel": "今すぐ実行", + "xpack.snapshotRestore.policyDetails.expireAfterLabel": "次の期間後削除:", + "xpack.snapshotRestore.policyDetails.generalTitle": "一般", + "xpack.snapshotRestore.policyDetails.historyTabTitle": "履歴", + "xpack.snapshotRestore.policyDetails.ignoreUnavailableFalseLabel": "いいえ", + "xpack.snapshotRestore.policyDetails.ignoreUnavailableLabel": "利用不可能なインデックスを無視", + "xpack.snapshotRestore.policyDetails.ignoreUnavailableTrueLabel": "はい", + "xpack.snapshotRestore.policyDetails.includeGlobalStateFalseLabel": "いいえ", + "xpack.snapshotRestore.policyDetails.includeGlobalStateLabel": "グローバルステータスを含める", + "xpack.snapshotRestore.policyDetails.includeGlobalStateTrueLabel": "はい", + "xpack.snapshotRestore.policyDetails.indicesCollapseAllLink": "{count, plural, one {# インデックス} other {# インデックス}}を非表示", + "xpack.snapshotRestore.policyDetails.indicesLabel": "インデックス", + "xpack.snapshotRestore.policyDetails.indicesShowAllLink": "{count}その他の{count, plural, one {インデックス} other {インデックス}}を表示", + "xpack.snapshotRestore.policyDetails.inProgressSnapshotLinkText": "「{snapshotName}」が進行中", + "xpack.snapshotRestore.policyDetails.lastFailure.dateLabel": "日付", + "xpack.snapshotRestore.policyDetails.lastFailure.detailsAriaLabel": "ポリシー「{name}」の前回のエラーの詳細", + "xpack.snapshotRestore.policyDetails.lastFailure.detailsLabel": "詳細", + "xpack.snapshotRestore.policyDetails.lastFailure.snapshotNameLabel": "スナップショット名", + "xpack.snapshotRestore.policyDetails.lastFailureTitle": "前回のスナップショットエラー", + "xpack.snapshotRestore.policyDetails.lastSuccess.dateLabel": "日付", + "xpack.snapshotRestore.policyDetails.lastSuccess.snapshotNameLabel": "スナップショット名", + "xpack.snapshotRestore.policyDetails.lastSuccessTitle": "前回成功したスナップショット", + "xpack.snapshotRestore.policyDetails.loadingPolicyDescription": "ポリシーを読み込み中…", + "xpack.snapshotRestore.policyDetails.loadingPolicyErrorTitle": "ポリシーの読み込み中にエラーが発生", + "xpack.snapshotRestore.policyDetails.manageButtonLabel": "ポリシーを管理", + "xpack.snapshotRestore.policyDetails.managePanelTitle": "ポリシーオプション", + "xpack.snapshotRestore.policyDetails.maxCountLabel": "最高カウント", + "xpack.snapshotRestore.policyDetails.minCountLabel": "最低カウント", + "xpack.snapshotRestore.policyDetails.modifiedDateLabel": "最終更新:", + "xpack.snapshotRestore.policyDetails.nextExecutionLabel": "次回のスナップショット", + "xpack.snapshotRestore.policyDetails.noHistoryMessage": "このポリシーは {date} {time} に実行されます。", + "xpack.snapshotRestore.policyDetails.partialFalseLabel": "いいえ", + "xpack.snapshotRestore.policyDetails.partialLabel": "部分シャードを許可", + "xpack.snapshotRestore.policyDetails.partialTrueLabel": "はい", + "xpack.snapshotRestore.policyDetails.policyNotFoundErrorMessage": "ポリシー「{name}」が存在しません。", + "xpack.snapshotRestore.policyDetails.reloadButtonAriaLabel": "再読み込み", + "xpack.snapshotRestore.policyDetails.repositoryLabel": "レポジトリ", + "xpack.snapshotRestore.policyDetails.retentionTitle": "保存", + "xpack.snapshotRestore.policyDetails.scheduleLabel": "スケジュール", + "xpack.snapshotRestore.policyDetails.snapshotDeletionFailuresStat": "削除失敗", + "xpack.snapshotRestore.policyDetails.snapshotNameLabel": "スナップショット名", + "xpack.snapshotRestore.policyDetails.snapshotsDeletedStat": "削除されました", + "xpack.snapshotRestore.policyDetails.snapshotsFailedStat": "失敗", + "xpack.snapshotRestore.policyDetails.snapshotsTakenStat": "スナップショット", + "xpack.snapshotRestore.policyDetails.summaryTabTitle": "まとめ", + "xpack.snapshotRestore.policyDetails.versionLabel": "バージョン", + "xpack.snapshotRestore.policyForm.addRepositoryButtonLabel": "レポジトリを登録", + "xpack.snapshotRestore.policyForm.backButtonLabel": "戻る", + "xpack.snapshotRestore.policyForm.cancelButtonLabel": "キャンセル", + "xpack.snapshotRestore.policyForm.createButtonLabel": "ポリシーを作成", + "xpack.snapshotRestore.policyForm.loadingRepositoriesDescription": "レポジトリを読み込み中…", + "xpack.snapshotRestore.policyForm.loadingRepositoriesErrorMessage": "レポジトリの読み込み中にエラーが発生しました", + "xpack.snapshotRestore.policyForm.navigation.stepLogisticsName": "ロジスティクス", + "xpack.snapshotRestore.policyForm.navigation.stepRetentionName": "スナップショットの保存", + "xpack.snapshotRestore.policyForm.navigation.stepReviewName": "確認", + "xpack.snapshotRestore.policyForm.navigation.stepSettingsName": "スナップショット設定", + "xpack.snapshotRestore.policyForm.nextButtonLabel": "次へ", + "xpack.snapshotRestore.policyForm.noRepositoriesErrorMessage": "スナップショットを格納するレポジトリの登録が必要です。", + "xpack.snapshotRestore.policyForm.noRepositoriesErrorTitle": "レポジトリがありません", + "xpack.snapshotRestore.policyForm.reloadRepositoriesButtonLabel": "レポジトリを再読み込み", + "xpack.snapshotRestore.policyForm.saveButtonLabel": "ポリシーを保存", + "xpack.snapshotRestore.policyForm.savingButtonLabel": "保存中…", + "xpack.snapshotRestore.policyForm.stepLogistics.docsButtonLabel": "ロジスティクスドキュメント", + "xpack.snapshotRestore.policyForm.stepLogistics.nameDescription": "このポリシーの固有の識別子です。", + "xpack.snapshotRestore.policyForm.stepLogistics.nameDescriptionTitle": "ポリシー名", + "xpack.snapshotRestore.policyForm.stepLogistics.nameLabel": "名前", + "xpack.snapshotRestore.policyForm.stepLogistics.namePlaceholder": "daily-snapshots", + "xpack.snapshotRestore.policyForm.stepLogistics.policyRepositoryLabel": "レポジトリ", + "xpack.snapshotRestore.policyForm.stepLogistics.policyScheduleButtonAdvancedLabel": "Cron expression を作成", + "xpack.snapshotRestore.policyForm.stepLogistics.policyScheduleButtonBasicLabel": "基本間隔を作成", + "xpack.snapshotRestore.policyForm.stepLogistics.policyScheduleHelpText": "Cron 表現を使用します。{docLink}", + "xpack.snapshotRestore.policyForm.stepLogistics.policyScheduleHelpTextDocLink": "さらに詳しく", + "xpack.snapshotRestore.policyForm.stepLogistics.policyScheduleLabel": "スケジュール", + "xpack.snapshotRestore.policyForm.stepLogistics.policySnapshotNameHelpText": "日付数学処理表現をサポート。{docLink}", + "xpack.snapshotRestore.policyForm.stepLogistics.policySnapshotNameHelpTextDocLink": "さらに詳しく", + "xpack.snapshotRestore.policyForm.stepLogistics.policySnapshotNameLabel": "スナップショット名", + "xpack.snapshotRestore.policyForm.stepLogistics.policySnapshotNamePlaceholder": "<daily-snap-\\{now \\}>", + "xpack.snapshotRestore.policyForm.stepLogistics.repositoryDescription": "スナップショットを格納する際のレポジトリです。", + "xpack.snapshotRestore.policyForm.stepLogistics.repositoryDescriptionTitle": "レポジトリ", + "xpack.snapshotRestore.policyForm.stepLogistics.scheduleDescription": "スナップショットを撮影する頻度です。", + "xpack.snapshotRestore.policyForm.stepLogistics.scheduleDescriptionTitle": "スケジュール", + "xpack.snapshotRestore.policyForm.stepLogistics.snapshotNameDescription": "スナップショットの名前です。それぞれの名前に自動的に追加される固有の識別子です。", + "xpack.snapshotRestore.policyForm.stepLogistics.snapshotNameDescriptionTitle": "スナップショット名", + "xpack.snapshotRestore.policyForm.stepLogisticsTitle": "ロジスティクス", + "xpack.snapshotRestore.policyForm.stepRetention.countDescription": "クラスターに格納するスナップショットの最少数と最大数。", + "xpack.snapshotRestore.policyForm.stepRetention.countTitle": "保存するスナップショット", + "xpack.snapshotRestore.policyForm.stepRetention.docsButtonLabel": "スナップショット保存ドキュメント", + "xpack.snapshotRestore.policyForm.stepRetention.expirationDescription": "スナップショットの削除までに待つ時間です。", + "xpack.snapshotRestore.policyForm.stepRetention.expirationTitle": "有効期限", + "xpack.snapshotRestore.policyForm.stepRetention.expireAfterLabel": "次の期間後削除:", + "xpack.snapshotRestore.policyForm.stepRetention.maxCountLabel": "最高カウント", + "xpack.snapshotRestore.policyForm.stepRetention.minCountLabel": "最低カウント", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionAddTitle": "保存スケジュールの追加", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionAdvancedLabel": "Cron expression を作成", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionBasicLabel": "基本間隔を作成", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionCancelButtonLabel": "キャンセル", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionEditButtonLabel": "変更を保存", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionEditTitle": "保存スケジュールの編集", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionErrorTitle": "保存スケジュールの保存中にエラーが発生", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionHelpText": "Cron 式を使用します。{docLink}", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionHelpTextDocLinkText": "さらに詳しく", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionSaveButtonLabel": "スケジュール", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionScheduleFieldErrorMessage": "保存スケジュールが必要です。", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionScheduleLabel": "保存スケジュール", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionSuccessMessage": "保存スケジュールが更新されました", + "xpack.snapshotRestore.policyForm.stepRetentionTitle": "スナップショットの保存 (オプション)", + "xpack.snapshotRestore.policyForm.stepReview.editIconAriaLabel": "ステップを編集", + "xpack.snapshotRestore.policyForm.stepReview.requestTabTitle": "リクエスト", + "xpack.snapshotRestore.policyForm.stepReview.retentionTab.expireAfterLabel": "次の期間後削除:", + "xpack.snapshotRestore.policyForm.stepReview.retentionTab.maxCountLabel": "最高カウント", + "xpack.snapshotRestore.policyForm.stepReview.retentionTab.minCountLabel": "最低カウント", + "xpack.snapshotRestore.policyForm.stepReview.retentionTab.sectionRetentionTitle": "スナップショットの保存", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.allIndicesValue": "すべてのインデックス", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.editStepTooltip": "編集", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.ignoreUnavailableFalseLabel": "いいえ", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.ignoreUnavailableLabel": "利用不可能なインデックスを無視", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.ignoreUnavailableTrueLabel": "はい", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.includeGlobalStateFalseLabel": "いいえ", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.includeGlobalStateLabel": "グローバルステータスを含める", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.includeGlobalStateTrueLabel": "はい", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.indicesCollapseAllLink": "{count, plural, one {# インデックス} other {# インデックス}}を非表示", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.indicesLabel": "インデックス", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.indicesShowAllLink": "{count}その他の{count, plural, one {インデックス} other {インデックス}}を表示", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.nameLabel": "ポリシー名", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.partialFalseLabel": "いいえ", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.partialLabel": "部分シャードを許可", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.partialTrueLabel": "はい", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.repositoryLabel": "レポジトリ", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.scheduleLabel": "スケジュール", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.sectionLogisticsTitle": "ロジスティクス", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.sectionSettingsTitle": "スナップショット設定", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.snapshotNameLabel": "スナップショット名", + "xpack.snapshotRestore.policyForm.stepReview.summaryTabTitle": "まとめ", + "xpack.snapshotRestore.policyForm.stepReviewTitle": "レビューポリシー", + "xpack.snapshotRestore.policyForm.stepSettings.allIndicesLabel": "システムインデックスを含むすべてのインデックス", + "xpack.snapshotRestore.policyForm.stepSettings.deselectAllIndicesLink": "すべて選択解除", + "xpack.snapshotRestore.policyForm.stepSettings.docsButtonLabel": "スナップショット設定ドキュメント", + "xpack.snapshotRestore.policyForm.stepSettings.ignoreUnavailableDescription": "スナップショットの撮影時に利用不可能なインデックスを無視します。これが設定されていない場合、スナップショット全体がエラーになります。", + "xpack.snapshotRestore.policyForm.stepSettings.ignoreUnavailableDescriptionTitle": "利用不可能なインデックスを無視", + "xpack.snapshotRestore.policyForm.stepSettings.ignoreUnavailableLabel": "利用不可能なインデックスを無視", + "xpack.snapshotRestore.policyForm.stepSettings.includeGlobalStateDescription": "スナップショットの一部としてクラスターのグローバルステータスを格納します。", + "xpack.snapshotRestore.policyForm.stepSettings.includeGlobalStateDescriptionTitle": "グローバルステータスを含める", + "xpack.snapshotRestore.policyForm.stepSettings.indicesDescription": "バックアップするインデックスです。", + "xpack.snapshotRestore.policyForm.stepSettings.indicesPatternLabel": "インデックスパターン", + "xpack.snapshotRestore.policyForm.stepSettings.indicesPatternPlaceholder": "logstash-* などのインデックスパターンを入力", + "xpack.snapshotRestore.policyForm.stepSettings.indicesTitle": "インデックス", + "xpack.snapshotRestore.policyForm.stepSettings.indicesToggleCustomLink": "インデックスパターンを使用", + "xpack.snapshotRestore.policyForm.stepSettings.indicesToggleListLink": "インデックスを選択", + "xpack.snapshotRestore.policyForm.stepSettings.partialDescription": "利用不可能なプライマリシャードのインデックスのスナップショットを許可します。これが設定されていない場合、スナップショット全体がエラーになります。", + "xpack.snapshotRestore.policyForm.stepSettings.partialDescriptionTitle": "部分インデックスを許可", + "xpack.snapshotRestore.policyForm.stepSettings.partialIndicesToggleSwitch": "部分インデックスを許可", + "xpack.snapshotRestore.policyForm.stepSettings.policyIncludeGlobalStateLabel": "グローバルステータスを含める", + "xpack.snapshotRestore.policyForm.stepSettings.selectAllIndicesLink": "すべて選択", + "xpack.snapshotRestore.policyForm.stepSettings.selectIndicesHelpText": "{count} 件の{count, plural, one {インデックス} other {インデックス}}がバックアップされます。{selectOrDeselectAllLink}", + "xpack.snapshotRestore.policyForm.stepSettings.selectIndicesLabel": "インデックスを選択", + "xpack.snapshotRestore.policyForm.stepSettingsTitle": "スナップショット設定", + "xpack.snapshotRestore.policyList.deniedPrivilegeDescription": "スナップショットライフサイクルポリシーを管理するには、{privilegesCount, plural, one {このクラスター特権} other {これらのクラスター特権}}が必要です: {missingPrivileges}。", + "xpack.snapshotRestore.policyList.deniedPrivilegeTitle": "クラスター特権が足りません", + "xpack.snapshotRestore.policyList.emptyPromptDescription": "クラスターを自動的にバックアップするポリシーを作成します。", + "xpack.snapshotRestore.policyList.emptyPromptTitle": "まだスナップショットポリシーがありません", + "xpack.snapshotRestore.policyList.loadingPoliciesDescription": "ポリシーを読み込み中…", + "xpack.snapshotRestore.policyList.LoadingPoliciesErrorMessage": "ポリシーの読み込み中にエラーが発生しました", + "xpack.snapshotRestore.policyList.table.actionDeleteAriaLabel": "ポリシー「{name}」を削除", + "xpack.snapshotRestore.policyList.table.actionDeleteTooltip": "削除", + "xpack.snapshotRestore.policyList.table.actionEditAriaLabel": "ポリシー「{name}」の編集", + "xpack.snapshotRestore.policyList.table.actionEditTooltip": "編集", + "xpack.snapshotRestore.policyList.table.actionExecuteAriaLabel": "「{name}」を直ちに実行", + "xpack.snapshotRestore.policyList.table.actionExecuteDisabledTooltip": "ポリシーを実行中です", + "xpack.snapshotRestore.policyList.table.actionExecuteTooltip": "今すぐ実行", + "xpack.snapshotRestore.policyList.table.actionsColumnTitle": "アクション", + "xpack.snapshotRestore.policyList.table.addPolicyButton": "ポリシーを作成", + "xpack.snapshotRestore.policyList.table.deletePolicyButton": "{count, plural, one {ポリシー} other {ポリシー}}を削除", + "xpack.snapshotRestore.policyList.table.inProgressTooltip": "スナップショット進行中", + "xpack.snapshotRestore.policyList.table.lastSnapshotFailedTooltip": "前回失敗したスナップショットです", + "xpack.snapshotRestore.policyList.table.nextExecutionColumnTitle": "次回のスナップショット", + "xpack.snapshotRestore.policyList.table.policyNameColumnTitle": "ポリシー", + "xpack.snapshotRestore.policyList.table.reloadPoliciesButton": "再読み込み", + "xpack.snapshotRestore.policyList.table.repositoryColumnTitle": "レポジトリ", + "xpack.snapshotRestore.policyList.table.repositoryFilterLabel": "レポジトリ", + "xpack.snapshotRestore.policyList.table.retentionColumnAriaLabel": "構成された保存", + "xpack.snapshotRestore.policyList.table.retentionColumnTitle": "保存", + "xpack.snapshotRestore.policyList.table.scheduleColumnTitle": "スケジュール", + "xpack.snapshotRestore.policyList.table.snapshotNameColumnTitle": "スナップショット名", + "xpack.snapshotRestore.policyRetentionSchedulePanel.addButtonLabel": "スケジュール", + "xpack.snapshotRestore.policyRetentionSchedulePanel.errorFetchingRetentionScheduleReloadButtonLabel": "再読み込み", + "xpack.snapshotRestore.policyRetentionSchedulePanel.errorFetchingRetentionScheduleTitle": "保存スケジュールの取得中にエラーが発生", + "xpack.snapshotRestore.policyRetentionSchedulePanel.executeButtonLabel": "今すぐ実行", + "xpack.snapshotRestore.policyRetentionSchedulePanel.managePanelTitle": "保存オプション", + "xpack.snapshotRestore.policyRetentionSchedulePanel.manageRetentionButtonLabel": "保存の管理", + "xpack.snapshotRestore.policyRetentionSchedulePanel.noScheduleConfiguredWarningDescription": "1 つまたは複数のポリシーに保存期間がありますが、保存がスケジュールされていません。", + "xpack.snapshotRestore.policyRetentionSchedulePanel.noScheduleConfiguredWarningTitle": "保存がスケジュールされていません", + "xpack.snapshotRestore.policyRetentionSchedulePanel.retentionScheduleDescription": "スナップショットを保存する cron スケジュール は {cronSchedule} です。", + "xpack.snapshotRestore.policyRetentionSchedulePanel.retentionScheduleEditLinkAriaLabel": "保存スケジュールの編集", + "xpack.snapshotRestore.policyRetentionSchedulePanel.retentionScheduleEditLinkTooltip": "保存スケジュールの編集", + "xpack.snapshotRestore.policyRetentionSchedulePanel.retentionScheduleExecuteLinkAriaLabel": "今すぐ保存を実行", + "xpack.snapshotRestore.policyRetentionSchedulePanel.retentionScheduleExecuteLinkTooltip": "今すぐ保存を実行", + "xpack.snapshotRestore.policyScheduleWarningDescription": "一度に 1 つのスナップショットしか撮影できません。スナップショットのエラーを避けるために、ポリシーを編集または削除してください。", + "xpack.snapshotRestore.policyScheduleWarningTitle": "2 つ以上のポリシーに同じスケジュールが設定されています", + "xpack.snapshotRestore.policyValidation.indexPatternRequiredErrorMessage": "インデックスパターンが最低 1 つ必要です。", + "xpack.snapshotRestore.policyValidation.indicesRequiredErrorMessage": "インデックスを最低 1 つ選択する必要があります。", + "xpack.snapshotRestore.policyValidation.invalidMinCountErrorMessage": "最低カウントは最高カウントよりも大きい値にできません。", + "xpack.snapshotRestore.policyValidation.nameRequiredErroMessage": "ポリシー名が必要です。", + "xpack.snapshotRestore.policyValidation.repositoryRequiredErrorMessage": "レポジトリが必要です。", + "xpack.snapshotRestore.policyValidation.scheduleRequiredErrorMessage": "スケジュールが必要です。", + "xpack.snapshotRestore.policyValidation.snapshotNameRequiredErrorMessage": "スナップショット名が必要です。", + "xpack.snapshotRestore.repositories.breadcrumbTitle": "レポジトリ", + "xpack.snapshotRestore.repositoryDetails.closeButtonLabel": "閉じる", + "xpack.snapshotRestore.repositoryDetails.editButtonLabel": "編集", + "xpack.snapshotRestore.repositoryDetails.genericSettingsDescription": "レポジトリ「{name}」のランダムな設定です", + "xpack.snapshotRestore.repositoryDetails.loadingRepositoryDescription": "レポジトリを読み込み中…", + "xpack.snapshotRestore.repositoryDetails.loadingRepositoryErrorTitle": "レポジトリの読み込み中にエラーが発生", + "xpack.snapshotRestore.repositoryDetails.managedRepositoryWarningTitle": "これは管理されているレポジトリで、他のシステムにより使用されています。変更を加えるとこれらのシステムのオペレーションに影響が及ぶ可能性があります。", + "xpack.snapshotRestore.repositoryDetails.noSnapshotInformationDescription": "スナップショット情報がありません", + "xpack.snapshotRestore.repositoryDetails.removeButtonLabel": "削除", + "xpack.snapshotRestore.repositoryDetails.removeManagedRepositoryButtonTitle": "管理されているレポジトリは削除できません。", + "xpack.snapshotRestore.repositoryDetails.repositoryNotFoundErrorMessage": "レポジトリ「{name}」は存在しません。", + "xpack.snapshotRestore.repositoryDetails.repositoryTypeDocLink": "レポジトリドキュメント", + "xpack.snapshotRestore.repositoryDetails.settingsTitle": "設定", + "xpack.snapshotRestore.repositoryDetails.snapshotsDescription": "{count} 件の {count, plural, one {スナップショット} other {スナップショット}}が見つかりました", + "xpack.snapshotRestore.repositoryDetails.snapshotsTitle": "スナップショット", + "xpack.snapshotRestore.repositoryDetails.typeAzure.basePathLabel": "ベースパス", + "xpack.snapshotRestore.repositoryDetails.typeAzure.chunkSizeLabel": "チャンクサイズ", + "xpack.snapshotRestore.repositoryDetails.typeAzure.clientLabel": "クライアント", + "xpack.snapshotRestore.repositoryDetails.typeAzure.compressLabel": "スナップショットの圧縮", + "xpack.snapshotRestore.repositoryDetails.typeAzure.containerLabel": "コンテナー", + "xpack.snapshotRestore.repositoryDetails.typeAzure.locationModeLabel": "位置情報モード", + "xpack.snapshotRestore.repositoryDetails.typeAzure.maxRestoreBytesLabel": "1 秒間の最高復元バイト数", + "xpack.snapshotRestore.repositoryDetails.typeAzure.maxSnapshotBytesLabel": "1 秒間の最高スナップショットバイト数", + "xpack.snapshotRestore.repositoryDetails.typeAzure.readonlyLabel": "読み込み専用", + "xpack.snapshotRestore.repositoryDetails.typeFS.chunkSizeLabel": "チャンクサイズ", + "xpack.snapshotRestore.repositoryDetails.typeFS.compressLabel": "スナップショットの圧縮", + "xpack.snapshotRestore.repositoryDetails.typeFS.locationLabel": "場所", + "xpack.snapshotRestore.repositoryDetails.typeFS.maxRestoreBytesLabel": "1 秒間の最高復元バイト数", + "xpack.snapshotRestore.repositoryDetails.typeFS.maxSnapshotBytesLabel": "1 秒間の最高スナップショットバイト数", + "xpack.snapshotRestore.repositoryDetails.typeFS.readonlyLabel": "読み込み専用", + "xpack.snapshotRestore.repositoryDetails.typeGCS.basePathLabel": "ベースパス", + "xpack.snapshotRestore.repositoryDetails.typeGCS.bucketLabel": "バケット", + "xpack.snapshotRestore.repositoryDetails.typeGCS.chunkSizeLabel": "チャンクサイズ", + "xpack.snapshotRestore.repositoryDetails.typeGCS.clientLabel": "クライアント", + "xpack.snapshotRestore.repositoryDetails.typeGCS.compressLabel": "スナップショットの圧縮", + "xpack.snapshotRestore.repositoryDetails.typeGCS.maxRestoreBytesLabel": "1 秒間の最高復元バイト数", + "xpack.snapshotRestore.repositoryDetails.typeGCS.maxSnapshotBytesLabel": "1 秒間の最高スナップショットバイト数", + "xpack.snapshotRestore.repositoryDetails.typeGCS.readonlyLabel": "読み込み専用", + "xpack.snapshotRestore.repositoryDetails.typeHDFS.chunkSizeLabel": "チャンクサイズ", + "xpack.snapshotRestore.repositoryDetails.typeHDFS.compressLabel": "スナップショットの圧縮", + "xpack.snapshotRestore.repositoryDetails.typeHDFS.loadDefaultsLabel": "デフォルトを読み込む", + "xpack.snapshotRestore.repositoryDetails.typeHDFS.maxRestoreBytesLabel": "1 秒間の最高復元バイト数", + "xpack.snapshotRestore.repositoryDetails.typeHDFS.maxSnapshotBytesLabel": "1 秒間の最高スナップショットバイト数", + "xpack.snapshotRestore.repositoryDetails.typeHDFS.pathLabel": "パス", + "xpack.snapshotRestore.repositoryDetails.typeHDFS.readonlyLabel": "読み込み専用", + "xpack.snapshotRestore.repositoryDetails.typeHDFS.securityPrincipalLabel": "セキュリティプリンシパル", + "xpack.snapshotRestore.repositoryDetails.typeHDFS.uriLabel": "URI", + "xpack.snapshotRestore.repositoryDetails.typeReadonly.urlLabel": "URL", + "xpack.snapshotRestore.repositoryDetails.typeS3.basePathLabel": "ベースパス", + "xpack.snapshotRestore.repositoryDetails.typeS3.bucketLabel": "バケット", + "xpack.snapshotRestore.repositoryDetails.typeS3.bufferSizeLabel": "バッファーサイズ", + "xpack.snapshotRestore.repositoryDetails.typeS3.cannedAclLabel": "Canned ACL", + "xpack.snapshotRestore.repositoryDetails.typeS3.chunkSizeLabel": "チャンクサイズ", + "xpack.snapshotRestore.repositoryDetails.typeS3.clientLabel": "クライアント", + "xpack.snapshotRestore.repositoryDetails.typeS3.compressLabel": "スナップショットの圧縮", + "xpack.snapshotRestore.repositoryDetails.typeS3.maxRestoreBytesLabel": "1 秒間の最高復元バイト数", + "xpack.snapshotRestore.repositoryDetails.typeS3.maxSnapshotBytesLabel": "1 秒間の最高スナップショットバイト数", + "xpack.snapshotRestore.repositoryDetails.typeS3.readonlyLabel": "読み込み専用", + "xpack.snapshotRestore.repositoryDetails.typeS3.serverSideEncryptionLabel": "サーバー側エコシステム", + "xpack.snapshotRestore.repositoryDetails.typeS3.storageClassLabel": "ストレージクラス", + "xpack.snapshotRestore.repositoryDetails.typeTitle": "レポジトリタイプ", + "xpack.snapshotRestore.repositoryDetails.verificationDetailsTitle": "詳細", + "xpack.snapshotRestore.repositoryDetails.verificationTitle": "認証ステータス", + "xpack.snapshotRestore.repositoryDetails.verifyButtonLabel": "レポジトリを検証", + "xpack.snapshotRestore.repositoryDetails.zeroSnapshotsDescription": "レポジトリにスナップショットがありません", + "xpack.snapshotRestore.repositoryFor.typeFS.locationDescription": "すべてのマスターおよびデータノードで {settingKey} 設定に場所を登録する必要があります。", + "xpack.snapshotRestore.repositoryForm.backButtonLabel": "戻る", + "xpack.snapshotRestore.repositoryForm.errorUnknownRepositoryTypesMessage": "レポジトリタイプ「{type}」はサポートされていません。", + "xpack.snapshotRestore.repositoryForm.errorUnknownRepositoryTypesTitle": "不明なレポジトリタイプ", + "xpack.snapshotRestore.repositoryForm.fields.cloudTypeDescription": "Elasticsearch はカスタムレポジトリ用のコアプラグインを提供します。{docLink}", + "xpack.snapshotRestore.repositoryForm.fields.defaultTypeDescription": "Elasticsearch はファイルシステムと読み取り専用の URL レポジトリをサポートします。他のタイプにはプラグインが必要です。{docLink}", + "xpack.snapshotRestore.repositoryForm.fields.nameDescription": "レポジトリのの固有の名前です。", + "xpack.snapshotRestore.repositoryForm.fields.nameDescriptionTitle": "レポジトリ名", + "xpack.snapshotRestore.repositoryForm.fields.nameLabel": "名前", + "xpack.snapshotRestore.repositoryForm.fields.settingsTitle": "{repositoryName} 設定", + "xpack.snapshotRestore.repositoryForm.fields.sourceOnlyDescription": "最大 50% のスペースを節約できるソースのみのスナップショットを作成します。{docLink}", + "xpack.snapshotRestore.repositoryForm.fields.sourceOnlyDescriptionTitle": "ソースのみのスナップショット", + "xpack.snapshotRestore.repositoryForm.fields.sourceOnlyDocLinkText": "ソースのみのレポジトリに関する詳細をご覧ください。", + "xpack.snapshotRestore.repositoryForm.fields.sourceOnlyLabel": "ソースのみのスナップショット", + "xpack.snapshotRestore.repositoryForm.fields.typeDescriptionTitle": "レポジトリタイプ", + "xpack.snapshotRestore.repositoryForm.fields.typeDocsLinkText": "その他のリソース", + "xpack.snapshotRestore.repositoryForm.fields.typePluginsDocLinkText": "プラグインの詳細をご覧ください。", + "xpack.snapshotRestore.repositoryForm.loadingRepositoryTypesDescription": "レポジトリタイプを読み込み中…", + "xpack.snapshotRestore.repositoryForm.loadingRepositoryTypesErrorMessage": "レポジトリタイプの読み込み中にエラーが発生しました", + "xpack.snapshotRestore.repositoryForm.nextButtonLabel": "次へ", + "xpack.snapshotRestore.repositoryForm.noRepositoryTypesErrorMessage": "プラグインをインストールして異なるレポジトリタイプを有効にできます。{docLink}", + "xpack.snapshotRestore.repositoryForm.noRepositoryTypesErrorTitle": "利用可能なレポジトリタイプがありません", + "xpack.snapshotRestore.repositoryForm.registerButtonLabel": "申込む", + "xpack.snapshotRestore.repositoryForm.repositoryTypeDocLink": "{repositoryType} レポジトリドキュメント", + "xpack.snapshotRestore.repositoryForm.saveButtonLabel": "保存", + "xpack.snapshotRestore.repositoryForm.savingButtonLabel": "保存中…", + "xpack.snapshotRestore.repositoryForm.typeAzure.basePathDescription": "レポジトリデータへのコンテナーパスです。", + "xpack.snapshotRestore.repositoryForm.typeAzure.basePathLabel": "ベースパス", + "xpack.snapshotRestore.repositoryForm.typeAzure.basePathTitle": "ベースパス", + "xpack.snapshotRestore.repositoryForm.typeAzure.chunkSizeDescription": "スナップショットの作成時にファイルを小さなユニットに分けます。", + "xpack.snapshotRestore.repositoryForm.typeAzure.chunkSizeLabel": "チャンクサイズ", + "xpack.snapshotRestore.repositoryForm.typeAzure.chunkSizeTitle": "チャンクサイズ", + "xpack.snapshotRestore.repositoryForm.typeAzure.clientDescription": "Azure クライアントの名前です。", + "xpack.snapshotRestore.repositoryForm.typeAzure.clientLabel": "クライアント", + "xpack.snapshotRestore.repositoryForm.typeAzure.clientTitle": "クライアント", + "xpack.snapshotRestore.repositoryForm.typeAzure.compressDescription": "スナップショット用にインデックスのマッピングと設定ファイルを圧縮します。データファイルは圧縮されません。", + "xpack.snapshotRestore.repositoryForm.typeAzure.compressLabel": "スナップショットを圧縮", + "xpack.snapshotRestore.repositoryForm.typeAzure.compressTitle": "スナップショットの圧縮", + "xpack.snapshotRestore.repositoryForm.typeAzure.containerDescription": "スナップショットに使用する Azure コンテナーの名前です。", + "xpack.snapshotRestore.repositoryForm.typeAzure.containerLabel": "コンテナー", + "xpack.snapshotRestore.repositoryForm.typeAzure.containerTitle": "コンテナー", + "xpack.snapshotRestore.repositoryForm.typeAzure.locationModeDescription": "プライマリまたはセカンダリの場所です。セカンダリの場合、読み込み専用が true です。", + "xpack.snapshotRestore.repositoryForm.typeAzure.locationModeLabel": "位置情報モード", + "xpack.snapshotRestore.repositoryForm.typeAzure.locationModeTitle": "位置情報モード", + "xpack.snapshotRestore.repositoryForm.typeAzure.maxRestoreBytesDescription": "各ノードのスナップショットの復元レートです。", + "xpack.snapshotRestore.repositoryForm.typeAzure.maxRestoreBytesLabel": "1 秒間の最高復元バイト数", + "xpack.snapshotRestore.repositoryForm.typeAzure.maxRestoreBytesTitle": "1 秒間の最高復元バイト数", + "xpack.snapshotRestore.repositoryForm.typeAzure.maxSnapshotBytesDescription": "各ノードのスナップショットの作成レートです。", + "xpack.snapshotRestore.repositoryForm.typeAzure.maxSnapshotBytesLabel": "1 秒間の最高スナップショットバイト数", + "xpack.snapshotRestore.repositoryForm.typeAzure.maxSnapshotBytesTitle": "1 秒間の最高スナップショットバイト数", + "xpack.snapshotRestore.repositoryForm.typeAzure.readonlyDescription": "このレポジトリへの書き込みアクセスがあるクラスターは 1 つだけでなければなりません。他のクラスターはすべて読み込み専用にする必要があります。", + "xpack.snapshotRestore.repositoryForm.typeAzure.readonlyLabel": "読み込み専用レポジトリ", + "xpack.snapshotRestore.repositoryForm.typeAzure.readonlyTitle": "読み込み専用", + "xpack.snapshotRestore.repositoryForm.typeFS.chunkSizeDescription": "スナップショットの作成時にファイルを小さなユニットに分けます。", + "xpack.snapshotRestore.repositoryForm.typeFS.chunkSizeLabel": "チャンクサイズ", + "xpack.snapshotRestore.repositoryForm.typeFS.chunkSizeTitle": "チャンクサイズ", + "xpack.snapshotRestore.repositoryForm.typeFS.compressDescription": "スナップショット用にインデックスのマッピングと設定ファイルを圧縮します。データファイルは圧縮されません。", + "xpack.snapshotRestore.repositoryForm.typeFS.compressLabel": "スナップショットを圧縮", + "xpack.snapshotRestore.repositoryForm.typeFS.compressTitle": "スナップショットの圧縮", + "xpack.snapshotRestore.repositoryForm.typeFS.locationLabel": "場所 (必須)", + "xpack.snapshotRestore.repositoryForm.typeFS.locationTitle": "ファイルシステムの場所", + "xpack.snapshotRestore.repositoryForm.typeFS.maxRestoreBytesDescription": "各ノードのスナップショットの復元レートです。", + "xpack.snapshotRestore.repositoryForm.typeFS.maxRestoreBytesLabel": "1 秒間の最高復元バイト数", + "xpack.snapshotRestore.repositoryForm.typeFS.maxRestoreBytesTitle": "1 秒間の最高復元バイト数", + "xpack.snapshotRestore.repositoryForm.typeFS.maxSnapshotBytesDescription": "各ノードのスナップショットの作成レートです。", + "xpack.snapshotRestore.repositoryForm.typeFS.maxSnapshotBytesLabel": "1 秒間の最高スナップショットバイト数", + "xpack.snapshotRestore.repositoryForm.typeFS.maxSnapshotBytesTitle": "1 秒間の最高スナップショットバイト数", + "xpack.snapshotRestore.repositoryForm.typeFS.readonlyDescription": "このレポジトリへの書き込みアクセスがあるクラスターは 1 つだけでなければなりません。他のクラスターはすべて読み込み専用にする必要があります。", + "xpack.snapshotRestore.repositoryForm.typeFS.readonlyLabel": "読み込み専用レポジトリ", + "xpack.snapshotRestore.repositoryForm.typeFS.readonlyTitle": "読み込み専用", + "xpack.snapshotRestore.repositoryForm.typeGCS.basePathDescription": "レポジトリデータへのバケットパスです。", + "xpack.snapshotRestore.repositoryForm.typeGCS.basePathLabel": "ベースパス", + "xpack.snapshotRestore.repositoryForm.typeGCS.basePathTitle": "ベースパス", + "xpack.snapshotRestore.repositoryForm.typeGCS.bucketDescription": "スナップショットに使用する Google Cloud Storage バケットの名前です。", + "xpack.snapshotRestore.repositoryForm.typeGCS.bucketLabel": "バケット (必須)", + "xpack.snapshotRestore.repositoryForm.typeGCS.bucketTitle": "バケット", + "xpack.snapshotRestore.repositoryForm.typeGCS.chunkSizeDescription": "スナップショットの作成時にファイルを小さなユニットに分けます。", + "xpack.snapshotRestore.repositoryForm.typeGCS.chunkSizeLabel": "チャンクサイズ", + "xpack.snapshotRestore.repositoryForm.typeGCS.chunkSizeTitle": "チャンクサイズ", + "xpack.snapshotRestore.repositoryForm.typeGCS.clientDescription": "Google Cloud Storage クライアントの名前です。", + "xpack.snapshotRestore.repositoryForm.typeGCS.clientLabel": "クライアント", + "xpack.snapshotRestore.repositoryForm.typeGCS.clientTitle": "クライアント", + "xpack.snapshotRestore.repositoryForm.typeGCS.compressDescription": "スナップショット用にインデックスのマッピングと設定ファイルを圧縮します。データファイルは圧縮されません。", + "xpack.snapshotRestore.repositoryForm.typeGCS.compressLabel": "スナップショットを圧縮", + "xpack.snapshotRestore.repositoryForm.typeGCS.compressTitle": "スナップショットを圧縮", + "xpack.snapshotRestore.repositoryForm.typeGCS.maxRestoreBytesDescription": "各ノードのスナップショットの復元レートです。", + "xpack.snapshotRestore.repositoryForm.typeGCS.maxRestoreBytesLabel": "1 秒間の最高復元バイト数", + "xpack.snapshotRestore.repositoryForm.typeGCS.maxRestoreBytesTitle": "1 秒間の最高復元バイト数", + "xpack.snapshotRestore.repositoryForm.typeGCS.maxSnapshotBytesDescription": "各ノードのスナップショットの作成レートです。", + "xpack.snapshotRestore.repositoryForm.typeGCS.maxSnapshotBytesLabel": "1 秒間の最高スナップショットバイト数", + "xpack.snapshotRestore.repositoryForm.typeGCS.maxSnapshotBytesTitle": "1 秒間の最高スナップショットバイト数", + "xpack.snapshotRestore.repositoryForm.typeGCS.readonlyDescription": "このレポジトリへの書き込みアクセスがあるクラスターは 1 つだけでなければなりません。他のクラスターはすべて読み込み専用にする必要があります。", + "xpack.snapshotRestore.repositoryForm.typeGCS.readonlyLabel": "読み込み専用レポジトリ", + "xpack.snapshotRestore.repositoryForm.typeGCS.readonlyTitle": "読み込み専用", + "xpack.snapshotRestore.repositoryForm.typeHDFS.chunkSizeDescription": "スナップショットの作成時にファイルを小さなユニットに分けます。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.chunkSizeLabel": "チャンクサイズ", + "xpack.snapshotRestore.repositoryForm.typeHDFS.chunkSizeTitle": "チャンクサイズ", + "xpack.snapshotRestore.repositoryForm.typeHDFS.compressDescription": "スナップショット用にインデックスのマッピングと設定ファイルを圧縮します。データファイルは圧縮されません。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.compressLabel": "スナップショットを圧縮", + "xpack.snapshotRestore.repositoryForm.typeHDFS.compressTitle": "スナップショットの圧縮", + "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationAriaLabel": "HDFS レポジトリ「{name}」の追加構成", + "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationDescription": "Hadoop 構成に追加する JSON フォーマット構成パラメーターです。Hadoop コアと HDFS ファイルからのクライアント中心のプロパティのみが認識されます。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationFormatError": "無効な JSON フォーマット", + "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationKeyDescription": "キーは {confKeyFormat} のフォーマットでなければなりません。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationLabel": "構成", + "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationTitle": "構成", + "xpack.snapshotRestore.repositoryForm.typeHDFS.loadDefaultsDescription": "デフォルトの Hadoop 構成を読み込みます。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.loadDefaultsLabel": "デフォルトを読み込む", + "xpack.snapshotRestore.repositoryForm.typeHDFS.loadDefaultsTitle": "デフォルトを読み込む", + "xpack.snapshotRestore.repositoryForm.typeHDFS.maxRestoreBytesDescription": "各ノードのスナップショットの復元レートです。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.maxRestoreBytesLabel": "1 秒間の最高復元バイト数", + "xpack.snapshotRestore.repositoryForm.typeHDFS.maxRestoreBytesTitle": "1 秒間の最高復元バイト数", + "xpack.snapshotRestore.repositoryForm.typeHDFS.maxSnapshotBytesDescription": "各ノードのスナップショットの作成レートです。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.maxSnapshotBytesLabel": "1 秒間の最高スナップショットバイト数", + "xpack.snapshotRestore.repositoryForm.typeHDFS.maxSnapshotBytesTitle": "1 秒間の最高スナップショットバイト数", + "xpack.snapshotRestore.repositoryForm.typeHDFS.pathDescription": "データが保管されているファイルへのパスです。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.pathLabel": "パス (必須)", + "xpack.snapshotRestore.repositoryForm.typeHDFS.pathTitle": "パス", + "xpack.snapshotRestore.repositoryForm.typeHDFS.readonlyDescription": "このレポジトリへの書き込みアクセスがあるクラスターは 1 つだけでなければなりません。他のクラスターはすべて読み込み専用にする必要があります。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.readonlyLabel": "読み込み専用レポジトリ", + "xpack.snapshotRestore.repositoryForm.typeHDFS.readonlyTitle": "読み込み専用", + "xpack.snapshotRestore.repositoryForm.typeHDFS.securityPrincipalDescription": "セキュアな HDFS クラスターへの接続時に使用する Kerberos プリンシパルです。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.securityPrincipalLabel": "セキュリティプリンシパル", + "xpack.snapshotRestore.repositoryForm.typeHDFS.securityPrincipalTitle": "セキュリティプリンシパル", + "xpack.snapshotRestore.repositoryForm.typeHDFS.uriDescription": "HDFS の URL アドレスです。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.uriLabel": "URI (必須)", + "xpack.snapshotRestore.repositoryForm.typeHDFS.uriTitle": "URI", + "xpack.snapshotRestore.repositoryForm.typeReadonly.urlDescription": "スナップショットの場所です。", + "xpack.snapshotRestore.repositoryForm.typeReadonly.urlFilePathDescription": "このファイルの場所は {settingKey} 設定で登録する必要があります。", + "xpack.snapshotRestore.repositoryForm.typeReadonly.urlLabel": "パス (必須)", + "xpack.snapshotRestore.repositoryForm.typeReadonly.urlSchemeLabel": "スキーム", + "xpack.snapshotRestore.repositoryForm.typeReadonly.urlTitle": "URL", + "xpack.snapshotRestore.repositoryForm.typeReadonly.urlWhitelistDescription": "この URL は {settingKey} 設定で登録する必要があります。", + "xpack.snapshotRestore.repositoryForm.typeS3.basePathDescription": "レポジトリデータへのバケットパスです。", + "xpack.snapshotRestore.repositoryForm.typeS3.basePathLabel": "ベースパス", + "xpack.snapshotRestore.repositoryForm.typeS3.basePathTitle": "ベースパス", + "xpack.snapshotRestore.repositoryForm.typeS3.bucketDescription": "スナップショットに使用する AWS S3 バケットの名前です。", + "xpack.snapshotRestore.repositoryForm.typeS3.bucketLabel": "バケット (必須)", + "xpack.snapshotRestore.repositoryForm.typeS3.bucketTitle": "バケット", + "xpack.snapshotRestore.repositoryForm.typeS3.bufferSizeDescription": "この最低しきい値を超えると、S3 レポジトリは AWS Multipart Upload API を使用してチャンクをいくつかのパーツに分け、各パーツをそれぞれのリクエストによってアップロードします。", + "xpack.snapshotRestore.repositoryForm.typeS3.bufferSizeLabel": "バッファーサイズ", + "xpack.snapshotRestore.repositoryForm.typeS3.bufferSizeTitle": "バッファーサイズ", + "xpack.snapshotRestore.repositoryForm.typeS3.cannedAclDescription": "新しい S3 バケットとオブジェクトに追加する canned ACL です。", + "xpack.snapshotRestore.repositoryForm.typeS3.cannedAclLabel": "Canned ACL", + "xpack.snapshotRestore.repositoryForm.typeS3.cannedAclTitle": "Canned ACL", + "xpack.snapshotRestore.repositoryForm.typeS3.chunkSizeDescription": "スナップショットの作成時にファイルを小さなユニットに分けます。", + "xpack.snapshotRestore.repositoryForm.typeS3.chunkSizeLabel": "チャンクサイズ", + "xpack.snapshotRestore.repositoryForm.typeS3.chunkSizeTitle": "チャンクサイズ", + "xpack.snapshotRestore.repositoryForm.typeS3.clientDescription": "AWS S3 クライアントの名前です。", + "xpack.snapshotRestore.repositoryForm.typeS3.clientLabel": "クライアント", + "xpack.snapshotRestore.repositoryForm.typeS3.clientTitle": "クライアント", + "xpack.snapshotRestore.repositoryForm.typeS3.compressDescription": "スナップショット用にインデックスのマッピングと設定ファイルを圧縮します。データファイルは圧縮されません。", + "xpack.snapshotRestore.repositoryForm.typeS3.compressLabel": "スナップショットを圧縮", + "xpack.snapshotRestore.repositoryForm.typeS3.compressTitle": "スナップショットの圧縮", + "xpack.snapshotRestore.repositoryForm.typeS3.maxRestoreBytesDescription": "各ノードのスナップショットの復元レートです。", + "xpack.snapshotRestore.repositoryForm.typeS3.maxRestoreBytesLabel": "1 秒間の最高復元バイト数", + "xpack.snapshotRestore.repositoryForm.typeS3.maxRestoreBytesTitle": "1 秒間の最高復元バイト数", + "xpack.snapshotRestore.repositoryForm.typeS3.maxSnapshotBytesDescription": "各ノードのスナップショットの作成レートです。", + "xpack.snapshotRestore.repositoryForm.typeS3.maxSnapshotBytesLabel": "1 秒間の最高スナップショットバイト数", + "xpack.snapshotRestore.repositoryForm.typeS3.maxSnapshotBytesTitle": "1 秒間の最高スナップショットバイト数", + "xpack.snapshotRestore.repositoryForm.typeS3.readonlyDescription": "このレポジトリへの書き込みアクセスがあるクラスターは 1 つだけでなければなりません。他のクラスターはすべて読み込み専用にする必要があります。", + "xpack.snapshotRestore.repositoryForm.typeS3.readonlyLabel": "読み込み専用レポジトリ", + "xpack.snapshotRestore.repositoryForm.typeS3.readonlyTitle": "読み込み専用", + "xpack.snapshotRestore.repositoryForm.typeS3.serverSideEncryptionDescription": "AES256 アルゴリズムでサーバーのファイルを暗号化します。", + "xpack.snapshotRestore.repositoryForm.typeS3.serverSideEncryptionLabel": "サーバー側エコシステム", + "xpack.snapshotRestore.repositoryForm.typeS3.serverSideEncryptionTitle": "サーバー側エコシステム", + "xpack.snapshotRestore.repositoryForm.typeS3.storageClassDescription": "S3 レポジトリの新規オブジェクトのストレージクラスです。", + "xpack.snapshotRestore.repositoryForm.typeS3.storageClassLabel": "ストレージクラス", + "xpack.snapshotRestore.repositoryForm.typeS3.storageClassTitle": "ストレージクラス", + "xpack.snapshotRestore.repositoryForm.validationErrorTitle": "続行する前にエラーを修正してください。", + "xpack.snapshotRestore.repositoryList.addRepositoryButtonLabel": "レポジトリを登録", + "xpack.snapshotRestore.repositoryList.emptyPromptDescription": "スナップショットを保管するレポジトリが必要です。", + "xpack.snapshotRestore.repositoryList.emptyPromptTitle": "まだレポジトリがありません", + "xpack.snapshotRestore.repositoryList.loadingRepositoriesDescription": "レポジトリを読み込み中…", + "xpack.snapshotRestore.repositoryList.LoadingRepositoriesErrorMessage": "レポジトリの読み込み中にエラーが発生しました", + "xpack.snapshotRestore.repositoryList.table.actionEditAriaLabel": "レポジトリ「{name}」を編集", + "xpack.snapshotRestore.repositoryList.table.actionEditTooltip": "編集", + "xpack.snapshotRestore.repositoryList.table.actionRemoveAriaLabel": "レポジトリ「{name}」を削除", + "xpack.snapshotRestore.repositoryList.table.actionRemoveTooltip": "削除", + "xpack.snapshotRestore.repositoryList.table.actionsColumnTitle": "アクション", + "xpack.snapshotRestore.repositoryList.table.deleteManagedRepositoryTooltip": "管理されているレポジトリは削除できません。", + "xpack.snapshotRestore.repositoryList.table.deleteMultipleRepositoriesButton": "レポジトリを削除", + "xpack.snapshotRestore.repositoryList.table.deleteSingleRepositoryButton": "レポジトリを削除", + "xpack.snapshotRestore.repositoryList.table.managedRepositoryBadgeLabel": "管理中", + "xpack.snapshotRestore.repositoryList.table.nameColumnTitle": "名前", + "xpack.snapshotRestore.repositoryList.table.reloadRepositoriesButton": "再読み込み", + "xpack.snapshotRestore.repositoryList.table.typeColumnTitle": "タイプ", + "xpack.snapshotRestore.repositoryList.table.typeFilterLabel": "タイプ", + "xpack.snapshotRestore.repositoryType.azureTypeName": "Azure", + "xpack.snapshotRestore.repositoryType.fileSystemTypeName": "共有ファイルシステム", + "xpack.snapshotRestore.repositoryType.gcsTypeName": "Google Cloud Storage", + "xpack.snapshotRestore.repositoryType.hdfsTypeName": "Hadoop HDFS", + "xpack.snapshotRestore.repositoryType.readonlyTypeName": "読み込み専用 URL", + "xpack.snapshotRestore.repositoryType.s3TypeName": "AWS S3", + "xpack.snapshotRestore.repositoryType.sourceTypeName": "ソースのみ", + "xpack.snapshotRestore.repositoryValidation.bucketRequired": "バケットが必要です。", + "xpack.snapshotRestore.repositoryValidation.delegateTypeRequired": "タイプが必要です。", + "xpack.snapshotRestore.repositoryValidation.locationRequired": "場所が必要です。", + "xpack.snapshotRestore.repositoryValidation.nameRequired": "レポジトリ名が必要です。", + "xpack.snapshotRestore.repositoryValidation.nameValidation.errorSpace": "名前にスペースは使用できません。", + "xpack.snapshotRestore.repositoryValidation.nameValidation.invalidCharacter": "名前に「{char}」は使用できません。", + "xpack.snapshotRestore.repositoryValidation.pathRequired": "パスが必要です。", + "xpack.snapshotRestore.repositoryValidation.uriRequired": "URI が必要です。", + "xpack.snapshotRestore.repositoryValidation.urlRequired": "URL が必要です。", + "xpack.snapshotRestore.repositoryVerification.verificationErrorValue": "未接続", + "xpack.snapshotRestore.repositoryVerification.verificationSuccessfulValue": "接続済み", + "xpack.snapshotRestore.repositoryVerification.verificationUnknownValue": "不明", + "xpack.snapshotRestore.repositoryWarningDescription": "スナップショットの読み込みが遅い可能性があります。{repositoryLink} に移動してエラーを解決してください。", + "xpack.snapshotRestore.repositoryWarningLinkText": "レポジトリ", + "xpack.snapshotRestore.repositoryWarningTitle": "一部のレポジトリにエラーがあります", + "xpack.snapshotRestore.restoreForm.backButtonLabel": "戻る", + "xpack.snapshotRestore.restoreForm.navigation.stepLogisticsName": "ロジスティクス", + "xpack.snapshotRestore.restoreForm.navigation.stepReviewName": "確認", + "xpack.snapshotRestore.restoreForm.navigation.stepSettingsName": "インデックス設定", + "xpack.snapshotRestore.restoreForm.nextButtonLabel": "次へ", + "xpack.snapshotRestore.restoreForm.savingButtonLabel": "復元中...", + "xpack.snapshotRestore.restoreForm.stepLogistics.allIndicesLabel": "システムインデックスを含むすべてのインデックス", + "xpack.snapshotRestore.restoreForm.stepLogistics.deselectAllIndicesLink": "すべて選択解除", + "xpack.snapshotRestore.restoreForm.stepLogistics.docsButtonLabel": "スナップショットと復元ドキュメント", + "xpack.snapshotRestore.restoreForm.stepLogistics.includeGlobalStateDescription": "現在クラスターに存在しないテンプレートを復元し、テンプレートを同じ名前で上書きします。永続的な設定も復元します。", + "xpack.snapshotRestore.restoreForm.stepLogistics.includeGlobalStateDisabledDescription": "このスナップショットでは使用できません。", + "xpack.snapshotRestore.restoreForm.stepLogistics.includeGlobalStateLabel": "グローバル状態の復元", + "xpack.snapshotRestore.restoreForm.stepLogistics.includeGlobalStateTitle": "グローバル状態の復元", + "xpack.snapshotRestore.restoreForm.stepLogistics.indicesDescription": "存在しない場合は、新しいインデックスを作成します。閉じていて、スナップショットインデックスと同じ数のシャードがある場合は、既存のインデックスを復元します。", + "xpack.snapshotRestore.restoreForm.stepLogistics.indicesPatternLabel": "インデックスパターン", + "xpack.snapshotRestore.restoreForm.stepLogistics.indicesPatternPlaceholder": "logstash-* などのインデックスパターンを入力", + "xpack.snapshotRestore.restoreForm.stepLogistics.indicesTitle": "インデックス", + "xpack.snapshotRestore.restoreForm.stepLogistics.indicesToggleCustomLink": "インデックスパターンを使用", + "xpack.snapshotRestore.restoreForm.stepLogistics.indicesToggleListLink": "インデックスを選択", + "xpack.snapshotRestore.restoreForm.stepLogistics.partialDescription": "すべてのシャードのスナップショットがないインデックスを復元できます。", + "xpack.snapshotRestore.restoreForm.stepLogistics.partialLabel": "部分復元", + "xpack.snapshotRestore.restoreForm.stepLogistics.partialTitle": "部分復元", + "xpack.snapshotRestore.restoreForm.stepLogistics.renameIndicesDescription": "復元時にインデックス名を変更します。", + "xpack.snapshotRestore.restoreForm.stepLogistics.renameIndicesLabel": "インデックス名の変更", + "xpack.snapshotRestore.restoreForm.stepLogistics.renameIndicesTitle": "インデックス名の変更", + "xpack.snapshotRestore.restoreForm.stepLogistics.renamePatternHelpText": "正規表現を使用", + "xpack.snapshotRestore.restoreForm.stepLogistics.renamePatternLabel": "取り込みパターン", + "xpack.snapshotRestore.restoreForm.stepLogistics.renameReplacementLabel": "置換パターン", + "xpack.snapshotRestore.restoreForm.stepLogistics.selectAllIndicesLink": "すべて選択", + "xpack.snapshotRestore.restoreForm.stepLogistics.selectIndicesHelpText": "{count} 件の{count, plural, one {インデックス} other {インデックス}}が復元されます。{selectOrDeselectAllLink}", + "xpack.snapshotRestore.restoreForm.stepLogistics.selectIndicesLabel": "インデックスを選択", + "xpack.snapshotRestore.restoreForm.stepLogisticsTitle": "詳細を復元", + "xpack.snapshotRestore.restoreForm.stepReview.jsonTab.jsonAriaLabel": "実行する設定を復元", + "xpack.snapshotRestore.restoreForm.stepReview.jsonTabTitle": "JSON", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.allIndicesValue": "すべてのインデックス", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.editStepTooltip": "編集", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.ignoreIndexSettingsLabel": "リセット", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.includeGlobalStateFalseValue": "いいえ", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.includeGlobalStateLabel": "グローバル状態の復元", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.includeGlobalStateTrueValue": "はい", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.indexSettingsLabel": "修正", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.indicesCollapseAllLink": "{count, plural, one {# インデックス} other {# インデックス}}を非表示", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.indicesLabel": "インデックス", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.indicesShowAllLink": "{count}その他の{count, plural, one {インデックス} other {インデックス}}を表示", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.noSettingsValue": "インデックス設定の修正はありません", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.partialFalseValue": "いいえ", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.partialLabel": "部分復元", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.partialTrueValue": "はい", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.renamePatternLabel": "取り込みパターン", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.renameReplacementLabel": "置換パターン", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.sectionLogisticsTitle": "ロジスティクス", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.sectionRenameTitle": "インデックス名の変更", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.sectionSettingsTitle": "インデックス設定", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTabTitle": "まとめ", + "xpack.snapshotRestore.restoreForm.stepReviewTitle": "復元詳細を確認", + "xpack.snapshotRestore.restoreForm.stepSettings.docsButtonLabel": "インデックス設定ドキュメント", + "xpack.snapshotRestore.restoreForm.stepSettings.ignoreIndexSettingsDescription": "復元中に、選択した設定を既定値にリセットします。{docLink}", + "xpack.snapshotRestore.restoreForm.stepSettings.ignoreIndexSettingsLabel": "インデックス設定のリセット", + "xpack.snapshotRestore.restoreForm.stepSettings.ignoreIndexSettingsPlaceholder": "インデックス設定を選択または入力", + "xpack.snapshotRestore.restoreForm.stepSettings.ignoreIndexSettingsTitle": "インデックス設定のリセット", + "xpack.snapshotRestore.restoreForm.stepSettings.indexSettingsAriaLabel": "修正するインデックス設定", + "xpack.snapshotRestore.restoreForm.stepSettings.indexSettingsDescription": "復元中に、インデックス設定を上書きします。{docLink}", + "xpack.snapshotRestore.restoreForm.stepSettings.indexSettingsDocLinkText": "さらに詳しく", + "xpack.snapshotRestore.restoreForm.stepSettings.indexSettingsEditorDescription": "JSONフォーマットを使用:{format}", + "xpack.snapshotRestore.restoreForm.stepSettings.indexSettingsEditorLabel": "インデックス設定", + "xpack.snapshotRestore.restoreForm.stepSettings.indexSettingsLabel": "インデックス設定の修正", + "xpack.snapshotRestore.restoreForm.stepSettings.indexSettingsTitle": "インデックス設定の修正", + "xpack.snapshotRestore.restoreForm.stepSettings.selectIgnoreIndexSettingsLabel": "設定を選択", + "xpack.snapshotRestore.restoreForm.stepSettingsTitle": "インデックス設定", + "xpack.snapshotRestore.restoreForm.submitButtonLabel": "スナップショットを復元", + "xpack.snapshotRestore.restoreList.deniedPrivilegeDescription": "スナップショット復元ステータスを表示するには、1 つ以上のインデックスで{privilegesCount, plural, one {このインデックス特権} other {これらのインデックス特権}}が必要です: {missingPrivileges}。", + "xpack.snapshotRestore.restoreList.deniedPrivilegeTitle": "インデックス特権がありません", + "xpack.snapshotRestore.restoreList.emptyPromptDescription": "{snapshotsLink}に移動して、復元を開始します。", + "xpack.snapshotRestore.restoreList.emptyPromptDescriptionLink": "スナップショット", + "xpack.snapshotRestore.restoreList.emptyPromptTitle": "復元されたスナップショットがありません", + "xpack.snapshotRestore.restoreList.intervalMenu.minutesIntervalValue": "{minutes} {minutes, plural, one {分} other {分}}", + "xpack.snapshotRestore.restoreList.intervalMenu.secondsIntervalValue": "{seconds} {seconds, plural, one {秒} other {秒}}", + "xpack.snapshotRestore.restoreList.intervalMenuButtonText": "{interval}ごとにデータを更新", + "xpack.snapshotRestore.restoreList.loadingRestoresDescription": "復元を読み込んでいます...", + "xpack.snapshotRestore.restoreList.loadingRestoresErrorMessage": "リソースの読み込みエラー", + "xpack.snapshotRestore.restoreList.shardTable.bytesColumnTitle": "バイト", + "xpack.snapshotRestore.restoreList.shardTable.durationColumnTitle": "期間", + "xpack.snapshotRestore.restoreList.shardTable.durationValue": "{seconds} {seconds, plural, one {秒} other {秒}}", + "xpack.snapshotRestore.restoreList.shardTable.endTimeColumnTitle": "終了時刻", + "xpack.snapshotRestore.restoreList.shardTable.filesColumnTitle": "ファイル", + "xpack.snapshotRestore.restoreList.shardTable.indexColumnTitle": "ID", + "xpack.snapshotRestore.restoreList.shardTable.primaryAbbreviationText": "P", + "xpack.snapshotRestore.restoreList.shardTable.primaryTooltipLabel": "プライマリ", + "xpack.snapshotRestore.restoreList.shardTable.progressTooltipLabel": "{restored} / {total}件が復元されました", + "xpack.snapshotRestore.restoreList.shardTable.repositoryColumnTitle": "レポジトリ", + "xpack.snapshotRestore.restoreList.shardTable.snapshotColumnTitle": "スナップショット", + "xpack.snapshotRestore.restoreList.shardTable.stageColumnTitle": "ステージ", + "xpack.snapshotRestore.restoreList.shardTable.startTimeColumnTitle": "開始時刻", + "xpack.snapshotRestore.restoreList.shardTable.targetHostColumnTitle": "ターゲットホスト", + "xpack.snapshotRestore.restoreList.shardTable.targetNodeColumnTitle": "ターゲットノード", + "xpack.snapshotRestore.restoreList.shardTable.versionColumnTitle": "バージョン", + "xpack.snapshotRestore.restoreList.table.indexColumnTitle": "インデックス", + "xpack.snapshotRestore.restoreList.table.lastActivityColumn.nowLabel": "今", + "xpack.snapshotRestore.restoreList.table.lastActivityTitle": "前回のアクティビティ", + "xpack.snapshotRestore.restoreList.table.shardsCompletedTitle": "シャード完了", + "xpack.snapshotRestore.restoreList.table.shardsInProgressTitle": "シャード進行中", + "xpack.snapshotRestore.restoreList.table.statusColumn.completeLabel": "完了", + "xpack.snapshotRestore.restoreList.table.statusColumn.inProgressLabel": "進行中", + "xpack.snapshotRestore.restoreList.table.statusColumnTitle": "ステータス", + "xpack.snapshotRestore.restoreSnapshot.breadcrumbTitle": "スナップショットを復元", + "xpack.snapshotRestore.restoreSnapshot.executeRestoreErrorTitle": "スナップショットを復元できません", + "xpack.snapshotRestore.restoreSnapshot.loadingSnapshotDescription": "スナップショット詳細を読み込み中…", + "xpack.snapshotRestore.restoreSnapshot.loadingSnapshotErrorTitle": "スナップショット詳細の読み込み中にエラーが発生しました", + "xpack.snapshotRestore.restoreSnapshot.snapshotNotFoundErrorMessage": "スナップショット'{snapshot}'はリポジトリ'{repository}'に存在しません。", + "xpack.snapshotRestore.restoreSnapshotTitle": "'{snapshot}'を復元", + "xpack.snapshotRestore.restoreStatus.breadcrumbTitle": "ステータスの復元", + "xpack.snapshotRestore.restoreValidation.ignoreIndexSettingsRequiredError": "設定が最低1つ必要です", + "xpack.snapshotRestore.restoreValidation.indexPatternRequiredError": "インデックスパターンが最低 1 つ必要です。", + "xpack.snapshotRestore.restoreValidation.indexSettingsInvalidError": "無効なJSONフォーマット", + "xpack.snapshotRestore.restoreValidation.indexSettingsNotModifiableError": "修正できません:{settings}", + "xpack.snapshotRestore.restoreValidation.indexSettingsNotRemovableError": "リセットできません:{settings}", + "xpack.snapshotRestore.restoreValidation.indexSettingsRequiredError": "設定が最低1つ必要です", + "xpack.snapshotRestore.restoreValidation.indicesRequiredError": "インデックスを最低1つ選択する必要があります。", + "xpack.snapshotRestore.restoreValidation.renamePatternRequiredError": "取り込みパターンが必要です。", + "xpack.snapshotRestore.restoreValidation.renameReplacementRequiredError": "置換パターンが必要です。", + "xpack.snapshotRestore.snapshotDetails.closeButtonLabel": "閉じる", + "xpack.snapshotRestore.snapshotDetails.createdByLabel": "作成者", + "xpack.snapshotRestore.snapshotDetails.deleteButtonLabel": "削除", + "xpack.snapshotRestore.snapshotDetails.deleteManagedRepositorySnapshotButtonTitle": "管理されているレポジトリに格納されているスナップショットは削除できません。", + "xpack.snapshotRestore.snapshotDetails.errorLoadingRepositoryTitle": "レポジトリの読み込み中にエラーが発生", + "xpack.snapshotRestore.snapshotDetails.errorSnapshotNotFound": "スナップショット「{snapshotId}」がレポジトリ「{repositoryName}」に存在しないか、レポジトリが存在しません。", + "xpack.snapshotRestore.snapshotDetails.failureShardTitle": "ャード {shardId}", + "xpack.snapshotRestore.snapshotDetails.failuresTabTitle": "失敗したインデックス ({failuresCount})", + "xpack.snapshotRestore.snapshotDetails.itemDurationLabel": "期間", + "xpack.snapshotRestore.snapshotDetails.itemDurationValueLabel": "{seconds} {seconds, plural, one {秒} other {秒}}", + "xpack.snapshotRestore.snapshotDetails.itemEndTimeLabel": "終了時刻", + "xpack.snapshotRestore.snapshotDetails.itemIncludeGlobalStateLabel": "グローバルステータスを含める", + "xpack.snapshotRestore.snapshotDetails.itemIncludeGlobalStateNoLabel": "いいえ", + "xpack.snapshotRestore.snapshotDetails.itemIncludeGlobalStateYesLabel": "はい", + "xpack.snapshotRestore.snapshotDetails.itemIndicesCollapseAllLink": "{count, plural, one {# インデックス} other {# インデックス}}を非表示", + "xpack.snapshotRestore.snapshotDetails.itemIndicesLabel": "インデックス ({indicesCount})", + "xpack.snapshotRestore.snapshotDetails.itemIndicesNoneLabel": "-", + "xpack.snapshotRestore.snapshotDetails.itemIndicesShowAllLink": "{count}その他の{count, plural, one {インデックス} other {インデックス}}を表示", + "xpack.snapshotRestore.snapshotDetails.itemStartTimeLabel": "開始時刻", + "xpack.snapshotRestore.snapshotDetails.itemStateLabel": "ステータス", + "xpack.snapshotRestore.snapshotDetails.itemUuidLabel": "UUID", + "xpack.snapshotRestore.snapshotDetails.itemVersionLabel": "バージョン / バージョン ID", + "xpack.snapshotRestore.snapshotDetails.loadingSnapshotDescription": "スナップショットを読み込み中…", + "xpack.snapshotRestore.snapshotDetails.noIndexFailuresMessage": "すべてのインデックスが保存されました。", + "xpack.snapshotRestore.snapshotDetails.repositoryTitle": "「{repositoryName}」レポジトリ", + "xpack.snapshotRestore.snapshotDetails.restoreButtonLabel": "復元", + "xpack.snapshotRestore.snapshotDetails.snapshotIsBeingCreatedMessage": "スナップショットを作成中です。", + "xpack.snapshotRestore.snapshotDetails.summaryTabTitle": "まとめ", + "xpack.snapshotRestore.snapshotList.emptyPrompt.addPolicyText": "ポリシーを作成", + "xpack.snapshotRestore.snapshotList.emptyPrompt.errorRepositoriesTitle": "一部のレポジトリにエラーがあります", + "xpack.snapshotRestore.snapshotList.emptyPrompt.goToPoliciesText": "ポリシーを表示", + "xpack.snapshotRestore.snapshotList.emptyPrompt.noRepositoriesAddButtonLabel": "レポジトリを登録", + "xpack.snapshotRestore.snapshotList.emptyPrompt.noRepositoriesDescription": "スナップショットのレポジトリを登録して始めます。", + "xpack.snapshotRestore.snapshotList.emptyPrompt.noRepositoriesTitle": "まだスナップショットやレポジトリがありません", + "xpack.snapshotRestore.snapshotList.emptyPrompt.noSnapshotsDescription": "Elasticsearch API でスナップショットを作成します。", + "xpack.snapshotRestore.snapshotList.emptyPrompt.noSnapshotsTitle": "まだスナップショットがありません", + "xpack.snapshotRestore.snapshotList.emptyPrompt.repositoryWarningDescription": "{repositoryLink} に移動してエラーを解決してください。", + "xpack.snapshotRestore.snapshotList.emptyPrompt.usePolicyDescription": "スナップショットを作成するには、スナップショットライフサイクルポリシーを実行してください。スナップショットは {docLink} でも作成できます。", + "xpack.snapshotRestore.snapshotList.loadingSnapshotsDescription": "スナップショットを読み込み中…", + "xpack.snapshotRestore.snapshotList.loadingSnapshotsErrorMessage": "スナップショットの読み込み中にエラーが発生しました", + "xpack.snapshotRestore.snapshotList.table.actionDeleteAriaLabel": "Delete snapshot `{name}`", + "xpack.snapshotRestore.snapshotList.table.actionDeleteTooltip": "削除", + "xpack.snapshotRestore.snapshotList.table.actionRestoreAriaLabel": "スナップショット`{name}`を保存", + "xpack.snapshotRestore.snapshotList.table.actionRestoreDisabledInProgressTooltip": "進行中のスナップショットを復元できません", + "xpack.snapshotRestore.snapshotList.table.actionRestoreDisabledInvalidTooltip": "無効なスナップショットを復元できません", + "xpack.snapshotRestore.snapshotList.table.actionRestoreTooltip": "復元", + "xpack.snapshotRestore.snapshotList.table.actionsColumnTitle": "アクション", + "xpack.snapshotRestore.snapshotList.table.deleteManagedRepositorySnapshotTooltip": "管理されているレポジトリに格納されているスナップショットは削除できません。", + "xpack.snapshotRestore.snapshotList.table.deleteSnapshotButton": "{count, plural, one {スナップショット} other {スナップショット}}を削除", + "xpack.snapshotRestore.snapshotList.table.durationColumnTitle": "期間", + "xpack.snapshotRestore.snapshotList.table.durationColumnValueLabel": "{seconds}秒", + "xpack.snapshotRestore.snapshotList.table.failedShardsColumnTitle": "シャードの失敗", + "xpack.snapshotRestore.snapshotList.table.indicesColumnTitle": "インデックス", + "xpack.snapshotRestore.snapshotList.table.reloadSnapshotsButton": "再読み込み", + "xpack.snapshotRestore.snapshotList.table.repositoryColumnTitle": "レポジトリ", + "xpack.snapshotRestore.snapshotList.table.repositoryFilterLabel": "レポジトリ", + "xpack.snapshotRestore.snapshotList.table.shardsColumnTitle": "シャード", + "xpack.snapshotRestore.snapshotList.table.snapshotColumnTitle": "スナップショット", + "xpack.snapshotRestore.snapshotList.table.startTimeColumnTitle": "日付が作成されました", + "xpack.snapshotRestore.snapshots.breadcrumbTitle": "スナップショット", + "xpack.snapshotRestore.snapshotState.completeLabel": "スナップショット完了", + "xpack.snapshotRestore.snapshotState.failedLabel": "スナップショット失敗", + "xpack.snapshotRestore.snapshotState.incompatibleLabel": "互換性のないバージョン", + "xpack.snapshotRestore.snapshotState.incompatibleTipDescription": "このスナップショットはクラスターのバージョンと互換性のないバージョンの Elasticsearch で作成されました。", + "xpack.snapshotRestore.snapshotState.inProgressLabel": "スナップショットを撮影中…", + "xpack.snapshotRestore.snapshotState.partialLabel": "一部失敗", + "xpack.snapshotRestore.snapshotState.partialTipDescription": "グローバルクラスターステータスが保存されましたが、1 つまたは複数のシャードの保存に失敗しました。「失敗したインシデント」タブをご覧ください。", + "xpack.spaces.defaultSpaceDescription": "これはデフォルトのスペースです!", + "xpack.spaces.defaultSpaceTitle": "デフォルト", + "xpack.spaces.displayName": "スペース", + "xpack.spaces.featureDescription": "ダッシュボードやその他の保存済みオブジェクトを、わかりやすいカテゴリー別に整理することができます。", + "xpack.spaces.management.advancedSettingsSubtitle.applyingSettingsOnPageToSpaceDescription": "このページの設定は、別途指定されていない限り {spaceName}’スペースに適用されます。’", + "xpack.spaces.management.advancedSettingsTitle.settingsTitle": "設定", + "xpack.spaces.management.collapsiblePanel.hideLinkDescription": "{title} を非表示", + "xpack.spaces.management.collapsiblePanel.hideLinkText": "非表示", + "xpack.spaces.management.collapsiblePanel.showLinkDescription": "{title} を表示", + "xpack.spaces.management.collapsiblePanel.showLinkText": "表示", + "xpack.spaces.management.confirmAlterActiveSpaceModal.cancelButton": "キャンセル", + "xpack.spaces.management.confirmAlterActiveSpaceModal.reloadWarningMessage": "このスペースで表示される機能を更新しました。保存後にページが更新されます。", + "xpack.spaces.management.confirmAlterActiveSpaceModal.title": "スペースの更新の確認", + "xpack.spaces.management.confirmAlterActiveSpaceModal.updateSpaceButton": "スペースを更新", + "xpack.spaces.management.confirmDeleteModal.allContentsText": "すべてのコンテンツ", + "xpack.spaces.management.confirmDeleteModal.cancelButtonLabel": "キャンセル", + "xpack.spaces.management.confirmDeleteModal.confirmDeleteSpaceButtonLabel": "スペース {spaceName} を削除", + "xpack.spaces.management.confirmDeleteModal.confirmSpaceNameFormRowLabel": "削除するスペース名の確定", + "xpack.spaces.management.confirmDeleteModal.deleteSpaceAndAllContentsButtonLabel": " スペースとすべてのコンテンツを削除", + "xpack.spaces.management.confirmDeleteModal.deletingSpaceWarningMessage": "スペースを削除すると、スペースと {allContents} が永久に削除されます。この操作は元に戻すことができません。", + "xpack.spaces.management.confirmDeleteModal.redirectAfterDeletingCurrentSpaceWarningMessage": "現在のスペース {name} を削除しようとしています。続行すると、別のスペースを選択する画面に移動します。", + "xpack.spaces.management.confirmDeleteModal.spaceNamesDoNoMatchErrorMessage": "スペース名が一致していません。", + "xpack.spaces.management.copyToSpace.actionDescription": "この保存されたオブジェクトを1つまたは複数のスペースにコピーします。", + "xpack.spaces.management.copyToSpace.actionTitle": "スペースにコピー", + "xpack.spaces.management.copyToSpace.automaticallyOverwrite": "すべての保存されたオブジェクトを自動的に上書き", + "xpack.spaces.management.copyToSpace.copyDetail.overwriteButton": "上書き", + "xpack.spaces.management.copyToSpace.copyDetail.skipOverwriteButton": "スキップ", + "xpack.spaces.management.copyToSpace.copyErrorTitle": "保存されたオブジェクトのコピー中にエラーが発生", + "xpack.spaces.management.copyToSpace.copyResultsLabel": "コピー結果", + "xpack.spaces.management.copyToSpace.copyStatus.conflictsMessage": "このスペースには同じID({id})の保存されたオブジェクトが既に存在します。", + "xpack.spaces.management.copyToSpace.copyStatus.conflictsOverwriteMessage": "「上書き」をクリックしてこのバージョンをコピーされたバージョンに置き換えます。", + "xpack.spaces.management.copyToSpace.copyStatus.pendingOverwriteMessage": "保存されたオブジェクトは上書きされます。「スキップ」をクリックしてこの操作をキャンセルします。", + "xpack.spaces.management.copyToSpace.copyStatus.successMessage": "保存されたオブジェクトがコピーされました。", + "xpack.spaces.management.copyToSpace.copyStatus.unresolvableErrorMessage": "この保存されたオブジェクトのコピー中にエラーが発生しました。", + "xpack.spaces.management.copyToSpace.copyStatusSummary.conflictsMessage": "{space}スペースに1つまたは複数の矛盾が検出されました。解決するにはこのセクションを拡張してください。", + "xpack.spaces.management.copyToSpace.copyStatusSummary.failedMessage": "{space}スペースへのコピーに失敗しました。詳細はこのセクションを展開してください。", + "xpack.spaces.management.copyToSpace.copyStatusSummary.successMessage": "{space}スペースにコピーされました。", + "xpack.spaces.management.copyToSpace.copyToSpacesButton": "{spaceCount} {spaceCount, plural, one {スペース} other {スペース}}にコピー", + "xpack.spaces.management.copyToSpace.disabledCopyToSpacesButton": "コピー", + "xpack.spaces.management.copyToSpace.dontIncludeRelatedLabel": "関連性のある保存されたオブジェクトを含みません", + "xpack.spaces.management.copyToSpace.dontOverwriteLabel": "保存されたオブジェクトを上書きしません", + "xpack.spaces.management.copyToSpace.finishCopyToSpacesButton": "終了", + "xpack.spaces.management.copyToSpace.finishedButtonLabel": "コピーが完了しました。", + "xpack.spaces.management.copyToSpace.finishPendingOverwritesCopyToSpacesButton": "{overwriteCount}件のオブジェクトを上書き", + "xpack.spaces.management.copyToSpace.includeRelatedFormLabel": "関連性のある保存されたオブジェクトを含みます", + "xpack.spaces.management.copyToSpace.includeRelatedLabel": "関連性のある保存されたオブジェクトを含みます", + "xpack.spaces.management.copyToSpace.inProgressButtonLabel": "コピーが進行中です。お待ちください。", + "xpack.spaces.management.copyToSpace.noSpacesBody": "コピーできるスペースがありません。", + "xpack.spaces.management.copyToSpace.noSpacesTitle": "スペースがありません", + "xpack.spaces.management.copyToSpace.overwriteLabel": "保存されたオブジェクトを自動的に上書きしています", + "xpack.spaces.management.copyToSpace.resolveCopyErrorTitle": "保存されたオブジェクトの矛盾の解決中にエラーが発生", + "xpack.spaces.management.copyToSpace.resolveCopySuccessTitle": "上書き成功", + "xpack.spaces.management.copyToSpace.selectSpacesLabel": "コピー先のスペースを選択してください", + "xpack.spaces.management.copyToSpace.spacesLoadErrorTitle": "利用可能なスペースを読み込み中にエラーが発生", + "xpack.spaces.management.copyToSpaceFlyoutFooter.conflictCount": "スキップ", + "xpack.spaces.management.copyToSpaceFlyoutFooter.errorCount": "エラー", + "xpack.spaces.management.copyToSpaceFlyoutFooter.pendingCount": "保留中", + "xpack.spaces.management.copyToSpaceFlyoutFooter.successCount": "コピー完了", + "xpack.spaces.management.copyToSpaceFlyoutHeader": "保存されたオブジェクトのスペースへのコピー", + "xpack.spaces.management.customizeSpaceAvatar.colorFormRowLabel": "色", + "xpack.spaces.management.customizeSpaceAvatar.imageUrl": "カスタム画像", + "xpack.spaces.management.customizeSpaceAvatar.initialItemsFormRowLabel": "イニシャル (最大 2 文字)", + "xpack.spaces.management.customizeSpaceAvatar.removeImage": "カスタム画像を削除", + "xpack.spaces.management.customizeSpaceAvatar.selectImageUrl": "画像ファイルを選択", + "xpack.spaces.management.deleteSpacesButton.deleteSpaceAriaLabel": "スペースを削除", + "xpack.spaces.management.deleteSpacesButton.deleteSpaceButtonLabel": "スペースを削除", + "xpack.spaces.management.deleteSpacesButton.deleteSpaceErrorTitle": "スペースの削除中にエラーが発生: {errorMessage}", + "xpack.spaces.management.deleteSpacesButton.spaceSuccessfullyDeletedNotificationMessage": "{spaceName} スペースが削除されました。", + "xpack.spaces.management.enabledSpaceFeatures.allFeaturesEnabledMessage": "(表示されているすべての機能)", + "xpack.spaces.management.enabledSpaceFeatures.enabledFeaturesSectionMessage": "機能の表示をカスタマイズ", + "xpack.spaces.management.enabledSpaceFeatures.enableFeaturesInSpaceMessage": "このスペースでどの機能が表示されるかを管理します。", + "xpack.spaces.management.enabledSpaceFeatures.goToRolesLink": "セキュアなアクセスをご希望の場合は、{rolesLink} にアクセスしてください。", + "xpack.spaces.management.enabledSpaceFeatures.noFeaturesEnabledMessage": "(表示されている機能がありません)", + "xpack.spaces.management.enabledSpaceFeatures.notASecurityMechanismMessage": "この機能は UI で非表示になっていますが、無効ではありません。", + "xpack.spaces.management.enabledSpaceFeatures.rolesLinkText": "ロール", + "xpack.spaces.management.enabledSpaceFeatures.someFeaturesEnabledMessage": "({featureCount} 件中 {enabledCount} 件の機能を表示中)", + "xpack.spaces.management.enabledSpaceFeaturesEnabledColumnTitle": "表示しますか?", + "xpack.spaces.management.enabledSpaceFeaturesFeatureColumnTitle": "機能", + "xpack.spaces.management.hideAllFeaturesText": "すべて非表示", + "xpack.spaces.management.manageSpacePage.avatarFormRowLabel": "アバター", + "xpack.spaces.management.manageSpacePage.awesomeSpacePlaceholder": "素晴らしいスペース", + "xpack.spaces.management.manageSpacePage.cancelSpaceButton": "キャンセル", + "xpack.spaces.management.manageSpacePage.clickToCustomizeTooltip": "クリックしてこのスペースのアバターをカスタマイズします", + "xpack.spaces.management.manageSpacePage.createSpaceButton": "スペースを作成", + "xpack.spaces.management.manageSpacePage.createSpaceTitle": "スペースの作成", + "xpack.spaces.management.manageSpacePage.customizeSpacePanelDescription": "スペースに名前を付けてアバターをカスタマイズします", + "xpack.spaces.management.manageSpacePage.customizeSpacePanelUrlIdentifierEditable": "URL 識別子に注意してください。スペースの作成後に変更することはできません。", + "xpack.spaces.management.manageSpacePage.customizeSpacePanelUrlIdentifierNotEditable": "URL 識別子は変更できません。", + "xpack.spaces.management.manageSpacePage.customizeSpaceTitle": "スペースのカスタマイズ", + "xpack.spaces.management.manageSpacePage.customizeVisibleFeatures": "表示される機能のカスタマイズ", + "xpack.spaces.management.manageSpacePage.errorLoadingSpaceTitle": "スペースの読み込み中にエラーが発生: {message}", + "xpack.spaces.management.manageSpacePage.errorSavingSpaceTitle": "スペースの保存中にエラーが発生: {message}", + "xpack.spaces.management.manageSpacePage.manageDescription": "保存済みオブジェクトをわかりやすいカテゴリー別に整理します。", + "xpack.spaces.management.manageSpacePage.nameFormRowLabel": "名前", + "xpack.spaces.management.manageSpacePage.spaceDescriptionFormRowLabel": "説明 (オプション)", + "xpack.spaces.management.manageSpacePage.spaceDescriptionHelpText": "説明はスペース選択画面に表示されます。", + "xpack.spaces.management.manageSpacePage.spaceSuccessfullySavedNotificationMessage": "スペース {name} が保存されました。", + "xpack.spaces.management.manageSpacePage.updateSpaceButton": "スペースを更新", + "xpack.spaces.management.reversedSpaceBadge.reversedSpacesCanBePartiallyModifiedTooltip": "リザーブされたスペースはビルトインのため、部分的な変更しかできません。", + "xpack.spaces.management.secureSpaceMessage.howToAssignRoleToSpaceDescription": "スペースへのロールの割り当てをご希望ですか?{rolesLink} にアクセスしてください。", + "xpack.spaces.management.secureSpaceMessage.rolesLinkText": "ロール", + "xpack.spaces.management.secureSpaceMessage.rolesLinkTextAriaLabel": "ロール管理ページ", + "xpack.spaces.management.showAllFeaturesText": "すべて表示", + "xpack.spaces.management.spaceIdentifier.customizeSpaceLinkText": "[カスタマイズ]", + "xpack.spaces.management.spaceIdentifier.customizeSpaceNameLinkLabel": "URL 識別子をカスタマイズ", + "xpack.spaces.management.spaceIdentifier.emptySpaceIdentifierText": "awesome-space", + "xpack.spaces.management.spaceIdentifier.kibanaURLForSpaceIdentifierDescription": "例: https://my-kibana.example{spaceIdentifier}/app/kibana.", + "xpack.spaces.management.spaceIdentifier.resetSpaceNameLinkLabel": "URL 識別子をリセット", + "xpack.spaces.management.spaceIdentifier.resetSpaceNameLinkText": "[リセット]", + "xpack.spaces.management.spaceIdentifier.urlIdentifierGeneratedFromSpaceNameTooltip": "awesome-space", + "xpack.spaces.management.spaceIdentifier.urlIdentifierLabel": "URL 識別子 ", + "xpack.spaces.management.spaceIdentifier.urlIdentifierTitle": "URL 識別子", + "xpack.spaces.management.spacesGridPage.actionsColumnName": "アクション", + "xpack.spaces.management.spacesGridPage.allFeaturesEnabled": "表示されているすべての機能", + "xpack.spaces.management.spacesGridPage.createSpaceButtonLabel": "スペースの作成", + "xpack.spaces.management.spacesGridPage.deleteActionName": "{spaceName} を削除。", + "xpack.spaces.management.spacesGridPage.descriptionColumnName": "説明", + "xpack.spaces.management.spacesGridPage.editSpaceActionName": "{spaceName} を編集。", + "xpack.spaces.management.spacesGridPage.errorDeletingSpaceErrorMessage": "スペースの削除中にエラーが発生: {errorMessage}", + "xpack.spaces.management.spacesGridPage.featuresColumnName": "機能", + "xpack.spaces.management.spacesGridPage.identifierColumnName": "識別子", + "xpack.spaces.management.spacesGridPage.loadingTitle": "読み込み中…", + "xpack.spaces.management.spacesGridPage.noFeaturesEnabled": "表示されている機能がありません", + "xpack.spaces.management.spacesGridPage.searchPlaceholder": "検索", + "xpack.spaces.management.spacesGridPage.someFeaturesEnabled": "{totalFeatureCount} 件中 {enabledFeatureCount} 件の機能を表示中", + "xpack.spaces.management.spacesGridPage.spaceColumnName": "スペース", + "xpack.spaces.management.spacesGridPage.spacesTitle": "スペース", + "xpack.spaces.management.spacesGridPage.spaceSuccessfullyDeletedNotificationMessage": "「{spaceName}」 スペースが削除されました。", + "xpack.spaces.management.toggleAllFeaturesLink": "(すべて変更)", + "xpack.spaces.management.unauthorizedPrompt.permissionDeniedDescription": "スペースを管理するパーミッションがありません。", + "xpack.spaces.management.unauthorizedPrompt.permissionDeniedTitle": "パーミッションが拒否されました", + "xpack.spaces.management.validateSpace.describeMaxLengthErrorMessage": "説明は 2000 文字以内でなければなりません。", + "xpack.spaces.management.validateSpace.nameMaxLengthErrorMessage": "名前はは 1024 文字以内でなければなりません。", + "xpack.spaces.management.validateSpace.requiredNameErrorMessage": "名前が必要です。", + "xpack.spaces.management.validateSpace.urlIdentifierAllowedCharactersErrorMessage": "URL 識別子には a-z、0-9、「_」、「-」のみ使用できます。", + "xpack.spaces.management.validateSpace.urlIdentifierRequiredErrorMessage": "URL 識別子が必要です。", + "xpack.spaces.manageSpacesButton.manageSpacesButtonLabel": "スペースの管理", + "xpack.spaces.navControl.spacesMenu.changeCurrentSpaceTitle": "現在のスペースの変更", + "xpack.spaces.navControl.spacesMenu.findSpacePlaceholder": "スペースを検索", + "xpack.spaces.navControl.spacesMenu.noSpacesFoundTitle": " スペースが見つかりません ", + "xpack.spaces.spaceSelector.changeSpaceAnytimeAvailabilityText": "スペースはいつでも変更できます", + "xpack.spaces.spaceSelector.findSpacePlaceholder": "スペースを検索", + "xpack.spaces.spaceSelector.noSpacesMatchSearchCriteriaDescription": "検索条件に一致するスペースがありません", + "xpack.spaces.spaceSelector.selectSpacesTitle": "スペースの選択", + "xpack.spaces.spacesTitle": "スペース", + "xpack.transform.agg.popoverForm.aggLabel": "集約", + "xpack.transform.agg.popoverForm.aggNameAlreadyUsedError": "別の集約で既に同じ名前が使用されています。", + "xpack.transform.agg.popoverForm.aggNameInvalidCharError": "無効な名前です。「[」、「]」「>」は使用できず、名前の始めと終わりにはスペースを使用できません。", + "xpack.transform.agg.popoverForm.fieldLabel": "フィールド", + "xpack.transform.agg.popoverForm.nameLabel": "集約名", + "xpack.transform.agg.popoverForm.submitButtonLabel": "適用", + "xpack.transform.agg.popoverForm.unsupportedAggregationHelpText": "このフォームでは集約名のみを編集できます。詳細エディターを使用して、集約の他の部分を編集してください。", + "xpack.transform.aggLabelForm.deleteItemAriaLabel": "アイテムを削除", + "xpack.transform.aggLabelForm.editAggAriaLabel": "集約を編集", + "xpack.transform.app.checkingPrivilegesDescription": "権限を確認中…", + "xpack.transform.app.checkingPrivilegesErrorMessage": "サーバーからユーザー特権を取得中にエラーが発生。", + "xpack.transform.app.deniedPrivilegeDescription": "Transforms のこのセクションを使用するには、{privilegesCount, plural, one {このクラスター特権} other {これらのクラスター特権}}が必要です: {missingPrivileges}。", + "xpack.transform.app.deniedPrivilegeTitle": "クラスター特権が足りません", + "xpack.transform.appName": "データフレームジョブ", + "xpack.transform.capability.noPermission.createTransformTooltip": "データフレーム変換を作成するパーミッションがありません。", + "xpack.transform.capability.noPermission.deleteTransformTooltip": "データフレーム変換を削除するパーミッションがありません。", + "xpack.transform.capability.noPermission.startOrStopTransformTooltip": "データフレーム変換を開始・停止するパーミッションがありません。", + "xpack.transform.capability.pleaseContactAdministratorTooltip": "{message} 管理者にお問い合わせください。", + "xpack.transform.createTransform.breadcrumbTitle": "変換の作成", + "xpack.transform.description": "説明", + "xpack.transform.destinationIndex": "デスティネーションインデックス", + "xpack.transform.groupby.popoverForm.aggLabel": "集約", + "xpack.transform.groupBy.popoverForm.aggNameAlreadyUsedError": "別のグループ分けの構成が既にこの名前を使用しています。", + "xpack.transform.groupBy.popoverForm.aggNameInvalidCharError": "無効な名前です。「[」、「]」「>」は使用できず、名前の始めと終わりにはスペースを使用できません。", + "xpack.transform.groupBy.popoverForm.fieldLabel": "フィールド", + "xpack.transform.groupBy.popoverForm.intervalError": "無効な間隔。", + "xpack.transform.groupBy.popoverForm.intervalLabel": "間隔", + "xpack.transform.groupBy.popoverForm.nameLabel": "グループ分け名", + "xpack.transform.groupBy.popoverForm.submitButtonLabel": "適用", + "xpack.transform.groupBy.popoverForm.unsupportedGroupByHelpText": "このフォームでは group_by 名のみを編集できます。詳細エディターを使用して、group_by 構成の他の部分を編集してください。", + "xpack.transform.groupByLabelForm.deleteItemAriaLabel": "アイテムを削除", + "xpack.transform.groupByLabelForm.editIntervalAriaLabel": "間隔を編集", + "xpack.transform.home.breadcrumbTitle": "データフレームジョブ", + "xpack.transform.list.emptyPromptButtonText": "初めての変換を作成してみましょう。", + "xpack.transform.list.emptyPromptTitle": "変換が見つかりません", + "xpack.transform.list.errorPromptTitle": "変換リストの取得中にエラーが発生しました。", + "xpack.transform.mode": "モード", + "xpack.transform.modeFilter": "モード", + "xpack.transform.models.transformService.allOtherRequestsCancelledDescription": "他のすべてのリクエストはキャンセルされました。", + "xpack.transform.models.transformService.requestToActionTimedOutErrorMessage": "「{id}」を{action}するリクエストがタイムアウトしました。{extra}", + "xpack.transform.multiTransformActionsMenu.managementActionsAriaLabel": "管理アクション", + "xpack.transform.multiTransformActionsMenu.transformsCount": "{count} 件の{count, plural, one {変換} other {変換}}を選択済み", + "xpack.transform.newTransform.chooseSourceTitle": "ソースの選択", + "xpack.transform.newTransform.newTransformTitle": "新規変換", + "xpack.transform.newTransform.searchSelection.notFoundLabel": "一致するインデックスまたは保存検索が見つかりませんでした。", + "xpack.transform.newTransform.searchSelection.savedObjectType.indexPattern": "インデックスパターン", + "xpack.transform.newTransform.searchSelection.savedObjectType.search": "保存検索", + "xpack.transform.pivotPreview.copyClipboardTooltip": "ピボットプレビューの開発コンソールステートメントをクリップボードにコピーします。", + "xpack.transform.pivotPreview.PivotPreviewError": "ピボットプレビューの読み込み中にエラーが発生しました。", + "xpack.transform.pivotPreview.PivotPreviewIncompleteConfigCalloutBody": "group-by フィールドと集約を 1 つ以上選んでください。", + "xpack.transform.pivotPreview.PivotPreviewNoDataCalloutBody": "プレビューリクエストはデータを返しませんでした。オプションのクエリがデータを返し、グループ分け基準により使用されるフィールドと集約フィールドに値が存在することを確認してください。", + "xpack.transform.pivotPreview.PivotPreviewNoDataCalloutTitle": "ピボットプレビューを利用できません", + "xpack.transform.pivotPreview.PivotPreviewTitle": "ピボットプレビューを変換", + "xpack.transform.progress": "進捗", + "xpack.transform.sourceIndex": "ソースインデックス", + "xpack.transform.sourceIndexPreview.copyClipboardTooltip": "ソースインデックスプレビューの開発コンソールステートメントをクリップボードにコピーします。", + "xpack.transform.sourceIndexPreview.fieldSelection": "{docFieldsCount, number} 件中 {selectedFieldsLength, number} 件の {docFieldsCount, plural, one {フィールド} other {フィールド}}を選択済み", + "xpack.transform.sourceIndexPreview.rowCollapse": "縮小", + "xpack.transform.sourceIndexPreview.rowExpand": "拡張", + "xpack.transform.sourceIndexPreview.selectColumnsAriaLabel": "列を選択", + "xpack.transform.sourceIndexPreview.selectFieldsPopoverTitle": "フィールドを選択", + "xpack.transform.sourceIndexPreview.SourceIndexArrayBadgeContent": "配列", + "xpack.transform.sourceIndexPreview.SourceIndexArrayToolTipContent": "この配列に基づく列の完全な内容は、展開された行に表示されます。", + "xpack.transform.sourceIndexPreview.SourceIndexNoDataCalloutBody": "ソースインデックスのクエリが結果を返しませんでした。インデックスにドキュメントが含まれていて、クエリ要件が妥当であることを確認してください。", + "xpack.transform.sourceIndexPreview.SourceIndexNoDataCalloutTitle": "ソースインデックスクエリの結果がありません", + "xpack.transform.sourceIndexPreview.SourceIndexObjectBadgeContent": "オブジェクト", + "xpack.transform.sourceIndexPreview.SourceIndexObjectToolTipContent": "このオブジェクトベースの列の完全な内容は、展開された行に表示されます。", + "xpack.transform.sourceIndexPreview.sourceIndexPatternError": "ソースインデックスデータの読み込み中にエラーが発生しました。", + "xpack.transform.sourceIndexPreview.sourceIndexPatternTitle": "ソースインデックス {indexPatternTitle}", + "xpack.transform.statsBar.batchTransformsLabel": "一斉", + "xpack.transform.statsBar.continuousTransformsLabel": "連続", + "xpack.transform.statsBar.failedTransformsLabel": "失敗", + "xpack.transform.statsBar.startedTransformsLabel": "開始済み", + "xpack.transform.statsBar.totalTransformsLabel": "変換合計", + "xpack.transform.status": "ステータス", + "xpack.transform.statusFilter": "ステータス", + "xpack.transform.stepCreateForm.continuousModeLabel": "連続モード", + "xpack.transform.stepCreateForm.copyTransformConfigToClipboardButton": "クリップボードにコピー", + "xpack.transform.stepCreateForm.copyTransformConfigToClipboardDescription": "ジョブを作成する Kibana 開発コンソールのコマンドをクリップボードにコピーします。", + "xpack.transform.stepCreateForm.createAndStartTransformButton": "作成して開始", + "xpack.transform.stepCreateForm.createAndStartTransformDescription": "変換を作成して開始します。変換は、クラスターの検索とインデックスによる負荷を増やします。過剰な負荷が生じた場合は変換を停止してください。変換の開始後、変換の閲覧を続けるオプションが提供されます。", + "xpack.transform.stepCreateForm.createIndexPatternErrorMessage": "Kibana インデックスパターン {indexPatternName} の作成中にエラーが発生しました:", + "xpack.transform.stepCreateForm.createIndexPatternLabel": "インデックスパターンを作成", + "xpack.transform.stepCreateForm.createIndexPatternSuccessMessage": "Kibana インデックスパターン {indexPatternName} が作成されました", + "xpack.transform.stepCreateForm.createTransformButton": "作成", + "xpack.transform.stepCreateForm.createTransformDescription": "変換を開始せずに作成します。変換は後程変換リストに戻って開始できます。", + "xpack.transform.stepCreateForm.createTransformErrorMessage": "変換 {transformId} の取得中にエラーが発生しました。", + "xpack.transform.stepCreateForm.createTransformSuccessMessage": "変換 {transformId} の作成リクエストが受け付けられました。", + "xpack.transform.stepCreateForm.creatingIndexPatternMessage": "Kibana インデックスパターンを作成中…", + "xpack.transform.stepCreateForm.discoverCardDescription": "ディスカバリでデータフレームピボットを閲覧します。", + "xpack.transform.stepCreateForm.discoverCardTitle": "ディスカバー", + "xpack.transform.stepCreateForm.duplicateIndexPatternErrorMessage": "Kibana インデックスパターン {indexPatternName} の作成中にエラーが発生しました:インデックスパターンが既に存在します。", + "xpack.transform.stepCreateForm.progressErrorMessage": "進捗パーセンテージの取得中にエラーが発生しました:", + "xpack.transform.stepCreateForm.progressTitle": "進捗", + "xpack.transform.stepCreateForm.startTransformButton": "開始", + "xpack.transform.stepCreateForm.startTransformDescription": "変換を開始します。変換は、クラスターの検索とインデックスによる負荷を増やします。過剰な負荷が生じた場合は変換を停止してください。変換の開始後、変換の閲覧を続けるオプションが提供されます。", + "xpack.transform.stepCreateForm.startTransformErrorMessage": "変換 {transformId} の開始中にエラーが発生しました。", + "xpack.transform.stepCreateForm.startTransformSuccessMessage": "変換 {transformId} の開始リクエストが受け付けられました。", + "xpack.transform.stepCreateForm.transformListCardDescription": "データフレームジョブの管理ページに戻ります。", + "xpack.transform.stepCreateForm.transformListCardTitle": "データフレームジョブ", + "xpack.transform.stepDefineForm.advancedEditorApplyButtonText": "変更を適用", + "xpack.transform.stepDefineForm.advancedEditorAriaLabel": "高度なピボットエディター", + "xpack.transform.stepDefineForm.advancedEditorHelpText": "詳細エディターでは、変換のピボット構成を編集できます。", + "xpack.transform.stepDefineForm.advancedEditorHelpTextLink": "使用可能なオプションの詳細を確認してください。", + "xpack.transform.stepDefineForm.advancedEditorLabel": "ピボット構成オブジェクト", + "xpack.transform.stepDefineForm.advancedEditorSourceConfigSwitchLabel": "クエリの詳細エディター", + "xpack.transform.stepDefineForm.advancedEditorSwitchLabel": "ピボットの詳細エディター", + "xpack.transform.stepDefineForm.advancedEditorSwitchModalBodyText": "詳細エディターの変更は適用されませんでした。詳細エディターを無効にすると、編集内容が失われます。", + "xpack.transform.stepDefineForm.advancedEditorSwitchModalCancelButtonText": "キャンセル", + "xpack.transform.stepDefineForm.advancedEditorSwitchModalConfirmButtonText": "詳細エディターを無効にする", + "xpack.transform.stepDefineForm.advancedEditorSwitchModalTitle": "適用されていない変更", + "xpack.transform.stepDefineForm.advancedSourceEditorApplyButtonText": "変更を適用", + "xpack.transform.stepDefineForm.advancedSourceEditorAriaLabel": "クエリの詳細エディター", + "xpack.transform.stepDefineForm.advancedSourceEditorHelpText": "高度なエディターでは、変換のソースクエリ句を編集できます。", + "xpack.transform.stepDefineForm.advancedSourceEditorLabel": "ソースクエリ句", + "xpack.transform.stepDefineForm.advancedSourceEditorSwitchModalBodyText": "KQL クエリバーに戻すと、編集内容が失われます。", + "xpack.transform.stepDefineForm.advancedSourceEditorSwitchModalConfirmButtonText": "KQL に切り替える", + "xpack.transform.stepDefineForm.advancedSourceEditorSwitchModalTitle": "編集内容は失われます", + "xpack.transform.stepDefineForm.aggExistsErrorMessage": "「{aggName}」という名前の集約構成は既に存在します。", + "xpack.transform.stepDefineForm.aggregationsLabel": "アグリゲーション(集計)", + "xpack.transform.stepDefineForm.aggregationsPlaceholder": "集約を追加…", + "xpack.transform.stepDefineForm.formHelp": "変換は、ピボット用のスケーラブルで自動化されたプロセスです。開始するにはグループ分けの条件と集約を少なくとも 1 つ選んでください。", + "xpack.transform.stepDefineForm.groupByExistsErrorMessage": "「{aggName}」という名前のグループ分け構成は既に存在します。", + "xpack.transform.stepDefineForm.groupByLabel": "グループ分けの条件", + "xpack.transform.stepDefineForm.groupByPlaceholder": "グループ分けの条件フィールドを追加…", + "xpack.transform.stepDefineForm.indexPatternHelpText": "このインデックスパターンのオプションのクエリはサポートされていません。サポートされているインデックスフィールドの数は {maxIndexFields} で、このインデックスには {numIndexFields} 個のフィールドがあります。", + "xpack.transform.stepDefineForm.indexPatternLabel": "インデックスパターン", + "xpack.transform.stepDefineForm.nestedAggListConflictErrorMessage": "「{aggListName}」とネスティングの矛盾があるため、構成「{aggName}」を追加できませんでした。", + "xpack.transform.stepDefineForm.nestedConflictErrorMessage": "「{aggNameCheck}」とネスティングの矛盾があるため、構成「{aggName}」を追加できませんでした。", + "xpack.transform.stepDefineForm.nestedGroupByListConflictErrorMessage": "「{groupByListName}」とネスティングの矛盾があるため、構成「{aggName}」を追加できませんでした。", + "xpack.transform.stepDefineForm.queryHelpText": "クエリ文字列でソースデータをフィルタリングしてください (オプション)。", + "xpack.transform.stepDefineForm.queryLabel": "クエリ", + "xpack.transform.stepDefineForm.queryPlaceholder": "例: {example}.", + "xpack.transform.stepDefineForm.savedSearchLabel": "保存検索", + "xpack.transform.stepDefineSummary.aggregationsLabel": "アグリゲーション(集計)", + "xpack.transform.stepDefineSummary.groupByLabel": "グループ分けの条件", + "xpack.transform.stepDefineSummary.indexPatternLabel": "インデックスパターン", + "xpack.transform.stepDefineSummary.queryCodeBlockLabel": "クエリ", + "xpack.transform.stepDefineSummary.queryLabel": "クエリ", + "xpack.transform.stepDefineSummary.savedSearchLabel": "保存検索", + "xpack.transform.stepDetailsForm.continuousModeAriaLabel": "遅延を選択してください。", + "xpack.transform.stepDetailsForm.continuousModeDateFieldHelpText": "新しいドキュメントを特定するために使用できる日付フィールドを選択してください。", + "xpack.transform.stepDetailsForm.continuousModeDateFieldLabel": "日付フィールド", + "xpack.transform.stepDetailsForm.continuousModeDelayError": "無効な遅延フォーマット", + "xpack.transform.stepDetailsForm.continuousModeDelayHelpText": "現在の時刻と最新のインプットデータ時刻の間の遅延です。", + "xpack.transform.stepDetailsForm.continuousModeDelayLabel": "遅延", + "xpack.transform.stepDetailsForm.continuousModeError": "日付フィールドがないインデックスでは、連続モードを使用できません。", + "xpack.transform.stepDetailsForm.destinationIndexHelpText": "この名前のインデックスが既に存在します。この変換を実行すると、デスティネーションインデックスが変更されます。", + "xpack.transform.stepDetailsForm.destinationIndexInputAriaLabel": "固有の宛先インデックス名を選択してください。", + "xpack.transform.stepDetailsForm.destinationIndexInvalidError": "無効なデスティネーションインデックス名。", + "xpack.transform.stepDetailsForm.destinationIndexInvalidErrorLink": "インデックス名の制限に関する詳細。", + "xpack.transform.stepDetailsForm.destinationIndexLabel": "デスティネーションインデックス", + "xpack.transform.stepDetailsForm.errorGettingIndexNames": "既存のインデックス名の取得中にエラーが発生しました:", + "xpack.transform.stepDetailsForm.errorGettingIndexPatternTitles": "既存のインデックスパターンのタイトルの取得中にエラーが発生しました:", + "xpack.transform.stepDetailsForm.errorGettingTransformList": "既存の変換 ID の取得中にエラーが発生しました:", + "xpack.transform.stepDetailsForm.indexPatternTitleError": "このタイトルのインデックスパターンが既に存在します。", + "xpack.transform.stepDetailsForm.transformDescriptionHelpText": "オプションの説明テキストです。", + "xpack.transform.stepDetailsForm.transformDescriptionInputAriaLabel": "オプションの変換の説明を選択してください。", + "xpack.transform.stepDetailsForm.transformDescriptionLabel": "変換の説明", + "xpack.transform.stepDetailsForm.transformIdExistsError": "この ID の変換が既に存在します。", + "xpack.transform.stepDetailsForm.transformIdInputAriaLabel": "固有のジョブ ID を選択してください。", + "xpack.transform.stepDetailsForm.transformIdInvalidError": "小文字のアルファベットと数字 (a-z と 0-9)、ハイフンまたはアンダーラインのみ使用でき、最初と最後を英数字にする必要があります。", + "xpack.transform.stepDetailsForm.transformIdLabel": "ジョブ ID", + "xpack.transform.stepDetailsSummary.continuousModeDateFieldLabel": "連続モード日付フィールド", + "xpack.transform.stepDetailsSummary.createIndexPatternMessage": "このジョブの Kibana インデックスパターンが作成されます。", + "xpack.transform.stepDetailsSummary.destinationIndexLabel": "デスティネーションインデックス", + "xpack.transform.stepDetailsSummary.transformDescriptionLabel": "変換の説明", + "xpack.transform.stepDetailsSummary.transformIdLabel": "ジョブ ID", + "xpack.transform.tableActionLabel": "アクション", + "xpack.transform.toastText.closeModalButtonText": "閉じる", + "xpack.transform.toastText.modalTitle": "詳細を入力", + "xpack.transform.toastText.openModalButtonText": "詳細を表示", + "xpack.transform.transformForm.sizeNotationPlaceholder": "例: {example1}、{example2}、{example3}、{example4}", + "xpack.transform.transformList.betaBadgeLabel": "ベータ", + "xpack.transform.transformList.betaBadgeTooltipContent": "変換はベータ機能です。フィードバックをお待ちしています。", + "xpack.transform.transformList.bulkDeleteModalBody": "{count, plural, one {この} other {これらの}} {count} 件の{count, plural, one {変換} other {変換}}を削除してよろしいですか?変換の送信先インデックスとオプションの Kibana インデックスパターンは削除されません。", + "xpack.transform.transformList.bulkDeleteModalTitle": "{count} 件の{count, plural, one {変換} other {変換}}を削除", + "xpack.transform.transformList.bulkStartModalTitle": "{count} 件の{count, plural, one {変換} other {変換}}を開始", + "xpack.transform.transformList.completeBatchTransformBulkActionToolTip": "1 つまたは複数の変換が完了済みの一斉変換で、再度開始できません。", + "xpack.transform.transformList.completeBatchTransformToolTip": "{transformId} は完了済みの一斉変換で、再度開始できません。", + "xpack.transform.transformList.createTransformButton": "変換の作成", + "xpack.transform.transformList.deleteActionDisabledToolTipContent": "削除するにはデータフレームジョブを停止してください。", + "xpack.transform.transformList.deleteActionName": "削除", + "xpack.transform.transformList.deleteBulkActionDisabledToolTipContent": "削除するには、選択された変換のうちの 1 つまたは複数を停止する必要があります。", + "xpack.transform.transformList.deleteModalBody": "この変換を削除してよろしいですか?変換の送信先インデックスとオプションの Kibana インデックスパターンは削除されません。", + "xpack.transform.transformList.deleteModalCancelButton": "キャンセル", + "xpack.transform.transformList.deleteModalDeleteButton": "削除", + "xpack.transform.transformList.deleteModalTitle": "{transformId} 削除", + "xpack.transform.transformList.deleteTransformErrorMessage": "変換 {transformId} の削除中にエラーが発生しました", + "xpack.transform.transformList.deleteTransformGenericErrorMessage": "変換を削除するための API エンドポイントの呼び出し中にエラーが発生しました。", + "xpack.transform.transformList.deleteTransformSuccessMessage": "変換 {transformId} の削除リクエストが受け付けられました。", + "xpack.transform.transformList.refreshButtonLabel": "更新", + "xpack.transform.transformList.rowCollapse": "{transformId} の詳細を非表示", + "xpack.transform.transformList.rowExpand": "{transformId} の詳細を表示", + "xpack.transform.transformList.startActionName": "開始", + "xpack.transform.transformList.startedTransformBulkToolTip": "1 つまたは複数の変換が既に開始済みです。", + "xpack.transform.transformList.startedTransformToolTip": "{transformId} は既に開始済みです。", + "xpack.transform.transformList.startModalBody": "変換は、クラスターの検索とインデックスによる負荷を増やします。過剰な負荷が生じた場合は変換を停止してください。{count, plural, one {この} other {これら}} {count} 件の{count, plural, one {変換} other {変換}}を開始してよろしいですか?", + "xpack.transform.transformList.startModalCancelButton": "キャンセル", + "xpack.transform.transformList.startModalStartButton": "開始", + "xpack.transform.transformList.startModalTitle": "{transformId} を開始", + "xpack.transform.transformList.startTransformErrorMessage": "変換 {transformId} の開始中にエラーが発生しました", + "xpack.transform.transformList.startTransformSuccessMessage": "変換 {transformId} の開始リクエストが受け付けられました。", + "xpack.transform.transformList.stepDetails.previewPane.errorMessage": "プレビューを読み込めませんでした", + "xpack.transform.transformList.stopActionName": "停止", + "xpack.transform.transformList.stoppedTransformBulkToolTip": "1 つまたは複数の変換が既に開始済みです。", + "xpack.transform.transformList.stoppedTransformToolTip": "{transformId} は既に停止済みです。", + "xpack.transform.transformList.stopTransformErrorMessage": "データフレーム変換 {transformId} の停止中にエラーが発生しました", + "xpack.transform.transformList.stopTransformSuccessMessage": "データフレーム変換 {transformId} の停止リクエストが受け付けられました。", + "xpack.transform.transformList.transformDescription": "変換を使用して、集約されたインデックスまたはエンティティ中心のインデックスに、既存のElasticsearchインデックスをインデックスします。", + "xpack.transform.transformList.transformDetails.messagesPane.errorMessage": "メッセージを読み込めませんでした", + "xpack.transform.transformList.transformDetails.messagesPane.messageLabel": "メッセージ", + "xpack.transform.transformList.transformDetails.messagesPane.nodeLabel": "ノード", + "xpack.transform.transformList.transformDetails.messagesPane.timeLabel": "時間", + "xpack.transform.transformList.transformDetails.tabs.transformMessagesLabel": "メッセージ", + "xpack.transform.transformList.transformDetails.tabs.transformPreviewLabel": "プレビュー", + "xpack.transform.transformList.transformDetails.tabs.transformSettingsLabel": "ジョブの詳細", + "xpack.transform.transformList.transformDocsLinkText": "変換ドキュメント", + "xpack.transform.transformList.transformTitle": "データフレームジョブ", + "xpack.transform.transformsWizard.betaBadgeLabel": "ベータ", + "xpack.transform.transformsWizard.betaBadgeTooltipContent": "変換はベータ機能です。フィードバックをお待ちしています。", + "xpack.transform.transformsWizard.createTransformTitle": "変換の作成", + "xpack.transform.transformsWizard.stepCreateTitle": "作成", + "xpack.transform.transformsWizard.stepDefineTitle": "ピボットの定義", + "xpack.transform.transformsWizard.stepDetailsTitle": "ジョブの詳細", + "xpack.transform.transformsWizard.transformDocsLinkText": "変換ドキュメント", + "xpack.transform.wizard.nextStepButton": "次へ", + "xpack.transform.wizard.previousStepButton": "前へ", + "xpack.upgradeAssistant.appTitle": "{version} アップグレードアシスタント", + "xpack.upgradeAssistant.checkupTab.backUpCallout.calloutBody.calloutDetail": "{snapshotRestoreDocsButton} でデータをバックアップします。", + "xpack.upgradeAssistant.checkupTab.backUpCallout.calloutBody.snapshotRestoreDocsButtonLabel": "API のスナップショットと復元", + "xpack.upgradeAssistant.checkupTab.backUpCallout.calloutTitle": "今すぐインデックをバックアップ", + "xpack.upgradeAssistant.checkupTab.changeFiltersShowMoreLabel": "より多く表示させるにはフィルターを変更します。", + "xpack.upgradeAssistant.checkupTab.clusterTabLabel": "クラスター", + "xpack.upgradeAssistant.checkupTab.controls.collapseAllButtonLabel": "すべて縮小", + "xpack.upgradeAssistant.checkupTab.controls.expandAllButtonLabel": "すべて拡張", + "xpack.upgradeAssistant.checkupTab.controls.filterBar.allButtonLabel": "すべて", + "xpack.upgradeAssistant.checkupTab.controls.filterBar.criticalButtonLabel": "致命的", + "xpack.upgradeAssistant.checkupTab.controls.groupByBar.byIndexLabel": "インデックス別", + "xpack.upgradeAssistant.checkupTab.controls.groupByBar.byIssueLabel": "問題別", + "xpack.upgradeAssistant.checkupTab.controls.refreshButtonLabel": "更新", + "xpack.upgradeAssistant.checkupTab.controls.searchBarPlaceholder": "フィルター", + "xpack.upgradeAssistant.checkupTab.deprecations.criticalActionTooltip": "アップグレード前にこの問題を解決してください。", + "xpack.upgradeAssistant.checkupTab.deprecations.criticalLabel": "致命的", + "xpack.upgradeAssistant.checkupTab.deprecations.documentationButtonLabel": "ドキュメント", + "xpack.upgradeAssistant.checkupTab.deprecations.indexTable.detailsColumnLabel": "詳細", + "xpack.upgradeAssistant.checkupTab.deprecations.indexTable.indexColumnLabel": "インデックス", + "xpack.upgradeAssistant.checkupTab.deprecations.warningActionTooltip": "アップグレード前にこの問題を解決することをお勧めしますが、必須ではありません。", + "xpack.upgradeAssistant.checkupTab.deprecations.warningLabel": "警告", + "xpack.upgradeAssistant.checkupTab.indexLabel": "インデックス", + "xpack.upgradeAssistant.checkupTab.indicesBadgeLabel": "{numIndices, plural, one {インデックス} other {インデックス}}", + "xpack.upgradeAssistant.checkupTab.indicesTabLabel": "インデックス", + "xpack.upgradeAssistant.checkupTab.noDeprecationsLabel": "説明がありません", + "xpack.upgradeAssistant.checkupTab.noIssues.nextStepsDetail": "{overviewTabButton} で次のステップを確認してください。", + "xpack.upgradeAssistant.checkupTab.noIssues.nextStepsDetail.overviewTabButtonLabel": "概要タブ", + "xpack.upgradeAssistant.checkupTab.noIssues.noIssuesLabel": "{strongCheckupLabel} の問題がありません。", + "xpack.upgradeAssistant.checkupTab.noIssues.noIssuesTitle": "完璧です!", + "xpack.upgradeAssistant.checkupTab.numDeprecationsShownLabel": "{total} 件中 {numShown} 件を表示中", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.cancelButtonLabel": "キャンセル", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.closeButtonLabel": "閉じる", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.continueButtonLabel": "再インデックスを続ける", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.insufficientPrivilegeCallout.calloutTitle": "このインデックスを再インデックスするための権限がありません", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.readonlyCallout.backgroundResumeDetail": "再インデックスはバックグラウンドで継続しますが、Kibana がシャットダウンまたは再起動した場合、このページに戻り再インデックスを再開させる必要があります。", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.readonlyCallout.calloutTitle": "インデックスは再インデックス中にドキュメントを投入、更新、または削除できません", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.readonlyCallout.cantStopDetail": "ドキュメントの更新を停止できない場合、または新しいクラスターに再インデックスする必要がある場合は、異なるアップグレード方法をお勧めします。", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexButton.doneLabel": "完了!", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexButton.reindexingLabel": "再インデックス中…", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexButton.resumeLabel": "再開", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexButton.runReindexLabel": "再インデックスを実行", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexButton.tryAgainLabel": "再試行", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.aliasSwapStepTitle": "オリジナルのインデックスをエイリアスと交換中", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.cancelButton.cancelLabel": "キャンセル", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.cancelButton.cancelledLabel": "キャンセル済み", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.cancelButton.cancellingLabel": "キャンセル中…", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.cancelButton.errorLabel": "キャンセルできませんでした", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.createIndexStepTitle": "新規インデックスを作成中", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.pauseMlStepTitle": "機械学習ジョブを一時停止中", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.readonlyStepTitle": "古いインデックスを読み込み専用に設定中", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.reindexingDocumentsStepTitle": "ドキュメントを再インデックス中", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.resumeMlStepTitle": "機械学習ジョブを再開中", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.resumeWatcherStepTitle": "Watcher を再開中", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.stopWatcherStepTitle": "Watcher を停止中", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklistTitle": "プロセスを再インデックス中", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.flyoutHeader": "{indexName} を再インデックス", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.warningsStep.apmReindexWarningDetail": "バージョン 7.0.0 以降、APM データは Elastic Common Schema で表示されます。過去の APM データは再インデックスされるまで表示されません。", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.warningsStep.apmReindexWarningTitle": "このインデックスは ECS 形式に変換されます", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.warningsStep.destructiveCallout.calloutDetail": "インデックスをバックアップして、互換性を破るそれぞれの変更に同意することで再インデックスしてください。", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.warningsStep.destructiveCallout.calloutTitle": "このインデックスには元に戻すことのできない破壊的な変更が含まれています", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.warningsStep.documentationLinkLabel": "ドキュメンテーション", + "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.cancelledLabel": "キャンセル済み", + "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.doneLabel": "完了", + "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.failedLabel": "失敗", + "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.loadingLabel": "読み込み中…", + "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.pausedLabel": "一時停止中", + "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.reindexLabel": "再インデックス", + "xpack.upgradeAssistant.checkupTab.tabDetail": "これらの {strongCheckupLabel} の問題への対処が必要です。Elasticsearch {nextEsVersion} へのアップグレード前に解決してください。", + "xpack.upgradeAssistant.forbiddenErrorCallout.calloutTitle": "このページを表示するための権限がありません。", + "xpack.upgradeAssistant.genericErrorCallout.calloutTitle": "チェックアップの結果を取得中にエラーが発生しました。", + "xpack.upgradeAssistant.overviewTab.overviewTabTitle": "概要", + "xpack.upgradeAssistant.overviewTab.steps.clusterStep.issuesRemainingStepTitle": "クラスターの問題を確認してください", + "xpack.upgradeAssistant.overviewTab.steps.clusterStep.noIssuesRemainingStepTitle": "クラスターの設定は準備完了です", + "xpack.upgradeAssistant.overviewTab.steps.clusterStep.noRemainingIssuesLabel": "廃止された設定は残っていません。", + "xpack.upgradeAssistant.overviewTab.steps.clusterStep.remainingIssuesDetail": "{numIssues} 件の問題が解決されました。", + "xpack.upgradeAssistant.overviewTab.steps.clusterStep.todo.clusterTabButtonLabel": "クラスタータブ", + "xpack.upgradeAssistant.overviewTab.steps.clusterStep.todo.todoDetail": "{clusterTabButton} に移動して廃止された設定を更新してください。", + "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.deprecationLogs.deprecationLogsDocButtonLabel": "廃止ログ", + "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.deprecationLogs.logsDetail": "{deprecationLogsDocButton} で、アプリケーションが {nextEsVersion} で利用できない機能を使用していないか確認してください。廃止ログを有効にする必要があるかもしれません。", + "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.enableDeprecationLoggingLabel": "廃止ログを有効にしますか?", + "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.enableDeprecationLoggingToggleSwitch.disabledLabel": "オフ", + "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.enableDeprecationLoggingToggleSwitch.enabledLabel": "オン", + "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.enableDeprecationLoggingToggleSwitch.errorLabel": "ログステータスを読み込めませんでした", + "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.stepTitle": "Elasticsearch の廃止ログを確認してください", + "xpack.upgradeAssistant.overviewTab.steps.indicesStep.issuesRemainingStepTitle": "インデックスの問題を確認してください", + "xpack.upgradeAssistant.overviewTab.steps.indicesStep.noIssuesRemainingStepTitle": "インデックスの設定は準備完了です", + "xpack.upgradeAssistant.overviewTab.steps.indicesStep.noRemainingIssuesLabel": "廃止された設定は残っていません。", + "xpack.upgradeAssistant.overviewTab.steps.indicesStep.remainingIssuesDetail": "{numIssues} 件の問題が解決されました。", + "xpack.upgradeAssistant.overviewTab.steps.indicesStep.todo.indicesTabButtonLabel": "インデックスタブ", + "xpack.upgradeAssistant.overviewTab.steps.indicesStep.todo.todoDetail": "{indicesTabButton} に移動して廃止された設定を更新してください。", + "xpack.upgradeAssistant.overviewTab.steps.startUpgradeStep.stepTitle": "アップグレード開始", + "xpack.upgradeAssistant.overviewTab.steps.startUpgradeStepCloud.stepDetail.goToCloudDashboardDetail": "Elastic Cloud ダッシュボードのデプロイセクションに移動し、アップグレードを開始します。", + "xpack.upgradeAssistant.overviewTab.steps.startUpgradeStepOnPrem.stepDetail.followInstructionsDetail": "{instructionButton} に従い、アップグレードを開始します。", + "xpack.upgradeAssistant.overviewTab.steps.startUpgradeStepOnPrem.stepDetail.instructionButtonLabel": "これらの手順", + "xpack.upgradeAssistant.overviewTab.steps.waitForReleaseStep.stepDetail": "リリースされ次第最新の {currentEsMajorVersion} バージョンにアップグレードし、ここに戻って {nextEsMajorVersion} へのアップグレードを行ってください。", + "xpack.upgradeAssistant.overviewTab.steps.waitForReleaseStep.stepTitle": "Elasticsearch {nextEsVersion} のリリース待ち", + "xpack.upgradeAssistant.overviewTab.tabDetail": "このアシスタントは、クラスターとインデックスの Elasticsearch への準備に役立ちます {nextEsVersion} 対処が必要な他の問題に関しては、Elasticsearch のログをご覧ください。", + "xpack.upgradeAssistant.tabs.checkupTab.clusterLabel": "クラスター", + "xpack.upgradeAssistant.tabs.incompleteCallout.calloutBody.breackingChangesDocButtonLabel": "廃止と互換性を破る変更", + "xpack.upgradeAssistant.tabs.incompleteCallout.calloutBody.calloutDetail": "Elasticsearch {nextEsVersion} の {breakingChangesDocButton} の完全なリストは、最終の {currentEsVersion} マイナーリリースで確認できます。この警告は、リストがすべて解決されると消えます。", + "xpack.upgradeAssistant.tabs.incompleteCallout.calloutTitle": "リストの問題がすべて解決されていない可能性があります。", + "xpack.upgradeAssistant.tabs.upgradingInterstitial.upgradeCompleteDescription": "すべての Elasticsearch ノードがアップグレードされました。Kibana をアップデートする準備ができました。", + "xpack.upgradeAssistant.tabs.upgradingInterstitial.upgradeCompleteTitle": "クラスターがアップグレードされました", + "xpack.upgradeAssistant.tabs.upgradingInterstitial.upgradingDescription": "1 つまたは複数の Elasticsearch ノードに、 Kibana よりも新しいバージョンの Elasticsearch があります。すべてのノードがアップグレードされた後で Kibana をアップグレードしてください。", + "xpack.upgradeAssistant.tabs.upgradingInterstitial.upgradingTitle": "クラスターをアップグレード中です", + "xpack.uptime.apmIntegrationAction.description": "このモニターの検索 APM", + "xpack.uptime.apmIntegrationAction.text": "ドメインでAPMを確認", + "xpack.uptime.badge.readOnly.text": "読み込み専用", + "xpack.uptime.badge.readOnly.tooltip": "を保存できませんでした", + "xpack.uptime.breadcrumbs.overviewBreadcrumbText": "アップタイム", + "xpack.uptime.durationChart.emptyPrompt.description": "このモニターは選択された時間範囲で一度も {emphasizedText} していません。", + "xpack.uptime.durationChart.emptyPrompt.title": "利用可能な期間データがありません", + "xpack.uptime.emptyState.configureHeartbeatLinkText": "Heartbeat を構成", + "xpack.uptime.emptyState.configureHeartbeatToGetStartedMessage": "アップタイムデータの収集を開始するには {configureHeartbeatLink}。", + "xpack.uptime.emptyState.loadingMessage": "読み込み中…", + "xpack.uptime.emptyState.noDataMessage": "アップタイムデータが見つかりませんでした", + "xpack.uptime.emptyState.noDataTitle": "利用可能なアップタイムデータがありません", + "xpack.uptime.emptyState.noIndexTitle": "アップタイムインデックスが見つかりません", + "xpack.uptime.emptyStateError.notAuthorized": "アップタイムデータの表示が承認されていません。システム管理者にお問い合わせください。", + "xpack.uptime.emptyStateError.notFoundPage": "ページが見つかりません", + "xpack.uptime.emptyStateError.title": "エラー", + "xpack.uptime.errorMessage": "エラー: {message}", + "xpack.uptime.featureCatalogueDescription": "エンドポイントヘルスチェックとアップタイム監視を行います。", + "xpack.uptime.featureRegistry.uptimeFeatureName": "アップタイム", + "xpack.uptime.filterBar.filterDownLabel": "ダウン", + "xpack.uptime.filterBar.filterUpLabel": "アップ", + "xpack.uptime.filterBar.options.location.name": "場所", + "xpack.uptime.filterBar.options.portLabel": "ポート", + "xpack.uptime.filterBar.options.schemeLabel": "スキーム", + "xpack.uptime.filterPopout.loadingMessage": "読み込み中…", + "xpack.uptime.filterPopout.searchMessage": "{title} を検索", + "xpack.uptime.integrationLink.missingDataMessage": "この統合に必要なデータが見つかりませんでした。", + "xpack.uptime.kueryBar.indexPatternMissingWarningMessage": "インデックスパターンの取得中にエラーが発生しました。", + "xpack.uptime.kueryBar.searchPlaceholder": "モニター ID、名前、プロトコルタイプなどを検索…", + "xpack.uptime.locationName.helpLinkAnnotation": "場所を追加", + "xpack.uptime.monitorChart.checksChart.bottomAxis.title": "タイムスタンプ", + "xpack.uptime.monitorChart.checksChart.leftAxis.title": "チェックの数", + "xpack.uptime.monitorCharts.checkStatus.series.downCountLabel": "ダウンカウント", + "xpack.uptime.monitorCharts.checkStatus.series.upCountLabel": "アップカウント", + "xpack.uptime.monitorCharts.checkStatus.title": "ステータスを確認", + "xpack.uptime.monitorCharts.durationChart.bottomAxis.title": "タイムスタンプ", + "xpack.uptime.monitorCharts.durationChart.leftAxis.title": "期間ms", + "xpack.uptime.monitorCharts.loadingMessage": "読み込み中…", + "xpack.uptime.monitorCharts.monitorDuration.titleLabel": "ミリ秒単位の監視時間", + "xpack.uptime.monitorList.downLineSeries.downLabel": "ダウン", + "xpack.uptime.monitorList.expandDrawerButton.ariaLabel": "ID {id}のモニターの行を展開", + "xpack.uptime.monitorList.geoName.helpLinkAnnotation": "場所を追加", + "xpack.uptime.monitorList.infraIntegrationAction.container.message": "コンテナーメトリックを表示", + "xpack.uptime.monitorList.infraIntegrationAction.docker.description": "このモニターのコンテナー ID のインフラストラクチャ UI を確認します", + "xpack.uptime.monitorList.infraIntegrationAction.docker.tooltip": "コンテナー ID「{containerId}」のインフラストラクチャ UI を確認します", + "xpack.uptime.monitorList.infraIntegrationAction.ip.ariaLabel": "このモニターの IP アドレスのインフラストラクチャ UI を確認します", + "xpack.uptime.monitorList.infraIntegrationAction.ip.message": "ホストメトリックを表示", + "xpack.uptime.monitorList.infraIntegrationAction.ip.tooltip": "IP「{ip}」のインフラストラクチャ UI を確認します", + "xpack.uptime.monitorList.infraIntegrationAction.kubernetes.description": "このモニターのポッド ID のインフラストラクチャ UI を確認します", + "xpack.uptime.monitorList.infraIntegrationAction.kubernetes.message": "ポッドメトリックを表示", + "xpack.uptime.monitorList.infraIntegrationAction.kubernetes.tooltip": "ポッド UID「{podUid}」のインフラストラクチャ UI を確認します", + "xpack.uptime.monitorList.integrationGroup.emptyMessage": "統合されたアプリケーションがありません", + "xpack.uptime.monitorList.loggingIntegrationAction.container.id": "コンテナーログを表示", + "xpack.uptime.monitorList.loggingIntegrationAction.container.message": "コンテナーログを表示", + "xpack.uptime.monitorList.loggingIntegrationAction.container.tooltip": "コンテナー ID「{containerId}」のロギング UI を確認します", + "xpack.uptime.monitorList.loggingIntegrationAction.ip.description": "このモニターのIPアドレスのロギングUIを確認", + "xpack.uptime.monitorList.loggingIntegrationAction.ip.message": "ホストログを表示", + "xpack.uptime.monitorList.loggingIntegrationAction.ip.tooltip": "IP\"{ip}\"のロギングUIを確認", + "xpack.uptime.monitorList.loggingIntegrationAction.kubernetes.ariaLabel": "ポッドログを表示", + "xpack.uptime.monitorList.loggingIntegrationAction.kubernetes.message": "ポッドログを表示", + "xpack.uptime.monitorList.loggingIntegrationAction.kubernetes.tooltip": "ポッド UID「{podUid}」のログを確認します", + "xpack.uptime.monitorList.monitorHistoryColumnLabel": "ダウンタイム履歴", + "xpack.uptime.monitorList.monitoringStatusTitle": "監視ステータス", + "xpack.uptime.monitorList.nameColumnLabel": "名前", + "xpack.uptime.monitorList.noItemForSelectedFiltersMessage": "選択されたフィルター条件でモニターが見つかりませんでした", + "xpack.uptime.monitorList.noItemMessage": "アップタイムモニターが見つかりません", + "xpack.uptime.monitorList.observabilityIntegrationsColumn.apmIntegrationLink.tooltip": "ここをクリックしてAPM でドメイン「{domain}」を確認します。", + "xpack.uptime.monitorList.observabilityIntegrationsColumn.popoverIconButton.ariaLabel": "URL {monitorUrl}で監査のための移行ポップオーバーを開く", + "xpack.uptime.monitorList.statusColumn.downLabel": "ダウン", + "xpack.uptime.monitorList.statusColumn.upLabel": "アップ", + "xpack.uptime.monitorList.statusColumnLabel": "ステータス", + "xpack.uptime.monitorList.table.description": "列にステータス、名前、URL、IP、ダウンタイム履歴、統合が入力されたモニターステータス表です。この表は現在 {length} 項目を表示しています。", + "xpack.uptime.monitorStatusBar.durationTextAriaLabel": "ミリ秒単位の監視時間", + "xpack.uptime.monitorStatusBar.healthStatusMessage.downLabel": "ダウン", + "xpack.uptime.monitorStatusBar.healthStatusMessage.upLabel": "アップ", + "xpack.uptime.monitorStatusBar.healthStatusMessageAriaLabel": "監視ステータス", + "xpack.uptime.monitorStatusBar.loadingMessage": "読み込み中…", + "xpack.uptime.monitorStatusBar.monitorUrlLinkAriaLabel": "監視 URL リンク", + "xpack.uptime.monitorStatusBar.timestampFromNowTextAriaLabel": "最終確認からの経過時間", + "xpack.uptime.notFountPage.homeLinkText": "ホームへ戻る", + "xpack.uptime.overviewPage.headerText": "概要", + "xpack.uptime.overviewPageLink.disabled.ariaLabel": "無効になったページ付けボタンです。モニターリストがこれ以上ナビゲーションできないことを示しています。", + "xpack.uptime.overviewPageLink.next.ariaLabel": "次の結果ページ", + "xpack.uptime.overviewPageLink.prev.ariaLabel": "前の結果ページ", + "xpack.uptime.overviewPageParsingErrorCallout.content": "フィルタークエリの解析中にエラーが発生しました. {content}", + "xpack.uptime.overviewPageParsingErrorCallout.noMessage": "エラーメッセージはありませんでした", + "xpack.uptime.overviewPageParsingErrorCallout.title": "エラーを解析中", + "xpack.uptime.pingList.checkHistoryTitle": "履歴", + "xpack.uptime.pingList.collapseRow": "縮小", + "xpack.uptime.pingList.durationMsColumnFormatting": "{millis}ミリ秒", + "xpack.uptime.pingList.durationMsColumnLabel": "期間", + "xpack.uptime.pingList.errorTypeColumnLabel": "エラータイプ", + "xpack.uptime.pingList.expandedRow.bodySize": "本文サイズは {bodyBytes} です。", + "xpack.uptime.pingList.expandedRow.error": "エラー", + "xpack.uptime.pingList.expandedRow.response_body": "応答本文", + "xpack.uptime.pingList.expandedRow.truncated": "初めの {contentBytes} バイトを表示中。", + "xpack.uptime.pingList.expandRow": "拡張", + "xpack.uptime.pingList.ipAddressColumnLabel": "IP", + "xpack.uptime.pingList.locationLabel": "場所", + "xpack.uptime.pingList.locationNameColumnLabel": "場所", + "xpack.uptime.pingList.recencyMessage": "最終確認 {fromNow}", + "xpack.uptime.pingList.responseCodeColumnLabel": "応答コード", + "xpack.uptime.pingList.statusColumnHealthDownLabel": "ダウン", + "xpack.uptime.pingList.statusColumnHealthUpLabel": "アップ", + "xpack.uptime.pingList.statusColumnLabel": "ステータス", + "xpack.uptime.pingList.statusLabel": "ステータス", + "xpack.uptime.pingList.statusOptions.allStatusOptionLabel": "すべて", + "xpack.uptime.pingList.statusOptions.downStatusOptionLabel": "ダウン", + "xpack.uptime.pingList.statusOptions.upStatusOptionLabel": "アップ", + "xpack.uptime.pluginDescription": "アップタイム監視", + "xpack.uptime.snapshot.downCountsMessage": "{down}/{total} 個のモニターがダウンしています", + "xpack.uptime.snapshot.noDataDescription": "申し訳ございませんが、ヒストグラムに利用可能なデータがありません", + "xpack.uptime.snapshot.noDataTitle": "ヒストグラムデータがありません", + "xpack.uptime.snapshot.noMonitorMessage": "モニターが見つかりません", + "xpack.uptime.snapshot.pingsOverTimeTitle": "一定時間のピング", + "xpack.uptime.snapshot.zeroDownMessage": "すべてのモニターが起動しています", + "xpack.uptime.snapshotHistogram.description": "{startTime} から {endTime} までの期間のアップタイムステータスを表示する棒グラフです。", + "xpack.uptime.snapshotHistogram.downMonitorsId": "ダウンモニター", + "xpack.uptime.snapshotHistogram.series.downLabel": "ダウン", + "xpack.uptime.snapshotHistogram.series.upLabel": "アップ", + "xpack.uptime.snapshotHistogram.xAxisId": "スナップショットX軸", + "xpack.uptime.snapshotHistogram.yAxis.title": "ピング", + "xpack.uptime.snapshotHistogram.yAxisId": "スナップショットY軸", + "xpack.uptime.uptimeFeatureCatalogueTitle": "起動時間", + "xpack.watcher.app.licenseErrorLinkText": "ライセンスを管理します。", + "xpack.watcher.app.licenseErrorTitle": "ライセンスエラー", + "xpack.watcher.appName": "Watcher", + "xpack.watcher.breadcrumb.createLabel": "作成", + "xpack.watcher.breadcrumb.editLabel": "編集", + "xpack.watcher.breadcrumb.listLabel": "Watcher", + "xpack.watcher.breadcrumb.statusLabel": "ステータス", + "xpack.watcher.constants.actionStates.acknowledgedStateText": "承認済み", + "xpack.watcher.constants.actionStates.configErrorStateText": "構成エラー", + "xpack.watcher.constants.actionStates.errorStateText": "エラー", + "xpack.watcher.constants.actionStates.firingStateText": "実行中", + "xpack.watcher.constants.actionStates.okStateText": "OK", + "xpack.watcher.constants.actionStates.throttledStateText": "スロットル", + "xpack.watcher.constants.watchStateComments.acknowledgedStateCommentText": "承認済み", + "xpack.watcher.constants.watchStateComments.executionFailingStateCommentText": "実行失敗", + "xpack.watcher.constants.watchStateComments.partiallyAcknowledgedStateCommentText": "部分承認済み", + "xpack.watcher.constants.watchStateComments.partiallyThrottledStateCommentText": "部分スロットル", + "xpack.watcher.constants.watchStateComments.throttledStateCommentText": "スロットル", + "xpack.watcher.constants.watchStates.configErrorStateText": "構成エラー", + "xpack.watcher.constants.watchStates.disabledStateText": "無効", + "xpack.watcher.constants.watchStates.errorStateText": "エラー", + "xpack.watcher.constants.watchStates.firingStateText": "実行中", + "xpack.watcher.constants.watchStates.okStateText": "OK", + "xpack.watcher.deleteSelectedWatchesConfirmModal.cancelButtonLabel": "キャンセル", + "xpack.watcher.deleteSelectedWatchesConfirmModal.deleteButtonLabel": "{numWatchesToDelete, plural, one {ウォッチ} other {# ウォッチ}}を削除 ", + "xpack.watcher.deleteSelectedWatchesConfirmModal.descriptionText": "{numWatchesToDelete, plural, one {削除されたウォッチ} other {削除されたウォッチ}}は回復できません", + "xpack.watcher.models.actionStatus.actionStatusJsonPropertyMissingBadRequestMessage": "JSON引数には\"{missingProperty}\"プロパティが含まれている必要があります", + "xpack.watcher.models.actionStatus.notDetermineActionStatusBadImplementationMessage": "アクションステータスを把握できませんでした; action = {actionStatusJson}", + "xpack.watcher.models.baseAction.selectMessageText": "アクションを実行します。", + "xpack.watcher.models.baseAction.simulateButtonLabel": "今すぐこのアクションをシミュレート", + "xpack.watcher.models.baseAction.simulateMessage": "アクション {id} のシミュレーションが完了しました", + "xpack.watcher.models.baseAction.typeName": "アクション", + "xpack.watcher.models.baseWatch.createUnknownActionTypeErrorMessage": "不明なアクションタイプ {type} を作成しようとしました。", + "xpack.watcher.models.baseWatch.displayName": "新規ウォッチ", + "xpack.watcher.models.baseWatch.idPropertyMissingBadRequestMessage": "json 引数には {id} プロパティが含まれている必要があります", + "xpack.watcher.models.baseWatch.selectMessageText": "新規ウォッチをセットアップします。", + "xpack.watcher.models.baseWatch.typeName": "ウォッチ", + "xpack.watcher.models.baseWatch.watchJsonPropertyMissingBadRequestMessage": "json 引数には {watchJson} プロパティが含まれている必要があります", + "xpack.watcher.models.baseWatch.watchStatusJsonPropertyMissingBadRequestMessage": "json 引数には {watchStatusJson} プロパティが含まれている必要があります", + "xpack.watcher.models.emailAction.actionJsonEmailPropertyMissingBadRequestMessage": "json 引数には {actionJsonEmail} プロパティが含まれている必要があります", + "xpack.watcher.models.emailAction.actionJsonEmailToPropertyMissingBadRequestMessage": "json 引数には {actionJsonEmailTo} プロパティが含まれている必要があります", + "xpack.watcher.models.emailAction.defaultSubjectText": "ウォッチ[{context}]はしきい値を超えました", + "xpack.watcher.models.emailAction.selectMessageText": "サーバーからメールを送信します。", + "xpack.watcher.models.emailAction.simulateButtonLabel": "今すぐメールをテスト送信", + "xpack.watcher.models.emailAction.simulateFailMessage": "{toList} へのメールの送信に失敗しました。", + "xpack.watcher.models.emailAction.simulateMessage": "{toList} にサンプルメールが送信されました", + "xpack.watcher.models.emailAction.typeName": "メール", + "xpack.watcher.models.fields.fieldsPropertyMissingBadRequestMessage": "json 引数には {fields} プロパティが含まれている必要があります", + "xpack.watcher.models.indexAction.actionJsonIndexPropertyMissingBadRequestMessage": "json引数には{actionJsonIndex}プロパティが含まれている必要があります", + "xpack.watcher.models.indexAction.selectMessageText": "データをElasticsearchにインデックスしてください。", + "xpack.watcher.models.indexAction.simulateButtonLabel": "データをインデックスする", + "xpack.watcher.models.indexAction.simulateFailMessage": "{index} のインデックスに失敗しました。", + "xpack.watcher.models.indexAction.simulateMessage": "インデックス {index} がインデックスされました。", + "xpack.watcher.models.indexAction.typeName": "インデックス", + "xpack.watcher.models.jiraAction.actionJsonJiraIssueTypePropertyMissingBadRequestMessage": "json引数には{actionJsonJiraIssueType}プロパティが含まれている必要があります", + "xpack.watcher.models.jiraAction.actionJsonJiraProjectKeyPropertyMissingBadRequestMessage": "json引数には{actionJsonJiraProjectKey}プロパティが含まれている必要があります", + "xpack.watcher.models.jiraAction.actionJsonJiraPropertyMissingBadRequestMessage": "json引数には{actionJsonJira}プロパティが含まれている必要があります", + "xpack.watcher.models.jiraAction.actionJsonJiraSummaryPropertyMissingBadRequestMessage": "json引数には{actionJsonJiraSummary}プロパティが含まれている必要があります", + "xpack.watcher.models.jiraAction.defaultSummaryText": "ウォッチ[{context}]はしきい値を超えました", + "xpack.watcher.models.jiraAction.selectMessageText": "AtlassianのJiraソフトウェアで問題を作成します。", + "xpack.watcher.models.jiraAction.simulateButtonLabel": "サンプルJira問題を作成", + "xpack.watcher.models.jiraAction.simulateFailMessage": "Jira の問題の作成に失敗しました。", + "xpack.watcher.models.jiraAction.simulateMessage": "Jira の問題が作成されました。", + "xpack.watcher.models.jiraAction.typeName": "Jira", + "xpack.watcher.models.jsonWatch.selectMessageText": "生 JSON のカスタムウォッチをセットアップします。", + "xpack.watcher.models.jsonWatch.typeName": "高度なウォッチ", + "xpack.watcher.models.loggingAction.actionJsonIndexNamePropertyMissingBadRequestMessage": "json引数には{actionJsonIndexName}プロパティが含まれている必要があります", + "xpack.watcher.models.loggingAction.actionJsonLoggingPropertyMissingBadRequestMessage": "json 引数には {actionJsonLogging} プロパティが含まれている必要があります", + "xpack.watcher.models.loggingAction.actionJsonLoggingTextPropertyMissingBadRequestMessage": "json 引数には {actionJsonLoggingText} プロパティが含まれている必要があります", + "xpack.watcher.models.loggingAction.actionJsonWebhookHostPropertyMissingBadRequestMessage": "json引数には{actionJsonWebhookHost}プロパティが含まれている必要があります", + "xpack.watcher.models.loggingAction.actionJsonWebhookPortPropertyMissingBadRequestMessage": "json引数には{actionJsonWebhookPort}プロパティが含まれている必要があります", + "xpack.watcher.models.loggingAction.defaultText": "ウォッチ[{context}]はしきい値を超えました", + "xpack.watcher.models.loggingAction.selectMessageText": "ログに新規項目を追加します。", + "xpack.watcher.models.loggingAction.simulateButtonLabel": "今すぐサンプルメッセージを記録", + "xpack.watcher.models.loggingAction.simulateFailMessage": "サンプルメッセージの記録に失敗しました", + "xpack.watcher.models.loggingAction.simulateMessage": "サンプルメッセージが記録されました", + "xpack.watcher.models.loggingAction.typeName": "ログ", + "xpack.watcher.models.monitoringWatch.formatVisualizeDataCalledBadRequestMessage": "ウォッチの監視に {formatVisualizeData} が必要です", + "xpack.watcher.models.monitoringWatch.fromDownstreamJsonCalledBadRequestMessage": "ウォッチの監視に {fromDownstreamJson} が必要です", + "xpack.watcher.models.monitoringWatch.getVisualizeQueryCalledBadRequestMessage": "ウォッチの監視に {getVisualizeQuery} が必要です", + "xpack.watcher.models.monitoringWatch.upstreamJsonCalledBadRequestMessage": "ウォッチの監視に {upstreamJson} が必要です", + "xpack.watcher.models.pagerDutyAction.actionJsonPagerDutyDescriptionPropertyMissingBadRequestMessage": "json引数には{actionJsonPagerDutyText}プロパティが含まれている必要があります", + "xpack.watcher.models.pagerDutyAction.actionJsonPagerDutyPropertyMissingBadRequestMessage": "json引数には{actionJsonPagerDuty}プロパティが含まれている必要があります", + "xpack.watcher.models.pagerdutyAction.defaultDescriptionText": "ウォッチ[{context}]はしきい値を超えました", + "xpack.watcher.models.pagerDutyAction.selectMessageText": "PagerDutyでイベントを作成してください。", + "xpack.watcher.models.pagerDutyAction.simulateButtonLabel": "PagerDutyイベントの送信", + "xpack.watcher.models.pagerDutyAction.simulateFailMessage": "Hipchat イベントの送信に失敗しました.。", + "xpack.watcher.models.pagerDutyAction.simulateMessage": "PagerDuty イベントが送信されました。", + "xpack.watcher.models.pagerDutyAction.typeName": "PagerDuty", + "xpack.watcher.models.slackAction.actionJsonSlackMessagePropertyMissingBadRequestMessage": "json 引数には {actionJsonSlackMessage} プロパティが含まれている必要があります", + "xpack.watcher.models.slackAction.actionJsonSlackPropertyMissingBadRequestMessage": "json 引数には {actionJsonSlack} プロパティが含まれている必要があります", + "xpack.watcher.models.slackAction.defaultText": "ウォッチ[{context}]はしきい値を超えました", + "xpack.watcher.models.slackAction.selectMessageText": "Slack ユーザーまたはチャンネルにメッセージを送信します。", + "xpack.watcher.models.slackAction.simulateButtonLabel": "今すぐサンプルメッセージを送信", + "xpack.watcher.models.slackAction.simulateFailMessage": "{toList} へのサンプル Slack メッセージの送信に失敗しました。", + "xpack.watcher.models.slackAction.simulateMessage": "{toList} にサンプル Slack メッセージが送信されました。", + "xpack.watcher.models.slackAction.TypeName": "Slack", + "xpack.watcher.models.thresholdWatch.selectMessageText": "特定の条件でアラートを送信します", + "xpack.watcher.models.thresholdWatch.sendAlertOnSpecificConditionTitleDescription": "特定の条件が満たされた時にアラートを送信します。", + "xpack.watcher.models.thresholdWatch.thresholdWatchIntervalTitleDescription": "これは {triggerIntervalSize} {timeUnitLabel} ごとに実行されます。", + "xpack.watcher.models.thresholdWatch.typeName": "しきい値アラート", + "xpack.watcher.models.unknownAction.actionJsonPropertyMissingBadRequestMessage": "json 引数には {actionJson} プロパティが含まれている必要があります", + "xpack.watcher.models.watch.typePropertyMissingBadRequestMessage": "json 引数には {type} プロパティが含まれている必要があります", + "xpack.watcher.models.watch.unknownWatchTypeLoadingAttemptBadRequestMessage": "不明なタイプ {jsonType} を読み込もうとしました", + "xpack.watcher.models.watch.watchJsonPropertyMissingBadRequestMessage": "json 引数には {watchJson} プロパティが含まれている必要があります", + "xpack.watcher.models.watchHistoryItem.idPropertyMissingBadRequestMessage": "json 引数には {id} プロパティが含まれている必要があります", + "xpack.watcher.models.watchHistoryItem.watchHistoryItemJsonPropertyMissingBadRequestMessage": "json 引数には {watchHistoryItemJson} プロパティが含まれている必要があります", + "xpack.watcher.models.watchHistoryItem.watchIdPropertyMissingBadRequestMessage": "json 引数には {watchId} プロパティが含まれている必要があります", + "xpack.watcher.models.watchStatus.idPropertyMissingBadRequestMessage": "json 引数には {id} プロパティが含まれている必要があります", + "xpack.watcher.models.watchStatus.watchStatusJsonPropertyMissingBadRequestMessage": "json 引数には {watchStatusJson} プロパティが含まれている必要があります", + "xpack.watcher.models.webhookAction.selectMessageText": "Webサービスにリクエストを送信してください。", + "xpack.watcher.models.webhookAction.simulateButtonLabel": "リクエストの送信", + "xpack.watcher.models.webhookAction.simulateFailMessage": "{fullPath} へのリクエストの送信に失敗しました。", + "xpack.watcher.models.webhookAction.simulateMessage": "{fullPath} にサンプルリクエストが送信されました", + "xpack.watcher.models.webhookAction.typeName": "Webフック", + "xpack.watcher.pageErrorForbidden.title": "Watcherを使用する権限がありません", + "xpack.watcher.pageErrorNotExist.description": "ID '{id}'のウォッチが見つかりませんでした。", + "xpack.watcher.pageErrorNotExist.title": "ウォッチが見つかりませんでした", + "xpack.watcher.requestFlyout.closeButtonLabel": "閉じる", + "xpack.watcher.requestFlyout.descriptionText": "この Elasticsearch リクエストは、このウォッチを作成または更新します。", + "xpack.watcher.requestFlyout.namedTitle": "「{id}」のリクエスト", + "xpack.watcher.requestFlyout.unnamedTitle": "リクエスト", + "xpack.watcher.saveRoute.duplicateWatchIdErrorMessage": "ID '{watchId}'のウォッチは既に存在します。", + "xpack.watcher.sections.watchDetail.actionErrorsCalloutTitle": "このアクションにはエラーがあります", + "xpack.watcher.sections.watchDetail.header": "'{watch}'の現在のステータス", + "xpack.watcher.sections.watchDetail.headerBadgeText": "システムウォッチ", + "xpack.watcher.sections.watchDetail.headerBadgeToolipText": "システムウォッチを無効にしたり、削除したりすることはできません。", + "xpack.watcher.sections.watchDetail.watchTable.ackActionCellTitle": "承認", + "xpack.watcher.sections.watchDetail.watchTable.ackActionCellTooltipTitle": "ウォッチアクションを承認します。", + "xpack.watcher.sections.watchDetail.watchTable.ackActionErrorMessage": "アクション{actionId}の承認中にエラーが発生しました", + "xpack.watcher.sections.watchDetail.watchTable.actionHeader": "名前", + "xpack.watcher.sections.watchDetail.watchTable.errorsCellText": "{total, number} {total, plural, one {エラー} other {エラー}}", + "xpack.watcher.sections.watchDetail.watchTable.errorsHeader": "エラー", + "xpack.watcher.sections.watchDetail.watchTable.noWatchesMessage": "表示するアクションがありません", + "xpack.watcher.sections.watchDetail.watchTable.stateHeader": "ステータス", + "xpack.watcher.sections.watchEdit.actions.addActionButtonLabel": "アクションの追加", + "xpack.watcher.sections.watchEdit.actions.disabledOptionLabel": "無効です。elasticsearch.ymlを構成します。", + "xpack.watcher.sections.watchEdit.actions.title": "条件が満たされたら、{watchActionsCount, plural, one{# アクション} other {# アクション}}を実行します", + "xpack.watcher.sections.watchEdit.errorLoadingWatchVisualizationTitle": "ウォッチビジュアライゼーションを読み込めません。", + "xpack.watcher.sections.watchEdit.errorTitle": "ウォッチの読み込み中にエラーが発生しました", + "xpack.watcher.sections.watchEdit.json.cancelButtonLabel": "キャンセル", + "xpack.watcher.sections.watchEdit.json.createButtonLabel": "ウォッチを作成", + "xpack.watcher.sections.watchEdit.json.editTabLabel": "編集", + "xpack.watcher.sections.watchEdit.json.error.invalidActionType": "アクション\"{action}\"に不明なアクションタイプが指定されています。", + "xpack.watcher.sections.watchEdit.json.error.invalidIdText": "IDには文字、数字、アンダースコア、ハイフン、数字のみを使用できます。", + "xpack.watcher.sections.watchEdit.json.error.invalidJsonText": "無効なJSON", + "xpack.watcher.sections.watchEdit.json.error.requiredIdText": "IDが必要です", + "xpack.watcher.sections.watchEdit.json.error.requiredJsonText": "JSONが必要です", + "xpack.watcher.sections.watchEdit.json.form.actionValidationErrorMessage": "無効なウォッチアクション", + "xpack.watcher.sections.watchEdit.json.form.watchIDLabel": "ID", + "xpack.watcher.sections.watchEdit.json.form.watchJsonAriaLabel": "コードエディター", + "xpack.watcher.sections.watchEdit.json.form.watchJsonDocLink": "API構文", + "xpack.watcher.sections.watchEdit.json.form.watchJsonLabel": "ウォッチJSON", + "xpack.watcher.sections.watchEdit.json.form.watchNameLabel": "名前(任意)", + "xpack.watcher.sections.watchEdit.json.hideRequestButtonLabel": "リクエストを非表示", + "xpack.watcher.sections.watchEdit.json.saveButtonLabel": "ウォッチを保存", + "xpack.watcher.sections.watchEdit.json.saveConfirmModal.cancelButtonLabel": "キャンセル", + "xpack.watcher.sections.watchEdit.json.saveConfirmModal.saveButtonLabel": "ウォッチを保存", + "xpack.watcher.sections.watchEdit.json.saveSuccessNotificationText": "「{watchDisplayName}」が保存されました", + "xpack.watcher.sections.watchEdit.json.saveWatchErrorTitle": "ウォッチの保存中にエラーが発生しました", + "xpack.watcher.sections.watchEdit.json.showRequestButtonLabel": "リクエストを表示", + "xpack.watcher.sections.watchEdit.json.simulateTabLabel": "シミュレート", + "xpack.watcher.sections.watchEdit.json.titlePanel.createNewTypeOfWatchTitle": "{typeName}を作成", + "xpack.watcher.sections.watchEdit.json.titlePanel.editWatchTitle": "{watchName}を編集", + "xpack.watcher.sections.watchEdit.loadingWatchDescription": "ウォッチの読み込み中...", + "xpack.watcher.sections.watchEdit.loadingWatchVisualizationDescription": "ウォッチビジュアライゼーションを読み込み中...", + "xpack.watcher.sections.watchEdit.monitoring.edit.calloutDescriptionText": "ウォッチ'{watchName}'はシステムウォッチであるため、編集できません。{watchStatusLink}", + "xpack.watcher.sections.watchEdit.monitoring.edit.calloutTitleText": "このウォッチは編集できません。", + "xpack.watcher.sections.watchEdit.monitoring.header.watchLinkTitle": "ウォッチステータスを表示します。", + "xpack.watcher.sections.watchEdit.simulate.form.actionModesFieldLabel": "アクションモード", + "xpack.watcher.sections.watchEdit.simulate.form.actionOverridesDescription": "ウォッチでアクションを実行またはスキップすることができるようにします。{actionsLink}", + "xpack.watcher.sections.watchEdit.simulate.form.actionOverridesDescription.linkLabel": "アクションの詳細をご覧ください。", + "xpack.watcher.sections.watchEdit.simulate.form.actionOverridesTitle": "アクション", + "xpack.watcher.sections.watchEdit.simulate.form.alternativeInputAriaLabel": "コードエディター", + "xpack.watcher.sections.watchEdit.simulate.form.alternativeInputFieldLabel": "代替インプット", + "xpack.watcher.sections.watchEdit.simulate.form.conditionOverridesDescription": "条件が満たされたときにウォッチを実行します。満たされない場合は、条件を無視し、設定されたスケジュールでウォッチを実行します。", + "xpack.watcher.sections.watchEdit.simulate.form.conditionOverridesTitle": "条件", + "xpack.watcher.sections.watchEdit.simulate.form.ignoreConditionFieldLabel": "条件を無視", + "xpack.watcher.sections.watchEdit.simulate.form.inputOverridesDescription": "インプットの実行から生成されたウォッチペイロードを上書きするには、JSONデータを入力します。", + "xpack.watcher.sections.watchEdit.simulate.form.inputOverridesTitle": "インプット", + "xpack.watcher.sections.watchEdit.simulate.form.invalidJsonFieldError": "無効なJSON", + "xpack.watcher.sections.watchEdit.simulate.form.saveButtonLabel": "ウォッチをシミュレート", + "xpack.watcher.sections.watchEdit.simulate.form.scheduledTimeFieldLabel": "スケジュール間隔", + "xpack.watcher.sections.watchEdit.simulate.form.triggeredTimeFieldLabel": "次の後にトリガーする", + "xpack.watcher.sections.watchEdit.simulate.form.triggerOverridesDescription": "ウォッチを開始する日時を設定します。", + "xpack.watcher.sections.watchEdit.simulate.form.triggerOverridesTitle": "トリガー", + "xpack.watcher.sections.watchEdit.simulate.pageDescription": "シミュレーターを使用して、ウォッチスケジュール、条件、アクション、およびインプット結果を上書きします。", + "xpack.watcher.sections.watchEdit.simulate.table.idColumnLabel": "ID", + "xpack.watcher.sections.watchEdit.simulate.table.modeColumnLabel": "モード", + "xpack.watcher.sections.watchEdit.simulate.table.modeSelectLabel": "アクションモード", + "xpack.watcher.sections.watchEdit.simulate.table.typeColumnLabel": "タイプ", + "xpack.watcher.sections.watchEdit.simulateResults.actionsSectionTitle": "アクション", + "xpack.watcher.sections.watchEdit.simulateResults.errorTitle": "ウォッチをシミュレートできません", + "xpack.watcher.sections.watchEdit.simulateResults.simulationOutputSectionTitle": "シミュレーションアウトプット", + "xpack.watcher.sections.watchEdit.simulateResults.table.actionColumnLabel": "ID", + "xpack.watcher.sections.watchEdit.simulateResults.table.modeColumnLabel": "モード", + "xpack.watcher.sections.watchEdit.simulateResults.table.reasonColumnLabel": "理由", + "xpack.watcher.sections.watchEdit.simulateResults.table.stateColumnLabel": "ステータス", + "xpack.watcher.sections.watchEdit.simulateResults.table.typeColumnLabel": "タイプ", + "xpack.watcher.sections.watchEdit.simulateResults.title": "シミュレーション結果", + "xpack.watcher.sections.watchEdit.threshold.accordion.deleteIconAriaLabel": "削除", + "xpack.watcher.sections.watchEdit.threshold.accordion.simulateResultsErrorTitle": "アクションのテスト中にエラーが発生しました", + "xpack.watcher.sections.watchEdit.threshold.actions.actionConfigurationWarningDescriptionText": "このアクションを作成するには、1つ以上の{accountType}アカウントを構成する必要があります。{docLink}", + "xpack.watcher.sections.watchEdit.threshold.actions.actionConfigurationWarningHelpLinkText": "さらに詳しく", + "xpack.watcher.sections.watchEdit.threshold.actions.actionConfigurationWarningTitleText": "アカウントが構成されていない可能性があります", + "xpack.watcher.sections.watchEdit.threshold.andLabel": "AND", + "xpack.watcher.sections.watchEdit.threshold.cancelButtonLabel": "キャンセル", + "xpack.watcher.sections.watchEdit.threshold.createButtonLabel": "アラートの作成", + "xpack.watcher.sections.watchEdit.threshold.emailAction.bodyTextAreaFieldLabel": "本文", + "xpack.watcher.sections.watchEdit.threshold.emailAction.recipientTextFieldLabel": "Toメールアドレス", + "xpack.watcher.sections.watchEdit.threshold.emailAction.subjectTextFieldLabel": "件名(任意)", + "xpack.watcher.sections.watchEdit.threshold.enterOneOrMoreIndicesValidationMessage": "1つまたは複数のインデックスを入力してください。", + "xpack.watcher.sections.watchEdit.threshold.error.requiredNameText": "名前が必要です。", + "xpack.watcher.sections.watchEdit.threshold.forTheLastButtonLabel": "過去", + "xpack.watcher.sections.watchEdit.threshold.forTheLastLabel": "過去", + "xpack.watcher.sections.watchEdit.threshold.groupedOverLabel": "次に対してグループ化", + "xpack.watcher.sections.watchEdit.threshold.indexAction.indexFieldLabel": "インデックス", + "xpack.watcher.sections.watchEdit.threshold.intervalSizeIsRequiredValidationMessage": "間隔サイズが必要です。", + "xpack.watcher.sections.watchEdit.threshold.intervalSizeNegativeNumberValidationMessage": "間隔サイズはマイナスの数字にできません。", + "xpack.watcher.sections.watchEdit.threshold.invalidIndexValidationMessage": "インデックスには時間フィールドがありません。", + "xpack.watcher.sections.watchEdit.threshold.jiraAction.issueTypeFieldLabel": "問題タイプ", + "xpack.watcher.sections.watchEdit.threshold.jiraAction.projectKeyFieldLabel": "プロジェクトキー", + "xpack.watcher.sections.watchEdit.threshold.jiraAction.summaryFieldLabel": "まとめ", + "xpack.watcher.sections.watchEdit.threshold.loggingAction.logTextFieldLabel": "ログテキスト", + "xpack.watcher.sections.watchEdit.threshold.ofButtonLabel": "/", + "xpack.watcher.sections.watchEdit.threshold.ofLabel": "/", + "xpack.watcher.sections.watchEdit.threshold.overButtonLabel": "の", + "xpack.watcher.sections.watchEdit.threshold.overLabel": "の", + "xpack.watcher.sections.watchEdit.threshold.pagerDutyAction.descriptionFieldLabel": "説明", + "xpack.watcher.sections.watchEdit.threshold.saveButtonLabel": "保存", + "xpack.watcher.sections.watchEdit.threshold.slackAction.messageTextAreaFieldLabel": "メッセージ(任意)", + "xpack.watcher.sections.watchEdit.threshold.slackAction.recipientTextFieldLabel": "受信者(任意)", + "xpack.watcher.sections.watchEdit.threshold.timeFieldIsRequiredValidationText": "時間フィールドドが必要です", + "xpack.watcher.sections.watchEdit.threshold.webhookAction.basicAuthPassword": "パスワード(任意)", + "xpack.watcher.sections.watchEdit.threshold.webhookAction.basicAuthUsername": "ユーザー名(任意)", + "xpack.watcher.sections.watchEdit.threshold.webhookAction.bodyCodeEditorAriaLabel": "コードエディター", + "xpack.watcher.sections.watchEdit.threshold.webhookAction.bodyFieldLabel": "本文", + "xpack.watcher.sections.watchEdit.threshold.webhookAction.hostFieldLabel": "ホスト", + "xpack.watcher.sections.watchEdit.threshold.webhookAction.methodFieldLabel": "メソド", + "xpack.watcher.sections.watchEdit.threshold.webhookAction.methodPortLabel": "ポート", + "xpack.watcher.sections.watchEdit.threshold.webhookAction.pathFieldLabel": "パス(任意)", + "xpack.watcher.sections.watchEdit.threshold.whenButtonLabel": "タイミング", + "xpack.watcher.sections.watchEdit.threshold.whenLabel": "タイミング", + "xpack.watcher.sections.watchEdit.titlePanel.chooseLabel": "選択...", + "xpack.watcher.sections.watchEdit.titlePanel.durationAriaLabel": "期間の時間単位", + "xpack.watcher.sections.watchEdit.titlePanel.howToBroadenSearchQueryDescription": "* で検索クエリの範囲を広げます", + "xpack.watcher.sections.watchEdit.titlePanel.indicesAndIndexPatternsLabel": "インデックスとインデックスパターンに基づく", + "xpack.watcher.sections.watchEdit.titlePanel.indicesToQueryLabel": "クエリを実行するインデックス", + "xpack.watcher.sections.watchEdit.titlePanel.timeFieldLabel": "時間フィールド", + "xpack.watcher.sections.watchEdit.titlePanel.timeFieldOptionLabel": "フィールドを選択", + "xpack.watcher.sections.watchEdit.titlePanel.watchIntervalLabel": "次の間隔でウォッチを実行:", + "xpack.watcher.sections.watchEdit.titlePanel.watchNameLabel": "名前", + "xpack.watcher.sections.watchEdit.watchConditionSectionTitle": "次の条件に一致", + "xpack.watcher.sections.watchHistory.changeTimespanSelectAriaLabel": "ウォッチ履歴のタイムスパンを変更", + "xpack.watcher.sections.watchHistory.deleteWatchButtonLabel": "削除", + "xpack.watcher.sections.watchHistory.timeSpan.1h": "過去1時間", + "xpack.watcher.sections.watchHistory.timeSpan.1y": "過去1年間", + "xpack.watcher.sections.watchHistory.timeSpan.24h": "過去24時間", + "xpack.watcher.sections.watchHistory.timeSpan.30d": "過去30日間", + "xpack.watcher.sections.watchHistory.timeSpan.6M": "過去6か月間", + "xpack.watcher.sections.watchHistory.timeSpan.7d": "過去7日間", + "xpack.watcher.sections.watchHistory.watchActionStatusTable.id": "名前", + "xpack.watcher.sections.watchHistory.watchActionStatusTable.state": "ステータス", + "xpack.watcher.sections.watchHistory.watchExecutionErrorTitle": "実行履歴の読み込み中にエラーが発生しました", + "xpack.watcher.sections.watchHistory.watchHistoryDetail.actionsTitle": "アクション", + "xpack.watcher.sections.watchHistory.watchHistoryDetail.errorTitle": "実行詳細", + "xpack.watcher.sections.watchHistory.watchHistoryDetail.jsonTitle": "JSON", + "xpack.watcher.sections.watchHistory.watchHistoryDetail.title": "{date}に実行", + "xpack.watcher.sections.watchHistory.watchHistoryDetailsErrorTitle": "実行詳細の読み込み中にエラーが発生しました", + "xpack.watcher.sections.watchHistory.watchTable.activateWatchLabel": "有効化", + "xpack.watcher.sections.watchHistory.watchTable.commentHeader": "コメント", + "xpack.watcher.sections.watchHistory.watchTable.deactivateWatchLabel": "無効化", + "xpack.watcher.sections.watchHistory.watchTable.noCurrentStatus": "表示する実行履歴がありません", + "xpack.watcher.sections.watchHistory.watchTable.noWatchesMessage": "表示する現在のステータスがありません", + "xpack.watcher.sections.watchHistory.watchTable.startTimeHeader": "トリガー時刻", + "xpack.watcher.sections.watchHistory.watchTable.stateHeader": "ステータス", + "xpack.watcher.sections.watchList.createAdvancedWatchButtonLabel": "高度なウォッチを作成", + "xpack.watcher.sections.watchList.createAdvancedWatchTooltip": "生 JSON のカスタムウォッチをセットアップします", + "xpack.watcher.sections.watchList.createThresholdAlertButtonLabel": "しきい値アラートを作成", + "xpack.watcher.sections.watchList.createThresholdAlertButtonTooltip": "特定の条件でアラートを送信します", + "xpack.watcher.sections.watchList.createWatchButtonLabel": "作成", + "xpack.watcher.sections.watchList.deleteMultipleWatchesButtonLabel": "ウォッチを削除", + "xpack.watcher.sections.watchList.deleteSelectedWatchesErrorNotification.descriptionText": "{numErrors, number} {numErrors, plural, one {ウォッチ} other {ウォッチ}}を削除できませんでした", + "xpack.watcher.sections.watchList.deleteSelectedWatchesSuccessNotification.descriptionText": "{numSuccesses, number} {numSuccesses, plural, one {ウォッチ} other {ウォッチ}}を削除しました", + "xpack.watcher.sections.watchList.deleteSingleWatchButtonLabel": "ウォッチを削除", + "xpack.watcher.sections.watchList.emptyPromptTitle": "まだウォッチがありません", + "xpack.watcher.sections.watchList.errorTitle": "ウォッチの読み込み中にエラーが発生しました", + "xpack.watcher.sections.watchList.header": "しきい値アラートを作成", + "xpack.watcher.sections.watchList.loadingWatchesDescription": "ウォッチの読み込み中...", + "xpack.watcher.sections.watchList.managementSection.editDisplayName": "編集", + "xpack.watcher.sections.watchList.managementSection.newWatchDisplayName": "新規ウォッチ", + "xpack.watcher.sections.watchList.managementSection.statusDisplayName": "ステータス", + "xpack.watcher.sections.watchList.managementSection.watcherDisplayName": "Watcher", + "xpack.watcher.sections.watchList.managementSection.watchesDisplayName": "ウォッチ", + "xpack.watcher.sections.watchList.subhead": "特定のパラメーターに到達した際にメール、Slack メッセージ、ログイベントを送信します。", + "xpack.watcher.sections.watchList.toggleActivatationErrorNotification.activateDescriptionText": "ウォッチを有効化できませんでした", + "xpack.watcher.sections.watchList.toggleActivatationErrorNotification.deactivateDescriptionText": "ウォッチを無効化できませんでした", + "xpack.watcher.sections.watchList.watcherGettingStartedDocsLinkText": "Watcherドキュメント", + "xpack.watcher.sections.watchList.watcherLearnMoreLinkText": "さらに詳しく", + "xpack.watcher.sections.watchList.watchTable.actionDeleteAriaLabel": "ウォッチ'{name}'を削除", + "xpack.watcher.sections.watchList.watchTable.actionDeleteTooltipLabel": "削除", + "xpack.watcher.sections.watchList.watchTable.actionEditAriaLabel": "ウォッチ'{name}'を編集", + "xpack.watcher.sections.watchList.watchTable.actionEditTooltipLabel": "編集", + "xpack.watcher.sections.watchList.watchTable.actionHeader": "アクション", + "xpack.watcher.sections.watchList.watchTable.commentHeader": "コメント", + "xpack.watcher.sections.watchList.watchTable.disabledWatchTooltipText": "このウォッチは読み取り専用です", + "xpack.watcher.sections.watchList.watchTable.idHeader": "ID", + "xpack.watcher.sections.watchList.watchTable.lastFiredHeader": "最終実行", + "xpack.watcher.sections.watchList.watchTable.lastTriggeredHeader": "最終トリガー実行", + "xpack.watcher.sections.watchList.watchTable.nameHeader": "名前", + "xpack.watcher.sections.watchList.watchTable.noWatchesMessage": "表示するウォッチがありません", + "xpack.watcher.sections.watchList.watchTable.stateHeader": "ステータス", + "xpack.watcher.sections.watchStatus.actionsTabLabel": "アクションステータス", + "xpack.watcher.sections.watchStatus.executionHistoryTabLabel": "実行履歴", + "xpack.watcher.sections.watchStatus.loadingWatchDetailsDescription": "ウォッチ詳細を読み込み中...", + "xpack.watcher.thresholdPreviewChart.dataDoesNotExistTextMessage": "インデックスと条件がデータを返しませんでした", + "xpack.watcher.thresholdPreviewChart.noDataTitle": "データなし", + "xpack.watcher.thresholdWatchExpression.aggType.xpack.watcher.thresholdWatchExpression.groupBy.requiredValueValidationMessage": "値が必要です。", + "xpack.watcher.thresholdWatchExpression.comparators.isAboveLabel": "より大きい:", + "xpack.watcher.thresholdWatchExpression.comparators.isAboveOrEqualsLabel": "以上", + "xpack.watcher.thresholdWatchExpression.comparators.isBelowLabel": "より小さい:", + "xpack.watcher.thresholdWatchExpression.comparators.isBelowOrEqualsLabel": "以下", + "xpack.watcher.thresholdWatchExpression.comparators.isBetweenLabel": "の間", + "xpack.watcher.thresholdWatchExpression.fixErrorInExpressionBelowValidationMessage": "下の表現のエラーを修正してください。", + "xpack.watcher.thresholdWatchExpression.groupBy.requiredFieldValidationMessage": "フィールドを選択してください。", + "xpack.watcher.thresholdWatchExpression.groupByLabel.allDocumentsLabel": "すべてのドキュメント", + "xpack.watcher.thresholdWatchExpression.groupByLabel.topLabel": "トップ", + "xpack.watcher.thresholdWatchExpression.thresholdLevel.secondValueMustBeGreaterMessage": "値は{lowerBound}よりも大きい値でなければなりません。", + "xpack.watcher.thresholdWatchExpression.thresholdLevel.valueIsRequiredValidationMessage": "値が必要です。", + "xpack.watcher.thresholdWatchExpression.timeWindow.durationSizeIsRequiredValidationMessage": "ウィンドウ期間サイズが必要です。", + "xpack.watcher.timeUnits.dayLabel": "{timeValue, plural, one {日} other {日}}", + "xpack.watcher.timeUnits.hourLabel": "{timeValue, plural, one {時間} other {時間}}", + "xpack.watcher.timeUnits.minuteLabel": "{timeValue, plural, one {分} other {分}}", + "xpack.watcher.timeUnits.secondLabel": "{timeValue, plural, one {秒} other {秒}}", + "xpack.watcher.watchActions.email.emailRecipientIsRequiredValidationMessage": "送信先メールアドレスが必要です。", + "xpack.watcher.watchActions.index.indexIsRequiredValidationMessage": "インデックス名が必要です。", + "xpack.watcher.watchActions.jira.issueTypeNameIsRequiredValidationMessage": "Jira問題タイプが必要です。", + "xpack.watcher.watchActions.jira.projectKeyIsRequiredValidationMessage": "Jiraプロジェクトキーが必要です。", + "xpack.watcher.watchActions.jira.summaryIsRequiredValidationMessage": "Jira概要が必要です。", + "xpack.watcher.watchActions.logging.logTextIsRequiredValidationMessage": "ログテキストが必要です。", + "xpack.watcher.watchActions.pagerduty.descriptionIsRequiredValidationMessage": "PagerDuty説明が必要です。", + "xpack.watcher.watchActions.webhook.hostIsRequiredValidationMessage": "Webフックホストが必要です。", + "xpack.watcher.watchActions.webhook.invalidJsonValidationMessage": "無効なJSON", + "xpack.watcher.watchActions.webhook.passwordIsRequiredIfUsernameValidationMessage": "パスワードが必要です。", + "xpack.watcher.watchActions.webhook.portIsRequiredValidationMessage": "Webフックポートが必要です。", + "xpack.watcher.watchActions.webhook.usernameIsRequiredIfPasswordValidationMessage": "ユーザー名が必要です", + "xpack.watcher.watchEdit.thresholdWatchExpression.aggType.fieldIsRequiredValidationMessage": "フィールドを選択してください。", + "xpack.watcher.watcherDescription": "アラートの作成、管理、監視によりデータへの変更を検知します。" } } \ No newline at end of file diff --git a/x-pack/plugins/translations/translations/zh-CN.json b/x-pack/plugins/translations/translations/zh-CN.json index 1bcfab4240aed..ba6ff117c688d 100644 --- a/x-pack/plugins/translations/translations/zh-CN.json +++ b/x-pack/plugins/translations/translations/zh-CN.json @@ -102,6 +102,7 @@ "common.ui.aggTypes.buckets.intervalOptions.yearlyDisplayName": "每年", "common.ui.aggTypes.buckets.ipRangeLabel": "{fieldName} IP 范围", "common.ui.aggTypes.buckets.ipRangeTitle": "IPv4 范围", + "common.ui.aggTypes.buckets.ranges.rangesFormatMessage": "{gte} {from} 且 {lt} {to}", "common.ui.aggTypes.buckets.rangesLabel": "{fieldName} 范围", "common.ui.aggTypes.buckets.rangeTitle": "范围", "common.ui.aggTypes.buckets.significantTerms.excludeLabel": "排除", @@ -121,9 +122,10 @@ "common.ui.aggTypes.customMetricLabel": "定制指标", "common.ui.aggTypes.dateRanges.acceptedDateFormatsLinkText": "已接受日期格式", "common.ui.aggTypes.dateRanges.addRangeButtonLabel": "添加范围", + "common.ui.aggTypes.dateRanges.errorMessage": "每个范围应至少有一个有效日期。", "common.ui.aggTypes.dateRanges.fromColumnLabel": "从", + "common.ui.aggTypes.dateRanges.removeRangeButtonAriaLabel": "移除范围 {from} 至 {to}", "common.ui.aggTypes.dateRanges.toColumnLabel": "到", - "common.ui.aggTypes.definiteMetricLabel": "指标:{metric}", "common.ui.aggTypes.dropPartialBucketsLabel": "丢弃部分存储桶", "common.ui.aggTypes.dropPartialBucketsTooltip": "移除超出时间范围的存储桶,以便直方图不以不完整的存储桶开始和结束。", "common.ui.aggTypes.extendedBounds.errorMessage": "最小值应小于或等于最大值。", @@ -246,8 +248,12 @@ "common.ui.aggTypes.precisionLabel": "精确度", "common.ui.aggTypes.ranges.addRangeButtonLabel": "添加范围", "common.ui.aggTypes.ranges.fromLabel": "从", + "common.ui.aggTypes.ranges.greaterThanOrEqualPrepend": "≥", + "common.ui.aggTypes.ranges.lessThanPrepend": "<", "common.ui.aggTypes.ranges.removeRangeButtonAriaLabel": "移除范围 {from} 至 {to}", "common.ui.aggTypes.ranges.toLabel": "到", + "common.ui.aggTypes.scaleMetricsLabel": "缩放指标值(已弃用)", + "common.ui.aggTypes.scaleMetricsTooltip": "如果选择手动最小时间间隔并将使用较大的时间间隔,则启用此设置将使计数和求和指标缩放到手动选择的时间间隔。", "common.ui.aggTypes.showEmptyBucketsLabel": "显示空存储桶", "common.ui.aggTypes.showEmptyBucketsTooltip": "显示所有存储桶,不仅仅有结果的存储桶", "common.ui.aggTypes.sizeLabel": "大小", @@ -261,10 +267,14 @@ "common.ui.aggTypes.timeInterval.scaledHelpText": "当前缩放至 {bucketDescription}", "common.ui.aggTypes.timeInterval.selectIntervalPlaceholder": "选择时间间隔", "common.ui.aggTypes.timeInterval.selectOptionHelpText": "选择选项或创建定制值示例:30s、20m、24h、2d、1w、1M", + "common.ui.chrome.bigUrlWarningNotificationMessage": "在{advancedSettingsLink}中启用“{storeInSessionStorageParam}”选项或简化屏幕视觉效果。", + "common.ui.chrome.bigUrlWarningNotificationMessage.advancedSettingsLinkText": "高级设置", + "common.ui.chrome.bigUrlWarningNotificationTitle": "URL 过长,Kibana 可能无法工作", "common.ui.directives.fieldNameIcons.booleanAriaLabel": "布尔字段", "common.ui.directives.fieldNameIcons.conflictFieldAriaLabel": "冲突字段", "common.ui.directives.fieldNameIcons.dateFieldAriaLabel": "日期字段", "common.ui.directives.fieldNameIcons.geoPointFieldAriaLabel": "地理位置点字段", + "common.ui.directives.fieldNameIcons.geoShapeFieldAriaLabel": "几何形状字段", "common.ui.directives.fieldNameIcons.ipAddressFieldAriaLabel": "IP 地址字段", "common.ui.directives.fieldNameIcons.murmur3FieldAriaLabel": "Murmur3 字段", "common.ui.directives.fieldNameIcons.numberFieldAriaLabel": "数字字段", @@ -395,6 +405,7 @@ "common.ui.fieldEditor.syntaxHeader": "语法", "common.ui.fieldEditor.truncate.lengthLabel": "字段长度", "common.ui.fieldEditor.typeLabel": "类型", + "common.ui.fieldEditor.url.heightLabel": "高", "common.ui.fieldEditor.url.labelTemplateHelpText": "标签模板帮助", "common.ui.fieldEditor.url.labelTemplateLabel": "标签模板", "common.ui.fieldEditor.url.offLabel": "关闭", @@ -403,6 +414,7 @@ "common.ui.fieldEditor.url.template.helpLinkText": "URL 模板帮助", "common.ui.fieldEditor.url.typeLabel": "类型", "common.ui.fieldEditor.url.urlTemplateLabel": "URL 模板", + "common.ui.fieldEditor.url.widthLabel": "宽", "common.ui.fieldEditor.urlTemplate.examplesHeader": "示例", "common.ui.fieldEditor.urlTemplate.inputHeader": "输入", "common.ui.fieldEditor.urlTemplate.outputHeader": "输出", @@ -470,15 +482,24 @@ "common.ui.vis.defaultEditor.aggSelect.noCompatibleAggsDescription": "索引模式“{indexPatternTitle}”不包含任何聚合。", "common.ui.vis.defaultEditor.aggSelect.selectAggPlaceholder": "选择聚合", "common.ui.vis.defaultEditor.aggSelect.subAggregationLabel": "子聚合", + "common.ui.vis.defaultEditor.controls.columnsLabel": "瀛楁", + "common.ui.vis.defaultEditor.controls.dotSizeRatioHelpText": "更改最小点与最大点的半径比率。", + "common.ui.vis.defaultEditor.controls.dotSizeRatioLabel": "点大小比率", + "common.ui.vis.defaultEditor.controls.rowsLabel": "行", + "common.ui.vis.defaultEditor.controls.splitByLegend": "按行或列拆分图表。", "common.ui.vis.defaultFeedbackMessage": "想反馈?请在“{link}中创建问题。", "common.ui.vis.editors.advancedToggle.advancedLinkLabel": "高级", "common.ui.vis.editors.agg.disableAggButtonTooltip": "禁用聚合", "common.ui.vis.editors.agg.enableAggButtonTooltip": "启用聚合", + "common.ui.vis.editors.agg.errorsAriaLabel": "聚合有错误", "common.ui.vis.editors.agg.modifyPriorityButtonTooltip": "通过拖动来修改优先级", "common.ui.vis.editors.agg.removeDimensionButtonTooltip": "移除维度", "common.ui.vis.editors.agg.toggleEditorButtonAriaLabel": "切换 {schema} 编辑器", + "common.ui.vis.editors.aggAdd.addButtonLabel": "娣诲姞", "common.ui.vis.editors.aggAdd.addGroupButtonLabel": "添加{groupNameLabel}", "common.ui.vis.editors.aggAdd.addSubGroupButtonLabel": "添加子{groupNameLabel}", + "common.ui.vis.editors.aggAdd.bucketLabel": "存储桶", + "common.ui.vis.editors.aggAdd.metricLabel": "指标", "common.ui.vis.editors.aggGroups.bucketsText": "存储桶", "common.ui.vis.editors.aggGroups.metricsText": "指标", "common.ui.vis.editors.aggParams.errors.aggWrongRunOrderErrorMessage": "“{schema}” 聚合必须在所有其他存储桶之前运行!", @@ -490,13 +511,14 @@ "common.ui.vis.editors.sidebar.autoApplyChangesTooltip": "自动应用更改", "common.ui.vis.editors.sidebar.discardChangesAriaLabel": "重置可视化", "common.ui.vis.editors.sidebar.discardChangesTooltip": "放弃更改", + "common.ui.vis.editors.sidebar.errorButtonAriaLabel": "需要解决突出显示的字段中的错误。", + "common.ui.vis.editors.sidebar.errorButtonTooltip": "需要解决突出显示的字段中的错误。", "common.ui.vis.editors.sidebar.tabs.dataLabel": "数据", "common.ui.vis.editors.sidebar.tabs.optionsLabel": "选项", "common.ui.vis.kibanaMap.leaflet.fitDataBoundsAriaLabel": "适应数据边界", "common.ui.vis.kibanaMap.zoomWarning": "已达到缩放级别最大数目。要一直放大,请升级到 Elasticsearch 和 Kibana 的 {defaultDistribution}。您可以通过 {ems} 免费使用其他缩放级别。或者,您可以配置自己的地图服务器。请前往 { wms } 或 { configSettings} 以获取详细信息。", "common.ui.vis.visTypes.legend.filterForValueButtonAriaLabel": "筛留值 {legendDataLabel}", "common.ui.vis.visTypes.legend.filterOutValueButtonAriaLabel": "筛除值 {legendDataLabel}", - "common.ui.vis.visTypes.legend.filterOptionsLegend": "{legendDataLabel}, 篩選器選項", "common.ui.vis.visTypes.legend.loadingLabel": "正在加载……", "common.ui.vis.visTypes.legend.setColorScreenReaderDescription": "为值 {legendDataLabel} 设置颜色", "common.ui.vis.visTypes.legend.toggleLegendButtonAriaLabel": "切换图例", @@ -508,368 +530,72 @@ "common.ui.vislib.colormaps.greysText": "灰色", "common.ui.vislib.colormaps.redsText": "红色", "common.ui.vislib.colormaps.yellowToRedText": "黄到红", - "common.ui.visualize.queryGeohashBounds.unableToGetBoundErrorTitle": "无法获取边界", - "common.ui.directives.fieldNameIcons.geoShapeFieldAriaLabel": "几何形状字段", - "common.ui.vis.editors.agg.errorsAriaLabel": "聚合有错误", "common.ui.vislib.heatmap.maxBucketsText": "定义了过多的序列 ({nr})。配置的最大值为 {max}。", - "common.ui.aggTypes.ranges.greaterThanOrEqualPrepend": "≥", - "common.ui.aggTypes.ranges.lessThanPrepend": "<", - "common.ui.aggTypes.scaleMetricsLabel": "缩放指标值(已弃用)", - "common.ui.aggTypes.scaleMetricsTooltip": "如果选择手动最小时间间隔并将使用较大的时间间隔,则启用此设置将使计数和求和指标缩放到手动选择的时间间隔。", - "common.ui.aggTypes.buckets.ranges.rangesFormatMessage": "{gte} {from} 且 {lt} {to}", - "management.connectDataDisplayName": "连接数据", - "management.displayName": "管理", - "management.nav.menu": "管理菜单", - "management.editIndexPattern.createIndex.defaultButtonDescription": "对任何数据执行完全聚合", - "management.editIndexPattern.createIndex.defaultButtonText": "标准索引模式", - "management.editIndexPattern.createIndex.defaultTypeName": "索引模式", - "timelion.savedObjectFinder.addNewItemButtonLabel": "添加新的 {item}", - "timelion.savedObjectFinder.manageItemsButtonLabel": "管理 {items}", - "timelion.savedObjectFinder.noMatchesFoundDescription": "未找到任何匹配的 {items}。", - "timelion.savedObjectFinder.pageItemsFromHitCountDescription": "{pageFirstItem}-{pageLastItem} 页,共 {hitCount} 页", - "timelion.savedObjectFinder.sortByButtonLabeAscendingScreenReaderOnly": "升序", - "timelion.savedObjectFinder.sortByButtonLabeDescendingScreenReaderOnly": "降序", - "timelion.savedObjectFinder.sortByButtonLabel": "名称", - "timelion.savedObjectFinder.sortByButtonLabelScreenReaderOnly": "排序依据", - "timelion.badge.readOnly.text": "只读", - "timelion.badge.readOnly.tooltip": "无法保存 Timelion 工作表", - "timelion.breadcrumbs.create": "创建", - "timelion.breadcrumbs.root": "Timelion", - "timelion.cells.actions.fullscreenAriaLabel": "全屏图表", - "timelion.cells.actions.fullscreenTooltip": "全屏", - "timelion.cells.actions.removeAriaLabel": "删除图表", - "timelion.cells.actions.removeTooltip": "删除", - "timelion.cells.actions.reorderAriaLabel": "拖动以重新排序", - "timelion.cells.actions.reorderTooltip": "拖动以重新排序", - "timelion.chart.seriesList.noSchemaWarning": "没有此类面板类型:{renderType}", - "timelion.expressionInputAriaLabel": "Timelion 表达式", - "timelion.expressionInputPlaceholder": "请尝试使用 {esQuery} 查询", - "timelion.expressionSuggestions.arg.infoTitle": "信息", - "timelion.expressionSuggestions.arg.listTitle": "参数:", - "timelion.expressionSuggestions.arg.nameTitle": "参数类型", - "timelion.expressionSuggestions.arg.typesTitle": "接受的类型", - "timelion.expressionSuggestions.func.description.chainableText": "{help}(可链接)", - "timelion.expressionSuggestions.func.description.dataSourceText": "{help}(数据源)", - "timelion.fitFunctions.carry.downSampleErrorMessage": "请勿使用“carry”拟合方法下采样,而是使用“scale”或“average”", - "timelion.fullscreen.exitAriaLabel": "退出全屏", - "timelion.fullscreen.exitTooltip": "退出全屏", - "timelion.function.help": "Timelion 可视化", - "timelion.help.configuration.firstTimeConfigurationLinkText": "首次配置", - "timelion.help.configuration.notValid.advancedSettingsPathText": "管理/Kibana/高级设置", - "timelion.help.configuration.notValid.notValidSettingsErrorMessage": "无法验证 Elasticsearch 设置:{reason}。请检查您的高级设置,然后重试。({count})", - "timelion.help.configuration.notValid.paragraph1": "如果使用的是 Logstash,则无需配置任何内容即可开始使用 Timelion 浏览日志数据。要搜索其他索引,请转到 {advancedSettingsPath},然后配置 {esDefaultIndex} 和 {esTimefield} 设置以匹配您的索引。", - "timelion.help.configuration.notValid.paragraph2": "您还会看到一些其他 Timelion 设置。您现在无需担心这些设置。稍后就会发现,您可以根据需要即时设置其中大部分的设置。", - "timelion.help.configuration.notValid.validateButtonLabel": "验证配置", - "timelion.help.configuration.notValidTitle": "首次配置", - "timelion.help.configuration.valid.advancedSettingsPathText": "管理/Kibana/高级设置", - "timelion.help.configuration.valid.intervalIsAutoText": "全部准备就绪!", - "timelion.help.configuration.valid.intervals.content.intervalIsNotAutoText": "将其设为 {auto} 以允许 Timelion 选择适当的间隔。", - "timelion.help.configuration.valid.intervalsTextPart1": "输入栏右侧的间隔选择器可让您控制采样频率。当前设为 {interval}。", - "timelion.help.configuration.valid.intervalsTextPart2": "如果 Timelion 认为您的时间范围和间隔组合生成的数据点过多,将引发一个错误。您可以通过在 {advancedSettingsPath} 中配置 {maxBuckets} 来调整该限制。", - "timelion.help.configuration.valid.intervalsTitle": "间隔", - "timelion.help.configuration.valid.paragraph1Part1": "我们已验证您的默认索引、时间字段及所有设置均正确无误。我们找到了范围介于 {statsMin} 到 {statsMax} 之间的数据。您大概已准备就绪。如果有错误,请参阅", - "timelion.help.configuration.valid.paragraph1Part2": ",了解有关配置 Elasticsearch 数据源的信息。", - "timelion.help.configuration.valid.paragraph2": "您应该能看到一个图表,但还需要做一些调整才能看到所有感兴趣的数据:", - "timelion.help.configuration.valid.paragraph3": "现在,您应看到一个数据点计数随时间变化的折线图。", - "timelion.help.configuration.valid.timeRangeText": "使用 Kibana 工具栏中的时间选择器,选择包含要可视化数据的时间段。请确保选择包含上述所示的全部或部分时间范围的时间段。", - "timelion.help.configuration.valid.timeRangeTitle": "时间范围", - "timelion.help.configuration.validTitle": "真棒,Elasticsearch 配置正确!", - "timelion.help.dataTransforming.functionReferenceLinkText": "函数引用", - "timelion.help.dataTransforming.paragraph1": "至此,您已经掌握了基础知识,接下来开始体验 Timelion 的强大功能。让我们来计算一段时间内部分数据子集占整体数量的百分比。例如,我们的 Web 流量中有多少来自美国?", - "timelion.help.dataTransforming.paragraph2": "首先,我们需要查找包含 US 的所有事件:{esUsQuery}。", - "timelion.help.dataTransforming.paragraph3": "接下来,要计算 US 事件与所有事件之比。要将 {us} 除以总值,我们可以使用 {divide} 函数:{divideDataQuery}。", - "timelion.help.dataTransforming.paragraph4": "还不错,但这是一个介于 0 到 1 之间的数字。要将其转换为百分比,只需乘以 100:{multiplyDataQuery}。", - "timelion.help.dataTransforming.paragraph5": "现在,我们知道了其中美国流量所占的百分比,并且可以看到其随时间的变化情况!Timelion 具有很多内置算术函数,例如 {sum}、{subtract}、{multiply} 和 {divide}。其中很多函数可以采用一个序列或一个数字。此外,还有其他有用的数据转换函数,例如 {movingaverage}、{abs} 和 {derivative}。", - "timelion.help.dataTransforming.paragraph6Part1": "现在您已熟悉了语法,然后,请参阅", - "timelion.help.dataTransforming.paragraph6Part2": ",了解如何使用所有可用的 Timelion 函数。您可以单击 Kibana 工具栏上的 \\{Docs\\},随时查看参考资料。要返回此教程,请单击参考资料顶部的 \\{Tutorial\\} 链接。", - "timelion.help.dataTransformingTitle": "转换您的数据:真正的乐趣所在!", - "timelion.help.dontShowHelpButtonLabel": "不再显示此内容", - "timelion.help.expressions.examples.customStylingDescription": "{descriptionTitle}将第一个序列着色为红色,并为第二个序列使用 1 像素宽的条。", - "timelion.help.expressions.examples.customStylingDescriptionTitle": "定制样式。", - "timelion.help.expressions.examples.groupedExpressionsDescription": "{descriptionTitle}您还可以将表达式组链接到函数。这里两个序列都显示为圈点,而不是线。", - "timelion.help.expressions.examples.groupedExpressionsDescriptionTitle": "将表达式分组。", - "timelion.help.expressions.examples.namedArgumentsDescription": "{descriptionTitle}请不要尝试记住指定参数所需的顺序,使用命名参数可使表达式更易于读写。", - "timelion.help.expressions.examples.namedArgumentsDescriptionTitle": "命名参数。", - "timelion.help.expressions.examples.twoExpressionsDescription": "{descriptionTitle}同一个图表上的两个表达式。", - "timelion.help.expressions.examples.twoExpressionsDescriptionTitle": "乐趣倍增。", - "timelion.help.expressions.functionReferenceLinkText": "函数引用", - "timelion.help.expressions.paragraph1": "每个表达式都以一个数据源函数开头。接着,您可以对数据源附加新函数,以对其进行转换和增强。", - "timelion.help.expressions.paragraph2": "对了,从现在开始,您可能比我们更了解自己的数据。可以随意将示例查询替换为更有意义的内容!", - "timelion.help.expressions.paragraph3": "接下来我们开始进行实验,请单击 Kibana 工具栏中的 {strongAdd} 添加另一个或第三个图表。然后,选择一个图表,复制下列其中一个表达式,粘贴到输入栏,然后按 Enter 键。清除,再重复上述操作来尝试其他表达式。", - "timelion.help.expressions.paragraph4": "Timelion 还提供了很多视图转换函数,可用于定制图表的外观。有关完整列表,请参阅", - "timelion.help.expressions.strongAddText": "添加", - "timelion.help.expressionsTitle": "使用表达式表达您自己", - "timelion.help.functions.absHelpText": "返回序列列表中每个值的绝对值", - "timelion.help.functions.aggregate.args.functionHelpText": "以下选项之一:{functions}", - "timelion.help.functions.aggregateHelpText": "基于对序列中所有点的处理结果创建静态线。可用函数:{functions}", - "timelion.help.functions.bars.args.stackHelpText": "条应堆叠,默认情况下为 true", - "timelion.help.functions.bars.args.widthHelpText": "条宽(以像素为单位)", - "timelion.help.functions.barsHelpText": "将 seriesList 显示为条", - "timelion.help.functions.color.args.colorHelpText": "序列颜色,以十六进制为单位,例如,#c6c6c6 表示雅致的浅灰色。如果您指定多种颜色,并有多个序列,可生成渐变色,例如,“#00B1CC:#00FF94:#FF3A39:#CC1A6F”", - "timelion.help.functions.colorHelpText": "更改序列颜色", - "timelion.help.functions.common.args.fitHelpText": "用于将序列拟合到目标时间跨度和间隔的算法。可用:{fitFunctions}", - "timelion.help.functions.common.args.offsetHelpText": "通过日期表达式(例如 -1M)偏移序列检索,使一个月前的事件看起来好像正在发生一样。通过使用值“timerange”,可以相对于图表整体时间范围来偏移序列。例如,“timerange:-2”将指定一个是过去图表整体时间范围两倍的偏移量。", - "timelion.help.functions.condition.args.elseHelpText": "比较为 false 时要将该点设置成的值。如果在此处传递 seriesList,将使用第一个序列", - "timelion.help.functions.condition.args.ifHelpText": "要与该点进行比较的值。如果在此处传递 seriesList,将使用第一个序列", - "timelion.help.functions.condition.args.operator.suggestions.eqHelpText": "等于", - "timelion.help.functions.condition.args.operator.suggestions.gteHelpText": "大于等于", - "timelion.help.functions.condition.args.operator.suggestions.gtHelpText": "大于", - "timelion.help.functions.condition.args.operator.suggestions.lteHelpText": "小于等于", - "timelion.help.functions.condition.args.operator.suggestions.ltHelpText": "小于", - "timelion.help.functions.condition.args.operator.suggestions.neHelpText": "不等于", - "timelion.help.functions.condition.args.operatorHelpText": "用于比较的比较运算符,有效运算符包括 eq(等于)、ne(不等于)、lt(小于)、lte(小于等于)、gt(大于)、gte(大于等于)", - "timelion.help.functions.condition.args.thenHelpText": "比较为 true 时要将该点设置成的值。如果在此处传递 seriesList,将使用第一个序列", - "timelion.help.functions.conditionHelpText": "使用运算符将每个点与另一个序列中的数字或相同点进行比较,然后在条件证明为 true 时将其值设置为该结果,且使用可选的 else。", - "timelion.help.functions.cusum.args.baseHelpText": "起始数字。基本上只会将此值添加到序列的开头", - "timelion.help.functions.cusumHelpText": "从基数开始,返回序列的累计和。", - "timelion.help.functions.derivativeHelpText": "绘制值随时间的变化。", - "timelion.help.functions.divide.args.divisorHelpText": "要除以的数字或序列。具有多个序列的 seriesList 将按标签方式应用。", - "timelion.help.functions.divideHelpText": "将 seriesList 中一个或多个序列的值除以输入 seriesList 的每个序列中的每个位置", - "timelion.help.functions.es.args.indexHelpText": "要查询的索引,接受通配符。在提供 metrics、split 和 timefield 参数建议之前,请先提供脚本字段的索引模式名称和字段名称类型。", - "timelion.help.functions.es.args.intervalHelpText": "**DO NOT USE THIS**.调试拟合函数很有趣,但建议您应使用间隔选择器", - "timelion.help.functions.es.args.kibanaHelpText": "在 Kibana 仪表板上使用筛选。仅当在 Kibana 仪表板上使用时才有效", - "timelion.help.functions.es.args.metricHelpText": "Elasticsearch 指标汇总:avg、sum、min、max、percentiles 或 cardinality,后跟一个字段。例如,“sum:bytes”、“percentiles:bytes:95,99,99.9”,或仅“count”", - "timelion.help.functions.es.args.qHelpText": "采用 lucene 查询字符串语法的查询", - "timelion.help.functions.es.args.splitHelpText": "Elasticsearch 字段用于拆分序列和设置限制。例如,“{hostnameSplitArg}” 用于获取前 10 个主机名", - "timelion.help.functions.es.args.timefieldHelpText": "用于 X 轴的“date”类型的字段", - "timelion.help.functions.esHelpText": "从 Elasticsearch 实例拉取数据", - "timelion.help.functions.firstHelpText": "这是内部函数,只返回输入 seriesList。请勿使用此选项", - "timelion.help.functions.fit.args.modeHelpText": "用于将序列拟合到目标的算法。以下选项之一:{fitFunctions}", - "timelion.help.functions.fitHelpText": "使用已定义的拟合函数填充 null 值", - "timelion.help.functions.graphite.args.metricHelpText": "要拉取的 Graphite 指标,例如 {metricExample}", - "timelion.help.functions.graphiteHelpText": "[实验] 从 Graphite 拉取数据。在 Kibana 的“高级设置”中配置 Graphite 服务器", - "timelion.help.functions.hide.args.hideHelpText": "隐藏或取消隐藏序列", - "timelion.help.functions.hideHelpText": "默认隐藏序列", - "timelion.help.functions.holt.args.alphaHelpText": "\n 平滑权重,0 到 1。\n 增加 alpha 值会使新序列更接近原始序列。\n 降低 alpha 值会使序列更平滑", - "timelion.help.functions.holt.args.betaHelpText": "\n 趋势权重,0 到 1。\n 增加 beta 值会使上升/下降的线条继续上升/下降更长。\n 降低 beta 值会使函数更快地学习新趋势", - "timelion.help.functions.holt.args.gammaHelpText": "季节性权重,0 到 1。您的数据是不是看起来像波形?\n 增加此值会使最近的季节更加重要,从而更快地改变波形。\n 降低此值会使新季节的重要性下降,使历史数据更加重要。", - "timelion.help.functions.holt.args.sampleHelpText": "\n 在季节性序列中开始“预测”前要采样的季节数。\n (仅适用于 gamma,默认值:all)", - "timelion.help.functions.holt.args.seasonHelpText": "季节的时长,例如,如果模式每周重复一次,则为 1w。(仅适用于 gamma)", - "timelion.help.functions.holtHelpText": "\n 对序列开头采样,并通过多个可选参数用它来\n 预测后续事件。通常,此方法不会真正预测未来,\n 而是根据过去的数据预测当前会发生的事件,\n 这对于异常检测很有帮助。注意,将使用预测值填充 null 值。", - "timelion.help.functions.label.args.labelHelpText": "序列的图例值。您可以在字符串中使用 $1、$2 等来匹配正则表达式捕获组", - "timelion.help.functions.label.args.regexHelpText": "支持捕获组的正则表达式", - "timelion.help.functions.labelHelpText": "更改序列标签。使用 %s 引用现有标签", - "timelion.help.functions.legend.args.columnsHelpText": "要将图例划分为的列数", - "timelion.help.functions.legend.args.position.suggestions.falseHelpText": "禁用图例", - "timelion.help.functions.legend.args.position.suggestions.neHelpText": "将图例放在东北角", - "timelion.help.functions.legend.args.position.suggestions.nwHelpText": "将图例放在西北角", - "timelion.help.functions.legend.args.position.suggestions.seHelpText": "将图例放在东南角", - "timelion.help.functions.legend.args.position.suggestions.swHelpText": "将图例放在西南角", - "timelion.help.functions.legend.args.positionHelpText": "放置图例的角:nw、ne、se 或 sw。您还可以传递 false 来禁用图例", - "timelion.help.functions.legend.args.showTimeHelpText": "悬停在图表上方时在图例中显示时间值。默认值:true", - "timelion.help.functions.legend.args.timeFormatHelpText": "moment.js 格式模式。默认值:{defaultTimeFormat}", - "timelion.help.functions.legendHelpText": "设置绘图上图例的位置和样式", - "timelion.help.functions.lines.args.fillHelpText": "介于 0 到 10 之间的数字。用于绘制面积图", - "timelion.help.functions.lines.args.showHelpText": "显示或隐藏线条", - "timelion.help.functions.lines.args.stackHelpText": "堆叠线条,通常会产生误导。如果使用此选项,请至少使用一些填充色。", - "timelion.help.functions.lines.args.stepsHelpText": "以步长显示线条,例如,不在点之间内插", - "timelion.help.functions.lines.args.widthHelpText": "线条粗细", - "timelion.help.functions.linesHelpText": "将 seriesList 显示为线条", - "timelion.help.functions.log.args.baseHelpText": "设置对数底数,默认为 10", - "timelion.help.functions.logHelpText": "返回序列列表中每个值的对数值(默认底数:10)", - "timelion.help.functions.max.args.valueHelpText": "将点设置为较大的值,即现有值或传递的值。如果传递 seriesList,则其必须只包含 1 个序列。", - "timelion.help.functions.maxHelpText": "将 seriesList 中的一个或多个序列的最大值加到输入 seriesList 的每个序列中的每个位置", - "timelion.help.functions.min.args.valueHelpText": "将点设置为较小的值,即现有值或传递的值。如果传递 seriesList,则其必须只包含 1 个序列。", - "timelion.help.functions.minHelpText": "seriesList 中一个或多个序列的最小值加到输入 seriesList 的每个序列中的每个位置", - "timelion.help.functions.movingaverage.args.positionHelpText": "平均点相对于结果时间的位置。以下选项之一:{validPositions}", - "timelion.help.functions.movingaverage.args.windowHelpText": "点数量,或用于求平均值的日期数学表达式(例如,1d、1M)。如果指定了日期数学表达式,函数将尽可能接近当前选择的间隔。如果日期数学表达式不能按间隔均分,结果可能会显示异常。", - "timelion.help.functions.movingaverageHelpText": "计算给定窗口的移动平均值。适合平滑干扰序列", - "timelion.help.functions.movingstd.args.positionHelpText": "窗口切片相对于结果时间的位置。选项为 {positions}。默认值:{defaultPosition}", - "timelion.help.functions.movingstd.args.windowHelpText": "要用于计算标准偏差的点数量。", - "timelion.help.functions.movingstdHelpText": "计算特定窗口的移动标准偏差。使用朴素的扫描两遍算法。对于极长的序列,或数量极大的序列,舍入错误可能会变得更明显。", - "timelion.help.functions.multiply.args.multiplierHelpText": "要乘以的数字或序列。具有多个序列的 seriesList 将按标签方式应用。", - "timelion.help.functions.multiplyHelpText": "将 seriesList 中一个或多个序列的值乘以输入 seriesList 的每个序列中的每个位置", - "timelion.help.functions.points.args.fillColorHelpText": "用于填充点的颜色", - "timelion.help.functions.points.args.fillHelpText": "介于 0 到 10 之间的数字,代表填充的不透明度", - "timelion.help.functions.points.args.radiusHelpText": "点大小", - "timelion.help.functions.points.args.showHelpText": "显示或不显示点", - "timelion.help.functions.points.args.symbolHelpText": "点符号。以下选项之一:{validSymbols}", - "timelion.help.functions.points.args.weightHelpText": "围绕点的线条粗细", - "timelion.help.functions.pointsHelpText": "将序列显示为点", - "timelion.help.functions.precision.args.precisionHelpText": "将每个值舍入到的小数位数", - "timelion.help.functions.precisionHelpText": "将值的小数部分舍入到的小数位数", - "timelion.help.functions.props.args.globalHelpText": "在 seriesList 与每个序列上设置属性", - "timelion.help.functions.propsHelpText": "在序列上可设置任意属性,但请自担风险。例如 {example}", - "timelion.help.functions.quandl.args.codeHelpText": "要绘图的 quandl 代码。可以在 quandl.com 找到这些内容。", - "timelion.help.functions.quandl.args.positionHelpText": "某些 quandl 源会返回多个序列,我该使用哪一个?基于 1 的索引。", - "timelion.help.functions.quandlHelpText": "\n [实验]\n 使用 quandl 代码从 quandl.com 拉取数据。在 Kibana 的“高级设置”中将 {quandlKeyField} 设置为\n 可用 API 密钥。API 在没有密钥的情况下,会有非常低的速率限制。", - "timelion.help.functions.range.args.maxHelpText": "新的最大值", - "timelion.help.functions.range.args.minHelpText": "新的最小值", - "timelion.help.functions.rangeHelpText": "保持形状不变的同时更改序列的最大值和最小值", - "timelion.help.functions.scaleInterval.args.intervalHelpText": "采用日期数学表示法的新间隔,例如,1 秒对应于 1s。1m、5m、1M、1w、1y 等。", - "timelion.help.functions.scaleIntervalHelpText": "更改会将值(通常是求和或计数)缩放到一个新间隔。例如,每秒速率", - "timelion.help.functions.static.args.labelHelpText": "一种快速设置序列标签的方法。您还可以使用 .label() 函数", - "timelion.help.functions.static.args.valueHelpText": "要显示的单个值,您还可以传递多个值,我会将这些值平均内插到您的时间范围内。", - "timelion.help.functions.staticHelpText": "跨图表绘制单个值", - "timelion.help.functions.subtract.args.termHelpText": "要从输入中减去的数字或序列。具有多个序列的 seriesList 将按标签方式应用。", - "timelion.help.functions.subtractHelpText": "将 seriesList 中一个或多个序列的值减去输入 seriesList 的每个序列中的每个位置", - "timelion.help.functions.sum.args.termHelpText": "要与输入序列求和的数字或序列。具有多个序列的 seriesList 将按标签方式应用。", - "timelion.help.functions.sumHelpText": "将 seriesList 中一个或多个序列的值加到输入 seriesList 的每个序列中的每个位置", - "timelion.help.functions.title.args.titleHelpText": "绘图标题。", - "timelion.help.functions.titleHelpText": "在绘图顶部添加一个标题。如果在多个 seriesList 上调用,则将使用最后一个调用。", - "timelion.help.functions.trend.args.endHelpText": "距开头或结尾停止计算的位置。例如,-10 将从距结尾 10 个点的位置停止计算,+15 将在距开头 15 个点的位置停止计算。默认值:0", - "timelion.help.functions.trend.args.modeHelpText": "用于生成趋势线的算法。以下值之一:{validRegressions}", - "timelion.help.functions.trend.args.startHelpText": "距开头或结尾开始计算的位置。例如,-10 将从距结尾 10 个点的位置开始计算,+15 将在距开头 15 个点的位置开始计算。默认值:0", - "timelion.help.functions.trendHelpText": "使用指定回归算法绘制趋势线", - "timelion.help.functions.trim.args.endHelpText": "从序列结尾剪裁的桶。默认值:1", - "timelion.help.functions.trim.args.startHelpText": "从序列开头剪裁的桶。默认值:1", - "timelion.help.functions.trimHelpText": "将序列开头或结尾的 N 个桶设为 null,以拟合“部分桶问题”", - "timelion.help.functions.worldbank.args.codeHelpText": "Worldbank API 路径。这通常是指在域之后、查询字符串之前的所有内容。例如:{apiPathExample}。", - "timelion.help.functions.worldbankHelpText": "\n [实验]\n 使用序列路径从 {worldbankUrl} 拉取数据。\n 世界银行主要提供年度数据,但通常不提供当年数据。\n 如果未获得最近时间范围的任何数据,请尝试使用 {offsetQuery}。", - "timelion.help.functions.worldbankIndicators.args.countryHelpText": "世界银行国家/地区标识符。通常使用国家/地区的两字母代码", - "timelion.help.functions.worldbankIndicators.args.indicatorHelpText": "要使用的指标代码。您必须在 {worldbankUrl} 上查看此代码。通常会比较迟钝。例如,{indicatorExample} 为人口", - "timelion.help.functions.worldbankIndicatorsHelpText": "\n [实验]\n 使用国家/地区名和指标从 {worldbankUrl} 拉取数据。世界银行主要提供\n 年度数据,但通常不提供当年数据。如果未获得最近时间范围的任何数据,请尝试使用 {offsetQuery}\n 。", - "timelion.help.functions.yaxis.args.colorHelpText": "轴标签的颜色", - "timelion.help.functions.yaxis.args.labelHelpText": "轴标签", - "timelion.help.functions.yaxis.args.maxHelpText": "最大值", - "timelion.help.functions.yaxis.args.minHelpText": "最小值", - "timelion.help.functions.yaxis.args.positionHelpText": "左或右", - "timelion.help.functions.yaxis.args.tickDecimalsHelpText": "Y 轴刻度标记的小数位数。", - "timelion.help.functions.yaxis.args.unitsHelpText": "用于设置 Y 轴标签格式的函数。以下选项之一:{formatters}", - "timelion.help.functions.yaxis.args.yaxisHelpText": "用于绘制此序列的带编号的 Y 轴,例如,.yaxis(2) 对应于第 2 个 Y 轴。", - "timelion.help.functions.yaxisHelpText": "配置各种 Y 轴选项,其中最重要的选项可能是添加第 N 个(例如第 2 个)Y 轴的功能", - "timelion.help.mainPage.functionReference.detailsTable.acceptedTypesColumnLabel": "接受的类型", - "timelion.help.mainPage.functionReference.detailsTable.argumentNameColumnLabel": "参数类型", - "timelion.help.mainPage.functionReference.detailsTable.informationColumnLabel": "信息", - "timelion.help.mainPage.functionReference.gettingStartedText": "请单击任何函数以了解更多信息。马上开始使用?", - "timelion.help.mainPage.functionReference.noArgumentsFunctionErrorMessage": "此函数不接受任何参数。嗯,这很简单,不是吗?", - "timelion.help.mainPage.functionReference.welcomePageLinkText": "查看教程", - "timelion.help.mainPage.functionReferenceTitle": "函数引用", - "timelion.help.mainPage.keyboardTips.autoComplete.downArrowDescription": "将焦点切换到自动完成菜单。使用箭头进一步选择词", - "timelion.help.mainPage.keyboardTips.autoComplete.downArrowLabel": "向下箭头", - "timelion.help.mainPage.keyboardTips.autoComplete.enterTabDescription": "选择自动完成菜单中当前选定的词或最顶部的词", - "timelion.help.mainPage.keyboardTips.autoComplete.escDescription": "关闭自动完成菜单", - "timelion.help.mainPage.keyboardTips.autoCompleteTitle": "当自动完成可见时", - "timelion.help.mainPage.keyboardTips.generalEditing.submitRequestText": "提交请求", - "timelion.help.mainPage.keyboardTips.generalEditingTitle": "常规编辑", - "timelion.help.mainPage.keyboardTipsTitle": "键盘提示", - "timelion.help.mainPageTitle": "帮助", - "timelion.help.nextPageButtonLabel": "下一个", - "timelion.help.previousPageButtonLabel": "上一页", - "timelion.help.querying.countMetricAggregationLinkText": "Elasticsearch 指标聚合", - "timelion.help.querying.countTextPart1": "除了具有卓越的事件计数功能,Elasticsearch 数据源还支持任何返回单个值的", - "timelion.help.querying.countTextPart2": "。其中最有用是 {min}、{max}、{avg}、{sum} 和 {cardinality}。假设您需要 {srcIp} 字段的唯一计数。只需使用 {cardinality} 指标:{esCardinalityQuery}。如需获取 {bytes} 字段的平均值,则可以使用 {avg} 指标:{esAvgQuery}。", - "timelion.help.querying.countTitle": "不只是计数", - "timelion.help.querying.esAsteriskQueryDescriptionText": "嗨 Elasticsearch,请在我的默认索引中查找所有内容", - "timelion.help.querying.esIndexQueryDescriptionText": "使用 * 作为 logstash-* 索引的 q (query)", - "timelion.help.querying.luceneQueryLinkText": "Lucene 查询字符串", - "timelion.help.querying.paragraph1": "至此,我们已验证您的 Elasticsearch 数据源工作正常,接下来,可以开始提交查询了。如果是初学者,请在输入栏中输入 {esPattern},然后按 Enter 键。", - "timelion.help.querying.paragraph2Part1": "这个意思是说 {esAsteriskQueryDescription}。如果要查找子集,可以输入 {htmlQuery} 之类的内容以算出与 {html} 匹配的事件个数,或输入 {bobQuery} 来查找在 {user} 字段中包含 {bob} 且 {bytes} 字段大于 100 的事件。注意,此查询需要用单引号引住,因为其包含空格。您可以输入任何", - "timelion.help.querying.paragraph2Part2": "作为 {esQuery} 函数的第一个参数。", - "timelion.help.querying.passingArgumentsText": "Timelion 具有很多快捷键,可以轻松完成各种常见操作。对于不包含空格或特殊字符的简单参数,无需使用引号。而且很多函数都具有默认值。例如,{esEmptyQuery} 和 {esStarQuery} 作用相同。参数也有名称,您无需为其指定特定顺序。例如,可以输入 {esLogstashQuery} 告知 Elasticsearch 数据源 {esIndexQueryDescription}。", - "timelion.help.querying.passingArgumentsTitle": "传递参数", - "timelion.help.queryingTitle": "查询 Elasticsearch 数据源", - "timelion.help.unknownErrorMessage": "未知错误", - "timelion.help.welcome.content.emphasizedEverythingText": "所有内容", - "timelion.help.welcome.content.functionReferenceLinkText": "跳到函数引用", - "timelion.help.welcome.content.paragraph1": "Timelion 是抓取精准、适用于所有内容的可插拔时间序列接口{emphasizedEverything}。如果您的数据存储可以生成时间序列,就能够随意使用 Timelion 的所有强大功能。借助 Timelion,可使用易于掌握的表达式语法,对跨多个数据源的数据集进行比较、合并和整理。尽管本教程主要介绍 Elasticsearch,但您很快会发现,本文所介绍的内容适用于 Timelion 支持的任何数据源。", - "timelion.help.welcome.content.paragraph2": "准备好开始了吗?单击 {strongNext}。想要跳过教程并查看文档?", - "timelion.help.welcome.content.strongNextText": "下一个", - "timelion.help.welcomeTitle": "欢迎来到 {strongTimelionLabel}!", - "timelion.intervals.customIntervalAriaLabel": "定制时间间隔", - "timelion.intervals.selectIntervalAriaLabel": "选择时间间隔", - "timelion.noFunctionErrorMessage": "没有此类函数:{name}", - "timelion.panels.noRenderFunctionErrorMessage": "面板必须具有渲染函数", - "timelion.panels.timechart.unknownIntervalErrorMessage": "时间间隔未知", - "timelion.registerFeatureDescription": "使用表达式语言分析时间序列数据,并将结果可视化。", - "timelion.requestHandlerErrorTitle": "Timelion 请求错误", - "timelion.saveExpression.successNotificationText": "已保存表达式“{title}”", - "timelion.saveSheet.successNotificationText": "已保存工作表“{title}”", - "timelion.search.submitAriaLabel": "搜索", - "timelion.searchErrorTitle": "Timelion 请求错误", - "timelion.serverSideErrors.argumentsOverflowErrorMessage": "太多参数传递到:{functionName}", - "timelion.serverSideErrors.bucketsOverflowErrorMessage": "超过了最大桶数:允许 {bucketCount}/{maxBuckets} 个。选择较大的时间间隔或较短的时间范围", - "timelion.serverSideErrors.colorFunction.colorNotProvidedErrorMessage": "未提供颜色", - "timelion.serverSideErrors.conditionFunction.unknownOperatorErrorMessage": "运算符未知", - "timelion.serverSideErrors.conditionFunction.wrongArgTypeErrorMessage": "必须为数字或 seriesList", - "timelion.serverSideErrors.esFunction.indexNotFoundErrorMessage": "找不到 Elasticsearch 索引:{index}", - "timelion.serverSideErrors.holtFunction.missingParamsErrorMessage": "必须指定季节长度,示例大小 >= 2", - "timelion.serverSideErrors.holtFunction.notEnoughPointsErrorMessage": "您需要至少 2 个点才能使用双指数平滑法", - "timelion.serverSideErrors.movingaverageFunction.notValidPositionErrorMessage": "有效位置为:{validPositions}", - "timelion.serverSideErrors.movingstdFunction.notValidPositionErrorMessage": "有效位置为:{validPositions}", - "timelion.serverSideErrors.pointsFunction.notValidSymbolErrorMessage": "有效符号为:{validSymbols}", - "timelion.serverSideErrors.quandlFunction.unsupportedIntervalErrorMessage": "quandl() 不支持的时间间隔:{interval}。quandl() 支持:{intervals}", - "timelion.serverSideErrors.sheetParseErrorMessage": "应为:字符位置 {column} 的{expectedDescription}", - "timelion.serverSideErrors.unknownArgumentErrorMessage": "{functionName} 的未知参数:{argumentName}", - "timelion.serverSideErrors.unknownArgumentTypeErrorMessage": "不支持的参数类型:{argument}", - "timelion.serverSideErrors.worldbankFunction.noDataErrorMessage": "世界银行请求成功,但 {code} 没有数据", - "timelion.serverSideErrors.wrongFunctionArgumentTypeErrorMessage": "{functionName}({argumentName}) 必须是 {requiredTypes} 之一。得到:{actualType}", - "timelion.serverSideErrors.yaxisFunction.notSupportedUnitTypeErrorMessage": "{units} 为不受支持的单元类型。", - "timelion.serverSideErrors.yaxisFunction.notValidCurrencyFormatErrorMessage": "货币必须使用三个字母的代码", - "timelion.timelionDescription": "使用函数表达式构建时间序列", - "timelion.topNavMenu.addChartButtonAriaLabel": "添加图表", - "timelion.topNavMenu.addChartButtonLabel": "添加", - "timelion.topNavMenu.delete.modal.confirmButtonLabel": "删除", - "timelion.topNavMenu.delete.modal.successNotificationText": "已删除“{title}”", - "timelion.topNavMenu.delete.modal.warningText": "您无法恢复已删除的工作表。", - "timelion.topNavMenu.delete.modalTitle": "是否删除 Timelion 工作表 “{title}”?", - "timelion.topNavMenu.deleteSheetButtonAriaLabel": "删除当前工作表", - "timelion.topNavMenu.deleteSheetButtonLabel": "删除", - "timelion.topNavMenu.helpButtonAriaLabel": "帮助", - "timelion.topNavMenu.helpButtonLabel": "帮助", - "timelion.topNavMenu.newSheetButtonAriaLabel": "新建工作表", - "timelion.topNavMenu.newSheetButtonLabel": "新建", - "timelion.topNavMenu.openSheetButtonAriaLabel": "打开工作表", - "timelion.topNavMenu.openSheetButtonLabel": "打开", - "timelion.topNavMenu.openSheetTitle": "打开工作表", - "timelion.topNavMenu.options.columnsCountLabel": "列(列数必须均分为 12)", - "timelion.topNavMenu.options.rowsCountLabel": "行(这是基于当前窗口高度的目标)", - "timelion.topNavMenu.optionsButtonAriaLabel": "选项", - "timelion.topNavMenu.optionsButtonLabel": "选项", - "timelion.topNavMenu.save.saveAsDashboardPanel.inputPlaceholder": "命名此面板", - "timelion.topNavMenu.save.saveAsDashboardPanel.selectedExpressionLabel": "当前选择的表达式", - "timelion.topNavMenu.save.saveAsDashboardPanel.submitButtonLabel": "保存", - "timelion.topNavMenu.save.saveAsDashboardPanelDescription": "是否需要将图表添加到 Kibana 仪表板?我们可以做到这一点!此选项会将当前选择的表达式另存为一个面板,可像添加任何其他内容一样添加到 Kibana 仪表板。注意,如果使用对其他面板的引用,则需要删除该引用,方法是:将引用的表达式直接复制到要保存的表达式中即可。单击图表可选择要保存的其他表达式。", - "timelion.topNavMenu.save.saveAsDashboardPanelLabel": "将表达式另存为", - "timelion.topNavMenu.save.saveAsDashboardPanelTitle": "将当前表达式另存为 Kibana 仪表板面板", - "timelion.topNavMenu.save.saveEntireSheet.inputAriaLabel": "名称", - "timelion.topNavMenu.save.saveEntireSheet.inputPlaceholder": "命名此工作表......", - "timelion.topNavMenu.save.saveEntireSheet.submitButtonLabel": "保存", - "timelion.topNavMenu.save.saveEntireSheetDescription": "如果您主要在 Timelion 应用中使用 Timelion 表达式,且不需要将 Timelion 图表添加到 Kibana 仪表板,则需要使用此选项。如果您使用对其他面板的引用,可能也需要此选项。", - "timelion.topNavMenu.save.saveEntireSheetLabel": "将工作表另存为", - "timelion.topNavMenu.save.saveEntireSheetTitle": "保存整个 Timelion 工作表", - "timelion.topNavMenu.saveSheetButtonAriaLabel": "保存工作表", - "timelion.topNavMenu.saveSheetButtonLabel": "保存", - "timelion.topNavMenu.sheetOptionsTitle": "工作表选项", - "timelion.topNavMenu.statsDescription": "查询时间 {queryTime}ms /处理时间 {processingTime}ms", - "timelion.uiSettings.defaultColumnsDescription": "默认情况下 Timelion 工作表上的列数目", - "timelion.uiSettings.defaultColumnsLabel": "默认列", - "timelion.uiSettings.defaultIndexDescription": "要使用 {esParam} 搜索的默认 Elasticsearch 索引", - "timelion.uiSettings.defaultIndexLabel": "默认索引", - "timelion.uiSettings.defaultRowsDescription": "默认情况下 Timelion 工作表上的行数目", - "timelion.uiSettings.defaultRowsLabel": "默认行数", - "timelion.uiSettings.experimentalLabel": "实验性", - "timelion.uiSettings.graphiteURLDescription": "{experimentalLabel} Graphite 主机的 URL", - "timelion.uiSettings.graphiteURLLabel": "Graphite URL", - "timelion.uiSettings.maximumBucketsDescription": "单个数据源可以返回的最大存储桶数目", - "timelion.uiSettings.maximumBucketsLabel": "最大存储桶数", - "timelion.uiSettings.minimumIntervalDescription": "使用“自动”时将计算的最小时间间隔", - "timelion.uiSettings.minimumIntervalLabel": "最小时间间隔", - "timelion.uiSettings.quandlKeyDescription": "{experimentalLabel} 来自 www.quandl.com 的 API 密钥", - "timelion.uiSettings.quandlKeyLabel": "Quandl 密钥", - "timelion.uiSettings.showTutorialDescription": "进入 Timelion 应用时我是否应该默认显示教程?", - "timelion.uiSettings.showTutorialLabel": "显示教程", - "timelion.uiSettings.targetBucketsDescription": "使用自动时间间隔时想要的存储桶数目", - "timelion.uiSettings.targetBucketsLabel": "目标存储桶", - "timelion.uiSettings.timeFieldDescription": "使用 {esParam} 时包含时间戳的默认字段", - "timelion.uiSettings.timeFieldLabel": "时间字段", - "timelion.vis.expressionLabel": "Timelion 表达式", - "timelion.vis.intervalLabel": "时间间隔", - "timelion.help.functions.notAllowedGraphiteUrl": "在 kibana.yml 文件中未配置此 Graphite URL。\n 请在 kibana.yml 文件中“timelion.graphiteUrls”下配置 Graphite 服务器列表,并\n 从 Kibana 的高级设置中选择一个", - "timelion.emptyExpressionErrorMessage": "Timelion 错误:未提供表达式", - "core.ui.overlays.banner.attentionTitle": "注意", - "core.ui.overlays.banner.closeButtonLabel": "关闭", - "core.ui.chrome.headerGlobalNav.goHomePageIconAriaLabel": "前往主页", - "core.ui.chrome.headerGlobalNav.helpMenuButtonAriaLabel": "帮助菜单", - "core.ui.chrome.headerGlobalNav.helpMenuTitle": "帮助", - "core.ui.chrome.headerGlobalNav.helpMenuVersion": "v {version}", - "core.ui.chrome.sideGlobalNav.viewRecentItemsFlyoutTitle": "最近项", - "core.ui.chrome.sideGlobalNav.viewRecentItemsLabel": "最近查看", - "core.ui.recentLinks.linkItem.screenReaderLabel": "{recentlyAccessedItemLinklabel},类型:{pageType}", - "core.ui.legacyBrowserMessage": "此 Kibana 安装启用了当前浏览器未满足的严格安全要求。", - "core.ui.legacyBrowserTitle": "请升级您的浏览器", - "core.ui.welcomeErrorMessage": "Kibana 未正确加载。检查服务器输出以了解详情。", - "core.ui.welcomeMessage": "正在加载 Kibana", + "common.ui.visualize.queryGeohashBounds.unableToGetBoundErrorTitle": "无法获取边界", + "console.autocomplete.addMethodMetaText": "方法", + "console.consoleDisplayName": "控制台", + "console.consoleMenu.copyAsCurlMessage": "请求已复制为 cURL", + "console.helpPage.keyboardCommands.autoIndentDescription": "自动缩进当前请求", + "console.helpPage.keyboardCommands.closeAutoCompleteMenuDescription": "关闭自动完成菜单", + "console.helpPage.keyboardCommands.collapseAllScopesDescription": "折叠当前范围除外的所有范围。通过加按 Shift 键来展开。", + "console.helpPage.keyboardCommands.collapseExpandCurrentScopeDescription": "折叠/展开当前范围。", + "console.helpPage.keyboardCommands.jumpToPreviousNextRequestDescription": "跳转至前一/后一请求开头或结尾。", + "console.helpPage.keyboardCommands.openAutoCompleteDescription": "打开自动完成(即使未键入)", + "console.helpPage.keyboardCommands.openDocumentationDescription": "打开当前请求的文档", + "console.helpPage.keyboardCommands.selectCurrentlySelectedInAutoCompleteMenuDescription": "选择自动完成菜单中当前选定的词或最顶部的词", + "console.helpPage.keyboardCommands.submitRequestDescription": "提交请求", + "console.helpPage.keyboardCommands.switchFocusToAutoCompleteMenuDescription": "将焦点切换到自动完成菜单。使用箭头进一步选择词", + "console.helpPage.keyboardCommandsTitle": "键盘命令", + "console.helpPage.pageTitle": "帮助", + "console.helpPage.requestFormatDescription": "您可以在空白编辑器中键入一个或多个请求。Console 理解紧凑格式的请求:", + "console.helpPage.requestFormatTitle": "请求格式", + "console.historyPage.applyHistoryButtonLabel": "应用", + "console.historyPage.clearHistoryButtonLabel": "清除", + "console.historyPage.closehistoryButtonLabel": "鍏抽棴", + "console.historyPage.itemOfRequestListAriaLabel": "请求:{historyItem}", + "console.historyPage.noHistoryTextMessage": "没有可用的历史记录", + "console.historyPage.pageTitle": "历史记录", + "console.historyPage.requestListAriaLabel": "已发送请求的历史记录", + "console.requestOptions.autoIndentButtonLabel": "自动缩进", + "console.requestOptions.copyAsUrlButtonLabel": "复制为 cURL", + "console.requestOptions.openDocumentationButtonLabel": "打开文档", + "console.requestOptionsButtonAriaLabel": "请求选项", + "console.sendRequestButtonTooltip": "单击可发送请求", + "console.settingsPage.autocompleteLabel": "自动完成", + "console.settingsPage.cancelButtonLabel": "取消", + "console.settingsPage.fieldsLabelText": "字段", + "console.settingsPage.fontSizeLabel": "字体大小", + "console.settingsPage.indicesAndAliasesLabelText": "索引和别名", + "console.settingsPage.jsonSyntaxLabel": "JSON 语法", + "console.settingsPage.pageTitle": "设置", + "console.settingsPage.pollingLabelText": "自动刷新自动完成建议", + "console.settingsPage.refreshButtonLabel": "刷新自动完成建议", + "console.settingsPage.refreshingDataDescription": "控制台通过查询 Elasticsearch 来刷新自动完成建议。如果您的集群较大或您的网络有限制,则自动刷新可能会造成问题。", + "console.settingsPage.refreshingDataLabel": "正在刷新自动完成建议", + "console.settingsPage.saveButtonLabel": "保存", + "console.settingsPage.templatesLabelText": "模板", + "console.settingsPage.tripleQuotesMessage": "在输出窗格中使用三重引号", + "console.settingsPage.wrapLongLinesLabelText": "长行换行", + "console.topNav.helpTabDescription": "帮助", + "console.topNav.helpTabLabel": "帮助", + "console.topNav.historyTabDescription": "历史记录", + "console.topNav.historyTabLabel": "历史记录", + "console.topNav.settingsTabDescription": "设置", + "console.topNav.settingsTabLabel": "设置", + "console.welcomePage.closeButtonLabel": "开始工作", + "console.welcomePage.pageTitle": "欢迎使用 Console", + "console.welcomePage.quickIntroDescription": "Console UI 分成两个窗格:编辑器窗格(左)和响应窗格(右)。使用编辑器键入请求并将它们提交到 Elasticsearch。结果将显示在右侧的响应窗格中。", + "console.welcomePage.quickIntroTitle": "UI 简介", + "console.welcomePage.quickTips.cUrlFormatForRequestsDescription": "您可以粘贴 cURL 格式的请求,这些请求将转换成 Console 语法格式。", + "console.welcomePage.quickTips.keyboardShortcutsDescription": "学习“帮助”按钮下的键盘快捷方式。那里有非常实用的信息!", + "console.welcomePage.quickTips.resizeEditorDescription": "您可以通过拖动编辑器和输出窗格之间的分隔条来调整它们的大小。", + "console.welcomePage.quickTips.submitRequestDescription": "使用绿色三角按钮将请求提交到 ES。", + "console.welcomePage.quickTips.useWrenchMenuDescription": "使用扳手菜单执行其他有用的操作。", + "console.welcomePage.quickTipsTitle": "有几个需要您注意的有用提示", + "console.welcomePage.supportedRequestFormatDescription": "键入请求时,控制台将提供建议,您可以通过按 Enter/Tab 键来接受建议。这些建议基于请求结构以及索引和类型进行提供。", + "console.welcomePage.supportedRequestFormatTitle": "Console 理解紧凑格式的请求,类似于 cURL:", + "core.application.appNotFound.pageDescription": "在此 URL 未找到任何应用程序。尝试返回或从菜单中选择应用。", + "core.application.appNotFound.title": "未找到应用程序", "core.chrome.legacyBrowserWarning": "您的浏览器不满足 Kibana 的安全要求。", "core.euiBasicTable.selectAllRows": "选择所有行", "core.euiBasicTable.selectThisRow": "选择此行", @@ -917,8 +643,14 @@ "core.euiStepNumber.hasErrors": "有错误", "core.euiStepNumber.hasWarnings": "有警告", "core.euiStepNumber.isComplete": "已完成", + "core.euiSuperDatePicker.showDatesButtonLabel": "显示日期", "core.euiSuperSelect.screenReaderAnnouncement": "您位于包含 {optionsCount} 个项的表单选择器中,必须选择单个选项。使用向上和向下键导航,使用 Esc 键关闭。", "core.euiSuperSelectControl.selectAnOption": "选择选项:{selectedValue} 已选", + "core.euiSuperUpdateButton.cannotUpdateTooltip": "无法更新", + "core.euiSuperUpdateButton.clickToApplyTooltip": "单击以应用", + "core.euiSuperUpdateButton.refreshButtonLabel": "刷新", + "core.euiSuperUpdateButton.updateButtonLabel": "更新", + "core.euiSuperUpdateButton.updatingButtonLabel": "正在更新", "core.euiTablePagination.rowsPerPage": "每页行数", "core.euiTablePagination.rowsPerPageOption": "{rowsPerPage} 行", "core.euiTableSortMobile.sorting": "排序", @@ -932,141 +664,23 @@ "core.notifications.errorToast.closeModal": "关闭", "core.notifications.unableUpdateUISettingNotificationMessageTitle": "无法更新 UI 设置", "core.toasts.errorToast.seeFullError": "请参阅完整的错误信息", - "core.euiSuperDatePicker.showDatesButtonLabel": "显示日期", - "core.euiSuperUpdateButton.cannotUpdateTooltip": "无法更新", - "core.euiSuperUpdateButton.clickToApplyTooltip": "单击以应用", - "core.euiSuperUpdateButton.refreshButtonLabel": "刷新", - "core.euiSuperUpdateButton.updateButtonLabel": "更新", - "core.euiSuperUpdateButton.updatingButtonLabel": "正在更新", - "core.application.appNotFound.pageDescription": "在此 URL 未找到任何应用程序。尝试返回或从菜单中选择应用。", - "core.application.appNotFound.title": "未找到应用程序", - "kibana-react.exitFullScreenButton.exitFullScreenModeButtonAriaLabel": "退出全屏模式", - "kibana-react.exitFullScreenButton.exitFullScreenModeButtonLabel": "退出全屏", - "kibana-react.exitFullScreenButton.fullScreenModeDescription": "在全屏模式下,按 ESC 键可退出。", - "kibana-react.tableListView.listing.deleteButtonMessage": "删除 {itemCount} 个{entityName}", - "kibana-react.tableListView.listing.deleteConfirmModalDescription": "您无法恢复删除的{entityNamePlural}。", - "kibana-react.tableListView.listing.deleteSelectedItemsConfirmModal.cancelButtonLabel": "取消", - "kibana-react.tableListView.listing.deleteSelectedItemsConfirmModal.confirmButtonLabel": "删除", - "kibana-react.tableListView.listing.deleteSelectedItemsConfirmModal.confirmButtonLabelDeleting": "正在删除", - "kibana-react.tableListView.listing.listingLimitExceeded.advancedSettingsLinkText": "高级设置", - "kibana-react.tableListView.listing.listingLimitExceededDescription": "您有 {totalItems} 个{entityNamePlural},但您的“{listingLimitText}”设置阻止下表显示 {listingLimitValue} 个以上。您可以在“{advancedSettingsLink}”下更改此设置。", - "kibana-react.tableListView.listing.listingLimitExceededTitle": "已超过列表限制", - "kibana-react.tableListView.listing.noAvailableItemsMessage": "没有可用的{entityNamePlural}", - "kibana-react.tableListView.listing.noMatchedItemsMessage": "没有任何{entityNamePlural}匹配您的搜索。", - "kibana-react.tableListView.listing.table.actionTitle": "操作", - "kibana-react.tableListView.listing.table.editActionDescription": "编辑", - "kibana-react.tableListView.listing.table.editActionName": "编辑", - "kibana-react.tableListView.listing.unableToDeleteDangerMessage": "无法删除{entityName}", - "kibana-react.savedObjects.finder.filterButtonLabel": "类型", - "kibana-react.savedObjects.finder.searchPlaceholder": "搜索……", - "kibana-react.savedObjects.finder.sortAsc": "升序", - "kibana-react.savedObjects.finder.sortAuto": "最佳匹配", - "kibana-react.savedObjects.finder.sortButtonLabel": "排序", - "kibana-react.savedObjects.finder.sortDesc": "降序", - "kibana-react.savedObjects.saveModal.cancelButtonLabel": "取消", - "kibana-react.savedObjects.saveModal.descriptionLabel": "描述", - "kibana-react.savedObjects.saveModal.duplicateTitleDescription": "单击“{confirmSaveLabel}”可覆盖现有 {objectType}。", - "kibana-react.savedObjects.saveModal.duplicateTitleLabel": "具有标题“{title}”的 {objectType} 已存在", - "kibana-react.savedObjects.saveModal.saveAsNewLabel": "另存为新的 {objectType}", - "kibana-react.savedObjects.saveModal.saveButtonLabel": "保存", - "kibana-react.savedObjects.saveModal.saveTitle": "保存 {objectType}", - "kibana-react.savedObjects.saveModal.titleLabel": "标题", - "kibana_utils.stateManagement.stateHash.unableToRestoreUrlErrorMessage": "无法完整还原 URL,确保使用共享功能。", - "kibana_utils.stateManagement.stateHash.unableToStoreHistoryInSessionErrorMessage": "Kibana 无法将历史记录项存储在您的会话中,因为其已满,并且似乎没有任何可安全删除的项。\n\n通常可通过移至新的标签页来解决此问题,但这会导致更大的问题。如果您有规律地看到此消息,请在 {gitHubIssuesUrl} 提交问题。", - "inspector.closeButton": "关闭检查器", - "inspector.reqTimestampDescription": "记录请求启动的时间", - "inspector.reqTimestampKey": "请求时间戳", - "inspector.title": "检查器", - "inspector.view": "视图:{viewName}", - "inspector.data.dataDescriptionTooltip": "查看可视化后面的数据", - "inspector.data.dataTitle": "数据", - "inspector.data.downloadCSVButtonLabel": "下载 CSV", - "inspector.data.downloadCSVToggleButtonLabel": "下载 CSV", - "inspector.data.filterForValueButtonAriaLabel": "筛留值", - "inspector.data.filterForValueButtonTooltip": "筛留值", - "inspector.data.filterOutValueButtonAriaLabel": "筛除值", - "inspector.data.filterOutValueButtonTooltip": "筛除值", - "inspector.data.formattedCSVButtonLabel": "格式化 CSV", - "inspector.data.formattedCSVButtonTooltip": "以表格式下载数据", - "inspector.data.gatheringDataLabel": "正在收集数据", - "inspector.data.noDataAvailableDescription": "该元素未提供任何数据。", - "inspector.data.noDataAvailableTitle": "没有可用数据", - "inspector.data.rawCSVButtonLabel": "原始 CSV", - "inspector.data.rawCSVButtonTooltip": "按原样下载数据,例如将日期作为时间戳下载", - "inspector.requests.descriptionRowIconAriaLabel": "描述", - "inspector.requests.failedLabel": " (失败)", - "inspector.requests.noRequestsLoggedDescription.elementHasNotLoggedAnyRequestsText": "该元素尚未记录任何请求。", - "inspector.requests.noRequestsLoggedDescription.whatDoesItUsuallyMeanText": "这通常表示无需提取任何数据,或该元素尚未开始提取数据。", - "inspector.requests.noRequestsLoggedTitle": "未记录任何请求", - "inspector.requests.requestFailedTooltipTitle": "请求失败", - "inspector.requests.requestInProgressAriaLabel": "请求进行中", - "inspector.requests.requestLabel": "请求:", - "inspector.requests.requestsDescriptionTooltip": "查看已收集数据的请求", - "inspector.requests.requestsTitle": "请求", - "inspector.requests.requestSucceededTooltipTitle": "请求成功", - "inspector.requests.requestTabLabel": "请求", - "inspector.requests.requestTimeLabel": "{requestTime}ms", - "inspector.requests.requestTooltipDescription": "请求所花费的总时间。", - "inspector.requests.requestWasMadeDescription": "{requestsCount, plural, one {# 个请求已} other {# 个请求已} }发出{failedRequests}", - "inspector.requests.requestWasMadeDescription.requestHadFailureText": ",{failedCount} 个失败", - "inspector.requests.responseTabLabel": "响应", - "inspector.requests.statisticsTabLabel": "统计信息", - "console.autocomplete.addMethodMetaText": "方法", - "console.consoleDisplayName": "Console", - "console.devToolsDescription": "跳过 cURL 并使用此 JSON 接口来直接处理您的数据。", - "console.devToolsTitle": "Console", - "console.helpPage.keyboardCommands.autoIndentDescription": "自动缩进当前请求", - "console.helpPage.keyboardCommands.closeAutoCompleteMenuDescription": "关闭自动完成菜单", - "console.helpPage.keyboardCommands.collapseAllScopesDescription": "折叠当前范围除外的所有范围。通过加按 Shift 键来展开。", - "console.helpPage.keyboardCommands.collapseExpandCurrentScopeDescription": "折叠/展开当前范围。", - "console.helpPage.keyboardCommands.jumpToPreviousNextRequestDescription": "跳转至前一/后一请求开头或结尾。", - "console.helpPage.keyboardCommands.openAutoCompleteDescription": "打开自动完成(即使未键入)", - "console.helpPage.keyboardCommands.openDocumentationDescription": "打开当前请求的文档", - "console.helpPage.keyboardCommands.selectCurrentlySelectedInAutoCompleteMenuDescription": "选择自动完成菜单中当前选定的词或最顶部的词", - "console.helpPage.keyboardCommands.submitRequestDescription": "提交请求", - "console.helpPage.keyboardCommands.switchFocusToAutoCompleteMenuDescription": "将焦点切换到自动完成菜单。使用箭头进一步选择词", - "console.helpPage.keyboardCommandsTitle": "键盘命令", - "console.helpPage.pageTitle": "帮助", - "console.helpPage.requestFormatDescription": "您可以在空白编辑器中键入一个或多个请求。Console 理解紧凑格式的请求:", - "console.helpPage.requestFormatTitle": "请求格式", - "console.historyPage.applyHistoryButtonLabel": "应用", - "console.historyPage.clearHistoryButtonLabel": "清除", - "console.historyPage.itemOfRequestListAriaLabel": "请求:{historyItem}", - "console.historyPage.noHistoryTextMessage": "没有可用的历史记录", - "console.historyPage.pageTitle": "历史记录", - "console.historyPage.requestListAriaLabel": "已发送请求的历史记录", - "console.requestOptions.autoIndentButtonLabel": "自动缩进", - "console.requestOptions.copyAsUrlButtonLabel": "复制为 cURL", - "console.requestOptions.openDocumentationButtonLabel": "打开文档", - "console.requestOptionsButtonAriaLabel": "请求选项", - "console.sendRequestButtonTooltip": "单击可发送请求", - "console.settingsPage.autocompleteLabel": "自动完成", - "console.settingsPage.cancelButtonLabel": "取消", - "console.settingsPage.fieldsLabelText": "字段", - "console.settingsPage.fontSizeLabel": "字体大小", - "console.settingsPage.indicesAndAliasesLabelText": "索引和别名", - "console.settingsPage.pageTitle": "设置", - "console.settingsPage.saveButtonLabel": "保存", - "console.settingsPage.templatesLabelText": "模板", - "console.settingsPage.wrapLongLinesLabelText": "长行换行", - "console.topNav.helpTabDescription": "帮助", - "console.topNav.helpTabLabel": "帮助", - "console.topNav.historyTabDescription": "历史记录", - "console.topNav.historyTabLabel": "历史记录", - "console.topNav.settingsTabDescription": "设置", - "console.topNav.settingsTabLabel": "设置", - "console.welcomePage.closeButtonLabel": "开始工作", - "console.welcomePage.pageTitle": "欢迎使用 Console", - "console.welcomePage.quickIntroDescription": "Console UI 分成两个窗格:编辑器窗格(左)和响应窗格(右)。使用编辑器键入请求并将它们提交到 Elasticsearch。结果将显示在右侧的响应窗格中。", - "console.welcomePage.quickIntroTitle": "UI 简介", - "console.welcomePage.quickTips.cUrlFormatForRequestsDescription": "您可以粘贴 cURL 格式的请求,这些请求将转换成 Console 语法格式。", - "console.welcomePage.quickTips.keyboardShortcutsDescription": "学习“帮助”按钮下的键盘快捷方式。那里有非常实用的信息!", - "console.welcomePage.quickTips.resizeEditorDescription": "您可以通过拖动编辑器和输出窗格之间的分隔条来调整它们的大小。", - "console.welcomePage.quickTips.submitRequestDescription": "使用绿色三角按钮将请求提交到 ES。", - "console.welcomePage.quickTips.useWrenchMenuDescription": "使用扳手菜单执行其他有用的操作。", - "console.welcomePage.quickTipsTitle": "有几个需要您注意的有用提示", - "console.welcomePage.supportedRequestFormatTitle": "Console 理解紧凑格式的请求,类似于 cURL:", - "console.consoleMenu.copyAsCurlMessage": "请求已复制为 cURL", + "core.ui.chrome.headerGlobalNav.goHomePageIconAriaLabel": "前往主页", + "core.ui.chrome.headerGlobalNav.helpMenuAskElasticTitle": "问询 Elastic", + "core.ui.chrome.headerGlobalNav.helpMenuButtonAriaLabel": "帮助菜单", + "core.ui.chrome.headerGlobalNav.helpMenuGiveFeedbackTitle": "反馈", + "core.ui.chrome.headerGlobalNav.helpMenuKibanaDocumentationTitle": "Kibana 文档", + "core.ui.chrome.headerGlobalNav.helpMenuOpenGitHubIssueTitle": "在 GitHub 中提出问题", + "core.ui.chrome.headerGlobalNav.helpMenuTitle": "帮助", + "core.ui.chrome.headerGlobalNav.helpMenuVersion": "v {version}", + "core.ui.chrome.sideGlobalNav.viewRecentItemsFlyoutTitle": "最近项", + "core.ui.chrome.sideGlobalNav.viewRecentItemsLabel": "最近查看", + "core.ui.overlays.banner.attentionTitle": "注意", + "core.ui.overlays.banner.closeButtonLabel": "关闭", + "core.ui.recentLinks.linkItem.screenReaderLabel": "{recentlyAccessedItemLinklabel},类型:{pageType}", + "dashboardEmbeddableContainer.actions.toggleExpandPanelMenuItem.expandedDisplayName": "最小化", + "dashboardEmbeddableContainer.actions.toggleExpandPanelMenuItem.notExpandedDisplayName": "全屏", + "dashboardEmbeddableContainer.dashboardGrid.toast.unableToLoadDashboardDangerMessage": "无法加载仪表板。", + "dashboardEmbeddableContainer.factory.displayName": "仪表板", "data.filter.applyFilters.popupHeader": "选择要应用的筛选", "data.filter.applyFiltersPopup.cancelButtonLabel": "取消", "data.filter.applyFiltersPopup.saveButtonLabel": "应用", @@ -1081,6 +695,7 @@ "data.filter.filterBar.filterItemBadgeIconAriaLabel": "删除", "data.filter.filterBar.includeFilterButtonLabel": "包括结果", "data.filter.filterBar.indexPatternSelectPlaceholder": "选择索引模式", + "data.filter.filterBar.moreFilterActionsMessage": "筛选:{innerText}。选择以获取更多筛选操作。", "data.filter.filterBar.negatedFilterPrefix": "非 ", "data.filter.filterBar.pinFilterButtonLabel": "在所有应用上固定", "data.filter.filterBar.pinnedFilterPrefix": "已固定", @@ -1105,7 +720,11 @@ "data.filter.filterEditor.isOneOfOperatorOptionLabel": "属于", "data.filter.filterEditor.isOperatorOptionLabel": "是", "data.filter.filterEditor.operatorSelectLabel": "运算符", + "data.filter.filterEditor.operatorSelectPlaceholderSelect": "选择", + "data.filter.filterEditor.operatorSelectPlaceholderWaiting": "正在等候", + "data.filter.filterEditor.queryDslLabel": "Elasticsearch 查询 DSL", "data.filter.filterEditor.rangeEndInputPlaceholder": "范围结束", + "data.filter.filterEditor.rangeInputLabel": "范围", "data.filter.filterEditor.rangeStartInputPlaceholder": "范围开始", "data.filter.filterEditor.saveButtonLabel": "保存", "data.filter.filterEditor.trueOptionLabel": "true", @@ -1127,22 +746,26 @@ "data.indexPatterns.unableWriteLabel": "无法写入索引模式!请刷新页面以获取此索引模式的最新更改。", "data.indexPatterns.unknownFieldErrorMessage": "indexPattern “{title}” 中的字段 “{name}” 使用未知字段类型。", "data.indexPatterns.unknownFieldHeader": "未知字段类型 {type}", + "data.parseEsInterval.invalidEsCalendarIntervalErrorMessage": "无效的日历时间间隔:{interval},值必须为 1", + "data.parseEsInterval.invalidEsIntervalFormatErrorMessage": "时间间隔格式无效:{interval}", + "data.query.queryBar.comboboxAriaLabel": "搜索并筛选 {pageType} 页面", "data.query.queryBar.kqlFullLanguageName": "Kibana 查询语言", "data.query.queryBar.kqlLanguageName": "KQL", "data.query.queryBar.kqlOffLabel": "关闭", "data.query.queryBar.kqlOnLabel": "开启", "data.query.queryBar.luceneLanguageName": "Lucene", "data.query.queryBar.luceneSyntaxWarningMessage": "尽管您选择了 Kibana 查询语言 (KQL),但似乎您正在尝试使用 Lucene 查询语法。请查看 KQL 文档 {link}。", + "data.query.queryBar.luceneSyntaxWarningOptOutText": "不再显示", "data.query.queryBar.luceneSyntaxWarningTitle": "Lucene 语法警告", + "data.query.queryBar.searchInputAriaLabel": "开始键入内容,以搜索并筛选 {pageType} 页面", "data.query.queryBar.searchInputPlaceholder": "搜索", "data.query.queryBar.syntaxOptionsDescription": "{docsLink} (KQL) 提供简化查询语法并支持脚本字段。如果您具有基本许可或更高级别的许可,KQL 还提供自动填充功能。如果关闭 KQL,Kibana 将使用 Lucene。", "data.query.queryBar.syntaxOptionsDescription.docsLinkText": "此处", "data.query.queryBar.syntaxOptionsTitle": "语法选项", - "data.filter.filterEditor.queryDslLabel": "Elasticsearch 查询 DSL", - "data.query.queryBar.luceneSyntaxWarningOptOutText": "不再显示", "data.search.searchBar.savedQueryDescriptionLabelText": "描述", "data.search.searchBar.savedQueryDescriptionText": "保存想要再次使用的查询文本和筛选。", "data.search.searchBar.savedQueryForm.titleConflictText": "标题与现有已保存查询有冲突", + "data.search.searchBar.savedQueryForm.titleMissingText": "“名称”必填", "data.search.searchBar.savedQueryForm.whitespaceErrorText": "标题不能包含前导或尾随空格", "data.search.searchBar.savedQueryFormCancelButtonText": "取消", "data.search.searchBar.savedQueryFormSaveButtonText": "保存", @@ -1159,6 +782,7 @@ "data.search.searchBar.savedQueryPopoverConfirmDeletionConfirmButtonText": "删除", "data.search.searchBar.savedQueryPopoverConfirmDeletionTitle": "删除“{savedQueryName}”?", "data.search.searchBar.savedQueryPopoverDeleteButtonAriaLabel": "删除已保存查询 {savedQueryName}", + "data.search.searchBar.savedQueryPopoverSaveAsNewButtonAriaLabel": "另存为新的已保存查询", "data.search.searchBar.savedQueryPopoverSaveAsNewButtonText": "另存为新的", "data.search.searchBar.savedQueryPopoverSaveButtonAriaLabel": "保存新的已保存查询", "data.search.searchBar.savedQueryPopoverSaveButtonText": "保存当前查询", @@ -1168,60 +792,10 @@ "data.search.searchBar.savedQueryPopoverSavedQueryListItemDescriptionAriaLabel": "{savedQueryName} 描述", "data.search.searchBar.savedQueryPopoverSavedQueryListItemSelectedButtonAriaLabel": "已保存查询按钮已选择 {savedQueryName}。按下可清除任何更改。", "data.search.searchBar.savedQueryPopoverTitleText": "已保存查询", - "data.search.searchSource.fetch.shardsFailedModal.close": "关闭", - "data.search.searchSource.fetch.shardsFailedModal.copyToClipboard": "将响应复制到剪贴板", - "data.search.searchSource.fetch.shardsFailedModal.failureHeader": "{failureDetails} 时为 {failureName}", - "data.search.searchSource.fetch.shardsFailedModal.showDetails": "显示详情", - "data.search.searchSource.fetch.shardsFailedModal.tabHeaderRequest": "请求", - "data.search.searchSource.fetch.shardsFailedModal.tabHeaderResponse": "响应", - "data.search.searchSource.fetch.shardsFailedModal.tabHeaderShardFailures": "分片错误", - "data.search.searchSource.fetch.shardsFailedModal.tableColIndex": "索引", - "data.search.searchSource.fetch.shardsFailedModal.tableColNode": "节点", - "data.search.searchSource.fetch.shardsFailedModal.tableColReason": "原因", - "data.search.searchSource.fetch.shardsFailedModal.tableColShard": "分片", - "data.search.searchSource.fetch.shardsFailedModal.tableRowCollapse": "折叠 {rowDescription}", - "data.search.searchSource.fetch.shardsFailedModal.tableRowExpand": "展开 {rowDescription}", - "data.search.searchSource.fetch.shardsFailedNotificationDescription": "您正在查看的数据可能不完整或有错误。", - "data.search.searchSource.fetch.requestTimedOutNotificationMessage": "由于您的请求超时,因此数据可能不完整", - "data.search.searchSource.fetch.shardsFailedNotificationMessage": "{shardsTotal} 个分片有 {shardsFailed} 个失败", - "data.search.searchSource.hitsDescription": "查询返回的文档数目。", - "data.search.searchSource.hitsLabel": "命中", - "data.search.searchSource.hitsTotalDescription": "匹配查询的文档数目。", - "data.search.searchSource.hitsTotalLabel": "命中(总计)", - "data.search.searchSource.indexPatternDescription": "连接到 Elasticsearch 索引的索引模式。", - "data.search.searchSource.indexPatternIdDescription": "{kibanaIndexPattern} 索引中的 ID。", - "data.search.searchSource.indexPatternIdLabel": "索引模式 ID", - "data.search.searchSource.indexPatternLabel": "索引模式", - "data.search.searchSource.noSearchStrategyRegisteredErrorMessageDescription": "无法为该搜索请求找到搜索策略", - "data.search.searchSource.noSearchStrategyRegisteredErrorMessageTitle": "未注册任何搜索策略", - "data.search.searchSource.queryTimeDescription": "处理查询所花费的时间。不包括发送请求或在浏览器中解析它的时间。", - "data.search.searchSource.queryTimeLabel": "查询时间", - "data.search.searchSource.queryTimeValue": "{queryTime}ms", - "data.search.searchSource.requestTimeDescription": "请求从浏览器到 Elasticsearch 以及返回的时间。不包括请求在队列中等候的时间。", - "data.search.searchSource.requestTimeLabel": "请求时间", - "data.search.searchSource.requestTimeValue": "{requestTime}ms", - "data.filter.filterEditor.operatorSelectPlaceholderSelect": "选择", - "data.filter.filterEditor.operatorSelectPlaceholderWaiting": "正在等候", - "data.filter.filterEditor.rangeInputLabel": "范围", - "data.query.queryBar.comboboxAriaLabel": "搜索并筛选 {pageType} 页面", - "data.search.searchBar.savedQueryForm.titleMissingText": "“名称”必填", - "data.query.queryBar.searchInputAriaLabel": "开始键入内容,以搜索并筛选 {pageType} 页面", - "data.search.searchBar.savedQueryPopoverSaveAsNewButtonAriaLabel": "另存为新的已保存查询", - "data.functions.esaggs.help": "运行 AggConfig 聚合", - "data.functions.esaggs.inspector.dataRequest.description": "此请求将查询 Elasticsearch 以获取用于可视化的数据。", - "data.functions.esaggs.inspector.dataRequest.title": "数据", - "data.common.esQuery.kql.errors.endOfInputText": "输入结束", - "data.common.esQuery.kql.errors.fieldNameText": "字段名称", - "data.common.esQuery.kql.errors.literalText": "文本", - "data.common.esQuery.kql.errors.syntaxError": "应为 {expectedList},但却找到了 {foundInput}。", - "data.common.esQuery.kql.errors.valueText": "值", - "data.common.esQuery.kql.errors.whitespaceText": "空白", - "devTools.badge.readOnly.text": "只读", - "devTools.badge.readOnly.tooltip": "无法保存", - "devTools.k7BreadcrumbsDevToolsLabel": "开发工具", "embeddableApi.actions.applyFilterActionTitle": "将筛选应用于当前视图", "embeddableApi.addPanel.createNewDefaultOption": "创建新的......", "embeddableApi.addPanel.displayName": "添加面板", + "embeddableApi.addPanel.noMatchingObjectsMessage": "未找到任何匹配对象。", "embeddableApi.addPanel.savedObjectAddedToContainerSuccessMessageTitle": "{savedObjectName} 已添加", "embeddableApi.addPanel.Title": "添加面板", "embeddableApi.customizePanel.action.displayName": "定制面板", @@ -1236,16 +810,69 @@ "embeddableApi.customizeTitle.optionsMenuForm.resetCustomDashboardButtonLabel": "重置标题", "embeddableApi.errors.embeddableFactoryNotFound": "{type} 无法加载。请升级到具有适当许可的默认 Elasticsearch 和 Kibana 分发。", "embeddableApi.errors.paneldoesNotExist": "未找到面板", + "embeddableApi.panel.dashboardPanelAriaLabel": "仪表板面板", "embeddableApi.panel.editPanel.displayName": "编辑 {value}", + "embeddableApi.panel.enhancedDashboardPanelAriaLabel": "仪表板面板:{title}", "embeddableApi.panel.inspectPanel.displayName": "检查", "embeddableApi.panel.optionsMenu.panelOptionsButtonAriaLabel": "面板选项", + "embeddableApi.panel.optionsMenu.panelOptionsButtonEnhancedAriaLabel": "{title} 的面板选项", "embeddableApi.panel.removePanel.displayName": "从仪表板删除", "embeddableApi.samples.contactCard.displayName": "联系卡片", "embeddableApi.samples.filterableContainer.displayName": "可筛选仪表板", "embeddableApi.samples.filterableEmbeddable.displayName": "可筛选", - "embeddableApi.panel.enhancedDashboardPanelAriaLabel": "仪表板面板:{title}", - "embeddableApi.panel.optionsMenu.panelOptionsButtonEnhancedAriaLabel": "{title} 的面板选项", - "embeddableApi.panel.dashboardPanelAriaLabel": "仪表板面板", + "esUi.cronEditor.cronDaily.fieldHour.textAtLabel": "在", + "esUi.cronEditor.cronDaily.fieldTimeLabel": "时间", + "esUi.cronEditor.cronDaily.hourSelectLabel": "小时", + "esUi.cronEditor.cronDaily.minuteSelectLabel": "分钟", + "esUi.cronEditor.cronHourly.fieldMinute.textAtLabel": "在", + "esUi.cronEditor.cronHourly.fieldTimeLabel": "分钟", + "esUi.cronEditor.cronMonthly.fieldDateLabel": "日期", + "esUi.cronEditor.cronMonthly.fieldHour.textAtLabel": "在", + "esUi.cronEditor.cronMonthly.fieldTimeLabel": "时间", + "esUi.cronEditor.cronMonthly.hourSelectLabel": "小时", + "esUi.cronEditor.cronMonthly.minuteSelectLabel": "分钟", + "esUi.cronEditor.cronMonthly.textOnTheLabel": "处于", + "esUi.cronEditor.cronWeekly.fieldDateLabel": "天", + "esUi.cronEditor.cronWeekly.fieldHour.textAtLabel": "在", + "esUi.cronEditor.cronWeekly.fieldTimeLabel": "时间", + "esUi.cronEditor.cronWeekly.hourSelectLabel": "小时", + "esUi.cronEditor.cronWeekly.minuteSelectLabel": "分钟", + "esUi.cronEditor.cronWeekly.textOnLabel": "开启", + "esUi.cronEditor.cronYearly.fieldDate.textOnTheLabel": "处于", + "esUi.cronEditor.cronYearly.fieldDateLabel": "日期", + "esUi.cronEditor.cronYearly.fieldHour.textAtLabel": "在", + "esUi.cronEditor.cronYearly.fieldMonth.textInLabel": "于", + "esUi.cronEditor.cronYearly.fieldMonthLabel": "月", + "esUi.cronEditor.cronYearly.fieldTimeLabel": "时间", + "esUi.cronEditor.cronYearly.hourSelectLabel": "小时", + "esUi.cronEditor.cronYearly.minuteSelectLabel": "分钟", + "esUi.cronEditor.day.friday": "星期五", + "esUi.cronEditor.day.monday": "星期一", + "esUi.cronEditor.day.saturday": "星期六", + "esUi.cronEditor.day.sunday": "星期日", + "esUi.cronEditor.day.thursday": "星期四", + "esUi.cronEditor.day.tuesday": "星期二", + "esUi.cronEditor.day.wednesday": "星期三", + "esUi.cronEditor.fieldFrequencyLabel": "频率", + "esUi.cronEditor.month.april": "四月", + "esUi.cronEditor.month.august": "八月", + "esUi.cronEditor.month.december": "十二月", + "esUi.cronEditor.month.february": "二月", + "esUi.cronEditor.month.january": "一月", + "esUi.cronEditor.month.july": "七月", + "esUi.cronEditor.month.june": "六月", + "esUi.cronEditor.month.march": "三月", + "esUi.cronEditor.month.may": "五月", + "esUi.cronEditor.month.november": "十一月", + "esUi.cronEditor.month.october": "十月", + "esUi.cronEditor.month.september": "九月", + "esUi.cronEditor.textEveryLabel": "所有", + "esUi.forms.comboBoxField.placeHolderText": "键入内容然后按“ENTER”键", + "esUi.forms.fieldValidation.indexNameInvalidCharactersError": "索引名称包含无效的{characterListLength, plural, one {字符} other {字符}} { characterList }。", + "esUi.forms.fieldValidation.indexNameSpacesError": "索引名称不能包含空格。", + "esUi.forms.fieldValidation.indexNameStartsWithDotError": "索引名称不能以点 (.) 开头。", + "esUi.forms.fieldValidation.indexPatternInvalidCharactersError": "索引模式包含无效的{characterListLength, plural, one {字符} other {字符}} { characterList }。", + "esUi.forms.fieldValidation.indexPatternSpacesError": "索引模式不能包含空格。", "inputControl.control.noIndexPatternTooltip": "找不到索引模式 ID:{indexPatternId}。", "inputControl.control.notInitializedTooltip": "尚未初始化控件", "inputControl.control.noValuesDisableTooltip": "按 “{fieldName}” 字段进行了筛选,但 “{indexPatternName}” 索引模式的任何文档中都不存在该字段。选择不同的字段或索引包含此字段的值的文档。", @@ -1287,28 +914,55 @@ "inputControl.vis.inputControlVis.applyChangesButtonLabel": "应用更改", "inputControl.vis.inputControlVis.cancelChangesButtonLabel": "取消更改", "inputControl.vis.inputControlVis.clearFormButtonLabel": "清除表单", + "inputControl.vis.listControl.partialResultsWarningMessage": "字词列表可能不完整,因为请求花费的时间过长。在 Kibana.yml 中调整自动完成设置以获取完整的结果。", "inputControl.vis.listControl.selectPlaceholder": "选择......", "inputControl.vis.listControl.selectTextPlaceholder": "选择......", - "inputControl.vis.listControl.partialResultsWarningMessage": "字词列表可能不完整,因为请求花费的时间过长。在 Kibana.yml 中调整自动完成设置以获取完整的结果。", - "visualizations.function.visDimension.accessor.help": "数据集中要使用的列(列索引或列名称)", - "visualizations.function.visDimension.error.accessor": "提供的列名称无效", - "visualizations.function.visDimension.help": "生成 visConfig 维度对象", - "expressions.functions.kibana_context.help": "更新 kibana 全局上下文", - "expressions.functions.kibana.help": "获取 kibana 全局上下文", - "expressions.functions.font.args.alignHelpText": "水平文本对齐。", - "expressions.functions.font.args.colorHelpText": "文本颜色。", - "expressions.functions.font.args.italicHelpText": "使文本变为斜体?", - "expressions.functions.font.args.lHeightHelpText": "行高(像素)", - "expressions.functions.font.args.sizeHelpText": "字体大小(像素)", - "expressions.functions.font.args.underlineHelpText": "为文本加下划线?", - "expressions.functions.font.args.weightHelpText": "字体粗细。例如 {list} 或 {end}。", - "expressions.functions.fontHelpText": "创建字体样式。", + "inspector.closeButton": "关闭检查器", + "inspector.data.dataDescriptionTooltip": "查看可视化后面的数据", + "inspector.data.dataTitle": "数据", + "inspector.data.downloadCSVButtonLabel": "下载 CSV", + "inspector.data.downloadCSVToggleButtonLabel": "下载 CSV", + "inspector.data.filterForValueButtonAriaLabel": "筛留值", + "inspector.data.filterForValueButtonTooltip": "筛留值", + "inspector.data.filterOutValueButtonAriaLabel": "筛除值", + "inspector.data.filterOutValueButtonTooltip": "筛除值", + "inspector.data.formattedCSVButtonLabel": "格式化 CSV", + "inspector.data.formattedCSVButtonTooltip": "以表格式下载数据", + "inspector.data.gatheringDataLabel": "正在收集数据", + "inspector.data.noDataAvailableDescription": "该元素未提供任何数据。", + "inspector.data.noDataAvailableTitle": "没有可用数据", + "inspector.data.rawCSVButtonLabel": "原始 CSV", + "inspector.data.rawCSVButtonTooltip": "按原样下载数据,例如将日期作为时间戳下载", + "inspector.reqTimestampDescription": "记录请求启动的时间", + "inspector.reqTimestampKey": "请求时间戳", + "inspector.requests.descriptionRowIconAriaLabel": "描述", + "inspector.requests.failedLabel": " (失败)", + "inspector.requests.noRequestsLoggedDescription.elementHasNotLoggedAnyRequestsText": "该元素尚未记录任何请求。", + "inspector.requests.noRequestsLoggedDescription.whatDoesItUsuallyMeanText": "这通常表示无需提取任何数据,或该元素尚未开始提取数据。", + "inspector.requests.noRequestsLoggedTitle": "未记录任何请求", + "inspector.requests.requestFailedTooltipTitle": "请求失败", + "inspector.requests.requestInProgressAriaLabel": "请求进行中", + "inspector.requests.requestLabel": "请求:", + "inspector.requests.requestsDescriptionTooltip": "查看已收集数据的请求", + "inspector.requests.requestsTitle": "请求", + "inspector.requests.requestSucceededTooltipTitle": "请求成功", + "inspector.requests.requestTabLabel": "请求", + "inspector.requests.requestTimeLabel": "{requestTime}ms", + "inspector.requests.requestTooltipDescription": "请求所花费的总时间。", + "inspector.requests.requestWasMadeDescription": "{requestsCount, plural, one {# 个请求已} other {# 个请求已} }发出{failedRequests}", + "inspector.requests.requestWasMadeDescription.requestHadFailureText": ",{failedCount} 个失败", + "inspector.requests.responseTabLabel": "响应", + "inspector.requests.statisticsTabLabel": "统计信息", + "inspector.title": "检查器", + "inspector.view": "视图:{viewName}", "kbn.advancedSettings.context.defaultSizeText": "要在上下文视图中显示的周围条目数目", "kbn.advancedSettings.context.defaultSizeTitle": "上下文大小", "kbn.advancedSettings.context.sizeStepText": "递增或递减上下文大小的步进大小", "kbn.advancedSettings.context.sizeStepTitle": "上下文大小步进", "kbn.advancedSettings.context.tieBreakerFieldsText": "要在具有相同时间戳值的文档之间用于平分决胜的字段逗号分隔列表。将使用此列表上存在且在当前索引模式下可排序的第一个字段。", "kbn.advancedSettings.context.tieBreakerFieldsTitle": "平分决胜字段", + "kbn.advancedSettings.courier.batchSearchesText": "禁用时,仪表板面板将分别加载,用户离开时或更新查询时,\n 搜索请求将终止。启用时,仪表板面板将一起加载并加载所有数据,\n 搜索将不会终止。", + "kbn.advancedSettings.courier.batchSearchesTitle": "批处理并发搜索", "kbn.advancedSettings.courier.customRequestPreference.requestPreferenceLinkText": "请求首选项", "kbn.advancedSettings.courier.customRequestPreferenceText": "将 “{setRequestReferenceSetting} 设置为 {customSettingValue} 时,将使用 “{requestPreferenceLink}”。", "kbn.advancedSettings.courier.customRequestPreferenceTitle": "定制请求首选项", @@ -1344,12 +998,17 @@ "kbn.advancedSettings.defaultColumnsTitle": "默认列", "kbn.advancedSettings.defaultIndexText": "未设置索引时要访问的索引", "kbn.advancedSettings.defaultIndexTitle": "默认索引", + "kbn.advancedSettings.defaultRoute.defaultRouteText": "此设置指定打开 Kibana 时的默认路由。您可以使用此设置修改打开 Kibana 时的登陆页面。路由必须以正斜杠(“/”)开头。", + "kbn.advancedSettings.defaultRoute.defaultRouteTitle": "默认路由", + "kbn.advancedSettings.defaultRoute.defaultRouteValidationMessage": "路由必须以正斜杠(“/”)开头", "kbn.advancedSettings.disableAnimationsText": "在 Kibana UI 中关闭所有没有必要的动画。刷新页面以应用更改。", "kbn.advancedSettings.disableAnimationsTitle": "禁用动画", "kbn.advancedSettings.discover.aggsTermsSizeText": "确定在单击“可视化”按钮时将在发现侧边栏的字段下拉列表中可视化多少个词。", "kbn.advancedSettings.discover.aggsTermsSizeTitle": "词数目", "kbn.advancedSettings.discover.sampleSizeText": "要在表中显示的行数目", "kbn.advancedSettings.discover.sampleSizeTitle": "行数目", + "kbn.advancedSettings.discover.searchOnPageLoadText": "控制在 Discover 首次加载时是否执行搜索。加载已保存搜索时,此设置无效。", + "kbn.advancedSettings.discover.searchOnPageLoadTitle": "在页面加载时搜索", "kbn.advancedSettings.discover.sortDefaultOrderText": "在 Discover 应用中控制基于时间的索引模式的默认排序方向。", "kbn.advancedSettings.discover.sortDefaultOrderTitle": "默认排序方向", "kbn.advancedSettings.discover.sortOrderAsc": "升序", @@ -1449,6 +1108,8 @@ "kbn.advancedSettings.visualization.colorMappingTitle": "颜色映射", "kbn.advancedSettings.visualization.dimmingOpacityText": "突出显示图表的其他元素时变暗图表项的透明度。此数字越低,突出显示的元素越突出。必须是介于 0 和 1 之间的数字。", "kbn.advancedSettings.visualization.dimmingOpacityTitle": "变暗透明度", + "kbn.advancedSettings.visualization.heatmap.maxBucketsText": "单个数据源可以返回的最大存储桶数目。较高的数目可能对浏览器呈现性能有负面影响", + "kbn.advancedSettings.visualization.heatmap.maxBucketsTitle": "热图最大存储桶数", "kbn.advancedSettings.visualization.loadingDelayText": "在查询期间在将可视化变暗之前要等待的时间", "kbn.advancedSettings.visualization.loadingDelayTitle": "加载延迟", "kbn.advancedSettings.visualization.showRegionMapWarningsText": "词无法联接到地图上的形状时,区域地图是否显示警告。", @@ -1765,10 +1426,17 @@ "kbn.context.breadcrumb": "{indexPatternTitle}#{docId} 的上下文", "kbn.context.failedToLoadAnchorDocumentDescription": "无法加载该定位点文档", "kbn.context.failedToLoadAnchorDocumentErrorDescription": "无法加载定位点文档。", + "kbn.context.loadButtonLabel": "加载", "kbn.context.loadingDescription": "正在加载……", + "kbn.context.newerDocumentsAriaLabel": "较新文档数目", "kbn.context.newerDocumentsDescription": "较新文档", + "kbn.context.newerDocumentsWarning": "仅可以找到 {docCount} 个比定位标记新的文档。", + "kbn.context.newerDocumentsWarningZero": "找不到比定位标记新的文档。", "kbn.context.noSearchableTiebreakerFieldDescription": "索引模式 {indexPatternId} 中找不到任何可搜索的平分决胜字段。请更改高级设置“{tieBreakerFields}”以包括此索引模式的有效字段。", + "kbn.context.olderDocumentsAriaLabel": "较旧文档数目", "kbn.context.olderDocumentsDescription": "较旧文档", + "kbn.context.olderDocumentsWarning": "仅可以找到 {docCount} 个比定位标记旧的文档。", + "kbn.context.olderDocumentsWarningZero": "找不到比定位标记旧的文档。", "kbn.context.reloadPageDescription.discoverLinkText": "Discover", "kbn.context.reloadPageDescription.reloadOrVisitTextMessage": "请重新加载或访问", "kbn.context.reloadPageDescription.selectValidAnchorDocumentTextMessage": "以选择有效地定位点文档。", @@ -1802,6 +1470,8 @@ "kbn.dashboard.listing.table.entityName": "仪表板", "kbn.dashboard.listing.table.entityNamePlural": "仪表板", "kbn.dashboard.listing.table.titleColumnName": "标题", + "kbn.dashboard.panel.invalidData": "url 中的数据无效", + "kbn.dashboard.panel.unableToMigratePanelDataForSixOneZeroErrorMessage": "无法迁移用于“6.1.0”向后兼容的面板数据,面板不包含所需的列和/或行字段", "kbn.dashboard.panel.unableToMigratePanelDataForSixThreeZeroErrorMessage": "无法迁移用于“6.3.0”向后兼容的面板数据,面板不包含预期字段:{key}", "kbn.dashboard.savedDashboard.newDashboardTitle": "新建仪表板", "kbn.dashboard.savedDashboardsTitle": "仪表板", @@ -1851,25 +1521,6 @@ "kbn.discover.discoverDescription": "通过查询和筛选原始文档来以交互方式浏览您的数据。", "kbn.discover.discoverTitle": "Discover", "kbn.discover.documentsAriaLabel": "文档", - "kbn.discover.docViews.table.fieldNamesBeginningWithUnderscoreUnsupportedTooltip": "不支持以 {underscoreSign} 开头的字段名称", - "kbn.discover.docViews.table.filterForFieldPresentButtonAriaLabel": "筛留存在的字段", - "kbn.discover.docViews.table.filterForFieldPresentButtonTooltip": "筛留存在的字段", - "kbn.discover.docViews.table.filterForValueButtonAriaLabel": "筛留值", - "kbn.discover.docViews.table.filterForValueButtonTooltip": "筛留值", - "kbn.discover.docViews.table.filterOutValueButtonAriaLabel": "筛除值", - "kbn.discover.docViews.table.filterOutValueButtonTooltip": "筛除值", - "kbn.discover.docViews.table.noCachedMappingForThisFieldTooltip": "此字段没有任何已缓存映射。从“管理”>“索引模式”页面刷新字段列表", - "kbn.discover.docViews.table.tableTitle": "表", - "kbn.discover.docViews.table.toggleColumnInTableButtonAriaLabel": "在表中切换列", - "kbn.discover.docViews.table.toggleColumnInTableButtonTooltip": "在表中切换列", - "kbn.discover.docViews.table.unableToFilterForPresenceOfMetaFieldsTooltip": "无法筛留元数据字段", - "kbn.discover.docViews.table.unableToFilterForPresenceOfScriptedFieldsTooltip": "无法筛留脚本字段", - "kbn.discover.docViews.table.unindexedFieldsCanNotBeSearchedTooltip": "无法搜索未索引字段", - "kbn.discover.docViews.json.codeEditorAriaLabel": "Elasticsearch 文档的只读 JSON 视图", - "kbn.discover.docViews.json.jsonTitle": "JSON", - "kbn.discover.docViews.table.fieldNamesBeginningWithUnderscoreUnsupportedAriaLabel": "警告", - "kbn.discover.docViews.table.noCachedMappingForThisFieldAriaLabel": "警告", - "kbn.discover.docViews.table.toggleFieldDetails": "切换字段详细信息", "kbn.discover.errorLoadingData": "加载数据时出错", "kbn.discover.fetchError.howToAddressErrorDescription": "您可以通过编辑 “{scriptedFields}” 选项卡下 “{managementLink}” 中的 “{fetchErrorScript}” 字段来解决此错误。", "kbn.discover.fetchError.managmentLinkText": "管理 > 索引模式", @@ -1889,6 +1540,7 @@ "kbn.discover.fieldChooser.fieldCalculator.analysisIsNotAvailableForGeoFieldsErrorMessage": "分析不适用于地理字段。", "kbn.discover.fieldChooser.fieldCalculator.analysisIsNotAvailableForObjectFieldsErrorMessage": "分析不适用于对象字段。", "kbn.discover.fieldChooser.fieldCalculator.fieldIsNotPresentInDocumentsErrorMessage": "此字段在您的 Elasticsearch 映射中,但不在文档表中显示的 {hitsLength} 个文档中。您可能仍能够基于其进行可视化或搜索。", + "kbn.discover.fieldChooser.fieldFilterFacetButtonLabel": "已筛选字段", "kbn.discover.fieldChooser.filter.aggregatableLabel": "可聚合", "kbn.discover.fieldChooser.filter.availableFieldsTitle": "可用字段", "kbn.discover.fieldChooser.filter.hideMissingFieldsLabel": "隐藏缺失字段", @@ -1897,8 +1549,10 @@ "kbn.discover.fieldChooser.filter.searchableLabel": "可搜索", "kbn.discover.fieldChooser.filter.selectedFieldsTitle": "选定字段", "kbn.discover.fieldChooser.filter.typeLabel": "类型", + "kbn.discover.fieldChooser.searchPlaceHolder": "搜索字段", "kbn.discover.fieldChooser.toggleFieldFilterButtonHideAriaLabel": "隐藏字段设置", "kbn.discover.fieldChooser.toggleFieldFilterButtonShowAriaLabel": "显示字段设置", + "kbn.discover.histogram.partialData.bucketTooltipText": "选定的时间范围不包括此整个存储桶,其可能包含部分数据。", "kbn.discover.histogramOfFoundDocumentsAriaLabel": "已找到文档的直方图", "kbn.discover.hitsPluralTitle": "{hits, plural, one {次命中} other {次命中}}", "kbn.discover.howToChangeTheTimeTooltip": "要更改时间,请单击导航栏中的日历图标", @@ -1911,6 +1565,7 @@ "kbn.discover.localMenu.openInspectorForSearchDescription": "打开 Inspector 以进行搜索", "kbn.discover.localMenu.openSavedSearchDescription": "打开保存的搜索", "kbn.discover.localMenu.openTitle": "打开", + "kbn.discover.localMenu.saveSaveSearchDescription": "保存您的 Discover 搜索,以便可以在可视化和仪表板中使用该搜索", "kbn.discover.localMenu.saveSearchDescription": "保存搜索", "kbn.discover.localMenu.saveTitle": "保存", "kbn.discover.localMenu.shareSearchDescription": "共享搜索", @@ -1934,6 +1589,7 @@ "kbn.discover.notifications.notSavedSearchTitle": "搜索 “{savedSearchTitle}” 未保存。", "kbn.discover.notifications.savedSearchTitle": "搜索 “{savedSearchTitle}” 已保存", "kbn.discover.painlessError.painlessScriptedFieldErrorMessage": "Painless 脚本字段 “{script}” 有错误。", + "kbn.discover.reloadSavedSearchButton": "重置搜索", "kbn.discover.rootBreadcrumb": "Discover", "kbn.discover.savedSearch.savedObjectName": "已保存搜索", "kbn.discover.scaledToDescription": "已缩放至 {bucketIntervalDescription}", @@ -1944,13 +1600,21 @@ "kbn.discover.topNav.openSearchPanel.manageSearchesButtonLabel": "管理搜索", "kbn.discover.topNav.openSearchPanel.noSearchesFoundDescription": "未找到匹配的搜索。", "kbn.discover.topNav.openSearchPanel.openSearchTitle": "打开搜索", + "kbn.discover.uninitializedRefreshButtonText": "刷新数据", + "kbn.discover.uninitializedText": "编写查询,添加一些筛选,或只需单击“刷新”来检索当前查询的结果。", + "kbn.discover.uninitializedTitle": "开始搜索", "kbn.discover.valueIsNotConfiguredIndexPatternIDWarningTitle": "{stateVal} 不是配置的索引模式 ID", "kbn.discoverTitle": "Discover", + "kbn.doc.couldNotFindDocumentsDescription": "无文档匹配该 ID。", "kbn.doc.failedToExecuteQueryDescription": "无法执行查询", "kbn.doc.failedToLocateDocumentDescription": "无法找到文档", + "kbn.doc.failedToLocateIndexPattern": "无索引模式匹配 ID {indexPatternId}", "kbn.doc.loadingDescription": "正在加载……", + "kbn.doc.somethingWentWrongDescription": "{indexName} 缺失。", + "kbn.doc.somethingWentWrongDescriptionAddon": "请确保索引存在。", "kbn.docTable.limitedSearchResultLabel": "仅限 {resultCount} 个结果。优化您的搜索。", "kbn.docTable.noResultsTitle": "找不到结果", + "kbn.docTable.pagerControl.pagesCountLabel": "{startItem}–{endItem} / {totalItems}", "kbn.docTable.tableHeader.moveColumnLeftButtonAriaLabel": "向左移动“{columnName}”列", "kbn.docTable.tableHeader.moveColumnLeftButtonTooltip": "向左移动列", "kbn.docTable.tableHeader.moveColumnRightButtonAriaLabel": "向右移动“{columnName}”列", @@ -1959,6 +1623,7 @@ "kbn.docTable.tableHeader.removeColumnButtonTooltip": "删除列", "kbn.docTable.tableHeader.sortByColumnAscendingAriaLabel": "升序排序 {columnName}", "kbn.docTable.tableHeader.sortByColumnDescendingAriaLabel": "降序排序 {columnName}", + "kbn.docTable.tableHeader.sortByColumnUnsortedAriaLabel": "停止按 {columnName} 排序", "kbn.docTable.tableRow.detailHeading": "已展开文档", "kbn.docTable.tableRow.filterForValueButtonAriaLabel": "筛留值", "kbn.docTable.tableRow.filterForValueButtonTooltip": "筛留值", @@ -1970,6 +1635,8 @@ "kbn.embeddable.errorTitle": "提取数据时出错", "kbn.embeddable.inspectorRequestDataTitle": "数据", "kbn.embeddable.inspectorRequestDescription": "此请求将查询 Elasticsearch 以获取搜索的数据。", + "kbn.embeddable.search.displayName": "搜索", + "kbn.embeddable.visualizations.displayName": "可视化", "kbn.home.addData.addDataToKibanaDescription": "使用这些解决方案可快速将您的数据转换成预建仪表板和监测系统。", "kbn.home.addData.addDataToKibanaTitle": "将数据添加到 Kibana", "kbn.home.addData.apm.addApmButtonLabel": "添加 APM", @@ -1983,12 +1650,21 @@ "kbn.home.addData.metrics.nameTitle": "指标", "kbn.home.addData.sampleDataLink": "加载数据集和 Kibana 仪表板", "kbn.home.addData.sampleDataTitle": "添加样例数据", + "kbn.home.addData.siem.addSiemEventsButtonLabel": "添加安全事件", + "kbn.home.addData.siem.nameDescription": "集中安全事件,以通过即用型可视化实现交互式调查。", + "kbn.home.addData.siem.nameTitle": "SIEM", "kbn.home.addData.uploadFileLink": "导入 CSV、NDJSON 或日志文件", "kbn.home.addData.uploadFileTitle": "从日志文件上传数据", "kbn.home.addData.yourDataLink": "连接到您的 Elasticsearch 索引", "kbn.home.addData.yourDataTitle": "使用 Elasticsearch 数据", "kbn.home.breadcrumbs.addDataTitle": "添加数据", "kbn.home.breadcrumbs.homeTitle": "主页", + "kbn.home.dataManagementDisableCollection": "要停止收集,", + "kbn.home.dataManagementDisableCollectionLink": "请在此禁用使用情况数据。", + "kbn.home.dataManagementDisclaimerPrivacy": "要了解使用情况数据如何帮助我们管理和改善产品和服务,请参阅我们的 ", + "kbn.home.dataManagementDisclaimerPrivacyLink": "隐私声明。", + "kbn.home.dataManagementEnableCollection": " 要启动收集,", + "kbn.home.dataManagementEnableCollectionLink": "请在此处启用使用情况数据。", "kbn.home.directories.manage.nameTitle": "管理 Elastic Stack", "kbn.home.directories.notFound.description": "未找到要寻找的内容?", "kbn.home.directories.notFound.viewFullButtonLabel": "查看 Kibana 插件的完整目录", @@ -2053,9 +1729,11 @@ "kbn.home.tutorial.tabs.loggingTitle": "日志", "kbn.home.tutorial.tabs.metricsTitle": "指标", "kbn.home.tutorial.tabs.sampleDataTitle": "样例数据", + "kbn.home.tutorial.tabs.siemTitle": "SIEM", "kbn.home.tutorial.unexpectedStatusCheckStateErrorDescription": "意外的状态检查状态 {statusCheckState}", "kbn.home.tutorial.unhandledInstructionTypeErrorDescription": "未处理的指令类型 {visibleInstructions}", "kbn.home.welcomeDescription": "您了解 Elastic Stack 的窗口", + "kbn.home.welcomeHomePageHeader": "Kibana 主页", "kbn.home.welcomeTitle": "欢迎使用 Kibana", "kbn.management.advancedSettings.badge.readOnly.text": "只读", "kbn.management.advancedSettings.badge.readOnly.tooltip": "无法保存高级设置", @@ -2243,6 +1921,7 @@ "kbn.management.objects.objectsTable.deleteSavedObjectsConfirmModalTitle": "删除已保存对象", "kbn.management.objects.objectsTable.export.dangerNotification": "无法生成报告", "kbn.management.objects.objectsTable.export.successNotification": "您的文件正在后台下载", + "kbn.management.objects.objectsTable.export.successWithMissingRefsNotification": "您的文件正在后台下载。找不到某些相关对象。有关缺失对象列表,请查看导出文件的最后一行。", "kbn.management.objects.objectsTable.exportObjectsConfirmModal.cancelButtonLabel": "取消", "kbn.management.objects.objectsTable.exportObjectsConfirmModal.exportAllButtonLabel": "全部导出", "kbn.management.objects.objectsTable.exportObjectsConfirmModal.exportOptionsLabel": "选项", @@ -2356,8 +2035,9 @@ "kbn.management.settings.categoryNames.discoverLabel": "Discover", "kbn.management.settings.categoryNames.generalLabel": "常规", "kbn.management.settings.categoryNames.notificationsLabel": "通知", - "kbn.management.settings.categoryNames.reportingLabel": "Reporting", + "kbn.management.settings.categoryNames.reportingLabel": "报告", "kbn.management.settings.categoryNames.searchLabel": "搜索", + "kbn.management.settings.categoryNames.siemLabel": "SIEM", "kbn.management.settings.categoryNames.timelionLabel": "Timelion", "kbn.management.settings.categoryNames.visualizationsLabel": "可视化", "kbn.management.settings.categorySearchLabel": "类别", @@ -2372,6 +2052,7 @@ "kbn.management.settings.field.defaultValueTypeJsonText": "默认值:{value}", "kbn.management.settings.field.helpText": "此设置将由 Kibana 覆盖,无法更改。", "kbn.management.settings.field.imageChangeErrorMessage": "图片无法保存", + "kbn.management.settings.field.imageTooLargeErrorMessage": "图像过大,最大大小为 {maxSizeDescription}", "kbn.management.settings.field.offLabel": "关闭", "kbn.management.settings.field.onLabel": "开启", "kbn.management.settings.field.requiresPageReloadToastButtonLabel": "重新加载页面", @@ -2431,12 +2112,14 @@ "kbn.server.tutorials.apm.dotNetClient.configureApplication.textPost": "传递 `IConfiguration` 实例为可选操作,通过此操作,代理将通过此`IConfiguration` 实例 读取配置设置(例如,从 `appsettings.json` 文件)。", "kbn.server.tutorials.apm.dotNetClient.configureApplication.textPre": "对于具有 `Elastic.Apm.NetCoreAll` 软件包的 ASP.NET Core,请在 `Startup.cs` 文件内的 `Configure` 方法中调用 `UseAllElasticApm`。", "kbn.server.tutorials.apm.dotNetClient.configureApplication.title": "将代理添加到应用程序", + "kbn.server.tutorials.apm.dotNetClient.download.textPre": "将代理软件包从 [NuGet]({allNuGetPackagesLink}) 添加到 .NET 应用程序。有多个 NuGet 软件包可用于不同的用例。\n\n对于具有 Entity Framework Core 的 ASP.NET Core 应用程序,请下载 [Elastic.Apm.NetCoreAll]({netCoreAllApmPackageLink}) 软件包。此软件包将自动将每个 代理组件添加到您的应用程序。\n\n 如果您希望最大程度减少依存关系,您可以将 [Elastic.Apm.AspNetCore]({aspNetCorePackageLink}) 软件包仅用于 ASP.NET Core 监测,或将 [Elastic.Apm.EfCore]({efCorePackageLink}) 软件包仅用于 Entity Framework Core 监测。\n\n 如果仅希望将公共代理 API 用于手动检测,请使用 [Elastic.Apm]({elasticApmPackageLink}) 软件包。", "kbn.server.tutorials.apm.dotNetClient.download.title": "下载 APM 代理", "kbn.server.tutorials.apm.downloadServer.title": "下载并解压缩 APM Server", "kbn.server.tutorials.apm.downloadServerRpm": "寻找 32 位软件包?请参阅[下载页面]({downloadPageLink})。", "kbn.server.tutorials.apm.downloadServerTitle": "寻找 32 位软件包?请参阅[下载页面]({downloadPageLink})。", "kbn.server.tutorials.apm.editConfig.textPre": "如果您正在使用 Elastic Stack 的 X-Pack 安全版本,则必须在 `apm-server.yml` 配置文件中指定凭据。", "kbn.server.tutorials.apm.editConfig.title": "编辑配置", + "kbn.server.tutorials.apm.elasticCloud.textPre": "要启用 APM Server,请前往 [Elastic Cloud 控制台](https://cloud.elastic.co/deployments?q={cloudId}) 并在部署设置中启用 APM。启用后,请刷新此页面。", "kbn.server.tutorials.apm.elasticCloudInstructions.title": "APM 代理", "kbn.server.tutorials.apm.flaskClient.configure.commands.allowedCharactersComment": "a-z、A-Z、0-9、-、_ 以及空格", "kbn.server.tutorials.apm.flaskClient.configure.commands.configureElasticApmComment": "或进行配置以在您的应用程序设置中使用 ELASTIC_APM", @@ -2468,9 +2151,6 @@ "kbn.server.tutorials.apm.javaClient.startApplication.textPost": "有关配置选项和高级用法,请参阅[文档]({documentationLink})。", "kbn.server.tutorials.apm.javaClient.startApplication.textPre": "添加 `-javaagent` 标志并使用系统属性配置代理。\n\n * 设置所需的服务名称(允许使用的字符:a-z、A-Z、0-9、-、_ 和空格)\n * 设置定制 APM Server URL(默认值:{customApmServerUrl})\n * 设置您的应用程序的基础软件包", "kbn.server.tutorials.apm.javaClient.startApplication.title": "使用 javaagent 标志设置您的应用程序", - "kbn.server.tutorials.apm.jsClient.installDependency.commands.setCustomApmServerUrlComment": "设置定制 APM Server URL(默认值:{defaultApmServerUrl})", - "kbn.server.tutorials.apm.jsClient.installDependency.commands.setRequiredServiceNameComment": "设置所需的服务名称(允许使用的字符:a-z、A-Z、0-9、-、_ 和空格)", - "kbn.server.tutorials.apm.jsClient.installDependency.commands.setServiceVersionComment": "设置服务版本(源地图功能要求)", "kbn.server.tutorials.apm.jsClient.enableRealUserMonitoring.textPre": "请参阅[文档]({documentationLink})。", "kbn.server.tutorials.apm.jsClient.enableRealUserMonitoring.title": "在 APM 服务器中启用真实用户 Monitoring 支持", "kbn.server.tutorials.apm.nodeClient.configure.commands.addThisToTheFileTopComment": "将其添加到您的应用中加载的第一个文件的上面", @@ -2541,6 +2221,10 @@ "kbn.server.tutorials.couchbaseMetrics.longDescription": "Metricbeat 模块 `couchbase` 从 Couchbase 提取内部指标。[了解详情]({learnMoreLink})。", "kbn.server.tutorials.couchbaseMetrics.nameTitle": "Couchbase 指标", "kbn.server.tutorials.couchbaseMetrics.shortDescription": "从 Couchbase 提取内部指标。", + "kbn.server.tutorials.couchdbMetrics.artifacts.dashboards.linkLabel": "CouchDB 指标仪表板", + "kbn.server.tutorials.couchdbMetrics.longDescription": "`couchdb` Metricbeat 模块从 CouchDB 提取监测指标。[了解详情]({learnMoreLink})。", + "kbn.server.tutorials.couchdbMetrics.nameTitle": "CouchDB 指标", + "kbn.server.tutorials.couchdbMetrics.shortDescription": "从 CouchdB 服务器提取监测指标。", "kbn.server.tutorials.dockerMetrics.artifacts.dashboards.linkLabel": "Docker 指标仪表板", "kbn.server.tutorials.dockerMetrics.longDescription": "Metricbeat 模块 `docker` 从 Docker 服务器提取指标。[了解详情]({learnMoreLink})。", "kbn.server.tutorials.dockerMetrics.nameTitle": "Docker 指标", @@ -2763,6 +2447,8 @@ "kbn.visualize.linkedToSearch.unlinkButtonTooltip": "双击可取消与“已保存搜索”的链接", "kbn.visualize.linkedToSearch.unlinkSuccessNotificationText": "取消与已保存搜索 “{searchTitle}” 的链接", "kbn.visualize.linkedToSearchInfoText": "链接到“已保存搜索”", + "kbn.visualize.listing.betaTitle": "公测版", + "kbn.visualize.listing.betaTooltip": "此可视化为公测版,可能会进行更改。设计和代码相对于正式发行版功能还不够成熟,将按原样提供,且不提供任何保证。公测版功能不受正式发行版功能支持 SLA 的约束", "kbn.visualize.listing.breadcrumb": "可视化", "kbn.visualize.listing.createNew.createButtonLabel": "新建可视化", "kbn.visualize.listing.createNew.description": "可以根据您的数据创建不同的可视化。", @@ -2775,6 +2461,8 @@ "kbn.visualize.listing.table.listTitle": "可视化", "kbn.visualize.listing.table.titleColumnName": "标题", "kbn.visualize.listing.table.typeColumnName": "类型", + "kbn.visualize.newVisWizard.betaDescription": "此可视化为公测版,可能会进行更改。设计和代码相对于正式发行版功能还不够成熟,将按原样提供,且不提供任何保证。公测版功能不受正式发行版功能支持 SLA 的约束", + "kbn.visualize.newVisWizard.betaTitle": "公测版", "kbn.visualize.newVisWizard.chooseSourceTitle": "选择源", "kbn.visualize.newVisWizard.experimentalDescription": "这是实验性可视化。与稳定的可视化相比,其设计和实现均不够成熟,可能会随时发生更改。", "kbn.visualize.newVisWizard.experimentalTitle": "实验性", @@ -2789,6 +2477,9 @@ "kbn.visualize.newVisWizard.searchSelection.savedObjectType.search": "已保存搜索", "kbn.visualize.newVisWizard.selectVisType": "选择可视化类型", "kbn.visualize.newVisWizard.title": "新建可视化", + "kbn.visualize.newVisWizard.visTypeAliasDescription": "打开 Visualize 外部的 Kibana 应用程序。", + "kbn.visualize.newVisWizard.visTypeAliasTitle": "Kibana 应用程序", + "kbn.visualize.pageHeading": "{chartName} {chartType}可视化", "kbn.visualize.saveDialog.saveAndAddToDashboardButtonLabel": "保存并添加到仪表板", "kbn.visualize.savedObjectName": "可视化", "kbn.visualize.topNavMenu.openInspectorButtonAriaLabel": "打开检查器查看可视化", @@ -2805,80 +2496,68 @@ "kbn.visualize.wizard.step1Breadcrumb": "创建", "kbn.visualize.wizard.step2Breadcrumb": "创建", "kbn.visualizeTitle": "可视化", - "kbn.advancedSettings.discover.searchOnPageLoadText": "控制在 Discover 首次加载时是否执行搜索。加载已保存搜索时,此设置无效。", - "kbn.advancedSettings.discover.searchOnPageLoadTitle": "在页面加载时搜索", - "kbn.advancedSettings.visualization.heatmap.maxBucketsText": "单个数据源可以返回的最大存储桶数目。较高的数目可能对浏览器呈现性能有负面影响", - "kbn.advancedSettings.visualization.heatmap.maxBucketsTitle": "热图最大存储桶数", - "kbn.discover.localMenu.saveSaveSearchDescription": "保存您的 Discover 搜索,以便可以在可视化和仪表板中使用该搜索", - "kbn.discover.uninitializedRefreshButtonText": "刷新数据", - "kbn.discover.uninitializedText": "编写查询,添加一些筛选,或只需单击“刷新”来检索当前查询的结果。", - "kbn.discover.uninitializedTitle": "开始搜索", - "kbn.docTable.tableHeader.sortByColumnUnsortedAriaLabel": "停止按 {columnName} 排序", - "kbn.embeddable.search.displayName": "搜索", - "kbn.embeddable.visualizations.displayName": "可视化", - "kbn.home.addData.siem.addSiemEventsButtonLabel": "添加安全事件", - "kbn.home.addData.siem.nameDescription": "集中安全事件,以通过即用型可视化实现交互式调查。", - "kbn.home.addData.siem.nameTitle": "SIEM", - "kbn.home.tutorial.tabs.siemTitle": "SIEM", - "kbn.home.welcomeHomePageHeader": "Kibana 主页", - "kbn.discover.reloadSavedSearchButton": "重置搜索", - "kbn.server.tutorials.apm.dotNetClient.download.textPre": "将代理软件包从 [NuGet]({allNuGetPackagesLink}) 添加到 .NET 应用程序。有多个 NuGet 软件包可用于不同的用例。\n\n对于具有 Entity Framework Core 的 ASP.NET Core 应用程序,请下载 [Elastic.Apm.NetCoreAll]({netCoreAllApmPackageLink}) 软件包。此软件包将自动将每个 代理组件添加到您的应用程序。\n\n 如果您希望最大程度减少依存关系,您可以将 [Elastic.Apm.AspNetCore]({aspNetCorePackageLink}) 软件包仅用于 ASP.NET Core 监测,或将 [Elastic.Apm.EfCore]({efCorePackageLink}) 软件包仅用于 Entity Framework Core 监测。\n\n 如果仅希望将公共代理 API 用于手动检测,请使用 [Elastic.Apm]({elasticApmPackageLink}) 软件包。", - "kbn.server.tutorials.apm.elasticCloud.textPre": "要启用 APM Server,请前往 [Elastic Cloud 控制台](https://cloud.elastic.co/deployments?q={cloudId}) 并在部署设置中启用 APM。启用后,请刷新此页面。", - "kbn.advancedSettings.defaultRoute.defaultRouteText": "此设置指定打开 Kibana 时的默认路由。您可以使用此设置修改打开 Kibana 时的登陆页面。路由必须以正斜杠(“/”)开头。", - "kbn.advancedSettings.defaultRoute.defaultRouteTitle": "默认路由", - "kbn.advancedSettings.defaultRoute.defaultRouteValidationMessage": "路由必须以正斜杠(“/”)开头", - "kbn.context.loadButtonLabel": "加载", - "kbn.context.newerDocumentsAriaLabel": "较新文档数目", - "kbn.context.newerDocumentsWarning": "仅可以找到 {docCount} 个比定位标记新的文档。", - "kbn.context.newerDocumentsWarningZero": "找不到比定位标记新的文档。", - "kbn.context.olderDocumentsAriaLabel": "较旧文档数目", - "kbn.context.olderDocumentsWarning": "仅可以找到 {docCount} 个比定位标记旧的文档。", - "kbn.context.olderDocumentsWarningZero": "找不到比定位标记旧的文档。", - "kbn.discover.fieldChooser.fieldFilterFacetButtonLabel": "已筛选字段", - "kbn.discover.fieldChooser.searchPlaceHolder": "搜索字段", - "kbn.discover.histogram.partialData.bucketTooltipText": "选定的时间范围不包括此整个存储桶,其可能包含部分数据。", - "kbn.doc.failedToLocateIndexPattern": "无索引模式匹配 ID {indexPatternId}", - "kbn.doc.somethingWentWrongDescriptionAddon": "请确保索引存在。", - "kbn.management.objects.objectsTable.export.successWithMissingRefsNotification": "您的文件正在后台下载。找不到某些相关对象。有关缺失对象列表,请查看导出文件的最后一行。", - "kbn.management.settings.categoryNames.siemLabel": "SIEM", - "kbn.management.settings.field.imageTooLargeErrorMessage": "图像过大,最大大小为 {maxSizeDescription}", - "kbn.server.tutorials.couchdbMetrics.artifacts.dashboards.linkLabel": "CouchDB 指标仪表板", - "kbn.server.tutorials.couchdbMetrics.longDescription": "`couchdb` Metricbeat 模块从 CouchDB 提取监测指标。[了解详情]({learnMoreLink})。", - "kbn.server.tutorials.couchdbMetrics.nameTitle": "CouchDB 指标", - "kbn.server.tutorials.couchdbMetrics.shortDescription": "从 CouchdB 服务器提取监测指标。", - "kbn.visualize.listing.betaTitle": "公测版", - "kbn.visualize.listing.betaTooltip": "此可视化为公测版,可能会进行更改。设计和代码相对于正式发行版功能还不够成熟,将按原样提供,且不提供任何保证。公测版功能不受正式发行版功能支持 SLA 的约束", - "kbn.visualize.newVisWizard.betaDescription": "此可视化为公测版,可能会进行更改。设计和代码相对于正式发行版功能还不够成熟,将按原样提供,且不提供任何保证。公测版功能不受正式发行版功能支持 SLA 的约束", - "kbn.visualize.newVisWizard.betaTitle": "公测版", - "kbn.visualize.pageHeading": "{chartName} {chartType}可视化", - "kbn.advancedSettings.courier.batchSearchesText": "禁用时,仪表板面板将分别加载,用户离开时或更新查询时,\n 搜索请求将终止。启用时,仪表板面板将一起加载并加载所有数据,\n 搜索将不会终止。", - "kbn.doc.couldNotFindDocumentsDescription": "无文档匹配该 ID。", - "kbn.doc.somethingWentWrongDescription": "{indexName} 缺失。", "kbnVislibVisTypes.area.areaDescription": "突出折线图下方的数量", "kbnVislibVisTypes.area.areaTitle": "面积图", + "kbnVislibVisTypes.area.countText": "计数", "kbnVislibVisTypes.area.groupTitle": "拆分序列", "kbnVislibVisTypes.area.metricsTitle": "Y 轴", "kbnVislibVisTypes.area.radiusTitle": "点大小", "kbnVislibVisTypes.area.segmentTitle": "X 轴", "kbnVislibVisTypes.area.splitTitle": "拆分图表", - "kbnVislibVisTypes.controls.gaugeOptions.alignmentLabel": "对齐方式", - "kbnVislibVisTypes.controls.gaugeOptions.displayWarningsLabel": "显示警告", - "kbnVislibVisTypes.controls.gaugeOptions.rangesTitle": "范围", - "kbnVislibVisTypes.controls.gaugeOptions.styleTitle": "样式", - "kbnVislibVisTypes.controls.heatmapOptions.colorLabel": "颜色", - "kbnVislibVisTypes.controls.heatmapOptions.colorsNumberLabel": "颜色个数", - "kbnVislibVisTypes.controls.heatmapOptions.overwriteAutomaticColorLabel": "覆盖自动配色", - "kbnVislibVisTypes.controls.heatmapOptions.rotateLabel": "旋转", - "kbnVislibVisTypes.controls.heatmapOptions.showLabelsTitle": "显示标签", - "kbnVislibVisTypes.controls.pointSeries.categoryAxis.filterLabelsLabel": "筛选标签", - "kbnVislibVisTypes.controls.pointSeries.categoryAxis.labelsTitle": "标签", - "kbnVislibVisTypes.controls.pointSeries.categoryAxis.positionLabel": "位置", - "kbnVislibVisTypes.controls.pointSeries.categoryAxis.showLabel": "显示", - "kbnVislibVisTypes.controls.pointSeries.categoryAxis.showLabelsLabel": "显示标签", - "kbnVislibVisTypes.controls.pointSeries.categoryAxis.xAxisTitle": "X 轴", - "kbnVislibVisTypes.controls.pointSeries.gridAxis.dontShowLabel": "不显示", + "kbnVislibVisTypes.area.tabs.metricsAxesTitle": "指标和轴", + "kbnVislibVisTypes.area.tabs.panelSettingsTitle": "面板设置", + "kbnVislibVisTypes.axisModes.normalText": "正常", + "kbnVislibVisTypes.axisModes.percentageText": "百分比", + "kbnVislibVisTypes.axisModes.silhouetteText": "剪影", + "kbnVislibVisTypes.axisModes.wiggleText": "扭动", + "kbnVislibVisTypes.categoryAxis.rotate.angledText": "带角度", + "kbnVislibVisTypes.categoryAxis.rotate.horizontalText": "水平", + "kbnVislibVisTypes.categoryAxis.rotate.verticalText": "垂直", + "kbnVislibVisTypes.chartModes.normalText": "正常", + "kbnVislibVisTypes.chartModes.stackedText": "堆叠", + "kbnVislibVisTypes.chartTypes.areaText": "面积图", + "kbnVislibVisTypes.chartTypes.barText": "条形图", + "kbnVislibVisTypes.chartTypes.lineText": "折线图", + "kbnVislibVisTypes.controls.colorRanges.errorText": "每个范围应大于前一范围。", + "kbnVislibVisTypes.controls.colorSchema.colorSchemaLabel": "颜色模式", + "kbnVislibVisTypes.controls.colorSchema.howToChangeColorsDescription": "可以更改图例中的各个颜色。", + "kbnVislibVisTypes.controls.colorSchema.resetColorsButtonLabel": "重置颜色", + "kbnVislibVisTypes.controls.colorSchema.reverseColorSchemaLabel": "反转模式", + "kbnVislibVisTypes.controls.gaugeOptions.alignmentLabel": "对齐方式", + "kbnVislibVisTypes.controls.gaugeOptions.autoExtendRangeLabel": "自动扩展范围", + "kbnVislibVisTypes.controls.gaugeOptions.displayWarningsLabel": "显示警告", + "kbnVislibVisTypes.controls.gaugeOptions.extendRangeTooltip": "将数据范围扩展到最大值。", + "kbnVislibVisTypes.controls.gaugeOptions.gaugeTypeLabel": "仪表类型", + "kbnVislibVisTypes.controls.gaugeOptions.labelsTitle": "标签", + "kbnVislibVisTypes.controls.gaugeOptions.percentageModeLabel": "百分比模式", + "kbnVislibVisTypes.controls.gaugeOptions.rangesTitle": "范围", + "kbnVislibVisTypes.controls.gaugeOptions.showLabelsLabel": "显示标签", + "kbnVislibVisTypes.controls.gaugeOptions.showLegendLabel": "显示图例", + "kbnVislibVisTypes.controls.gaugeOptions.showScaleLabel": "显示比例", + "kbnVislibVisTypes.controls.gaugeOptions.styleTitle": "样式", + "kbnVislibVisTypes.controls.gaugeOptions.subTextLabel": "子标签", + "kbnVislibVisTypes.controls.gaugeOptions.switchWarningsTooltip": "打开/关闭警告。打开时,如果标签没有全部显示,则显示警告。", + "kbnVislibVisTypes.controls.heatmapOptions.colorLabel": "颜色", + "kbnVislibVisTypes.controls.heatmapOptions.colorScaleLabel": "色阶", + "kbnVislibVisTypes.controls.heatmapOptions.colorsNumberLabel": "颜色个数", + "kbnVislibVisTypes.controls.heatmapOptions.labelsTitle": "标签", + "kbnVislibVisTypes.controls.heatmapOptions.overwriteAutomaticColorLabel": "覆盖自动配色", + "kbnVislibVisTypes.controls.heatmapOptions.percentageModeLabel": "百分比模式", + "kbnVislibVisTypes.controls.heatmapOptions.rotateLabel": "旋转", + "kbnVislibVisTypes.controls.heatmapOptions.scaleToDataBoundsLabel": "缩放到数据边界", + "kbnVislibVisTypes.controls.heatmapOptions.showLabelsTitle": "显示标签", + "kbnVislibVisTypes.controls.heatmapOptions.useCustomRangesLabel": "使用定制范围", + "kbnVislibVisTypes.controls.pointSeries.categoryAxis.alignLabel": "对齐", + "kbnVislibVisTypes.controls.pointSeries.categoryAxis.filterLabelsLabel": "筛选标签", + "kbnVislibVisTypes.controls.pointSeries.categoryAxis.labelsTitle": "标签", + "kbnVislibVisTypes.controls.pointSeries.categoryAxis.positionLabel": "位置", + "kbnVislibVisTypes.controls.pointSeries.categoryAxis.showLabel": "显示", + "kbnVislibVisTypes.controls.pointSeries.categoryAxis.showLabelsLabel": "显示标签", + "kbnVislibVisTypes.controls.pointSeries.categoryAxis.xAxisTitle": "X 轴", + "kbnVislibVisTypes.controls.pointSeries.gridAxis.dontShowLabel": "不显示", "kbnVislibVisTypes.controls.pointSeries.gridAxis.gridText": "网格", "kbnVislibVisTypes.controls.pointSeries.gridAxis.xAxisLinesLabel": "显示 X 轴线", + "kbnVislibVisTypes.controls.pointSeries.gridAxis.yAxisLinesDisabledTooltip": "直方图的 X 轴线无法显示。", "kbnVislibVisTypes.controls.pointSeries.gridAxis.yAxisLinesLabel": "Y 轴线", "kbnVislibVisTypes.controls.pointSeries.series.chartTypeLabel": "图表类型", "kbnVislibVisTypes.controls.pointSeries.series.lineModeLabel": "线条模式", @@ -2886,23 +2565,53 @@ "kbnVislibVisTypes.controls.pointSeries.series.metricsTitle": "指标", "kbnVislibVisTypes.controls.pointSeries.series.modeLabel": "模式", "kbnVislibVisTypes.controls.pointSeries.series.newAxisLabel": "新建轴…...", + "kbnVislibVisTypes.controls.pointSeries.series.showDotsLabel": "显示点线", "kbnVislibVisTypes.controls.pointSeries.series.showLineLabel": "显示为线条", "kbnVislibVisTypes.controls.pointSeries.series.valueAxisLabel": "值轴", + "kbnVislibVisTypes.controls.pointSeries.seriesAccordionAriaLabel": "切换 {agg} 选项", + "kbnVislibVisTypes.controls.pointSeries.valueAxes.addButtonTooltip": "添加 Y 轴", + "kbnVislibVisTypes.controls.pointSeries.valueAxes.customExtentsLabel": "定制范围", "kbnVislibVisTypes.controls.pointSeries.valueAxes.maxLabel": "最大值", + "kbnVislibVisTypes.controls.pointSeries.valueAxes.minErrorMessage": "最小值应小于最大值。", "kbnVislibVisTypes.controls.pointSeries.valueAxes.minLabel": "最小值", "kbnVislibVisTypes.controls.pointSeries.valueAxes.minNeededScaleText": "如果选择了对数刻度,最小值必须大于 0。", "kbnVislibVisTypes.controls.pointSeries.valueAxes.modeLabel": "模式", "kbnVislibVisTypes.controls.pointSeries.valueAxes.positionLabel": "位置", + "kbnVislibVisTypes.controls.pointSeries.valueAxes.removeButtonTooltip": "移除 Y 轴", + "kbnVislibVisTypes.controls.pointSeries.valueAxes.scaleToDataBounds.boundsMargin": "边界边距", + "kbnVislibVisTypes.controls.pointSeries.valueAxes.scaleToDataBounds.minNeededBoundsMargin": "边界边距必须大于或等于 0。", "kbnVislibVisTypes.controls.pointSeries.valueAxes.scaleToDataBoundsLabel": "缩放到数据边界", "kbnVislibVisTypes.controls.pointSeries.valueAxes.scaleTypeLabel": "缩放类型", "kbnVislibVisTypes.controls.pointSeries.valueAxes.setAxisExtentsLabel": "设置轴范围", "kbnVislibVisTypes.controls.pointSeries.valueAxes.showLabel": "显示", "kbnVislibVisTypes.controls.pointSeries.valueAxes.titleLabel": "标题", + "kbnVislibVisTypes.controls.pointSeries.valueAxes.toggleCustomExtendsAriaLabel": "切换定制范围", + "kbnVislibVisTypes.controls.pointSeries.valueAxes.toggleOptionsAriaLabel": "切换 {axisName} 选项", "kbnVislibVisTypes.controls.pointSeries.valueAxes.yAxisTitle": "Y 轴", + "kbnVislibVisTypes.controls.rangeErrorMessage": "值必须是在 {min} 到 {max} 的范围内", + "kbnVislibVisTypes.controls.truncateLabel": "截断", + "kbnVislibVisTypes.controls.vislibBasicOptions.legendPositionLabel": "图例位置", + "kbnVislibVisTypes.controls.vislibBasicOptions.showTooltipLabel": "显示工具提示", + "kbnVislibVisTypes.editors.heatmap.basicSettingsTitle": "基本设置", + "kbnVislibVisTypes.editors.heatmap.heatmapSettingsTitle": "热图设置", + "kbnVislibVisTypes.editors.heatmap.highlightLabel": "高亮范围", + "kbnVislibVisTypes.editors.heatmap.highlightLabelTooltip": "高亮显示图表中鼠标悬停的范围以及图例中对应的标签。", "kbnVislibVisTypes.editors.pie.donutLabel": "圆环图", + "kbnVislibVisTypes.editors.pie.labelsSettingsTitle": "标签设置", + "kbnVislibVisTypes.editors.pie.pieSettingsTitle": "饼图设置", + "kbnVislibVisTypes.editors.pie.showLabelsLabel": "显示标签", + "kbnVislibVisTypes.editors.pie.showTopLevelOnlyLabel": "仅显示顶级", + "kbnVislibVisTypes.editors.pie.showValuesLabel": "显示值", "kbnVislibVisTypes.editors.pointSeries.currentTimeMarkerLabel": "当前时间标记", "kbnVislibVisTypes.editors.pointSeries.orderBucketsBySumLabel": "按总计值排序存储桶", "kbnVislibVisTypes.editors.pointSeries.settingsTitle": "设置", + "kbnVislibVisTypes.editors.pointSeries.showLabels": "在图表上显示值", + "kbnVislibVisTypes.editors.pointSeries.thresholdLine.colorLabel": "线条颜色", + "kbnVislibVisTypes.editors.pointSeries.thresholdLine.showLabel": "显示阈值线条", + "kbnVislibVisTypes.editors.pointSeries.thresholdLine.styleLabel": "线条样式", + "kbnVislibVisTypes.editors.pointSeries.thresholdLine.valueLabel": "阈值", + "kbnVislibVisTypes.editors.pointSeries.thresholdLine.widthLabel": "线条宽度", + "kbnVislibVisTypes.editors.pointSeries.thresholdLineSettingsTitle": "阈值线条", "kbnVislibVisTypes.functions.pie.help": "饼图可视化", "kbnVislibVisTypes.functions.vislib.help": "Vislib 可视化", "kbnVislibVisTypes.gauge.alignmentAutomaticTitle": "自动", @@ -2910,6 +2619,8 @@ "kbnVislibVisTypes.gauge.alignmentVerticalTitle": "垂直", "kbnVislibVisTypes.gauge.gaugeDescription": "仪表盘图指示指标的状态。用于显示指标值与参考阈值的相关程度。", "kbnVislibVisTypes.gauge.gaugeTitle": "仪表盘图", + "kbnVislibVisTypes.gauge.gaugeTypes.arcText": "弧形", + "kbnVislibVisTypes.gauge.gaugeTypes.circleText": "圆形", "kbnVislibVisTypes.gauge.groupTitle": "拆分组", "kbnVislibVisTypes.gauge.metricTitle": "指标", "kbnVislibVisTypes.goal.goalDescription": "目标图指示与最终目标的接近程度。", @@ -2936,6 +2647,13 @@ "kbnVislibVisTypes.horizontalBar.radiusTitle": "点大小", "kbnVislibVisTypes.horizontalBar.segmentTitle": "X 轴", "kbnVislibVisTypes.horizontalBar.splitTitle": "拆分图表", + "kbnVislibVisTypes.interpolationModes.smoothedText": "平滑", + "kbnVislibVisTypes.interpolationModes.steppedText": "渐变", + "kbnVislibVisTypes.interpolationModes.straightText": "直线", + "kbnVislibVisTypes.legendPositions.bottomText": "下", + "kbnVislibVisTypes.legendPositions.leftText": "左", + "kbnVislibVisTypes.legendPositions.rightText": "右", + "kbnVislibVisTypes.legendPositions.topText": "上", "kbnVislibVisTypes.line.groupTitle": "拆分序列", "kbnVislibVisTypes.line.lineDescription": "突出趋势", "kbnVislibVisTypes.line.lineTitle": "折线图", @@ -2948,114 +2666,34 @@ "kbnVislibVisTypes.pie.pieTitle": "饼图", "kbnVislibVisTypes.pie.segmentTitle": "拆分切片", "kbnVislibVisTypes.pie.splitTitle": "拆分图表", - "kbnVislibVisTypes.controls.gaugeOptions.extendRangeTooltip": "将数据范围扩展到最大值。", - "kbnVislibVisTypes.controls.gaugeOptions.labelsTitle": "标签", - "kbnVislibVisTypes.controls.gaugeOptions.switchWarningsTooltip": "打开/关闭警告。打开时,如果标签没有全部显示,则显示警告。", - "kbnVislibVisTypes.controls.pointSeries.gridAxis.yAxisLinesDisabledTooltip": "直方图的 X 轴线无法显示。", - "kbnVislibVisTypes.controls.rangeErrorMessage": "值必须是在 {min} 到 {max} 的范围内", - "kbnVislibVisTypes.controls.truncateLabel": "截断", - "kbnVislibVisTypes.editors.pointSeries.thresholdLine.valueLabel": "阈值", - "kbnVislibVisTypes.editors.pointSeries.thresholdLine.widthLabel": "线条宽度", - "kbnVislibVisTypes.gauge.gaugeTypes.arcText": "弧形", - "kbnVislibVisTypes.gauge.gaugeTypes.circleText": "圆形", - "kbnVislibVisTypes.legendPositions.bottomText": "下", - "kbnVislibVisTypes.legendPositions.leftText": "左", - "kbnVislibVisTypes.legendPositions.rightText": "右", - "kbnVislibVisTypes.legendPositions.topText": "上", - "kbnVislibVisTypes.controls.gaugeOptions.autoExtendRangeLabel": "自动扩展范围", - "kbnVislibVisTypes.controls.gaugeOptions.gaugeTypeLabel": "仪表类型", - "kbnVislibVisTypes.controls.gaugeOptions.percentageModeLabel": "百分比模式", - "kbnVislibVisTypes.controls.gaugeOptions.showLabelsLabel": "显示标签", - "kbnVislibVisTypes.controls.gaugeOptions.showLegendLabel": "显示图例", - "kbnVislibVisTypes.controls.gaugeOptions.showScaleLabel": "显示比例", - "kbnVislibVisTypes.controls.gaugeOptions.subTextLabel": "子标签", - "kbnVislibVisTypes.controls.vislibBasicOptions.legendPositionLabel": "图例位置", - "kbnVislibVisTypes.controls.vislibBasicOptions.showTooltipLabel": "显示工具提示", - "kbnVislibVisTypes.editors.pie.labelsSettingsTitle": "标签设置", - "kbnVislibVisTypes.editors.pie.pieSettingsTitle": "饼图设置", - "kbnVislibVisTypes.editors.pie.showLabelsLabel": "显示标签", - "kbnVislibVisTypes.editors.pie.showTopLevelOnlyLabel": "仅显示顶级", - "kbnVislibVisTypes.editors.pie.showValuesLabel": "显示值", - "kbnVislibVisTypes.area.countText": "计数", - "kbnVislibVisTypes.area.tabs.metricsAxesTitle": "指标和轴", - "kbnVislibVisTypes.area.tabs.panelSettingsTitle": "面板设置", - "kbnVislibVisTypes.axisModes.normalText": "正常", - "kbnVislibVisTypes.axisModes.percentageText": "百分比", - "kbnVislibVisTypes.axisModes.silhouetteText": "剪影", - "kbnVislibVisTypes.axisModes.wiggleText": "扭动", - "kbnVislibVisTypes.categoryAxis.rotate.angledText": "带角度", - "kbnVislibVisTypes.categoryAxis.rotate.horizontalText": "水平", - "kbnVislibVisTypes.categoryAxis.rotate.verticalText": "垂直", - "kbnVislibVisTypes.chartModes.normalText": "正常", - "kbnVislibVisTypes.chartModes.stackedText": "堆叠", - "kbnVislibVisTypes.chartTypes.areaText": "面积图", - "kbnVislibVisTypes.chartTypes.barText": "条形图", - "kbnVislibVisTypes.chartTypes.lineText": "折线图", - "kbnVislibVisTypes.controls.colorRanges.errorText": "每个范围应大于前一范围。", - "kbnVislibVisTypes.controls.colorSchema.colorSchemaLabel": "颜色模式", - "kbnVislibVisTypes.controls.colorSchema.howToChangeColorsDescription": "可以更改图例中的各个颜色。", - "kbnVislibVisTypes.controls.colorSchema.resetColorsButtonLabel": "重置颜色", - "kbnVislibVisTypes.controls.colorSchema.reverseColorSchemaLabel": "反转模式", - "kbnVislibVisTypes.controls.heatmapOptions.labelsTitle": "标签", - "kbnVislibVisTypes.controls.heatmapOptions.useCustomRangesLabel": "使用定制范围", - "kbnVislibVisTypes.controls.pointSeries.categoryAxis.alignLabel": "对齐", - "kbnVislibVisTypes.controls.pointSeries.series.showDotsLabel": "显示点线", - "kbnVislibVisTypes.controls.pointSeries.seriesAccordionAriaLabel": "切换 {agg} 选项", - "kbnVislibVisTypes.controls.pointSeries.valueAxes.addButtonTooltip": "添加 Y 轴", - "kbnVislibVisTypes.controls.pointSeries.valueAxes.customExtentsLabel": "定制范围", - "kbnVislibVisTypes.controls.pointSeries.valueAxes.minErrorMessage": "最小值应小于最大值。", - "kbnVislibVisTypes.controls.pointSeries.valueAxes.removeButtonTooltip": "移除 Y 轴", - "kbnVislibVisTypes.controls.pointSeries.valueAxes.toggleCustomExtendsAriaLabel": "切换定制范围", - "kbnVislibVisTypes.controls.pointSeries.valueAxes.toggleOptionsAriaLabel": "切换 {axisName} 选项", - "kbnVislibVisTypes.editors.heatmap.highlightLabelTooltip": "高亮显示图表中鼠标悬停的范围以及图例中对应的标签。", - "kbnVislibVisTypes.editors.pointSeries.thresholdLine.colorLabel": "线条颜色", - "kbnVislibVisTypes.editors.pointSeries.thresholdLine.showLabel": "显示阈值线条", - "kbnVislibVisTypes.editors.pointSeries.thresholdLine.styleLabel": "线条样式", - "kbnVislibVisTypes.editors.pointSeries.thresholdLineSettingsTitle": "阈值线条", - "kbnVislibVisTypes.interpolationModes.smoothedText": "平滑", - "kbnVislibVisTypes.interpolationModes.steppedText": "渐变", - "kbnVislibVisTypes.interpolationModes.straightText": "直线", "kbnVislibVisTypes.scaleTypes.linearText": "线性", "kbnVislibVisTypes.scaleTypes.logText": "对数", "kbnVislibVisTypes.scaleTypes.squareRootText": "平方根", "kbnVislibVisTypes.thresholdLine.style.dashedText": "虚线", "kbnVislibVisTypes.thresholdLine.style.dotdashedText": "点虚线", "kbnVislibVisTypes.thresholdLine.style.fullText": "实线", - "kbnVislibVisTypes.controls.heatmapOptions.colorScaleLabel": "色阶", - "kbnVislibVisTypes.controls.heatmapOptions.percentageModeLabel": "百分比模式", - "kbnVislibVisTypes.controls.heatmapOptions.scaleToDataBoundsLabel": "缩放到数据边界", - "kbnVislibVisTypes.controls.pointSeries.valueAxes.scaleToDataBounds.boundsMargin": "边界边距", - "kbnVislibVisTypes.controls.pointSeries.valueAxes.scaleToDataBounds.minNeededBoundsMargin": "边界边距必须大于或等于 0。", - "kbnVislibVisTypes.editors.heatmap.basicSettingsTitle": "基本设置", - "kbnVislibVisTypes.editors.heatmap.heatmapSettingsTitle": "热图设置", - "kbnVislibVisTypes.editors.heatmap.highlightLabel": "高亮范围", - "visTypeMetric.colorModes.backgroundOptionLabel": "背景", - "visTypeMetric.colorModes.labelsOptionLabel": "标签", - "visTypeMetric.colorModes.noneOptionLabel": "无", - "visTypeMetric.function.help": "指标可视化", - "visTypeMetric.metricDescription": "将计算结果显示为单个数字", - "visTypeMetric.metricTitle": "指标", - "visTypeMetric.params.rangesTitle": "范围", - "visTypeMetric.params.style.styleTitle": "样式", - "visTypeMetric.schemas.metricTitle": "指标", - "visTypeMetric.schemas.splitGroupTitle": "拆分组", - "visTypeMetric.function.bgFill.help": "将颜色表示为 html 十六进制代码 (#123456)、html 颜色(red、blue)或 rgba 值 (rgba(255,255,255,1))。", - "visTypeMetric.function.bucket.help": "存储桶维度配置", - "visTypeMetric.function.colorMode.help": "指标的哪部分要上色", - "visTypeMetric.function.colorRange.help": "指定应将不同颜色应用到的值组的范围对象。", - "visTypeMetric.function.colorScheme.help": "要使用的颜色方案", - "visTypeMetric.function.font.help": "字体设置。", - "visTypeMetric.function.invertColors.help": "反转颜色范围", - "visTypeMetric.function.metric.help": "指标维度配置", - "visTypeMetric.function.percentage.help": "以百分比模式显示指标。需要设置 colorRange。", - "visTypeMetric.function.showLabels.help": "在指标值下显示标签。", - "visTypeMetric.function.subText.help": "要在指标下显示的定制文本", - "visTypeMetric.function.useRanges.help": "已启用颜色范围。", - "visTypeMetric.params.settingsTitle": "设置", - "visTypeMetric.params.showTitleLabel": "显示标题", - "visTypeMetric.params.color.useForLabel": "将颜色用于", - "visTypeMetric.params.percentageModeLabel": "百分比模式", - "visTypeMetric.params.style.fontSizeLabel": "指标字体大小(磅)", + "kibana-react.exitFullScreenButton.exitFullScreenModeButtonLabel": "退出全屏", + "kibana-react.exitFullScreenButton.fullScreenModeDescription": "在全屏模式下,按 ESC 键可退出。", + "kibana-react.savedObjects.finder.filterButtonLabel": "类型", + "kibana-react.savedObjects.finder.searchPlaceholder": "搜索……", + "kibana-react.savedObjects.finder.sortAsc": "升序", + "kibana-react.savedObjects.finder.sortAuto": "最佳匹配", + "kibana-react.savedObjects.finder.sortButtonLabel": "排序", + "kibana-react.savedObjects.finder.sortDesc": "降序", + "kibana-react.savedObjects.saveModal.cancelButtonLabel": "取消", + "kibana-react.savedObjects.saveModal.descriptionLabel": "描述", + "kibana-react.savedObjects.saveModal.duplicateTitleDescription": "单击“{confirmSaveLabel}”可覆盖现有 {objectType}。", + "kibana-react.savedObjects.saveModal.duplicateTitleLabel": "具有标题“{title}”的 {objectType} 已存在", + "kibana-react.savedObjects.saveModal.saveAsNewLabel": "另存为新的 {objectType}", + "kibana-react.savedObjects.saveModal.saveButtonLabel": "保存", + "kibana-react.savedObjects.saveModal.saveTitle": "保存 {objectType}", + "kibana-react.savedObjects.saveModal.titleLabel": "标题", + "newsfeed.emptyPrompt.noNewsText": "如果您的 Kibana 实例没有 Internet 连接,请让您的管理员禁用此功能。否则,我们将不断尝试获取新闻。", + "newsfeed.emptyPrompt.noNewsTitle": "无新闻?", + "newsfeed.flyoutList.closeButtonLabel": "鍏抽棴", + "newsfeed.flyoutList.versionTextLabel": "{version}", + "newsfeed.flyoutList.whatsNewTitle": "最近的新闻", + "newsfeed.loadingPrompt.gettingNewsText": "正在获取最近的新闻...", "regionMap.choroplethLayer.downloadingVectorData404ErrorMessage": "尝试提取 {name} 时,服务器响应状态为“404”。请确保目标文件位于该位置。", "regionMap.choroplethLayer.downloadingVectorDataErrorMessage": "无法下载 {name} 文件。请确保服务器的 CORS 配置允许来自此主机上的 Kibana 应用程序的请求。", "regionMap.choroplethLayer.downloadingVectorDataErrorMessageTitle": "下载矢量数据时出错", @@ -3065,8 +2703,11 @@ "regionMap.mapVis.regionMapEditorConfig.schemas.metricTitle": "值", "regionMap.mapVis.regionMapEditorConfig.schemas.segmentTitle": "形状字段", "regionMap.mapVis.regionMapTitle": "区域地图", + "regionMap.visParams.colorSchemaLabel": "颜色模式", "regionMap.visParams.displayWarningsLabel": "显示警告", "regionMap.visParams.joinFieldLabel": "联接字段", + "regionMap.visParams.layerSettingsTitle": "图层设置", + "regionMap.visParams.outlineWeightLabel": "边框粗细", "regionMap.visParams.previewOnEMSLinkText": "在 EMS 上预览", "regionMap.visParams.previewOnEMSLinkTitle": "在 Elastic 地图服务上预览“{selectedLayerName}”", "regionMap.visParams.showAllShapesLabel": "显示所有形状", @@ -3076,84 +2717,12 @@ "regionMap.visParams.vectorMapLabel": "矢量地图", "regionMap.visualization.unableToShowMismatchesWarningText": "确保每个字词与该形状的联接字段匹配:{mismatches}", "regionMap.visualization.unableToShowMismatchesWarningTitle": "无法在地图上显示 {mismatchesLength} {oneMismatch, plural, one { 个结果} other { 个结果}}", - "regionMap.visParams.colorSchemaLabel": "颜色模式", - "regionMap.visParams.layerSettingsTitle": "图层设置", - "regionMap.visParams.outlineWeightLabel": "边框粗细", - "home.sampleData.ecommerceSpec.averageSalesPerRegionTitle": "[电子商务] 每地区平均销售额", - "home.sampleData.ecommerceSpec.averageSalesPriceTitle": "[电子商务] 平均销售价格", - "home.sampleData.ecommerceSpec.averageSoldQuantityTitle": "[电子商务] 平均销售数量", - "home.sampleData.ecommerceSpec.controlsTitle": "[电子商务] 控件", - "home.sampleData.ecommerceSpec.markdownTitle": "[电子商务] Markdown", - "home.sampleData.ecommerceSpec.ordersTitle": "[电子商务] 订单", - "home.sampleData.ecommerceSpec.promotionTrackingTitle": "[电子商务] 促销追踪", - "home.sampleData.ecommerceSpec.revenueDashboardDescription": "分析模拟的电子商务订单和收入", - "home.sampleData.ecommerceSpec.revenueDashboardTitle": "[电子商务] 收入仪表板", - "home.sampleData.ecommerceSpec.salesByCategoryTitle": "[电子商务] 按类别划分的销售额", - "home.sampleData.ecommerceSpec.salesByGenderTitle": "[电子商务] 按性别划分的销售额", - "home.sampleData.ecommerceSpec.soldProductsPerDayTitle": "[电子商务] 每天已售产品", - "home.sampleData.ecommerceSpec.topSellingProductsTitle": "[电子商务] 热卖产品", - "home.sampleData.ecommerceSpec.totalRevenueTitle": "[电子商务] 总收入", - "home.sampleData.ecommerceSpecDescription": "用于追踪电子商务订单的样例数据、可视化和仪表板。", - "home.sampleData.ecommerceSpecTitle": "样例电子商务订单", - "home.sampleData.flightsSpec.airlineCarrierTitle": "[航班] 航空公司", - "home.sampleData.flightsSpec.airportConnectionsTitle": "[航班] 机场航线(将鼠标悬停在机场上)", - "home.sampleData.flightsSpec.averageTicketPriceTitle": "[航班] 平均票价", - "home.sampleData.flightsSpec.controlsTitle": "[航班] 控件", - "home.sampleData.flightsSpec.delayBucketsTitle": "[航班] 延误存储桶", - "home.sampleData.flightsSpec.delaysAndCancellationsTitle": "[航班] 延误与取消", - "home.sampleData.flightsSpec.delayTypeTitle": "[航班] 延误类型", - "home.sampleData.flightsSpec.destinationWeatherTitle": "[航班] 到达地天气", - "home.sampleData.flightsSpec.flightCancellationsTitle": "[航班] 航班取消", - "home.sampleData.flightsSpec.flightCountAndAverageTicketPriceTitle": "[航班] 航班计数和平均票价", - "home.sampleData.flightsSpec.flightDelaysTitle": "[航班] 航班延误", - "home.sampleData.flightsSpec.flightLogTitle": "[航班] 飞行日志", - "home.sampleData.flightsSpec.globalFlightDashboardDescription": "分析 ES-Air、Logstash Airways、Kibana Airlines 和 JetBeats 的模拟航班数据", - "home.sampleData.flightsSpec.globalFlightDashboardTitle": "[航班] 全球航班仪表板", - "home.sampleData.flightsSpec.markdownInstructionsTitle": "[航班] Markdown 说明", - "home.sampleData.flightsSpec.originCountryTicketPricesTitle": "[航班] 始发国/地区票价", - "home.sampleData.flightsSpec.originCountryTitle": "[航班] 始发国/地区与到达国/地区", - "home.sampleData.flightsSpec.totalFlightCancellationsTitle": "[航班] 航班取消总数", - "home.sampleData.flightsSpec.totalFlightDelaysTitle": "[航班] 航班延误总数", - "home.sampleData.flightsSpec.totalFlightsTitle": "[航班] 航班总数", - "home.sampleData.flightsSpecDescription": "用于监测航班路线的样例数据、可视化和仪表板。", - "home.sampleData.flightsSpecTitle": "样例航班数据", - "home.sampleData.logsSpec.fileTypeScatterPlotTitle": "[日志] 文件类型散点图", - "home.sampleData.logsSpec.goalsTitle": "[日志] 目标", - "home.sampleData.logsSpec.heatmapTitle": "[日志] 热图", - "home.sampleData.logsSpec.hostVisitsBytesTableTitle": "[日志] 主机、访问和字节表", - "home.sampleData.logsSpec.inputControlsTitle": "[日志] 输入控件", - "home.sampleData.logsSpec.markdownInstructionsTitle": "[日志] Markdown 说明", - "home.sampleData.logsSpec.responseCodesOverTimeTitle": "[日志] 时移响应代码 + 注释", - "home.sampleData.logsSpec.sourceAndDestinationSankeyChartTitle": "[日志] 始发地和到达地 Sankey 图", - "home.sampleData.logsSpec.uniqueVisitorsByCountryTitle": "[日志] 按国家/地区划分的独立访客", - "home.sampleData.logsSpec.uniqueVisitorsTitle": "[日志] 独立访客与平均字节数", - "home.sampleData.logsSpec.visitorOSTitle": "[日志] 按 OS 划分的访客", - "home.sampleData.logsSpec.webTrafficDescription": "分析 Elastic 网站的模拟网络流量日志数据", - "home.sampleData.logsSpec.webTrafficTitle": "[日志] 网络流量", - "home.sampleData.logsSpecDescription": "用于监测 Web 日志的样例数据、可视化和仪表板。", - "home.sampleData.logsSpecTitle": "样例 Web 日志", "server.stats.notReadyMessage": "统计尚未就绪。请稍后重试", "server.status.disabledTitle": "已禁用", "server.status.greenTitle": "绿", "server.status.redTitle": "红", "server.status.uninitializedTitle": "未初始化", "server.status.yellowTitle": "黄", - "share.contextMenu.embedCodeLabel": "嵌入代码", - "share.contextMenu.embedCodePanelTitle": "嵌入代码", - "share.contextMenu.permalinkPanelTitle": "固定链接", - "share.contextMenu.permalinksLabel": "固定链接", - "share.contextMenuTitle": "共享此 {objectType}", - "share.urlPanel.canNotShareAsSavedObjectHelpText": "只有保存 {objectType} 后,才能共享为已保存对象。", - "share.urlPanel.copyIframeCodeButtonLabel": "复制 iFrame 代码", - "share.urlPanel.copyLinkButtonLabel": "复制链接", - "share.urlPanel.generateLinkAsLabel": "将链接生成为", - "share.urlPanel.savedObjectDescription": "您可以将此 URL 共享给相关人员,以便他们可以加载此 {objectType} 最新的已保存版本。", - "share.urlPanel.savedObjectLabel": "已保存对象", - "share.urlPanel.shortUrlHelpText": "建议共享缩短的快照 URL,以实现最大的兼容性。Internet Explorer 有 URL 长度限制,某些 wiki 和标记分析器无法很好地处理全长版本的快照 URL,但应能很好地处理短 URL。", - "share.urlPanel.shortUrlLabel": "短 URL", - "share.urlPanel.snapshotDescription": "快照 URL 将{objectType}的当前状态编入 URL 自身之中。通过此 URL,将无法看到对已保存的{objectType}的编辑。", - "share.urlPanel.snapshotLabel": "快照", - "share.urlPanel.unableCreateShortUrlErrorMessage": "无法创建短 URL。错误:{errorMessage}", "statusPage.loadStatus.serverIsDownErrorMessage": "无法请求服务器状态。也许您的服务器已关闭?", "statusPage.loadStatus.serverStatusCodeErrorMessage": "无法使用状态代码 {responseStatus} 请求服务器状态", "statusPage.metricsTiles.columns.heapTotalHeader": "堆总计", @@ -3169,63 +2738,54 @@ "statusPage.statusApp.statusTitle": "插件状态", "statusPage.statusTable.columns.idHeader": "ID", "statusPage.statusTable.columns.statusHeader": "状态", - "visTypeTable.aggTable.exportLabel": "导出:", - "visTypeTable.aggTable.formattedLabel": "格式化", - "visTypeTable.aggTable.rawLabel": "原始", - "visTypeTable.directives.tableCellFilter.filterForValueTooltip": "筛留值", - "visTypeTable.directives.tableCellFilter.filterOutValueTooltip": "筛除值", - "visTypeTable.function.help": "表可视化", - "visTypeTable.params.showMetricsLabel": "显示每个桶/级别的指标", - "visTypeTable.params.showPartialRowsLabel": "显示部分行", - "visTypeTable.params.showPartialRowsTip": "显示具有部分数据的行。这仍将计算每个桶/级别的指标,即使它们未显示。", - "visTypeTable.params.showTotalLabel": "显示汇总", - "visTypeTable.params.totalFunctionLabel": "汇总函数", - "visTypeTable.tableVisDescription": "在表中显示值", - "visTypeTable.tableVisEditorConfig.schemas.bucketTitle": "拆分行", - "visTypeTable.tableVisEditorConfig.schemas.metricTitle": "指标", - "visTypeTable.tableVisEditorConfig.schemas.splitTitle": "拆分表", - "visTypeTable.tableVisTitle": "数据表", - "visTypeTable.vis.noResultsFoundTitle": "找不到结果", - "visTypeTable.params.PercentageColLabel": "百分比列", - "visTypeTable.params.percentageTableColumnName": "{title} 百分比", - "visTypeTable.params.defaultPercentageCol": "不显示", - "visTypeTable.totalAggregations.averageText": "平均值", - "visTypeTable.totalAggregations.countText": "计数", - "visTypeTable.totalAggregations.maxText": "最大值", - "visTypeTable.totalAggregations.minText": "最小值", - "visTypeTable.totalAggregations.sumText": "和", - "visTypeTable.params.perPageLabel": "每页行数", - "visTypeTagCloud.feedbackMessage.tooSmallContainerDescription": "容器太小,无法显示整个云。标记可能被裁剪或省略。", - "visTypeTagCloud.feedbackMessage.truncatedTagsDescription": "标记数量已截断,以避免绘制时间过长。", - "visTypeTagCloud.function.bucket.help": "存储桶维度配置", - "visTypeTagCloud.function.help": "标签云图可视化", - "visTypeTagCloud.function.metric.help": "指标维度配置", - "visTypeTagCloud.function.orientation.help": "标签云图内的字方向", - "visTypeTagCloud.function.scale.help": "缩放以确定字体大小", - "visTypeTagCloud.vis.schemas.metricTitle": "标记大小", - "visTypeTagCloud.vis.schemas.segmentTitle": "标记", - "visTypeTagCloud.vis.tagCloudDescription": "一组字词,可根据其重要性调整大小", - "visTypeTagCloud.vis.tagCloudTitle": "标签云图", - "visTypeTagCloud.visParams.orientationsLabel": "方向", - "visTypeTagCloud.vis.editorConfig.orientations.multipleText": "多个", - "visTypeTagCloud.vis.editorConfig.orientations.rightAngledText": "直角", - "visTypeTagCloud.vis.editorConfig.orientations.singleText": "单个", - "visTypeTagCloud.vis.editorConfig.scales.linearText": "线性", - "visTypeTagCloud.vis.editorConfig.scales.logText": "对数", - "visTypeTagCloud.vis.editorConfig.scales.squareRootText": "平方根", - "visTypeTagCloud.visParams.fontSizeLabel": "字体大小范围(像素)", - "visTypeTagCloud.visParams.showLabelToggleLabel": "显示标签", - "visTypeTagCloud.visParams.textScaleLabel": "文本比例", + "telemetry.callout.appliesSettingTitle": "此设置适用于{allOfKibanaText}", + "telemetry.callout.appliesSettingTitle.allOfKibanaText": "所有 Kibana。", + "telemetry.callout.clusterStatisticsDescription": "这是我们将收集的基本集群统计信息的示例。其包括索引、分片和节点的数目。还包括概括性的使用情况统计信息,例如监测是否打开。", + "telemetry.callout.clusterStatisticsTitle": "集群统计信息", + "telemetry.callout.errorLoadingClusterStatisticsDescription": "尝试提取集群统计信息时发生意外错误。发生此问题的原因可能是 Elasticsearch 出故障、Kibana 出故障或者有网络错误。检查 Kibana,然后重新加载页面并重试。", + "telemetry.callout.errorLoadingClusterStatisticsTitle": "加载集群统计信息时出错", + "telemetry.callout.errorUnprivilegedUserDescription": "您无权查看未加密的集群统计信息。", + "telemetry.callout.errorUnprivilegedUserTitle": "显示集群统计信息时出错", + "telemetry.optInErrorToastText": "尝试设置使用统计信息首选项时发生错误。", + "telemetry.optInErrorToastTitle": "错误", + "telemetry.optInNoticeSeenErrorTitle": "错误", + "telemetry.optInNoticeSeenErrorToastText": "关闭声明时发生错误", + "telemetry.readOurUsageDataPrivacyStatementLinkText": "阅读我们的使用情况数据隐私声明", + "telemetry.seeExampleOfWhatWeCollectLinkText": "查看我们收集的内容示例", + "telemetry.telemetryBannerDescription": "想帮助我们改进 Elastic Stack?数据使用情况收集当前已禁用。启用数据使用情况收集可帮助我们管理并改善产品和服务。有关详情,请参阅我们的{privacyStatementLink}。", + "telemetry.telemetryConfigDescription": "通过提供基本功能的使用情况统计信息,来帮助我们改进 Elastic Stack。我们不会在 Elastic 之外共享此数据。", + "telemetry.telemetryConfigTitle": "遥测选择加入", + "telemetry.telemetryErrorNotificationMessageDescription.tryAgainText": "确认 Kibana 和 Elasticsearch 仍在运行,然后重试。", + "telemetry.telemetryErrorNotificationMessageDescription.unableToSaveTelemetryPreferenceText": "无法保存遥测首选项。", + "telemetry.telemetryErrorNotificationMessageTitle": "遥测错误", + "telemetry.telemetryOptedInDisableUsage": "请在此禁用使用情况数据", + "telemetry.telemetryOptedInDismissMessage": "关闭", + "telemetry.telemetryOptedInNoticeDescription": "要了解使用情况数据如何帮助我们管理和改善产品和服务,请参阅我们的{privacyStatementLink}。要停止收集,{disableLink}。", + "telemetry.telemetryOptedInPrivacyStatement": "隐私声明", + "telemetry.usageDataTitle": "使用情况数据", + "telemetry.welcomeBanner.disableButtonLabel": "禁用", + "telemetry.welcomeBanner.enableButtonLabel": "启用", + "telemetry.welcomeBanner.telemetryConfigDetailsDescription.telemetryPrivacyStatementLinkText": "遥测隐私声明", + "telemetry.welcomeBanner.title": "帮助我们改进 Elastic Stack", "tileMap.baseMapsVisualization.childShouldImplementMethodErrorMessage": "子函数应实现此方法以响应数据更新", "tileMap.function.help": "磁贴地图可视化", "tileMap.geohashLayer.mapTitle": "{mapType} 地图类型无法识别", "tileMap.tooltipFormatter.latitudeLabel": "纬度", "tileMap.tooltipFormatter.longitudeLabel": "经度", + "tileMap.vis.editorConfig.legendPositions.bottomLeftText": "左下方", + "tileMap.vis.editorConfig.legendPositions.bottomRightText": "右下方", + "tileMap.vis.editorConfig.legendPositions.topLeftText": "左上方", + "tileMap.vis.editorConfig.legendPositions.topRightText": "右上方", + "tileMap.vis.editorConfig.mapTypes.heatmapText": "热图", + "tileMap.vis.editorConfig.mapTypes.scaledCircleMarkersText": "缩放式圆形标记", + "tileMap.vis.editorConfig.mapTypes.shadedCircleMarkersText": "带阴影圆形标记", + "tileMap.vis.editorConfig.mapTypes.shadedGeohashGridText": "带阴影 geohash 网格", "tileMap.vis.map.editorConfig.schemas.geoCoordinatesTitle": "地理坐标", "tileMap.vis.map.editorConfig.schemas.metricTitle": "值", "tileMap.vis.mapDescription": "在地图上绘制纬度和经度坐标", "tileMap.vis.mapTitle": "坐标地图", "tileMap.visParams.clusterSizeLabel": "集群大小", + "tileMap.visParams.colorSchemaLabel": "颜色模式", "tileMap.visParams.desaturateTilesLabel": "降低平铺地图饱和度", "tileMap.visParams.mapTypeLabel": "地图类型", "tileMap.visParams.reduceVibrancyOfTileColorsTip": "降低平铺地图颜色的亮度。此设置在任何版本的 IE 浏览器中均不起作用。", @@ -3234,8888 +2794,432 @@ "tileMap.wmsOptions.imageFormatToUseTip": "通常为 image/png 或 image/jpeg。如果服务器返回透明图层,则使用 png。", "tileMap.wmsOptions.layersLabel": "图层", "tileMap.wmsOptions.listOfLayersToUseTip": "要使用的图层逗号分隔列表。", + "tileMap.wmsOptions.mapLoadFailDescription": "如果此参数不正确,将无法加载地图。", "tileMap.wmsOptions.urlOfWMSWebServiceTip": "WMS Web 服务的 URL。", "tileMap.wmsOptions.useWMSCompliantMapTileServerTip": "使用符合 WMS 规范的平铺地图服务器。仅适用于高级用户。", "tileMap.wmsOptions.versionOfWMSserverSupportsTip": "服务器支持的 WMS 版本。", "tileMap.wmsOptions.wmsAttributionLabel": "WMS 属性", - "tileMap.wmsOptions.wmsMapServerLabel": "WMS 地图服务器", - "tileMap.wmsOptions.wmsServerSupportedStylesListTip": "要使用的以逗号分隔的 WMS 服务器支持的样式列表。在大部分情况下为空。", - "tileMap.vis.editorConfig.legendPositions.bottomLeftText": "左下方", - "tileMap.vis.editorConfig.legendPositions.bottomRightText": "右下方", - "tileMap.vis.editorConfig.legendPositions.topLeftText": "左上方", - "tileMap.vis.editorConfig.legendPositions.topRightText": "右上方", - "tileMap.vis.editorConfig.mapTypes.heatmapText": "热图", - "tileMap.vis.editorConfig.mapTypes.scaledCircleMarkersText": "缩放式圆形标记", - "tileMap.vis.editorConfig.mapTypes.shadedCircleMarkersText": "带阴影圆形标记", - "tileMap.vis.editorConfig.mapTypes.shadedGeohashGridText": "带阴影 geohash 网格", - "tileMap.visParams.colorSchemaLabel": "颜色模式", - "tileMap.wmsOptions.mapLoadFailDescription": "如果此参数不正确,将无法加载地图。", "tileMap.wmsOptions.wmsDescription": "WMS 是用于地图图像服务的 {wmsLink}。", "tileMap.wmsOptions.wmsFormatLabel": "WMS 格式", "tileMap.wmsOptions.wmsLayersLabel": "WMS 图层", "tileMap.wmsOptions.wmsLinkText": "OGC 标准", + "tileMap.wmsOptions.wmsMapServerLabel": "WMS 地图服务器", + "tileMap.wmsOptions.wmsServerSupportedStylesListTip": "要使用的以逗号分隔的 WMS 服务器支持的样式列表。在大部分情况下为空。", "tileMap.wmsOptions.wmsStylesLabel": "WMS 样式", "tileMap.wmsOptions.wmsUrlLabel": "WMS url", "tileMap.wmsOptions.wmsVersionLabel": "WMS 版本", - "visTypeVega.editor.formatError": "格式化规范时出错", - "visTypeVega.editor.reformatAsHJSONButtonLabel": "重新格式化为 HJSON", - "visTypeVega.editor.reformatAsJSONButtonLabel": "重新格式化为 JSON,删除注释", - "visTypeVega.editor.vegaEditorOptionsButtonAriaLabel": "Vega 编辑器选项", - "visTypeVega.editor.vegaHelpButtonAriaLabel": "Vega 帮助", - "visTypeVega.emsFileParser.emsFileNameDoesNotExistErrorMessage": "{emsfile} {emsfileName} 不存在", - "visTypeVega.emsFileParser.missingNameOfFileErrorMessage": "具有 {dataUrlParamValue} 的 {dataUrlParam} 需要 {nameParam} 参数(文件名)", - "visTypeVega.esQueryParser.autointervalValueTypeErrorMessage": "{autointerval} 必须为 {trueValue} 或数字", - "visTypeVega.esQueryParser.dataUrlMustNotHaveLegacyAndBodyQueryValuesAtTheSameTimeErrorMessage": "{dataUrlParam} 不得同时具有旧的 {legacyContext} 和 {bodyQueryConfigName} 值", - "visTypeVega.esQueryParser.dataUrlMustNotHaveLegacyContextTogetherWithContextOrTimefieldErrorMessage": "{dataUrlParam} 不得同时具有 {legacyContext} 与 {context} 或 {timefield}", - "visTypeVega.esQueryParser.legacyContextCanBeTrueErrorMessage": "旧 {legacyContext} 可以为 {trueValue}(忽略时间范围选取器),也可以为时间字段的名称,例如 {timestampParam}", - "visTypeVega.esQueryParser.legacyUrlShouldChangeToWarningMessage": "旧 {urlParam}:{legacyUrl} 应更改为 {result}", - "visTypeVega.esQueryParser.shiftMustValueTypeErrorMessage": "{shiftParam} 必须为数值", - "visTypeVega.esQueryParser.timefilterValueErrorMessage": "{timefilter} 属性必须设置为 {trueValue}、{minValue} 或 {maxValue}", - "visTypeVega.esQueryParser.unknownUnitValueErrorMessage": "{unitParamName} 值未知。必须为以下值之一:[{unitParamValues}]", - "visTypeVega.esQueryParser.urlBodyValueTypeErrorMessage": "{configName} 必须为对象", - "visTypeVega.esQueryParser.urlContextAndUrlTimefieldMustNotBeUsedErrorMessage": "设置了 {queryParam} 时,不得使用 {urlContext} 和 {timefield}", - "visTypeVega.function.help": "Vega 可视化", - "visTypeVega.mapView.mapStyleNotFoundWarningMessage": "找不到 {mapStyleParam}", - "visTypeVega.mapView.minZoomAndMaxZoomHaveBeenSwappedWarningMessage": "已交换 {minZoomPropertyName} 和 {maxZoomPropertyName}", - "visTypeVega.mapView.resettingPropertyToMaxValueWarningMessage": "将 {name} 重置为 {max}", - "visTypeVega.mapView.resettingPropertyToMinValueWarningMessage": "将 {name} 重置为 {min}", - "visTypeVega.type.vegaDescription": "使用 Vega 和 Vega-Lite 创建定制可视化", - "visTypeVega.urlParser.dataUrlRequiresUrlParameterInFormErrorMessage": "{dataUrlParam} 需要以“{formLink}”形式的 {urlParam} 参数", - "visTypeVega.urlParser.urlShouldHaveQuerySubObjectWarningMessage": "使用 {urlObject} 应具有 {subObjectName} 子对象", - "visTypeVega.vegaParser.baseView.externalUrlsAreNotEnabledErrorMessage": "未启用外部 URL。将 {enableExternalUrls} 添加到 {kibanaConfigFileName}", - "visTypeVega.vegaParser.baseView.functionIsNotDefinedForGraphErrorMessage": "没有为此图表定义 {funcName}", - "visTypeVega.vegaParser.baseView.timeValuesTypeErrorMessage": "设置时间筛选时出错:时间值必须为相对日期或绝对日期。{start}、{end}", - "visTypeVega.vegaParser.centerOnMarkConfigValueTypeErrorMessage": "{configName} 应为 {trueValue}、{falseValue} 或数字", - "visTypeVega.vegaParser.dataExceedsSomeParamsUseTimesLimitErrorMessage": "数据不得包含 {urlParam}、{valuesParam} 和 {sourceParam} 中的多个值", - "visTypeVega.vegaParser.hostConfigIsDeprecatedWarningMessage": "{deprecatedConfigName} 已弃用。请改用 {newConfigName}。", - "visTypeVega.vegaParser.hostConfigValueTypeErrorMessage": "如果存在,{configName} 必须为对象", - "visTypeVega.vegaParser.inputSpecDoesNotSpecifySchemaWarningMessage": "输入规范未指定 {schemaParam},其默认值为 {defaultSchema}", - "visTypeVega.vegaParser.invalidVegaSpecErrorMessage": "Vega 规范无效", - "visTypeVega.vegaParser.kibanaConfigValueTypeErrorMessage": "如果存在,{configName} 必须为对象", - "visTypeVega.vegaParser.mapStyleValueTypeWarningMessage": "{mapStyleConfigName} 可能为 {mapStyleConfigFirstAllowedValue} 或 {mapStyleConfigSecondAllowedValue}", - "visTypeVega.vegaParser.maxBoundsValueTypeWarningMessage": "{maxBoundsConfigName} 必须为具有四个数字的数组", - "visTypeVega.vegaParser.notSupportedUrlTypeErrorMessage": "不支持 {urlObject}", - "visTypeVega.vegaParser.notValidLibraryVersionForInputSpecWarningMessage": "输入规范使用 {schemaLibrary} {schemaVersion},但 {schemaLibrary} 的当前版本为 {libraryVersion}。", - "visTypeVega.vegaParser.paddingConfigValueTypeErrorMessage": "{configName} 应为数字", - "visTypeVega.vegaParser.someKibanaConfigurationIsNoValidWarningMessage": "{configName} 无效", - "visTypeVega.vegaParser.someKibanaParamValueTypeWarningMessage": "{configName} 必须为布尔值", - "visTypeVega.vegaParser.unexpectedValueForPositionConfigurationErrorMessage": "意外的 {configurationName} 配置值", - "visTypeVega.vegaParser.unrecognizedControlsLocationValueErrorMessage": "无法识别的 {controlsLocationParam} 值。应为 [{locToDirMap}] 之一", - "visTypeVega.vegaParser.unrecognizedDirValueErrorMessage": "{dirParam} 值无法识别。应为 [{expectedValues}] 之一", - "visTypeVega.vegaParser.VLCompilerShouldHaveGeneratedSingleProtectionObjectErrorMessage": "内部错误:Vega-Lite 编译器应已生成单个投影对象", - "visTypeVega.vegaParser.widthAndHeightParamsAreIgnoredWithAutosizeFitWarningMessage": "使用 {autosizeParam} 时,将忽略 {widthParam} 和 {heightParam} 参数", - "visTypeVega.visualization.indexNotFoundErrorMessage": "找不到索引 {index}", - "visTypeVega.visualization.renderErrorTitle": "Vega 错误", - "visTypeVega.visualization.unableToFindDefaultIndexErrorMessage": "找不到默认索引", - "visTypeVega.visualization.unableToRenderWithoutDataWarningMessage": "没有数据时无法渲染", - "xpack.apm.agentMetrics.java.heapMemoryChartTitle": "堆内存", - "xpack.apm.agentMetrics.java.heapMemorySeriesCommitted": "已提交平均值", - "xpack.apm.agentMetrics.java.heapMemorySeriesMax": "限制平均值", - "xpack.apm.agentMetrics.java.heapMemorySeriesUsed": "已使用平均值", - "xpack.apm.agentMetrics.java.nonHeapMemoryChartTitle": "非堆内存", - "xpack.apm.agentMetrics.java.nonHeapMemorySeriesCommitted": "已提交平均值", - "xpack.apm.agentMetrics.java.nonHeapMemorySeriesUsed": "已使用平均值", - "xpack.apm.agentMetrics.java.threadCount": "平均计数", - "xpack.apm.agentMetrics.java.threadCountChartTitle": "线程计数", - "xpack.apm.agentMetrics.java.threadCountMax": "最大计数", - "xpack.apm.apmDescription": "自动从您的应用程序内收集深入全面的性能指标和错误。", - "xpack.apm.apmForESDescription": "Elastic Stack 的 APM", - "xpack.apm.breadcrumb.errorsTitle": "错误", - "xpack.apm.breadcrumb.metricsTitle": "指标", - "xpack.apm.breadcrumb.servicesTitle": "服务", - "xpack.apm.breadcrumb.tracesTitle": "追溯", - "xpack.apm.breadcrumb.transactionsTitle": "事务", - "xpack.apm.chart.cpuSeries.processAverageLabel": "进程平均值", - "xpack.apm.chart.cpuSeries.processMaxLabel": "进程最大值", - "xpack.apm.chart.cpuSeries.systemAverageLabel": "系统平均值", - "xpack.apm.chart.cpuSeries.systemMaxLabel": "系统最大值", - "xpack.apm.chart.memorySeries.systemAverageLabel": "平均值", - "xpack.apm.chart.memorySeries.systemMaxLabel": "最大值", - "xpack.apm.emptyMessage.noDataFoundDescription": "尝试其他时间范围或重置搜索筛选。", - "xpack.apm.emptyMessage.noDataFoundLabel": "未找到任何数据", - "xpack.apm.errorGroupDetails.culpritLabel": "原因", - "xpack.apm.errorGroupDetails.errorGroupTitle": "错误组 {errorGroupId}", - "xpack.apm.errorGroupDetails.errorOccurrenceTitle": "错误发生", - "xpack.apm.errorGroupDetails.exceptionMessageLabel": "异常消息", - "xpack.apm.errorGroupDetails.logMessageLabel": "日志消息", - "xpack.apm.errorGroupDetails.noErrorsLabel": "未找到任何错误", - "xpack.apm.errorGroupDetails.occurrencesChartLabel": "发生次数", - "xpack.apm.errorGroupDetails.occurrencesLongLabel": "{occCount} 次发生", - "xpack.apm.errorGroupDetails.occurrencesShortLabel": "{occCount} 次发生", - "xpack.apm.errorGroupDetails.unhandledLabel": "未处理", - "xpack.apm.errorGroupDetails.viewOccurrencesInDiscoverButtonLabel": "在 Discover 查看 {occurrencesCount} 个 {occurrencesCount, plural, one {匹配项} other {匹配项}}。", - "xpack.apm.errorsTable.errorMessageAndCulpritColumnLabel": "错误消息和原因", - "xpack.apm.errorsTable.groupIdColumnLabel": "组 ID", - "xpack.apm.errorsTable.latestOccurrenceColumnLabel": "最新一次发生", - "xpack.apm.errorsTable.noErrorsLabel": "未找到任何错误", - "xpack.apm.errorsTable.occurrencesColumnLabel": "发生次数", - "xpack.apm.errorsTable.unhandledLabel": "未处理", - "xpack.apm.featureRegistry.apmFeatureName": "APM", - "xpack.apm.filter.environment.allLabel": "全部", - "xpack.apm.filter.environment.label": "环境", - "xpack.apm.filter.environment.notDefinedLabel": "未定义", - "xpack.apm.filter.environment.selectEnvironmentLabel": "选择环境", - "xpack.apm.formatters.microsTimeUnitLabel": "μs", - "xpack.apm.formatters.millisTimeUnitLabel": "ms", - "xpack.apm.formatters.requestsPerMinLabel": "rpm", - "xpack.apm.formatters.secondsTimeUnitLabel": "s", - "xpack.apm.formatters.minutesTimeUnitLabel": "分钟", - "xpack.apm.formatters.hoursTimeUnitLabel": "h", - "xpack.apm.formatters.transactionsPerMinLabel": "tpm", - "xpack.apm.header.badge.readOnly.text": "只读", - "xpack.apm.header.badge.readOnly.tooltip": "无法保存", - "xpack.apm.helpMenu.upgradeAssistantLink": "升级助手", - "xpack.apm.home.servicesTabLabel": "服务", - "xpack.apm.home.tracesTabLabel": "追溯", - "xpack.apm.invalidLicense.licenseManagementLink": "管理您的许可", - "xpack.apm.invalidLicense.message": "APM UI 不可用,因为您当前的许可已过期或不再有效。", - "xpack.apm.invalidLicense.title": "许可无效", - "xpack.apm.metadataTable.section.agentLabel": "代理", - "xpack.apm.metadataTable.section.containerLabel": "容器", - "xpack.apm.metadataTable.section.customLabel": "定制", - "xpack.apm.metadataTable.section.hostLabel": "主机", - "xpack.apm.metadataTable.section.httpLabel": "HTTP", - "xpack.apm.metadataTable.section.labelsLabel": "标签", - "xpack.apm.metadataTable.section.processLabel": "进程", - "xpack.apm.metadataTable.section.serviceLabel": "服务", - "xpack.apm.metadataTable.section.urlLabel": "URL", - "xpack.apm.metadataTable.section.userLabel": "用户", - "xpack.apm.metrics.plot.noDataLabel": "此时间范围内没有数据。", - "xpack.apm.metrics.transactionChart.machineLearningLabel": "Machine Learning", - "xpack.apm.metrics.transactionChart.machineLearningTooltip": "环绕平均持续时间的流显示预期边界。对 >= 75 的异常分数显示标注。", - "xpack.apm.metrics.transactionChart.pageLoadTimesLabel": "页面加载时间", - "xpack.apm.metrics.transactionChart.requestsPerMinuteLabel": "每分钟请求数", - "xpack.apm.metrics.transactionChart.routeChangeTimesLabel": "路由更改时间", - "xpack.apm.metrics.transactionChart.transactionDurationLabel": "事务持续时间", - "xpack.apm.metrics.transactionChart.transactionsPerMinuteLabel": "每分钟事务数", - "xpack.apm.notAvailableLabel": "不适用", - "xpack.apm.propertiesTable.agentFeature.noDataAvailableLabel": "没有可用数据", - "xpack.apm.propertiesTable.tabs.exceptionStacktraceLabel": "异常堆栈追溯", - "xpack.apm.propertiesTable.tabs.logStacktraceLabel": "日志堆栈追溯", - "xpack.apm.propertiesTable.tabs.metadataLabel": "元数据", - "xpack.apm.propertiesTable.tabs.timelineLabel": "时间线", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.callout.jobExistsDescription": "当前有 {serviceName}({transactionType})的作业正在运行。", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.callout.jobExistsDescription.viewJobLinkText": "查看现有作业", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.callout.jobExistsTitle": "作业已存在", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.createMLJobDescription": "在这里可以创建 Machine Learning 作业以基于 {serviceName} 服务内 APM 事务的持续时间计算异常分数。启用后,一旦异常分数 >=75,{transactionDurationGraphText}将显示预期边界并标注图表。", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.createMLJobDescription.transactionDurationGraphText": "事务持续时间图表", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.createNewJobButtonLabel": "创建新作业", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.enableAnomalyDetectionTitle": "启用异常检测", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.jobCreatedNotificationText": "现在正在运行对 {serviceName}({transactionType})的分析。可能要花费点时间,才会将结果添加响应时间图表。", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.jobCreatedNotificationText.viewJobLinkText": "查看作业", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.jobCreatedNotificationTitle": "作业已成功创建", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.jobCreationFailedNotificationText": "您当前的许可可能不允许创建 Machine Learning 作业,或者此作业可能已存在。", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.jobCreationFailedNotificationTitle": "作业创建失败", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.manageMLJobDescription": "可以创建每个服务 + 事务类型组合的作业。创建作业后,可以在 {mlJobsPageLink}中管理作业以及查看更多详细信息。", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.manageMLJobDescription.mlJobsPageLinkText": "Machine Learning 作业管理页面", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.manageMLJobDescription.noteText": "注意:可能要过几分钟后,作业才会开始计算结果。", - "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.selectTransactionTypeLabel": "为此作业选择事务类型", - "xpack.apm.serviceDetails.enableErrorReportsPanel.actionsDescription": "可以通过电子邮件发送报告或将报告发布到 Slack 频道。每个报告将包括按发生次数排序的前 10 个错误。", - "xpack.apm.serviceDetails.enableErrorReportsPanel.actionsTitle": "操作", - "xpack.apm.serviceDetails.enableErrorReportsPanel.conditionTitle": "条件", - "xpack.apm.serviceDetails.enableErrorReportsPanel.createWatchButtonLabel": "创建监视", - "xpack.apm.serviceDetails.enableErrorReportsPanel.dailyReportHelpText": "每日报告将在 {dailyTimeFormatted} / {dailyTime12HourFormatted} 发送。", - "xpack.apm.serviceDetails.enableErrorReportsPanel.dailyReportRadioButtonLabel": "每日报告", - "xpack.apm.serviceDetails.enableErrorReportsPanel.emailSubjectText": "{serviceName} 具有超过阈值的错误组", - "xpack.apm.serviceDetails.enableErrorReportsPanel.emailTemplateText": "您的服务 {serviceName} 具有在 {timeRange}内发生次数超过 {threshold} 次的错误组{br}{br}{errorGroupsBuckets}{br}{errorLogMessage}{br}{errorCulprit}不适用{slashErrorCulprit}{br}{docCountParam} 次{br}{slashErrorGroupsBucket}", - "xpack.apm.serviceDetails.enableErrorReportsPanel.enableErrorReportsTitle": "启用错误报告", - "xpack.apm.serviceDetails.enableErrorReportsPanel.formDescription": "此表单将帮助创建从此服务向您通知错误发生次数的监视。要详细了解 Watcher,请阅读我们的恶{documentationLink}", - "xpack.apm.serviceDetails.enableErrorReportsPanel.formDescription.documentationLinkText": "文档", - "xpack.apm.serviceDetails.enableErrorReportsPanel.intervalHelpText": "报告时间间隔。", - "xpack.apm.serviceDetails.enableErrorReportsPanel.intervalRadioButtonLabel": "时间间隔", - "xpack.apm.serviceDetails.enableErrorReportsPanel.intervalUnit.hrsLabel": "小时", - "xpack.apm.serviceDetails.enableErrorReportsPanel.intervalUnit.minsLabel": "分钟", - "xpack.apm.serviceDetails.enableErrorReportsPanel.occurrencesThresholdHelpText": "要将错误组包括在报告中所要达到的阈值。", - "xpack.apm.serviceDetails.enableErrorReportsPanel.occurrencesThresholdLabel": "每错误组的发生次数阈值", - "xpack.apm.serviceDetails.enableErrorReportsPanel.recipientsHelpText": "如果未配置电子邮件,请参阅{documentationLink}", - "xpack.apm.serviceDetails.enableErrorReportsPanel.recipientsHelpText.documentationLinkText": "文档", - "xpack.apm.serviceDetails.enableErrorReportsPanel.recipientsLabel": "接收人(逗号分隔)", - "xpack.apm.serviceDetails.enableErrorReportsPanel.sendEmailLabel": "发送电子邮件", - "xpack.apm.serviceDetails.enableErrorReportsPanel.sendSlackNotificationLabel": "发送 Slack 通知", - "xpack.apm.serviceDetails.enableErrorReportsPanel.slackTemplateText": "您的服务 {serviceName} 具有在 {timeRange}内发生次数超过 {threshold} 次的错误组\n{errorGroupsBuckets}\n{errorLogMessage}\n{errorCulprit}不适用{slashErrorCulprit}\n{docCountParam} 次发生\n{slashErrorGroupsBucket}", - "xpack.apm.serviceDetails.enableErrorReportsPanel.slackWebhookURLHelpText": "要获取 Slack Webhook,请参阅{documentationLink}", - "xpack.apm.serviceDetails.enableErrorReportsPanel.slackWebhookURLHelpText.documentationLinkText": "文档", - "xpack.apm.serviceDetails.enableErrorReportsPanel.slackWebhookURLLabel": "Slack Webhook URL", - "xpack.apm.serviceDetails.enableErrorReportsPanel.triggerScheduleDescription": "选择阈值达到时报告的时间间隔。", - "xpack.apm.serviceDetails.enableErrorReportsPanel.triggerScheduleTitle": "触发排定", - "xpack.apm.serviceDetails.enableErrorReportsPanel.triggerText": "必须在触发器部分更改此值", - "xpack.apm.serviceDetails.enableErrorReportsPanel.watchCreatedNotificationText": "监视已就绪,将发送 {serviceName} 的错误报告。", - "xpack.apm.serviceDetails.enableErrorReportsPanel.watchCreatedNotificationText.viewWatchLinkText": "查看监视", - "xpack.apm.serviceDetails.enableErrorReportsPanel.watchCreatedNotificationTitle": "新监视已创建!", - "xpack.apm.serviceDetails.enableErrorReportsPanel.watchCreationFailedNotificationText": "确保您的用户有权创建监视。", - "xpack.apm.serviceDetails.enableErrorReportsPanel.watchCreationFailedNotificationTitle": "监视创建失败", - "xpack.apm.serviceDetails.errorsTabLabel": "错误", - "xpack.apm.serviceDetails.integrationsMenu.enableMLAnomalyDetectionButtonLabel": "启用 ML 异常检测", - "xpack.apm.serviceDetails.integrationsMenu.enableMLAnomalyDetectionButtonTooltip": "为此服务设置 Machine Learning 作业", - "xpack.apm.serviceDetails.integrationsMenu.enableWatcherErrorReportsButtonLabel": "启用 Watcher 错误报告", - "xpack.apm.serviceDetails.integrationsMenu.integrationsButtonLabel": "集成", - "xpack.apm.serviceDetails.integrationsMenu.viewWatchesButtonLabel": "查看现有监视", - "xpack.apm.serviceDetails.metrics.cpuUsageChartTitle": "CPU 使用", - "xpack.apm.serviceDetails.metrics.errorOccurrencesChartTitle": "错误发生次数", - "xpack.apm.serviceDetails.metrics.memoryUsageChartTitle": "系统内存使用", - "xpack.apm.serviceDetails.metricsTabLabel": "指标", - "xpack.apm.serviceDetails.transactionsTabLabel": "事务", - "xpack.apm.serviceOverview.toastText": "您正在运行 Elastic Stack 7.0+,我们检测到来自以前 6.x 版本的不兼容数据。如果想在 APM 中查看,您应迁移这些数据。在以下位置查看更多: ", - "xpack.apm.serviceOverview.toastTitle": "在选定时间范围中检测到旧数据", - "xpack.apm.serviceOverview.upgradeAssistantLink": "升级助手", - "xpack.apm.servicesTable.7xOldDataMessage": "可能还有需要迁移的旧数据。", - "xpack.apm.servicesTable.7xUpgradeServerMessage": "从 7.x 之前的版本升级?确保您已将\n APM 服务器实例升级到至少 7.0。", - "xpack.apm.servicesTable.agentColumnLabel": "代理", - "xpack.apm.servicesTable.avgResponseTimeColumnLabel": "平均响应时间", - "xpack.apm.servicesTable.environmentColumnLabel": "环境", - "xpack.apm.servicesTable.environmentCount": "{environmentCount, plural, one {1 个环境} other {# 个环境}}", - "xpack.apm.servicesTable.errorsPerMinuteColumnLabel": "每分钟错误数", - "xpack.apm.servicesTable.errorsPerMinuteUnitLabel": "错误", - "xpack.apm.servicesTable.nameColumnLabel": "名称", - "xpack.apm.servicesTable.noServicesLabel": "似乎您没有安装任何 APM 服务。让我们添加一些!", - "xpack.apm.servicesTable.notFoundLabel": "未找到任何服务", - "xpack.apm.servicesTable.transactionsPerMinuteColumnLabel": "每分钟事务数", - "xpack.apm.servicesTable.transactionsPerMinuteUnitLabel": "tpm", - "xpack.apm.servicesTable.UpgradeAssistantLink": "通过访问 Kibana 升级助手来了解详情", - "xpack.apm.setupInstructionsButtonLabel": "设置说明", - "xpack.apm.stacktraceTab.localVariablesToogleButtonLabel": "本地变量", - "xpack.apm.stacktraceTab.noStacktraceAvailableLabel": "没有可用的堆栈追溯信息。", - "xpack.apm.toggleHeight.showLessButtonLabel": "显示较少行", - "xpack.apm.toggleHeight.showMoreButtonLabel": "显示更多行", - "xpack.apm.tracesTable.avgResponseTimeColumnLabel": "平均响应时间", - "xpack.apm.tracesTable.impactColumnLabel": "影响", - "xpack.apm.tracesTable.nameColumnLabel": "名称", - "xpack.apm.tracesTable.notFoundLabel": "未找到与此查询的任何追溯信息", - "xpack.apm.tracesTable.originatingServiceColumnLabel": "发起服务", - "xpack.apm.tracesTable.tracesPerMinuteColumnLabel": "每分钟追溯次数", - "xpack.apm.tracesTable.tracesPerMinuteUnitLabel": "tpm", - "xpack.apm.transactionActionMenu.actionsButtonLabel": "操作", - "xpack.apm.transactionActionMenu.actionsLabel": "操作", - "xpack.apm.transactionActionMenu.showContainerLogsLinkLabel": "显示容器日志", - "xpack.apm.transactionActionMenu.showContainerMetricsLinkLabel": "显示容器指标", - "xpack.apm.transactionActionMenu.showHostLogsLinkLabel": "显示主机日志", - "xpack.apm.transactionActionMenu.showHostMetricsLinkLabel": "显示主机指标", - "xpack.apm.transactionActionMenu.showPodLogsLinkLabel": "显示 Pod 日志", - "xpack.apm.transactionActionMenu.showPodMetricsLinkLabel": "显示 Pod 指标", - "xpack.apm.transactionActionMenu.showTraceLogsLinkLabel": "显示跟踪日志", - "xpack.apm.transactionActionMenu.viewInUptime": "查看监测状态", - "xpack.apm.transactionActionMenu.viewSampleDocumentLinkLabel": "查看样例文档", - "xpack.apm.transactionDetails.errorsOverviewLinkTooltip": "{errorCount, plural, one {查看 1 个相关错误} other {查看 # 个相关错误}}", - "xpack.apm.transactionDetails.notFoundLabel": "未找到任何事务。", - "xpack.apm.transactionDetails.noTraceParentButtonTooltip": "找不到上级追溯", - "xpack.apm.transactionDetails.resultLabel": "结果", - "xpack.apm.transactionDetails.serviceLabel": "服务", - "xpack.apm.transactionDetails.servicesTitle": "服务", - "xpack.apm.transactionDetails.spanFlyout.databaseStatementTitle": "数据库语句", - "xpack.apm.transactionDetails.spanFlyout.nameLabel": "名称", - "xpack.apm.transactionDetails.spanFlyout.spanDetailsTitle": "跨度详情", - "xpack.apm.transactionDetails.spanFlyout.spanType.navigationTimingLabel": "导航定时", - "xpack.apm.transactionDetails.spanFlyout.stackTraceTabLabel": "堆栈追溯", - "xpack.apm.transactionDetails.spanFlyout.viewSpanInDiscoverButtonLabel": "在 Discover 中查看跨度", - "xpack.apm.transactionDetails.transactionLabel": "事务", - "xpack.apm.transactionDetails.transactionsDurationDistributionChart.noSampleTooltip": "此存储桶没有可用样例", - "xpack.apm.transactionDetails.transactionsDurationDistributionChart.requestTypeUnitLongLabel": "{transCount, plural, =0 {# 个请求} one {# 个请求} other {# 个请求}}", - "xpack.apm.transactionDetails.transactionsDurationDistributionChart.transactionTypeUnitLongLabel": "{transCount, plural, =0 {# 个事务} one {# 个事务} other {# 个事务}}", - "xpack.apm.transactionDetails.transactionsDurationDistributionChart.unitShortLabel": "{transCount} 个{transType, select, request {请求} other {事务}}", - "xpack.apm.transactionDetails.transactionsDurationDistributionChartTitle": "事务持续时间分布", - "xpack.apm.transactionDetails.transactionsDurationDistributionChartTooltip.samplingDescription": "每个存储桶将显示一个样例事务。如果没有可用的样例,很可能是在代理配置设置了采样限制。", - "xpack.apm.transactionDetails.transactionsDurationDistributionChartTooltip.samplingLabel": "采样", - "xpack.apm.transactionDetails.transFlyout.callout.agentDroppedSpansMessage": "报告此事务的 APM 代理基于其配置丢弃了 {dropped} 个跨度。", - "xpack.apm.transactionDetails.transFlyout.callout.learnMoreAboutDroppedSpansLinkText": "详细了解丢弃的跨度。", - "xpack.apm.transactionDetails.transFlyout.transactionDetailsTitle": "事务详情", - "xpack.apm.transactionDetails.viewFullTraceButtonLabel": "查看完整追溯信息", - "xpack.apm.transactionDetails.viewingFullTraceButtonTooltip": "当前正在查看完整追溯信息", - "xpack.apm.transactions.chart.95thPercentileLabel": "第 95 个百分位", - "xpack.apm.transactions.chart.99thPercentileLabel": "第 99 个百分位", - "xpack.apm.transactions.chart.anomalyBoundariesLabel": "异常边界", - "xpack.apm.transactions.chart.anomalyScoreLabel": "异常分数", - "xpack.apm.transactions.chart.averageLabel": "平均", - "xpack.apm.transactionsTable.95thPercentileColumnLabel": "第 95 个百分位", - "xpack.apm.transactionsTable.avgDurationColumnLabel": "平均持续时间", - "xpack.apm.transactionsTable.impactColumnLabel": "影响", - "xpack.apm.transactionsTable.nameColumnLabel": "名称", - "xpack.apm.transactionsTable.transactionsPerMinuteColumnLabel": "每分钟事务数", - "xpack.apm.transactionsTable.transactionsPerMinuteUnitLabel": "tpm", - "xpack.apm.applyFilter": "应用 {title} 筛选", - "xpack.apm.applyOptions": "应用选项", - "xpack.apm.clearFilters": "清除筛选", - "xpack.apm.datePicker.last15MinutesLabel": "过去 15 分钟", - "xpack.apm.datePicker.last1HourLabel": "过去 1 小时", - "xpack.apm.datePicker.last1YearLabel": "过去 1 年", - "xpack.apm.datePicker.last24HoursLabel": "过去 24 小时", - "xpack.apm.datePicker.last30DaysLabel": "过去 30 天", - "xpack.apm.datePicker.last30MinutesLabel": "过去 30 分钟", - "xpack.apm.datePicker.last7DaysLabel": "过去 7 天", - "xpack.apm.datePicker.last90DaysLabel": "过去 90 天", - "xpack.apm.error.prompt.body": "有关详情,请查看您的浏览器开发者控制台。", - "xpack.apm.error.prompt.title": "抱歉,发生错误 :(", - "xpack.apm.fetcher.error.status": "错误", - "xpack.apm.fetcher.error.title": "提取资源时出错", - "xpack.apm.fetcher.error.url": "URL", - "xpack.apm.localFilters.titles.agentName": "代理名称", - "xpack.apm.localFilters.titles.containerId": "容器 ID", - "xpack.apm.localFilters.titles.host": "主机", - "xpack.apm.localFilters.titles.podName": "Pod", - "xpack.apm.localFilters.titles.transactionResult": "事务结果", - "xpack.apm.localFilters.titles.transactionType": "事务类型", - "xpack.apm.localFiltersTitle": "筛选", - "xpack.apm.metrics.durationByCountryMap.avgPageLoadByCountryLabel": "页面加载平均时长分布(按国家/地区)", - "xpack.apm.metrics.durationByCountryMap.RegionMapChart.ToolTip.avgPageLoadDuration": "页面加载平均时长:", - "xpack.apm.metrics.durationByCountryMap.RegionMapChart.ToolTip.countPageLoads": "{docCount} 个页面加载", - "xpack.apm.settings.agentConf.configTable.editButtonDescription": "编辑此配置", - "xpack.apm.settings.agentConf.configTable.editButtonLabel": "编辑", - "xpack.apm.settings.agentConf.configTable.emptyPromptText": "让我们改动一下!可以直接从 Kibana 微调代理配置,无需重新部署。首先创建您的第一个配置。", - "xpack.apm.settings.agentConf.configTable.emptyPromptTitle": "未找到任何配置。", - "xpack.apm.settings.agentConf.configTable.environmentColumnLabel": "服务环境", - "xpack.apm.settings.agentConf.configTable.lastUpdatedColumnLabel": "最后更新时间", - "xpack.apm.settings.agentConf.configTable.sampleRateColumnLabel": "采样速率", - "xpack.apm.settings.agentConf.configTable.serviceNameColumnLabel": "服务名称", - "xpack.apm.settings.agentConf.configurationsPanelTitle": "代理远程配置", - "xpack.apm.settings.agentConf.createConfigButtonLabel": "创建配置", - "xpack.apm.transactionDetails.traceNotFound": "找不到所选跟踪", - "xpack.apm.transactionDetails.traceSampleTitle": "跟踪样例", - "xpack.apm.transactionsTable.notFoundLabel": "未找到任何事务。", - "xpack.apm.waterfall.exceedsMax": "此跟踪中的项目数超过显示的项目数", - "xpack.apm.agentMetrics.java.gcRate": "GC 速率", - "xpack.apm.agentMetrics.java.gcRateChartTitle": "每分钟垃圾回收率", - "xpack.apm.agentMetrics.java.gcTime": "GC 时间", - "xpack.apm.agentMetrics.java.gcTimeChartTitle": "每分钟花费的垃圾回收时间", - "xpack.apm.breadcrumb.nodesTitle": "JVM", - "xpack.apm.breadcrumb.serviceMapTitle": "服务地图", - "xpack.apm.errorGroupDetails.relatedTransactionSample": "相关的事务样本", - "xpack.apm.home.serviceMapTabLabel": "服务地图", - "xpack.apm.jvmsTable.cpuColumnLabel": "CPU 平均值", - "xpack.apm.jvmsTable.explainServiceNodeNameMissing": "无法识别这些指标属于哪些 JVM。这可能因为运行的 APM Server 版本低于 7.5。如果升级到 APM Server 7.5 或更高版本,应可解决此问题。", - "xpack.apm.jvmsTable.heapMemoryColumnLabel": "堆内存平均值", - "xpack.apm.jvmsTable.nameColumnLabel": "名称", - "xpack.apm.jvmsTable.nameExplanation": "默认情况下,JVM 名称是容器 ID(如果适用)或主机名,但其可以通过代理的“service_node_name”配置手动进行配置。", - "xpack.apm.jvmsTable.noJvmsLabel": "未找到任何 JVM", - "xpack.apm.jvmsTable.nonHeapMemoryColumnLabel": "非堆内存平均值", - "xpack.apm.jvmsTable.threadCountColumnLabel": "线程计数最大值", - "xpack.apm.metadataTable.section.errorLabel": "错误", - "xpack.apm.metadataTable.section.pageLabel": "页", - "xpack.apm.metadataTable.section.spanLabel": "范围", - "xpack.apm.metadataTable.section.traceLabel": "跟踪", - "xpack.apm.metadataTable.section.transactionLabel": "事务", - "xpack.apm.metadataTable.section.userAgentLabel": "用户代理", - "xpack.apm.percentOfParent": "({value} 的 {parentType, select, transaction {事务} trace {trace} })", - "xpack.apm.serviceDetails.nodesTabLabel": "JVM", - "xpack.apm.serviceMap.fullscreen": "全屏", - "xpack.apm.serviceMap.zoomIn": "放大", - "xpack.apm.serviceMap.zoomOut": "缩小", - "xpack.apm.serviceNodeMetrics.containerId": "容器 ID", - "xpack.apm.serviceNodeMetrics.host": "主机", - "xpack.apm.serviceNodeMetrics.unidentifiedServiceNodesWarningDocumentationLink": "APM Server 的文档", - "xpack.apm.serviceNodeMetrics.unidentifiedServiceNodesWarningText": "无法识别这些指标属于哪些 JVM。这可能因为运行的 APM Server 版本低于 7.5。如果升级到 APM Server 7.5 或更高版本,应可解决此问题。有关升级的详细信息,请参阅{link}。或者,也可以使用 Kibana 查询栏按主机名、容器 ID 或其他字段筛选。", - "xpack.apm.serviceNodeMetrics.unidentifiedServiceNodesWarningTitle": "找不到 JVM", - "xpack.apm.serviceNodeNameMissing": "(空)", - "xpack.apm.settings.agentConf.allOptionLabel": "全部", - "xpack.apm.settings.agentConf.cancelButtonLabel": "取消", - "xpack.apm.settings.agentConf.configTable.appliedTooltipMessage": "已至少由一个代理应用", - "xpack.apm.settings.agentConf.configTable.captureBodyColumnLabel": "捕获正文", - "xpack.apm.settings.agentConf.configTable.configTable.failurePromptText": "无法获取代理配置列表。您的用户可能没有足够的权限。", - "xpack.apm.settings.agentConf.configTable.createConfigButtonLabel": "创建配置", - "xpack.apm.settings.agentConf.configTable.notAppliedTooltipMessage": "尚未由任何代理应用", - "xpack.apm.settings.agentConf.configTable.transactionMaxSpansColumnLabel": "事务最大跨度数", - "xpack.apm.settings.agentConf.createConfigTitle": "创建配置", - "xpack.apm.settings.agentConf.editConfigTitle": "编辑配置", - "xpack.apm.settings.agentConf.flyout.deleteSection.buttonLabel": "删除", - "xpack.apm.settings.agentConf.flyout.deleteSection.deleteConfigFailedText": "为“{serviceName}”删除配置时出现问题。错误:“{errorMessage}”", - "xpack.apm.settings.agentConf.flyout.deleteSection.deleteConfigFailedTitle": "配置无法删除", - "xpack.apm.settings.agentConf.flyout.deleteSection.deleteConfigSucceededText": "您已成功为“{serviceName}”删除配置。将需要一些时间才能传播到代理。", - "xpack.apm.settings.agentConf.flyout.deleteSection.deleteConfigSucceededTitle": "配置已删除", - "xpack.apm.settings.agentConf.flyOut.serviceSection.alreadyConfiguredOption": "已配置", - "xpack.apm.settings.agentConf.flyOut.serviceSection.selectPlaceholder": "选择", - "xpack.apm.settings.agentConf.flyOut.serviceSection.serviceEnvironmentSelectHelpText": "每个配置仅支持单个环境。", - "xpack.apm.settings.agentConf.flyOut.serviceSection.serviceEnvironmentSelectLabel": "环境", - "xpack.apm.settings.agentConf.flyOut.serviceSection.serviceNameSelectHelpText": "选择要配置的服务。", - "xpack.apm.settings.agentConf.flyOut.serviceSection.serviceNameSelectLabel": "名称", - "xpack.apm.settings.agentConf.flyOut.serviceSection.title": "服务", - "xpack.apm.settings.agentConf.flyOut.settingsSection.captureBodyInputHelpText": "有关属于 HTTP 请求的事务,代理可以选择性地捕获请求正文(例如 POST 变量)。默认为“off”。", - "xpack.apm.settings.agentConf.flyOut.settingsSection.captureBodyInputLabel": "捕获正文", - "xpack.apm.settings.agentConf.flyOut.settingsSection.captureBodyInputPlaceholderText": "选择选项", - "xpack.apm.settings.agentConf.flyOut.settingsSection.sampleRateConfigurationInputErrorText": "采样速率必须介于 0.000 和 1 之间", - "xpack.apm.settings.agentConf.flyOut.settingsSection.sampleRateConfigurationInputHelpText": "选择 0.000 和 1.0 之间的速率。默认为 1.0(100% 的跟踪)。", - "xpack.apm.settings.agentConf.flyOut.settingsSection.sampleRateConfigurationInputLabel": "事务采样速率", - "xpack.apm.settings.agentConf.flyOut.settingsSection.sampleRateConfigurationInputPlaceholderText": "设置采样速率", - "xpack.apm.settings.agentConf.flyOut.settingsSection.title": "选项", - "xpack.apm.settings.agentConf.flyOut.settingsSection.transactionMaxSpansConfigInputErrorText": "必须介于 0 和 32000 之间", - "xpack.apm.settings.agentConf.flyOut.settingsSection.transactionMaxSpansConfigInputHelpText": "限制每个事务记录的跨度数量。默认值为 500。", - "xpack.apm.settings.agentConf.flyOut.settingsSection.transactionMaxSpansConfigInputLabel": "事务最大跨度数", - "xpack.apm.settings.agentConf.flyOut.settingsSection.transactionMaxSpansConfigInputPlaceholderText": "设置事务最大跨度数", - "xpack.apm.settings.agentConf.saveConfig.failed.text": "编辑“{serviceName}”的配置时出现问题。错误:“{errorMessage}”", - "xpack.apm.settings.agentConf.saveConfig.failed.title": "配置无法编辑", - "xpack.apm.settings.agentConf.saveConfig.succeeded.text": "“{serviceName}”的配置已保存。将需要一些时间才能传播到代理。", - "xpack.apm.settings.agentConf.saveConfig.succeeded.title": "配置已保存", - "xpack.apm.settings.agentConf.saveConfigurationButtonLabel": "保存", - "xpack.apm.tracesTable.impactColumnDescription": "服务中最常用的和最慢的终端节点。其计算方法是相对平均持续时间乘以每分钟事务数。", - "xpack.apm.transactionBreakdown.noData": "此时间范围内没有数据。", - "xpack.apm.transactionDetails.errorCount": "{errorCount, number} 个 {errorCount, plural, one {错误} other {错误}}", - "xpack.apm.transactionDetails.requestMethodLabel": "请求方法", - "xpack.apm.transactionDetails.spanFlyout.spanAction": "操作", - "xpack.apm.transactionDetails.spanFlyout.spanSubtype": "子类型", - "xpack.apm.transactionDetails.spanFlyout.spanType": "类型", - "xpack.apm.transactionDetails.statusCode": "状态代码", - "xpack.apm.transactionDetails.userAgentAndVersionLabel": "用户代理和版本", - "xpack.apm.transactionDurationLabel": "持续时间", - "xpack.apm.transactionsTable.impactColumnDescription": "服务中最常用的和最慢的终端节点。其计算方法是相对平均持续时间乘以每分钟事务数。", - "xpack.apm.transactionDetails.percentOfTraceLabelExplanation": "{parentType, select, transaction {事务} trace {trace} } 的 % 超过 100%,因为此{childType, select, span {跨度} transaction {transaction} }比根事务花费更长时间。", - "xpack.beatsManagement.beat.actionSectionTypeLabel": "类型:{beatType}。", - "xpack.beatsManagement.beat.actionSectionVersionLabel": "版本:{beatVersion}。", - "xpack.beatsManagement.beat.beatNameAndIdTitle": "Beat:{nameOrNoName}(ID:{id})", - "xpack.beatsManagement.beat.beatNotFoundErrorMessage": "未找到 Beat", - "xpack.beatsManagement.beat.beatNotFoundErrorTitle": "未找到 Beat", - "xpack.beatsManagement.beat.beatNotFoundMessage": "未找到 Beat", - "xpack.beatsManagement.beat.configTabLabel": "配置", - "xpack.beatsManagement.beat.configurationTagsTabLabel": "配置标记", - "xpack.beatsManagement.beat.detailsConfigurationDescription": "可以将多个配置应用到单个标记。这些配置类型可以根据需要进行重复或混合。例如,您可以同时使用三个 Metricbeat 配置和一个输入和 Filebeat 配置。", - "xpack.beatsManagement.beat.detailsConfigurationTitle": "配置", - "xpack.beatsManagement.beat.lastConfigUpdateMessage": "上次配置更新:{lastUpdateTime}。", - "xpack.beatsManagement.beat.loadingTitle": "正在加载", - "xpack.beatsManagement.beatConfigurations.descriptionColumnName": "描述", - "xpack.beatsManagement.beatConfigurations.moduleColumnName": "模块", - "xpack.beatsManagement.beatConfigurations.tagColumnName": "标签", - "xpack.beatsManagement.beatConfigurations.typeColumnName": "类型", - "xpack.beatsManagement.beats.addedNotificationDescription": "将标记 {tag} 添加到 {assignmentsLength, plural, one {个 Beat {beatName}} other {# 个 Beats}}。", - "xpack.beatsManagement.beats.addedNotificationTitle": "{assignmentsLength, plural, one {个标记} other {个标记}}已添加", - "xpack.beatsManagement.beats.beatDisenrolledNotificationDescription": "ID 为 {firstBeatId} 的 Beat 已除名。", - "xpack.beatsManagement.beats.beatDisenrolledNotificationTitle": "{firstBeatNameOrId} 已除名", - "xpack.beatsManagement.beats.configurationTagsTabTitle": "配置标记", - "xpack.beatsManagement.beats.disenrolledBeatsNotificationTitle": "{beatsLength} 个 Beats 已除名", - "xpack.beatsManagement.beats.enrollBeatsButtonLabel": "注册 Beats", - "xpack.beatsManagement.beats.enrolledBeatsTabTitle": "已注册 Beats", - "xpack.beatsManagement.beats.enrollNewBeatsTitle": "注册新 Beat", - "xpack.beatsManagement.beats.installBeatsLearningButtonLabel": "了解如何安装 Beats", - "xpack.beatsManagement.beats.removedNotificationDescription": "已从 {assignmentsLength, plural, one {Beat {beatName}} other {# 个 Beat}} 移除标记 {tag}", - "xpack.beatsManagement.beats.removedNotificationTitle": "{assignmentsLength, plural, one {个标记} other {个标记}}已删除", - "xpack.beatsManagement.beatsListAssignmentOptions.setTagsButtonLabel": "设置标记", - "xpack.beatsManagement.beatsListAssignmentOptions.unenrollBeatsWarninigMessage": "选定的 Beats 将不再使用集中管理", - "xpack.beatsManagement.beatsListAssignmentOptions.unenrollBeatsWarninigTitle": "取消注册选定的 Beats?", - "xpack.beatsManagement.beatsListAssignmentOptions.unenrollButtonLabel": "取消注册选定", - "xpack.beatsManagement.beatsTable.beatNameTitle": "Beat 名称", - "xpack.beatsManagement.beatsTable.configErrorStatusLabel": "配置错误", - "xpack.beatsManagement.beatsTable.configStatus.errorTooltip": "此 Beat 有错误,请查看此主机的日志。", - "xpack.beatsManagement.beatsTable.configStatus.noConnectionTooltip": "此 Beat 未连接到 Kibana 的时间已超过 10 分钟", - "xpack.beatsManagement.beatsTable.configStatus.notStartedLabel": "未开始", - "xpack.beatsManagement.beatsTable.configStatus.notStartedTooltip": "此 Beat 尚未启动。", - "xpack.beatsManagement.beatsTable.configStatus.offlineLabel": "脱机", - "xpack.beatsManagement.beatsTable.configStatus.okLabel": "确定", - "xpack.beatsManagement.beatsTable.configStatus.okTooltip": "Beat 成功应用最新的配置", - "xpack.beatsManagement.beatsTable.configStatus.progressTooltip": "此 Beat 当前正在从 CM 重新加载配置。", - "xpack.beatsManagement.beatsTable.configStatus.runningTooltip": "此 Beat 正在运行,没有任何问题。", - "xpack.beatsManagement.beatsTable.configStatus.startingTooltip": "此 Beat 正在启动。", - "xpack.beatsManagement.beatsTable.configStatusTitle": "配置状态", - "xpack.beatsManagement.beatsTable.disenrollSelectedLabel": "取消注册选定", - "xpack.beatsManagement.beatsTable.failedStatusLabel": "错误", - "xpack.beatsManagement.beatsTable.runningStatusLabel": "正在运行", - "xpack.beatsManagement.beatsTable.startingStatusLabel": "正在启动", - "xpack.beatsManagement.beatsTable.stoppedStatusLabel": "已停止", - "xpack.beatsManagement.beatsTable.tagsTitle": "标记", - "xpack.beatsManagement.beatsTable.typeLabel": "类型", - "xpack.beatsManagement.beatsTable.typeTitle": "类型", - "xpack.beatsManagement.beatsTable.updatingStatusLabel": "正在更新", - "xpack.beatsManagement.beatTagsTable.addTagLabel": "添加标记", - "xpack.beatsManagement.beatTagsTable.lastUpdateTitle": "上次更新", - "xpack.beatsManagement.beatTagsTable.removeSelectedLabel": "删除选定", - "xpack.beatsManagement.beatTagsTable.tagNameTitle": "标记名称", - "xpack.beatsManagement.breadcrumb.beatDetails": "{beatId} 的 Beat 详情", - "xpack.beatsManagement.breadcrumb.beatTags": "{beatId} 的 Beat 标记", - "xpack.beatsManagement.breadcrumb.configurationTags": "配置标记", - "xpack.beatsManagement.breadcrumb.enrolledBeats": "已注册 Beats", - "xpack.beatsManagement.centralManagementLinkLabel": "集中管理", - "xpack.beatsManagement.centralManagementSectionLabel": "Beats", - "xpack.beatsManagement.config.other.error": "使用有效的 YAML 格式", - "xpack.beatsManagement.config.otherConfigDescription": "使用 YAML 格式指定 Filebeat 输入的其他设置", - "xpack.beatsManagement.config.otherConfigLabel": "其他配置", - "xpack.beatsManagement.confirmModal.cancelButtonLabel": "取消", - "xpack.beatsManagement.confirmModal.confirmButtonLabel": "确认", - "xpack.beatsManagement.confirmModal.confirmWarningTitle": "确认", - "xpack.beatsManagement.createTag.errorSavingTagTitle": "保存标记时出错", - "xpack.beatsManagement.createTag.saveAndContinueButtonLabel": "保存并继续", - "xpack.beatsManagement.disabledSecurityDescription": "必须在 Kibana 和 Elasticsearch 启用安全性,才能使用 Beats 集中管理。", - "xpack.beatsManagement.disabledSecurityTitle": "安全性未启用", - "xpack.beatsManagement.enrollBeat.assignTagToBeatInvalidURLNoTagFoundTitle": "URL 无效,未找到 createdTag", - "xpack.beatsManagement.enrollBeat.assignTagToBeatInvalidURLNoTokenFountTitle": "URL 无效,未找到 enrollmentToken", - "xpack.beatsManagement.enrollBeat.assignTagToBeatNotEnrolledProperlyTitle": "错误:Beat 未正确注册", - "xpack.beatsManagement.enrollBeat.beatEnrolledTitle": "该 Beat 当前已在集中管理中注册:", - "xpack.beatsManagement.enrollBeat.beatsCentralManagementDescription": "在集中位置管理您的配置。", - "xpack.beatsManagement.enrollBeat.beatTypeColumnName": "Beat 类型", - "xpack.beatsManagement.enrollBeat.beatTypeTitle": "Beat 类型:", - "xpack.beatsManagement.enrollBeat.copyButtonLabel": "复制命令", - "xpack.beatsManagement.enrollBeat.createTagStepLabel": "创建标记", - "xpack.beatsManagement.enrollBeat.enrollBeatButtonLabel": "注册 Beat", - "xpack.beatsManagement.enrollBeat.enrollBeatStepLabel": "注册 Beat", - "xpack.beatsManagement.enrollBeat.finishStepLabel": "完成", - "xpack.beatsManagement.enrollBeat.firstBeatEnrollingDoneButtonLabel": "完成", - "xpack.beatsManagement.enrollBeat.getStartedBeatsCentralManagementTitle": "开始使用 Beats 集中管理", - "xpack.beatsManagement.enrollBeat.hostnameColumnName": "主机名", - "xpack.beatsManagement.enrollBeat.nextStepDescription": "启动您的 Beat 以检查是否有配置错误,然后单击“完成”。", - "xpack.beatsManagement.enrollBeat.nextStepTitle": "您的 Beat 已注册。后续操作", - "xpack.beatsManagement.enrollBeat.platformTitle": "平台:", - "xpack.beatsManagement.enrollBeat.versionColumnName": "版本", - "xpack.beatsManagement.enrollBeat.waitingBeatTypeToEnrollTitle": "正在等待注册 {beatType}……", - "xpack.beatsManagement.enrollBeat.yourBeatTypeHostTitle": "在安装您的 {beatType} 的主机上,运行:", - "xpack.beatsManagement.filebeatInputConfig.otherConfigDescription": "使用 YAML 格式指定 Filebeat 输入的其他设置", - "xpack.beatsManagement.filebeatInputConfig.otherConfigErrorMessage": "使用有效的 YAML 格式", - "xpack.beatsManagement.filebeatInputConfig.otherConfigLabel": "其他配置", - "xpack.beatsManagement.filebeatInputConfig.pathsDescription": "将每个路径放置在单独的行上", - "xpack.beatsManagement.filebeatInputConfig.pathsErrorMessage": "每行一个文件路径", - "xpack.beatsManagement.filebeatInputConfig.pathsLabel": "路径", - "xpack.beatsManagement.filebeatModuleConfig.moduleDescription": "使用 YAML 格式指定 Filebeat 模块的其他设置", - "xpack.beatsManagement.filebeatModuleConfig.moduleErrorMessage": "请选择模块", - "xpack.beatsManagement.filebeatModuleConfig.moduleLabel": "模块", - "xpack.beatsManagement.filebeatModuleConfig.otherConfigErrorMessage": "使用有效的 YAML 格式", - "xpack.beatsManagement.filebeatModuleConfig.otherConfigLabel": "其他配置", - "xpack.beatsManagement.invalidLicenseDescription": "您当前的许可已过期。已注册 Beats 将继续工作,但您需要有效的许可,才能访问 Beats 管理 UI。", - "xpack.beatsManagement.invalidLicenseTitle": "已过期许可", - "xpack.beatsManagement.management.breadcrumb": "管理", - "xpack.beatsManagement.metricbeatModuleConfig.hostsDescription": "将每个路径放置在单独的行上", - "xpack.beatsManagement.metricbeatModuleConfig.hostsErrorMessage": "每行一个文件主机", - "xpack.beatsManagement.metricbeatModuleConfig.hostsLabel": "主机", - "xpack.beatsManagement.metricbeatModuleConfig.moduleErrorMessage": "请选择模块", - "xpack.beatsManagement.metricbeatModuleConfig.moduleLabel": "模块", - "xpack.beatsManagement.metricbeatModuleConfig.otherConfigDescription": "使用 YAML 格式指定 Metricbeat 模块的其他设置", - "xpack.beatsManagement.metricbeatModuleConfig.otherConfigErrorMessage": "使用有效的 YAML 格式", - "xpack.beatsManagement.metricbeatModuleConfig.otherConfigLabel": "其他配置", - "xpack.beatsManagement.metricbeatModuleConfig.periodErrorMessage": "期间无效,10 秒的格式必须为 `10s`。", - "xpack.beatsManagement.metricbeatModuleConfig.periodLabel": "期间", - "xpack.beatsManagement.noAccess.accessDeniedDescription": "您无权访问 Beats 集中管理。要使用 Beats 集中管理,您需要 {beatsAdminRole} 角色授予的权限。", - "xpack.beatsManagement.noAccess.accessDeniedTitle": "访问被拒绝", - "xpack.beatsManagement.noContentFoundErrorMessage": "未找到任何内容", - "xpack.beatsManagement.outputConfig.hostsErrorMessage": "每行一个文件主机", - "xpack.beatsManagement.outputConfig.hostsLabel": "主机", - "xpack.beatsManagement.outputConfig.outputTypeErrorMessage": "请选择输出类型", - "xpack.beatsManagement.outputConfig.outputTypeLabel": "输出类型", - "xpack.beatsManagement.outputConfig.passwordErrorMessage": "无法处理的密码", - "xpack.beatsManagement.outputConfig.passwordLabel": "密码", - "xpack.beatsManagement.outputConfig.usernameErrorMessage": "无法处理的用户名", - "xpack.beatsManagement.outputConfig.usernameLabel": "用户名", - "xpack.beatsManagement.overview.betaBadgeText": "公测版", - "xpack.beatsManagement.table.filterResultsPlaceholder": "筛选结果", - "xpack.beatsManagement.table.selectOptionLabel": "请选择选项", - "xpack.beatsManagement.table.selectThisBeatTooltip": "选择此 Beat", - "xpack.beatsManagement.tag.addConfigurationButtonLabel": "添加配置块", - "xpack.beatsManagement.tag.beatsAssignedToTagTitle": "具有此标记的 Beats", - "xpack.beatsManagement.tag.cancelButtonLabel": "取消", - "xpack.beatsManagement.tag.createTagTitle": "创建标记", - "xpack.beatsManagement.tag.saveButtonLabel": "保存", - "xpack.beatsManagement.tag.tagColorLabel": "标记颜色", - "xpack.beatsManagement.tag.tagConfigurationsDescription": "标记可以有不同类型 Beats 的配置块。例如,标记可以有两个 Metricbeat 配置块和一个 Filebeat 输入配置块。", - "xpack.beatsManagement.tag.tagConfigurationsTitle": "配置块", - "xpack.beatsManagement.tag.tagDetailsDescription": "标记是可以应用到一个或多个 Beats 的一组配置块。", - "xpack.beatsManagement.tag.tagDetailsTitle": "标记详情", - "xpack.beatsManagement.tag.tagName.validationErrorMessage": "标记名称只能由字母、数字和短划线构成", - "xpack.beatsManagement.tag.tagNameLabel": "标记名称", - "xpack.beatsManagement.tag.tagNamePlaceholder": "标记名称(必填)", - "xpack.beatsManagement.tag.updateTagTitle": "创建标记:{tagId}", - "xpack.beatsManagement.tagConfig.addConfigurationTitle\"": "添加配置块", - "xpack.beatsManagement.tagConfig.closeButtonLabel": "关闭", - "xpack.beatsManagement.tagConfig.configurationTypeText": "{configType} 配置", - "xpack.beatsManagement.tagConfig.descriptionLabel": "描述", - "xpack.beatsManagement.tagConfig.descriptionPlaceholder": "描述(可选)", - "xpack.beatsManagement.tagConfig.editConfigurationTitle": "编辑配置块", - "xpack.beatsManagement.tagConfig.filebeatInputLabel": "Filebeat 输入", - "xpack.beatsManagement.tagConfig.filebeatModuleLabel": "Filebeat 模块", - "xpack.beatsManagement.tagConfig.invalidSchema": "错误:此配置无效,其不受 Beats 支持,应移除", - "xpack.beatsManagement.tagConfig.metricbeatModuleLabel": "Metricbeat 模块", - "xpack.beatsManagement.tagConfig.outputLabel": "输出", - "xpack.beatsManagement.tagConfig.saveButtonLabel": "保存", - "xpack.beatsManagement.tagConfig.typeLabel": "类型", - "xpack.beatsManagement.tagConfig.viewConfigurationTitle\"": "查看配置块", - "xpack.beatsManagement.tagConfigAssignmentOptions.removeTagsButtonLabel": "删除标记", - "xpack.beatsManagement.tagConfigAssignmentOptions.removeTagsWarninigMessage": "从选定 Beats 删除该标记?", - "xpack.beatsManagement.tagConfigAssignmentOptions.removeTagsWarninigTitle": "删除标记", - "xpack.beatsManagement.tagListAssignmentOptions.removeTagsButtonLabel": "删除选定", - "xpack.beatsManagement.tagListAssignmentOptions.removeTagsWarninigTitle": "删除标记", - "xpack.beatsManagement.tagListAssignmentOptions.removeTagWarninigMessage": "删除标记?", - "xpack.beatsManagement.tags.addTagButtonLabel": "添加标记", - "xpack.beatsManagement.tags.someTagsMightBeAssignedToBeatsTitle": "以下部分标记可能已分配给 Beats。请确保正要删除的标记未分配", - "xpack.beatsManagement.tagsTable.lastUpdateTitle": "上次更新", - "xpack.beatsManagement.tagsTable.removeSelectedLabel": "删除选定", - "xpack.beatsManagement.tagsTable.tagNameTitle": "标记名称", - "xpack.beatsManagement.tagTable.actions.removeButtonAriaLabel": "删除", - "xpack.beatsManagement.tagTable.actions.removeTooltip": "从标记删除此配置", - "xpack.beatsManagement.tagTable.actionsColumnName": "操作", - "xpack.beatsManagement.tagTable.descriptionColumnName": "描述", - "xpack.beatsManagement.tagTable.moduleColumn.notAvailibaleLabel": "不适用", - "xpack.beatsManagement.tagTable.moduleColumnName": "模块", - "xpack.beatsManagement.tagTable.typeColumnName": "类型", - "xpack.beatsManagement.walkthrough.initial.betaBadgeText": "公测版", - "xpack.canvas.badge.readOnly.text": "只读", - "xpack.canvas.elements.areaChartDisplayName": "面积图", - "xpack.canvas.elements.areaChartHelpText": "已填充主体的折线图", - "xpack.canvas.elements.bubbleChartDisplayName": "气泡图", - "xpack.canvas.elements.bubbleChartHelpText": "可定制的气泡图", - "xpack.canvas.elements.debugDisplayName": "“Debug”(故障排查)", - "xpack.canvas.elements.debugHelpText": "只需丢弃元素的配置", - "xpack.canvas.elements.donutChartDisplayName": "圆环图", - "xpack.canvas.elements.donutChartHelpText": "可定制的圆环图", - "xpack.canvas.elements.dropdownFilterDisplayName": "下拉列表筛选", - "xpack.canvas.elements.dropdownFilterHelpText": "可以从其中为“完全”筛选选择值的下拉列表", - "xpack.canvas.elements.horizontalBarChartDisplayName": "水平条形图", - "xpack.canvas.elements.horizontalBarChartHelpText": "可定制的水平条形图", - "xpack.canvas.elements.horizontalProgressBarDisplayName": "水平进度条", - "xpack.canvas.elements.horizontalProgressBarHelpText": "将进度显示为水平条的一部分", - "xpack.canvas.elements.horizontalProgressPillDisplayName": "水平进度胶囊", - "xpack.canvas.elements.horizontalProgressPillHelpText": "将进度显示为水平胶囊的一部分", - "xpack.canvas.elements.imageDisplayName": "图像", - "xpack.canvas.elements.imageHelpText": "静态图像", - "xpack.canvas.elements.lineChartDisplayName": "折线图", - "xpack.canvas.elements.lineChartHelpText": "可定制的折线图", - "xpack.canvas.elements.markdownDisplayName": "Markdown", - "xpack.canvas.elements.markdownHelpText": "来自 Markdown 的标记", - "xpack.canvas.elements.metricDisplayName": "指标", - "xpack.canvas.elements.metricHelpText": "具有标签的数字", - "xpack.canvas.elements.pieDisplayName": "饼图", - "xpack.canvas.elements.pieHelpText": "饼图", - "xpack.canvas.elements.plotDisplayName": "坐标图", - "xpack.canvas.elements.plotHelpText": "混合的折线图、条形图或点图", - "xpack.canvas.elements.progressGaugeDisplayName": "进度仪表", - "xpack.canvas.elements.progressGaugeHelpText": "将进度显示为仪表的一部分", - "xpack.canvas.elements.progressSemicircleDisplayName": "进度半圆", - "xpack.canvas.elements.progressSemicircleHelpText": "将进度显示为半圆的一部分", - "xpack.canvas.elements.progressWheelDisplayName": "进度轮盘", - "xpack.canvas.elements.progressWheelHelpText": "将进度显示为轮盘的一部分", - "xpack.canvas.elements.repeatImageDisplayName": "图像重复", - "xpack.canvas.elements.repeatImageHelpText": "使图像重复 N 次", - "xpack.canvas.elements.revealImageDisplayName": "图像显示", - "xpack.canvas.elements.revealImageHelpText": "显示图像特定百分比", - "xpack.canvas.elements.shapeDisplayName": "形状", - "xpack.canvas.elements.shapeHelpText": "可定制的形状", - "xpack.canvas.elements.tableDisplayName": "数据表", - "xpack.canvas.elements.tableHelpText": "用于以表格形式显示数据的可滚动网格", - "xpack.canvas.elements.tiltedPieDisplayName": "斜饼图", - "xpack.canvas.elements.tiltedPieHelpText": "可定制的斜饼图", - "xpack.canvas.elements.timeFilterDisplayName": "时间筛选", - "xpack.canvas.elements.timeFilterHelpText": "设置时间窗口", - "xpack.canvas.elements.verticalBarChartDisplayName": "垂直条形图", - "xpack.canvas.elements.verticalBarChartHelpText": "可定制的垂直条形图", - "xpack.canvas.elements.verticalProgressBarDisplayName": "垂直进度条", - "xpack.canvas.elements.verticalProgressBarHelpText": "将进度显示为垂直条的一部分", - "xpack.canvas.elements.verticalProgressPillDisplayName": "垂直进度胶囊", - "xpack.canvas.elements.verticalProgressPillHelpText": "将进度显示为垂直胶囊的一部分", - "xpack.canvas.functions.alterColumn.args.columnHelpText": "要更改的列的名称。", - "xpack.canvas.functions.alterColumn.args.nameHelpText": "结果列名称。留空将不重命名。", - "xpack.canvas.functions.alterColumn.args.typeHelpText": "将列转换成的类型。留空将不更改类型。", - "xpack.canvas.functions.alterColumn.cannotConvertTypeErrorMessage": "无法连接到“{type}”", - "xpack.canvas.functions.alterColumn.columnNotFoundErrorMessage": "找不到列:“{column}”", - "xpack.canvas.functions.as.args.nameHelpText": "要给予列的名称。", - "xpack.canvas.functions.axisConfig.args.showHelpText": "显示轴标签?", - "xpack.canvas.functions.axisConfig.args.tickSizeHelpText": "刻度间的增量大小。仅用于`数值`轴", - "xpack.canvas.functions.axisConfig.invalidMaxPositionErrorMessage": "日期字符串无效:“{max}”。“max”必须是数值、以毫秒为单位的日期或 ISO8601 日期字符串", - "xpack.canvas.functions.axisConfig.invalidMinDateStringErrorMessage": "日期字符串无效:“{min}”。“min”必须是数值、以毫秒为单位的日期或 ISO8601 日期字符串", - "xpack.canvas.functions.axisConfig.invalidPositionErrorMessage": "无效的位置:“{position}”", - "xpack.canvas.functions.case.args.thenHelpText": "条件得到满足时要返回的值。", - "xpack.canvas.functions.compare.args.opHelpText": "要用于比较的运算符:{eq}(等于)、{gt}(大于)、{gte}(大于或等于)、{lt}(小于)、{lte}(小于或等于)、{ne} 或 {neq}(不等于)。", - "xpack.canvas.functions.compare.invalidCompareOperatorErrorMessage": "无效的比较运算符:“{op}”。使用 {ops}", - "xpack.canvas.functions.containerStyle.args.borderRadiusHelpText": "设置圆角时要使用的像素数。", - "xpack.canvas.functions.containerStyle.args.opacityHelpText": "0 和 1 之间的数值,表示元素的透明度。", - "xpack.canvas.functions.containerStyle.args.paddingHelpText": "内容与边框的距离(像素)。", - "xpack.canvas.functions.containerStyle.invalidBackgroundImageErrorMessage": "无效的背景图。请提供资产或 URL。", - "xpack.canvas.functions.csv.args.delimeterHelpText": "数据分隔字符。", - "xpack.canvas.functions.csv.args.newlineHelpText": "行分隔字符。", - "xpack.canvas.functions.csv.invalidInputCSVErrorMessage": "解析输入 CSV 时出错。", - "xpack.canvas.functions.date.invalidDateInputErrorMessage": "无效的日期输入:{date}", - "xpack.canvas.functions.dateHelpText": "将当前时间或从指定字符串解析的时间返回为自 Epoch 起毫秒数。", - "xpack.canvas.functions.demodata.args.typeHelpText": "要使用的演示数据集的名称。", - "xpack.canvas.functions.demodata.invalidDataSetErrorMessage": "无效的数据集:“{arg}”,请使用“{ci}”或“{shirts}”。", - "xpack.canvas.functions.demodataHelpText": "包含项目 {ci} 时间以及用户名、国家/地区以及运行阶段的模拟数据集。", - "xpack.canvas.functions.dropdownControl.args.filterColumnHelpText": "要筛选的列或字段。", - "xpack.canvas.functions.dropdownControl.args.filterGroupHelpText": "筛选的组名称。", - "xpack.canvas.functions.dropdownControl.args.valueColumnHelpText": "从其中提取下拉列表唯一值的列或字段。", - "xpack.canvas.functions.dropdownControlHelpText": "配置下拉列表筛选控制元素。", - "xpack.canvas.functions.escount.args.indexHelpText": "索引或索引模式。例如:{example}。", - "xpack.canvas.functions.esdocs.args.countHelpText": "要检索的文档数目。要获取更佳的性能,请使用较小的数据集。", - "xpack.canvas.functions.esdocs.args.fieldsHelpText": "字段逗号分隔列表。要获取更佳的性能,请使用较少的字段。", - "xpack.canvas.functions.esdocs.args.indexHelpText": "索引或索引模式。例如:{example}。", - "xpack.canvas.functions.esdocs.args.metaFieldsHelpText": "元字段逗号分隔列表。例如:{example}。", - "xpack.canvas.functions.esdocs.args.sortHelpText": "格式为 {directions} 的排序方向。例如 {example1} 或 {example2}。", - "xpack.canvas.functions.essql.args.countHelpText": "要检索的文档数目。要获取更佳的性能,请使用较小的数据集。", - "xpack.canvas.functions.exactly.args.columnHelpText": "要筛选的列或字段。", - "xpack.canvas.functions.exactly.args.valueHelpText": "要完全匹配的值,包括空格和大写。", - "xpack.canvas.functions.exactlyHelpText": "创建使给定列匹配确切值的筛选。", - "xpack.canvas.functions.getCell.args.rowHelpText": "行编号,从 0 开始。", - "xpack.canvas.functions.getCell.columnNotFoundErrorMessage": "找不到列:“{column}”", - "xpack.canvas.functions.getCell.rowNotFoundErrorMessage": "找不到行:“{row}”", - "xpack.canvas.functions.ifHelpText": "执行条件逻辑", - "xpack.canvas.functions.image.args.modeHelpText": "{contain} 将显示整个图像,图像缩放至适合大小。{cover} 将使用该图像填充容器,根据需要在两边或底部裁剪图像。{stretch} 将图像的高和宽调整为容器的 100%。", - "xpack.canvas.functions.image.invalidImageModeErrorMessage": "“mode”必须为“{contain}”、“{cover}”或“{stretch}”", - "xpack.canvas.functions.mapColumn.args.nameHelpText": "结果列的名称。", - "xpack.canvas.functions.math.emptyDatatableErrorMessage": "空数据表", - "xpack.canvas.functions.math.emptyExpressionErrorMessage": "空表达式", - "xpack.canvas.functions.math.executionFailedErrorMessage": "无法执行数学表达式。检查您的列名称", - "xpack.canvas.functions.math.tooManyResultsErrorMessage": "表达式必须返回单个数字。尝试将您的表达式包装在 {mean} 或 {sum} 中", - "xpack.canvas.functions.metric.args.labelHelpText": "描述指标的文本。", - "xpack.canvas.functions.metricHelpText": "在标签上显示数字。", - "xpack.canvas.functions.palette.args.gradientHelpText": "受支持时提供渐变的调色板?", - "xpack.canvas.functions.palette.args.reverseHelpText": "反转调色板?", - "xpack.canvas.functions.paletteHelpText": "创建颜色调色板。", - "xpack.canvas.functions.pie.args.holeHelpText": "在饼图中绘制介于 `0` and `100`(饼图半径的百分比)之间的孔洞。", - "xpack.canvas.functions.pie.args.labelRadiusHelpText": "要用作标签圆形半径的容器面积百分比。", - "xpack.canvas.functions.pie.args.labelsHelpText": "显示饼图标签?", - "xpack.canvas.functions.pie.args.radiusHelpText": "饼图的半径,表示为可用空间的百分比(介于 `0` 和 `1` 之间)。要自动设置半径,请使用 {auto}。", - "xpack.canvas.functions.pie.args.seriesStyleHelpText": "特定序列的样式", - "xpack.canvas.functions.pie.args.tiltHelpText": "倾斜百分比,其中 `1` 为完全垂直,`0` 为完全水平。", - "xpack.canvas.functions.pieHelpText": "配置饼图元素。", - "xpack.canvas.functions.plot.args.defaultStyleHelpText": "要用于每个序列的默认样式。", - "xpack.canvas.functions.plot.args.seriesStyleHelpText": "特定序列的样式", - "xpack.canvas.functions.ply.columnNotFoundErrorMessage": "找不到列:“{by}”", - "xpack.canvas.functions.ply.rowCountMismatchErrorMessage": "所有表达式必须返回相同数目的行", - "xpack.canvas.functions.pointseries.args.colorHelpText": "要用于确定标记颜色的表达式。", - "xpack.canvas.functions.pointseries.args.sizeHelpText": "标记的大小。仅适用于支持的元素。", - "xpack.canvas.functions.pointseries.args.textHelpText": "要在标记上显示的文本。仅适用于支持的元素。", - "xpack.canvas.functions.pointseries.args.xHelpText": "X 轴上的值。", - "xpack.canvas.functions.pointseries.args.yHelpText": "Y 轴上的值。", - "xpack.canvas.functions.pointseries.unwrappedExpressionErrorMessage": "表达式必须包装在函数中,例如 {fn}", - "xpack.canvas.functions.progress.args.barColorHelpText": "背景条形的颜色。", - "xpack.canvas.functions.progress.args.barWeightHelpText": "背景条形的粗细。", - "xpack.canvas.functions.progress.args.maxHelpText": "进度元素的最大值。", - "xpack.canvas.functions.progress.args.shapeHelpText": "选择 {list} 或 {end}。", - "xpack.canvas.functions.progress.args.valueColorHelpText": "进度条的颜色。", - "xpack.canvas.functions.progress.args.valueWeightHelpText": "进度条的粗细。", - "xpack.canvas.functions.progress.invalidMaxValueErrorMessage": "无效的 {arg} 值:“{max, number}”。“{arg}”必须大于 0", - "xpack.canvas.functions.progress.invalidValueErrorMessage": "无效的值:“{value, number}”。值必须介于 0 和 {max, number} 之间", - "xpack.canvas.functions.progressHelpText": "配置进度元素。", - "xpack.canvas.functions.render.args.containerStyleHelpText": "容器的样式,包括背景、边框和透明度。", - "xpack.canvas.functions.repeatImage.args.maxHelpText": "图像可以重复的最大次数。", - "xpack.canvas.functions.repeatImage.args.sizeHelpText": "图像的最大高度或宽度,以像素为单位。图像的高大于宽时,此函数将限制高度。", - "xpack.canvas.functions.repeatImageHelpText": "配置重复图像元素。", - "xpack.canvas.functions.replace.args.flagsHelpText": "指定标志。请参见 {url}。", - "xpack.canvas.functions.replace.args.replacementHelpText": "字符串匹配部分的替代。捕获组可以通过其索引进行访问。例如:{example}。", - "xpack.canvas.functions.replaceImageHelpText": "使用正则表达式替换字符串各部分。", - "xpack.canvas.functions.revealImage.invalidPercentErrorMessage": "无效的值:“{percent}”。百分比必须介于 0 和 1 之间", - "xpack.canvas.functions.revealImageHelpText": "配置图像显示元素。", - "xpack.canvas.functions.seriesStyle.args.barsHelpText": "条形的宽度。", - "xpack.canvas.functions.seriesStyle.args.colorHelpText": "线条颜色。", - "xpack.canvas.functions.seriesStyle.args.fillHelpText": "应该填入点吗?", - "xpack.canvas.functions.seriesStyle.args.horizontalBarsHelpText": "将图表中的条形方向设置为横向。", - "xpack.canvas.functions.seriesStyle.args.labelHelpText": "要加上样式的序列的名称。", - "xpack.canvas.functions.seriesStyle.args.linesHelpText": "线条的宽度。", - "xpack.canvas.functions.seriesStyle.args.pointsHelpText": "折线上的点大小", - "xpack.canvas.functions.shape.args.borderWidthHelpText": "边框的粗细。", - "xpack.canvas.functions.shape.args.shapeHelpText": "选取形状。", - "xpack.canvas.functions.shapeHelpText": "创建形状。", - "xpack.canvas.functions.sortHelpText": "按指定列排序数据库。", - "xpack.canvas.functions.staticColumn.args.nameHelpText": "新列的名称。", - "xpack.canvas.functions.table.args.showHeaderHelpText": "显示/隐藏具有每列标题的标题行。", - "xpack.canvas.functions.timefilter.args.columnHelpText": "要筛选的列或字段。", - "xpack.canvas.functions.timefilter.invalidStringErrorMessage": "无效的日期/时间字符串:“{str}”", - "xpack.canvas.functions.timefilterControl.args.columnHelpText": "要筛选的列或字段。", - "xpack.canvas.functions.timefilterControl.args.compactHelpText": "将时间筛选显示为触发弹出框的按钮。", - "xpack.canvas.appDescription": "以最佳像素展示您的数据。", - "xpack.canvas.functions.exactly.args.filterGroupHelpText": "筛选的组名称。", - "xpack.canvas.functions.metric.args.metricFormatHelpText": "{NUMERALJS} 格式字符串。例如 {example1} 或 {example2}。请参见 {url}。", - "xpack.canvas.functions.timefilter.args.filterGroupHelpText": "筛选的组名称。", - "xpack.canvas.functions.all.args.conditionHelpText": "要检查的条件。", - "xpack.canvas.functions.allHelpText": "如果满足所有条件,则返回 {BOOLEAN_TRUE}。另见 {anyFn}。", - "xpack.canvas.functions.alterColumnHelpText": "在核心类型(包括 {list})和 {end} 之间转换并重命名列。另见 {mapColumnFn} 和 {staticColumnFn}。", - "xpack.canvas.functions.any.args.conditionHelpText": "要检查的条件。", - "xpack.canvas.functions.anyHelpText": "至少满足一个条件时,则返回 {BOOLEAN_TRUE}。另见 {all_fn}。", - "xpack.canvas.functions.asHelpText": "使用单个值创建 {DATATABLE}。另见 {getCellFn}。", - "xpack.canvas.functions.axisConfig.args.maxHelpText": "轴上显示的最大值。必须为数字或自 Epoch 起毫秒数表示的日期或 {ISO8601} 字符串。", - "xpack.canvas.functions.axisConfig.args.minHelpText": "轴上显示的最小值。必须为数字或自 Epoch 起毫秒数表示的日期或 {ISO8601} 字符串。", - "xpack.canvas.functions.axisConfig.args.positionHelpText": "轴标签的位置。例如 {list} 或 {end}。", - "xpack.canvas.functions.axisConfigHelpText": "配置可视化的轴。仅用于 {plotFn}。", - "xpack.canvas.functions.case.args.ifHelpText": "此值表示条件是否满足,通常使用子表达式。{IF_ARG} 和 {WHEN_ARG} 参数都提供时,前者将覆盖后者。", - "xpack.canvas.functions.case.args.whenHelpText": "与 {CONTEXT} 比较的值,通过比较来确定它们是否相等。同时指定 {WHEN_ARG} 和 {IF_ARG} 时,将忽略前者。", - "xpack.canvas.functions.caseHelpText": "构建要传递给 {switchFn} 函数的 {case},包括条件/结果。", - "xpack.canvas.functions.clearHelpText": "清除 {CONTEXT},然后返回 {TYPE_NULL}。", - "xpack.canvas.functions.columns.args.excludeHelpText": "要从 {DATATABLE} 中移除的列名称逗号分隔列表。", - "xpack.canvas.functions.columns.args.includeHelpText": "要在 {DATATABLE} 中保留的列名称逗号分隔列表。", - "xpack.canvas.functions.columnsHelpText": "在/从 {DATATABLE} 中包括或排除列。两个参数都指定时,将首先移除排除的列。", - "xpack.canvas.functions.compare.args.toHelpText": "与 {CONTEXT} 比较的值。", - "xpack.canvas.functions.compareHelpText": "将 {CONTEXT} 与指定值比较,以确定 {BOOLEAN_TRUE} 或 {BOOLEAN_FALSE}。通常与 `{ifFn}` 或 `{caseFn}` 一起使用。这仅适用于基元类型,如 {examples}。另见 `{eqFn}`、`{gtFn}`、`{gteFn}`、`{ltFn}`、`{lteFn}`、`{neqFn}`", - "xpack.canvas.functions.containerStyle.args.backgroundColorHelpText": "有效的 {CSS} 背景色。", - "xpack.canvas.functions.containerStyle.args.backgroundImageHelpText": "有效的 {CSS} 背景图。", - "xpack.canvas.functions.containerStyle.args.backgroundRepeatHelpText": "有效的 {CSS} 背景重复。", - "xpack.canvas.functions.containerStyle.args.backgroundSizeHelpText": "有效的 {CSS} 背景大小。", - "xpack.canvas.functions.containerStyle.args.borderHelpText": "有效的 {CSS} 边框。", - "xpack.canvas.functions.containerStyle.args.overflowHelpText": "有效的 {CSS} 溢出。", - "xpack.canvas.functions.containerStyleHelpText": "创建用于为元素容器提供样式的对象,包括背景、边框和透明度。", - "xpack.canvas.functions.contextHelpText": "返回传入该函数的任何内容。需要将 {CONTEXT} 用作充当子表达式的参数时,这会非常有用。", - "xpack.canvas.functions.csv.args.dataHelpText": "要使用的 {CSV} 数据。", - "xpack.canvas.functions.csvHelpText": "从 {CSV} 输入创建 {DATATABLE}。", - "xpack.canvas.functions.date.args.formatHelpText": "用于解析指定日期字符串的 {MOMENTJS}。请参见 {url}。", - "xpack.canvas.functions.date.args.valueHelpText": "解析成自 Epoch 起毫秒数的可选日期字符串。日期字符串可以是有效的 {JS} {date} 输入,也可以是要使用 {formatArg} 参数解析的字符串。必须为 {ISO8601} 字符串,或必须提供该格式。", - "xpack.canvas.functions.do.args.fnHelpText": "要执行的子表达式。这些子表达式的返回值在根管道中不可用,因为此函数仅返回原始 {CONTEXT}。", - "xpack.canvas.functions.doHelpText": "执行多个子表达式,然后返回原始 {CONTEXT}。用于运行产生操作或副作用时不会更改原始 {CONTEXT} 的函数。", - "xpack.canvas.functions.eq.args.valueHelpText": "与 {CONTEXT} 比较的值。", - "xpack.canvas.functions.eqHelpText": "返回 {CONTEXT} 是否等于参数。", - "xpack.canvas.functions.escount.args.queryHelpText": "{LUCENE} 查询字符串。", - "xpack.canvas.functions.escountHelpText": "在 {ELASTICSEARCH} 中查询匹配指定查询的命中数。", - "xpack.canvas.functions.esdocs.args.queryHelpText": "{LUCENE} 查询字符串。", - "xpack.canvas.functions.esdocsHelpText": "在 {ELASTICSEARCH} 中查询原始文档。指定要检索的字段,特别是需要大量的行。", - "xpack.canvas.functions.essql.args.queryHelpText": "{ELASTICSEARCH} {SQL} 查询。", - "xpack.canvas.functions.essql.args.timezoneHelpText": "要用于日期操作的时区。有效的 {ISO8601} 格式和 {UTC} 偏倚均适用。", - "xpack.canvas.functions.essqlHelpText": "使用 {ELASTICSEARCH} {SQL} 查询 {ELASTICSEARCH}。", - "xpack.canvas.functions.filterrows.args.fnHelpText": "传递到 {DATATABLE} 中每一行的表达式。表达式应返回 {TYPE_BOOLEAN}。{BOOLEAN_TRUE} 值保留行,{BOOLEAN_FALSE} 值删除行。", - "xpack.canvas.functions.filterrowsHelpText": "根据子表达式的返回值筛选 {DATATABLE} 中的行。", - "xpack.canvas.functions.formatdate.args.formatHelpText": "{MOMENTJS} 格式。例如:{example}。请参见 {url}。", - "xpack.canvas.functions.formatdateHelpText": "使用 {MOMENTJS} 格式化 {ISO8601} 日期字符串或自 Epoch 起以毫秒表示的日期。请参见 {url}。", - "xpack.canvas.functions.formatnumber.args.formatHelpText": "{NUMERALJS} 格式字符串。例如 {example1} 或 {example2}。请参见 {url}。", - "xpack.canvas.functions.formatnumberHelpText": "使用 {NUMERALJS} 将数字格式化为带格式数字字符串。请参见 {url}。", - "xpack.canvas.functions.getCell.args.columnHelpText": "从其中提取值的列的名称。如果未提供,将从第一列检索值。", - "xpack.canvas.functions.getCellHelpText": "从 {DATATABLE} 提取单个单元格。", - "xpack.canvas.functions.gt.args.valueHelpText": "与 {CONTEXT} 比较的值。", - "xpack.canvas.functions.gte.args.valueHelpText": "与 {CONTEXT} 比较的值。", - "xpack.canvas.functions.gteHelpText": "返回 {CONTEXT} 是否大于或等于参数。", - "xpack.canvas.functions.gtHelpText": "返回 {CONTEXT} 是否大于参数。", - "xpack.canvas.functions.head.args.countHelpText": "要从 {DATATABLE} 的起始位置检索的行数目。", - "xpack.canvas.functions.headHelpText": "从 {DATATABLE} 检索前 {n} 行。另见 {tailFn}", - "xpack.canvas.functions.if.args.conditionHelpText": "表示条件是否满足的 {BOOLEAN_TRUE} 或 {BOOLEAN_FALSE},通常由子表达式返回。未指定时,将返回原始 {CONTEXT}。", - "xpack.canvas.functions.if.args.elseHelpText": "条件为 {BOOLEAN_FALSE} 时的返回值。未指定且条件未满足时,将返回原始 {CONTEXT}。", - "xpack.canvas.functions.if.args.thenHelpText": "条件为 {BOOLEAN_TRUE} 时的返回值。未指定且条件满足时,将返回原始 {CONTEXT}。", - "xpack.canvas.functions.image.args.dataurlHelpText": "图像的 {https} {URL} 或 {BASE64} 数据 {URL}。", - "xpack.canvas.functions.imageHelpText": "显示图像。将图像资产作为 {BASE64} 数据 {URL} 提供或传入子表达式。", - "xpack.canvas.functions.joinRows.args.columnHelpText": "要用于联接值的列", - "xpack.canvas.functions.joinRows.args.distinctHelpText": "移除重复值?", - "xpack.canvas.functions.joinRows.args.quoteHelpText": "引起值的引号字符", - "xpack.canvas.functions.joinRows.args.separatorHelpText": "用于分隔行值的分隔符", - "xpack.canvas.functions.locationHelpText": "使用浏览器的 {geolocationAPI} 查找您的当前位置。性能可能会因浏览器而异,但相当准确。请参见 {url}。", - "xpack.canvas.functions.lt.args.valueHelpText": "与 {CONTEXT} 比较的值。", - "xpack.canvas.functions.lte.args.valueHelpText": "与 {CONTEXT} 比较的值。", - "xpack.canvas.functions.lteHelpText": "返回 {CONTEXT} 是否小于或等于参数。", - "xpack.canvas.functions.ltHelpText": "返回 {CONTEXT} 是否小于参数。", - "xpack.canvas.functions.mapColumn.args.expressionHelpText": "作为单行 {DATATABLE} 传递到每一行的 {CANVAS} 表达式。", - "xpack.canvas.functions.mapColumnHelpText": "添加计算为其他列的结果的列。只有提供参数时,才会进行更改。另请参见 {mapColumnFn} 和 {staticColumnFn}。", - "xpack.canvas.functions.markdown.args.contentHelpText": "包含 {MARKDOWN} 的文本字符串。要进行串联,请传递 {stringFn} 函数多次。", - "xpack.canvas.functions.markdown.args.fontHelpText": "内容的 {CSS} 字体属性。例如:{fontFamily} 或 {fontWeight}。", - "xpack.canvas.functions.markdownHelpText": "添加呈现 {MARKDOWN} 文本的元素。提示:将 {markdownFn} 函数用于单个数字、指标和文本段落。", - "xpack.canvas.functions.math.args.expressionHelpText": "已计算的 {TINYMATH} 表达式。请参阅 {TINYMATH_URL}。", - "xpack.canvas.functions.mathHelpText": "通过将数字或 {DATATABLE} 用作 {CONTEXT} 来解析 {TINYMATH} 数学表达式。{DATATABLE} 列可通过列名来使用。如果 {CONTEXT} 是数字,其可用作 {value}。", - "xpack.canvas.functions.metric.args.labelFontHelpText": "标签的 {CSS} 字体属性。例如 {FONT_FAMILY} 或 {FONT_WEIGHT}。", - "xpack.canvas.functions.metric.args.metricFontHelpText": "指标的 {CSS} 字体属性。例如 {FONT_FAMILY} 或 {FONT_WEIGHT}。", - "xpack.canvas.functions.neq.args.valueHelpText": "与 {CONTEXT} 比较的值。", - "xpack.canvas.functions.neqHelpText": "返回 {CONTEXT} 是否不等于参数。", - "xpack.canvas.functions.palette.args.colorHelpText": "调色板颜色。接受 {html} 颜色名称、{hex}、{hsl}、{hsla}、{rgb} 或 {rgba}。", - "xpack.canvas.functions.pie.args.fontHelpText": "标签的 {CSS} 字体属性。例如 {FONT_FAMILY} 或 {FONT_WEIGHT}。", - "xpack.canvas.functions.pie.args.legendHelpText": "图例位置。例如 {positions} 或 {BOOLEAN_FALSE}。为 {BOOLEAN_FALSE} 时,图例隐藏。", - "xpack.canvas.functions.pie.args.paletteHelpText": "用于描述要在饼图上使用的颜色的 {palette} 对象。请参见 {paletteFn}。", - "xpack.canvas.functions.plot.args.fontHelpText": "标签的 {CSS} 字体属性。例如 {FONT_FAMILY} 或 {FONT_WEIGHT}。", - "xpack.canvas.functions.plot.args.legendHelpText": "图例位置。例如 {positions} 或 {BOOLEAN_FALSE}。为 {BOOLEAN_FALSE} 时,图例隐藏。", - "xpack.canvas.functions.plot.args.paletteHelpText": "用于描述要在此图表上使用的颜色的 {palette} 对象。请参见 {paletteFn}。", - "xpack.canvas.functions.plot.args.xaxisHelpText": "轴配置。为 {BOOLEAN_FALSE} 时,轴隐藏。", - "xpack.canvas.functions.plot.args.yaxisHelpText": "轴配置。为 {BOOLEAN_FALSE} 时,轴隐藏。", - "xpack.canvas.functions.plotHelpText": "配置图表元素", - "xpack.canvas.functions.ply.args.byHelpText": "用于细分 {DATATABLE} 的列。", - "xpack.canvas.functions.ply.args.expressionHelpText": "要将每个结果 {DATATABLE} 传入的表达式。提示:表达式必须返回 {DATATABLE}。使用 `{asFn}` 将文本转成 {DATATABLE}。多个表达式必须返回相同数量的行。如果需要返回不同的行数,请导向另一个 {plyFn} 实例。如果多个表达式返回同名的列,最后一列将胜出。", - "xpack.canvas.functions.plyHelpText": "通过指定列的唯一值细分 {DATATABLE},并将生成的表传入表达式,然后合并每个表达式的输出", - "xpack.canvas.functions.pointseriesHelpText": "将 {DATATABLE} 转成点序列模型。当前我们通过寻找 {TINYMATH} 表达式来区分度量和维度。请参阅 {TINYMATH_URL}。如果在参数中输入 {TINYMATH} 表达式,我们将该参数视为度量,否则该参数为维度。维度将进行组合以创建唯一键。然后,这些键使用指定的 {TINYMATH} 函数消除重复的度量", - "xpack.canvas.functions.progress.args.fontHelpText": "标签的 {CSS} 字体属性。例如 {FONT_FAMILY} 或 {FONT_WEIGHT}。", - "xpack.canvas.functions.progress.args.labelHelpText": "要显示或隐藏标签,请使用 {BOOLEAN_TRUE} 或 {BOOLEAN_FALSE}。或者,提供要显示为标签的字符串。", - "xpack.canvas.functions.render.args.asHelpText": "要呈现的元素类型。您可能需要专门的函数,例如 {plotFn} 或 {shapeFn}。", - "xpack.canvas.functions.render.args.cssHelpText": "要限定于元素的任何定制 {CSS} 块。", - "xpack.canvas.functions.renderHelpText": "将 {CONTEXT} 呈现为特定元素并设置元素级别选项,例如背景和边框样式。", - "xpack.canvas.functions.repeatImage.args.emptyImageHelpText": "使用图像在 {CONTEXT} 和元素的 {maxArg} 参数之间填充差异。以 {BASE64} 数据 {URL} 方式提供图像资产,或传入子表达式。", - "xpack.canvas.functions.repeatImage.args.imageHelpText": "要重复的图像。将图像资产作为 {BASE64} 数据 {URL} 提供或传入子表达式。", - "xpack.canvas.functions.replace.args.patternHelpText": "{JS} 正则表达式的文本或模式。例如:{example}。您可以在此处使用捕获组。", - "xpack.canvas.functions.revealImage.args.emptyImageHelpText": "要显示的可选背景图像。将图像资产作为 {BASE64} 数据 {URL} 提供或传入子表达式。", - "xpack.canvas.functions.revealImage.args.imageHelpText": "要显示的图像。将图像资产作为 {BASE64} 数据 {URL} 提供或传入子表达式。", - "xpack.canvas.functions.revealImage.args.originHelpText": "要开始图像填充的位置。例如 {list} 或 {end}。", - "xpack.canvas.functions.rounddate.args.formatHelpText": "用于存储桶存储的 {MOMENTJS} 格式。例如,{example} 将每个日期舍入到月份。请参见 {url}。", - "xpack.canvas.functions.rounddateHelpText": "使用 {MOMENTJS} 格式字符串舍入自 Epoch 起毫秒数,并返回自 Epoch 起毫秒数。", - "xpack.canvas.functions.rowCountHelpText": "返回行数。与 {plyFn} 搭配,可获取唯一行值的计数或唯一行值的组合。", - "xpack.canvas.functions.seriesStyle.args.stackHelpText": "指定是否应堆叠序列。编号为堆叠 ID。具有相同堆叠 ID 的序列将堆叠在一起。", - "xpack.canvas.functions.seriesStyleHelpText": "创建用于在图表上描述序列属性的对象。在图表绘制函数(如 {plotFn} 或 {pieFn})中使用 {seriesStyleFn}。", - "xpack.canvas.functions.shape.args.borderHelpText": "形状轮廓边框的 {SVG} 颜色。", - "xpack.canvas.functions.shape.args.fillHelpText": "填充形状的 {SVG} 颜色。", - "xpack.canvas.functions.shape.args.maintainAspectHelpText": "维持形状的原始纵横比?", - "xpack.canvas.functions.sort.args.byHelpText": "排序要依据的列。未指定时,将按第一列排序 `{DATATABLE}`。", - "xpack.canvas.functions.sort.args.reverseHelpText": "反转排序顺序。未指定时,将升序排序 `{DATATABLE}`。", - "xpack.canvas.functions.staticColumn.args.valueHelpText": "在每一行新列中要插入的值。提示:使用子表达式将其他列汇总为静态值。", - "xpack.canvas.functions.staticColumnHelpText": "在每一行添加具有相同静态值的列。另见 {alterColumnFn} 和 {mapColumnFn}。", - "xpack.canvas.functions.string.args.valueHelpText": "要连结成一个字符串的值。根据需要加入空格。", - "xpack.canvas.functions.stringHelpText": "将所有参数串联成单个字符串。", - "xpack.canvas.functions.switch.args.caseHelpText": "要检查的条件", - "xpack.canvas.functions.switch.args.defaultHelpText": "未满足任何条件时返回的值。未指定且没有条件满足时,将返回原始 {CONTEXT}。", - "xpack.canvas.functions.switchHelpText": "执行具有多个条件的条件逻辑。另见 {caseFn},其用于构建要传递到 {switchFn} 函数的 {case}。", - "xpack.canvas.functions.table.args.fontHelpText": "表内容的 {CSS} 字体属性。例如 {FONT_FAMILY} 或 {FONT_WEIGHT}。", - "xpack.canvas.functions.table.args.paginateHelpText": "显示分页控件?为 {BOOLEAN_FALSE} 时,仅显示第一页。", - "xpack.canvas.functions.table.args.perPageHelpText": "要在每页上显示的行数目。", - "xpack.canvas.functions.tableHelpText": "配置表元素", - "xpack.canvas.functions.tail.args.countHelpText": "要从 {DATATABLE} 的结尾位置检索的行数目。", - "xpack.canvas.functions.tailHelpText": "从 {DATATABLE} 结尾检索后 N 行。另见 {headFn}。", - "xpack.canvas.functions.timefilter.args.fromHelpText": "以 {ISO8601} 或 {ELASTICSEARCH} {DATEMATH} 格式表示的范围起始", - "xpack.canvas.functions.timefilter.args.toHelpText": "以 {ISO8601} 或 {ELASTICSEARCH} {DATEMATH} 格式表示的范围结束", - "xpack.canvas.functions.timefilterControlHelpText": "配置时间筛选控制元素。", - "xpack.canvas.functions.timefilterHelpText": "创建用于查询源的时间筛选。", - "xpack.canvas.functions.urlparam.args.defaultHelpText": "未指定 {URL} 参数时返回的值。", - "xpack.canvas.functions.urlparam.args.paramHelpText": "要检索的 {URL} 哈希参数。", - "xpack.canvas.functions.urlparamHelpText": "检索要在表达式中使用的 {URL} 参数。{urlparamFn} 函数始终返回 {TYPE_STRING}。例如,从 {URL} 的参数 {myVar} 检索值 {value} ({example})。", - "xpack.canvas.app.loadErrorMessage": "消息:{error}", - "xpack.canvas.app.loadErrorTitle": "Canvas 加载失败", - "xpack.canvas.app.loadingMessage": "Canvas 正在加载", - "xpack.canvas.argAddPopover.addAriaLabel": "添加参数", - "xpack.canvas.argFormAdvancedFailure.applyButtonLabel": "应用", - "xpack.canvas.argFormAdvancedFailure.resetButtonLabel": "重置", - "xpack.canvas.argFormAdvancedFailure.rowErrorMessage": "表达式无效", - "xpack.canvas.argFormArgSimpleForm.removeAriaLabel": "删除", - "xpack.canvas.argFormArgSimpleForm.requiredTooltip": "此参数为必需,应指定值。", - "xpack.canvas.argFormPendingArgValue.loadingMessage": "正在加载", - "xpack.canvas.argFormSimpleFailure.failureTooltip": "此参数的接口无法解析该值,因此将使用回退输入", - "xpack.canvas.asset.copyAssetTooltip": "将 ID 复制到剪贴板", - "xpack.canvas.asset.createImageTooltip": "创建图像元素", - "xpack.canvas.asset.deleteAssetTooltip": "删除", - "xpack.canvas.asset.downloadAssetTooltip": "下载", - "xpack.canvas.asset.thumbnailAltText": "资产缩略图", - "xpack.canvas.assetManager.confirmModalButtonLabel": "删除", - "xpack.canvas.assetManager.confirmModalDetail": "确定要删除此资产?", - "xpack.canvas.assetManager.confirmModalTitle": "删除资产", - "xpack.canvas.assetManager.manageButtonLabel": "管理资产", - "xpack.canvas.assetModal.emptyAssetsDescription": "导入您的资产以开始", - "xpack.canvas.assetModal.filePickerPromptText": "选择或拖放图像", - "xpack.canvas.assetModal.loadingText": "正在上传图像", - "xpack.canvas.assetModal.modalCloseButtonLabel": "关闭", - "xpack.canvas.assetModal.modalDescription": "以下为此 Workpad 中的图像资产。此时无法确定当前在用的任何资产。要回收空间,请删除资产。", - "xpack.canvas.assetModal.modalTitle": "管理 Workpad 资产", - "xpack.canvas.assetModal.spacedUsedText": "{percentageUsed}% 空间已用", - "xpack.canvas.assetpicker.assetAltText": "资产缩略图", - "xpack.canvas.colorManager.addAriaLabel": "添加颜色", - "xpack.canvas.colorManager.codePlaceholder": "颜色代码", - "xpack.canvas.colorManager.removeAriaLabel": "删除颜色", - "xpack.canvas.customElementModal.cancelButtonLabel": "取消", - "xpack.canvas.customElementModal.descriptionInputLabel": "描述", - "xpack.canvas.customElementModal.elementPreviewTitle": "元素预览", - "xpack.canvas.customElementModal.imageFilePickerPlaceholder": "选择或拖放图像", - "xpack.canvas.customElementModal.imageInputDescription": "对您的元素进行截屏并将截图上传到此处。也可以在保存之后执行此操作。", - "xpack.canvas.customElementModal.imageInputLabel": "缩略图", - "xpack.canvas.customElementModal.nameInputLabel": "名称", - "xpack.canvas.customElementModal.remainingCharactersDescription": "剩余 {numberOfRemainingCharacter} 个字符", - "xpack.canvas.customElementModal.saveButtonLabel": "保存", - "xpack.canvas.datasourceDatasourceComponent.changeButtonLabel": "更改您的数据源", - "xpack.canvas.datasourceDatasourceComponent.previewButtonLabel": "预览", - "xpack.canvas.datasourceDatasourceComponent.saveButtonLabel": "保存", - "xpack.canvas.datasourceDatasourcePreview.emptyFirstLineDescription": "找不到与您的搜索条件匹配的任何文档。", - "xpack.canvas.datasourceDatasourcePreview.emptySecondLineDescription": "请检查您的数据源设置并重试。", - "xpack.canvas.datasourceDatasourcePreview.emptyTitle": "找不到文档", - "xpack.canvas.datasourceDatasourcePreview.modalDescription": "单击侧栏中“{saveLabel}”以保存此数据。", - "xpack.canvas.datasourceDatasourcePreview.modalTitle": "数据源预览", - "xpack.canvas.datasourceNoDatasource.panelDescription": "此元素未附加数据源。通常这是因为该元素为图像或其他静态资产。否则,您可能需要检查表达式,以确保其格式正确。", - "xpack.canvas.datasourceNoDatasource.panelTitle": "数据源不存在", - "xpack.canvas.elementConfig.failedLabel": "失败", - "xpack.canvas.elementConfig.loadedLabel": "已加载", - "xpack.canvas.elementConfig.progressLabel": "进度", - "xpack.canvas.elementConfig.title": "元素", - "xpack.canvas.elementConfig.totalLabel": "合计", - "xpack.canvas.elementControls.deleteAriaLabel": "删除元素", - "xpack.canvas.elementControls.deleteToolTip": "删除", - "xpack.canvas.elementControls.editAriaLabel": "编辑元素", - "xpack.canvas.elementControls.editToolTip": "编辑", - "xpack.canvas.elementSettings.dataTabLabel": "数据", - "xpack.canvas.elementSettings.displayTabLabel": "显示", - "xpack.canvas.elementTypes.addNewElementDescription": "分组并保存 Workpad 元素以创建新元素", - "xpack.canvas.elementTypes.addNewElementTitle": "添加新元素", - "xpack.canvas.elementTypes.cancelButtonLabel": "取消", - "xpack.canvas.elementTypes.deleteButtonLabel": "删除", - "xpack.canvas.elementTypes.deleteElementDescription": "确定要删除此元素?", - "xpack.canvas.elementTypes.deleteElementTitle": "删除元素“{elementName}”?", - "xpack.canvas.elementTypes.editElementTitle": "编辑元素", - "xpack.canvas.elementTypes.elementsTitle": "元素", - "xpack.canvas.elementTypes.findElementPlaceholder": "查找元素", - "xpack.canvas.elementTypes.myElementsTitle": "我的元素", - "xpack.canvas.embedObject.noMatchingObjectsMessage": "未找到任何匹配对象。", - "xpack.canvas.embedObject.titleText": "嵌入对象", - "xpack.canvas.error.actionsElements.invaludArgIndexErrorMessage": "无效的参数索引:{index}", - "xpack.canvas.error.downloadWorkpad.downloadFailureErrorMessage": "无法下载 Workpad", - "xpack.canvas.error.downloadWorkpad.downloadRenderedWorkpadFailureErrorMessage": "无法下载已呈现 Workpad", - "xpack.canvas.error.downloadWorkpad.downloadRuntimeFailureErrorMessage": "无法下载 Shareable Runtime", - "xpack.canvas.error.downloadWorkpad.downloadZippedRuntimeFailureErrorMessage": "无法下载 ZIP 文件", - "xpack.canvas.error.esPersist.saveFailureTitle": "无法将您的更改保存到 Elasticsearch", - "xpack.canvas.error.esPersist.tooLargeErrorMessage": "服务器响应 Workpad 数据过大。这通常表示上传的图像资产对于 Kibana 或代理过大。请尝试移除资产管理器中的一些资产。", - "xpack.canvas.error.esPersist.updateFailureTitle": "无法更新 Workpad", - "xpack.canvas.error.esService.defaultIndexFetchErrorMessage": "无法提取默认索引", - "xpack.canvas.error.esService.fieldsFetchErrorMessage": "无法为“{index}”提取 Elasticsearch 字段", - "xpack.canvas.error.esService.indicesFetchErrorMessage": "无法提取 Elasticsearch 索引", - "xpack.canvas.error.RenderWithFn.renderErrorMessage": "呈现“{functionName}”失败", - "xpack.canvas.error.repeatImage.missingMaxArgument": "如果提供 {emptyImageArgument},则必须设置 {maxArgument}", - "xpack.canvas.error.workpadLoader.cloneFailureErrorMessage": "无法克隆 Workpad", - "xpack.canvas.error.workpadLoader.deleteFailureErrorMessage": "无法删除所有 Workpad", - "xpack.canvas.error.workpadLoader.findFailureErrorMessage": "无法查找 Workpad", - "xpack.canvas.error.workpadLoader.uploadFailureErrorMessage": "无法上传 Workpad", - "xpack.canvas.error.workpadRoutes.createFailureErrorMessage": "无法创建 Workpad", - "xpack.canvas.error.workpadRoutes.loadFailureErrorMessage": "无法加载具有以下 ID 的 Workpad", - "xpack.canvas.error.workpadUpload.acceptJSONOnlyErrorMessage": "仅接受 {JSON} 文件", - "xpack.canvas.error.workpadUpload.fileUploadFailureWithoutFileNameErrorMessage": "无法上传文件", - "xpack.canvas.error.workpadUpload.missingPropertiesErrorMessage": "{CANVAS} Workpad 所需的某些属性缺失。 编辑 {JSON} 文件以提供正确的属性值,然后重试。", - "xpack.canvas.errorComponent.description": "表达式失败,并显示消息:", - "xpack.canvas.errorComponent.title": "哎哟!表达式失败", - "xpack.canvas.errors.workpadUpload.fileUploadFileWithFileNameErrorMessage": "无法上传“{fileName}”", - "xpack.canvas.expression.cancelButtonLabel": "取消", - "xpack.canvas.expression.closeButtonLabel": "关闭", - "xpack.canvas.expression.learnLinkText": "学习表达式语法", - "xpack.canvas.expression.maximizeButtonLabel": "最大化编辑器", - "xpack.canvas.expression.minimizeButtonLabel": "最小化编辑器", - "xpack.canvas.expression.runButtonLabel": "运行", - "xpack.canvas.expression.runTooltip": "运行表达式", - "xpack.canvas.expressionElementNotSelected.closeButtonLabel": "关闭", - "xpack.canvas.expressionElementNotSelected.selectDescription": "选择元素以显示表达式输入", - "xpack.canvas.expressionInput.argReferenceAliasesDetail": "{BOLD_MD_TOKEN}别名{BOLD_MD_TOKEN}:{aliases}", - "xpack.canvas.expressionInput.argReferenceDefaultDetail": "{BOLD_MD_TOKEN}默认{BOLD_MD_TOKEN}:{defaultVal}", - "xpack.canvas.expressionInput.argReferenceRequiredDetail": "{BOLD_MD_TOKEN}必需{BOLD_MD_TOKEN}:{required}", - "xpack.canvas.expressionInput.argReferenceTypesDetail": "{BOLD_MD_TOKEN}类型{BOLD_MD_TOKEN}:{types}", - "xpack.canvas.expressionInput.functionReferenceAccepts": "{BOLD_MD_TOKEN}接受{BOLD_MD_TOKEN}:{acceptTypes}", - "xpack.canvas.expressionInput.functionReferenceReturns": "{BOLD_MD_TOKEN}返回{BOLD_MD_TOKEN}:{returnType}", - "xpack.canvas.expressionTypes.argTypes.colorDisplayName": "颜色", - "xpack.canvas.expressionTypes.argTypes.colorHelp": "颜色选取器", - "xpack.canvas.expressionTypes.argTypes.containerStyle.appearanceTitle": "外观", - "xpack.canvas.expressionTypes.argTypes.containerStyle.borderTitle": "边框", - "xpack.canvas.expressionTypes.argTypes.containerStyle.colorLabel": "颜色", - "xpack.canvas.expressionTypes.argTypes.containerStyle.opacityLabel": "图层透明度", - "xpack.canvas.expressionTypes.argTypes.containerStyle.overflowHiddenDropDown": "隐藏", - "xpack.canvas.expressionTypes.argTypes.containerStyle.overflowLabel": "溢出", - "xpack.canvas.expressionTypes.argTypes.containerStyle.overflowVisibleDropDown": "可见", - "xpack.canvas.expressionTypes.argTypes.containerStyle.paddingLabel": "填充", - "xpack.canvas.expressionTypes.argTypes.containerStyle.radiusLabel": "半径", - "xpack.canvas.expressionTypes.argTypes.containerStyle.styleLabel": "样式", - "xpack.canvas.expressionTypes.argTypes.containerStyle.thicknessLabel": "厚度", - "xpack.canvas.expressionTypes.argTypes.containerStyleLabel": "调整元素容器的外观", - "xpack.canvas.expressionTypes.argTypes.containerStyleTitle": "容器样式", - "xpack.canvas.expressionTypes.argTypes.fontHelpLabel": "设置字体、大小和颜色", - "xpack.canvas.expressionTypes.argTypes.fontTitle": "文本设置", - "xpack.canvas.expressionTypes.argTypes.seriesStyle.barLabel": "条形图", - "xpack.canvas.expressionTypes.argTypes.seriesStyle.colorLabel": "颜色", - "xpack.canvas.expressionTypes.argTypes.seriesStyle.lineLabel": "折线图", - "xpack.canvas.expressionTypes.argTypes.seriesStyle.noneDropDown": "无", - "xpack.canvas.expressionTypes.argTypes.seriesStyle.noSeriesTooltip": "数据没有要应用样式的序列,请添加颜色维度", - "xpack.canvas.expressionTypes.argTypes.seriesStyle.pointLabel": "点", - "xpack.canvas.expressionTypes.argTypes.seriesStyle.removeAriaLabel": "移除序列颜色", - "xpack.canvas.expressionTypes.argTypes.seriesStyle.selectSeriesDropDown": "选择序列", - "xpack.canvas.expressionTypes.argTypes.seriesStyle.seriesIdentifierLabel": "序列标识符", - "xpack.canvas.expressionTypes.argTypes.seriesStyle.styleLabel": "样式", - "xpack.canvas.expressionTypes.argTypes.seriesStyleLabel": "设置选定已命名序列的样式", - "xpack.canvas.expressionTypes.argTypes.seriesStyleTitle": "序列样式", - "xpack.canvas.expressionTypes.datasources.esdocs.ascendingDropDown": "升序", - "xpack.canvas.expressionTypes.datasources.esdocs.descendingDropDown": "降序", - "xpack.canvas.expressionTypes.datasources.esdocs.fieldsLabel": "要提取的字段。Kibana 脚本字段当前不可用", - "xpack.canvas.expressionTypes.datasources.esdocs.fieldsTitle": "字段", - "xpack.canvas.expressionTypes.datasources.esdocs.fieldsWarningLabel": "字段不超过 10 个时,此数据源性能最佳", - "xpack.canvas.expressionTypes.datasources.esdocs.indexLabel": "输入索引名称或选择索引模式", - "xpack.canvas.expressionTypes.datasources.esdocs.indexTitle": "索引", - "xpack.canvas.expressionTypes.datasources.esdocs.queryLabel": "{lucene} 查询字符串语法", - "xpack.canvas.expressionTypes.datasources.esdocs.queryTitle": "查询", - "xpack.canvas.expressionTypes.datasources.esdocs.sortFieldLabel": "文档排序字段", - "xpack.canvas.expressionTypes.datasources.esdocs.sortFieldTitle": "排序字段", - "xpack.canvas.expressionTypes.datasources.esdocs.sortOrderLabel": "文档排序顺序", - "xpack.canvas.expressionTypes.datasources.esdocs.sortOrderTitle": "排序顺序", - "xpack.canvas.expressionTypes.datasources.esdocs.warningTitle": "务必谨慎操作", - "xpack.canvas.expressionTypes.datasources.esdocsLabel": "从 Elasticsearch 拉取原始文档", - "xpack.canvas.expressionTypes.datasources.esdocsTitle": "Elasticsearch 原始文档", - "xpack.canvas.functionForm.contextError": "错误:{errorMessage}", - "xpack.canvas.functionForm.functionUnknown.unknownArgumentTypeError": "表达式类型“{expressionType}”未知", - "xpack.canvas.functions.asset.args.id": "要检索的资产的 ID。", - "xpack.canvas.functions.asset.invalidAssetId": "无法通过以下 ID 获取资产:“{assetId}”", - "xpack.canvas.functions.assetHelpText": "检索要作为参数值来提供的 Canvas Workpad 资产对象。通常为图像。", - "xpack.canvas.functions.filters.args.group": "要使用的筛选组的名称。", - "xpack.canvas.functions.filters.args.ungrouped": "排除属于筛选组的筛选?", - "xpack.canvas.functions.filtersHelpText": "聚合 Workpad 的元素筛选以用于他处,通常用于数据源。", - "xpack.canvas.functions.savedMapHelpText": "为已保存地图对象返回可嵌入对象", - "xpack.canvas.functions.savedSearchHelpText": "为已保存搜索对象返回可嵌入对象", - "xpack.canvas.functions.savedVisualizationHelpText": "为已保存可视化对象返回可嵌入对象", - "xpack.canvas.functions.timelion.args.from": "表示时间范围起始的 {ELASTICSEARCH} {DATEMATH} 字符串。", - "xpack.canvas.functions.timelion.args.interval": "时间序列的存储桶间隔。", - "xpack.canvas.functions.timelion.args.query": "Timelion 查询", - "xpack.canvas.functions.timelion.args.timezone": "时间范围的时区。请参阅 {MOMENTJS_TIMEZONE_URL}。", - "xpack.canvas.functions.timelion.args.to": "表示时间范围结束的 {ELASTICSEARCH} {DATEMATH} 字符串。", - "xpack.canvas.functions.timelionHelpText": "使用 Timelion 从多个源中提取一个或多个时间序列。", - "xpack.canvas.functions.to.args.type": "表达式语言中的已知数据类型。", - "xpack.canvas.functions.to.missingType": "必须指定转换类型", - "xpack.canvas.functions.toHelpText": "将 {CONTEXT} 的类型显式转换为指定类型。", - "xpack.canvas.groupSettings.multipleElementsActionsDescription": "取消选择这些元素以编辑各自的设置,按 ({gKey}) 以对它们进行分组,或将此选择另存为新元素,以在整个 Workpad 中重复使用。", - "xpack.canvas.groupSettings.multipleElementsDescription": "当前选择了多个元素。", - "xpack.canvas.groupSettings.saveGroupDescription": "将此组另存为新元素,以在整个 Workpad 重复使用。", - "xpack.canvas.groupSettings.ungroupDescription": "取消分组 ({uKey}) 以编辑各个元素设置。", - "xpack.canvas.helpMenu.description": "有关 {CANVAS} 特定信息", - "xpack.canvas.helpMenu.documentationLinkLabel": "{CANVAS} 文档", - "xpack.canvas.helpMenu.keyboardShortcutsLinkLabel": "快捷键", - "xpack.canvas.keyboardShortcuts.bringFowardShortcutHelpText": "置前", - "xpack.canvas.keyboardShortcuts.bringToFrontShortcutHelpText": "前移", - "xpack.canvas.keyboardShortcuts.cloneShortcutHelpText": "克隆", - "xpack.canvas.keyboardShortcuts.copyShortcutHelpText": "复制", - "xpack.canvas.keyboardShortcuts.cutShortcutHelpText": "剪切", - "xpack.canvas.keyboardShortcuts.deleteShortcutHelpText": "删除", - "xpack.canvas.keyboardShortcuts.editingShortcutHelpText": "切换编辑模式", - "xpack.canvas.keyboardShortcuts.fullscreenExitShortcutHelpText": "退出演示模式", - "xpack.canvas.keyboardShortcuts.fullscreenShortcutHelpText": "进入演示模式", - "xpack.canvas.keyboardShortcuts.gridShortcutHelpText": "显示网格", - "xpack.canvas.keyboardShortcuts.groupShortcutHelpText": "组", - "xpack.canvas.keyboardShortcuts.ignoreSnapShortcutHelpText": "移动、调整大小及旋转时不对齐", - "xpack.canvas.keyboardShortcuts.multiselectShortcutHelpText": "选择多个元素", - "xpack.canvas.keyboardShortcuts.namespace.editorDisplayName": "编辑器控件", - "xpack.canvas.keyboardShortcuts.namespace.elementDisplayName": "元素控件", - "xpack.canvas.keyboardShortcuts.namespace.expressionDisplayName": "表达式控件", - "xpack.canvas.keyboardShortcuts.namespace.presentationDisplayName": "演示控件", - "xpack.canvas.keyboardShortcuts.nextShortcutHelpText": "前往下一页", - "xpack.canvas.keyboardShortcuts.nudgeDownShortcutHelpText": "下移 {ELEMENT_NUDGE_OFFSET}px", - "xpack.canvas.keyboardShortcuts.nudgeLeftShortcutHelpText": "左移 {ELEMENT_NUDGE_OFFSET}px", - "xpack.canvas.keyboardShortcuts.nudgeRightShortcutHelpText": "右移 {ELEMENT_NUDGE_OFFSET}px", - "xpack.canvas.keyboardShortcuts.nudgeUpShortcutHelpText": "上移 {ELEMENT_NUDGE_OFFSET}px", - "xpack.canvas.keyboardShortcuts.pageCycleToggleShortcutHelpText": "切换页面循环播放", - "xpack.canvas.keyboardShortcuts.pasteShortcutHelpText": "粘贴", - "xpack.canvas.keyboardShortcuts.prevShortcutHelpText": "前往上一页", - "xpack.canvas.keyboardShortcuts.redoShortcutHelpText": "恢复上一操作", - "xpack.canvas.keyboardShortcuts.resizeFromCenterShortcutHelpText": "从中心调整大小", - "xpack.canvas.keyboardShortcuts.runShortcutHelpText": "运行整个表达式", - "xpack.canvas.keyboardShortcuts.selectBehindShortcutHelpText": "在下面选择元素", - "xpack.canvas.keyboardShortcuts.sendBackwardShortcutHelpText": "后移", - "xpack.canvas.keyboardShortcuts.sendToBackShortcutHelpText": "置后", - "xpack.canvas.keyboardShortcuts.shiftDownShortcutHelpText": "下移 {ELEMENT_SHIFT_OFFSET}px", - "xpack.canvas.keyboardShortcuts.shiftLeftShortcutHelpText": "左移 {ELEMENT_SHIFT_OFFSET}px", - "xpack.canvas.keyboardShortcuts.shiftRightShortcutHelpText": "右移 {ELEMENT_SHIFT_OFFSET}px", - "xpack.canvas.keyboardShortcuts.shiftUpShortcutHelpText": "上移 {ELEMENT_SHIFT_OFFSET}px", - "xpack.canvas.keyboardShortcuts.ShortcutHelpText": "刷新 Workpad", - "xpack.canvas.keyboardShortcuts.undoShortcutHelpText": "撤消上一操作", - "xpack.canvas.keyboardShortcuts.ungroupShortcutHelpText": "取消分组", - "xpack.canvas.keyboardShortcuts.zoomInShortcutHelpText": "放大", - "xpack.canvas.keyboardShortcuts.zoomOutShortcutHelpText": "缩小", - "xpack.canvas.keyboardShortcuts.zoomResetShortcutHelpText": "将缩放比例重置为 100%", - "xpack.canvas.keyboardShortcutsDoc.flyout.closeButtonAriaLabel": "关闭快捷键参考", - "xpack.canvas.keyboardShortcutsDoc.flyoutHeaderTitle": "快捷键", - "xpack.canvas.keyboardShortcutsDoc.shortcutListSeparator": "或", - "xpack.canvas.link.errorMessage": "链接错误:{message}", - "xpack.canvas.pageConfig.backgroundColorDescription": "接受 HEX、RGB 或 HTML 颜色名称", - "xpack.canvas.pageConfig.backgroundColorLabel": "背景色", - "xpack.canvas.pageConfig.title": "页", - "xpack.canvas.pageConfig.transitionLabel": "切换", - "xpack.canvas.pageConfig.transitionPreviewLabel": "预览", - "xpack.canvas.pageConfig.transitions.noneDropDownOptionLabel": "无", - "xpack.canvas.pageManager.pageNumberAriaLabel": "加载页码 {pageNumber}", - "xpack.canvas.pagePreviewPageControls.clonePageAriaLabel": "克隆页面", - "xpack.canvas.pagePreviewPageControls.clonePageTooltip": "克隆", - "xpack.canvas.pagePreviewPageControls.deletePageAriaLabel": "删除页面", - "xpack.canvas.pagePreviewPageControls.deletePageTooltip": "删除", - "xpack.canvas.renderer.advancedFilter.applyButtonLabel": "应用", - "xpack.canvas.renderer.advancedFilter.displayName": "高级筛选", - "xpack.canvas.renderer.advancedFilter.helpDescription": "呈现 Canvas 筛选表达式", - "xpack.canvas.renderer.advancedFilter.inputPlaceholder": "输入筛选表达式", - "xpack.canvas.renderer.debug.displayName": "故障排查", - "xpack.canvas.renderer.debug.helpDescription": "将故障排查输出呈现为带格式的 {JSON}", - "xpack.canvas.renderer.dropdownFilter.displayName": "下拉列表筛选", - "xpack.canvas.renderer.dropdownFilter.helpDescription": "可以从其中为“{exactly}”筛选选择值的下拉列表", - "xpack.canvas.renderer.dropdownFilter.matchAllOptionLabel": "任意", - "xpack.canvas.renderer.embeddable.displayName": "可嵌入", - "xpack.canvas.renderer.embeddable.helpDescription": "从 Kibana 的其他部分呈现可嵌入的已保存对象", - "xpack.canvas.renderer.error.displayName": "错误信息", - "xpack.canvas.renderer.error.helpDescription": "以用户友好的方式呈现错误数据", - "xpack.canvas.renderer.image.displayName": "图像", - "xpack.canvas.renderer.image.helpDescription": "呈现图像", - "xpack.canvas.renderer.markdown.displayName": "Markdown", - "xpack.canvas.renderer.markdown.helpDescription": "使用 {MARKDOWN} 输入呈现 {HTML}", - "xpack.canvas.renderer.metric.displayName": "指标", - "xpack.canvas.renderer.metric.helpDescription": "在标签上呈现数字", - "xpack.canvas.renderer.pie.displayName": "饼图", - "xpack.canvas.renderer.pie.helpDescription": "根据您的数据呈现饼图", - "xpack.canvas.renderer.plot.displayName": "坐标图", - "xpack.canvas.renderer.plot.helpDescription": "根据您的数据呈现 XY 坐标图", - "xpack.canvas.renderer.progress.displayName": "进度指示", - "xpack.canvas.renderer.progress.helpDescription": "呈现显示元素百分比的进度指示", - "xpack.canvas.renderer.repeatImage.displayName": "图像重复", - "xpack.canvas.renderer.repeatImage.helpDescription": "重复图像给定次数", - "xpack.canvas.renderer.revealImage.displayName": "图像显示", - "xpack.canvas.renderer.revealImage.helpDescription": "显示一定百分比的图像,以制作定制的仪表样式图表", - "xpack.canvas.renderer.shape.displayName": "形状", - "xpack.canvas.renderer.shape.helpDescription": "呈现基本形状", - "xpack.canvas.renderer.table.displayName": "数据表", - "xpack.canvas.renderer.table.helpDescription": "将表格数据呈现为 {HTML}", - "xpack.canvas.renderer.text.displayName": "纯文本", - "xpack.canvas.renderer.text.helpDescription": "将输出呈现为纯文本", - "xpack.canvas.renderer.timeFilter.displayName": "时间筛选", - "xpack.canvas.renderer.timeFilter.helpDescription": "设置时间窗口以筛选数据", - "xpack.canvas.shareWebsiteFlyout.description": "按照以下步骤在外部网站上共享此 Workpad 的静态版本。其将是当前 Workpad 的可视化快照,对实时数据没有访问权限。", - "xpack.canvas.shareWebsiteFlyout.flyoutCalloutDescription": "要尝试共享,可以{link},其包含此 Workpad、{CANVAS} Shareable Workpad Runtime 及示例 {HTML} 文件。", - "xpack.canvas.shareWebsiteFlyout.flyoutTitle": "在网站上共享", - "xpack.canvas.shareWebsiteFlyout.runtimeStep.description": "要呈现可共享 Workpad,还需要加入 {CANVAS} Shareable Workpad Runtime。如果您的网站已包含该运行时,则可以跳过此步骤。", - "xpack.canvas.shareWebsiteFlyout.runtimeStep.downloadLabel": "下载运行时", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.addSnippetsTitle": "将代码段添加到网站", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.autoplayParameterDescription": "该运行时是否应自动播放 Workpad 的所有页面?", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.callRuntimeLabel": "调用运行时", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.description": "通过使用 {HTML} 占位符,Workpad 将置于站点的 {HTML} 内。将内联包含运行时的参数。请在下面参阅参数的完整列表。可以在页面上包含多个 Workpad。", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.downloadRuntimeTitle": "下载运行时", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.downloadWorkpadTitle": "下载 Workpad", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.heightParameterDescription": "Workpad 的高度。默认为 Workpad 高度。", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.includeRuntimeLabel": "包含运行时", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.intervalParameterDescription": "页面前进的间隔,时间格式(例如 {twoSeconds}、{oneMinute}", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.pageParameterDescription": "要显示的页面。默认为 Workpad 指定的页面。", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.parametersDescription": "有很多可用于配置可共享 Workpad 的内联参数。", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.parametersLabel": "参数", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.placeholderLabel": "占位符", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.requiredLabel": "必需", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.shareableParameterDescription": "可共享对象的类型。在这种情况下,为 {CANVAS} Workpad。", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.toolbarParameterDescription": "工具栏是否应隐藏?", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.urlParameterDescription": "可共享 Workpad {JSON} 文件的 {URL}", - "xpack.canvas.shareWebsiteFlyout.snippetsStep.widthParameterDescription": "Workdpad 的宽度。默认为 Workpad 宽度。", - "xpack.canvas.shareWebsiteFlyout.workpadStep.description": "Workpad 将导出为单个 {JSON} 文件,以在其他站点上共享。", - "xpack.canvas.shareWebsiteFlyout.workpadStep.downloadLabel": "下载 Workpad", - "xpack.canvas.shareWebsiteFlyout.zipDownloadLinkLabel": "下载示例 {ZIP} 文件", - "xpack.canvas.sidebarContent.groupedElementSidebarTitle": "已分组元素", - "xpack.canvas.sidebarContent.multiElementSidebarTitle": "多个元素", - "xpack.canvas.sidebarContent.singleElementSidebarTitle": "选定元素", - "xpack.canvas.sidebarHeader.alignmentMenuItemLabel": "对齐方式", - "xpack.canvas.sidebarHeader.bottomAlignMenuItemLabel": "下", - "xpack.canvas.sidebarHeader.bringForwardArialLabel": "将元素上移一层", - "xpack.canvas.sidebarHeader.bringToFrontArialLabel": "将元素移到顶层", - "xpack.canvas.sidebarHeader.centerAlignMenuItemLabel": "中", - "xpack.canvas.sidebarHeader.contextMenuAriaLabel": "元素选项", - "xpack.canvas.sidebarHeader.createElementModalTitle": "创建新元素", - "xpack.canvas.sidebarHeader.distributionMenutItemLabel": "分布", - "xpack.canvas.sidebarHeader.groupMenuItemLabel": "分组", - "xpack.canvas.sidebarHeader.horizontalDistributionMenutItemLabel": "水平", - "xpack.canvas.sidebarHeader.leftAlignMenuItemLabel": "左", - "xpack.canvas.sidebarHeader.middleAlignMenuItemLabel": "中", - "xpack.canvas.sidebarHeader.orderMenuItemLabel": "顺序", - "xpack.canvas.sidebarHeader.rightAlignMenuItemLabel": "右", - "xpack.canvas.sidebarHeader.savedElementMenuItemLabel": "另存为新元素", - "xpack.canvas.sidebarHeader.sendBackwardArialLabel": "将元素下移一层", - "xpack.canvas.sidebarHeader.sendToBackArialLabel": "将元素移到底层", - "xpack.canvas.sidebarHeader.topAlignMenuItemLabel": "上", - "xpack.canvas.sidebarHeader.ungroupMenuItemLabel": "取消分组", - "xpack.canvas.sidebarHeader.verticalDistributionMenutItemLabel": "垂直", - "xpack.canvas.tags.chartTag": "图表", - "xpack.canvas.tags.filterTag": "筛选", - "xpack.canvas.tags.graphicTag": "图形", - "xpack.canvas.tags.presentationTag": "演示", - "xpack.canvas.tags.proportionTag": "比例", - "xpack.canvas.tags.reportTag": "报告", - "xpack.canvas.tags.textTag": "文本", - "xpack.canvas.templates.darkHelp": "深色主题的演示幻灯片", - "xpack.canvas.templates.darkName": "深色", - "xpack.canvas.templates.lightHelp": "浅色主题的演示幻灯片", - "xpack.canvas.templates.lightName": "浅色", - "xpack.canvas.templates.pitchHelp": "具有大尺寸照片的冠名演示", - "xpack.canvas.templates.pitchName": "推销演示", - "xpack.canvas.templates.statusHelp": "具有动态图表的文档式报告", - "xpack.canvas.templates.statusName": "状态", - "xpack.canvas.templates.summaryDisplayName": "总结", - "xpack.canvas.templates.summaryHelp": "具有动态图表的信息图式报告", - "xpack.canvas.textStylePicker.alignCenterOption": "中间对齐", - "xpack.canvas.textStylePicker.alignLeftOption": "左对齐", - "xpack.canvas.textStylePicker.alignRightOption": "右对齐", - "xpack.canvas.textStylePicker.styleBoldOption": "粗体", - "xpack.canvas.textStylePicker.styleItalicOption": "斜体", - "xpack.canvas.textStylePicker.styleUnderlineOption": "下划线", - "xpack.canvas.timePicker.applyButtonLabel": "应用", - "xpack.canvas.toolbar.editorButtonLabel": "表达式编辑器", - "xpack.canvas.toolbar.nextPageAriaLabel": "下一页", - "xpack.canvas.toolbar.pageButtonLabel": "页 {pageNum}{rest}", - "xpack.canvas.toolbar.previousPageAriaLabel": "上一页", - "xpack.canvas.toolbar.workpadManagerCloseButtonLabel": "关闭", - "xpack.canvas.toolbarTray.closeTrayAriaLabel": "关闭托盘", - "xpack.canvas.transitions.fade.displayName": "淡化", - "xpack.canvas.transitions.fade.help": "从一页淡入到下一页", - "xpack.canvas.transitions.rotate.displayName": "旋转", - "xpack.canvas.transitions.rotate.help": "从一页旋转到下一页", - "xpack.canvas.transitions.slide.displayName": "滑动", - "xpack.canvas.transitions.slide.help": "从一页滑到下一页", - "xpack.canvas.transitions.zoom.displayName": "缩放", - "xpack.canvas.transitions.zoom.help": "从一页缩放到下一页", - "xpack.canvas.uis.arguments.axisConfig.position.options.bottomDropDown": "下", - "xpack.canvas.uis.arguments.axisConfig.position.options.leftDropDown": "左", - "xpack.canvas.uis.arguments.axisConfig.position.options.rightDropDown": "右", - "xpack.canvas.uis.arguments.axisConfig.position.options.topDropDown": "上", - "xpack.canvas.uis.arguments.axisConfig.positionLabel": "位置", - "xpack.canvas.uis.arguments.axisConfigLabel": "可视化轴配置", - "xpack.canvas.uis.arguments.axisConfigTitle": "轴配置", - "xpack.canvas.uis.arguments.dataColumn.options.averageDropDown": "平均值", - "xpack.canvas.uis.arguments.dataColumn.options.countDropDown": "计数", - "xpack.canvas.uis.arguments.dataColumn.options.firstDropDown": "第一", - "xpack.canvas.uis.arguments.dataColumn.options.lastDropDown": "最后", - "xpack.canvas.uis.arguments.dataColumn.options.maxDropDown": "最大值", - "xpack.canvas.uis.arguments.dataColumn.options.medianDropDown": "中值", - "xpack.canvas.uis.arguments.dataColumn.options.minDropDown": "最小值", - "xpack.canvas.uis.arguments.dataColumn.options.sumDropDown": "和", - "xpack.canvas.uis.arguments.dataColumn.options.uniqueDropDown": "唯一", - "xpack.canvas.uis.arguments.dataColumn.options.valueDropDown": "值", - "xpack.canvas.uis.arguments.dataColumnLabel": "选择数据列", - "xpack.canvas.uis.arguments.dataColumnTitle": "列", - "xpack.canvas.uis.arguments.dateFormatLabel": "选择或输入 {momentJS} 格式", - "xpack.canvas.uis.arguments.dateFormatTitle": "日期格式", - "xpack.canvas.uis.arguments.filterGroup.createNewGroupLinkText": "创建新组", - "xpack.canvas.uis.arguments.filterGroupLabel": "创建或选择筛选组", - "xpack.canvas.uis.arguments.filterGroupTitle": "筛选组", - "xpack.canvas.uis.arguments.imageUpload.fileUploadPromptLabel": "选择或拖放图像", - "xpack.canvas.uis.arguments.imageUpload.imageUploadingLabel": "图像上传", - "xpack.canvas.uis.arguments.imageUpload.urlFieldPlaceholder": "图像 {url}", - "xpack.canvas.uis.arguments.imageUpload.urlTypes.assetDropDown": "资产", - "xpack.canvas.uis.arguments.imageUpload.urlTypes.fileDropDown": "导入", - "xpack.canvas.uis.arguments.imageUpload.urlTypes.linkDropDown": "链接", - "xpack.canvas.uis.arguments.imageUploadLabel": "选择或上传图像", - "xpack.canvas.uis.arguments.imageUploadTitle": "图像上传", - "xpack.canvas.uis.arguments.numberFormat.format.bytesDropDown": "字节", - "xpack.canvas.uis.arguments.numberFormat.format.currencyDropDown": "货币", - "xpack.canvas.uis.arguments.numberFormat.format.durationDropDown": "持续时间", - "xpack.canvas.uis.arguments.numberFormat.format.numberDropDown": "数字", - "xpack.canvas.uis.arguments.numberFormat.format.percentDropDown": "百分比", - "xpack.canvas.uis.arguments.numberFormatLabel": "选择或输入有效的 {numeralJS} 格式", - "xpack.canvas.uis.arguments.numberFormatTitle": "数字格式", - "xpack.canvas.uis.arguments.numberLabel": "输入数字", - "xpack.canvas.uis.arguments.numberTitle": "数字", - "xpack.canvas.uis.arguments.paletteLabel": "选择调色板", - "xpack.canvas.uis.arguments.paletteTitle": "调色板", - "xpack.canvas.uis.arguments.percentageLabel": "百分比滑块 ", - "xpack.canvas.uis.arguments.percentageTitle": "百分比", - "xpack.canvas.uis.arguments.rangeLabel": "范围内的值滑块", - "xpack.canvas.uis.arguments.rangeTitle": "范围", - "xpack.canvas.uis.arguments.selectLabel": "从具有多个选项的下拉列表中选择", - "xpack.canvas.uis.arguments.selectTitle": "选择", - "xpack.canvas.uis.arguments.shapeLabel": "形状选取器", - "xpack.canvas.uis.arguments.shapeTitle": "形状", - "xpack.canvas.uis.arguments.stringLabel": "输入短字符串", - "xpack.canvas.uis.arguments.stringTitle": "字符串", - "xpack.canvas.uis.arguments.textareaLabel": "输入长字符串", - "xpack.canvas.uis.arguments.textareaTitle": "文本区域", - "xpack.canvas.uis.arguments.toggleLabel": "True/False 切换开关", - "xpack.canvas.uis.arguments.toggleTitle": "切换", - "xpack.canvas.uis.dataSources.demoData.headingTitle": "您正在使用演示数据", - "xpack.canvas.uis.dataSources.demoDataLabel": "使用用户名、价格、项目、国家/地区和阶段模拟数据集", - "xpack.canvas.uis.dataSources.demoDataTitle": "演示数据", - "xpack.canvas.uis.dataSources.essqlLabel": "使用 {elasticsearch} {sql} 以获取数据表", - "xpack.canvas.uis.dataSources.essqlTitle": "{elasticsearch} {sql}", - "xpack.canvas.uis.dataSources.timelion.intervalTitle": "时间间隔", - "xpack.canvas.uis.dataSources.timelion.queryLabel": "{lucene} 查询字符串语法", - "xpack.canvas.uis.dataSources.timelion.queryTitle": "查询", - "xpack.canvas.uis.dataSources.timelion.tips.functions": "一些 {timelion} 函数(如 {functionExample})不转换成 {canvas} 数据表。任何与数据操作有关的内容都适用。", - "xpack.canvas.uis.dataSources.timelion.tips.time": "{timelion} 需要时间范围,您应将时间筛选元素添加到页面上的某个位置,或使用代码编辑器传入时间筛选。", - "xpack.canvas.uis.dataSources.timelionLabel": "使用 {timelion} 语法检索时间序列", - "xpack.canvas.uis.models.math.args.valueLabel": "要用于从数据源提取值的函数和列", - "xpack.canvas.uis.models.math.args.valueTitle": "值", - "xpack.canvas.uis.models.mathTitle": "度量", - "xpack.canvas.uis.models.pointSeries.args.colorLabel": "确定标记或序列的颜色", - "xpack.canvas.uis.models.pointSeries.args.colorTitle": "颜色", - "xpack.canvas.uis.models.pointSeries.args.sizeLabel": "确定标记的大小", - "xpack.canvas.uis.models.pointSeries.args.sizeTitle": "大小", - "xpack.canvas.uis.models.pointSeries.args.textLabel": "设置要用作标记或用在标记旁的文本", - "xpack.canvas.uis.models.pointSeries.args.textTitle": "文本", - "xpack.canvas.uis.models.pointSeries.args.xaxisLabel": "横轴上的数据。通常为数字、字符串或日期", - "xpack.canvas.uis.models.pointSeries.args.xaxisTitle": "X 轴", - "xpack.canvas.uis.models.pointSeries.args.yaxisLabel": "竖轴上的数据。通常为数字", - "xpack.canvas.uis.models.pointSeries.args.yaxisTitle": "Y 轴", - "xpack.canvas.uis.models.pointSeriesTitle": "维度和度量", - "xpack.canvas.uis.transforms.formatDate.args.formatTitle": "格式", - "xpack.canvas.uis.transforms.formatDateTitle": "日期格式", - "xpack.canvas.uis.transforms.formatNumber.args.formatTitle": "格式", - "xpack.canvas.uis.transforms.formatNumberTitle": "数字格式", - "xpack.canvas.uis.transforms.roundDate.args.formatLabel": "选择或输入 {momentJs} 格式以舍入日期", - "xpack.canvas.uis.transforms.roundDate.args.formatTitle": "格式", - "xpack.canvas.uis.transforms.roundDateTitle": "舍入日期", - "xpack.canvas.uis.transforms.sort.args.reverseToggleSwitch": "降序", - "xpack.canvas.uis.transforms.sort.args.sortFieldTitle": "排序字段", - "xpack.canvas.uis.transforms.sortTitle": "数据表排序", - "xpack.canvas.uis.views.dropdownControl.args.filterColumnLabel": "从下拉列表中选择的值应用到的列", - "xpack.canvas.uis.views.dropdownControl.args.filterColumnTitle": "筛选列", - "xpack.canvas.uis.views.dropdownControl.args.filterGroupLabel": "将选定组名称应用到元素的筛选函数,以定位该筛选", - "xpack.canvas.uis.views.dropdownControl.args.filterGroupTitle": "筛选组", - "xpack.canvas.uis.views.dropdownControl.args.valueColumnLabel": "从其中提取下拉列表可用值的列", - "xpack.canvas.uis.views.dropdownControl.args.valueColumnTitle": "值列", - "xpack.canvas.uis.views.dropdownControlTitle": "下拉列表筛选", - "xpack.canvas.uis.views.getCellLabel": "获取第一行和第一列", - "xpack.canvas.uis.views.getCellTitle": "下拉列表筛选", - "xpack.canvas.uis.views.image.args.mode.containDropDown": "包含", - "xpack.canvas.uis.views.image.args.mode.coverDropDown": "覆盖", - "xpack.canvas.uis.views.image.args.mode.stretchDropDown": "拉伸", - "xpack.canvas.uis.views.image.args.modeLabel": "注意:拉伸填充可能不适用于矢量图。", - "xpack.canvas.uis.views.image.args.modeTitle": "填充模式", - "xpack.canvas.uis.views.imageTitle": "图像", - "xpack.canvas.uis.views.markdown.args.contentLabel": "{markdown} 格式文本", - "xpack.canvas.uis.views.markdown.args.contentTitle": "{markdown} 内容", - "xpack.canvas.uis.views.markdownLabel": "使用 {markdown} 生成标记", - "xpack.canvas.uis.views.markdownTitle": "{markdown}", - "xpack.canvas.uis.views.metric.args.labelArgLabel": "描述指标", - "xpack.canvas.uis.views.metric.args.labelArgTitle": "标签", - "xpack.canvas.uis.views.metric.args.labelFontLabel": "字体、对齐和颜色", - "xpack.canvas.uis.views.metric.args.labelFontTitle": "标签文本设置", - "xpack.canvas.uis.views.metric.args.metricFontLabel": "字体、对齐和颜色", - "xpack.canvas.uis.views.metric.args.metricFontTitle": "指标文本设置", - "xpack.canvas.uis.views.metric.args.metricFormatLabel": "字体、对齐和颜色", - "xpack.canvas.uis.views.metric.args.metricFormatTitle": "指标格式", - "xpack.canvas.uis.views.metricTitle": "指标", - "xpack.canvas.uis.views.numberArgTitle": "数字", - "xpack.canvas.uis.views.pie.args.holeLabel": "孔洞半径", - "xpack.canvas.uis.views.pie.args.holeTitle": "内半径", - "xpack.canvas.uis.views.pie.args.labelRadiusLabel": "标签到饼图中心的距离", - "xpack.canvas.uis.views.pie.args.labelRadiusTitle": "标签半径", - "xpack.canvas.uis.views.pie.args.labelsTitle": "标签", - "xpack.canvas.uis.views.pie.args.labelsToggleSwitch": "显示/隐藏标签", - "xpack.canvas.uis.views.pie.args.legendLabel": "禁用或定位图例", - "xpack.canvas.uis.views.pie.args.legendTitle": "图例位置", - "xpack.canvas.uis.views.pie.args.radiusLabel": "饼图半径", - "xpack.canvas.uis.views.pie.args.radiusTitle": "半径", - "xpack.canvas.uis.views.pie.args.tiltLabel": "倾斜百分比,其中 100 为完全垂直,0 为完全水平", - "xpack.canvas.uis.views.pie.args.tiltTitle": "倾斜角度", - "xpack.canvas.uis.views.pieTitle": "图表样式", - "xpack.canvas.uis.views.plot.args.defaultStyleLabel": "设置每个序列默认使用的样式,除非被覆盖", - "xpack.canvas.uis.views.plot.args.defaultStyleTitle": "默认样式", - "xpack.canvas.uis.views.plot.args.legendLabel": "禁用或定位图例", - "xpack.canvas.uis.views.plot.args.legendTitle": "图例位置", - "xpack.canvas.uis.views.plot.args.xaxisLabel": "配置或禁用 X 轴", - "xpack.canvas.uis.views.plot.args.xaxisTitle": "X 轴", - "xpack.canvas.uis.views.plot.args.yaxisLabel": "配置或禁用 Y 轴", - "xpack.canvas.uis.views.plot.args.yaxisTitle": "Y 轴", - "xpack.canvas.uis.views.plotTitle": "图表样式", - "xpack.canvas.uis.views.progress.args.barColorLabel": "接受 HEX、RGB 或 HTML 颜色名称", - "xpack.canvas.uis.views.progress.args.barColorTitle": "背景色", - "xpack.canvas.uis.views.progress.args.barWeightLabel": "背景条形的粗细", - "xpack.canvas.uis.views.progress.args.barWeightTitle": "背景权重", - "xpack.canvas.uis.views.progress.args.fontLabel": "标签的字体设置。通常,也可以添加其他样式", - "xpack.canvas.uis.views.progress.args.fontTitle": "标签设置", - "xpack.canvas.uis.views.progress.args.labelArgLabel": "设置 {true}/{false} 以显示/隐藏标签或提供显示为标签的字符串", - "xpack.canvas.uis.views.progress.args.labelArgTitle": "标签", - "xpack.canvas.uis.views.progress.args.maxLabel": "进度元素的最大值", - "xpack.canvas.uis.views.progress.args.maxTitle": "最大值", - "xpack.canvas.uis.views.progress.args.shapeLabel": "进度指示的形状", - "xpack.canvas.uis.views.progress.args.shapeTitle": "形状", - "xpack.canvas.uis.views.progress.args.valueColorLabel": "接受 {hex}、{rgb} 或 {html} 颜色名称", - "xpack.canvas.uis.views.progress.args.valueColorTitle": "进度颜色", - "xpack.canvas.uis.views.progress.args.valueWeightLabel": "进度条的粗细", - "xpack.canvas.uis.views.progress.args.valueWeightTitle": "进度权重", - "xpack.canvas.uis.views.progressTitle": "进度", - "xpack.canvas.uis.views.render.args.css.applyButtonLabel": "应用样式表", - "xpack.canvas.uis.views.render.args.cssLabel": "适用于您的元素的 {css} 样式表", - "xpack.canvas.uis.views.renderLabel": "您的元素的容器设置", - "xpack.canvas.uis.views.renderTitle": "元素样式", - "xpack.canvas.uis.views.repeatImage.args.emptyImageLabel": "填补值与最大计数之间差异的图像", - "xpack.canvas.uis.views.repeatImage.args.emptyImageTitle": "空图像", - "xpack.canvas.uis.views.repeatImage.args.imageLabel": "要重复的图像", - "xpack.canvas.uis.views.repeatImage.args.imageTitle": "图像", - "xpack.canvas.uis.views.repeatImage.args.maxLabel": "重复图像的最大数目", - "xpack.canvas.uis.views.repeatImage.args.maxTitle": "最大计数", - "xpack.canvas.uis.views.repeatImage.args.sizeLabel": "图像最大维度的大小。例如,如果图像高而不宽,则其为高度", - "xpack.canvas.uis.views.repeatImage.args.sizeTitle": "图像大小", - "xpack.canvas.uis.views.repeatImageTitle": "重复图像", - "xpack.canvas.uis.views.revealImage.args.emptyImageLabel": "背景图像。例如,空杯子", - "xpack.canvas.uis.views.revealImage.args.emptyImageTitle": "背景图像", - "xpack.canvas.uis.views.revealImage.args.imageLabel": "显示给定函数输入的图像。例如,满杯子", - "xpack.canvas.uis.views.revealImage.args.imageTitle": "图像", - "xpack.canvas.uis.views.revealImage.args.origin.bottomDropDown": "下", - "xpack.canvas.uis.views.revealImage.args.origin.leftDropDown": "左", - "xpack.canvas.uis.views.revealImage.args.origin.rightDropDown": "右", - "xpack.canvas.uis.views.revealImage.args.origin.topDropDown": "上", - "xpack.canvas.uis.views.revealImage.args.originLabel": "开始显示的方向", - "xpack.canvas.uis.views.revealImage.args.originTitle": "显示自", - "xpack.canvas.uis.views.revealImageTitle": "显示图像", - "xpack.canvas.uis.views.shape.args.borderLabel": "接受 HEX、RGB 或 HTML 颜色名称", - "xpack.canvas.uis.views.shape.args.borderTitle": "边框", - "xpack.canvas.uis.views.shape.args.borderWidthLabel": "边框宽度", - "xpack.canvas.uis.views.shape.args.borderWidthTitle": "边框宽度", - "xpack.canvas.uis.views.shape.args.fillLabel": "接受 HEX、RGB 或 HTML 颜色名称", - "xpack.canvas.uis.views.shape.args.fillTitle": "填充", - "xpack.canvas.uis.views.shape.args.maintainAspectTitle": "保持纵横比", - "xpack.canvas.uis.views.shape.args.shapeTitle": "选择形状", - "xpack.canvas.uis.views.shapeTitle": "形状", - "xpack.canvas.uis.views.table.args.paginateLabel": "显示或隐藏分页控制。如果禁用,仅第一页显示", - "xpack.canvas.uis.views.table.args.paginateTitle": "分页", - "xpack.canvas.uis.views.table.args.perPageLabel": "每个表页面要显示的行数", - "xpack.canvas.uis.views.table.args.perPageTitle": "每页行数", - "xpack.canvas.uis.views.table.args.showHeaderLabel": "显示或隐藏具有每列标题的标题行", - "xpack.canvas.uis.views.table.args.showHeaderTitle": "标题", - "xpack.canvas.uis.views.tableLabel": "设置表元素的样式", - "xpack.canvas.uis.views.tableTitle": "表样式", - "xpack.canvas.uis.views.timefilter.args.columnConfirmButtonLabel": "设置", - "xpack.canvas.uis.views.timefilter.args.columnLabel": "应用选定时间的列", - "xpack.canvas.uis.views.timefilter.args.columnTitle": "列", - "xpack.canvas.uis.views.timefilter.args.filterGroupLabel": "将选定组名称应用到元素的筛选函数,以定位该筛选", - "xpack.canvas.uis.views.timefilter.args.filterGroupTitle": "筛选组名称", - "xpack.canvas.uis.views.timefilterTitle": "时间筛选", - "xpack.canvas.units.quickRange.dayBeforeYesterday": "前天", - "xpack.canvas.units.quickRange.last12Hours": "过去 12 小时", - "xpack.canvas.units.quickRange.last15Minutes": "过去 15 分钟", - "xpack.canvas.units.quickRange.last1Hour": "过去 1 小时", - "xpack.canvas.units.quickRange.last1Year": "过去 1 年", - "xpack.canvas.units.quickRange.last24Hours": "过去 24 小时", - "xpack.canvas.units.quickRange.last2Weeks": "过去 2 周", - "xpack.canvas.units.quickRange.last2Years": "过去 2 年", - "xpack.canvas.units.quickRange.last30Days": "过去 30 天", - "xpack.canvas.units.quickRange.last30Minutes": "过去 30 分钟", - "xpack.canvas.units.quickRange.last4Hours": "过去 4 小时", - "xpack.canvas.units.quickRange.last5Years": "过去 5 年", - "xpack.canvas.units.quickRange.last60Days": "过去 60 天", - "xpack.canvas.units.quickRange.last6Months": "过去 6 个月", - "xpack.canvas.units.quickRange.last7Days": "过去 7 天", - "xpack.canvas.units.quickRange.last90Days": "过去 90 天", - "xpack.canvas.units.quickRange.monthToDate": "本月迄今为止", - "xpack.canvas.units.quickRange.previousMonth": "上一月", - "xpack.canvas.units.quickRange.previousWeek": "上一周", - "xpack.canvas.units.quickRange.previousYear": "上一年", - "xpack.canvas.units.quickRange.theDaySoFar": "今天迄今为止", - "xpack.canvas.units.quickRange.thisDayLastWeek": "上周本日", - "xpack.canvas.units.quickRange.thisMonth": "本月", - "xpack.canvas.units.quickRange.thisWeek": "本周", - "xpack.canvas.units.quickRange.thisYear": "本年", - "xpack.canvas.units.quickRange.today": "今日", - "xpack.canvas.units.quickRange.weekToDate": "本周迄今为止", - "xpack.canvas.units.quickRange.yearToDate": "本年迄今为止", - "xpack.canvas.units.quickRange.yesterday": "昨天", - "xpack.canvas.units.time.days": "{days, plural, one {# 天} other {# 天}}", - "xpack.canvas.units.time.hours": "{hours, plural, one {# 小时} other {# 小时}}", - "xpack.canvas.units.time.minutes": "{minutes, plural, one {# 分钟} other {# 分钟}}", - "xpack.canvas.units.time.seconds": "{seconds, plural, one {# 秒} other {# 秒}}", - "xpack.canvas.workpadConfig.applyStylesheetButtonLabel": "应用样式表", - "xpack.canvas.workpadConfig.globalCSSLabel": "全局 CSS 覆盖", - "xpack.canvas.workpadConfig.globalCSSTooltip": "将样式应用到此 Workpad 中的所有页面", - "xpack.canvas.workpadConfig.heightLabel": "高", - "xpack.canvas.workpadConfig.nameLabel": "名称", - "xpack.canvas.workpadConfig.pageSizeBadgeAriaLabel": "预设页面大小:{sizeName}", - "xpack.canvas.workpadConfig.pageSizeBadgeOnClickAriaLabel": "将页面大小设置为 {sizeName}", - "xpack.canvas.workpadConfig.swapDimensionsAriaLabel": "交换页面的宽和高", - "xpack.canvas.workpadConfig.swapDimensionsTooltip": "交换宽高", - "xpack.canvas.workpadConfig.title": "Workpad", - "xpack.canvas.workpadConfig.USLetterButtonLabel": "美国信函", - "xpack.canvas.workpadConfig.widthLabel": "宽", - "xpack.canvas.workpadCreate.createButtonLabel": "创建 Workpad", - "xpack.canvas.workpadHeader.addElementButtonLabel": "添加元素", - "xpack.canvas.workpadHeader.addElementModalCloseButtonLabel": "关闭", - "xpack.canvas.workpadHeader.cycleIntervalDaysText": "每 {days} {days, plural, one {天} other {天}}", - "xpack.canvas.workpadHeader.cycleIntervalHoursText": "每 {hours} {hours, plural, one {小时} other {小时}}", - "xpack.canvas.workpadHeader.cycleIntervalMinutesText": "每 {minutes} {minutes, plural, one {分钟} other {分钟}}", - "xpack.canvas.workpadHeader.cycleIntervalSecondsText": "每 {seconds} {seconds, plural, one {秒} other {秒}}", - "xpack.canvas.workpadHeader.embedObjectButtonLabel": "嵌入对象", - "xpack.canvas.workpadHeader.fullscreenButtonAriaLabel": "全屏查看", - "xpack.canvas.workpadHeader.fullscreenTooltip": "进入全屏模式", - "xpack.canvas.workpadHeader.hideEditControlTooltip": "隐藏编辑控件", - "xpack.canvas.workpadHeader.noWritePermissionTooltip": "您无权编辑此 Workpad", - "xpack.canvas.workpadHeader.showEditControlTooltip": "显示编辑控件", - "xpack.canvas.workpadHeaderAutoRefreshControls.disableTooltip": "禁用自动刷新", - "xpack.canvas.workpadHeaderAutoRefreshControls.intervalFormLabel": "更改自动刷新时间间隔", - "xpack.canvas.workpadHeaderAutoRefreshControls.refreshListDurationManualText": "手动", - "xpack.canvas.workpadHeaderAutoRefreshControls.refreshListTitle": "刷新元素", - "xpack.canvas.workpadHeaderControlSettings.settingsTooltip": "控制设置", - "xpack.canvas.workpadHeaderCustomInterval.confirmButtonLabel": "设置", - "xpack.canvas.workpadHeaderCustomInterval.formDescription": "使用速记表示法,如 {secondsExample}、{minutesExample} 或 {hoursExample}", - "xpack.canvas.workpadHeaderCustomInterval.formLabel": "设置定制时间间隔", - "xpack.canvas.workpadHeaderKioskControl.controlTitle": "循环播放全屏页面", - "xpack.canvas.workpadHeaderKioskControl.cycleFormLabel": "更改循环播放时间间隔", - "xpack.canvas.workpadHeaderKioskControl.cycleToggleSwitch": "自动循环播放幻灯片", - "xpack.canvas.workpadHeaderRefreshControlSettings.refreshAriaLabel": "刷新元素", - "xpack.canvas.workpadHeaderRefreshControlSettings.refreshTooltip": "刷新数据", - "xpack.canvas.workpadHeaderWorkpadExport.copyPDFMessage": "{PDF} 生成 {URL} 已复制到剪贴板", - "xpack.canvas.workpadHeaderWorkpadExport.copyReportingConfigMessage": "已将报告配置复制到剪贴板", - "xpack.canvas.workpadHeaderWorkpadExport.copyShareConfigMessage": "已将共享标记复制到剪贴板", - "xpack.canvas.workpadHeaderWorkpadExport.exportPDFErrorMessage": "无法为“{workpadName}”创建 {PDF}", - "xpack.canvas.workpadHeaderWorkpadExport.exportPDFMessage": "正在导出 {PDF}。可以在“管理”中跟踪进度。", - "xpack.canvas.workpadHeaderWorkpadExport.exportPDFTitle": "Workpad“{workpadName}”的 {PDF} 导出", - "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelCopyAriaLabel": "或者,也可以从脚本或使用 {URL} 通过 Watcher 生成 {PDF}。按 Enter 键可将 {URL} 复制到剪贴板。", - "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelCopyButtonLabel": "复制 {POST} {URL}", - "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelCopyDescription": "或者,复制此 {POST} {URL} 以从 {KIBANA} 外部或从 Watcher 调用生成。", - "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelDisabledDescription": "导出到 PDF 已禁用。必须配置报告,才能使用 Chromium 浏览器。将其添加到您的 {fileName} 文件中。", - "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelGenerateButtonLabel": "生成 {PDF}", - "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelGenerateDescription": "{PDF} 可能会花费 1 或 2 分钟生成,取决于 Workpad 的大小。", - "xpack.canvas.workpadHeaderWorkpadExport.shareDownloadJSONTitle": "下载为 {JSON}", - "xpack.canvas.workpadHeaderWorkpadExport.shareDownloadPDFTitle": "{PDF} 报告", - "xpack.canvas.workpadHeaderWorkpadExport.shareWebsiteErrorTitle": "无法为“{workpadName}”创建 {ZIP} 文件。Workpad 可能过大。您将需要分别下载文件。", - "xpack.canvas.workpadHeaderWorkpadExport.shareWebsiteTitle": "在网站上共享", - "xpack.canvas.workpadHeaderWorkpadExport.shareWorkpadMessage": "共享此 Workpad", - "xpack.canvas.workpadHeaderWorkpadExport.unknownExportErrorMessage": "未知导出类型:{type}", - "xpack.canvas.workpadHeaderWorkpadExport.unsupportedRendererWarning": "此 Workpad 包含 {CANVAS} Shareable Workpad Runtime 不支持的呈现函数。将不会呈现以下元素:", - "xpack.canvas.workpadHeaderWorkpadZoom.zoomControlsAriaLabel": "缩放控制", - "xpack.canvas.workpadHeaderWorkpadZoom.zoomControlsTooltip": "缩放控制", - "xpack.canvas.workpadHeaderWorkpadZoom.zoomFitToWindowText": "适应窗口大小", - "xpack.canvas.workpadHeaderWorkpadZoom.zoomInText": "放大", - "xpack.canvas.workpadHeaderWorkpadZoom.zoomOutText": "缩小", - "xpack.canvas.workpadHeaderWorkpadZoom.zoomPanelTitle": "缩放", - "xpack.canvas.workpadHeaderWorkpadZoom.zoomPrecentageValue": "重置", - "xpack.canvas.workpadHeaderWorkpadZoom.zoomResetText": "{scalePercentage}%", - "xpack.canvas.workpadLoader.clonedWorkpadName": "{workpadName} 的副本", - "xpack.canvas.workpadLoader.cloneTooltip": "克隆 Workpad", - "xpack.canvas.workpadLoader.createWorkpadLoadingDescription": "正在创建 Workpad......", - "xpack.canvas.workpadLoader.deleteButtonAriaLabel": "删除 {numberOfWorkpads} 个 Workpad", - "xpack.canvas.workpadLoader.deleteButtonLabel": "删除 ({numberOfWorkpads})", - "xpack.canvas.workpadLoader.deleteModalConfirmButtonLabel": "删除", - "xpack.canvas.workpadLoader.deleteModalDescription": "您无法恢复删除的 Workpad。", - "xpack.canvas.workpadLoader.deleteMultipleWorkpadsModalTitle": "删除 {numberOfWorkpads} 个 Workpad?", - "xpack.canvas.workpadLoader.deleteSingleWorkpadModalTitle": "删除 Workpad“{workpadName}”?", - "xpack.canvas.workpadLoader.emptyPromptGettingStartedDescription": "创建新的 Workpad、从模板入手或通过将 Workpad {JSON} 文件拖放到此处来导入。", - "xpack.canvas.workpadLoader.emptyPromptNewUserDescription": "{CANVAS} 新手?", - "xpack.canvas.workpadLoader.emptyPromptTitle": "添加您的首个 Workpad", - "xpack.canvas.workpadLoader.exportButtonAriaLabel": "导出 {numberOfWorkpads} 个 Workpad", - "xpack.canvas.workpadLoader.exportButtonLabel": "导出 ({numberOfWorkpads})", - "xpack.canvas.workpadLoader.exportTooltip": "导出 Workpad", - "xpack.canvas.workpadLoader.fetchLoadingDescription": "正在获取 Workpad......", - "xpack.canvas.workpadLoader.filePickerPlaceholder": "导入 Workpad {JSON} 文件", - "xpack.canvas.workpadLoader.loadWorkpadArialLabel": "加载 Workpad“{workpadName}”", - "xpack.canvas.workpadLoader.noPermissionToCloneToolTip": "您无权克隆 Workpad", - "xpack.canvas.workpadLoader.noPermissionToCreateToolTip": "您无权创建 Workpad", - "xpack.canvas.workpadLoader.noPermissionToDeleteToolTip": "您无权删除 Workpad", - "xpack.canvas.workpadLoader.noPermissionToUploadToolTip": "您无权上传 Workpad", - "xpack.canvas.workpadLoader.sampleDataLinkLabel": "添加您的首个 Workpad", - "xpack.canvas.workpadLoader.table.createdColumnTitle": "创建时间", - "xpack.canvas.workpadLoader.table.nameColumnTitle": "Workpad 名称", - "xpack.canvas.workpadLoader.table.updatedColumnTitle": "更新时间", - "xpack.canvas.workpadManager.modalTitle": "{CANVAS} Workpad", - "xpack.canvas.workpadManager.myWorkpadsTabLabel": "我的 Workpad", - "xpack.canvas.workpadManager.workpadTemplatesTabLabel": "模板", - "xpack.canvas.workpadSearch.searchPlaceholder": "查找 Workpad", - "xpack.canvas.workpadTemplate.cloneTemplateLinkAriaLabel": "克隆 Workpad 模板“{templateName}”", - "xpack.canvas.workpadTemplate.searchPlaceholder": "查找模板", - "xpack.canvas.workpadTemplates.table.descriptionColumnTitle": "描述", - "xpack.canvas.workpadTemplates.table.nameColumnTitle": "模板名称", - "xpack.canvas.workpadTemplates.table.tagsColumnTitle": "标记", - "xpack.canvas.badge.readOnly.tooltip": "无法保存 {canvas} Workpad", - "xpack.crossClusterReplication.addAutoFollowPatternButtonLabel": "创建自动跟随模式", - "xpack.crossClusterReplication.addBreadcrumbTitle": "添加", - "xpack.crossClusterReplication.addFollowerButtonLabel": "创建 Follower 索引", - "xpack.crossClusterReplication.app.checkPermissionsFatalErrorTitle": "跨集群复制应用", - "xpack.crossClusterReplication.app.deniedPermissionDescription": "要使用跨集群复制,您必须具有{clusterPrivilegesCount, plural, one {以下集群权限} other {以下集群权限}}:{clusterPrivileges}。", - "xpack.crossClusterReplication.app.deniedPermissionTitle": "您缺少集群权限", - "xpack.crossClusterReplication.app.permissionCheckErrorTitle": "检查权限时出错", - "xpack.crossClusterReplication.app.permissionCheckTitle": "正在检查权限......", - "xpack.crossClusterReplication.appTitle": "跨集群复制", - "xpack.crossClusterReplication.autoFollowPattern.addAction.successNotificationTitle": "已添加自动跟随模式“{name}”", - "xpack.crossClusterReplication.autoFollowPattern.addTitle": "添加自动跟随模式", - "xpack.crossClusterReplication.autoFollowPattern.editTitle": "编辑自动跟随模式", - "xpack.crossClusterReplication.autoFollowPattern.leaderIndexPatternValidation.illegalCharacters": "从索引模式中删除{characterListLength, plural, one {字符} other {字符}} {characterList}。", - "xpack.crossClusterReplication.autoFollowPattern.leaderIndexPatternValidation.isEmpty": "至少需要一个 Leader 索引模式。", - "xpack.crossClusterReplication.autoFollowPattern.leaderIndexPatternValidation.noEmptySpace": "索引模式中不允许使用空格。", - "xpack.crossClusterReplication.autoFollowPattern.nameValidation.errorComma": "名称中不允许使用逗号。", - "xpack.crossClusterReplication.autoFollowPattern.nameValidation.errorEmptyName": "“名称”必填", - "xpack.crossClusterReplication.autoFollowPattern.nameValidation.errorSpace": "名称中不允许使用空格。", - "xpack.crossClusterReplication.autoFollowPattern.nameValidation.errorUnderscore": "名称不能以下划线开头。", - "xpack.crossClusterReplication.autoFollowPattern.prefixValidation.beginsWithPeriod": "前缀不能以逗点开头。", - "xpack.crossClusterReplication.autoFollowPattern.prefixValidation.illegalCharacters": "从前缀中删除{characterListLength, plural, one {字符} other {字符}} {characterList}。", - "xpack.crossClusterReplication.autoFollowPattern.prefixValidation.noEmptySpace": "前缀中不能使用空格。", - "xpack.crossClusterReplication.autoFollowPattern.removeAction.errorMultipleNotificationTitle": "删除 {count} 个自动跟随模式时出错", - "xpack.crossClusterReplication.autoFollowPattern.removeAction.errorSingleNotificationTitle": "删除 “{name}” 自动跟随模式时出错", - "xpack.crossClusterReplication.autoFollowPattern.removeAction.successMultipleNotificationTitle": "{count} 个自动跟随模式已删除", - "xpack.crossClusterReplication.autoFollowPattern.removeAction.successSingleNotificationTitle": "自动跟随模式 “{name}” 已删除", - "xpack.crossClusterReplication.autoFollowPattern.suffixValidation.illegalCharacters": "从后缀中删除{characterListLength, plural, one {字符} other {字符}} {characterList}。", - "xpack.crossClusterReplication.autoFollowPattern.suffixValidation.noEmptySpace": "后缀中不能使用空格。", - "xpack.crossClusterReplication.autoFollowPattern.updateAction.successNotificationTitle": "自动跟随模式 “{name}” 已成功更新", - "xpack.crossClusterReplication.autoFollowPatternCreateForm.loadingRemoteClustersMessage": "正在加载远程集群……", - "xpack.crossClusterReplication.autoFollowPatternCreateForm.saveButtonLabel": "创建", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.closeButtonLabel": "关闭", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.deleteButtonLabel": "删除", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.editButtonLabel": "编辑", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.leaderPatternsLabel": "Leader 模式", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.notFoundLabel": "未找到自动跟随模式", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.prefixEmptyValue": "无前缀", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.prefixLabel": "前缀", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.recentErrorsTitle": "最近错误", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.remoteClusterLabel": "远程集群", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.statusTitle": "设置", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.suffixEmptyValue": "无后缀", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.suffixLabel": "后缀", - "xpack.crossClusterReplication.autoFollowPatternDetailPanel.viewIndicesLink": "在“索引管理”中查看您的 Follower 索引", - "xpack.crossClusterReplication.autoFollowPatternEditForm.loadingErrorMessage": "自动跟随模式“{name}”不存在。", - "xpack.crossClusterReplication.autoFollowPatternEditForm.loadingErrorTitle": "加载自动跟随模式时出错", - "xpack.crossClusterReplication.autoFollowPatternEditForm.loadingRemoteClustersMessage": "正在加载远程集群……", - "xpack.crossClusterReplication.autoFollowPatternEditForm.loadingTitle": "正在加载自动跟随模式……", - "xpack.crossClusterReplication.autoFollowPatternEditForm.saveButtonLabel": "更新", - "xpack.crossClusterReplication.autoFollowPatternEditForm.viewAutoFollowPatternsButtonLabel": "查看自动跟随模式", - "xpack.crossClusterReplication.autoFollowPatternForm.actions.savingText": "正在保存", - "xpack.crossClusterReplication.autoFollowPatternForm.autoFollowPattern.fieldPrefixLabel": "前缀", - "xpack.crossClusterReplication.autoFollowPatternForm.autoFollowPattern.fieldSuffixLabel": "后缀", - "xpack.crossClusterReplication.autoFollowPatternForm.autoFollowPatternName.fieldNameLabel": "名称", - "xpack.crossClusterReplication.autoFollowPatternForm.cancelButtonLabel": "取消", - "xpack.crossClusterReplication.autoFollowPatternForm.currentRemoteClusterNotConnectedCallOutDescription": "可以通过编辑远程集群来解决此问题。", - "xpack.crossClusterReplication.autoFollowPatternForm.currentRemoteClusterNotConnectedCallOutTitle": "无法编辑自动跟随模式,因为远程集群“{name}”未连接", - "xpack.crossClusterReplication.autoFollowPatternForm.currentRemoteClusterNotFoundCallOutDescription": "要编辑此自动跟随模式,您必须添加名为“{name}”的远程集群。", - "xpack.crossClusterReplication.autoFollowPatternForm.emptyRemoteClustersCallOutDescription": "自动跟随模式捕获远程集群上的索引。", - "xpack.crossClusterReplication.autoFollowPatternForm.fieldFollowerIndicesHelpLabel": "不允许使用空格和字符 {characterList}。", - "xpack.crossClusterReplication.autoFollowPatternForm.fieldLeaderIndexPatternsHelpLabel": "不允许使用空格和字符 {characterList}。", - "xpack.crossClusterReplication.autoFollowPatternForm.fieldLeaderIndexPatternsLabel": "索引模式", - "xpack.crossClusterReplication.autoFollowPatternForm.fieldLeaderIndexPatternsPlaceholder": "键入并按 ENTER 键", - "xpack.crossClusterReplication.autoFollowPatternForm.indicesPreviewDescription": "上述设置将生成类似下面的索引名称:", - "xpack.crossClusterReplication.autoFollowPatternForm.indicesPreviewTitle": "索引名称示例", - "xpack.crossClusterReplication.autoFollowPatternForm.leaderIndexPatternError.duplicateMessage": "不允许重复的 Leader 索引模式。", - "xpack.crossClusterReplication.autoFollowPatternForm.savingErrorTitle": "无法创建自动跟随模式", - "xpack.crossClusterReplication.autoFollowPatternForm.sectionAutoFollowPatternDescription": "应用于 Follower 索引名称的定制前缀或后缀,以便您可以更容易辨识复制的索引。默认情况下,Follower 索引与 Leader 索引有相同的名称。", - "xpack.crossClusterReplication.autoFollowPatternForm.sectionAutoFollowPatternNameDescription": "自动跟随模式的唯一名称。", - "xpack.crossClusterReplication.autoFollowPatternForm.sectionAutoFollowPatternNameTitle": "名称", - "xpack.crossClusterReplication.autoFollowPatternForm.sectionAutoFollowPatternTitle": "Follower 索引(可选)", - "xpack.crossClusterReplication.autoFollowPatternForm.sectionLeaderIndexPatternsDescription1": "用于标识要从远程集群复制的索引的一个或多个索引模式。创建匹配这些模式的新索引时,它们将会复制到本地集群上的 Follower 索引。", - "xpack.crossClusterReplication.autoFollowPatternForm.sectionLeaderIndexPatternsDescription2": "{note}不会复制已存在的索引。", - "xpack.crossClusterReplication.autoFollowPatternForm.sectionLeaderIndexPatternsDescription2.noteLabel": "注意:", - "xpack.crossClusterReplication.autoFollowPatternForm.sectionLeaderIndexPatternsTitle": "Leader 索引", - "xpack.crossClusterReplication.autoFollowPatternForm.sectionRemoteClusterDescription": "要从其中复制 Leader 索引的远程索引。", - "xpack.crossClusterReplication.autoFollowPatternForm.sectionRemoteClusterTitle": "远程集群", - "xpack.crossClusterReplication.autoFollowPatternForm.validationErrorTitle": "继续前请解决错误。", - "xpack.crossClusterReplication.autoFollowPatternList.addAutoFollowPatternButtonLabel": "创建自动跟随模式", - "xpack.crossClusterReplication.autoFollowPatternList.autoFollowPatternsDescription": "自动跟随模式从远程集群复制 Leader 索引,将它们复制到本地集群上的 Follower 索引。", - "xpack.crossClusterReplication.autoFollowPatternList.autoFollowPatternsTitle": "自动跟随模式", - "xpack.crossClusterReplication.autoFollowPatternList.crossClusterReplicationTitle": "跨集群复制", - "xpack.crossClusterReplication.autoFollowPatternList.emptyPromptDescription": "使用自动跟随模式自动从远程集群复制索引。", - "xpack.crossClusterReplication.autoFollowPatternList.emptyPromptTitle": "创建第一个自动跟随模式", - "xpack.crossClusterReplication.autoFollowPatternList.followerIndicesTitle": "Follower 索引", - "xpack.crossClusterReplication.autoFollowPatternList.loadingErrorTitle": "加载自动跟随模式时出错", - "xpack.crossClusterReplication.autoFollowPatternList.loadingTitle": "正在加载自动跟随模式……", - "xpack.crossClusterReplication.autoFollowPatternList.noPermissionText": "您无权查看或添加自动跟随模式。", - "xpack.crossClusterReplication.autoFollowPatternList.permissionErrorTitle": "权限错误", - "xpack.crossClusterReplication.autoFollowPatternList.table.actionDeleteDescription": "删除自动跟随模式", - "xpack.crossClusterReplication.autoFollowPatternList.table.actionEditDescription": "编辑自动跟随模式", - "xpack.crossClusterReplication.autoFollowPatternList.table.actionsColumnTitle": "操作", - "xpack.crossClusterReplication.autoFollowPatternList.table.clusterColumnTitle": "远程集群", - "xpack.crossClusterReplication.autoFollowPatternList.table.leaderPatternsColumnTitle": "Leader 模式", - "xpack.crossClusterReplication.autoFollowPatternList.table.nameColumnTitle": "名称", - "xpack.crossClusterReplication.autoFollowPatternList.table.prefixColumnTitle": "Follower 索引前缀", - "xpack.crossClusterReplication.autoFollowPatternList.table.suffixColumnTitle": "Follower 索引后缀", - "xpack.crossClusterReplication.checkLicense.errorExpiredMessage": "您不能使用 {pluginName},因为您的 {licenseType} 许可证已过期", - "xpack.crossClusterReplication.checkLicense.errorUnavailableMessage": "您不能使用 {pluginName},因为许可证信息当前不可用。", - "xpack.crossClusterReplication.checkLicense.errorUnsupportedMessage": "您的 {licenseType} 许可证不支持 {pluginName}。请升级您的许可。", - "xpack.crossClusterReplication.deleteAutoFollowPattern.confirmModal.cancelButtonText": "取消", - "xpack.crossClusterReplication.deleteAutoFollowPattern.confirmModal.confirmButtonText": "删除", - "xpack.crossClusterReplication.deleteAutoFollowPattern.confirmModal.deleteMultipleTitle": "是否删除 {count} 个自动跟随模式?", - "xpack.crossClusterReplication.deleteAutoFollowPattern.confirmModal.deleteSingleTitle": "是否删除自动跟随模式 {name}?", - "xpack.crossClusterReplication.deleteAutoFollowPattern.confirmModal.multipleDeletionDescription": "您即将删除以下自动跟随模式:", - "xpack.crossClusterReplication.deleteAutoFollowPatternButtonLabel": "删除自动跟随 {total, plural, one { 个模式} other { 个模式}}", - "xpack.crossClusterReplication.editBreadcrumbTitle": "编辑", - "xpack.crossClusterReplication.followerIndex.addAction.successNotificationTitle": "已添加 Follower 索引“{name}”", - "xpack.crossClusterReplication.followerIndex.addTitle": "添加 Follower 索引", - "xpack.crossClusterReplication.followerIndex.advancedSettingsForm.showSwitchLabel": "自定义高级设置", - "xpack.crossClusterReplication.followerIndex.contextMenu.buttonLabel": "管理 Follower {followerIndicesLength, plural, one {索引} other {索引}}", - "xpack.crossClusterReplication.followerIndex.contextMenu.editLabel": "编辑 Follower 索引", - "xpack.crossClusterReplication.followerIndex.contextMenu.pauseLabel": "暂停复制", - "xpack.crossClusterReplication.followerIndex.contextMenu.resumeLabel": "恢复复制", - "xpack.crossClusterReplication.followerIndex.contextMenu.title": "Follower {followerIndicesLength, plural, one {索引} other {索引}}选项", - "xpack.crossClusterReplication.followerIndex.contextMenu.unfollowLabel": "取消跟随 Leader {followerIndicesLength, plural, one {索引} other {索引}}", - "xpack.crossClusterReplication.followerIndex.editTitle": "编辑 Follower 索引", - "xpack.crossClusterReplication.followerIndex.indexNameValidation.noEmptySpace": "名称中不允许使用空格。", - "xpack.crossClusterReplication.followerIndex.leaderIndexValidation.noEmptySpace": "Leader 索引中不允许使用空格。", - "xpack.crossClusterReplication.followerIndex.pauseAction.errorMultipleNotificationTitle": "暂停 {count} 个 Follower 索引时出错", - "xpack.crossClusterReplication.followerIndex.pauseAction.errorSingleNotificationTitle": "暂停 Follower 索引“{name}”时出错", - "xpack.crossClusterReplication.followerIndex.pauseAction.successMultipleNotificationTitle": "{count} 个 Follower 索引已暂停", - "xpack.crossClusterReplication.followerIndex.pauseAction.successSingleNotificationTitle": "Follower 索引“{name}”已暂停", - "xpack.crossClusterReplication.followerIndex.resumeAction.errorMultipleNotificationTitle": "恢复 {count} 个 Follower 索引时出错", - "xpack.crossClusterReplication.followerIndex.resumeAction.errorSingleNotificationTitle": "恢复 Follower 索引“{name}”时出错", - "xpack.crossClusterReplication.followerIndex.resumeAction.successMultipleNotificationTitle": "{count} 个 Follower 索引已恢复", - "xpack.crossClusterReplication.followerIndex.resumeAction.successSingleNotificationTitle": "Follower 索引“{name}”已恢复", - "xpack.crossClusterReplication.followerIndex.unfollowAction.errorMultipleNotificationTitle": "取消跟随 {count} 个 Follower 索引的 Leader 索引时出错", - "xpack.crossClusterReplication.followerIndex.unfollowAction.errorSingleNotificationTitle": "取消跟随 Follower 索引“{name}”的 Leader 索引时出错", - "xpack.crossClusterReplication.followerIndex.unfollowAction.notOpenWarningMultipleNotificationTitle": "无法重新打开 {count} 个索引", - "xpack.crossClusterReplication.followerIndex.unfollowAction.notOpenWarningSingleNotificationTitle": "无法重新打开索引“{name}”", - "xpack.crossClusterReplication.followerIndex.unfollowAction.successMultipleNotificationTitle": "已取消跟随 {count} 个 Follower 索引的 Leader 索引", - "xpack.crossClusterReplication.followerIndex.unfollowAction.successSingleNotificationTitle": "已取消跟随 Follower 索引“{name}”的 Leader 索引", - "xpack.crossClusterReplication.followerIndex.updateAction.successNotificationTitle": "Follower 索引“{name}”已成功更新", - "xpack.crossClusterReplication.followerIndexCreateForm.loadingRemoteClustersMessage": "正在加载远程集群……", - "xpack.crossClusterReplication.followerIndexCreateForm.saveButtonLabel": "创建", - "xpack.crossClusterReplication.followerIndexDetailPanel.activeStatus": "有效", - "xpack.crossClusterReplication.followerIndexDetailPanel.closeButtonLabel": "关闭", - "xpack.crossClusterReplication.followerIndexDetailPanel.leaderIndexLabel": "Leader 索引", - "xpack.crossClusterReplication.followerIndexDetailPanel.loadingLabel": "正在加载 Follower 索引......", - "xpack.crossClusterReplication.followerIndexDetailPanel.manageButtonLabel": "管理", - "xpack.crossClusterReplication.followerIndexDetailPanel.notFoundLabel": "找不到 Follower 索引", - "xpack.crossClusterReplication.followerIndexDetailPanel.pausedFollowerCalloutTitle": "暂停的 Follower 索引不具有设置或分片统计。", - "xpack.crossClusterReplication.followerIndexDetailPanel.pausedStatus": "已暂停", - "xpack.crossClusterReplication.followerIndexDetailPanel.remoteClusterLabel": "远程集群", - "xpack.crossClusterReplication.followerIndexDetailPanel.settingsTitle": "设置", - "xpack.crossClusterReplication.followerIndexDetailPanel.shardStatsTitle": "分片 {id} 统计", - "xpack.crossClusterReplication.followerIndexDetailPanel.statusLabel": "状态", - "xpack.crossClusterReplication.followerIndexDetailPanel.viewIndexLink": "在“索引管理”中查看", - "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.cancelButtonText": "取消", - "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.confirmAndResumeButtonText": "更新并恢复", - "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.confirmButtonText": "更新", - "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.description": "该 Follower 索引先被暂停,然后被恢复。如果更新失败,请尝试手动恢复复制。", - "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.resumeDescription": "更新 Follower 索引可恢复其 Leader 索引的复制。", - "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.title": "更新 Follower 索引“{id}”?", - "xpack.crossClusterReplication.followerIndexEditForm.loadingErrorMessage": "该 Follower 索引“{name}”不存在。", - "xpack.crossClusterReplication.followerIndexEditForm.loadingErrorTitle": "加载 Follower 索引时出错", - "xpack.crossClusterReplication.followerIndexEditForm.loadingFollowerIndexTitle": "正在加载 Follower 索引......", - "xpack.crossClusterReplication.followerIndexEditForm.loadingRemoteClustersMessage": "正在加载远程集群……", - "xpack.crossClusterReplication.followerIndexEditForm.saveButtonLabel": "更新", - "xpack.crossClusterReplication.followerIndexEditForm.viewFollowerIndicesButtonLabel": "查看 Follower 索引", - "xpack.crossClusterReplication.followerIndexForm.actions.savingText": "正在保存", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.byteUnitsHelpText": "示例值:10b、1024kb、1mb、5gb、2tb、1pb。{link}", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.byteUnitsHelpTextLinkMessage": "了解详情", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingReadRequestsDescription": "来自远程集群的未完成读请求最大数目。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingReadRequestsLabel": "未完成读请求最大数", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingReadRequestsTitle": "未完成读请求最大数", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingWriteRequestsDescription": "Follower 上未完成写请求最大数目。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingWriteRequestsLabel": "未完成写请求最大数", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingWriteRequestsTitle": "未完成写请求最大数", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestOperationCountDescription": "从远程集群每次读取所拉取的最大操作数目。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestOperationCountLabel": "读请求操作最大计数", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestOperationCountTitle": "读请求操作最大计数", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestSizeDescription": "从远程集群拉取的批量操作的每次读取最大大小(字节)。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestSizeLabel": "读请求最大大小", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestSizeTitle": "读请求最大大小", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxRetryDelayDescription": "重试异常失败的操作前要等待的最长时间;重试时采用了指数退避策略。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxRetryDelayLabel": "最大重试延迟", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxRetryDelayTitle": "最大重试延迟", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferCountDescription": "可排队等待写入的最大操作数目;当此限制达到时,将会延迟从远程集群的读取,直到已排队操作的数目低于该限制。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferCountLabel": "最大写缓冲区计数", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferCountTitle": "最大写缓冲区计数", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferSizeDescription": "可排队等待写入的操作的最大总字节数;当此限制达到时,将会延迟从远程集群的读取,直到已排队操作的总字节数低于此限制。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferSizeLabel": "最大写缓冲区大小", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferSizeTitle": "最大写缓冲区大小", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestOperationCountDescription": "在 Follower 上执行的每个批量写请求的最大操作数目。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestOperationCountLabel": "最大写请求操作计数", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestOperationCountTitle": "最大写请求操作计数", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestSizeDescription": "在 Follower 上执行的每个批量写请求的最大操作总字节数。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestSizeLabel": "最大写请求大小", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestSizeTitle": "最大写请求大小", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.readPollTimeoutDescription": "当 Follower 索引与 Leader 索引同步时等待远程集群上的新操作的最长时间;当超时结束时,对操作的轮询将返回到 Follower,以便其可以更新某些统计,然后 Follower 将立即尝试再次从 Leader 读取。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.readPollTimeoutLabel": "读取轮询超时", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.readPollTimeoutTitle": "读取轮询超时", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.timeUnitsHelpText": "示例值:2d、24h、20m、30s、500ms、10000micros、80000nanos。{link}", - "xpack.crossClusterReplication.followerIndexForm.advancedSettings.timeUnitsHelpTextLinkMessage": "了解详情", - "xpack.crossClusterReplication.followerIndexForm.advancedSettingsDescription": "高级设置控制复制的速率。您可以定制这些设置或使用默认值。", - "xpack.crossClusterReplication.followerIndexForm.advancedSettingsTitle": "高级设置(可选)", - "xpack.crossClusterReplication.followerIndexForm.cancelButtonLabel": "取消", - "xpack.crossClusterReplication.followerIndexForm.currentRemoteClusterNotConnectedCallOutDescription": "可以通过编辑远程集群来解决此问题。", - "xpack.crossClusterReplication.followerIndexForm.currentRemoteClusterNotConnectedCallOutTitle": "无法编辑 Follower 索引,因为远程集群“{name}”未连接", - "xpack.crossClusterReplication.followerIndexForm.currentRemoteClusterNotFoundCallOutDescription": "要编辑此 Follower 索引,您必须添加名为“{name}”的远程集群。", - "xpack.crossClusterReplication.followerIndexForm.emptyRemoteClustersCallOutDescription": "复制需要远程集群上有 Leader 索引。", - "xpack.crossClusterReplication.followerIndexForm.errors.leaderIndexIllegalCharactersMessage": "从 Leader 索引中删除 {characterList} 字符。", - "xpack.crossClusterReplication.followerIndexForm.errors.leaderIndexMissingMessage": "Leader 索引必填。", - "xpack.crossClusterReplication.followerIndexForm.errors.nameBeginsWithPeriodMessage": "名称不能以句点开头。", - "xpack.crossClusterReplication.followerIndexForm.errors.nameIllegalCharactersMessage": "从名称中删除 {characterList} 字符。", - "xpack.crossClusterReplication.followerIndexForm.errors.nameMissingMessage": "“名称”必填", - "xpack.crossClusterReplication.followerIndexForm.indexAlreadyExistError": "同名索引已存在。", - "xpack.crossClusterReplication.followerIndexForm.indexNameHelpLabel": "不允许使用空格和字符 {characterList}。", - "xpack.crossClusterReplication.followerIndexForm.indexNameValidatingLabel": "正在检查可用性......", - "xpack.crossClusterReplication.followerIndexForm.indexNameValidationFatalErrorTitle": "Follower 索引表单索引名称验证", - "xpack.crossClusterReplication.followerIndexForm.leaderIndexNotFoundError": "Leader 索引“{leaderIndex}”不存在。", - "xpack.crossClusterReplication.followerIndexForm.resetFieldButtonLabel": "重置为默认值", - "xpack.crossClusterReplication.followerIndexForm.savingErrorTitle": "无法创建 Follower 索引", - "xpack.crossClusterReplication.followerIndexForm.sectionFollowerIndexNameDescription": "索引的唯一名称。", - "xpack.crossClusterReplication.followerIndexForm.sectionFollowerIndexNameTitle": "Follower 索引", - "xpack.crossClusterReplication.followerIndexForm.sectionLeaderIndexDescription": "远程群集上要复制到 Follower 索引的索引。", - "xpack.crossClusterReplication.followerIndexForm.sectionLeaderIndexDescription2": "{note}Leader 索引必须已存在。", - "xpack.crossClusterReplication.followerIndexForm.sectionLeaderIndexDescription2.noteLabel": "注意:", - "xpack.crossClusterReplication.followerIndexForm.sectionLeaderIndexTitle": "Leader 索引", - "xpack.crossClusterReplication.followerIndexForm.sectionRemoteClusterDescription": "包含要复制的索引的集群。", - "xpack.crossClusterReplication.followerIndexForm.sectionRemoteClusterTitle": "远程集群", - "xpack.crossClusterReplication.followerIndexForm.validationErrorTitle": "继续前请解决错误。", - "xpack.crossClusterReplication.followerIndexList.addFollowerButtonLabel": "创建 Follower 索引", - "xpack.crossClusterReplication.followerIndexList.emptyPromptDescription": "使用 Follower 索引复制远程集群上的 Leader 索引。", - "xpack.crossClusterReplication.followerIndexList.emptyPromptTitle": "创建首个 Follower 索引", - "xpack.crossClusterReplication.followerIndexList.followerIndicesDescription": "Follower 索引复制远程集群上的 Leader 索引。", - "xpack.crossClusterReplication.followerIndexList.loadingErrorTitle": "加载 Follower 索引时出错", - "xpack.crossClusterReplication.followerIndexList.loadingTitle": "正在加载 Follower 索引......", - "xpack.crossClusterReplication.followerIndexList.noPermissionText": "您无权查看或添加 Follower 索引。", - "xpack.crossClusterReplication.followerIndexList.permissionErrorTitle": "权限错误", - "xpack.crossClusterReplication.followerIndexList.table.actionEditDescription": "编辑 Follower 索引", - "xpack.crossClusterReplication.followerIndexList.table.actionPauseDescription": "暂停复制", - "xpack.crossClusterReplication.followerIndexList.table.actionResumeDescription": "恢复复制", - "xpack.crossClusterReplication.followerIndexList.table.actionsColumnTitle": "操作", - "xpack.crossClusterReplication.followerIndexList.table.actionUnfollowDescription": "取消跟随 Leader 索引", - "xpack.crossClusterReplication.followerIndexList.table.clusterColumnTitle": "远程集群", - "xpack.crossClusterReplication.followerIndexList.table.leaderIndexColumnTitle": "Leader 索引", - "xpack.crossClusterReplication.followerIndexList.table.nameColumnTitle": "名称", - "xpack.crossClusterReplication.followerIndexList.table.statusColumn.activeLabel": "有效", - "xpack.crossClusterReplication.followerIndexList.table.statusColumn.pausedLabel": "已暂停", - "xpack.crossClusterReplication.followerIndexList.table.statusColumnTitle": "状态", - "xpack.crossClusterReplication.homeBreadcrumbTitle": "跨集群复制", - "xpack.crossClusterReplication.indexMgmtBadge.followerLabel": "Follower", - "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.cancelButtonText": "取消", - "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.confirmButtonText": "暂停复制", - "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.multiplePauseDescription": "复制将在以下 Follower 索引上暂停:", - "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.multiplePauseDescriptionWithSettingWarning": "暂停复制到 Follower 索引可清除其定制高级设置。", - "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.pauseMultipleTitle": "暂停复制到 {count} 个 Follower 索引?", - "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.pauseSingleTitle": "暂停复制到 Follower 索引“{name}”?", - "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.singlePauseDescriptionWithSettingWarning": "暂停复制到此 Follower 索引可清除其定制高级设置。", - "xpack.crossClusterReplication.readDocsAutoFollowPatternButtonLabel": "自动跟随模式文档", - "xpack.crossClusterReplication.readDocsFollowerIndexButtonLabel": "Follower 索引文档", - "xpack.crossClusterReplication.remoteClustersFormField.addRemoteClusterButtonLabel": "添加远程集群", - "xpack.crossClusterReplication.remoteClustersFormField.currentRemoteClusterNotConnectedCallOutDescription": "编辑远程集群或选择连接的集群。", - "xpack.crossClusterReplication.remoteClustersFormField.currentRemoteClusterNotConnectedCallOutTitle": "远程集群“{name}”未连接", - "xpack.crossClusterReplication.remoteClustersFormField.emptyRemoteClustersCallOutDescription": "至少需要一个远程集群才能创建 Follower 索引。", - "xpack.crossClusterReplication.remoteClustersFormField.emptyRemoteClustersCallOutTitle": "您没有任何远程集群", - "xpack.crossClusterReplication.remoteClustersFormField.fieldClusterLabel": "远程集群", - "xpack.crossClusterReplication.remoteClustersFormField.invalidRemoteClusterError": "远程集群无效", - "xpack.crossClusterReplication.remoteClustersFormField.remoteClusterDropdownNotConnected": "{name}(未连接)", - "xpack.crossClusterReplication.remoteClustersFormField.remoteClusterNotFoundTitle": "找不到远程集群“{name}”", - "xpack.crossClusterReplication.remoteClustersFormField.validRemoteClusterRequired": "需要连接的远程集群。", - "xpack.crossClusterReplication.remoteClustersFormField.viewRemoteClusterButtonLabel": "编辑远程集群", - "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.cancelButtonText": "取消", - "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.confirmButtonText": "恢复复制", - "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.multipleResumeDescription": "复制将在以下 Follower 索引上恢复:", - "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.multipleResumeDescriptionWithSettingWarning": "复制将恢复使用默认高级设置。", - "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.resumeMultipleTitle": "恢复复制到 {count} 个 Follower 索引?", - "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.resumeSingleTitle": "恢复复制到 Follower 索引“{name}”?", - "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.singleResumeDescription": "复制将恢复使用默认高级设置。要使用定制高级设置,请{editLink}。", - "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.singleResumeEditLink": "编辑 Follower 索引", - "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.cancelButtonText": "取消", - "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.confirmButtonText": "取消跟随 Leader", - "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.multipleUnfollowDescription": "Follower 索引将转换为标准索引。它们不再显示在跨集群复制中,但您可以在“索引管理”中管理它们。此操作无法撤消。", - "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.singleUnfollowDescription": "Follower 索引将转换为标准索引。它不再显示在跨集群复制中,但您可以在“索引管理”中管理它。此操作无法撤消。", - "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.unfollowMultipleTitle": "取消跟随 {count} 个 Leader 索引?", - "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.unfollowSingleTitle": "取消跟随“{name}”的 Leader 索引?", - "xpack.crossClusterReplication.autoFollowPatternForm.hideRequestButtonLabel": "隐藏请求", - "xpack.crossClusterReplication.autoFollowPatternForm.requestFlyout.closeButtonLabel": "关闭", - "xpack.crossClusterReplication.autoFollowPatternForm.requestFlyout.createDescriptionText": "此 Elasticsearch 请求将创建此自动跟随模式。", - "xpack.crossClusterReplication.autoFollowPatternForm.requestFlyout.editDescriptionText": "此 Elasticsearch 请求将更新此自动跟随模式。", - "xpack.crossClusterReplication.autoFollowPatternForm.requestFlyout.namedTitle": "对“{name}”的请求", - "xpack.crossClusterReplication.autoFollowPatternForm.requestFlyout.unnamedTitle": "请求", - "xpack.crossClusterReplication.autoFollowPatternFormm.showRequestButtonLabel": "显示请求", - "xpack.crossClusterReplication.followerIndexForm.hideRequestButtonLabel": "隐藏请求", - "xpack.crossClusterReplication.followerIndexForm.requestFlyout.closeButtonLabel": "关闭", - "xpack.crossClusterReplication.followerIndexForm.requestFlyout.descriptionText": "此 Elasticsearch 请求将创建此 Follower 索引。", - "xpack.crossClusterReplication.followerIndexForm.requestFlyout.title": "请求", - "xpack.crossClusterReplication.followerIndexForm.showRequestButtonLabel": "显示请求", - "xpack.dashboardMode.dashboardViewer.dashboardDescription": "仪表板查看器", - "xpack.dashboardMode.dashboardViewer.dashboardTitle": "仪表板", - "xpack.dashboardMode.dashboardViewerDescription": "查看仪表板", - "xpack.dashboardMode.dashboardViewerTitle": "仪表板查看器", - "xpack.dashboardMode.uiSettings.dashboardsOnlyRolesDescription": "属于“仅查看仪表板”模式的角色", - "xpack.dashboardMode.uiSettings.dashboardsOnlyRolesTitle": "仅限仪表板的角色", - "xpack.graph.badge.readOnly.text": "只读", - "xpack.graph.badge.readOnly.tooltip": "无法保存 Graph 工作空间", - "xpack.graph.exploreGraph.timedOutWarningText": "浏览超时", - "xpack.graph.featureRegistry.graphFeatureName": "Graph", - "xpack.graph.home.breadcrumb": "Graph", - "xpack.graph.missingWorkspaceErrorMessage": "缺少工作空间", - "xpack.graph.outlinkEncoders.esqPlainDescription": "使用标准 URL 编码的 JSON", - "xpack.graph.outlinkEncoders.esqPlainTitle": "Elasticsearch 查询(纯编码)", - "xpack.graph.outlinkEncoders.esqRisonDescription": "rison 编码的 JSON,minimum_should_match=2,与大部分 Kibana URL 兼容", - "xpack.graph.outlinkEncoders.esqRisonLooseDescription": "rison 编码的 JSON,minimum_should_match=1,与大部分 Kibana URL 兼容", - "xpack.graph.outlinkEncoders.esqRisonLooseTitle": "Elasticsearch OR 查询(rison 编码)", - "xpack.graph.outlinkEncoders.esqRisonTitle": "Elasticsearch AND 查询(rison 编码)", - "xpack.graph.outlinkEncoders.esqSimilarRisonDescription": "rison 编码的 JSON“like this but not this”类型的查询,用于查找缺少的文档", - "xpack.graph.outlinkEncoders.esqSimilarRisonTitle": "Elasticsearch“more like this”查询(rison 编码)", - "xpack.graph.outlinkEncoders.textLuceneDescription": "所选顶点标签的文本,已对 Lucene 特殊字符进行了编码", - "xpack.graph.outlinkEncoders.textLuceneTitle": "Lucene 转义文本", - "xpack.graph.outlinkEncoders.textPlainDescription": "所选顶点标签的文本,采用纯 URL 编码的字符串形式", - "xpack.graph.outlinkEncoders.textPlainTitle": "纯文本", - "xpack.graph.pluginDescription": "显示并分析 Elasticsearch 数据中的相关关系。", - "xpack.graph.savedWorkspace.workspaceNameTitle": "新建 Graph 工作空间", - "xpack.graph.savedWorkspaces.graphWorkspaceLabel": "Graph 工作空间", - "xpack.graph.savedWorkspaces.graphWorkspacesLabel": "Graph 工作空间", - "xpack.graph.saveWorkspace.successNotification.noDataSavedText": "配置会被保存,但不保存数据", - "xpack.graph.saveWorkspace.successNotificationTitle": "已保存“{workspaceTitle}”", - "xpack.graph.serverSideErrors.unavailableGraphErrorMessage": "Graph 不可用", - "xpack.graph.serverSideErrors.unavailableLicenseInformationErrorMessage": "Graph 不可用 - 许可信息当前不可用。", - "xpack.graph.settings.advancedSettings.certaintyInputHelpText": "在引入相关字词之前作为证据所需的最小文档数量。", - "xpack.graph.settings.advancedSettings.certaintyInputLabel": "确定性", - "xpack.graph.settings.advancedSettings.diversityFieldInputHelpText1": "为避免文档示例过于雷同,请选取有助于识别偏差来源的字段。", - "xpack.graph.settings.advancedSettings.diversityFieldInputHelpText2": "此字段必须为单字字段,否则会拒绝搜索,并发生错误。", - "xpack.graph.settings.advancedSettings.diversityFieldInputLabel": "多元化字段", - "xpack.graph.settings.advancedSettings.diversityFieldInputOptionLabel": "[没有多元化]", - "xpack.graph.settings.advancedSettings.maxValuesInputHelpText": "示例中可以包含相同", - "xpack.graph.settings.advancedSettings.maxValuesInputHelpText.fieldText": "字段", - "xpack.graph.settings.advancedSettings.maxValuesInputLabel": "每个字段的最大文档数量", - "xpack.graph.settings.advancedSettings.sampleSizeInputHelpText": "字词从最相关的文档样本中进行识别。较大样本不一定更好—因为较大的样本会更慢且相关性更差。", - "xpack.graph.settings.advancedSettings.sampleSizeInputLabel": "示例大小", - "xpack.graph.settings.advancedSettings.significantLinksCheckboxHelpText": "识别“重要”而不只是常用的字词。", - "xpack.graph.settings.advancedSettings.significantLinksCheckboxLabel": "重要链接", - "xpack.graph.settings.advancedSettings.timeoutInputHelpText": "请求可以运行的最大时间(以毫秒为单位)。", - "xpack.graph.settings.advancedSettings.timeoutInputLabel": "超时 (ms)", - "xpack.graph.settings.advancedSettingsTitle": "高级设置", - "xpack.graph.settings.blacklist.blacklistHelpText": "这些字词当前已列入黑名单,不允许重新显示在工作空间中。", - "xpack.graph.settings.blacklist.clearButtonLabel": "清除", - "xpack.graph.settings.blacklistTitle": "黑名单", - "xpack.graph.settings.drillDowns.defaultUrlTemplateTitle": "原始文档", - "xpack.graph.settings.drillDowns.invalidUrlWarningText": "URL 必须包含 {placeholder} 字符串。", - "xpack.graph.settings.drillDowns.kibanaUrlWarningText": "这会类似于 Kibana URL。是否要将其转换为模板?", - "xpack.graph.settings.drillDowns.resetButtonLabel": "重置", - "xpack.graph.settings.drillDowns.toolbarIconPickerLabel": "工具栏图标", - "xpack.graph.settings.drillDowns.urlDescriptionInputLabel": "标题", - "xpack.graph.settings.drillDowns.urlDescriptionInputPlaceholder": "在 Google 上搜索", - "xpack.graph.settings.drillDowns.urlEncoderInputLabel": "URL 参数类型", - "xpack.graph.settings.drillDowns.urlInputHelpText": "使用插入选定顶点字词的 {gquery} 定义模板 URL。", - "xpack.graph.settings.drillDowns.urlInputLabel": "URL", - "xpack.graph.settings.drillDownsTitle": "向下钻取", - "xpack.graph.sidebar.displayLabelHelpText": "更改此顶点的标签。", - "xpack.graph.sidebar.displayLabelLabel": "显示标签", - "xpack.graph.sidebar.drillDowns.noDrillDownsHelpText": "从设置菜单配置向下钻取", - "xpack.graph.sidebar.drillDownsTitle": "向下钻取", - "xpack.graph.sidebar.groupButtonLabel": "组", - "xpack.graph.sidebar.groupButtonTooltip": "将当前选定的项分组成 {latestSelectionLabel}", - "xpack.graph.sidebar.linkSummary.bothTermsCountTooltip": "{count} 个文档同时具有这两个字词", - "xpack.graph.sidebar.linkSummary.leftTermCountTooltip": "{count} 个文档具有字词 {term}", - "xpack.graph.sidebar.linkSummary.mergeTerm1ToTerm2ButtonTooltip": "将 {term1} 合并到 {term2}", - "xpack.graph.sidebar.linkSummary.mergeTerm2ToTerm1ButtonTooltip": "将 {term2} 合并到 {term1}", - "xpack.graph.sidebar.linkSummary.rightTermCountTooltip": "{count} 个文档具有字词 {term}", - "xpack.graph.sidebar.linkSummaryTitle": "链接摘要", - "xpack.graph.sidebar.selections.invertSelectionButtonLabel": "反向", - "xpack.graph.sidebar.selections.invertSelectionButtonTooltip": "反向选择", - "xpack.graph.sidebar.selections.noSelectionsHelpText": "无选择。点击顶点以添加。", - "xpack.graph.sidebar.selections.selectAllButtonLabel": "全部", - "xpack.graph.sidebar.selections.selectAllButtonTooltip": "全选", - "xpack.graph.sidebar.selections.selectNeighboursButtonLabel": "已链接", - "xpack.graph.sidebar.selections.selectNeighboursButtonTooltip": "选择邻居", - "xpack.graph.sidebar.selections.selectNoneButtonLabel": "无", - "xpack.graph.sidebar.selections.selectNoneButtonTooltip": "不选择任何内容", - "xpack.graph.sidebar.selectionsTitle": "选择的内容", - "xpack.graph.sidebar.styleVerticesTitle": "样式选择的顶点", - "xpack.graph.sidebar.topMenu.addLinksButtonTooltip": "在现有字词之间添加链接", - "xpack.graph.sidebar.topMenu.blacklistButtonTooltip": "返回工作空间时选择的黑名单", - "xpack.graph.sidebar.topMenu.customStyleButtonTooltip": "定制样式选择的顶点", - "xpack.graph.sidebar.topMenu.drillDownButtonTooltip": "向下钻取", - "xpack.graph.sidebar.topMenu.expandSelectionButtonTooltip": "展开选择内容", - "xpack.graph.sidebar.topMenu.pauseLayoutButtonTooltip": "暂停布局", - "xpack.graph.sidebar.topMenu.redoButtonTooltip": "重做", - "xpack.graph.sidebar.topMenu.removeVerticesButtonTooltip": "从工作空间删除顶点", - "xpack.graph.sidebar.topMenu.runLayoutButtonTooltip": "运行布局", - "xpack.graph.sidebar.topMenu.undoButtonTooltip": "撤消", - "xpack.graph.sidebar.ungroupButtonLabel": "取消分组", - "xpack.graph.sidebar.ungroupButtonTooltip": "取消分组 {latestSelectionLabel}", - "xpack.graph.topNavMenu.newWorkspaceAriaLabel": "新建工作空间", - "xpack.graph.topNavMenu.newWorkspaceLabel": "新建", - "xpack.graph.topNavMenu.newWorkspaceTooltip": "新建工作空间", - "xpack.graph.topNavMenu.save.descriptionInputLabel": "描述", - "xpack.graph.topNavMenu.save.saveConfigurationOnlyText": "将清除此工作空间的数据,仅保存配置。", - "xpack.graph.topNavMenu.save.saveConfigurationOnlyWarning": "将清除此工作空间的数据,仅保存配置。", - "xpack.graph.topNavMenu.save.saveGraphContentCheckboxLabel": "保存 Graph 内容", - "xpack.graph.topNavMenu.saveWorkspace.disabledTooltip": "当前保存策略不允许对已保存的工作空间做任何更改", - "xpack.graph.topNavMenu.saveWorkspace.enabledAriaLabel": "保存工作空间", - "xpack.graph.topNavMenu.saveWorkspace.enabledLabel": "保存", - "xpack.graph.topNavMenu.saveWorkspace.enabledTooltip": "保存此工作空间", - "xpack.graph.topNavMenu.settingsAriaLabel": "设置", - "xpack.graph.topNavMenu.settingsLabel": "设置", - "xpack.graph.errorToastTitle": "Graph 错误", - "xpack.graph.bar.exploreLabel": "Graph", - "xpack.graph.bar.pickFieldsLabel": "添加字段", - "xpack.graph.bar.pickSourceLabel": "选择数据源", - "xpack.graph.bar.pickSourceTooltip": "选择数据源以开始绘制关系图。", - "xpack.graph.bar.searchFieldPlaceholder": "搜索数据并将其添加到图表", - "xpack.graph.blacklist.noEntriesDescription": "您没有任何已阻止字词。选择顶点并单击右侧控制面板上的 {stopSign} 以阻止它们。匹配已阻止字词的文档将不再被浏览,与它们的关系将隐藏。", - "xpack.graph.blacklist.removeButtonAriaLabel": "删除", - "xpack.graph.clearWorkspace.modalTitle": "未保存更改", - "xpack.graph.drilldowns.description": "使用向下钻取以链接到其他应用程序。选定的顶点成为 URL 的一部分。", - "xpack.graph.fieldManager.cancelLabel": "取消", - "xpack.graph.fieldManager.colorLabel": "颜色", - "xpack.graph.fieldManager.deleteFieldLabel": "取消选择字段", - "xpack.graph.fieldManager.deleteFieldTooltipContent": "此字段的新顶点将不会发现。 现有顶点仍在图表中。", - "xpack.graph.fieldManager.disabledFieldBadgeDescription": "已禁用字段 {field}:单击以配置。按 Shift 键并单击可启用", - "xpack.graph.fieldManager.disableFieldLabel": "禁用字段", - "xpack.graph.fieldManager.disableFieldTooltipContent": "关闭此字段顶点的发现。还可以按 Shift 键并单击字段可将其禁用。", - "xpack.graph.fieldManager.enableFieldLabel": "启用字段", - "xpack.graph.fieldManager.enableFieldTooltipContent": "打开此字段顶点的发现。还可以按 Shift 键并单击字段可将其启用。", - "xpack.graph.fieldManager.fieldBadgeDescription": "字段 {field}:单击以配置。按 Shift 键并单击可禁用", - "xpack.graph.fieldManager.fieldLabel": "字段", - "xpack.graph.fieldManager.fieldSearchPlaceholder": "筛选依据", - "xpack.graph.fieldManager.iconLabel": "图标", - "xpack.graph.fieldManager.maxTermsPerHopDescription": "控制要为每个搜索步长返回的字词最大数目。", - "xpack.graph.fieldManager.maxTermsPerHopLabel": "每跃点字词数", - "xpack.graph.fieldManager.settingsFormTitle": "编辑", - "xpack.graph.fieldManager.settingsLabel": "编辑设置", - "xpack.graph.fieldManager.updateLabel": "保存更改", - "xpack.graph.fillWorkspaceError": "获取排名最前字词失败:{message}", - "xpack.graph.guidancePanel.datasourceItem.indexPatternButtonLabel": "选择数据源。", - "xpack.graph.guidancePanel.fieldsItem.fieldsButtonLabel": "添加字段。", - "xpack.graph.guidancePanel.nodesItem.description": "在搜索栏中输入查询以开始浏览。不知道如何入手?{topTerms}。", - "xpack.graph.guidancePanel.nodesItem.topTermsButtonLabel": "将排名最前字词绘入图表", - "xpack.graph.guidancePanel.title": "绘制图表的三个步骤", - "xpack.graph.icon.areaChart": "面积图", - "xpack.graph.icon.at": "@ 符号", - "xpack.graph.icon.automobile": "汽车", - "xpack.graph.icon.bank": "银行", - "xpack.graph.icon.barChart": "条形图", - "xpack.graph.icon.bolt": "闪电", - "xpack.graph.icon.cube": "立方", - "xpack.graph.icon.desktop": "台式机", - "xpack.graph.icon.exclamation": "惊叹号", - "xpack.graph.icon.externalLink": "外部链接", - "xpack.graph.icon.eye": "眼睛", - "xpack.graph.icon.file": "文件打开", - "xpack.graph.icon.fileText": "文件", - "xpack.graph.icon.flag": "旗帜", - "xpack.graph.icon.folderOpen": "文件夹打开", - "xpack.graph.icon.font": "字体", - "xpack.graph.icon.globe": "地球", - "xpack.graph.icon.google": "Google", - "xpack.graph.icon.heart": "心形", - "xpack.graph.icon.home": "主页", - "xpack.graph.icon.industry": "工业", - "xpack.graph.icon.info": "信息", - "xpack.graph.icon.key": "钥匙", - "xpack.graph.icon.lineChart": "折线图", - "xpack.graph.icon.list": "列表", - "xpack.graph.icon.mapMarker": "地图标记", - "xpack.graph.icon.music": "音乐", - "xpack.graph.icon.phone": "电话", - "xpack.graph.icon.pieChart": "饼图", - "xpack.graph.icon.plane": "飞机", - "xpack.graph.icon.question": "问号", - "xpack.graph.icon.shareAlt": "Share alt", - "xpack.graph.icon.table": "桌子", - "xpack.graph.icon.tachometer": "转速表", - "xpack.graph.icon.user": "用户", - "xpack.graph.icon.users": "用户", - "xpack.graph.inspect.requestTabTitle": "请求", - "xpack.graph.inspect.responseTabTitle": "响应", - "xpack.graph.inspect.title": "检查", - "xpack.graph.leaveWorkspace.confirmButtonLabel": "离开", - "xpack.graph.leaveWorkspace.confirmText": "如果现在离开,将丢失未保存的更改。", - "xpack.graph.leaveWorkspace.modalTitle": "未保存更改", - "xpack.graph.listing.createNewGraph.combineDataViewFromKibanaAppDescription": "发现 Elasticsearch 索引中的模式和关系。", - "xpack.graph.listing.createNewGraph.createButtonLabel": "创建图表", - "xpack.graph.listing.createNewGraph.newToKibanaDescription": "Kibana 新手?从 {sampleDataInstallLink} 入手。", - "xpack.graph.listing.createNewGraph.sampleDataInstallLinkText": "样例数据", - "xpack.graph.listing.createNewGraph.title": "创建您的首个图表", - "xpack.graph.listing.graphsTitle": "图表", - "xpack.graph.listing.noDataSource.newToKibanaDescription": "Kibana 新手?还可以使用我们的{sampleDataInstallLink}。", - "xpack.graph.listing.noDataSource.sampleDataInstallLinkText": "样例数据", - "xpack.graph.listing.noItemsMessage": "似乎您没有任何图表。", - "xpack.graph.listing.table.descriptionColumnName": "描述", - "xpack.graph.listing.table.entityName": "图表", - "xpack.graph.listing.table.entityNamePlural": "图表", - "xpack.graph.listing.table.titleColumnName": "标题", - "xpack.graph.newGraphTitle": "未保存图表", - "xpack.graph.outlinkEncoders.kqlLooseDescription": "KQL 查询,与 Discover、Visualize 和仪表板兼容", - "xpack.graph.outlinkEncoders.kqlLooseTitle": "KQL OR 查询", - "xpack.graph.outlinkEncoders.kqlTitle": "KQL AND 查询", - "xpack.graph.saveWorkspace.savingErrorMessage": "无法保存工作空间:{message}", - "xpack.graph.settings.advancedSettings.timeoutUnit": "ms", - "xpack.graph.settings.closeLabel": "关闭", - "xpack.graph.settings.drillDowns.cancelButtonLabel": "取消", - "xpack.graph.settings.drillDowns.kibanaUrlWarningConvertOptionLinkText": "转换它。", - "xpack.graph.settings.drillDowns.newSaveButtonLabel": "保存向下钻取", - "xpack.graph.settings.drillDowns.removeButtonLabel": "删除", - "xpack.graph.settings.drillDowns.updateSaveButtonLabel": "更新向下钻取", - "xpack.graph.settings.title": "设置", - "xpack.graph.sourceModal.notFoundLabel": "未找到数据源。", - "xpack.graph.sourceModal.savedObjectType.indexPattern": "索引模式", - "xpack.graph.sourceModal.title": "选择数据源", - "xpack.graph.templates.addLabel": "新向下钻取", - "xpack.graph.templates.newTemplateFormLabel": "添加向下钻取", - "xpack.graph.topNavMenu.inspectAriaLabel": "检查", - "xpack.graph.topNavMenu.inspectLabel": "检查", - "xpack.graph.topNavMenu.save.objectType": "图表", - "xpack.graph.clearWorkspace.confirmButtonLabel": "更改数据源", - "xpack.graph.clearWorkspace.confirmText": "如果更改数据源,您当前的字段和顶点将会重置。", - "xpack.graph.loadWorkspace.missingIndexPatternErrorMessage": "未找到索引模式", - "xpack.graph.noDataSourceNotificationMessageText": "未找到数据源。前往 {managementIndexPatternsLink},为您的 Elasticsearch 索引创建索引模式。", - "xpack.grokDebugger.customPatterns.callOutTitle": "每行输入一个自定义模式。例如:", - "xpack.grokDebugger.customPatternsButtonLabel": "自定义模式", - "xpack.grokDebugger.displayName": "Grok Debugger", - "xpack.grokDebugger.grokPatternLabel": "Grok 模式", - "xpack.grokDebugger.licenseHasExpiredMessage": "您不能使用 {grokLogParsingTool} Debugger,因为您的 {licenseType} 许可证已过期。", - "xpack.grokDebugger.patternsErrorMessage": "提供的 {grokLogParsingTool} 模式不匹配输入中的数据", - "xpack.grokDebugger.registryProviderDescription": "采集时模拟和调试用于数据转换的 {grokLogParsingTool} 模式。", - "xpack.grokDebugger.registryProviderTitle": "{grokLogParsingTool} Debugger", - "xpack.grokDebugger.sampleDataLabel": "样例数据", - "xpack.grokDebugger.simulateButtonLabel": "模拟", - "xpack.grokDebugger.structuredDataLabel": "结构化数据", - "xpack.grokDebugger.unavailableLicenseInformationMessage": "您不能使用 {grokLogParsingTool} Debugger,因为许可证信息当前不可用。", - "xpack.idxMgmt.appTitle": "索引管理", - "xpack.idxMgmt.badgeAriaLabel": "{label}。选择以基于此选项进行筛选。", - "xpack.idxMgmt.clearCacheIndicesAction.successMessage": "已成功清除缓存:[{indexNames}]", - "xpack.idxMgmt.closeIndicesAction.successfullyClosedIndicesMessage": "已成功关闭:[{indexNames}]", - "xpack.idxMgmt.deleteIndicesAction.successfullyDeletedIndicesMessage": "已成功删除:[{indexNames}]", - "xpack.idxMgmt.detailPanel.manageContextMenuLabel": "管理", - "xpack.idxMgmt.detailPanel.missingIndexMessage": "此索引不存在。它可能已被正在运行的作业或其他系统删除。", - "xpack.idxMgmt.detailPanel.missingIndexTitle": "缺少索引", - "xpack.idxMgmt.detailPanel.tabEditSettingsLabel": "编辑设置", - "xpack.idxMgmt.detailPanel.tabMappingLabel": "映射", - "xpack.idxMgmt.detailPanel.tabSettingsLabel": "设置", - "xpack.idxMgmt.detailPanel.tabStatsLabel": "统计", - "xpack.idxMgmt.detailPanel.tabSummaryLabel": "结论", - "xpack.idxMgmt.editIndexSettingsAction.successfullySavedSettingsForIndicesMessage": "已成功保存 {indexName} 的设置", - "xpack.idxMgmt.editSettingsJSON.saveJSONButtonLabel": "保存", - "xpack.idxMgmt.editSettingsJSON.saveJSONDescription": "编辑并保存您的 JSON", - "xpack.idxMgmt.editSettingsJSON.settingsReferenceLinkText": "设置参考", - "xpack.idxMgmt.flushIndicesAction.successfullyFlushedIndicesMessage": "已成功清空:[{indexNames}]", - "xpack.idxMgmt.forceMergeIndicesAction.successfullyForceMergedIndicesMessage": "已成功强制合并:[{indexNames}]", - "xpack.idxMgmt.freezeIndicesAction.successfullyFrozeIndicesMessage": "成功冻结:[{indexNames}]", - "xpack.idxMgmt.frozenBadgeLabel": "已冻结", - "xpack.idxMgmt.indexActionsMenu.clearIndexCacheLabel": "清除 {selectedIndexCount, plural, one { 个索引} other { 个索引} } 缓存", - "xpack.idxMgmt.indexActionsMenu.closeIndexLabel": "关闭 {selectedIndexCount, plural, one { 个索引} other { 个索引} }", - "xpack.idxMgmt.indexActionsMenu.deleteIndex.confirmModal.cancelButtonText": "取消", - "xpack.idxMgmt.indexActionsMenu.deleteIndex.confirmModal.modalTitle": "确认删除 {selectedIndexCount, plural, one { 个索引} other { 个索引} }", - "xpack.idxMgmt.indexActionsMenu.deleteIndex.deleteDescription": "您将要删除{selectedIndexCount, plural, one {以下索引} other {以下索引} }:", - "xpack.idxMgmt.indexActionsMenu.deleteIndex.deleteWarningDescription": "此操作无法撤消。确保您有适当的备份。", - "xpack.idxMgmt.indexActionsMenu.deleteIndex.proceedWithCautionCallOutTitle": "谨慎操作!", - "xpack.idxMgmt.indexActionsMenu.deleteIndexLabel": "删除 {selectedIndexCount, plural, one { 个索引} other { 个索引} }", - "xpack.idxMgmt.indexActionsMenu.editIndexSettingsLabel": "编辑 {selectedIndexCount, plural, one { 个索引} other { 个索引} }设置", - "xpack.idxMgmt.indexActionsMenu.flushIndexLabel": "清空 {selectedIndexCount, plural, one { 个索引} other { 个索引} }", - "xpack.idxMgmt.indexActionsMenu.forceMerge.confirmModal.cancelButtonText": "取消", - "xpack.idxMgmt.indexActionsMenu.forceMerge.confirmModal.confirmButtonText": "强制合并", - "xpack.idxMgmt.indexActionsMenu.forceMerge.confirmModal.modalTitle": "强制合并", - "xpack.idxMgmt.indexActionsMenu.forceMerge.forceMergeDescription": "您将要强制合并{selectedIndexCount, plural, one {以下索引} other {以下索引} }:", - "xpack.idxMgmt.indexActionsMenu.forceMerge.forceMergeSegmentsHelpText": "合并索引中的段,直到段数减至此数目或更小数目。默认值为 1。", - "xpack.idxMgmt.indexActionsMenu.forceMerge.forceMergeWarningDescription": " 强制合并大型索引或非只读索引可能会使未正确运行(根据非只读索引运行)或在高峰时段运行的集群出现性能和稳定性问题。", - "xpack.idxMgmt.indexActionsMenu.forceMerge.maximumNumberOfSegmentsFormRowLabel": "每分片最大段数", - "xpack.idxMgmt.indexActionsMenu.forceMerge.proceedWithCautionCallOutTitle": "谨慎操作!", - "xpack.idxMgmt.indexActionsMenu.forceMergeIndexLabel": "强制合并 {selectedIndexCount, plural, one { 个索引} other { 个索引} }", - "xpack.idxMgmt.indexActionsMenu.freezeEntity.confirmModal.cancelButtonText": "取消", - "xpack.idxMgmt.indexActionsMenu.freezeEntity.freezeEntityWarningDescription": " 冻结的索引在集群上有很少的开销,已被阻止进行写操作。您可以搜索冻结的索引,但查询应会较慢。", - "xpack.idxMgmt.indexActionsMenu.freezeEntity.proceedWithCautionCallOutTitle": "谨慎操作", - "xpack.idxMgmt.indexActionsMenu.freezeIndexLabel": "冻结 {selectedIndexCount, plural, one { 个索引} other {} }", - "xpack.idxMgmt.indexActionsMenu.manageButtonAriaLabel": "{selectedIndexCount, plural, one { 个索引} other { 个索引} }选项", - "xpack.idxMgmt.indexActionsMenu.manageButtonLabel": "管理 {selectedIndexCount, plural, one { 个索引} other { 个索引}}", - "xpack.idxMgmt.indexActionsMenu.openIndexLabel": "打开 {selectedIndexCount, plural, one { 个索引} other { 个索引} }", - "xpack.idxMgmt.indexActionsMenu.panelTitle": "{selectedIndexCount, plural, one { 个索引} other { 个索引} }选项", - "xpack.idxMgmt.indexActionsMenu.refreshIndexLabel": "刷新 {selectedIndexCount, plural, one {个索引} other {个索引} }", - "xpack.idxMgmt.indexActionsMenu.segmentsNumberErrorMessage": "段数必须大于零。", - "xpack.idxMgmt.indexActionsMenu.showIndexMappingLabel": "显示 {selectedIndexCount, plural, one { 个索引} other { 个索引} }映射", - "xpack.idxMgmt.indexActionsMenu.showIndexSettingsLabel": "显示 {selectedIndexCount, plural, one { 个索引} other { 个索引} }设置", - "xpack.idxMgmt.indexActionsMenu.showIndexStatsLabel": "显示 {selectedIndexCount, plural, one { 个索引} other { 个索引} }统计信息", - "xpack.idxMgmt.indexActionsMenu.unfreezeIndexLabel": "取消冻结 {selectedIndexCount, plural, one { 个索引} other { 个索引} }", - "xpack.idxMgmt.indexStatusLabels.clearingCacheStatusLabel": "正在清除缓存......", - "xpack.idxMgmt.indexStatusLabels.closedStatusLabel": "已关闭", - "xpack.idxMgmt.indexStatusLabels.closingStatusLabel": "正在关闭...", - "xpack.idxMgmt.indexStatusLabels.flushingStatusLabel": "正在清空...", - "xpack.idxMgmt.indexStatusLabels.forcingMergeStatusLabel": "正在强制合并...", - "xpack.idxMgmt.indexStatusLabels.mergingStatusLabel": "正在合并...", - "xpack.idxMgmt.indexStatusLabels.openingStatusLabel": "正在打开...", - "xpack.idxMgmt.indexStatusLabels.refreshingStatusLabel": "正在刷新...", - "xpack.idxMgmt.indexTable.headers.documentsHeader": "文档计数", - "xpack.idxMgmt.indexTable.headers.healthHeader": "运行状况", - "xpack.idxMgmt.indexTable.headers.nameHeader": "名称", - "xpack.idxMgmt.indexTable.headers.primaryHeader": "主分片", - "xpack.idxMgmt.indexTable.headers.replicaHeader": "副本分片", - "xpack.idxMgmt.indexTable.headers.statusHeader": "状态", - "xpack.idxMgmt.indexTable.headers.storageSizeHeader": "存储大小", - "xpack.idxMgmt.indexTable.invalidSearchErrorMessage": "无效搜索:{errorMessage}", - "xpack.idxMgmt.indexTable.reloadIndicesButton": "重载索引", - "xpack.idxMgmt.indexTable.serverErrorTitle": "加载索引时出错", - "xpack.idxMgmt.indexTable.systemIndicesSearchIndicesAriaLabel": "搜索索引", - "xpack.idxMgmt.indexTable.systemIndicesSearchInputPlaceholder": "搜索", - "xpack.idxMgmt.indexTable.systemIndicesSwitchLabel": "包括系统索引", - "xpack.idxMgmt.noMatch.noIndicesDescription": "没有要显示的索引", - "xpack.idxMgmt.openIndicesAction.successfullyOpenedIndicesMessage": "已成功打开:[{indexNames}]", - "xpack.idxMgmt.pageErrorForbidden.title": "您无权使用“索引管理”", - "xpack.idxMgmt.refreshIndicesAction.successfullyRefreshedIndicesMessage": "已成功刷新:[{indexNames}]", - "xpack.idxMgmt.reloadIndicesAction.indicesPageRefreshFailureMessage": "无法刷新当前页面的索引。", - "xpack.idxMgmt.summary.headers.aliases": "别名", - "xpack.idxMgmt.summary.headers.deletedDocumentsHeader": "文档已删除", - "xpack.idxMgmt.summary.headers.documentsHeader": "文档计数", - "xpack.idxMgmt.summary.headers.healthHeader": "运行状况", - "xpack.idxMgmt.summary.headers.primaryHeader": "主分片", - "xpack.idxMgmt.summary.headers.primaryStorageSizeHeader": "主存储大小", - "xpack.idxMgmt.summary.headers.replicaHeader": "副本分片", - "xpack.idxMgmt.summary.headers.statusHeader": "状态", - "xpack.idxMgmt.summary.headers.storageSizeHeader": "存储大小", - "xpack.idxMgmt.summary.summaryTitle": "常规", - "xpack.idxMgmt.unfreezeIndicesAction.successfullyUnfrozeIndicesMessage": "成功取消冻结:[{indexNames}]", - "xpack.idxMgmt.updateIndexSettingsAction.settingsSuccessUpdateMessage": "已成功更新索引 {indexName} 的设置", - "xpack.idxMgmt.breadcrumb.cloneTemplateLabel": "克隆模板", - "xpack.idxMgmt.breadcrumb.createTemplateLabel": "创建模板", - "xpack.idxMgmt.breadcrumb.editTemplateLabel": "编辑模板", - "xpack.idxMgmt.breadcrumb.homeLabel": "索引管理", - "xpack.idxMgmt.breadcrumb.templatesLabel": "模板", - "xpack.idxMgmt.createRoute.duplicateTemplateIdErrorMessage": "已有名称为“{name}”的模板。", - "xpack.idxMgmt.createTemplate.cloneTemplatePageTitle": "克隆模板“{name}”", - "xpack.idxMgmt.createTemplate.createTemplatePageTitle": "创建模板", - "xpack.idxMgmt.deleteTemplatesModal.cancelButtonLabel": "取消", - "xpack.idxMgmt.deleteTemplatesModal.confirmButtonLabel": "删除{numTemplatesToDelete, plural, one {模板} other {模板} }", - "xpack.idxMgmt.deleteTemplatesModal.confirmDeleteCheckboxLabel": "我了解删除系统模板的后果", - "xpack.idxMgmt.deleteTemplatesModal.deleteDescription": "您即将删除{numTemplatesToDelete, plural, one {以下模板} other {以下模板} }:", - "xpack.idxMgmt.deleteTemplatesModal.errorNotificationMessageText": "删除模板“{name}”时出错", - "xpack.idxMgmt.deleteTemplatesModal.modalTitleText": "删除 {numTemplatesToDelete, plural, one { 个模板} other {# 个模板}}", - "xpack.idxMgmt.deleteTemplatesModal.multipleErrorsNotificationMessageText": "删除 {count} 个模板时出错", - "xpack.idxMgmt.deleteTemplatesModal.proceedWithCautionCallOutDescription": "系统模板对内部操作至关重要。如果删除此模板,将无法恢复。", - "xpack.idxMgmt.deleteTemplatesModal.proceedWithCautionCallOutTitle": "删除系统模板会使 Kibana 无法运行", - "xpack.idxMgmt.deleteTemplatesModal.successDeleteMultipleNotificationMessageText": "已删除 {numSuccesses, plural, one {# 个模板} other {# 个模板}}", - "xpack.idxMgmt.deleteTemplatesModal.successDeleteSingleNotificationMessageText": "已删除模板“{templateName}”", - "xpack.idxMgmt.deleteTemplatesModal.systemTemplateLabel": "系统模板", - "xpack.idxMgmt.editTemplate.editTemplatePageTitle": "编辑模板“{name}”", - "xpack.idxMgmt.home.appTitle": "索引管理", - "xpack.idxMgmt.home.idxMgmtDescription": "单个或批量更新您的 Elasticsearch 索引。", - "xpack.idxMgmt.home.idxMgmtDocsLinkText": "索引管理文档", - "xpack.idxMgmt.home.indexTemplatesDescription": "使用模板可将设置、映射和别名自动应用到索引。", - "xpack.idxMgmt.home.indexTemplatesTabTitle": "索引模板", - "xpack.idxMgmt.home.indicesTabTitle": "索引", - "xpack.idxMgmt.indexTemplatesList.emptyPrompt.noIndexTemplatesTitle": "您尚未有任何模板", - "xpack.idxMgmt.indexTemplatesList.loadingIndexTemplatesDescription": "正在加载模板……", - "xpack.idxMgmt.indexTemplatesList.loadingIndexTemplatesErrorMessage": "加载模板时出错", - "xpack.idxMgmt.indexTemplatesTable.systemIndexTemplatesSwitchLabel": "包括系统模板", - "xpack.idxMgmt.mappingsEditor.formatError": "JSON 格式错误", - "xpack.idxMgmt.mappingsEditor.mappingsEditorAriaLabel": "索引映射编辑器", - "xpack.idxMgmt.templateCreate.loadingTemplateToCloneDescription": "正在加载要克隆的模板……", - "xpack.idxMgmt.templateCreate.loadingTemplateToCloneErrorMessage": "加载要克隆的模板时出错", - "xpack.idxMgmt.templateDetails.aliasesTab.noAliasesTitle": "未定义任何别名。", - "xpack.idxMgmt.templateDetails.aliasesTabTitle": "别名", - "xpack.idxMgmt.templateDetails.cloneButtonLabel": "克隆", - "xpack.idxMgmt.templateDetails.closeButtonLabel": "关闭", - "xpack.idxMgmt.templateDetails.deleteButtonLabel": "删除", - "xpack.idxMgmt.templateDetails.editButtonLabel": "编辑", - "xpack.idxMgmt.templateDetails.loadingIndexTemplateDescription": "正在加载模板……", - "xpack.idxMgmt.templateDetails.loadingIndexTemplateErrorMessage": "加载模板时出错", - "xpack.idxMgmt.templateDetails.manageButtonLabel": "管理", - "xpack.idxMgmt.templateDetails.manageContextMenuPanelTitle": "模板选项", - "xpack.idxMgmt.templateDetails.managedTemplateInfoDescription": "托管模板对内部操作至关重要。", - "xpack.idxMgmt.templateDetails.managedTemplateInfoTitle": "不允许编辑托管模板", - "xpack.idxMgmt.templateDetails.mappingsTab.noMappingsTitle": "未定义任何映射。", - "xpack.idxMgmt.templateDetails.mappingsTabTitle": "映射", - "xpack.idxMgmt.templateDetails.settingsTab.noSettingsTitle": "未定义任何设置。", - "xpack.idxMgmt.templateDetails.settingsTabTitle": "设置", - "xpack.idxMgmt.templateDetails.summaryTab.ilmPolicyDescriptionListTitle": "ILM 策略", - "xpack.idxMgmt.templateDetails.summaryTab.indexPatternsDescriptionListTitle": "索引{numIndexPatterns, plural, one {模式} other {模式}}", - "xpack.idxMgmt.templateDetails.summaryTab.noneDescriptionText": "无", - "xpack.idxMgmt.templateDetails.summaryTab.orderDescriptionListTitle": "顺序", - "xpack.idxMgmt.templateDetails.summaryTab.versionDescriptionListTitle": "版本", - "xpack.idxMgmt.templateDetails.summaryTabTitle": "总结", - "xpack.idxMgmt.templateEdit.loadingIndexTemplateDescription": "正在加载模板……", - "xpack.idxMgmt.templateEdit.loadingIndexTemplateErrorMessage": "加载模板时出错", - "xpack.idxMgmt.templateEdit.managedTemplateWarningDescription": "托管模板对内部操作至关重要。", - "xpack.idxMgmt.templateEdit.managedTemplateWarningTitle": "不允许编辑托管模板", - "xpack.idxMgmt.templateEdit.systemTemplateWarningDescription": "系统模板对内部操作至关重要。", - "xpack.idxMgmt.templateEdit.systemTemplateWarningTitle": "编辑系统模板会使 Kibana 无法运行", - "xpack.idxMgmt.templateForm.backButtonLabel": "上一步", - "xpack.idxMgmt.templateForm.createButtonLabel": "创建模板", - "xpack.idxMgmt.templateForm.nextButtonLabel": "下一步", - "xpack.idxMgmt.templateForm.saveButtonLabel": "保存模板", - "xpack.idxMgmt.templateForm.saveTemplateError": "无法创建模板", - "xpack.idxMgmt.templateForm.savingButtonLabel": "正在保存……", - "xpack.idxMgmt.templateForm.stepAliases.aliasesDescription": "设置要与索引关联的别名。", - "xpack.idxMgmt.templateForm.stepAliases.aliasesEditorHelpText": "使用 JSON 格式:{code}", - "xpack.idxMgmt.templateForm.stepAliases.docsButtonLabel": "索引模板文档", - "xpack.idxMgmt.templateForm.stepAliases.fieldAliasesAriaLabel": "别名代码编辑器", - "xpack.idxMgmt.templateForm.stepAliases.fieldAliasesLabel": "别名", - "xpack.idxMgmt.templateForm.stepAliases.stepTitle": "别名(可选)", - "xpack.idxMgmt.templateForm.stepLogistics.docsButtonLabel": "索引模板文档", - "xpack.idxMgmt.templateForm.stepLogistics.fieldIndexPatternsHelpText": "不允许使用空格和字符 {invalidCharactersList}。", - "xpack.idxMgmt.templateForm.stepLogistics.fieldIndexPatternsLabel": "索引模式", - "xpack.idxMgmt.templateForm.stepLogistics.fieldNameLabel": "名称", - "xpack.idxMgmt.templateForm.stepLogistics.fieldOrderLabel": "顺序(可选)", - "xpack.idxMgmt.templateForm.stepLogistics.fieldVersionLabel": "版本(可选)", - "xpack.idxMgmt.templateForm.stepLogistics.indexPatternsDescription": "要应用于模板的索引模式。", - "xpack.idxMgmt.templateForm.stepLogistics.indexPatternsTitle": "索引模式", - "xpack.idxMgmt.templateForm.stepLogistics.nameDescription": "此模板的唯一标识符。", - "xpack.idxMgmt.templateForm.stepLogistics.nameTitle": "名称", - "xpack.idxMgmt.templateForm.stepLogistics.orderDescription": "多个模板匹配一个索引时的合并顺序。", - "xpack.idxMgmt.templateForm.stepLogistics.orderTitle": "合并顺序", - "xpack.idxMgmt.templateForm.stepLogistics.stepTitle": "运筹", - "xpack.idxMgmt.templateForm.stepLogistics.versionDescription": "在外部管理系统中标识该模板的编号。", - "xpack.idxMgmt.templateForm.stepLogistics.versionTitle": "版本", - "xpack.idxMgmt.templateForm.stepMappings.docsButtonLabel": "映射文档", - "xpack.idxMgmt.templateForm.stepMappings.fieldMappingsAriaLabel": "映射编辑器", - "xpack.idxMgmt.templateForm.stepMappings.fieldMappingsLabel": "映射", - "xpack.idxMgmt.templateForm.stepMappings.mappingsDescription": "定义如何存储和索引文档。", - "xpack.idxMgmt.templateForm.stepMappings.mappingsEditorHelpText": "使用 JSON 格式:{code}", - "xpack.idxMgmt.templateForm.stepMappings.stepTitle": "映射(可选)", - "xpack.idxMgmt.templateForm.stepReview.requestTab.descriptionText": "此请求将创建以下索引模板。", - "xpack.idxMgmt.templateForm.stepReview.requestTabTitle": "请求", - "xpack.idxMgmt.templateForm.stepReview.stepTitle": "查看 “{templateName}” 的详情", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.aliasesLabel": "别名", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.indexPatternsLabel": "索引{numIndexPatterns, plural, one {模式} other {模式}}", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.indexPatternsWarningDescription": "您创建的所有新索引将使用此模板。", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.indexPatternsWarningLinkText": "编辑索引模式。", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.indexPatternsWarningTitle": "此模板将通配符 (*) 用作索引模式。", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.mappingLabel": "映射", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.noDescriptionText": "否", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.noneDescriptionText": "无", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.orderLabel": "顺序", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.settingsLabel": "索引设置", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.versionLabel": "版本", - "xpack.idxMgmt.templateForm.stepReview.summaryTab.yesDescriptionText": "是", - "xpack.idxMgmt.templateForm.stepReview.summaryTabTitle": "总结", - "xpack.idxMgmt.templateForm.steps.aliasesStepName": "别名", - "xpack.idxMgmt.templateForm.steps.logisticsStepName": "运筹", - "xpack.idxMgmt.templateForm.steps.mappingsStepName": "映射", - "xpack.idxMgmt.templateForm.steps.settingsStepName": "索引设置", - "xpack.idxMgmt.templateForm.steps.summaryStepName": "复查模板", - "xpack.idxMgmt.templateForm.stepSettings.docsButtonLabel": "索引设置文档", - "xpack.idxMgmt.templateForm.stepSettings.fieldIndexSettingsAriaLabel": "索引设置编辑器", - "xpack.idxMgmt.templateForm.stepSettings.fieldIndexSettingsLabel": "索引设置", - "xpack.idxMgmt.templateForm.stepSettings.settingsDescription": "定义索引的行为。", - "xpack.idxMgmt.templateForm.stepSettings.settingsEditorHelpText": "使用 JSON 格式:{code}", - "xpack.idxMgmt.templateForm.stepSettings.stepTitle": "索引设置(可选)", - "xpack.idxMgmt.templateList.table.actionCloneDescription": "克隆此模板", - "xpack.idxMgmt.templateList.table.actionCloneTitle": "克隆", - "xpack.idxMgmt.templateList.table.actionColumnTitle": "操作", - "xpack.idxMgmt.templateList.table.actionDeleteDecription": "删除此模板", - "xpack.idxMgmt.templateList.table.actionDeleteText": "删除", - "xpack.idxMgmt.templateList.table.actionEditDecription": "编辑此模板", - "xpack.idxMgmt.templateList.table.actionEditText": "编辑", - "xpack.idxMgmt.templateList.table.aliasesColumnTitle": "别名", - "xpack.idxMgmt.templateList.table.createTemplatesButtonLabel": "创建模板", - "xpack.idxMgmt.templateList.table.deleteManagedTemplateTooltip": "您无法删除托管模板。", - "xpack.idxMgmt.templateList.table.deleteTemplatesButtonLabel": "删除{count, plural, one {模板} other {模板} }", - "xpack.idxMgmt.templateList.table.ilmPolicyColumnDescription": "“{policyName}”索引生命周期策略", - "xpack.idxMgmt.templateList.table.ilmPolicyColumnTitle": "ILM 策略", - "xpack.idxMgmt.templateList.table.indexPatternsColumnTitle": "索引模式", - "xpack.idxMgmt.templateList.table.mappingsColumnTitle": "映射", - "xpack.idxMgmt.templateList.table.nameColumnTitle": "名称", - "xpack.idxMgmt.templateList.table.noIndexTemplatesMessage": "未找到任何模板", - "xpack.idxMgmt.templateList.table.orderColumnTitle": "顺序", - "xpack.idxMgmt.templateList.table.reloadTemplatesButtonLabel": "重新加载", - "xpack.idxMgmt.templateList.table.settingsColumnTitle": "设置", - "xpack.idxMgmt.templateValidation.indexPatternsRequiredError": "至少需要一个索引模式。", - "xpack.idxMgmt.templateValidation.templateNameInvalidaCharacterError": "模板名称不得包含字符“{invalidChar}”", - "xpack.idxMgmt.templateValidation.templateNamePeriodError": "模板名称不得以句点开头。", - "xpack.idxMgmt.templateValidation.templateNameRequiredError": "模板名称必填。", - "xpack.idxMgmt.templateValidation.templateNameSpacesError": "模板名称不允许包含空格。", - "xpack.idxMgmt.templateValidation.templateNameUnderscoreError": "模板名称不得以下划线开头。", - "xpack.idxMgmt.indexTable.captionText": "下面是包含 {count, plural, one {# 行} other {# 行}}(共 {total} 行)的索引表。", - "xpack.idxMgmt.indexTable.selectAllIndicesAriaLabel": "选择所有行", - "xpack.idxMgmt.indexTable.selectIndexAriaLabel": "选择此行", - "xpack.idxMgmt.validators.string.invalidJSONError": "JSON 格式无效。", - "xpack.idxMgmt.indexActionsMenu.closeIndex.systemIndexLabel": "系统索引", - "xpack.idxMgmt.indexActionsMenu.deleteIndex.proceedWithCautionCallOutDescription": "系统索引对内部操作至关重要。如果删除系统索引,将无法恢复。确保您有适当的备份。", - "xpack.idxMgmt.indexActionsMenu.deleteIndex.systemIndexLabel": "系统索引", - "xpack.indexLifecycleMgmt.activePhaseMessage": "有效", - "xpack.indexLifecycleMgmt.addLifecyclePolicyActionButtonLabel": "添加生命周期策略", - "xpack.indexLifecycleMgmt.appTitle": "索引生命周期策略", - "xpack.indexLifecycleMgmt.checkLicense.errorExpiredMessage": "您不能使用 {pluginName},因为您的 {licenseType} 许可已过期。", - "xpack.indexLifecycleMgmt.checkLicense.errorUnavailableMessage": "您不能使用 {pluginName},因为许可证信息当前不可用。", - "xpack.indexLifecycleMgmt.checkLicense.errorUnsupportedMessage": "您的 {licenseType} 许可证不支持 {pluginName}。请升级您的许可。", - "xpack.indexLifecycleMgmt.coldPhase.freezeIndexLabel": "冻结索引", - "xpack.indexLifecycleMgmt.coldPhase.numberOfReplicasLabel": "副本分片数目", - "xpack.indexLifecycleMgmt.coldPhase.replicaCountHelpText": "默认情况下,副本分片数目仍一样。", - "xpack.indexLifecycleMgmt.confirmDelete.cancelButton": "取消", - "xpack.indexLifecycleMgmt.confirmDelete.deleteButton": "删除", - "xpack.indexLifecycleMgmt.confirmDelete.errorMessage": "删除策略 {policyName} 时出错", - "xpack.indexLifecycleMgmt.confirmDelete.successMessage": "已删除策略 {policyName}", - "xpack.indexLifecycleMgmt.confirmDelete.title": "删除策略“{name}”", - "xpack.indexLifecycleMgmt.confirmDelete.undoneWarning": "无法恢复删除的策略。", - "xpack.indexLifecycleMgmt.editPolicy.cancelButton": "取消", - "xpack.indexLifecycleMgmt.editPolicy.coldPhase.activateWarmPhaseSwitchLabel": "激活冷阶段", - "xpack.indexLifecycleMgmt.editPolicy.coldPhase.coldPhaseDescriptionText": "您查询自己索引的频率较低,因此您可以在效率较低的硬件上分配分片。因为您的查询较为缓慢,所以您可以减少副本分片数目。", - "xpack.indexLifecycleMgmt.editPolicy.coldPhase.coldPhaseLabel": "冷阶段", - "xpack.indexLifecycleMgmt.editPolicy.coldPhase.freezeIndexExplanationText": "冻结的索引在集群上有很少的开销,已被阻止进行写操作。您可以搜索冻结的索引,但查询应会较慢。", - "xpack.indexLifecycleMgmt.editPolicy.coldPhase.freezeText": "冻结", - "xpack.indexLifecycleMgmt.editPolicy.createdMessage": "创建于", - "xpack.indexLifecycleMgmt.editPolicy.createPolicyMessage": "创建索引生命周期策略", - "xpack.indexLifecycleMgmt.editPolicy.creationDaysOptionLabel": "天(自索引创建)", - "xpack.indexLifecycleMgmt.editPolicy.creationHoursOptionLabel": "小时(自索引创建)", - "xpack.indexLifecycleMgmt.editPolicy.deletePhase.activateWarmPhaseSwitchLabel": "激活删除阶段", - "xpack.indexLifecycleMgmt.editPolicy.deletePhase.deletePhaseDescriptionText": "您不再需要自己的索引。 您可以定义安全删除它的时间。", - "xpack.indexLifecycleMgmt.editPolicy.deletePhase.deletePhaseLabel": "删除阶段", - "xpack.indexLifecycleMgmt.editPolicy.differentPolicyNameRequiredError": "策略名称必须不同。", - "xpack.indexLifecycleMgmt.editPolicy.editingExistingPolicyExplanationMessage": "所做的任何更改将影响附加到此策略的索引。或者,您可以在新策略中保存这些更改。", - "xpack.indexLifecycleMgmt.editPolicy.editingExistingPolicyMessage": "您正在编辑现有策略", - "xpack.indexLifecycleMgmt.editPolicy.editPolicyMessage": "编辑索引生命周期策略 {originalPolicyName}", - "xpack.indexLifecycleMgmt.editPolicy.formErrorsMessage": "请修复此页面上的错误。", - "xpack.indexLifecycleMgmt.editPolicy.hotPhase.hotPhaseDescriptionMessage": "此阶段为必需。您正频繁地查询并写到您的索引。 为了获取更快的更新,在索引变得过大或过旧时,您可以滚动更新索引。", - "xpack.indexLifecycleMgmt.editPolicy.hotPhase.hotPhaseLabel": "热阶段", - "xpack.indexLifecycleMgmt.editPolicy.hotPhase.learnAboutRolloverLinkText": "了解滚动更新", - "xpack.indexLifecycleMgmt.editPolicy.hotPhase.rolloverDescriptionMessage": "滚动更新创建的新索引将添加到索引别名,并被指定为写索引。", - "xpack.indexLifecycleMgmt.editPolicy.indexPriorityText": "索引优先级", - "xpack.indexLifecycleMgmt.editPolicy.learnAboutIndexLifecycleManagementLinkText": "了解索引生命周期。", - "xpack.indexLifecycleMgmt.editPolicy.learnAboutIndexTemplatesLink": "了解索引模板", - "xpack.indexLifecycleMgmt.editPolicy.learnAboutShardAllocationLink": "了解分片分配", - "xpack.indexLifecycleMgmt.editPolicy.learnAboutTimingText": "了解计时", - "xpack.indexLifecycleMgmt.editPolicy.lifecyclePolicyDescriptionText": "使用索引策略自动化索引生命周期的四个阶段,从频繁地写入到索引到删除索引。", - "xpack.indexLifecycleMgmt.editPolicy.loadPolicyErrorMessage": "加载策略时出错", - "xpack.indexLifecycleMgmt.editPolicy.maximumAgeMissingError": "最大存在时间必填。", - "xpack.indexLifecycleMgmt.editPolicy.maximumDocumentsMissingError": "最大文档数必填。", - "xpack.indexLifecycleMgmt.editPolicy.maximumIndexSizeMissingError": "最大索引大小必填。", - "xpack.indexLifecycleMgmt.editPolicy.nameLabel": "名称", - "xpack.indexLifecycleMgmt.editPolicy.nodeAllocationLabel": "选择节点属性来控制分片分配", - "xpack.indexLifecycleMgmt.editPolicy.nodeAttributesMissingDescription": "没有节点属性,将无法控制分片分配。", - "xpack.indexLifecycleMgmt.editPolicy.nodeAttributesMissingLabel": "elasticsearch.yml 中未配置任何节点属性", - "xpack.indexLifecycleMgmt.editPolicy.nodeDetailErrorMessage": "加载节点属性详细信息时出错", - "xpack.indexLifecycleMgmt.editPolicy.nodeInfoErrorMessage": "加载节点属性信息时出错", - "xpack.indexLifecycleMgmt.editPolicy.numberRequiredError": "数字必填。", - "xpack.indexLifecycleMgmt.editPolicy.phaseCold.minimumAgeLabel": "冷阶段计时", - "xpack.indexLifecycleMgmt.editPolicy.phaseCold.minimumAgeUnitsAriaLabel": "冷阶段计时单位", - "xpack.indexLifecycleMgmt.editPolicy.phaseDelete.minimumAgeLabel": "删除阶段计时", - "xpack.indexLifecycleMgmt.editPolicy.phaseDelete.minimumAgeUnitsAriaLabel": "删除阶段计时单位", - "xpack.indexLifecycleMgmt.editPolicy.phaseErrorMessage": "修复错误", - "xpack.indexLifecycleMgmt.editPolicy.phaseWarm.minimumAgeLabel": "温阶段计时", - "xpack.indexLifecycleMgmt.editPolicy.phaseWarm.minimumAgeUnitsAriaLabel": "温阶段计时单位", - "xpack.indexLifecycleMgmt.editPolicy.policyNameAlreadyUsedError": "该策略名称已被使用。", - "xpack.indexLifecycleMgmt.editPolicy.policyNameContainsCommaError": "策略名称不能包含逗号。", - "xpack.indexLifecycleMgmt.editPolicy.policyNameContainsSpaceError": "策略名称不能包含空格。", - "xpack.indexLifecycleMgmt.editPolicy.policyNameLabel": "策略名称", - "xpack.indexLifecycleMgmt.editPolicy.policyNameRequiredError": "策略名称必填。", - "xpack.indexLifecycleMgmt.editPolicy.policyNameStartsWithUnderscoreError": "策略名称不能以下划线开头。", - "xpack.indexLifecycleMgmt.editPolicy.policyNameTooLongError": "策略名称的长度不能大于 255 字节。", - "xpack.indexLifecycleMgmt.editPolicy.positiveNumberAboveZeroRequiredError": "仅允许使用 0 以上的数字。", - "xpack.indexLifecycleMgmt.editPolicy.positiveNumberRequiredError": "仅允许使用正数。", - "xpack.indexLifecycleMgmt.editPolicy.rolloverDaysOptionLabel": "天(自滚动更新)", - "xpack.indexLifecycleMgmt.editPolicy.rolloverHoursOptionLabel": "小时(自滚动更新)", - "xpack.indexLifecycleMgmt.editPolicy.saveAsNewButton": "另存为新策略", - "xpack.indexLifecycleMgmt.editPolicy.saveAsNewPolicyMessage": "另存为新策略", - "xpack.indexLifecycleMgmt.editPolicy.saveButton": "保存策略", - "xpack.indexLifecycleMgmt.editPolicy.saveErrorMessage": "保存生命周期策略 {lifecycleName} 时出错", - "xpack.indexLifecycleMgmt.editPolicy.successfulSaveMessage": "{verb}生命周期策略“{lifecycleName}”", - "xpack.indexLifecycleMgmt.editPolicy.updatedMessage": "已更新", - "xpack.indexLifecycleMgmt.editPolicy.validPolicyNameMessage": "策略名称不能以下划线开头,且不能包含问号或空格。", - "xpack.indexLifecycleMgmt.editPolicy.viewNodeDetailsButton": "查看附加到此配置的节点列表", - "xpack.indexLifecycleMgmt.editPolicy.warmPhase.activateWarmPhaseSwitchLabel": "激活温阶段", - "xpack.indexLifecycleMgmt.editPolicy.warmPhase.forceMergeDataExplanationText": "通过合并较小文件并清除已删除文件,来减少分片中的段数目。", - "xpack.indexLifecycleMgmt.editPolicy.warmPhase.forceMergeDataText": "强制合并", - "xpack.indexLifecycleMgmt.editPolicy.warmPhase.indexPriorityExplanationText": "设置在节点重新启动后恢复索引的优先级。较高优先级的索引会在较低优先级的索引之前恢复。", - "xpack.indexLifecycleMgmt.editPolicy.warmPhase.shrinkIndexExplanationText": "将索引缩小成具有较少主分片的新索引。", - "xpack.indexLifecycleMgmt.editPolicy.warmPhase.shrinkText": "缩小", - "xpack.indexLifecycleMgmt.editPolicy.warmPhase.warmPhaseDescriptionMessage": "您仍在查询自己的索引,但其为只读。您可以将分片分配给效率较低的硬件。为了获取更快的搜索,您可以减少分片数目并强制合并段。", - "xpack.indexLifecycleMgmt.editPolicy.warmPhase.warmPhaseLabel": "温阶段", - "xpack.indexLifecycleMgmt.hotPhase.daysLabel": "天", - "xpack.indexLifecycleMgmt.hotPhase.enableRolloverLabel": "启用滚动更新", - "xpack.indexLifecycleMgmt.hotPhase.gigabytesLabel": "千兆字节", - "xpack.indexLifecycleMgmt.hotPhase.hoursLabel": "小时", - "xpack.indexLifecycleMgmt.hotPhase.maximumAgeLabel": "最大存在时间", - "xpack.indexLifecycleMgmt.hotPhase.maximumAgeUnitsAriaLabel": "最大存在时间单位", - "xpack.indexLifecycleMgmt.hotPhase.maximumDocumentsLabel": "最大文档数", - "xpack.indexLifecycleMgmt.hotPhase.maximumIndexSizeLabel": "最大索引大小", - "xpack.indexLifecycleMgmt.hotPhase.maximumIndexSizeUnitsAriaLabel": "最大索引大小单位", - "xpack.indexLifecycleMgmt.hotPhase.megabytesLabel": "兆字节", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.actionStatusTitle": "操作状态", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.headers.currentActionHeader": "当前操作", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.headers.currentActionTimeHeader": "当前操作名称", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.headers.currentPhaseHeader": "当前阶段", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.headers.failedStepHeader": "失败的步骤", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.headers.lifecyclePolicyHeader": "生命周期策略", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.phaseDefinitionTitle": "阶段定义", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.showPhaseDefinitionButton": "显示阶段定义", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.stackTraceButton": "堆栈追溯", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.summaryErrorMessage": "索引生命周期错误", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.summaryTitle": "索引生命周期管理", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.addPolicyButtonText": "添加策略", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.addPolicyToIndexError": "向索引添加策略时出错", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.addPolicyToIndexSuccess": "已将策略 “{policyName}” 添加到索引 “{indexName}”。", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.cancelButtonText": "取消", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.chooseAliasLabel": "索引滚动更新别名", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.chooseAliasMessage": "选择别名", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.choosePolicyLabel": "生命周期策略", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.choosePolicyMessage": "选择生命周期策略", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.defineLifecyclePolicyLinkText": "定义生命周期策略", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.indexHasNoAliasesWarningMessage": "已为滚动更新配置策略 “{policyName}”,但索引 “{indexName}” 没有滚动更新所需的别名。", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.indexHasNoAliasesWarningTitle": "索引没有别名", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.loadPolicyError": "加载策略列表时出错", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.modalTitle": "将生命周期策略添加到“{indexName}”", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.noPoliciesWarningTitle": "未定义任何索引生命周期策略", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.noPolicySelectedErrorMessage": "必须选择策略。", - "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyToTemplateConfirmModal.indexHasNoAliasesWarningMessage": "策略 “{existingPolicyName}” 已附加到此索引模板。添加此策略将覆盖该配置。", - "xpack.indexLifecycleMgmt.indexManagementTable.removeLifecyclePolicyConfirmModal.cancelButtonText": "取消", - "xpack.indexLifecycleMgmt.indexManagementTable.removeLifecyclePolicyConfirmModal.removePolicyButtonText": "删除策略", - "xpack.indexLifecycleMgmt.indexManagementTable.removeLifecyclePolicyConfirmModal.removePolicyToIndexError": "删除策略时出错", - "xpack.indexLifecycleMgmt.indexMgmtBanner.errorMessage": "{ numIndicesWithLifecycleErrors, number}\n {numIndicesWithLifecycleErrors, plural, one { 个索引已} other { 个索引已} }\n 生命周期错误", - "xpack.indexLifecycleMgmt.indexMgmtBanner.filterLabel": "显示错误", - "xpack.indexLifecycleMgmt.indexMgmtFilter.lifecycleStatusLabel": "生命周期状态", - "xpack.indexLifecycleMgmt.indexMgmtFilter.managedLabel": "受管", - "xpack.indexLifecycleMgmt.indexMgmtFilter.unmanagedLabel": "未受管", - "xpack.indexLifecycleMgmt.indexPriorityLabel": "索引优先级", - "xpack.indexLifecycleMgmt.learnMore": "了解详情", - "xpack.indexLifecycleMgmt.nodeAttrDetails.hostField": "主机", - "xpack.indexLifecycleMgmt.nodeAttrDetails.idField": "ID", - "xpack.indexLifecycleMgmt.nodeAttrDetails.nameField": "名称", - "xpack.indexLifecycleMgmt.nodeAttrDetails.title": "包含属性 {selectedNodeAttrs} 的节点", - "xpack.indexLifecycleMgmt.noMatch.noPolicicesDescription": "没有要显示的策略", - "xpack.indexLifecycleMgmt.optionalMessage": " (可选)", - "xpack.indexLifecycleMgmt.policyTable.actionsButtonText": "操作", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.cancelButton": "取消", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.chooseTemplateLabel": "索引模板", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.chooseTemplateMessage": "选择索引模板", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.confirmButton": "添加策略", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.errorMessage": "向索引模板 “{templateName}” 添加策略 “{policyName}” 时出错", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.explanationText": "这会将生命周期策略应用到匹配索引模板的所有索引。", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.noTemplateSelectedErrorMessage": "必须选择索引模板。", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.rolloverAliasLabel": "滚动更新索引的别名", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.successMessage": "已将策略 “{policyName}” 添加到索引模板 “{templateName}”。", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.templateHasPolicyWarningTitle": "模板已有策略", - "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.title": "将策略 “{name}” 添加到索引模板", - "xpack.indexLifecycleMgmt.policyTable.addPolicyToTemplateButtonText": "将策略添加到索引模板", - "xpack.indexLifecycleMgmt.policyTable.deletedPoliciesText": "已删除 {numSelected} 个{numSelected, plural, one {策略} other {策略}}", - "xpack.indexLifecycleMgmt.policyTable.deletePolicyButtonDisabledTooltip": "您无法删除索引正在使用的策略", - "xpack.indexLifecycleMgmt.policyTable.deletePolicyButtonText": "删除策略", - "xpack.indexLifecycleMgmt.policyTable.emptyPrompt.createButtonLabel": "创建策略", - "xpack.indexLifecycleMgmt.policyTable.emptyPromptDescription": " 索引生命周期策略帮助您管理变旧的索引", - "xpack.indexLifecycleMgmt.policyTable.emptyPromptTitle": "创建您的首个索引生命周期索引", - "xpack.indexLifecycleMgmt.policyTable.headers.linkedIndicesHeader": "已链接索引", - "xpack.indexLifecycleMgmt.policyTable.headers.modifiedDateHeader": "上次修改日期", - "xpack.indexLifecycleMgmt.policyTable.headers.nameHeader": "名称", - "xpack.indexLifecycleMgmt.policyTable.headers.versionHeader": "版本", - "xpack.indexLifecycleMgmt.policyTable.policyActionsMenu.panelTitle": "策略选项", - "xpack.indexLifecycleMgmt.policyTable.sectionDescription": "管理变旧的索引。 附加策略以自动化何时以及如何在索引整个生命周期中变迁索引。", - "xpack.indexLifecycleMgmt.policyTable.sectionHeading": "索引生命周期策略", - "xpack.indexLifecycleMgmt.policyTable.systempoliciesSearchInputAriaLabel": "搜索策略", - "xpack.indexLifecycleMgmt.policyTable.systempoliciesSearchInputPlaceholder": "搜索", - "xpack.indexLifecycleMgmt.policyTable.viewIndicesButtonText": "查看链接到策略的索引", - "xpack.indexLifecycleMgmt.removeIndexLifecycleActionButtonLabel": "删除生命周期策略", - "xpack.indexLifecycleMgmt.retryIndexLifecycleAction.retriedLifecycleMessage": "已为以下索引调用重试生命周期步骤:{indexNames}", - "xpack.indexLifecycleMgmt.retryIndexLifecycleActionButtonLabel": "重试生命周期步骤", - "xpack.indexLifecycleMgmt.warmPhase.forceMergeDataLabel": "强制合并数据", - "xpack.indexLifecycleMgmt.warmPhase.moveToWarmPhaseOnRolloverLabel": "滚动更新时移到温阶段", - "xpack.indexLifecycleMgmt.warmPhase.numberOfPrimaryShardsLabel": "主分片数目", - "xpack.indexLifecycleMgmt.warmPhase.numberOfReplicasLabel": "副本分片数目", - "xpack.indexLifecycleMgmt.warmPhase.numberOfSegmentsLabel": "段数目", - "xpack.indexLifecycleMgmt.warmPhase.replicaCountHelpText": "默认情况下,副本分片数目仍一样。", - "xpack.indexLifecycleMgmt.warmPhase.shrinkIndexLabel": "缩小索引", - "xpack.indexLifecycleMgmt.editPolicy.hidePolicyJsonButto": "隐藏请求", - "xpack.indexLifecycleMgmt.editPolicy.showPolicyJsonButto": "显示请求", - "xpack.indexLifecycleMgmt.policyJsonFlyout.closeButtonLabel": "关闭", - "xpack.indexLifecycleMgmt.policyJsonFlyout.descriptionText": "此 Elasticsearch 请求将创建或更新此索引生命周期策略。", - "xpack.indexLifecycleMgmt.policyJsonFlyout.namedTitle": "对“{policyName}”的请求", - "xpack.indexLifecycleMgmt.policyJsonFlyout.unnamedTitle": "请求", - "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.showPhaseDefinitionDescriptionTitle": "阶段定义", - "xpack.indexLifecycleMgmt.policyTable.captionText": "下面是包含 {count, plural, one {# 行} other {# 行}}(共 {total} 行)的索引生命周期策略表。", - "xpack.infra.chartSection.missingMetricDataText": "缺失数据", - "xpack.infra.chartSection.notEnoughDataPointsToRenderText": "没有足够的数据点来呈现图表,请尝试增大时间范围。", - "xpack.infra.configureSourceActionLabel": "更改源配置", - "xpack.infra.errorPage.errorOccurredTitle": "发生错误", - "xpack.infra.errorPage.tryAgainButtonLabel": "重试", - "xpack.infra.errorPage.tryAgainDescription ": "请点击后退按钮,然后重试。", - "xpack.infra.errorPage.unexpectedErrorTitle": "糟糕!", - "xpack.infra.featureRegistry.linkInfrastructureTitle": "指标", - "xpack.infra.featureRegistry.linkLogsTitle": "Logs", - "xpack.infra.groupByDisplayNames.availabilityZone": "可用区", - "xpack.infra.groupByDisplayNames.hostName": "主机", - "xpack.infra.groupByDisplayNames.kubernetesNamespace": "命名空间", - "xpack.infra.groupByDisplayNames.kubernetesNodeName": "节点", - "xpack.infra.groupByDisplayNames.machineType": "机器类型", - "xpack.infra.groupByDisplayNames.projectID": "项目 ID", - "xpack.infra.groupByDisplayNames.provider": "云服务提供商", - "xpack.infra.groupByDisplayNames.serviceType": "服务类型", - "xpack.infra.header.badge.readOnly.text": "只读", - "xpack.infra.header.badge.readOnly.tooltip": "无法更改源配置", - "xpack.infra.header.infrastructureTitle": "指标", - "xpack.infra.homePage.documentTitle": "指标", - "xpack.infra.homePage.inventoryTabTitle": "库存", - "xpack.infra.homePage.metricsExplorerTabTitle": "指标浏览器", - "xpack.infra.homePage.noMetricsIndicesDescription": "让我们添加一些!", - "xpack.infra.homePage.noMetricsIndicesInstructionsActionLabel": "查看设置说明", - "xpack.infra.homePage.noMetricsIndicesTitle": "似乎您没有任何指标索引。", - "xpack.infra.homePage.toolbar.kqlSearchFieldPlaceholder": "搜索基础设施数据……(例如 host.name:host-1)", - "xpack.infra.infrastructureDescription": "浏览您的基础设施", - "xpack.infra.infrastructureMetricsExplorerPage.documentTitle": "{previousTitle} | 指标浏览器", - "xpack.infra.infrastructureSnapshotPage.documentTitle": "{previousTitle} | 库存", - "xpack.infra.infrastructureTitle": "指标", - "xpack.infra.kibanaMetrics.invalidInfraMetricErrorMessage": "{id} 不是有效的 InfraMetric", - "xpack.infra.kibanaMetrics.nodeDoesNotExistErrorMessage": "{nodeId} 不存在。", - "xpack.infra.legendControls.applyButton": "应用", - "xpack.infra.legendControls.buttonLabel": "配置图例", - "xpack.infra.legendControls.errorMessage": "最小值应小于最大值", - "xpack.infra.legendControls.maxLabel": "最大值", - "xpack.infra.legendControls.minLabel": "最小值", - "xpack.infra.legendControls.switchLabel": "自动计算范围", - "xpack.infra.linkInfrastructureDescription": "浏览您的基础设施", - "xpack.infra.linkInfrastructureTitle": "指标", - "xpack.infra.linkLogsDescription": "浏览您的日志", - "xpack.infra.linkLogsTitle": "Logs", - "xpack.infra.linkTo.hostWithIp.error": "未找到 IP 地址为“{hostIp}”的主机。", - "xpack.infra.linkTo.hostWithIp.loading": "正在加载 IP 地址为“{hostIp}”的主机。", - "xpack.infra.logEntryActionsMenu.buttonLabel": "操作", - "xpack.infra.logEntryActionsMenu.uptimeActionLabel": "查看监测状态", - "xpack.infra.logEntryItemView.viewDetailsToolTip": "查看详情", - "xpack.infra.logFlyout.fieldColumnLabel": "字段", - "xpack.infra.logFlyout.filterAriaLabel": "筛选", - "xpack.infra.logFlyout.flyoutTitle": "日志事件文档详情", - "xpack.infra.logFlyout.loadingMessage": "正在加载事件", - "xpack.infra.logFlyout.setFilterTooltip": "使用筛选查看事件", - "xpack.infra.logFlyout.valueColumnLabel": "值", - "xpack.infra.logs.customizeLogs.customizeButtonLabel": "定制", - "xpack.infra.logs.customizeLogs.lineWrappingFormRowLabel": "换行", - "xpack.infra.logs.customizeLogs.minimapScaleFormRowLabel": "迷你地图比例", - "xpack.infra.logs.customizeLogs.textSizeFormRowLabel": "文本大小", - "xpack.infra.logs.customizeLogs.textSizeRadioGroup": "{textScale, select, small {小} medium {Medium} large {Large} other {{textScale}} }", - "xpack.infra.logs.customizeLogs.wrapLongLinesSwitchLabel": "长行换行", - "xpack.infra.logs.emptyView.checkForNewDataButtonLabel": "检查新数据", - "xpack.infra.logs.emptyView.noLogMessageDescription": "尝试调整您的筛选。", - "xpack.infra.logs.emptyView.noLogMessageTitle": "没有可显示的日志消息。", - "xpack.infra.logs.lastStreamingUpdateText": " 最后更新时间:{lastUpdateTime}", - "xpack.infra.logs.loadAgainButtonLabel": "重新加载", - "xpack.infra.logs.loadingAdditionalEntriesText": "正在加载其他条目", - "xpack.infra.logs.noAdditionalEntriesFoundText": "找不到其他条目", - "xpack.infra.logs.scrollableLogTextStreamView.loadingEntriesLabel": "正在加载条目", - "xpack.infra.logs.search.nextButtonLabel": "下一个", - "xpack.infra.logs.search.previousButtonLabel": "上一页", - "xpack.infra.logs.search.searchInLogsAriaLabel": "搜索", - "xpack.infra.logs.search.searchInLogsPlaceholder": "搜索", - "xpack.infra.logs.searchResultTooltip": "{bucketCount, plural, one {# 个高亮条目} other {# 个高亮条目}}", - "xpack.infra.logs.startStreamingButtonLabel": "实时流式传输", - "xpack.infra.logs.stopStreamingButtonLabel": "停止流式传输", - "xpack.infra.logs.streamingDescription": "正在流式传输新条目……", - "xpack.infra.logs.streamingNewEntriesText": "正在流式传输新条目", - "xpack.infra.logsPage.noLoggingIndicesDescription": "让我们添加一些!", - "xpack.infra.logsPage.noLoggingIndicesInstructionsActionLabel": "查看设置说明", - "xpack.infra.logsPage.noLoggingIndicesTitle": "似乎您没有任何日志索引。", - "xpack.infra.logsPage.toolbar.kqlSearchFieldPlaceholder": "搜索日志条目……(例如 host.name:host-1)", - "xpack.infra.mapLogs.oneDayLabel": "1 日", - "xpack.infra.mapLogs.oneHourLabel": "1 小时", - "xpack.infra.mapLogs.oneMinuteLabel": "1 分钟", - "xpack.infra.mapLogs.oneMonthLabel": "1 个月", - "xpack.infra.mapLogs.oneWeekLabel": "1 周", - "xpack.infra.mapLogs.oneYearLabel": "1 年", - "xpack.infra.metricDetailPage.containerMetricsLayout.cpuUsageSection.sectionLabel": "CPU 使用", - "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoBytesSection.readRateSeriesLabel": "读取数", - "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoBytesSection.sectionLabel": "磁盘 IO(字节)", - "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoBytesSection.writeRateSeriesLabel": "写入数", - "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoOpsSection.readRateSeriesLabel": "读取数", - "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoOpsSection.sectionLabel": "磁盘 IO(操作数)", - "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoOpsSection.writeRateSeriesLabel": "写入数", - "xpack.infra.metricDetailPage.containerMetricsLayout.layoutLabel": "容器", - "xpack.infra.metricDetailPage.containerMetricsLayout.memoryUsageSection.sectionLabel": "内存利用率", - "xpack.infra.metricDetailPage.containerMetricsLayout.networkTrafficSection.networkRxRateSeriesLabel": "传入", - "xpack.infra.metricDetailPage.containerMetricsLayout.networkTrafficSection.networkTxRateSeriesLabel": "传出", - "xpack.infra.metricDetailPage.containerMetricsLayout.networkTrafficSection.sectionLabel": "网络流量", - "xpack.infra.metricDetailPage.containerMetricsLayout.overviewSection.cpuUsageSeriesLabel": "CPU 使用", - "xpack.infra.metricDetailPage.containerMetricsLayout.overviewSection.inboundRXSeriesLabel": "入站 (RX)", - "xpack.infra.metricDetailPage.containerMetricsLayout.overviewSection.memoryUsageSeriesLabel": "内存利用率", - "xpack.infra.metricDetailPage.containerMetricsLayout.overviewSection.outboundTXSeriesLabel": "出站 (TX)", - "xpack.infra.metricDetailPage.containerMetricsLayout.overviewSection.sectionLabel": "概览", - "xpack.infra.metricDetailPage.documentTitle": "Infrastructure | 指标 | {name}", - "xpack.infra.metricDetailPage.documentTitleError": "{previousTitle} | 啊哦", - "xpack.infra.metricDetailPage.hostMetricsLayout.cpuUsageSection.sectionLabel": "CPU 使用", - "xpack.infra.metricDetailPage.hostMetricsLayout.layoutLabel": "主机", - "xpack.infra.metricDetailPage.hostMetricsLayout.loadSection.fifteenMinuteSeriesLabel": "15 分钟", - "xpack.infra.metricDetailPage.hostMetricsLayout.loadSection.fiveMinuteSeriesLabel": "5 分钟", - "xpack.infra.metricDetailPage.hostMetricsLayout.loadSection.oneMinuteSeriesLabel": "1 分钟", - "xpack.infra.metricDetailPage.hostMetricsLayout.loadSection.sectionLabel": "负载", - "xpack.infra.metricDetailPage.hostMetricsLayout.memoryUsageSection.sectionLabel": "内存利用率", - "xpack.infra.metricDetailPage.hostMetricsLayout.networkTrafficSection.networkRxRateSeriesLabel": "传入", - "xpack.infra.metricDetailPage.hostMetricsLayout.networkTrafficSection.networkTxRateSeriesLabel": "传出", - "xpack.infra.metricDetailPage.hostMetricsLayout.networkTrafficSection.sectionLabel": "网络流量", - "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.cpuUsageSeriesLabel": "CPU 使用", - "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.inboundRXSeriesLabel": "入站 (RX)", - "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.loadSeriesLabel": "负载(5 分钟)", - "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.memoryCapacitySeriesLabel": "内存利用率", - "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.outboundTXSeriesLabel": "出站 (TX)", - "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.sectionLabel": "概览", - "xpack.infra.metricDetailPage.kubernetesMetricsLayout.nodeCpuCapacitySection.sectionLabel": "节点 CPU 容量", - "xpack.infra.metricDetailPage.kubernetesMetricsLayout.nodeDiskCapacitySection.sectionLabel": "节点磁盘容量", - "xpack.infra.metricDetailPage.kubernetesMetricsLayout.nodeMemoryCapacitySection.sectionLabel": "节点内存容量", - "xpack.infra.metricDetailPage.kubernetesMetricsLayout.nodePodCapacitySection.sectionLabel": "节点 Pod 容量", - "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.cpuUsageSeriesLabel": "CPU 容量", - "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.diskCapacitySeriesLabel": "磁盘容量", - "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.loadSeriesLabel": "负载(5 分钟)", - "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.memoryUsageSeriesLabel": "内存容量", - "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.podCapacitySeriesLabel": "Pod 容量", - "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.sectionLabel": "概览", - "xpack.infra.metricDetailPage.nginxMetricsLayout.activeConnectionsSection.sectionLabel": "活动连接", - "xpack.infra.metricDetailPage.nginxMetricsLayout.hitsSection.sectionLabel": "命中", - "xpack.infra.metricDetailPage.nginxMetricsLayout.requestRateSection.sectionLabel": "请求速率", - "xpack.infra.metricDetailPage.nginxMetricsLayout.requestsPerConnectionsSection.reqsPerConnSeriesLabel": "每连接请求数", - "xpack.infra.metricDetailPage.nginxMetricsLayout.requestsPerConnectionsSection.sectionLabel": "每连接请求数", - "xpack.infra.metricDetailPage.podMetricsLayout.cpuUsageSection.sectionLabel": "CPU 使用", - "xpack.infra.metricDetailPage.podMetricsLayout.layoutLabel": "Pod", - "xpack.infra.metricDetailPage.podMetricsLayout.memoryUsageSection.sectionLabel": "内存利用率", - "xpack.infra.metricDetailPage.podMetricsLayout.networkTrafficSection.networkRxRateSeriesLabel": "传入", - "xpack.infra.metricDetailPage.podMetricsLayout.networkTrafficSection.networkTxRateSeriesLabel": "传出", - "xpack.infra.metricDetailPage.podMetricsLayout.networkTrafficSection.sectionLabel": "网络流量", - "xpack.infra.metricDetailPage.podMetricsLayout.overviewSection.cpuUsageSeriesLabel": "CPU 使用", - "xpack.infra.metricDetailPage.podMetricsLayout.overviewSection.inboundRXSeriesLabel": "入站 (RX)", - "xpack.infra.metricDetailPage.podMetricsLayout.overviewSection.memoryUsageSeriesLabel": "内存利用率", - "xpack.infra.metricDetailPage.podMetricsLayout.overviewSection.outboundTXSeriesLabel": "出站 (TX)", - "xpack.infra.metricDetailPage.podMetricsLayout.overviewSection.sectionLabel": "概览", - "xpack.infra.metrics.emptyViewDescription": "尝试调整您的时间或筛选。", - "xpack.infra.metrics.emptyViewTitle": "没有可显示的数据。", - "xpack.infra.metrics.invalidNodeErrorDescription": "反复检查您的配置", - "xpack.infra.metrics.invalidNodeErrorTitle": "似乎 {nodeName} 未在收集任何指标数据", - "xpack.infra.metrics.loadingNodeDataText": "正在加载数据", - "xpack.infra.metrics.refetchButtonLabel": "检查新数据", - "xpack.infra.metricsExplorer.actionsLabel.aria": "适用于 {grouping} 的操作", - "xpack.infra.metricsExplorer.actionsLabel.button": "操作", - "xpack.infra.metricsExplorer.aggregationLabel": "的", - "xpack.infra.metricsExplorer.aggregationLables.avg": "平均值", - "xpack.infra.metricsExplorer.aggregationLables.cardinality": "基数", - "xpack.infra.metricsExplorer.aggregationLables.count": "文档计数", - "xpack.infra.metricsExplorer.aggregationLables.max": "最大值", - "xpack.infra.metricsExplorer.aggregationLables.min": "最小值", - "xpack.infra.metricsExplorer.aggregationLables.rate": "速率", - "xpack.infra.metricsExplorer.aggregationSelectLabel": "选择聚合", - "xpack.infra.metricsExplorer.emptyChart.body": "无法呈现图表。", - "xpack.infra.metricsExplorer.emptyChart.title": "图表数据缺失", - "xpack.infra.metricsExplorer.errorMessage": "似乎请求失败,并出现“{message}”", - "xpack.infra.metricsExplorer.filterByLabel": "添加筛选", - "xpack.infra.metricsExplorer.footerPaginationMessage": "显示 {length} 个图表,共 {total} 个,按“{groupBy}”分组", - "xpack.infra.metricsExplorer.groupByLabel": "所有内容", - "xpack.infra.metricsExplorer.groupByToolbarLabel": "图表/", - "xpack.infra.metricsExplorer.loadingCharts": "正在加载图表", - "xpack.infra.metricsExplorer.loadMoreChartsButton": "加载更多图表", - "xpack.infra.metricsExplorer.metricComboBoxPlaceholder": "选择指标以进行绘图", - "xpack.infra.metricsExplorer.noDataBodyText": "尝试调整您的时间、筛选或分组依据设置。", - "xpack.infra.metricsExplorer.noDataRefetchText": "检查新数据", - "xpack.infra.metricsExplorer.noDataTitle": "没有可显示的数据。", - "xpack.infra.metricsExplorer.noMetrics.body": "请在上面选择指标。", - "xpack.infra.metricsExplorer.noMetrics.title": "缺失指标", - "xpack.infra.metricsExplorer.openInTSVB": "在 Visualize 中打开", - "xpack.infra.metricsExplorer.viewNodeDetail": "查看 {name} 的指标", - "xpack.infra.node.ariaLabel": "{nodeName},单击打开菜单", - "xpack.infra.nodeContextMenu.viewLogsName": "查看日志", - "xpack.infra.nodeContextMenu.viewMetricsName": "查看指标", - "xpack.infra.nodesToWaffleMap.groupsWithGroups.allName": "全部", - "xpack.infra.nodesToWaffleMap.groupsWithNodes.allName": "全部", - "xpack.infra.notFoundPage.noContentFoundErrorTitle": "未找到任何内容", - "xpack.infra.redirectToNodeLogs.loadingNodeLogsMessage": "正在加载 {nodeType} 日志", - "xpack.infra.registerFeatures.infraOpsDescription": "浏览常用服务器、容器和服务的基础设施指标和日志。", - "xpack.infra.registerFeatures.infraOpsTitle": "指标", - "xpack.infra.registerFeatures.logsDescription": "实时流式传输日志或在类似控制台的工具中滚动浏览历史视图。", - "xpack.infra.registerFeatures.logsTitle": "Logs", - "xpack.infra.sourceConfiguration.addLogColumnButtonLabel": "添加列", - "xpack.infra.sourceConfiguration.containerFieldLabel": "容器 ID", - "xpack.infra.sourceConfiguration.fieldEmptyErrorMessage": "字段不得为空。", - "xpack.infra.sourceConfiguration.fieldLogColumnTitle": "字段", - "xpack.infra.sourceConfiguration.fieldsSectionTitle": "字段", - "xpack.infra.sourceConfiguration.hostFieldDescription": "推荐值为 {defaultValue}", - "xpack.infra.sourceConfiguration.hostFieldLabel": "主机名", - "xpack.infra.sourceConfiguration.indicesSectionTitle": "索引", - "xpack.infra.sourceConfiguration.logColumnListEmptyErrorMessage": "日志列列表不得为空。", - "xpack.infra.sourceConfiguration.logColumnsSectionTitle": "日志列", - "xpack.infra.sourceConfiguration.logIndicesLabel": "日志索引", - "xpack.infra.sourceConfiguration.messageLogColumnDescription": "此系统字段显示派生自文档字段的日志条目消息。", - "xpack.infra.sourceConfiguration.metricIndicesLabel": "指标索引", - "xpack.infra.sourceConfiguration.nameLabel": "名称", - "xpack.infra.sourceConfiguration.nameSectionTitle": "名称", - "xpack.infra.sourceConfiguration.noLogColumnsDescription": "使用上面的按钮将列添加到此列表。", - "xpack.infra.sourceConfiguration.noLogColumnsTitle": "无列", - "xpack.infra.sourceConfiguration.podFieldLabel": "Pod ID", - "xpack.infra.sourceConfiguration.systemColumnBadgeLabel": "系统", - "xpack.infra.sourceConfiguration.tiebreakerFieldLabel": "决胜属性", - "xpack.infra.sourceConfiguration.timestampFieldLabel": "时间戳", - "xpack.infra.sourceConfiguration.timestampLogColumnDescription": "此系统字段显示 {timestampSetting} 字段设置所确定的日志条目时间。", - "xpack.infra.sourceErrorPage.failedToLoadDataSourcesMessage": "无法加载数据源。", - "xpack.infra.sourceLoadingPage.loadingDataSourcesMessage": "正在加载数据源", - "xpack.infra.tableView.columnName.avg": "平均值", - "xpack.infra.tableView.columnName.last1m": "过去 1 分钟", - "xpack.infra.tableView.columnName.max": "最大值", - "xpack.infra.tableView.columnName.name": "名称", - "xpack.infra.viewSwitcher.lenged": "在表视图和地图视图间切换", - "xpack.infra.viewSwitcher.mapViewLabel": "地图视图", - "xpack.infra.viewSwitcher.tableViewLabel": "表视图", - "xpack.infra.waffle.checkNewDataButtonLabel": "检查新数据", - "xpack.infra.waffle.customGroupByDropdownPlacehoder": "选择一个", - "xpack.infra.waffle.customGroupByFieldLabel": "字段", - "xpack.infra.waffle.customGroupByHelpText": "这是用于词聚合的字段", - "xpack.infra.waffle.customGroupByOptionName": "定制字段", - "xpack.infra.waffle.customGroupByPanelTitle": "按定制字段分组", - "xpack.infra.waffle.groupByAllTitle": "全部", - "xpack.infra.waffle.groupByButtonLabel": "分组依据:", - "xpack.infra.waffle.loadingDataText": "正在加载数据", - "xpack.infra.waffle.metricButtonLabel": "指标:{selectedMetric}", - "xpack.infra.waffle.metricOptions.cpuUsageText": "CPU 使用", - "xpack.infra.waffle.metricOptions.hostLogRateText": "日志速率", - "xpack.infra.waffle.metricOptions.inboundTrafficText": "入站流量", - "xpack.infra.waffle.metricOptions.loadText": "负载", - "xpack.infra.waffle.metricOptions.memoryUsageText": "内存利用率", - "xpack.infra.waffle.metricOptions.outboundTrafficText": "出站流量", - "xpack.infra.waffle.noDataDescription": "尝试调整您的时间或筛选。", - "xpack.infra.waffle.noDataTitle": "没有可显示的数据。", - "xpack.infra.waffle.selectTwoGroupingsTitle": "选择最多两个分组", - "xpack.infra.waffle.unableToSelectGroupErrorMessage": "无法选择 {nodeType} 的分组依据选项", - "xpack.infra.waffle.unableToSelectMetricErrorTitle": "无法选择指标选项或指标值。", - "xpack.infra.waffleTime.autoRefreshButtonLabel": "自动刷新", - "xpack.infra.waffleTime.stopRefreshingButtonLabel": "停止刷新", - "xpack.infra.analysisSetup.analysisSetupDescription": "使用 Machine Learning 自动检测异常日志速率计数。", - "xpack.infra.analysisSetup.analysisSetupTitle": "启用 Machine Learning 分析", - "xpack.infra.analysisSetup.createMlJobButton": "创建 ML 作业", - "xpack.infra.analysisSetup.endTimeDefaultDescription": "无限期", - "xpack.infra.analysisSetup.endTimeLabel": "结束时间", - "xpack.infra.analysisSetup.startTimeDefaultDescription": "日志索引的开始时间", - "xpack.infra.analysisSetup.startTimeLabel": "开始时间", - "xpack.infra.analysisSetup.timeRangeDescription": "默认情况下,Machine Learning 分析日志索引中 4 周前的日志消息,并无限持续下去。您可以指定不同的开始日期或/和结束日期。", - "xpack.infra.analysisSetup.timeRangeTitle": "选择时间范围", - "xpack.infra.chartSection.missingMetricDataBody": "此图表的数据缺失。", - "xpack.infra.chartSection.notEnoughDataPointsToRenderTitle": "没有足够的数据", - "xpack.infra.header.logsTitle": "Logs", - "xpack.infra.homePage.settingsTabTitle": "设置", - "xpack.infra.kibanaMetrics.cloudIdMissingErrorMessage": "{metricId} 的模型需要云 ID,但没有为 {nodeId} 提供。", - "xpack.infra.logs.analysis.logRateSectionLineSeriesName": "每 15 分钟日志条目数(平均值)", - "xpack.infra.logs.analysis.logRateSectionLoadingAriaLabel": "正在加载日志速率结果", - "xpack.infra.logs.analysis.logRateSectionNoDataBody": "您可能想调整时间范围。", - "xpack.infra.logs.analysis.logRateSectionNoDataTitle": "没有可显示的数据。", - "xpack.infra.logs.analysis.logRateSectionTitle": "日志速率", - "xpack.infra.logs.analysisPage.loadingMessage": "正在检查分析作业的状态......", - "xpack.infra.logs.analysisPage.unavailable.mlAppLink": "Machine Learning 应用", - "xpack.infra.logs.highlights.goToNextHighlightButtonLabel": "跳转到下一高亮条目", - "xpack.infra.logs.highlights.goToPreviousHighlightButtonLabel": "跳转到上一高亮条目", - "xpack.infra.logs.index.settingsTabTitle": "设置", - "xpack.infra.logs.index.streamTabTitle": "流式传输", - "xpack.infra.logs.streamPage.documentTitle": "{previousTitle} | 流式传输", - "xpack.infra.logsPage.toolbar.kqlSearchFieldAriaLabel": "搜索日志条目", - "xpack.infra.metricDetailPage.awsMetricsLayout.cpuUtilSection.percentSeriesLabel": "百分比", - "xpack.infra.metricDetailPage.awsMetricsLayout.cpuUtilSection.sectionLabel": "CPU 使用率", - "xpack.infra.metricDetailPage.awsMetricsLayout.diskioBytesSection.readsSeriesLabel": "读取数", - "xpack.infra.metricDetailPage.awsMetricsLayout.diskioBytesSection.sectionLabel": "磁盘 I/O 字节数", - "xpack.infra.metricDetailPage.awsMetricsLayout.diskioBytesSection.writesSeriesLabel": "写入数", - "xpack.infra.metricDetailPage.awsMetricsLayout.diskioOperationsSection.readsSeriesLabel": "读取数", - "xpack.infra.metricDetailPage.awsMetricsLayout.diskioOperationsSection.sectionLabel": "磁盘 I/O 操作数", - "xpack.infra.metricDetailPage.awsMetricsLayout.diskioOperationsSection.writesSeriesLabel": "写入数", - "xpack.infra.metricDetailPage.awsMetricsLayout.networkBytesSection.rxSeriesLabel": "传入", - "xpack.infra.metricDetailPage.awsMetricsLayout.networkBytesSection.sectionLabel": "网络流量", - "xpack.infra.metricDetailPage.awsMetricsLayout.networkBytesSection.txSeriesLabel": "传出", - "xpack.infra.metricDetailPage.awsMetricsLayout.networkPacketsSection.packetsInSeriesLabel": "传入", - "xpack.infra.metricDetailPage.awsMetricsLayout.networkPacketsSection.packetsOutSeriesLabel": "传出", - "xpack.infra.metricDetailPage.awsMetricsLayout.networkPacketsSection.sectionLabel": "网络数据包(平均值)", - "xpack.infra.metricDetailPage.awsMetricsLayout.overviewSection.cpuUtilizationSeriesLabel": "CPU 使用率", - "xpack.infra.metricDetailPage.awsMetricsLayout.overviewSection.networkPacketsInLabel": "数据包(传入)", - "xpack.infra.metricDetailPage.awsMetricsLayout.overviewSection.networkPacketsOutLabel": "数据包(传出)", - "xpack.infra.metricDetailPage.awsMetricsLayout.overviewSection.sectionLabel": "概览", - "xpack.infra.metricDetailPage.awsMetricsLayout.overviewSection.statusCheckFailedLabel": "状态检查失败", - "xpack.infra.metricsExplorer.chartOptions.areaLabel": "面积图", - "xpack.infra.metricsExplorer.chartOptions.autoLabel": "自动(最小值到最大值)", - "xpack.infra.metricsExplorer.chartOptions.fromZeroLabel": "从零(0 到最大值)", - "xpack.infra.metricsExplorer.chartOptions.lineLabel": "折线图", - "xpack.infra.metricsExplorer.chartOptions.stackLabel": "堆叠序列", - "xpack.infra.metricsExplorer.chartOptions.stackSwitchLabel": "堆叠", - "xpack.infra.metricsExplorer.chartOptions.typeLabel": "图表样式", - "xpack.infra.metricsExplorer.chartOptions.yAxisDomainLabel": "Y 轴域", - "xpack.infra.metricsExplorer.customizeChartOptions": "定制", - "xpack.infra.sourceConfiguration.applySettingsButtonLabel": "应用", - "xpack.infra.sourceConfiguration.containerFieldRecommendedValue": "推荐值为 {defaultValue}", - "xpack.infra.sourceConfiguration.discardSettingsButtonLabel": "丢弃", - "xpack.infra.sourceConfiguration.hostNameFieldDescription": "用于标识主机的字段", - "xpack.infra.sourceConfiguration.hostNameFieldLabel": "主机名", - "xpack.infra.sourceConfiguration.logIndicesRecommendedValue": "推荐值为 {defaultValue}", - "xpack.infra.sourceConfiguration.logIndicesTitle": "日志索引", - "xpack.infra.sourceConfiguration.metricIndicesRecommendedValue": "推荐值为 {defaultValue}", - "xpack.infra.sourceConfiguration.metricIndicesTitle": "指标索引", - "xpack.infra.sourceConfiguration.nameDescription": "源配置的描述性名称", - "xpack.infra.sourceConfiguration.podFieldRecommendedValue": "推荐值为 {defaultValue}", - "xpack.infra.sourceConfiguration.tiebreakerFieldRecommendedValue": "推荐值为 {defaultValue}", - "xpack.infra.sourceConfiguration.timestampFieldRecommendedValue": "推荐值为 {defaultValue}", - "xpack.infra.sourceConfiguration.unsavedFormPrompt": "是否确定要离开?更改将丢失", - "xpack.infra.useHTTPRequest.error.status": "错误", - "xpack.infra.useHTTPRequest.error.title": "提取资源时出错", - "xpack.infra.useHTTPRequest.error.url": "URL", - "xpack.infra.sourceConfiguration.containerFieldDescription": "用于标识 Docker 容器的字段", - "xpack.infra.sourceConfiguration.logIndicesDescription": "用于匹配包含日志数据的索引的索引模式", - "xpack.infra.sourceConfiguration.metricIndicesDescription": "用于匹配包含 Metricbeat 数据的索引的索引模式", - "xpack.infra.sourceConfiguration.podFieldDescription": "用于标识 Kubernetes Pod 的字段", - "xpack.infra.sourceConfiguration.removeLogColumnButtonLabel": "删除“{columnDescription}”列", - "xpack.infra.sourceConfiguration.tiebreakerFieldDescription": "用于时间戳相同的两个条目间决胜的字段", - "xpack.infra.sourceConfiguration.timestampFieldDescription": "用于排序日志条目的时间戳", - "xpack.infra.analysisSetup.deleteAnalysisResultsWarning": "这将移除以前检测到的异常。", - "xpack.infra.analysisSetup.recreateMlJobButton": "重新创建 ML 作业", - "xpack.infra.analysisSetup.steps.setupProcess.loadingText": "正在创建 ML 作业......", - "xpack.infra.analysisSetup.steps.setupProcess.successText": "ML 作业已设置成功", - "xpack.infra.analysisSetup.steps.setupProcess.tryAgainButton": "重试", - "xpack.infra.analysisSetup.steps.setupProcess.viewResultsButton": "查看结果", - "xpack.infra.logs.analysis.analyzeInMlButtonLabel": "在 ML 中分析", - "xpack.infra.logs.analysis.anomaliesExpandedRowNumberOfLogEntriesDescription": "日志条目数", - "xpack.infra.logs.analysis.anomaliesSectionLineSeriesName": "每 15 分钟日志条目数(平均值)", - "xpack.infra.logs.analysis.anomaliesSectionLoadingAriaLabel": "正在加载异常", - "xpack.infra.logs.analysis.anomaliesSectionTitle": "异常", - "xpack.infra.logs.analysis.anomaliesTableCollapseLabel": "折叠", - "xpack.infra.logs.analysis.anomaliesTableExpandLabel": "展开", - "xpack.infra.logs.analysis.anomaliesTableMaxAnomalyScoreColumnName": "最大异常分数", - "xpack.infra.logs.analysis.anomaliesTablePartitionColumnName": "分区", - "xpack.infra.logs.analysis.anomalySectionNoAnomaliesTitle": "未检测到任何异常。", - "xpack.infra.logs.analysis.anomalySectionNoDataBody": "您可能想调整时间范围。", - "xpack.infra.logs.analysis.anomalySectionNoDataTitle": "没有可显示的数据。", - "xpack.infra.logs.analysis.jobConfigurationOutdatedCalloutMessage": "创建 ML 作业时所使用的源配置不同。重新创建作业以应用当前配置。这将移除以前检测到的异常。", - "xpack.infra.logs.analysis.jobConfigurationOutdatedCalloutTitle": "ML 作业配置已过期", - "xpack.infra.logs.analysis.jobDefinitionOutdatedCalloutMessage": "ML 作业有更新的版本可用。重新创建作业以部署更新的版本。这将移除以前检测到的异常。", - "xpack.infra.logs.analysis.jobDefinitionOutdatedCalloutTitle": "ML 作业定义已过期", - "xpack.infra.logs.analysis.jobStoppedCalloutMessage": "ML 作业已手动停止或由于缺乏资源而停止。作业重新启动后,才会处理新的日志条目。", - "xpack.infra.logs.analysis.jobStoppedCalloutTitle": "ML 作业已停止", - "xpack.infra.logs.analysis.logRateResultsToolbarText": "从 {startTime} 到 {endTime} 已分析 {numberOfLogs} 个日志条目", - "xpack.infra.logs.analysis.logRateSectionBucketSpanLabel": "存储桶跨度:", - "xpack.infra.logs.analysis.logRateSectionBucketSpanValue": "15 分钟", - "xpack.infra.logs.analysis.overallAnomaliesNumberOfLogEntriesDescription": "日志条目数", - "xpack.infra.logs.analysis.overallAnomaliesTopAnomalyScoreDescription": "最大异常分数", - "xpack.infra.logs.analysis.overallAnomalyChartMaxScoresLabel": "最大异常分数:", - "xpack.infra.logs.analysis.partitionMaxAnomalyScoreAnnotationLabel": "最大异常分数:{maxAnomalyScore}", - "xpack.infra.logs.analysis.recreateJobButtonLabel": "重新创建 ML 作业", - "xpack.infra.logs.jumpToTailText": "跳到最近的条目", - "xpack.infra.metricsExplorer.chartOptions.barLabel": "条形图", - "xpack.infra.nodeDetails.labels.availabilityZone": "可用区", - "xpack.infra.nodeDetails.labels.cloudProvider": "云服务提供商", - "xpack.infra.nodeDetails.labels.containerized": "容器化", - "xpack.infra.nodeDetails.labels.hostname": "主机名", - "xpack.infra.nodeDetails.labels.instanceId": "实例 ID", - "xpack.infra.nodeDetails.labels.instanceName": "实例名称", - "xpack.infra.nodeDetails.labels.kernelVersion": "内核版本", - "xpack.infra.nodeDetails.labels.machineType": "机器类型", - "xpack.infra.nodeDetails.labels.operatinSystem": "操作系统", - "xpack.infra.nodeDetails.labels.projectId": "项目 ID", - "xpack.infra.nodeDetails.labels.showMoreDetails": "显示更多详情", - "xpack.infra.nodeDetails.no": "否", - "xpack.infra.nodeDetails.yes": "是", - "xpack.infra.openView.actionNames.deleteConfirmation": "删除视图?", - "xpack.infra.openView.cancelButton": "取消", - "xpack.infra.openView.columnNames.actions": "操作", - "xpack.infra.openView.columnNames.name": "名称", - "xpack.infra.openView.flyoutHeader": "加载视图", - "xpack.infra.sampleDataLinkLabel": "日志", - "xpack.infra.savedView.defaultViewName": "默认值", - "xpack.infra.savedView.errorOnCreate.title": "保存视图时出错。", - "xpack.infra.savedView.findError.title": "加载视图时出错。", - "xpack.infra.waffle.inventoryButtonLabel": "视图:{selectedText}", - "xpack.infra.waffle.metricOptions.countText": "计数", - "xpack.infra.waffle.savedView.createHeader": "保存视图", - "xpack.infra.waffle.savedViews.cancel": "取消", - "xpack.infra.waffle.savedViews.cancelButton": "取消", - "xpack.infra.waffle.savedViews.includeTimeFilterLabel": "将时间与视图一起存储", - "xpack.infra.waffle.savedViews.includeTimeHelpText": "每次加载此仪表板时,这都会将时间筛选更改为当前选定的时间", - "xpack.infra.waffle.savedViews.loadViewsLabel": "负载", - "xpack.infra.waffle.savedViews.saveButton": "保存", - "xpack.infra.waffle.savedViews.saveViewLabel": "保存", - "xpack.infra.waffle.savedViews.viewNamePlaceholder": "名称", - "xpack.kueryAutocomplete.andOperatorDescription": "需要{bothArguments}为真", - "xpack.kueryAutocomplete.andOperatorDescription.bothArgumentsText": "两个参数都", - "xpack.kueryAutocomplete.equalOperatorDescription": "{equals}某一值", - "xpack.kueryAutocomplete.equalOperatorDescription.equalsText": "等于", - "xpack.kueryAutocomplete.existOperatorDescription": "以任意形式{exists}", - "xpack.kueryAutocomplete.existOperatorDescription.existsText": "存在", - "xpack.kueryAutocomplete.filterResultsDescription": "筛选包含 {fieldName} 的结果", - "xpack.kueryAutocomplete.greaterThanOperatorDescription": "{greaterThan}某一值", - "xpack.kueryAutocomplete.greaterThanOperatorDescription.greaterThanText": "大于", - "xpack.kueryAutocomplete.greaterThanOrEqualOperatorDescription": "{greaterThanOrEqualTo}某一值", - "xpack.kueryAutocomplete.greaterThanOrEqualOperatorDescription.greaterThanOrEqualToText": "大于或等于", - "xpack.kueryAutocomplete.lessThanOperatorDescription": "{lessThan}某一值", - "xpack.kueryAutocomplete.lessThanOperatorDescription.lessThanText": "小于", - "xpack.kueryAutocomplete.lessThanOrEqualOperatorDescription": "{lessThanOrEqualTo}某一值", - "xpack.kueryAutocomplete.lessThanOrEqualOperatorDescription.lessThanOrEqualToText": "小于或等于", - "xpack.kueryAutocomplete.orOperatorDescription": "需要{oneOrMoreArguments}为真", - "xpack.kueryAutocomplete.orOperatorDescription.oneOrMoreArgumentsText": "一个或多个参数", - "xpack.licenseMgmt.dashboard.breadcrumb": "许可管理", - "xpack.licenseMgmt.licenseDashboard.addLicense.updateLicenseButtonLabel": "更新许可", - "xpack.licenseMgmt.licenseDashboard.addLicense.updateLicenseTitle": "更新您的许可", - "xpack.licenseMgmt.licenseDashboard.addLicense.useAvailableLicenseDescription": "如果已有新的许可,请立即上传。", - "xpack.licenseMgmt.licenseDashboard.licenseStatus.activeLicenseStatusDescription": "您的许可将于 {expiryDate}过期", - "xpack.licenseMgmt.licenseDashboard.licenseStatus.activeLicenseStatusText": "有效", - "xpack.licenseMgmt.licenseDashboard.licenseStatus.activeLicenseStatusTitle": "您的{typeTitleCase}许可{status}", - "xpack.licenseMgmt.licenseDashboard.licenseStatus.expiredLicenseStatusDescription": "您的许可已于 {expiryDate}过期", - "xpack.licenseMgmt.licenseDashboard.licenseStatus.expiredLicenseStatusTitle": "您的{typeTitleCase}许可已过期", - "xpack.licenseMgmt.licenseDashboard.licenseStatus.inactiveLicenseStatusText": "无效", - "xpack.licenseMgmt.licenseDashboard.licenseStatus.permanentActiveLicenseStatusDescription": "您的许可永不会过期。", - "xpack.licenseMgmt.licenseDashboard.requestTrialExtension.extendTrialButtonLabel": "延期试用", - "xpack.licenseMgmt.licenseDashboard.requestTrialExtension.extendYourTrialTitle": "延期您的试用", - "xpack.licenseMgmt.licenseDashboard.requestTrialExtension.howToContinueUsingPluginsDescription": "如果您想继续使用 Machine Learning、高级安全性以及我们其他超卓的{platinumLicenseFeaturesLinkText},请立即申请延期。", - "xpack.licenseMgmt.licenseDashboard.requestTrialExtension.platinumLicenseFeaturesLinkText": "白金级功能", - "xpack.licenseMgmt.licenseDashboard.revertToBasic.acknowledgeModal.revertToBasicButtonLabel": "恢复为基础级", - "xpack.licenseMgmt.licenseDashboard.revertToBasic.acknowledgeModalTitle": "恢复为基础级许可", - "xpack.licenseMgmt.licenseDashboard.revertToBasic.confirmModal.cancelButtonLabel": "取消", - "xpack.licenseMgmt.licenseDashboard.revertToBasic.confirmModal.confirmButtonLabel": "确认", - "xpack.licenseMgmt.licenseDashboard.revertToBasic.confirmModalTitle": "确认恢复为基础级许可", - "xpack.licenseMgmt.licenseDashboard.revertToBasic.platinumLicenseFeaturesLinkText": "白金级功能", - "xpack.licenseMgmt.licenseDashboard.revertToBasic.revertToFreeFeaturesDescription": "您将恢复到我们的免费功能,并失去对 Machine Learning、高级安全性和其他{platinumLicenseFeaturesLinkText}的访问权限。", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModal.cancelButtonLabel": "取消", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModal.startTrialButtonLabel": "开始我的试用", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription": "此试用具有 Elastic Stack 的全套{platinumLicenseFeaturesLinkText}您立即可以访问:", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.alertingFeatureTitle": "Alerting", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.dataBaseConnectivityFeatureTitle": "{sqlDataBase} 的 {jdbcStandard} 和 {odbcStandard} 连接性", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.graphCapabilitiesFeatureTitle": "图表功能", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.mashingLearningFeatureTitle": "Machine Learning", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.platinumLicenseFeaturesLinkText": "白金级功能", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.securityDocumentationLinkText": "文档", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.securityFeaturesConfigurationDescription": "诸如身份验证 ({authenticationTypeList})、字段级和文档级安全以及审计等高级安全功能需要配置。有关说明,请参阅 {securityDocumentationLinkText}。", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.termsAndConditionsDescription": "通过开始此试用,您同意其受这些{termsAndConditionsLinkText}约束。", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.termsAndConditionsLinkText": "条款和条件", - "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalTitle": "立即开始为期 30 天的免费试用", - "xpack.licenseMgmt.licenseDashboard.startTrial.platinumFeaturesExperienceDescription": "体验 Machine Learning、高级安全性以及我们所有其他{platinumLicenseFeaturesLinkText}能帮您做什么。", - "xpack.licenseMgmt.licenseDashboard.startTrial.platinumLicenseFeaturesLinkText": "白金级功能", - "xpack.licenseMgmt.licenseDashboard.startTrial.startTrialButtonLabel": "开始试用", - "xpack.licenseMgmt.licenseDashboard.startTrialTitle": "开始为期 30 天的试用", - "xpack.licenseMgmt.managementSectionDisplayName": "许可管理", - "xpack.licenseMgmt.replacingCurrentLicenseWithBasicLicenseWarningMessage": "如果将您的{currentLicenseType}许可替换成基础级许可,将会失去部分功能。查看下面的功能列表。", - "xpack.licenseMgmt.telemetryOptIn.customersHelpSupportDescription": "帮助 Elastic 支持提供更好的服务", - "xpack.licenseMgmt.telemetryOptIn.exampleLinkText": "示例", - "xpack.licenseMgmt.telemetryOptIn.featureUsageWarningMessage": "此功能定期发送基本的功能使用统计信息。此信息不会在 Elastic 以外进行共享。请参阅{exampleLink}或阅读我们的{telemetryPrivacyStatementLink}。您可以随时禁用此功能。", - "xpack.licenseMgmt.telemetryOptIn.readMoreLinkText": "阅读更多内容", - "xpack.licenseMgmt.telemetryOptIn.sendBasicFeatureStatisticsLabel": "定期向 Elastic 发送基本的功能使用统计信息。{popover}", - "xpack.licenseMgmt.telemetryOptIn.telemetryPrivacyStatementLinkText": "遥测隐私声明", - "xpack.licenseMgmt.upload.breadcrumb": "上传", - "xpack.licenseMgmt.uploadLicense.cancelButtonLabel": "取消", - "xpack.licenseMgmt.uploadLicense.checkLicenseFileErrorMessage": "{genericUploadError}检查您的许可文件。", - "xpack.licenseMgmt.uploadLicense.confirmModal.cancelButtonLabel": "取消", - "xpack.licenseMgmt.uploadLicense.confirmModal.confirmButtonLabel": "确认", - "xpack.licenseMgmt.uploadLicense.confirmModalTitle": "确认许可上传", - "xpack.licenseMgmt.uploadLicense.expiredLicenseErrorMessage": "提供的许可已过期。", - "xpack.licenseMgmt.uploadLicense.genericUploadErrorMessage": "上传许可时遇到错误:", - "xpack.licenseMgmt.uploadLicense.invalidLicenseErrorMessage": "提供的许可对于此产品无效。", - "xpack.licenseMgmt.uploadLicense.licenseFileNotSelectedErrorMessage": "必须选择许可文件。", - "xpack.licenseMgmt.uploadLicense.licenseKeyTypeDescription": "您的许可密钥是附有签名的 JSON 文件。", - "xpack.licenseMgmt.uploadLicense.problemWithUploadedLicenseDescription": "如果将您的{currentLicenseType}许可替换成{newLicenseType}许可,将会失去部分功能。查看下面的功能列表。", - "xpack.licenseMgmt.uploadLicense.replacingCurrentLicenseWarningMessage": "上传许可将会替换您当前的{currentLicenseType}许可。", - "xpack.licenseMgmt.uploadLicense.selectLicenseFileDescription": "选择或拖来您的许可文件", - "xpack.licenseMgmt.uploadLicense.unknownErrorErrorMessage": "未知错误。", - "xpack.licenseMgmt.uploadLicense.uploadButtonLabel": "上传", - "xpack.licenseMgmt.uploadLicense.uploadingButtonLabel": "正在上传……", - "xpack.licenseMgmt.uploadLicense.uploadLicenseTitle": "上传您的许可", - "xpack.logstash.addRoleAlert.grantAdditionalPrivilegesDescription": "在 Kibana“管理”中,将 {role} 角色分配给您的 Kibana 用户。", - "xpack.logstash.addRoleAlert.grantAdditionalPrivilegesTitle": "授予其他权限。", - "xpack.logstash.alertCallOut.howToSeeAdditionalPipelinesDescription": "我如何可以看到其他管道?", - "xpack.logstash.confirmDeleteModal.cancelButtonLabel": "取消", - "xpack.logstash.confirmDeleteModal.deletedPipelineConfirmButtonLabel": "删除管道", - "xpack.logstash.confirmDeleteModal.deletedPipelinesConfirmButtonLabel": "删除 {numPipelinesSelected} 个管道", - "xpack.logstash.confirmDeleteModal.deletedPipelinesTitle": "删除 {numPipelinesSelected} 个管道", - "xpack.logstash.confirmDeleteModal.deletedPipelinesWarningMessage": "您无法恢复删除的管道。", - "xpack.logstash.confirmDeleteModal.deletedPipelineTitle": "删除管道“{id}”", - "xpack.logstash.confirmDeleteModal.deletedPipelineWarningMessage": "您无法恢复删除的管道", - "xpack.logstash.confirmDeletePipelineModal.cancelButtonText": "取消", - "xpack.logstash.confirmDeletePipelineModal.confirmButtonText": "删除管道", - "xpack.logstash.confirmDeletePipelineModal.deletePipelineTitle": "删除管道 {id}", - "xpack.logstash.couldNotLoadPipelineErrorNotification": "无法加载管道。错误:“{errStatusText}”。", - "xpack.logstash.deletePipelineModalMessage": "您无法恢复删除的管道。", - "xpack.logstash.enableMonitoringAlert.enableMonitoringDescription": "在 {configFileName} 文件中,将 {monitoringConfigParam} 和 {monitoringUiConfigParam} 设置为 {trueValue}。", - "xpack.logstash.enableMonitoringAlert.enableMonitoringTitle": "启用监测。", - "xpack.logstash.homeFeature.logstashPipelinesDescription": "创建、删除、更新和克隆数据采集管道。", - "xpack.logstash.homeFeature.logstashPipelinesTitle": "Logstash 管道", - "xpack.logstash.idFormatErrorMessage": "管道 ID 必须以字母或下划线开头,并只能包含字母、下划线、短划线和数字", - "xpack.logstash.insufficientUserPermissionsDescription": "管理 Logstash 管道的用户权限不足", - "xpack.logstash.kibanaManagementPipelinesTitle": "仅在 Kibana“管理”中创建的管道显示在此处", - "xpack.logstash.managementSection.createPipelineTitle": "创建管道", - "xpack.logstash.managementSection.editPipelineTitle": "编辑管道", - "xpack.logstash.managementSection.enableSecurityDescription": "必须启用 Security,才能使用 Logstash 管道管理功能。请在 elasticsearch.yml 中设置 xpack.security.enabled: true。", - "xpack.logstash.managementSection.licenseDoesNotSupportDescription": "您的{licenseType}许可不支持 Logstash 管道管理功能。请升级您的许可。", - "xpack.logstash.managementSection.notPossibleToManagePipelinesMessage": "您不能管理 Logstash 管道,因为许可信息当前不可用。", - "xpack.logstash.managementSection.pipelineCrudOperationsNotAllowedDescription": "您不能编辑、创建或删除您的 Logstash 管道,因为您的{licenseType}许可已过期。", - "xpack.logstash.managementSection.pipelinesTitle": "管道", - "xpack.logstash.manualUpgradeButtonLabel": "重试", - "xpack.logstash.newPipelineMessage": "在您可以添加管道之前,我们需要升级您的配置。", - "xpack.logstash.notManualUpgradeButtonLabel": "升级", - "xpack.logstash.notManualUpgradeTitle": "是时候升级了!", - "xpack.logstash.notNewPipelineMessage": "在您可以编辑此管道之前,我们需要升级您的配置。", - "xpack.logstash.pipelineBatchDelayTooltip": "创建管道事件批时,将过小的批分派给管道工作线程之前要等候每个事件的时长(毫秒)。\n\n默认值:50ms", - "xpack.logstash.pipelineBatchSizeTooltip": "单个工作线程在尝试执行其筛选和输出之前可以从输入收集的最大事件数目。较大的批大小通常更有效,但代价是内存开销也较大。您可能需要通过设置 LS_HEAP_SIZE 变量来增大 JVM 堆大小,从而有效利用该选项。\n\n默认值:125", - "xpack.logstash.pipelineEditor.cancelButtonLabel": "取消", - "xpack.logstash.pipelineEditor.clonePipelineTitle": "克隆管道“{id}”", - "xpack.logstash.pipelineEditor.createAndDeployButtonLabel": "创建并部署", - "xpack.logstash.pipelineEditor.createPipelineTitle": "创建管道", - "xpack.logstash.pipelineEditor.deletePipelineButtonLabel": "删除管道", - "xpack.logstash.pipelineEditor.descriptionFormRowLabel": "描述", - "xpack.logstash.pipelineEditor.editPipelineTitle": "编辑管道“{id}”", - "xpack.logstash.pipelineEditor.errorHandlerToastTitle": "管道错误", - "xpack.logstash.pipelineEditor.pipelineBatchDelayFormRowLabel": "管道批延迟", - "xpack.logstash.pipelineEditor.pipelineBatchSizeFormRowLabel": "管道批大小", - "xpack.logstash.pipelineEditor.pipelineFormRowLabel": "管道", - "xpack.logstash.pipelineEditor.pipelineIdFormRowLabel": "管道 ID", - "xpack.logstash.pipelineEditor.pipelineSuccessfullyDeletedMessage": "已删除“{id}”", - "xpack.logstash.pipelineEditor.pipelineSuccessfullySavedMessage": "已保存“{id}”", - "xpack.logstash.pipelineEditor.pipelineWorkersFormRowLabel": "管道工作线程", - "xpack.logstash.pipelineEditor.queueCheckpointWritesFormRowLabel": "队列检查点写入数", - "xpack.logstash.pipelineEditor.queueMaxBytesFormRowLabel": "队列最大字节数", - "xpack.logstash.pipelineEditor.queueTypeFormRowLabel": "队列类型", - "xpack.logstash.pipelineIdRequiredMessage": "管道 ID 必填", - "xpack.logstash.pipelineList.couldNotDeletePipelinesNotification": "无法删除 {numErrors, plural, one {# 个管道} other {# 个管道}}", - "xpack.logstash.pipelineList.head": "管道", - "xpack.logstash.pipelineList.noPermissionToManageDescription": "请联系您的管理员。", - "xpack.logstash.pipelineList.noPermissionToManageTitle": "您无权管理 Logstash 管道。", - "xpack.logstash.pipelineList.noPipelinesDescription": "未定义任何管道。", - "xpack.logstash.pipelineList.noPipelinesTitle": "没有管道", - "xpack.logstash.pipelineList.pipelineLoadingErrorNotification": "无法加载管道。错误:“{errStatusText}”。", - "xpack.logstash.pipelineList.pipelinesCouldNotBeDeletedDescription": "但 {numErrors, plural, one {# 个管道} other {# 个管道}}无法删除。", - "xpack.logstash.pipelineList.pipelinesLoadingErrorDescription": "加载管道时出错。", - "xpack.logstash.pipelineList.pipelinesLoadingErrorTitle": "错误", - "xpack.logstash.pipelineList.pipelinesLoadingMessage": "正在加载管道……", - "xpack.logstash.pipelineList.pipelinesSuccessfullyDeletedNotification": "已删除“{id}”", - "xpack.logstash.pipelineList.subhead": "管理 Logstash 事件处理并直观地查看结果", - "xpack.logstash.pipelineList.successfullyDeletedPipelinesNotification": "{numPipelinesSelected, plural, one {# 个管道} other {# 个管道}}有 {numSuccesses} 个已删除", - "xpack.logstash.pipelineNotCentrallyManagedTooltip": "此管道不是使用“集中配置管理”创建的。不能在此处管理或编辑它。", - "xpack.logstash.pipelines.createBreadcrumb": "创建", - "xpack.logstash.pipelines.listBreadcrumb": "管道", - "xpack.logstash.pipelinesTable.cloneButtonLabel": "克隆", - "xpack.logstash.pipelinesTable.createPipelineButtonLabel": "创建管道", - "xpack.logstash.pipelinesTable.deleteButtonLabel": "删除", - "xpack.logstash.pipelinesTable.descriptionColumnLabel": "描述", - "xpack.logstash.pipelinesTable.filterByIdLabel": "按 ID 筛选", - "xpack.logstash.pipelinesTable.idColumnLabel": "ID", - "xpack.logstash.pipelinesTable.lastModifiedColumnLabel": "最后修改时间", - "xpack.logstash.pipelinesTable.modifiedByColumnLabel": "修改者", - "xpack.logstash.pipelinesTable.selectablePipelineMessage": "选择管道“{id}”", - "xpack.logstash.queueCheckpointWritesTooltip": "启用持久性队列时,在强制执行检查点之前已写入事件的最大数目。指定 0 以将此值设置为无限制。\n\n默认值:1024", - "xpack.logstash.queueMaxBytesTooltip": "队列的总容量(字节数)。确保您的磁盘驱动器容量大于您在此处指定的值。\n\n默认值:1024mb (1g)", - "xpack.logstash.queueTypes.memoryLabel": "memory", - "xpack.logstash.queueTypes.persistedLabel": "persisted", - "xpack.logstash.queueTypeTooltip": "用于事件缓冲的内部排队模型。为旧式的内存内排队指定 memory 或为基于磁盘的已确认排队指定 persisted\n\n默认值:memory", - "xpack.logstash.units.bytesLabel": "字节", - "xpack.logstash.units.gigabytesLabel": "千兆字节", - "xpack.logstash.units.kilobytesLabel": "千字节", - "xpack.logstash.units.megabytesLabel": "兆字节", - "xpack.logstash.units.petabytesLabel": "万兆字节", - "xpack.logstash.units.terabytesLabel": "兆兆字节", - "xpack.logstash.upgradeFailedTitle": "升级失败", - "xpack.logstash.upgradeFailureActions.goBackButtonLabel": "返回", - "xpack.logstash.upstreamPipelineArgumentMustContainAnIdPropertyErrorMessage": "upstreamPipeline 参数必须包含 id 属性", - "xpack.logstash.workersTooltip": "并行执行管道的筛选和输出阶段的工作线程数目。如果您发现事件出现积压或 CPU 未饱和,请考虑增大此数值,以更好地利用机器处理能力。\n\n默认值:主机的 CPU 核心数", - "xpack.maps.addLayerPanel.changeDataSourceButtonLabel": "更改数据源", - "xpack.maps.addLayerPanel.chooseDataSourceTitle": "选择数据源", - "xpack.maps.appDescription": "地图应用程序", - "xpack.maps.appTitle": "Maps", - "xpack.maps.badge.readOnly.text": "只读", - "xpack.maps.badge.readOnly.tooltip": "无法保存地图", - "xpack.maps.esSearch.featureCountMsg": "找到 {count} 个文档。", - "xpack.maps.esSearch.resultsTrimmedMsg": "结果仅限于前 {count} 个文档。", - "xpack.maps.esSearch.topHitsEntitiesCountMsg": "找到 {entityCount} 个实体。", - "xpack.maps.feature.appDescription": "从 Elasticsearch 和 Elastic 地图服务浏览地理空间数据", - "xpack.maps.featureRegistry.mapsFeatureName": "Maps", - "xpack.maps.geoGrid.resolutionLabel": "网格分辨率", - "xpack.maps.heatmap.colorRampLabel": "颜色范围", - "xpack.maps.heatmapLegend.coldLabel": "冷", - "xpack.maps.heatmapLegend.hotLabel": "热", - "xpack.maps.inspector.centerLatLabel": "中心纬度", - "xpack.maps.inspector.centerLonLabel": "中心经度", - "xpack.maps.inspector.mapboxStyleTitle": "Mapbox 样式", - "xpack.maps.inspector.mapDetailsTitle": "地图详情", - "xpack.maps.inspector.mapDetailsViewHelpText": "查看地图状态", - "xpack.maps.inspector.mapDetailsViewTitle": "地图详情", - "xpack.maps.inspector.zoomLabel": "缩放", - "xpack.maps.layer.layerHiddenTooltip": "图层已隐藏。", - "xpack.maps.layer.loadWarningAriaLabel": "加载警告", - "xpack.maps.layer.zoomFeedbackTooltip": "图层在缩放级别 {minZoom} 和 {maxZoom} 之间可见。", - "xpack.maps.layerControl.addLayerButtonLabel": "添加图层", - "xpack.maps.layerControl.closeLayerTOCButtonAriaLabel": "折叠图层面板", - "xpack.maps.layerControl.layersTitle": "图层", - "xpack.maps.layerControl.openLayerTOCButtonAriaLabel": "展开图层面板", - "xpack.maps.layerControl.tocEntry.editButtonAriaLabel": "编辑图层", - "xpack.maps.layerControl.tocEntry.editButtonTitle": "编辑图层", - "xpack.maps.layerControl.tocEntry.grabButtonAriaLabel": "重新排序图层", - "xpack.maps.layerControl.tocEntry.grabButtonTitle": "重新排序图层", - "xpack.maps.layerControl.tocEntry.hideDetailsButtonAriaLabel": "隐藏图层详情", - "xpack.maps.layerControl.tocEntry.hideDetailsButtonTitle": "隐藏图层详情", - "xpack.maps.layerControl.tocEntry.showDetailsButtonAriaLabel": "显示图层详情", - "xpack.maps.layerControl.tocEntry.showDetailsButtonTitle": "显示图层详情", - "xpack.maps.layerPanel.filterEditor.addFilterButtonLabel": "添加筛选", - "xpack.maps.layerPanel.filterEditor.editFilterButtonLabel": "编辑筛选", - "xpack.maps.layerPanel.filterEditor.emptyState.description": "添加筛选以缩小图层数据范围。", - "xpack.maps.layerPanel.filterEditor.queryBarSubmitButtonLabel": "设置筛选", - "xpack.maps.layerPanel.filterEditor.title": "筛选", - "xpack.maps.layerPanel.fitToBoundsAriaLabel": "适应边界", - "xpack.maps.layerPanel.fitToBoundsButtonLabel": "适应", - "xpack.maps.layerPanel.footer.cancelButtonLabel": "取消", - "xpack.maps.layerPanel.footer.closeButtonLabel": "关闭", - "xpack.maps.layerPanel.footer.removeLayerButtonLabel": "移除图层", - "xpack.maps.layerPanel.footer.saveAndCloseButtonLabel": "保存并关闭", - "xpack.maps.layerPanel.join.deleteJoinAriaLabel": "删除联接", - "xpack.maps.layerPanel.join.deleteJoinTitle": "删除联接", - "xpack.maps.layerPanel.join.noIndexPatternErrorMessage": "找不到索引模式 {indexPatternId}", - "xpack.maps.layerPanel.joinEditor.addJoinAriaLabel": "添加联接", - "xpack.maps.layerPanel.joinEditor.addJoinButtonLabel": "添加联接", - "xpack.maps.layerPanel.joinEditor.termJoinsTitle": "词联接", - "xpack.maps.layerPanel.joinExpression.joinPopoverTitle": "联接", - "xpack.maps.layerPanel.joinExpression.leftFieldLabel": "左字段", - "xpack.maps.layerPanel.joinExpression.leftSourceLabel": "左源", - "xpack.maps.layerPanel.joinExpression.rightFieldLabel": "右字段", - "xpack.maps.layerPanel.joinExpression.rightSourceLabel": "右源", - "xpack.maps.layerPanel.joinExpression.selectFieldPlaceholder": "选择字段", - "xpack.maps.layerPanel.joinExpression.selectIndexPatternPlaceholder": "选择索引模式", - "xpack.maps.layerPanel.joinExpression.selectPlaceholder": "-- 选择 --", - "xpack.maps.layerPanel.layerSettingsTitle": "图层设置", - "xpack.maps.layerPanel.metricsExpression.joinMustBeSetErrorMessage": "必须设置联接", - "xpack.maps.layerPanel.metricsExpression.metricsPopoverTitle": "指标", - "xpack.maps.layerPanel.metricsExpression.useMetricsDescription": "{metricsLength, plural, one {并使用指标} other {并使用指标}}", - "xpack.maps.layerPanel.settingsPanel.layerNameLabel": "名称", - "xpack.maps.layerPanel.settingsPanel.layerTransparencyLabel": "图层透明度", - "xpack.maps.layerPanel.settingsPanel.unableToLoadTitle": "无法加载图层", - "xpack.maps.layerPanel.settingsPanel.visibleZoomLabel": "图层可见性的缩放范围", - "xpack.maps.layerPanel.sourceDetailsLabel": "源详情", - "xpack.maps.layerPanel.styleSettingsTitle": "图层样式", - "xpack.maps.layerTocActions.cloneLayerTitle": "克隆图层", - "xpack.maps.layerTocActions.editLayerTitle": "编辑图层", - "xpack.maps.layerTocActions.fitToDataTitle": "适应数据", - "xpack.maps.layerTocActions.hideLayerTitle": "隐藏图层", - "xpack.maps.layerTocActions.layerActionsTitle": "图层操作", - "xpack.maps.layerTocActions.noFitSupportTooltip": "图层不支持适应数据", - "xpack.maps.layerTocActions.showLayerTitle": "显示图层", - "xpack.maps.map.initializeErrorTitle": "无法初始化地图", - "xpack.maps.mapController.fullScreenButtonLabel": "全屏", - "xpack.maps.mapController.fullScreenDescription": "全屏", - "xpack.maps.mapController.mapsBreadcrumbLabel": "Maps", - "xpack.maps.mapController.openInspectorButtonLabel": "检查", - "xpack.maps.mapController.openInspectorDescription": "打开检查器", - "xpack.maps.mapController.saveErrorMessage": "保存 “{title}” 时出错", - "xpack.maps.mapController.saveMapButtonLabel": "保存", - "xpack.maps.mapController.saveMapDescription": "保存地图", - "xpack.maps.mapController.saveSuccessMessage": "已保存“{title}”", - "xpack.maps.mapListing.advancedSettingsLinkText": "高级设置", - "xpack.maps.mapListing.cancelTitle": "取消", - "xpack.maps.mapListing.createMapButtonLabel": "创建地图", - "xpack.maps.mapListing.deleteSelectedButtonLabel": "删除选定", - "xpack.maps.mapListing.deleteSelectedItemsTitle": "删除选定项?", - "xpack.maps.mapListing.deleteTitle": "删除", - "xpack.maps.mapListing.deleteWarning": "您无法恢复已删除项。", - "xpack.maps.mapListing.descriptionFieldTitle": "描述", - "xpack.maps.mapListing.limitExceededTitle": "已超过列表限制", - "xpack.maps.mapListing.limitHelpDescription": "您有 {totalItems} 项,但您的 listingLimit 设置阻止下表显示 {listingLimit} 项以上。此设置可在以下选项下更改: ", - "xpack.maps.mapListing.listingTableTitle": "Maps", - "xpack.maps.mapListing.noItemsDescription": "似乎您没有任何地图。单击创建按钮来创建。", - "xpack.maps.mapListing.noMatchDescription": "没有任何项匹配您的搜索。", - "xpack.maps.mapListing.searchAriaLabel": "筛选项", - "xpack.maps.mapListing.searchPlaceholder": "搜索......", - "xpack.maps.mapListing.titleFieldTitle": "标题", - "xpack.maps.mapListing.unableToDeleteToastTitle": "无法删除地图", - "xpack.maps.mapSavedObjectLabel": "地图", - "xpack.maps.metricsEditor.addMetricButtonLabel": "添加指标", - "xpack.maps.metricsEditor.deleteMetricAriaLabel": "删除指标", - "xpack.maps.metricsEditor.deleteMetricButtonLabel": "删除指标", - "xpack.maps.metricsEditor.selectFieldPlaceholder": "选择字段", - "xpack.maps.metricSelect.averageDropDownOptionLabel": "平均值", - "xpack.maps.metricSelect.countDropDownOptionLabel": "计数", - "xpack.maps.metricSelect.maxDropDownOptionLabel": "最大值", - "xpack.maps.metricSelect.minDropDownOptionLabel": "最小值", - "xpack.maps.metricSelect.selectAggregationPlaceholder": "选择聚合", - "xpack.maps.metricSelect.sumDropDownOptionLabel": "和", - "xpack.maps.noIndexPattern.doThisLinkTextDescription": "创建索引模式", - "xpack.maps.noIndexPattern.doThisPrefixDescription": "您将需要 ", - "xpack.maps.noIndexPattern.doThisSuffixDescription": " 使用地理空间字段。", - "xpack.maps.noIndexPattern.getStartedLinkText": "开始使用一些样例数据集。", - "xpack.maps.noIndexPattern.hintDescription": "没有任何地理空间数据集?", - "xpack.maps.noIndexPattern.messageTitle": "找不到任何具有地理空间字段的索引模式", - "xpack.maps.sampleData.ecommerceSpec.mapsTitle": "[电子商务] 订单(按国家/地区)", - "xpack.maps.sampleData.flightaSpec.logsTitle": "[日志] 请求和字节总数", - "xpack.maps.sampleData.flightaSpec.mapsTitle": "[航班] 始发地和到达地航班时间", - "xpack.maps.sampleDataLinkLabel": "地图", - "xpack.maps.source.dataSourceLabel": "数据源", - "xpack.maps.source.ems_xyzDescription": "来自包括 XYZ 坐标的 URL 的地图磁贴", - "xpack.maps.source.ems_xyzTitle": "来自 URL 的磁贴地图服务", - "xpack.maps.source.ems.disabledDescription": "已禁用对 Elastic 地图服务的访问。让您的系统管理员在 kibana.yml 中设置“map.includeElasticMapsService”。", - "xpack.maps.source.ems.noAccessDescription": "Kibana 无法访问 Elastic 地图服务。请联系您的系统管理员", - "xpack.maps.source.emsFile.layerLabel": "图层", - "xpack.maps.source.emsFile.selectPlaceholder": "选择 EMS 矢量形状", - "xpack.maps.source.emsFile.unableToFindIdErrorMessage": "找不到 ID {id} 的 EMS 矢量形状", - "xpack.maps.source.emsFileDescription": "来自 Elastic 地图服务的管理边界的矢量形状", - "xpack.maps.source.emsFileTitle": "矢量形状", - "xpack.maps.source.emsTile.errorMessage": "找不到 ID {id} 的 EMS 磁贴配置", - "xpack.maps.source.emsTile.label": "Tile Service", - "xpack.maps.source.emsTile.serviceId": "Tile Service", - "xpack.maps.source.emsTileDescription": "Elastic 地图服务的地图磁贴", - "xpack.maps.source.emsTileTitle": "磁贴", - "xpack.maps.source.esGeoGrid.geofieldLabel": "地理空间字段", - "xpack.maps.source.esGeoGrid.geofieldPlaceholder": "选择地理字段", - "xpack.maps.source.esGeoGrid.gridRectangleDropdownOption": "网格矩形", - "xpack.maps.source.esGeoGrid.heatmapDropdownOption": "热图", - "xpack.maps.source.esGeoGrid.indexPatternLabel": "索引模式", - "xpack.maps.source.esGeoGrid.indexPatternPlaceholder": "选择索引模式", - "xpack.maps.source.esGeoGrid.pointsDropdownOption": "磅", - "xpack.maps.source.esGeoGrid.showAsLabel": "显示为", - "xpack.maps.source.esGeoGrid.showAsPlaceholder": "选择单个选项", - "xpack.maps.source.esGrid.coarseDropdownOption": "粗糙", - "xpack.maps.source.esGrid.fineDropdownOption": "精致", - "xpack.maps.source.esGrid.finestDropdownOption": "最精致化", - "xpack.maps.source.esGrid.geospatialFieldLabel": "地理空间字段", - "xpack.maps.source.esGrid.indexPatternLabel": "索引模式", - "xpack.maps.source.esGrid.inspectorDescription": "Elasticsearch 地理网格聚合请求", - "xpack.maps.source.esGrid.noIndexPatternErrorMessage": "找不到索引模式 {id}", - "xpack.maps.source.esGrid.resolutionParamErrorMessage": "无法识别网格分辨率参数:{resolution}", - "xpack.maps.source.esGrid.showasFieldLabel": "显示为", - "xpack.maps.source.esGridDescription": "地理空间数据在网格中进行分组,每个网格单元格都具有指标", - "xpack.maps.source.esGridTitle": "网格聚合", - "xpack.maps.source.esJoin.joinDescription": "{description} 的 Elasticsearch 词聚合请求", - "xpack.maps.source.esJoin.joinLeftDescription": "将 {leftSourceName}:{leftFieldName} 联接到", - "xpack.maps.source.esJoin.joinMetricsDescription": "以获取指标 {metrics}", - "xpack.maps.source.esSearch.convertToGeoJsonErrorMsg": "无法将搜索响应转换成 geoJson 功能集合,错误:{errorMsg}", - "xpack.maps.source.esSearch.disableFilterByMapBoundsExplainMsg": "索引“{indexPatternTitle}”具有很少数量的文档,不需要动态筛选。", - "xpack.maps.source.esSearch.disableFilterByMapBoundsTitle": "动态数据筛选已禁用", - "xpack.maps.source.esSearch.disableFilterByMapBoundsTurnOnMsg": "如果预期文档数量会增加,请打开动态筛选。", - "xpack.maps.source.esSearch.extentFilterLabel": "在可见地图区域中动态筛留数据", - "xpack.maps.source.esSearch.geofieldLabel": "地理空间字段", - "xpack.maps.source.esSearch.geoFieldLabel": "地理空间字段", - "xpack.maps.source.esSearch.geoFieldTypeLabel": "地理空间字段类型", - "xpack.maps.source.esSearch.indexPatternLabel": "索引模式", - "xpack.maps.source.esSearch.loadErrorMessage": "找不到索引模式 {id}", - "xpack.maps.source.esSearch.loadTooltipPropertiesErrorMsg": "找不到文档,_id:{docId}", - "xpack.maps.source.esSearch.selectIndexPatternPlaceholder": "选择索引模式", - "xpack.maps.source.esSearch.selectLabel": "选择地理字段", - "xpack.maps.source.esSearch.topHitsSizeLabel": "每个实体的文档", - "xpack.maps.source.esSearch.topHitsSplitFieldLabel": "实体", - "xpack.maps.source.esSearch.topHitsSplitFieldSelectPlaceholder": "选择实体字段", - "xpack.maps.source.esSearch.useTopHitsLabel": "按实体显示最近的文档", - "xpack.maps.source.esSearchDescription": "Kibana 索引模式的地理空间数据", - "xpack.maps.source.esSearchTitle": "文档", - "xpack.maps.source.esSource.noGeoFieldErrorMessage": "索引模式“{indexPatternTitle}”不再包含地理字段 {geoField}", - "xpack.maps.source.esSource.noIndexPatternErrorMessage": "找不到 ID {indexPatternId} 的索引模式", - "xpack.maps.source.esSource.requestFailedErrorMessage": "Elasticsearch 搜索请求失败,错误:{message}", - "xpack.maps.source.kbnRegionMap.noConfigErrorMessage": "找不到 {name} 的 map.regionmap 配置", - "xpack.maps.source.kbnRegionMap.noLayerAvailableHelptext": "没有可用的矢量图层。让您的系统管理员在 kibana.yml 中设置“map.regionmap”。", - "xpack.maps.source.kbnRegionMap.vectorLayerLabel": "矢量图层", - "xpack.maps.source.kbnRegionMapDescription": "来自 kibana.yml 配置的静态文件的矢量形状", - "xpack.maps.source.kbnRegionMapTitle": "定制矢量形状", - "xpack.maps.source.kbnTMS.kbnTMS.urlLabel": "磁贴地图 URL", - "xpack.maps.source.kbnTMS.noConfigErrorMessage": "在 kibana.yml 中找不到 map.tilemap.url 配置", - "xpack.maps.source.kbnTMS.noLayerAvailableHelptext": "没有可用的磁贴地图图层。让您的系统管理员在 kibana.yml 中设置“map.tilemap.url”。", - "xpack.maps.source.kbnTMS.urlLabel": "磁贴地图 URL", - "xpack.maps.source.kbnTMSDescription": "在 kibana.yml 中配置的地图磁贴", - "xpack.maps.source.kbnTMSTitle": "定制磁贴地图服务", - "xpack.maps.source.urlLabel": "URL", - "xpack.maps.source.vetorSource.formatErrorMessage": "无法从以下 URL 获取矢量形状:{format}", - "xpack.maps.source.vetorSource.requestFailedErrorMessage": "无法从以下 URL 获取矢量形状:{fetchUrl}", - "xpack.maps.source.wms.getCapabilitiesButtonText": "加载功能", - "xpack.maps.source.wms.getCapabilitiesErrorCalloutTitle": "无法加载服务元数据", - "xpack.maps.source.wms.layersHelpText": "使用图层名称逗号分隔列表", - "xpack.maps.source.wms.layersLabel": "图层", - "xpack.maps.source.wms.stylesHelpText": "使用样式名称逗号分隔列表", - "xpack.maps.source.wms.stylesLabel": "样式", - "xpack.maps.source.wms.urlLabel": "URL", - "xpack.maps.source.wmsDescription": "来自 OGC 标准 WMS 的地图", - "xpack.maps.source.wmsTitle": "Web 地图服务", - "xpack.maps.style.heatmap.displayNameLabel": "热图样式", - "xpack.maps.style.heatmap.resolutionStyleErrorMessage": "无法识别分辨率参数:{resolution}", - "xpack.maps.styles.vector.borderColorLabel": "边框颜色", - "xpack.maps.styles.vector.borderWidthLabel": "边框宽度", - "xpack.maps.styles.vector.fillColorLabel": "填充颜色", - "xpack.maps.styles.vector.selectFieldPlaceholder": "选择字段", - "xpack.maps.styles.vector.symbolSizeLabel": "符号大小", - "xpack.maps.toolbarOverlay.drawBoundsLabel": "绘制边界以筛选数据", - "xpack.maps.toolbarOverlay.drawShapeLabel": "绘制形状以筛选数据", - "xpack.maps.toolbarOverlay.tools.toolbarTitle": "工具", - "xpack.maps.tooltip.closeAriaLabel": "关闭工具提示", - "xpack.maps.tooltip.filterOnPropertyAriaLabel": "基于属性筛选", - "xpack.maps.tooltip.filterOnPropertyTitle": "基于属性筛选", - "xpack.maps.tooltip.loadingMsg": "正在加载", - "xpack.maps.tooltip.unableToLoadContentTitle": "无法加载工具提示内容", - "xpack.maps.validatedRange.rangeErrorMessage": "必须介于 {min} 和 {max} 之间", - "xpack.maps.vector.symbolAs.circleLabel": "圆", - "xpack.maps.vector.symbolAs.IconLabel": "图标", - "xpack.maps.vector.symbolLabel": "符号", - "xpack.maps.vectorLayer.noResultsFoundTooltip": "找不到结果", - "xpack.maps.vectorStyleEditor.featureTypeButtonGroupLegend": "矢量功能按钮组", - "xpack.maps.vectorStyleEditor.lineLabel": "线", - "xpack.maps.vectorStyleEditor.pointLabel": "Points", - "xpack.maps.vectorStyleEditor.polygonLabel": "多边形", - "xpack.maps.viewControl.latLabel": "纬度:", - "xpack.maps.viewControl.lonLabel": "经度:", - "xpack.maps.common.esSpatialRelation.containsLabel": "contains", - "xpack.maps.common.esSpatialRelation.disjointLabel": "disjoint", - "xpack.maps.common.esSpatialRelation.intersectsLabel": "intersects", - "xpack.maps.common.esSpatialRelation.withinLabel": "within", - "xpack.maps.drawTooltip.boundsInstructions": "单击可开始绘制矩形。再次单击以完成。", - "xpack.maps.drawTooltip.polygonInstructions": "单击以添加顶点。双击以完成。", - "xpack.maps.embeddableDisplayName": "地图", - "xpack.maps.es_geo_utils.convert.unsupportedGeometryTypeErrorMessage": "无法将 {geometryType} 几何图形转换成 geojson,不支持", - "xpack.maps.es_geo_utils.shapeFilter.geoPointRelationLabel": "传入", - "xpack.maps.es_geo_utils.unsupportedFieldTypeErrorMessage": "字段类型不受支持,应为 {expectedTypes},而提供的是 {fieldType}", - "xpack.maps.es_geo_utils.unsupportedGeometryTypeErrorMessage": "几何类型不受支持,应为 {expectedTypes},而提供的是 {geometryType}", - "xpack.maps.es_geo_utils.wkt.invalidWKTErrorMessage": "无法将 {wkt} 转换成 geojson。需要有效的 WKT。", - "xpack.maps.geometryFilterForm.geoFieldLabel": "已筛选字段", - "xpack.maps.geometryFilterForm.geometryLabelLabel": "几何标签", - "xpack.maps.geometryFilterForm.relationLabel": "空间关系", - "xpack.maps.layer.isUsingSearchMsg": "通过搜索栏缩减的结果", - "xpack.maps.mapController.unsavedChangesWarning": "可能不会保存您未保存的更改", - "xpack.maps.mapEmbeddableFactory.invalidLayerList": "无法加载地图,图层列表格式不正确", - "xpack.maps.mapEmbeddableFactory.invalidSavedObject": "无法加载地图,已保存对象格式错误", - "xpack.maps.setViewControl.goToButtonLabel": "前往", - "xpack.maps.setViewControl.latitudeLabel": "纬度", - "xpack.maps.setViewControl.longitudeLabel": "经度", - "xpack.maps.setViewControl.submitButtonLabel": "Go", - "xpack.maps.setViewControl.zoomLabel": "缩放", - "xpack.maps.source.emsTile.autoLabel": "基于 Kibana 主题自动选择", - "xpack.maps.source.emsTile.isAutoSelectLabel": "基于 Kibana 主题自动选择", - "xpack.maps.source.geojsonFileDescription": "在 Elasticsearch 上传 GeoJSON 文件和索引", - "xpack.maps.source.geojsonFileTitle": "上传 GeoJSON 矢量文件", - "xpack.maps.source.pewPew.destGeoFieldLabel": "目标", - "xpack.maps.source.pewPew.destGeoFieldPlaceholder": "选择目标地理位置字段", - "xpack.maps.source.pewPew.indexPatternLabel": "索引模式", - "xpack.maps.source.pewPew.indexPatternPlaceholder": "选择索引模式", - "xpack.maps.source.pewPew.inspectorDescription": "源-目标连接请求", - "xpack.maps.source.pewPew.metricsLabel": "指标", - "xpack.maps.source.pewPew.noIndexPatternErrorMessage": "找不到索引模式 {id}", - "xpack.maps.source.pewPew.noSourceAndDestDetails": "选定的索引模式不包含源和目标字段。", - "xpack.maps.source.pewPew.sourceGeoFieldLabel": "源", - "xpack.maps.source.pewPew.sourceGeoFieldPlaceholder": "选择源地理位置字段", - "xpack.maps.source.pewPewDescription": "源和目标之间的聚合数据路径", - "xpack.maps.source.pewPewTitle": "源-目标连接", - "xpack.maps.source.wms.attributionLink": "属性文本必须附带链接", - "xpack.maps.source.wms.attributionText": "属性 url 必须附带文本", - "xpack.maps.style.customColorRampLabel": "定制颜色渐变", - "xpack.maps.toolbarOverlay.drawBounds.initialGeometryLabel": "边界", - "xpack.maps.toolbarOverlay.drawShape.initialGeometryLabel": "形状", - "xpack.maps.tooltip.geometryFilterForm.createFilterButtonLabel": "创建筛选", - "xpack.maps.tooltip.pageNumerText": "{total} 的 {pageNumber}", - "xpack.maps.tooltip.showGeometryFilterViewLinkLabel": "按几何筛选", - "xpack.maps.tooltip.toolsControl.cancelDrawButtonLabel": "取消", - "xpack.maps.xyztmssource.attributionLink": "属性文本必须附带链接", - "xpack.maps.xyztmssource.attributionText": "属性 url 必须附带文本", - "xpack.maps.layerPanel.settingsPanel.percentageLabel": "%", - "xpack.maps.layerPanel.settingsPanel.visibleZoom": "缩放级别", - "xpack.maps.source.esSearch.sortFieldSelectPlaceholder": "选择排序字段", - "xpack.maps.toolbarOverlay.drawBoundsLabelShort": "绘制边界", - "xpack.maps.toolbarOverlay.drawShapeLabelShort": "绘制形状", - "xpack.maps.tooltipSelector.addLabelWithCount": "添加 {count} 个", - "xpack.maps.tooltipSelector.addLabelWithoutCount": "添加", - "xpack.maps.tooltipSelector.grabButtonAriaLabel": "重新排序属性", - "xpack.maps.tooltipSelector.grabButtonTitle": "重新排序属性", - "xpack.maps.tooltipSelector.togglePopoverLabel": "添加", - "xpack.maps.tooltipSelector.trashButtonAriaLabel": "移除属性", - "xpack.maps.tooltipSelector.trashButtonTitle": "移除属性", - "xpack.maps.vector.dualSize.unitLabel": "px", - "xpack.maps.vector.size.unitLabel": "px", - "xpack.ml.annotationsTable.actionsColumnName": "操作", - "xpack.ml.annotationsTable.annotationColumnName": "注释", - "xpack.ml.annotationsTable.annotationsNotCreatedTitle": "没有为此作业创建注释", - "xpack.ml.annotationsTable.editAnnotationsTooltip": "编辑注释", - "xpack.ml.annotationsTable.editAnnotationsTooltipAriaLabel": "编辑注释", - "xpack.ml.annotationsTable.fromColumnName": "从", - "xpack.ml.annotationsTable.howToCreateAnnotationDescription": "要创建注释,请打开 {linkToSingleMetricView}", - "xpack.ml.annotationsTable.howToCreateAnnotationDescription.singleMetricViewerLinkText": "Single Metric Viewer", - "xpack.ml.annotationsTable.jobConfigurationNotSupportedInSingleMetricViewerAriaLabel": "Single Metric Viewer 中不支持作业配置", - "xpack.ml.annotationsTable.jobConfigurationNotSupportedInSingleMetricViewerTooltip": "Single Metric Viewer 中不支持作业配置", - "xpack.ml.annotationsTable.jobIdColumnName": "作业 ID", - "xpack.ml.annotationsTable.labelColumnName": "标签", - "xpack.ml.annotationsTable.lastModifiedByColumnName": "上次修改者", - "xpack.ml.annotationsTable.lastModifiedDateColumnName": "上次修改日期", - "xpack.ml.annotationsTable.openInSingleMetricViewerAriaLabel": "在 Single Metric Viewer 中打开", - "xpack.ml.annotationsTable.openInSingleMetricViewerTooltip": "在 Single Metric Viewer 中打开", - "xpack.ml.annotationsTable.toColumnName": "到", - "xpack.ml.anomaliesTable.actionsColumnName": "操作", - "xpack.ml.anomaliesTable.actualSortColumnName": "实际", - "xpack.ml.anomaliesTable.anomalyDetails.actualTitle": "实际", - "xpack.ml.anomaliesTable.anomalyDetails.anomalyDescriptionListMoreLinkText": "及另外 {othersCount} 个", - "xpack.ml.anomaliesTable.anomalyDetails.anomalyDescriptionShowLessLinkText": "显示更少", - "xpack.ml.anomaliesTable.anomalyDetails.anomalyDetailsTitle": "异常详情", - "xpack.ml.anomaliesTable.anomalyDetails.anomalyInLabel": "{anomalyDetector} 中的 {anomalySeverity} 异常", - "xpack.ml.anomaliesTable.anomalyDetails.anomalyTimeRangeLabel": "{anomalyTime} 至 {anomalyEndTime}", - "xpack.ml.anomaliesTable.anomalyDetails.categoryExamplesTitle": "类别示例", - "xpack.ml.anomaliesTable.anomalyDetails.causeValuesDescription": "{causeEntityValue}实际 {actualValue}典型 {typicalValue}可能性 {probabilityValue}", - "xpack.ml.anomaliesTable.anomalyDetails.causeValuesTitle": "{causeEntityName} 值", - "xpack.ml.anomaliesTable.anomalyDetails.descriptionTitle": "描述", - "xpack.ml.anomaliesTable.anomalyDetails.detailsOnHighestSeverityAnomalyTitle": "有关最高严重性异常的详情", - "xpack.ml.anomaliesTable.anomalyDetails.detailsTitle": "详情", - "xpack.ml.anomaliesTable.anomalyDetails.detectedInLabel": " 在 {sourcePartitionFieldName} {sourcePartitionFieldValue} 检测到", - "xpack.ml.anomaliesTable.anomalyDetails.examplesTitle": "示例", - "xpack.ml.anomaliesTable.anomalyDetails.fieldNameTitle": "fieldName", - "xpack.ml.anomaliesTable.anomalyDetails.foundForLabel": " 已为 {anomalyEntityName} {anomalyEntityValue} 找到", - "xpack.ml.anomaliesTable.anomalyDetails.functionTitle": "函数", - "xpack.ml.anomaliesTable.anomalyDetails.influencersTitle": "影响因素", - "xpack.ml.anomaliesTable.anomalyDetails.interimResultLabel": "中间结果", - "xpack.ml.anomaliesTable.anomalyDetails.jobIdTitle": "作业 ID", - "xpack.ml.anomaliesTable.anomalyDetails.multiBucketImpactTitle": "多存储桶影响", - "xpack.ml.anomaliesTable.anomalyDetails.multivariateDescription": "{sourceByFieldName} 中找到多变量关联;如果{sourceCorrelatedByFieldValue},{sourceByFieldValue} 将被视为有异常", - "xpack.ml.anomaliesTable.anomalyDetails.probabilityTitle": "可能性", - "xpack.ml.anomaliesTable.anomalyDetails.regexDescriptionAriaLabel": "描述", - "xpack.ml.anomaliesTable.anomalyDetails.regexDescriptionTooltip": "用于搜索匹配该类别的值(可能已截短至最大字符限制 {maxChars})的正则表达式", - "xpack.ml.anomaliesTable.anomalyDetails.regexTitle": "Regex", - "xpack.ml.anomaliesTable.anomalyDetails.termsDescriptionAriaLabel": "描述", - "xpack.ml.anomaliesTable.anomalyDetails.termsDescriptionTooltip": "该类别的值(可能已截短至最大字符限制({maxChars})中匹配的常见令牌的空格分隔列表", - "xpack.ml.anomaliesTable.anomalyDetails.termsTitle": "词", - "xpack.ml.anomaliesTable.anomalyDetails.timeTitle": "时间", - "xpack.ml.anomaliesTable.anomalyDetails.typicalTitle": "典型", - "xpack.ml.anomaliesTable.categoryExamplesColumnName": "类别示例", - "xpack.ml.anomaliesTable.detectorCell.rulesConfiguredTooltip": "个规则已为此检测工具配置", - "xpack.ml.anomaliesTable.detectorColumnName": "检测工具", - "xpack.ml.anomaliesTable.entityCell.addFilterAriaLabel": "添加筛选", - "xpack.ml.anomaliesTable.entityCell.addFilterTooltip": "添加筛选", - "xpack.ml.anomaliesTable.entityCell.removeFilterAriaLabel": "删除筛选", - "xpack.ml.anomaliesTable.entityCell.removeFilterTooltip": "删除筛选", - "xpack.ml.anomaliesTable.entityValueColumnName": "查找对象", - "xpack.ml.anomaliesTable.hideDetailsAriaLabel": "隐藏详情", - "xpack.ml.anomaliesTable.influencersCell.addFilterAriaLabel": "添加筛选", - "xpack.ml.anomaliesTable.influencersCell.addFilterTooltip": "添加筛选", - "xpack.ml.anomaliesTable.influencersCell.moreInfluencersLinkText": "及另外 {othersCount} 个", - "xpack.ml.anomaliesTable.influencersCell.removeFilterAriaLabel": "删除筛选", - "xpack.ml.anomaliesTable.influencersCell.removeFilterTooltip": "删除筛选", - "xpack.ml.anomaliesTable.influencersCell.showLessInfluencersLinkText": "显示更少", - "xpack.ml.anomaliesTable.influencersColumnName": "影响因素", - "xpack.ml.anomaliesTable.jobIdColumnName": "作业 ID", - "xpack.ml.anomaliesTable.linksMenu.configureRulesLabel": "配置规则", - "xpack.ml.anomaliesTable.linksMenu.loadingDetailsErrorMessage": "无法查看示例,因为加载有关类别 ID {categoryId} 的详细信息时出错", - "xpack.ml.anomaliesTable.linksMenu.noMappingCouldBeFoundErrorMessage": "无法查看 mlcategory 为 {categoryId} 的文档的示例,因为找不到分类字段 {categorizationFieldName} 的映射", - "xpack.ml.anomaliesTable.linksMenu.selectActionAriaLabel": "为 {time} 的异常选择操作", - "xpack.ml.anomaliesTable.linksMenu.unableToOpenLinkErrorMessage": "无法打开链接,因为加载有关类别 ID {categoryId} 的详细信息时出错", - "xpack.ml.anomaliesTable.linksMenu.unableToViewExamplesErrorMessage": "无法查看示例,因为未找到作业 ID {jobId} 的详细信息", - "xpack.ml.anomaliesTable.linksMenu.viewExamplesLabel": "查看示例", - "xpack.ml.anomaliesTable.linksMenu.viewSeriesLabel": "查看序列", - "xpack.ml.anomaliesTable.metricDescriptionSortColumnName": "描述", - "xpack.ml.anomaliesTable.noMatchingAnomaliesFoundTitle": "未找到任何匹配的异常", - "xpack.ml.anomaliesTable.severityColumnName": "严重性", - "xpack.ml.anomaliesTable.showDetailsAriaLabel": "显示详情", - "xpack.ml.anomaliesTable.timeColumnName": "时间", - "xpack.ml.anomaliesTable.typicalSortColumnName": "典型", - "xpack.ml.anomalyExplorerPageLabel": "Anomaly Explorer", - "xpack.ml.anomalyUtils.multiBucketImpact.highLabel": "高", - "xpack.ml.anomalyUtils.multiBucketImpact.lowLabel": "低", - "xpack.ml.anomalyUtils.multiBucketImpact.mediumLabel": "中", - "xpack.ml.anomalyUtils.multiBucketImpact.noneLabel": "无", - "xpack.ml.anomalyUtils.severity.criticalLabel": "紧急", - "xpack.ml.anomalyUtils.severity.majorLabel": "重大", - "xpack.ml.anomalyUtils.severity.minorLabel": "轻微", - "xpack.ml.anomalyUtils.severity.unknownLabel": "未知", - "xpack.ml.anomalyUtils.severity.warningLabel": "警告", - "xpack.ml.anomalyUtils.severityWithLow.lowLabel": "低", - "xpack.ml.calendarsEdit.calendarForm.allowedCharactersDescription": "使用小写字母数字(a-z 和 0-9)、连字符或下划线;必须以字母数字字符开头和结尾", - "xpack.ml.calendarsEdit.calendarForm.calendarIdLabel": "日历 ID", - "xpack.ml.calendarsEdit.calendarForm.calendarTitle": "日历 {calendarId}", - "xpack.ml.calendarsEdit.calendarForm.cancelButtonLabel": "取消", - "xpack.ml.calendarsEdit.calendarForm.createCalendarTitle": "创建新日历", - "xpack.ml.calendarsEdit.calendarForm.descriptionLabel": "描述", - "xpack.ml.calendarsEdit.calendarForm.eventsLabel": "事件", - "xpack.ml.calendarsEdit.calendarForm.groupsLabel": "组", - "xpack.ml.calendarsEdit.calendarForm.jobsLabel": "作业", - "xpack.ml.calendarsEdit.calendarForm.saveButtonLabel": "保存", - "xpack.ml.calendarsEdit.calendarForm.savingButtonLabel": "正在保存……", - "xpack.ml.calendarsEdit.canNotCreateCalendarWithExistingIdErrorMessag": "无法创建 ID 为 [{formCalendarId}] 的日历,因为它已经存在。", - "xpack.ml.calendarsEdit.errorWithCreatingCalendarErrorMessage": "创建日历 {calendarId} 时出错", - "xpack.ml.calendarsEdit.errorWithFetchingJobSummariesErrorMessage": "提取作业摘要时出错:{err}", - "xpack.ml.calendarsEdit.errorWithLoadingCalendarFromDataErrorMessage": "加载日历表单数据时出错。请尝试刷新页面。", - "xpack.ml.calendarsEdit.errorWithLoadingCalendarsErrorMessage": "加载日历时出错:{err}", - "xpack.ml.calendarsEdit.errorWithLoadingGroupsErrorMessage": "加载组时出错:{err}", - "xpack.ml.calendarsEdit.errorWithUpdatingCalendarErrorMessage": "保存日历 {calendarId} 时出错。请尝试刷新页面。", - "xpack.ml.calendarsEdit.eventsTable.cancelButtonLabel": "取消", - "xpack.ml.calendarsEdit.eventsTable.deleteButtonLabel": "删除", - "xpack.ml.calendarsEdit.eventsTable.descriptionColumnName": "描述", - "xpack.ml.calendarsEdit.eventsTable.endColumnName": "结束", - "xpack.ml.calendarsEdit.eventsTable.importButtonLabel": "导入", - "xpack.ml.calendarsEdit.eventsTable.importEventsButtonLabel": "导入事件", - "xpack.ml.calendarsEdit.eventsTable.importEventsDescription": "从 ICS 文件导入事件。", - "xpack.ml.calendarsEdit.eventsTable.importEventsTitle": "导入事件", - "xpack.ml.calendarsEdit.eventsTable.newEventButtonLabel": "新建事件", - "xpack.ml.calendarsEdit.eventsTable.startColumnName": "开始", - "xpack.ml.calendarsEdit.importedEvents.eventsToImportTitle": "要导入的事件:{eventsCount}", - "xpack.ml.calendarsEdit.importedEvents.includePastEventsLabel": "包含过去的事件", - "xpack.ml.calendarsEdit.importedEvents.recurringEventsNotSupportedDescription": "不支持重复事件。仅导入第一个事件。", - "xpack.ml.calendarsEdit.importModal.couldNotParseICSFileErrorMessage": "无法解析 ICS 文件。", - "xpack.ml.calendarsEdit.importModal.selectOrDragAndDropFilePromptText": "选择或拖放文件", - "xpack.ml.calendarsEdit.newEventModal.addButtonLabel": "添加", - "xpack.ml.calendarsEdit.newEventModal.cancelButtonLabel": "取消", - "xpack.ml.calendarsEdit.newEventModal.createNewEventTitle": "创建新事件", - "xpack.ml.calendarsEdit.newEventModal.descriptionLabel": "描述", - "xpack.ml.calendarsEdit.newEventModal.endDateAriaLabel": "结束日期", - "xpack.ml.calendarsEdit.newEventModal.fromLabel": "从:", - "xpack.ml.calendarsEdit.newEventModal.startDateAriaLabel": "开始日期", - "xpack.ml.calendarsEdit.newEventModal.toLabel": "到:", - "xpack.ml.calendarsList.deleteCalendars.calendarsLabel": "{calendarsToDeleteCount} 个日历", - "xpack.ml.calendarsList.deleteCalendars.deletingCalendarErrorMessage": "删除日历 {calendarId} 时出错。{errorMessage}", - "xpack.ml.calendarsList.deleteCalendars.deletingCalendarsNotificationMessage": "正在删除 {messageId}", - "xpack.ml.calendarsList.deleteCalendars.deletingCalendarSuccessNotificationMessage": "已删除 {messageId}", - "xpack.ml.calendarsList.deleteCalendarsModal.cancelButtonLabel": "取消", - "xpack.ml.calendarsList.deleteCalendarsModal.deleteButtonLabel": "删除", - "xpack.ml.calendarsList.deleteCalendarsModal.deleteCalendarsDescription": "是否删除{calendarsCount, plural, one {此日历} other {这些日历}}?{calendarsList}", - "xpack.ml.calendarsList.deleteCalendarsModal.deleteCalendarTitle": "删除日历", - "xpack.ml.calendarsList.errorWithLoadingListOfCalendarsErrorMessage": "加载日历列表时出错。", - "xpack.ml.calendarsList.table.deleteButtonLabel": "删除", - "xpack.ml.calendarsList.table.eventsColumnName": "事件", - "xpack.ml.calendarsList.table.eventsCountLabel": "{eventsLength, plural, one {# 个事件} other {# 个事件}}", - "xpack.ml.calendarsList.table.idColumnName": "ID", - "xpack.ml.calendarsList.table.jobsColumnName": "作业", - "xpack.ml.calendarsList.table.newButtonLabel": "新建", - "xpack.ml.checkLicense.licenseHasExpiredMessage": "您的 {licenseTypeName} Machine Learning 许可证已过期。", - "xpack.ml.checkLicense.licenseInformationNotAvailableThisTimeMessage": "您不能使用 Machine Learning,因为许可证信息当前不可用。", - "xpack.ml.checkLicense.mlIsUnavailableMessage": "Machine Learning 不可用", - "xpack.ml.controls.checkboxShowCharts.showChartsCheckboxLabel": "显示图表", - "xpack.ml.controls.selectInterval.autoLabel": "自动", - "xpack.ml.controls.selectInterval.dayLabel": "1 天", - "xpack.ml.controls.selectInterval.hourLabel": "1 小时", - "xpack.ml.controls.selectInterval.showAllLabel": "全部显示", - "xpack.ml.controls.selectSeverity.criticalLabel": "紧急", - "xpack.ml.controls.selectSeverity.majorLabel": "重大", - "xpack.ml.controls.selectSeverity.minorLabel": "轻微", - "xpack.ml.controls.selectSeverity.scoreDetailsDescription": "分数 {value} 及以上", - "xpack.ml.controls.selectSeverity.warningLabel": "警告", - "xpack.ml.customUrlEditor.discoverLabel": "Discover", - "xpack.ml.customUrlEditor.kibanaDashboardLabel": "Kibana 仪表板", - "xpack.ml.customUrlEditor.otherLabel": "其他", - "xpack.ml.customUrlEditorList.deleteCustomUrlAriaLabel": "删除定制 URL", - "xpack.ml.customUrlEditorList.deleteCustomUrlTooltip": "删除定制 URL", - "xpack.ml.customUrlEditorList.invalidTimeRangeFormatErrorMessage": "格式无效", - "xpack.ml.customUrlEditorList.labelIsNotUniqueErrorMessage": "必须提供唯一的标签", - "xpack.ml.customUrlEditorList.labelLabel": "标签", - "xpack.ml.customUrlEditorList.obtainingUrlToTestConfigurationErrorMessage": "获取 URL 用于测试配置时出错", - "xpack.ml.customUrlEditorList.testCustomUrlAriaLabel": "测试定制 URL", - "xpack.ml.customUrlEditorList.testCustomUrlTooltip": "测试定制 URL", - "xpack.ml.customUrlEditorList.timeRangeLabel": "时间范围", - "xpack.ml.customUrlEditorList.urlLabel": "URL", - "xpack.ml.customUrlsEditor.createNewCustomUrlTitle": "新建定制 URL", - "xpack.ml.customUrlsEditor.dashboardNameLabel": "仪表板名称", - "xpack.ml.customUrlsEditor.indexPatternLabel": "索引模式", - "xpack.ml.customUrlsEditor.intervalLabel": "时间间隔", - "xpack.ml.customUrlsEditor.invalidLabelErrorMessage": "必须提供唯一的标签", - "xpack.ml.customUrlsEditor.labelLabel": "标签", - "xpack.ml.customUrlsEditor.linkToLabel": "链接到", - "xpack.ml.customUrlsEditor.queryEntitiesLabel": "查询实体", - "xpack.ml.customUrlsEditor.selectEntitiesPlaceholder": "选择实体", - "xpack.ml.customUrlsEditor.timeRangeLabel": "时间范围", - "xpack.ml.customUrlsEditor.urlLabel": "URL", - "xpack.ml.customUrlsList.invalidIntervalFormatErrorMessage": "时间间隔格式无效", - "xpack.ml.datavisualizer.selector.dataVisualizerDescription": "Machine Learning Data Visualizer 工具通过分析日志文件或现有 Elasticsearch 索引中的指标和字段,帮助您理解数据。", - "xpack.ml.datavisualizer.selector.dataVisualizerTitle": "数据可视化工具", - "xpack.ml.datavisualizer.selector.experimentalBadgeLabel": "实验性", - "xpack.ml.datavisualizer.selector.experimentalBadgeTooltipLabel": "实验功能。我们很乐意听取您的反馈意见。", - "xpack.ml.datavisualizer.selector.importDataDescription": "从日志文件导入数据。您可以上传最大 100 MB 的文件。", - "xpack.ml.datavisualizer.selector.importDataTitle": "导入数据", - "xpack.ml.datavisualizer.selector.selectIndexButtonLabel": "选择索引", - "xpack.ml.datavisualizer.selector.selectIndexPatternDescription": "可视化现有 Elasticsearch 索引中的数据。", - "xpack.ml.datavisualizer.selector.selectIndexPatternTitle": "选择索引模式", - "xpack.ml.datavisualizer.selector.startTrialButtonLabel": "开始试用", - "xpack.ml.datavisualizer.selector.startTrialTitle": "开始试用", - "xpack.ml.datavisualizer.selector.uploadFileButtonLabel": "上传文件", - "xpack.ml.dataVisualizerPageLabel": "数据可视化工具", - "xpack.ml.explorer.annotationsTitle": "注释", - "xpack.ml.explorer.anomaliesTitle": "异常", - "xpack.ml.explorer.anomalyTimelineTitle": "异常时间线", - "xpack.ml.explorer.charts.detectorLabel": "{detectorLabel}{br}y 轴事件分布按 “{fieldName}” 分割", - "xpack.ml.explorer.charts.infoTooltip.aggregationIntervalTitle": "聚合时间间隔", - "xpack.ml.explorer.charts.infoTooltip.chartEventDistributionDescription": "灰点表示 {byFieldValuesParam} 的样例随时间发生的近似分布情况,其中顶部的事件类型较频繁,底部的事件类型较少。", - "xpack.ml.explorer.charts.infoTooltip.chartFunctionTitle": "图表功能", - "xpack.ml.explorer.charts.infoTooltip.chartPopulationDistributionDescription": "灰点表示 {overFieldValuesParam} 样例的值随时间的近似分布。", - "xpack.ml.explorer.charts.infoTooltip.jobIdTitle": "作业 ID", - "xpack.ml.explorer.charts.openInSingleMetricViewerButtonLabel": "在 Single Metric Viewer 中打开", - "xpack.ml.explorer.charts.tooManyBucketsDescription": "此选项包含太多要显示的时段。最好设置一个较短的时间范围来查看仪表板。", - "xpack.ml.explorer.charts.viewLabel": "查看", - "xpack.ml.explorer.createNewJobLinkText": "创建新作业", - "xpack.ml.explorer.fetchingSuggestionsErrorMessage": "获取建议时出错", - "xpack.ml.explorer.intervalLabel": "时间间隔", - "xpack.ml.explorer.invalidKuerySyntaxErrorMessage": "kuery 语法无效", - "xpack.ml.explorer.invalidKuerySyntaxErrorMessageFromTable": "查询栏中的语法无效。输入必须是有效的 Kibana 查询语言 (KQL)", - "xpack.ml.explorer.jobIdLabel": "作业 ID", - "xpack.ml.explorer.jobScoreAcrossAllInfluencersLabel": "(所有影响因素的作业分数)", - "xpack.ml.explorer.kueryBar.filterPlaceholder": "按影响因素字段筛选……({queryExample})", - "xpack.ml.explorer.limitLabel": "限制", - "xpack.ml.explorer.loadingLabel": "正在加载", - "xpack.ml.explorer.noConfiguredInfluencersTooltip": "“顶级影响因素”列表被隐藏,因为没有为所选作业配置影响因素。", - "xpack.ml.explorer.noInfluencersFoundTitle": "找不到 {viewBySwimlaneFieldName} 影响因素", - "xpack.ml.explorer.noInfluencersFoundTitleFilterMessage": "找不到指定筛选的 {viewBySwimlaneFieldName} 影响因素", - "xpack.ml.explorer.noJobsFoundLabel": "找不到作业", - "xpack.ml.explorer.noResultsFoundLabel": "找不到结果", - "xpack.ml.explorer.overallLabel": "总体", - "xpack.ml.explorer.overallSwimlaneUnfilteredLabel": "{label}(未筛选)", - "xpack.ml.explorer.severityThresholdLabel": "严重性阈值", - "xpack.ml.explorer.sortedByMaxAnomalyScoreForTimeFormattedLabel": "(按 {viewByLoadedForTimeFormatted} 的异常分数最大值排序)", - "xpack.ml.explorer.sortedByMaxAnomalyScoreLabel": "(按异常分数最大值排序)", - "xpack.ml.explorer.topInfuencersTitle": "顶级影响因素", - "xpack.ml.explorer.tryWideningTimeSelectionLabel": "请尝试扩大时间选择范围或进一步向前追溯", - "xpack.ml.explorer.viewByLabel": "查看者", - "xpack.ml.feature.reserved.description": "要向用户授予访问权限,还应分配 machine_learning_user 或 machine_learning_admin 角色。", - "xpack.ml.featureRegistry.mlFeatureName": "机器学习", - "xpack.ml.fieldDataCard.cardBoolean.valuesLabel": "值", - "xpack.ml.fieldDataCard.cardDocumentCount.calculatedOverAllDocumentsLabel": "计算所有文档", - "xpack.ml.fieldDataCard.cardIp.topValuesLabel": "排在前面的值", - "xpack.ml.fieldDataCard.cardKeyword.topValuesLabel": "排在前面的值", - "xpack.ml.fieldDataCard.cardNumber.details.distributionOfValuesLabel": "值分布", - "xpack.ml.fieldDataCard.cardNumber.details.topValuesLabel": "排在前面的值", - "xpack.ml.fieldDataCard.cardNumber.maxLabel": "最大值", - "xpack.ml.fieldDataCard.cardNumber.medianLabel": "中值", - "xpack.ml.fieldDataCard.cardNumber.minLabel": "最小值", - "xpack.ml.fieldDataCard.cardOther.cardTypeLabel": "{cardType} 类型", - "xpack.ml.fieldDataCard.cardText.fieldMayBePopulatedDescription": "例如,可以使用文档映射中的 {copyToParam} 参数进行填充,也可以在索引后通过使用 {includesParam} 和 {excludesParam} 参数从 {sourceParam} 字段中进行剪裁。", - "xpack.ml.fieldDataCard.loadingLabel": "正在加载", - "xpack.ml.fieldTitleBar.documentCountLabel": "文档计数", - "xpack.ml.fieldTypeIcon.booleanTypeAriaLabel": "布尔类型", - "xpack.ml.fieldTypeIcon.dateTypeAriaLabel": "日期类型", - "xpack.ml.fieldTypeIcon.fieldTypeTooltip": "{type} 类型", - "xpack.ml.fieldTypeIcon.geoPointTypeAriaLabel": "{geoPointParam} 类型", - "xpack.ml.fieldTypeIcon.ipTypeAriaLabel": "IP 类型", - "xpack.ml.fieldTypeIcon.keywordTypeAriaLabel": "关键字类型", - "xpack.ml.fieldTypeIcon.numberTypeAriaLabel": "数字类型", - "xpack.ml.fieldTypeIcon.textTypeAriaLabel": "文本类型", - "xpack.ml.fieldTypeIcon.unknownTypeAriaLabel": "未知类型", - "xpack.ml.fileDatavisualizer.aboutPanel.analyzingDataTitle": "正在分析数据", - "xpack.ml.fileDatavisualizer.aboutPanel.selectOrDragAndDropFileDescription": "选择或拖放文件", - "xpack.ml.fileDatavisualizer.advancedImportSettings.createIndexPatternLabel": "创建索引模式", - "xpack.ml.fileDatavisualizer.advancedImportSettings.indexNameAriaLabel": "索引名称,必填字段", - "xpack.ml.fileDatavisualizer.advancedImportSettings.indexNameLabel": "索引名称", - "xpack.ml.fileDatavisualizer.advancedImportSettings.indexNamePlaceholder": "索引名称", - "xpack.ml.fileDatavisualizer.advancedImportSettings.indexPatternNameLabel": "索引模式名称", - "xpack.ml.fileDatavisualizer.advancedImportSettings.indexSettingsLabel": "索引设置", - "xpack.ml.fileDatavisualizer.advancedImportSettings.ingestPipelineLabel": "采集管道", - "xpack.ml.fileDatavisualizer.advancedImportSettings.mappingsLabel": "映射", - "xpack.ml.fileDatavisualizer.analysisSummary.analyzedLinesNumberTitle": "已分析的行数", - "xpack.ml.fileDatavisualizer.analysisSummary.delimiterTitle": "分隔符", - "xpack.ml.fileDatavisualizer.analysisSummary.formatTitle": "格式", - "xpack.ml.fileDatavisualizer.analysisSummary.grokPatternTitle": "Grok 模式", - "xpack.ml.fileDatavisualizer.analysisSummary.hasHeaderRowTitle": "包含标题行", - "xpack.ml.fileDatavisualizer.analysisSummary.summaryTitle": "结论", - "xpack.ml.fileDatavisualizer.analysisSummary.timeFieldTitle": "时间字段", - "xpack.ml.fileDatavisualizer.analysisSummary.timeFormatTitle": "时间 {timestampFormats, plural, zero {格式} one {format} 其他 {formats}}", - "xpack.ml.fileDatavisualizer.bottomBar.backButtonLabel": "上一步", - "xpack.ml.fileDatavisualizer.bottomBar.cancelButtonLabel": "取消", - "xpack.ml.fileDatavisualizer.bottomBar.readMode.cancelButtonLabel": "取消", - "xpack.ml.fileDatavisualizer.bottomBar.readMode.importButtonLabel": "导入", - "xpack.ml.fileDatavisualizer.editFlyout.applyOverrideSettingsButtonLabel": "应用", - "xpack.ml.fileDatavisualizer.editFlyout.closeOverrideSettingsButtonLabel": "关闭", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.customDelimiterFormRowLabel": "定制分隔符", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.customTimestampFormatErrorMessage": "时间戳格式必须为这些 Java 日期/时间格式的组合:\n yy、yyyy、M、MM、MMM、MMMM、d、dd、EEE、EEEE、H、HH、h、mm、ss、S 至 SSSSSSSSS、a、XX、XXX、zzz", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.customTimestampFormatFormRowLabel": "定制时间戳格式", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.dataFormatFormRowLabel": "数据格式", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.delimiterFormRowLabel": "分隔符", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.editFieldNamesTitle": "编辑字段名称", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.grokPatternFormRowLabel": "Grok 模式", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.hasHeaderRowLabel": "包含标题行", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.linesToSampleErrorMessage": "值必须大于 {min} 并小于或等于 {max}", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.linesToSampleFormRowLabel": "要采样的行数", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.quoteCharacterFormRowLabel": "引用字符", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.timeFieldFormRowLabel": "时间字段", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampEmptyValidationErrorMessage": "时间戳格式 {timestampFormat} 中没有时间格式字母组", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampFormatFormRowLabel": "时间戳格式", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampFormatHelpText": "请参阅有关接受格式的更多内容。", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampLetterSValidationErrorMessage": "{format}的字母 { length, plural, one { {lg} } other { 组 {lg} } } 不受支持,因为其未前置 ss 和 {sep} 中的分隔符", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampLetterValidationErrorMessage": "{format}的字母 { length, plural, one { {lg} } other { 组 {lg} } } 不受支持", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampQuestionMarkValidationErrorMessage": "时间戳格式 {timestampFormat} 不受支持,因为其包含问号字符 ({fieldPlaceholder})", - "xpack.ml.fileDatavisualizer.editFlyout.overrides.trimFieldsLabel": "应剪裁字段", - "xpack.ml.fileDatavisualizer.editFlyout.overrideSettingsTitle": "替代设置", - "xpack.ml.fileDatavisualizer.experimentalBadge.experimentalLabel": "实验性", - "xpack.ml.fileDatavisualizer.fieldStatsCard.distinctCountDescription": "{fieldCardinality} 不同的 {fieldCardinality, plural, zero {值} one {value} 其他 {values}}", - "xpack.ml.fileDatavisualizer.fieldStatsCard.documentsCountDescription": "{fieldCount, plural, zero {# 个文档} one {# 个文档} other {# 个文档}} ({fieldPercent}%)", - "xpack.ml.fileDatavisualizer.fieldStatsCard.maxTitle": "最大值", - "xpack.ml.fileDatavisualizer.fieldStatsCard.medianTitle": "中值", - "xpack.ml.fileDatavisualizer.fieldStatsCard.minTitle": "最小值", - "xpack.ml.fileDatavisualizer.fieldStatsCard.noFieldInformationAvailableDescription": "没有可用的字段信息", - "xpack.ml.fileDatavisualizer.fieldStatsCard.topStatsValuesDescription": "排在前面的值", - "xpack.ml.fileDatavisualizer.fileContents.fileContentsTitle": "文件内容", - "xpack.ml.fileDatavisualizer.fileContents.firstLinesDescription": "前 {numberOfLines, plural, zero {# 行} one {# 行} other {# 行}}", - "xpack.ml.fileDatavisualizer.fileDatavisualizerView.xmlNotCurrentlySupportedErrorMessage": "当前不支持 XML", - "xpack.ml.fileDatavisualizer.fileErrorCallouts.fileCouldNotBeReadTitle": "无法读取文件", - "xpack.ml.fileDatavisualizer.fileErrorCallouts.fileSizeExceedsAllowedSizeByDiffFormatErrorMessage": "您选择用于上传的文件大小超过上限值 {maxFileSizeFormatted} 的 {diffFormatted}", - "xpack.ml.fileDatavisualizer.fileErrorCallouts.fileSizeExceedsAllowedSizeErrorMessage": "您选择用于上传的文件大小为 {fileSizeFormatted},超过上限值 {maxFileSizeFormatted}", - "xpack.ml.fileDatavisualizer.fileErrorCallouts.fileSizeTooLargeTitle": "文件太大", - "xpack.ml.fileDatavisualizer.fileErrorCallouts.revertingToPreviousSettingsDescription": "恢复到以前的设置", - "xpack.ml.fileDatavisualizer.importErrors.checkingPermissionErrorMessage": "导入权限错误", - "xpack.ml.fileDatavisualizer.importErrors.creatingIndexErrorMessage": "创建索引时出错", - "xpack.ml.fileDatavisualizer.importErrors.creatingIndexPatternErrorMessage": "创建索引模式时出错", - "xpack.ml.fileDatavisualizer.importErrors.creatingIngestPipelineErrorMessage": "创建采集管道时出错", - "xpack.ml.fileDatavisualizer.importErrors.defaultErrorMessage": "错误", - "xpack.ml.fileDatavisualizer.importErrors.moreButtonLabel": "更多", - "xpack.ml.fileDatavisualizer.importErrors.parsingJSONErrorMessage": "解析 JSON 出错", - "xpack.ml.fileDatavisualizer.importErrors.readingFileErrorMessage": "读取文件时出错", - "xpack.ml.fileDatavisualizer.importErrors.unknownErrorMessage": "未知错误", - "xpack.ml.fileDatavisualizer.importErrors.uploadingDataErrorMessage": "上传数据时出错", - "xpack.ml.fileDatavisualizer.importProgress.createIndexPatternTitle": "创建索引模式", - "xpack.ml.fileDatavisualizer.importProgress.createIndexTitle": "创建索引", - "xpack.ml.fileDatavisualizer.importProgress.createIngestPipelineTitle": "创建采集管道", - "xpack.ml.fileDatavisualizer.importProgress.creatingIndexPatternDescription": "正在创建索引模式", - "xpack.ml.fileDatavisualizer.importProgress.creatingIndexPatternTitle": "正在创建索引模式", - "xpack.ml.fileDatavisualizer.importProgress.creatingIndexTitle": "正在创建索引", - "xpack.ml.fileDatavisualizer.importProgress.creatingIngestPipelineTitle": "正在创建采集管道", - "xpack.ml.fileDatavisualizer.importProgress.dataUploadedTitle": "数据已上传", - "xpack.ml.fileDatavisualizer.importProgress.fileProcessedTitle": "文件已处理", - "xpack.ml.fileDatavisualizer.importProgress.indexCreatedTitle": "索引已创建", - "xpack.ml.fileDatavisualizer.importProgress.indexPatternCreatedTitle": "索引模式已创建", - "xpack.ml.fileDatavisualizer.importProgress.ingestPipelineCreatedTitle": "采集管道已创建", - "xpack.ml.fileDatavisualizer.importProgress.processFileTitle": "处理文件", - "xpack.ml.fileDatavisualizer.importProgress.processingFileTitle": "正在处理文件", - "xpack.ml.fileDatavisualizer.importProgress.processingImportedFileDescription": "正在处理要导入的文件", - "xpack.ml.fileDatavisualizer.importProgress.stepTwoCreatingIndexDescription": "正在创建索引", - "xpack.ml.fileDatavisualizer.importProgress.stepTwoCreatingIndexIngestPipelineDescription": "正在创建索引和采集管道", - "xpack.ml.fileDatavisualizer.importProgress.uploadDataTitle": "上传数据", - "xpack.ml.fileDatavisualizer.importProgress.uploadingDataDescription": "正在上传数据", - "xpack.ml.fileDatavisualizer.importProgress.uploadingDataTitle": "正在上传数据", - "xpack.ml.fileDatavisualizer.importSettings.advancedTabName": "高级", - "xpack.ml.fileDatavisualizer.importSettings.simpleTabName": "简单", - "xpack.ml.fileDatavisualizer.importSummary.documentsCouldNotBeImportedDescription": "无法导入 {importFailuresLength} 个文档(共 {docCount} 个)这可能是由于行与 Grok 模式不匹配。", - "xpack.ml.fileDatavisualizer.importSummary.documentsCouldNotBeImportedTitle": "部分文档无法导入", - "xpack.ml.fileDatavisualizer.importSummary.documentsIngestedTitle": "已采集的文档", - "xpack.ml.fileDatavisualizer.importSummary.failedDocumentsButtonLabel": "失败的文档", - "xpack.ml.fileDatavisualizer.importSummary.failedDocumentsTitle": "失败的文档", - "xpack.ml.fileDatavisualizer.importSummary.importCompleteTitle": "导入完成", - "xpack.ml.fileDatavisualizer.importSummary.indexPatternTitle": "索引模式", - "xpack.ml.fileDatavisualizer.importSummary.indexTitle": "索引", - "xpack.ml.fileDatavisualizer.importSummary.ingestPipelineTitle": "采集管道", - "xpack.ml.fileDatavisualizer.importView.experimentalFeatureTooltip": "实验功能。我们很乐意听取您的反馈意见。", - "xpack.ml.fileDatavisualizer.importView.importButtonLabel": "导入", - "xpack.ml.fileDatavisualizer.importView.importDataTitle": "导入数据", - "xpack.ml.fileDatavisualizer.importView.importPermissionError": "您无权创建或将数据导入索引 {index}", - "xpack.ml.fileDatavisualizer.importView.indexNameAlreadyExistsErrorMessage": "索引名称已存在", - "xpack.ml.fileDatavisualizer.importView.indexNameContainsIllegalCharactersErrorMessage": "索引名称包含非法字符", - "xpack.ml.fileDatavisualizer.importView.indexPatternDoesNotMatchIndexNameErrorMessage": "索引模式与索引名称不匹配", - "xpack.ml.fileDatavisualizer.importView.indexPatternNameAlreadyExistsErrorMessage": "索引模式名称已存在", - "xpack.ml.fileDatavisualizer.importView.noIdOrIndexSuppliedErrorMessage": "未提供任何 ID 或索引", - "xpack.ml.fileDatavisualizer.importView.parseMappingsError": "解析映射时出错:", - "xpack.ml.fileDatavisualizer.importView.parsePipelineError": "解析采集管道时出错:", - "xpack.ml.fileDatavisualizer.importView.parseSettingsError": "解析设置时出错:", - "xpack.ml.fileDatavisualizer.importView.resetButtonLabel": "重置", - "xpack.ml.fileDatavisualizer.resultsLinks.createNewMLJobTitle": "新建 ML 作业", - "xpack.ml.fileDatavisualizer.resultsLinks.indexManagementTitle": "索引管理", - "xpack.ml.fileDatavisualizer.resultsLinks.indexPatternManagementTitle": "索引模式管理", - "xpack.ml.fileDatavisualizer.resultsLinks.openInDataVisualizerTitle": "在数据可视化工具中打开", - "xpack.ml.fileDatavisualizer.resultsLinks.viewIndexInDiscoverTitle": "在 Discover 中查看索引", - "xpack.ml.fileDatavisualizer.resultsView.fileStatsTabName": "文件统计", - "xpack.ml.fileDatavisualizer.resultsView.overrideSettingsButtonLabel": "替代设置", - "xpack.ml.fileDatavisualizer.simpleImportSettings.createIndexPatternLabel": "创建索引模式", - "xpack.ml.fileDatavisualizer.simpleImportSettings.indexNameAriaLabel": "索引名称,必填字段", - "xpack.ml.fileDatavisualizer.simpleImportSettings.indexNameFormRowLabel": "索引名称", - "xpack.ml.fileDatavisualizer.simpleImportSettings.indexNamePlaceholder": "索引名称", - "xpack.ml.fileDatavisualizer.welcomeContent.delimitedTextFilesDescription": "分隔的文本文件,例如 CSV 和 TSV", - "xpack.ml.fileDatavisualizer.welcomeContent.experimentalFeatureDescription": "此功能处于试验状态。收到反馈?请在 {githubLink} 中创建问题。", - "xpack.ml.fileDatavisualizer.welcomeContent.experimentalFeatureTooltip": "实验功能。我们很乐意听取您的反馈意见。", - "xpack.ml.fileDatavisualizer.welcomeContent.logFilesWithCommonFormatDescription": "具有时间戳通用格式的日志文件", - "xpack.ml.fileDatavisualizer.welcomeContent.newlineDelimitedJsonDescription": "换行符分隔的 JSON", - "xpack.ml.fileDatavisualizer.welcomeContent.supportedFileFormatDescription": "File Data Visualizer 支持以下文件格式:", - "xpack.ml.fileDatavisualizer.welcomeContent.uploadedFilesAllowedSizeDescription": "您可以上传最大 100 MB 的文件。", - "xpack.ml.fileDatavisualizer.welcomeContent.visualizeDataFromLogFileDescription": "File Data Visualizer 可帮助您理解日志文件中的字段和指标。上传文件、分析文件数据,然后选择是否将数据导入 Elasticsearch 索引。", - "xpack.ml.fileDatavisualizer.welcomeContent.visualizeDataFromLogFileTitle": "可视化来自日志文件的数据 {experimentalBadge}", - "xpack.ml.formatters.metricChangeDescription.actualSameAsTypicalDescription": "实际上与典型模式相同", - "xpack.ml.formatters.metricChangeDescription.moreThan100xHigherDescription": "高 100 多倍", - "xpack.ml.formatters.metricChangeDescription.moreThan100xLowerDescription": "低 100 多倍", - "xpack.ml.formatters.metricChangeDescription.moreThanOneAndFiveHundredthsxHigherDescription": "高 {factor} 倍", - "xpack.ml.formatters.metricChangeDescription.moreThanOneAndFiveHundredthsxLowerDescription": "低 {factor} 倍", - "xpack.ml.formatters.metricChangeDescription.moreThanOneAndHalfxHigherDescription": "高 {factor} 倍", - "xpack.ml.formatters.metricChangeDescription.moreThanOneAndHalfxLowerDescription": "低 {factor} 倍", - "xpack.ml.formatters.metricChangeDescription.unexpectedNonZeroValueDescription": "异常非零值", - "xpack.ml.formatters.metricChangeDescription.unexpectedZeroValueDescription": "异常零值", - "xpack.ml.formatters.metricChangeDescription.unusuallyHighDescription": "异常高", - "xpack.ml.formatters.metricChangeDescription.unusuallyLowDescription": "异常低", - "xpack.ml.formatters.metricChangeDescription.unusualValuesDescription": "异常值", - "xpack.ml.fullTimeRangeSelector.errorSettingTimeRangeNotification": "设置时间范围时出错。", - "xpack.ml.fullTimeRangeSelector.useFullDataButtonLabel": "使用完整的 {indexPatternTitle} 数据", - "xpack.ml.indexPatternNotBasedOnTimeSeriesNotificationDescription": "仅针对基于时间的索引运行异常检测", - "xpack.ml.indexPatternNotBasedOnTimeSeriesNotificationTitle": "索引模式 {indexPatternTitle} 不基于时间序列", - "xpack.ml.influencersList.maxAnomalyScoreTooltipDescription": "最大异常分数:{maxScoreLabel}", - "xpack.ml.influencersList.noInfluencersFoundTitle": "找不到影响因素", - "xpack.ml.influencersList.totalAnomalyScoreTooltipDescription": "总异常分数:{totalScoreLabel}", - "xpack.ml.itemsGrid.itemsCountLabel": "{pageSize} 项", - "xpack.ml.itemsGrid.itemsPerPageButtonLabel": "每页中的项:{itemsPerPage}", - "xpack.ml.itemsGrid.noItemsAddedTitle": "没有添加任何项", - "xpack.ml.itemsGrid.noMatchingItemsTitle": "没有匹配的项", - "xpack.ml.jobsBreadcrumbs.advancedConfigurationLabel": "高级配置", - "xpack.ml.jobsBreadcrumbs.multiMetricLabel": "多指标", - "xpack.ml.jobsBreadcrumbs.populationLabel": "填充", - "xpack.ml.jobsBreadcrumbs.selectIndexOrSearchLabel": "选择索引或搜索", - "xpack.ml.jobsBreadcrumbs.singleMetricLabel": "单一指标", - "xpack.ml.jobSelect.noJobsSelectedWarningMessage": "未选择作业,将自动选择第一个作业", - "xpack.ml.jobSelect.requestedJobsDoesNotExistWarningMessage": "已请求\n{invalidIdsLength, plural, one { 个作业 {invalidIds} 不存在} other { 个作业 {invalidIds} 不存在}}", - "xpack.ml.jobSelectList.groupTimeRangeLabel": "{fromString} 到 {toString}", - "xpack.ml.jobSelector.applyFlyoutButton": "应用", - "xpack.ml.jobSelector.applyTimerangeSwitchLabel": "应用时间范围", - "xpack.ml.jobSelector.clearAllFlyoutButton": "全部清除", - "xpack.ml.jobSelector.closeFlyoutButton": "关闭", - "xpack.ml.jobSelector.customTable.searchBarPlaceholder": "搜索......", - "xpack.ml.jobSelector.customTable.selectAllCheckboxLabel": "全选", - "xpack.ml.jobSelector.filterBar.groupLabel": "组", - "xpack.ml.jobSelector.filterBar.invalidSearchErrorMessage": "无效搜索:{errorMessage}", - "xpack.ml.jobSelector.filterBar.jobGroupTitle": "({jobsCount, plural, one {# 个作业} other {# 个作业}})", - "xpack.ml.jobSelector.flyoutTitle": "作业选择", - "xpack.ml.jobSelector.groupsTab": "组", - "xpack.ml.jobSelector.hideBarBadges": "隐藏", - "xpack.ml.jobSelector.hideFlyoutBadges": "隐藏", - "xpack.ml.jobSelector.jobFetchErrorMessage": "获取作业时出错。刷新并重试。", - "xpack.ml.jobSelector.jobSelectionButton": "编辑作业选择", - "xpack.ml.jobSelector.jobsTab": "作业", - "xpack.ml.jobSelector.jobTimeRangeLabel": "{fromString} 到 {toString}", - "xpack.ml.jobSelector.selectedGroupJobs": "({jobsCount, plural, one {# 个作业} other {# 个作业}})", - "xpack.ml.jobSelector.showBarBadges": "和另外 {overFlow} 个", - "xpack.ml.jobSelector.showFlyoutBadges": "和另外 {overFlow} 个", - "xpack.ml.jobService.activeDatafeedsLabel": "活动数据馈送", - "xpack.ml.jobService.activeMLNodesLabel": "活动 ML 节点", - "xpack.ml.jobService.closedJobsLabel": "已关闭的作业", - "xpack.ml.jobService.couldNotStartDatafeedErrorMessage": "无法开始 {jobId} 的数据馈送", - "xpack.ml.jobService.couldNotStopDatafeedErrorMessage": "无法停止 {jobId} 的数据馈送", - "xpack.ml.jobService.couldNotUpdateDatafeedErrorMessage": "无法更新数据馈送:{datafeedId}", - "xpack.ml.jobService.couldNotUpdateJobErrorMessage": "无法更新作业:{jobId}", - "xpack.ml.jobService.datafeedsListCouldNotBeRetrievedErrorMessage": "无法检索数据馈送列表", - "xpack.ml.jobService.failedJobsLabel": "失败的作业", - "xpack.ml.jobService.jobsListCouldNotBeRetrievedErrorMessage": "无法检索作业列表", - "xpack.ml.jobService.jobValidationErrorMessage": "作业验证错误:{errorMessage}", - "xpack.ml.jobService.openJobsLabel": "打开的作业", - "xpack.ml.jobService.requestMayHaveTimedOutErrorMessage": "请求可能已超时,并可能仍在后台运行。", - "xpack.ml.jobService.totalJobsLabel": "总计作业数", - "xpack.ml.jobsList.actionExecuteSuccessfullyNotificationMessage": "{successesJobsCount, plural, one{{successJob}} other{# 个作业}}{actionTextPT}已成功", - "xpack.ml.jobsList.actionFailedNotificationMessage": "{failureId} 未能{actionText}", - "xpack.ml.jobsList.actionsLabel": "操作", - "xpack.ml.jobsList.cloneJobErrorMessage": "无法克隆 {jobId}。找不到作业", - "xpack.ml.jobsList.closeActionStatusText": "关闭", - "xpack.ml.jobsList.closedActionStatusText": "已关闭", - "xpack.ml.jobsList.closeJobErrorMessage": "作业无法关闭", - "xpack.ml.jobsList.collapseJobDetailsAriaLabel": "隐藏 {itemId} 的详情", - "xpack.ml.jobsList.createNewJobButtonLabel": "创建新作业", - "xpack.ml.jobsList.createWatchFlyout.closeButtonLabel": "关闭", - "xpack.ml.jobsList.createWatchFlyout.editWatchButtonLabel": "编辑监视", - "xpack.ml.jobsList.createWatchFlyout.pageTitle": "创建 {jobId} 的监视", - "xpack.ml.jobsList.createWatchFlyout.saveButtonLabel": "保存", - "xpack.ml.jobsList.createWatchFlyout.watchCreatedSuccessfullyNotificationMessage": "监视 {id} 已成功创建", - "xpack.ml.jobsList.createWatchFlyout.watchNotSavedErrorNotificationMessage": "无法保存监视", - "xpack.ml.jobsList.datafeedStateLabel": "数据馈送状态", - "xpack.ml.jobsList.deleteActionStatusText": "删除", - "xpack.ml.jobsList.deletedActionStatusText": "已删除", - "xpack.ml.jobsList.deleteJobErrorMessage": "作业无法删除", - "xpack.ml.jobsList.deleteJobModal.cancelButtonLabel": "取消", - "xpack.ml.jobsList.deleteJobModal.closeButtonLabel": "关闭", - "xpack.ml.jobsList.deleteJobModal.deleteButtonLabel": "删除", - "xpack.ml.jobsList.deleteJobModal.deleteJobsDescription": "是否确定要删除{jobsCount, plural, one {此作业} other {这些作业}}?", - "xpack.ml.jobsList.deleteJobModal.deleteJobsTitle": "删除 {jobsCount, plural, one {{jobId}} other {# 个作业}}", - "xpack.ml.jobsList.deleteJobModal.deleteMultipleJobsDescription": "删除{jobsCount, plural, one {一个作业} other {多个作业}}会非常耗时。将在后台删除{jobsCount, plural, one {该作业} other {这些作业}},但删除的作业可能不会立即从作业列表中消失", - "xpack.ml.jobsList.deleteJobModal.deletingJobsStatusLabel": "正在删除作业", - "xpack.ml.jobsList.descriptionLabel": "描述", - "xpack.ml.jobsList.editJobFlyout.changesNotSavedNotificationMessage": "无法保存对 {jobId} 所做的更改", - "xpack.ml.jobsList.editJobFlyout.changesSavedNotificationMessage": "已保存对 {jobId} 所做的更改", - "xpack.ml.jobsList.editJobFlyout.closeButtonLabel": "关闭", - "xpack.ml.jobsList.editJobFlyout.customUrls.addButtonLabel": "添加", - "xpack.ml.jobsList.editJobFlyout.customUrls.addCustomUrlButtonLabel": "添加定制 URL", - "xpack.ml.jobsList.editJobFlyout.customUrls.addNewUrlErrorNotificationMessage": "基于提供的设置构建新的定制 URL 时出错", - "xpack.ml.jobsList.editJobFlyout.customUrls.buildUrlErrorNotificationMessage": "基于提供的设置构建用于测试的定制 URL 时出错", - "xpack.ml.jobsList.editJobFlyout.customUrls.closeEditorAriaLabel": "关闭定制 URL 编辑器", - "xpack.ml.jobsList.editJobFlyout.customUrls.getTestUrlErrorNotificationMessage": "获取 URL 用于测试配置时出错", - "xpack.ml.jobsList.editJobFlyout.customUrls.loadIndexPatternsErrorNotificationMessage": "加载已保存的索引模式列表时出错", - "xpack.ml.jobsList.editJobFlyout.customUrls.loadSavedDashboardsErrorNotificationMessage": "加载已保存的 Kibana 仪表板列表时出错", - "xpack.ml.jobsList.editJobFlyout.customUrls.testButtonLabel": "测试", - "xpack.ml.jobsList.editJobFlyout.customUrlsTitle": "定制 URL", - "xpack.ml.jobsList.editJobFlyout.datafeed.frequencyLabel": "频率", - "xpack.ml.jobsList.editJobFlyout.datafeed.queryDelayLabel": "查询延迟", - "xpack.ml.jobsList.editJobFlyout.datafeed.queryLabel": "查询", - "xpack.ml.jobsList.editJobFlyout.datafeed.scrollSizeLabel": "滚动条大小", - "xpack.ml.jobsList.editJobFlyout.datafeedTitle": "数据馈送", - "xpack.ml.jobsList.editJobFlyout.detectorsTitle": "检测工具", - "xpack.ml.jobsList.editJobFlyout.groupsAndJobsHasSameIdErrorMessage": "已存在具有此 ID 的作业。组和作业不能使用相同的 ID。", - "xpack.ml.jobsList.editJobFlyout.jobDetails.jobDescriptionLabel": "作业描述", - "xpack.ml.jobsList.editJobFlyout.jobDetails.jobGroupsLabel": "作业组", - "xpack.ml.jobsList.editJobFlyout.jobDetails.jobGroupsPlaceholder": "选择或创建组", - "xpack.ml.jobsList.editJobFlyout.jobDetails.modelMemoryLimitLabel": "模型内存限制", - "xpack.ml.jobsList.editJobFlyout.jobDetailsTitle": "作业详情", - "xpack.ml.jobsList.editJobFlyout.pageTitle": "编辑 {jobId}", - "xpack.ml.jobsList.editJobFlyout.saveButtonLabel": "保存", - "xpack.ml.jobsList.expandJobDetailsAriaLabel": "显示 {itemId} 的详情", - "xpack.ml.jobsList.idLabel": "ID", - "xpack.ml.jobsList.jobDetails.analysisConfigTitle": "分析配置", - "xpack.ml.jobsList.jobDetails.analysisLimitsTitle": "分析限制", - "xpack.ml.jobsList.jobDetails.calendarsTitle": "日历", - "xpack.ml.jobsList.jobDetails.countsTitle": "计数", - "xpack.ml.jobsList.jobDetails.customUrlsTitle": "定制 URL", - "xpack.ml.jobsList.jobDetails.dataDescriptionTitle": "数据描述", - "xpack.ml.jobsList.jobDetails.datafeedTitle": "数据馈送", - "xpack.ml.jobsList.jobDetails.detectorsTitle": "检测工具", - "xpack.ml.jobsList.jobDetails.forecastsTable.createdLabel": "创建于", - "xpack.ml.jobsList.jobDetails.forecastsTable.expiresLabel": "过期时间", - "xpack.ml.jobsList.jobDetails.forecastsTable.fromLabel": "从", - "xpack.ml.jobsList.jobDetails.forecastsTable.loadingErrorMessage": "加载此作业上运行的预测列表时出错", - "xpack.ml.jobsList.jobDetails.forecastsTable.memorySizeLabel": "内存大小", - "xpack.ml.jobsList.jobDetails.forecastsTable.messagesLabel": "消息", - "xpack.ml.jobsList.jobDetails.forecastsTable.msTimeUnitLabel": "{ms} 毫秒", - "xpack.ml.jobsList.jobDetails.forecastsTable.noForecastsDescription": "要运行预测,请打开 {singleMetricViewerLink}", - "xpack.ml.jobsList.jobDetails.forecastsTable.noForecastsDescription.linkText": "Single Metric Viewer", - "xpack.ml.jobsList.jobDetails.forecastsTable.noForecastsTitle": "还没有针对此作业运行的预测", - "xpack.ml.jobsList.jobDetails.forecastsTable.processingTimeLabel": "处理时间", - "xpack.ml.jobsList.jobDetails.forecastsTable.statusLabel": "状态", - "xpack.ml.jobsList.jobDetails.forecastsTable.toLabel": "到", - "xpack.ml.jobsList.jobDetails.forecastsTable.viewAriaLabel": "查看在 {createdDate} 创建的预测", - "xpack.ml.jobsList.jobDetails.forecastsTable.viewLabel": "查看", - "xpack.ml.jobsList.jobDetails.generalTitle": "常规", - "xpack.ml.jobsList.jobDetails.influencersTitle": "影响因素", - "xpack.ml.jobsList.jobDetails.modelSizeStatsTitle": "模型大小统计", - "xpack.ml.jobsList.jobDetails.nodeTitle": "节点", - "xpack.ml.jobsList.jobDetails.noPermissionToViewDatafeedPreviewTitle": "您无权查看数据馈送预览", - "xpack.ml.jobsList.jobDetails.pleaseContactYourAdministratorLabel": "请联系您的管理员。", - "xpack.ml.jobsList.jobDetails.tabs.annotationsLabel": "注释", - "xpack.ml.jobsList.jobDetails.tabs.countsLabel": "计数", - "xpack.ml.jobsList.jobDetails.tabs.datafeedLabel": "数据馈送", - "xpack.ml.jobsList.jobDetails.tabs.datafeedPreviewLabel": "数据馈送预览", - "xpack.ml.jobsList.jobDetails.tabs.forecastsLabel": "预测", - "xpack.ml.jobsList.jobDetails.tabs.jobConfigLabel": "作业配置", - "xpack.ml.jobsList.jobDetails.tabs.jobMessagesLabel": "作业消息", - "xpack.ml.jobsList.jobDetails.tabs.jobSettingsLabel": "作业设置", - "xpack.ml.jobsList.jobDetails.tabs.jsonLabel": "JSON", - "xpack.ml.jobsList.jobFilterBar.closedLabel": "已关闭", - "xpack.ml.jobsList.jobFilterBar.failedLabel": "失败", - "xpack.ml.jobsList.jobFilterBar.groupLabel": "组", - "xpack.ml.jobsList.jobFilterBar.invalidSearchErrorMessage": "无效搜索:{errorMessage}", - "xpack.ml.jobsList.jobFilterBar.jobGroupTitle": "({jobsCount, plural, one {# 个作业} other {# 个作业}})", - "xpack.ml.jobsList.jobFilterBar.openedLabel": "已打开", - "xpack.ml.jobsList.jobFilterBar.startedLabel": "已开始", - "xpack.ml.jobsList.jobFilterBar.stoppedLabel": "已停止", - "xpack.ml.jobsList.jobStateLabel": "作业状态", - "xpack.ml.jobsList.latestTimestampLabel": "最新时间戳", - "xpack.ml.jobsList.loadingJobsLabel": "正在加载作业", - "xpack.ml.jobsList.managementActions.cloneJobDescription": "克隆作业", - "xpack.ml.jobsList.managementActions.cloneJobLabel": "克隆作业", - "xpack.ml.jobsList.managementActions.closeJobDescription": "关闭作业", - "xpack.ml.jobsList.managementActions.closeJobLabel": "关闭作业", - "xpack.ml.jobsList.managementActions.deleteJobDescription": "删除作业", - "xpack.ml.jobsList.managementActions.deleteJobLabel": "删除作业", - "xpack.ml.jobsList.managementActions.editJobDescription": "编辑作业", - "xpack.ml.jobsList.managementActions.editJobLabel": "编辑作业", - "xpack.ml.jobsList.managementActions.startDatafeedDescription": "开始数据馈送", - "xpack.ml.jobsList.managementActions.startDatafeedLabel": "开始数据馈送", - "xpack.ml.jobsList.managementActions.stopDatafeedDescription": "停止数据馈送", - "xpack.ml.jobsList.managementActions.stopDatafeedLabel": "停止数据馈送", - "xpack.ml.jobsList.memoryStatusLabel": "内存状态", - "xpack.ml.jobsList.multiJobActions.groupSelector.addButtonAriaLabel": "添加", - "xpack.ml.jobsList.multiJobActions.groupSelector.addNewGroupPlaceholder": "添加新组", - "xpack.ml.jobsList.multiJobActions.groupSelector.applyButtonLabel": "应用", - "xpack.ml.jobsList.multiJobActions.groupSelector.applyGroupsToJobTitle": "将组应用到{jobsCount, plural, one { 个作业} other { 个作业}}", - "xpack.ml.jobsList.multiJobActions.groupSelector.editJobGroupsButtonAriaLabel": "编辑作业组", - "xpack.ml.jobsList.multiJobActions.groupSelector.editJobGroupsButtonTooltip": "编辑作业组", - "xpack.ml.jobsList.multiJobActions.groupSelector.groupsAndJobsCanNotUseSameIdErrorMessage": "已存在具有此 ID 的作业。组和作业不能使用相同的 ID。", - "xpack.ml.jobsList.multiJobActionsMenu.managementActionsAriaLabel": "管理操作", - "xpack.ml.jobsList.multiJobsActions.closeJobsLabel": "关闭 {jobsCount, plural, one { 个作业} other { 个作业}}", - "xpack.ml.jobsList.multiJobsActions.deleteJobsLabel": "删除 {jobsCount, plural, one { 个作业} other { 个作业}}", - "xpack.ml.jobsList.multiJobsActions.jobsSelectedLabel": "已选择{selectedJobsCount, plural, one {# 个作业} other {# 个作业}}", - "xpack.ml.jobsList.multiJobsActions.startDatafeedsLabel": "开始 {jobsCount, plural, one { 个数据馈送} other { 个数据馈送}}", - "xpack.ml.jobsList.multiJobsActions.stopDatafeedsLabel": "停止 {jobsCount, plural, one { 个数据馈送} other { 个数据馈送}}", - "xpack.ml.jobsList.nodeAvailableWarning.linkToCloud.hereLinkText": "此处", - "xpack.ml.jobsList.nodeAvailableWarning.noMLNodesAvailableDescription": "没有可用的 ML 节点。", - "xpack.ml.jobsList.nodeAvailableWarning.noMLNodesAvailableTitle": "没有可用的 ML 节点", - "xpack.ml.jobsList.noJobsFoundLabel": "找不到作业", - "xpack.ml.jobsList.processedRecordsLabel": "已处理记录", - "xpack.ml.jobsList.refreshButtonLabel": "刷新", - "xpack.ml.jobsList.resultActions.openJobsInAnomalyExplorerText": "在 Anomaly Explorer 中打开 {jobsCount, plural, one {{jobId}} other {# 个作业}}", - "xpack.ml.jobsList.resultActions.openJobsInSingleMetricViewerText": "在 Single Metric Viewer 中打开 {jobsCount, plural, one {{jobId}} other {# 个作业}}", - "xpack.ml.jobsList.startActionStatusText": "开始", - "xpack.ml.jobsList.startDatafeedModal.cancelButtonLabel": "取消", - "xpack.ml.jobsList.startDatafeedModal.continueFromNowLabel": "从当前继续", - "xpack.ml.jobsList.startDatafeedModal.continueFromSpecifiedTimeLabel": "从指定时间继续", - "xpack.ml.jobsList.startDatafeedModal.continueFromStartTimeLabel": "从 {formattedStartTime} 继续", - "xpack.ml.jobsList.startDatafeedModal.createWatchDescription": "在数据馈送开始后创建监视", - "xpack.ml.jobsList.startDatafeedModal.noEndTimeLabel": "无结束时间(实时搜索)", - "xpack.ml.jobsList.startDatafeedModal.searchEndTimeTitle": "搜索结束时间", - "xpack.ml.jobsList.startDatafeedModal.searchStartTimeTitle": "搜索开始时间", - "xpack.ml.jobsList.startDatafeedModal.specifyEndTimeLabel": "指定结束时间", - "xpack.ml.jobsList.startDatafeedModal.specifyStartTimeLabel": "指定开始时间", - "xpack.ml.jobsList.startDatafeedModal.startAtBeginningOfDataLabel": "从数据开始处开始", - "xpack.ml.jobsList.startDatafeedModal.startButtonLabel": "开始", - "xpack.ml.jobsList.startDatafeedModal.startFromNowLabel": "从当前开始", - "xpack.ml.jobsList.startDatafeedModal.startJobsTitle": "启动 {jobsCount, plural, one {{jobId}} other {# 个作业}}", - "xpack.ml.jobsList.startedActionStatusText": "已启动", - "xpack.ml.jobsList.startJobErrorMessage": "作业无法启动", - "xpack.ml.jobsList.statsBar.activeDatafeedsLabel": "活动数据馈送", - "xpack.ml.jobsList.statsBar.activeMLNodesLabel": "活动 ML 节点", - "xpack.ml.jobsList.statsBar.closedJobsLabel": "已关闭的作业", - "xpack.ml.jobsList.statsBar.failedJobsLabel": "失败的作业", - "xpack.ml.jobsList.statsBar.openJobsLabel": "打开的作业", - "xpack.ml.jobsList.statsBar.totalJobsLabel": "总计作业数", - "xpack.ml.jobsList.stopActionStatusText": "停止", - "xpack.ml.jobsList.stopJobErrorMessage": "作业无法停止", - "xpack.ml.jobsList.stoppedActionStatusText": "已停止", - "xpack.ml.machineLearningBreadcrumbLabel": "机器学习", - "xpack.ml.machineLearningDescription": "对时序数据的正常行为自动建模以检测异常。", - "xpack.ml.machineLearningTitle": "机器学习", - "xpack.ml.mlNavDescription": "Elastic Stack 的 Machine Learning", - "xpack.ml.mlNavTitle": "机器学习", - "xpack.ml.models.jobService.allOtherRequestsCancelledDescription": " 所有其他请求已取消。", - "xpack.ml.models.jobService.deletingJob": "正在删除", - "xpack.ml.models.jobService.jobHasNoDatafeedErrorMessage": "作业没有数据馈送", - "xpack.ml.models.jobService.requestToActionTimedOutErrorMessage": "对 {action} “{id}” 的请求超时。{extra}", - "xpack.ml.models.jobValidation.analysisConfigIsNotObjectErrorMessage": "无效的 {invalidParamName}:需要是对象。", - "xpack.ml.models.jobValidation.detectorsAreNotArrayErrorMessage": "无效的 {invalidParamName}:需要是数组。", - "xpack.ml.models.jobValidation.jobIsNotObjectErrorMessage": "无效的 {invalidParamName}:需要是对象。", - "xpack.ml.models.jobValidation.messages.bucketSpanEmptyMessage": "必须指定存储桶跨度字段。", - "xpack.ml.models.jobValidation.messages.bucketSpanEstimationMismatchHeading": "存储桶跨度", - "xpack.ml.models.jobValidation.messages.bucketSpanEstimationMismatchMessage": "当前存储桶跨度为 {currentBucketSpan},但存储桶跨度估计返回 {estimateBucketSpan}。", - "xpack.ml.models.jobValidation.messages.bucketSpanHighHeading": "存储桶跨度", - "xpack.ml.models.jobValidation.messages.bucketSpanHighMessage": "存储桶跨度为 1 天或以上。请注意,天数被视为 UTC 天数,而非本地天数。", - "xpack.ml.models.jobValidation.messages.bucketSpanInvalidHeading": "存储桶跨度", - "xpack.ml.models.jobValidation.messages.bucketSpanInvalidMessage": "指定的存储桶跨度不是有效的时间间隔格式,例如 10m、1h。它还需要大于零。", - "xpack.ml.models.jobValidation.messages.bucketSpanValidHeading": "存储桶跨度", - "xpack.ml.models.jobValidation.messages.bucketSpanValidMessage": "{bucketSpan} 的格式有效。", - "xpack.ml.models.jobValidation.messages.cardinalityByFieldMessage": "{fieldName} 的基数大于 1000,可能会导致高内存用量。", - "xpack.ml.models.jobValidation.messages.cardinalityModelPlotHighMessage": "与创建模型绘图相关的字段的估计基数 {modelPlotCardinality} 可能导致资源密集型作业出现。", - "xpack.ml.models.jobValidation.messages.cardinalityOverFieldHighMessage": "{fieldName} 的基数大于 1000000,可能会导致高内存用量。", - "xpack.ml.models.jobValidation.messages.cardinalityOverFieldLowMessage": "{fieldName} 的基数低于 10,可能不适合人口分析。", - "xpack.ml.models.jobValidation.messages.cardinalityPartitionFieldMessage": "{fieldName} 的基数大于 1000,可能会导致高内存用量。", - "xpack.ml.models.jobValidation.messages.categorizationFiltersInvalidMessage": "分类筛选配置无效。确保筛选是有效的正则表达式,且已设置 {categorizationFieldName}。", - "xpack.ml.models.jobValidation.messages.categorizationFiltersValidMessage": "分类筛选检查已通过。", - "xpack.ml.models.jobValidation.messages.detectorsDuplicatesMessage": "找到重复的检测工具。在同一作业中,不允许存在具有 “{functionParam}”、“{fieldNameParam}”、“{byFieldNameParam}”、“{overFieldNameParam}” 和 “{partitionFieldNameParam}” 相同组合配置的检测工具。", - "xpack.ml.models.jobValidation.messages.detectorsEmptyMessage": "未找到任何检测工具。必须至少指定一个检测工具。", - "xpack.ml.models.jobValidation.messages.detectorsFunctionEmptyMessage": "检测工具函数之一为空。", - "xpack.ml.models.jobValidation.messages.detectorsFunctionNotEmptyHeading": "检测工具函数", - "xpack.ml.models.jobValidation.messages.detectorsFunctionNotEmptyMessage": "在所有检测工具中已验证检测工具函数的存在。", - "xpack.ml.models.jobValidation.messages.estimatedMmlGreaterThanMaxMmlMessage": "估计模型内存限制大于为此集群配置的最大模型内存限制。", - "xpack.ml.models.jobValidation.messages.estimatedMmlGreaterThanMmlMessage": "估计模型内存限制 大于已配置的模型内容限制。", - "xpack.ml.models.jobValidation.messages.fieldNotAggregatableMessage": "检测工具字段 {fieldName} 不是可聚合字段。", - "xpack.ml.models.jobValidation.messages.fieldsNotAggregatableMessage": "有一个检测工具字段不是可聚合字段。", - "xpack.ml.models.jobValidation.messages.halfEstimatedMmlGreaterThanMmlMessage": "指定的模型内存限制小于估计模型内存限制的一半,很可能会达到硬性限制。", - "xpack.ml.models.jobValidation.messages.indexFieldsInvalidMessage": "无法从索引加载字段。", - "xpack.ml.models.jobValidation.messages.indexFieldsValidMessage": "数据馈送中存在索引字段。", - "xpack.ml.models.jobValidation.messages.influencerHighMessage": "作业配置包括 3 个以上影响因素。考虑使用较少的影响因素或创建多个作业。", - "xpack.ml.models.jobValidation.messages.influencerLowMessage": "尚未配置任何影响因素。强烈建议选取影响因素。", - "xpack.ml.models.jobValidation.messages.influencerLowSuggestionMessage": "尚未配置任何影响因素。考虑使用 {influencerSuggestion} 作为影响因素。", - "xpack.ml.models.jobValidation.messages.influencerLowSuggestionsMessage": "尚未配置任何影响因素。考虑使用一个或多个 {influencerSuggestion}。", - "xpack.ml.models.jobValidation.messages.jobGroupIdInvalidMessage": "有一个作业组名称无效。它们可以包含小写字母数字(a-z 和 0-9)字符、连字符或下划线,必须以字母数字字符开头和结尾", - "xpack.ml.models.jobValidation.messages.jobGroupIdValidHeading": "作业 ID 格式有效。", - "xpack.ml.models.jobValidation.messages.jobIdEmptyMessage": "作业名称字段不得为空。", - "xpack.ml.models.jobValidation.messages.jobIdInvalidMessage": "作业 ID 无效.其可以包含小写字母数字(a-z 和 0-9)字符、连字符或下划线,且必须以字母数字字符开头和结尾。", - "xpack.ml.models.jobValidation.messages.jobIdValidHeading": "作业 ID 格式有效", - "xpack.ml.models.jobValidation.messages.mmlGreaterThanMaxMmlMessage": "模型内存限制大于为此集群配置的最大模型内存限制。", - "xpack.ml.models.jobValidation.messages.mmlValueInvalidMessage": "{mml} 不是有效的模型内存限制值。该值需要至少 1MB,且应以字节为单位(例如 10MB)指定。", - "xpack.ml.models.jobValidation.messages.skippedExtendedTestsMessage": "已跳过其他检查,因为未满足作业配置的基本要求。", - "xpack.ml.models.jobValidation.messages.successBucketSpanHeading": "存储桶跨度", - "xpack.ml.models.jobValidation.messages.successBucketSpanMessage": "{bucketSpan} 的格式有效,已通过验证检查。", - "xpack.ml.models.jobValidation.messages.successCardinalityHeading": "基数", - "xpack.ml.models.jobValidation.messages.successCardinalityMessage": "检测工具字段的基数在建议边界内。", - "xpack.ml.models.jobValidation.messages.successInfluencersMessage": "影响因素配置已通过验证检查。", - "xpack.ml.models.jobValidation.messages.successMmlHeading": "模型内存限制", - "xpack.ml.models.jobValidation.messages.successMmlMessage": "有效且在估计模型内存限制内。", - "xpack.ml.models.jobValidation.messages.successTimeRangeHeading": "时间范围", - "xpack.ml.models.jobValidation.messages.successTimeRangeMessage": "有效且长度足以对数据中的模式进行建模。", - "xpack.ml.models.jobValidation.messages.timeFieldInvalidMessage": "{timeField} 不能用作时间字段,因为它不是类型“date”的有效字段。", - "xpack.ml.models.jobValidation.messages.timeRangeBeforeEpochHeading": "时间范围", - "xpack.ml.models.jobValidation.messages.timeRangeBeforeEpochMessage": "选定或可用时间范围包含时间戳在 UNIX epoch 开始之前的数据。Machine Learning 作业不支持在 01/01/1970 00:00:00 (UTC) 之前的时间戳。", - "xpack.ml.models.jobValidation.messages.timeRangeShortHeading": "时间范围", - "xpack.ml.models.jobValidation.messages.timeRangeShortMessage": "选定或可用时间范围可能过短。建议的最小时间范围应至少为 {minTimeSpanReadable} 且是存储桶跨度的 {bucketSpanCompareFactor} 倍。", - "xpack.ml.models.jobValidation.payloadIsNotObjectErrorMessage": "无效的 {invalidParamName}:需要是对象。", - "xpack.ml.models.jobValidation.unknownMessageIdErrorMessage": "{messageId}(未知消息 ID)", - "xpack.ml.models.jobValidation.validateJobObject.analysisConfigIsNotObjectErrorMessage": "无效的 {invalidParamName}:需要是对象。", - "xpack.ml.models.jobValidation.validateJobObject.dataDescriptionIsNotObjectErrorMessage": "无效的 {invalidParamName}:需要是对象。", - "xpack.ml.models.jobValidation.validateJobObject.datafeedConfigIsNotObjectErrorMessage": "无效的 {invalidParamName}:需要是对象。", - "xpack.ml.models.jobValidation.validateJobObject.detectorsAreNotArrayErrorMessage": "无效的 {invalidParamName}:需要是数组。", - "xpack.ml.models.jobValidation.validateJobObject.indicesAreNotArrayErrorMessage": "无效的 {invalidParamName}:需要是数组。", - "xpack.ml.models.jobValidation.validateJobObject.influencersAreNotArrayErrorMessage": "无效的 {invalidParamName}:需要是数组。", - "xpack.ml.models.jobValidation.validateJobObject.jobIsNotObjectErrorMessage": "无效的 {invalidParamName}:需要是对象。", - "xpack.ml.models.jobValidation.validateJobObject.timeFieldIsNotStringErrorMessage": "无效的 {invalidParamName}:需要是字符串。", - "xpack.ml.navMenu.anomalyExplorerTabLinkText": "Anomaly Explorer", - "xpack.ml.navMenu.dataVisualizerTabLinkText": "数据可视化工具", - "xpack.ml.navMenu.jobManagementTabLinkText": "作业管理", - "xpack.ml.navMenu.settingsTabLinkText": "设置", - "xpack.ml.navMenu.singleMetricViewerTabLinkText": "Single Metric Viewer", - "xpack.ml.newJob.simple.createWatchView.emailAddressPlaceholder": "电子邮件地址", - "xpack.ml.newJob.simple.createWatchView.nowLabel": "立即 - {selectInterval}", - "xpack.ml.newJob.simple.createWatchView.sendEmailLabel": "发送电子邮件", - "xpack.ml.newJob.simple.createWatchView.severityThresholdLabel": "严重性阈值", - "xpack.ml.newJob.simple.createWatchView.successLabel": "成功", - "xpack.ml.newJob.simple.createWatchView.timeRangeLabel": "时间范围", - "xpack.ml.newJob.simple.createWatchView.watchAlreadyExistsWarningMessage": "警告,监视 ml-{jobId} 已存在,点击“应用”将覆盖原始监视。", - "xpack.ml.newJob.simple.createWatchView.watchEmailAddressAriaLabel": "监视电子邮件地址", - "xpack.ml.newJob.simple.watcher.email.anomalyScoreLabel": "异常分数", - "xpack.ml.newJob.simple.watcher.email.elasticStackMachineLearningAlertLabel": "Elastic Stack Machine Learning 告警", - "xpack.ml.newJob.simple.watcher.email.jobLabel": "作业", - "xpack.ml.newJob.simple.watcher.email.mlWatcherAlertSubjectTitle": "ML Watcher 告警", - "xpack.ml.newJob.simple.watcher.email.openInAnomalyExplorerLinkText": "单击此处在 Anomaly Explorer 中打开。", - "xpack.ml.newJob.simple.watcher.email.timeLabel": "时间", - "xpack.ml.newJob.simple.watcher.email.topInfluencersLabel": "排在前面的影响因素:", - "xpack.ml.newJob.simple.watcher.email.topRecordsLabel": "排在前面的记录:", - "xpack.ml.newJob.wizard.jobType.advancedAriaLabel": "高级作业", - "xpack.ml.newJob.wizard.jobType.advancedDescription": "使用全部选项为更高级的用例创建作业。", - "xpack.ml.newJob.wizard.jobType.advancedTitle": "高级", - "xpack.ml.newJob.wizard.jobType.createJobFromTitle": "从 {pageTitleLabel} 创建作业", - "xpack.ml.newJob.wizard.jobType.dataVisualizerAriaLabel": "数据可视化工具", - "xpack.ml.newJob.wizard.jobType.dataVisualizerDescription": "详细了解数据的特征,并通过 Machine Learning 识别分析字段。", - "xpack.ml.newJob.wizard.jobType.dataVisualizerTitle": "数据可视化工具", - "xpack.ml.newJob.wizard.jobType.howToRunAnomalyDetectionDescription": "异常检测只能在基于时间的索引上运行。", - "xpack.ml.newJob.wizard.jobType.indexPatternFromSavedSearchNotTimeBasedMessage": "{savedSearchTitle} 使用了不基于时间的索引模式 {indexPatternTitle}", - "xpack.ml.newJob.wizard.jobType.indexPatternNotTimeBasedMessage": "索引模式 {indexPatternTitle} 不基于时间", - "xpack.ml.newJob.wizard.jobType.indexPatternPageTitleLabel": "索引模式 {indexPatternTitle}", - "xpack.ml.newJob.wizard.jobType.learnMoreAboutDataDescription": "如果您不确定要创建的作业类型,请先浏览数据中的字段和指标。", - "xpack.ml.newJob.wizard.jobType.learnMoreAboutDataTitle": "深入了解数据", - "xpack.ml.newJob.wizard.jobType.multiMetricAriaLabel": "多指标作业", - "xpack.ml.newJob.wizard.jobType.multiMetricDescription": "通过按分类字段分割时序来检测多个指标中的异常。", - "xpack.ml.newJob.wizard.jobType.multiMetricTitle": "多指标", - "xpack.ml.newJob.wizard.jobType.populationAriaLabel": "填充作业", - "xpack.ml.newJob.wizard.jobType.populationDescription": "通过与人口行为比较检测异常活动。", - "xpack.ml.newJob.wizard.jobType.populationTitle": "填充", - "xpack.ml.newJob.wizard.jobType.savedSearchPageTitleLabel": "已保存搜索 {savedSearchTitle}", - "xpack.ml.newJob.wizard.jobType.selectDifferentIndexLinkText": "选择其他索引", - "xpack.ml.newJob.wizard.jobType.singleMetricAriaLabel": "单一指标作业", - "xpack.ml.newJob.wizard.jobType.singleMetricDescription": "检测单个时序中的异常。", - "xpack.ml.newJob.wizard.jobType.singleMetricTitle": "单一指标", - "xpack.ml.newJob.wizard.jobType.useSuppliedConfigurationDescription": "数据中的字段已被识别为匹配已知配置。选择并创建一组 Machine Learning 作业和关联的仪表板。", - "xpack.ml.newJob.wizard.jobType.useSuppliedConfigurationTitle": "使用提供的配置", - "xpack.ml.newJob.wizard.jobType.useWizardDescription": "使用其中一个向导创建 Machine Learning 作业,以查找数据中的异常。", - "xpack.ml.newJob.wizard.jobType.useWizardTitle": "使用向导", - "xpack.ml.privilege.licenseHasExpiredTooltip": "您的许可证已过期。", - "xpack.ml.privilege.noPermission.createCalendarsTooltip": "您没有权限创建日历。", - "xpack.ml.privilege.noPermission.createMLJobsTooltip": "您没有权限创建 Machine Learning 作业。", - "xpack.ml.privilege.noPermission.deleteCalendarsTooltip": "您没有权限删除日历。", - "xpack.ml.privilege.noPermission.deleteJobsTooltip": "您没有权限删除作业。", - "xpack.ml.privilege.noPermission.editJobsTooltip": "您没有权限编辑作业。", - "xpack.ml.privilege.noPermission.runForecastsTooltip": "您没有权限运行预测。", - "xpack.ml.privilege.noPermission.startOrStopDatafeedsTooltip": "您没有权限开始或停止数据馈送。", - "xpack.ml.privilege.pleaseContactAdministratorTooltip": "{message}请联系您的管理员。", - "xpack.ml.routes.annotations.annotationsFeatureUnavailableErrorMessage": "尚未创建或当前用户无法访问注释功能所需的索引和别名。", - "xpack.ml.ruleEditor.actionsSection.chooseActionsDescription": "选择在规则匹配异常时要采取的操作。", - "xpack.ml.ruleEditor.actionsSection.resultWillNotBeCreatedTooltip": "将不会创建结果。", - "xpack.ml.ruleEditor.actionsSection.skipModelUpdateLabel": "跳过模型更新", - "xpack.ml.ruleEditor.actionsSection.skipResultLabel": "跳过结果(建议)", - "xpack.ml.ruleEditor.actionsSection.valueWillNotBeUsedToUpdateModelTooltip": "该序列的值将不用于更新模型。", - "xpack.ml.ruleEditor.actualAppliesTypeText": "实际", - "xpack.ml.ruleEditor.addValueToFilterListLinkText": "将 {fieldValue} 添加到 {filterId}", - "xpack.ml.ruleEditor.conditionExpression.appliesToButtonLabel": "当", - "xpack.ml.ruleEditor.conditionExpression.appliesToPopoverTitle": "当", - "xpack.ml.ruleEditor.conditionExpression.deleteConditionButtonAriaLabel": "删除条件", - "xpack.ml.ruleEditor.conditionExpression.operatorValueButtonLabel": "是 {operator}", - "xpack.ml.ruleEditor.conditionExpression.operatorValuePopoverTitle": "是", - "xpack.ml.ruleEditor.conditionsSection.addNewConditionButtonLabel": "添加新条件", - "xpack.ml.ruleEditor.deleteJobRule.ruleNoLongerExistsErrorMessage": "作业 {jobId} 中不再存在检测工具索引 {detectorIndex} 的规则", - "xpack.ml.ruleEditor.deleteRuleModal.cancelButtonLabel": "取消", - "xpack.ml.ruleEditor.deleteRuleModal.deleteButtonLabel": "删除", - "xpack.ml.ruleEditor.deleteRuleModal.deleteRuleDescription": "是否确定要删除此规则?", - "xpack.ml.ruleEditor.deleteRuleModal.deleteRuleLinkText": "删除规则", - "xpack.ml.ruleEditor.deleteRuleModal.deleteRuleTitle": "删除规则", - "xpack.ml.ruleEditor.detectorDescriptionList.detectorTitle": "检测工具", - "xpack.ml.ruleEditor.detectorDescriptionList.jobIdTitle": "作业 ID", - "xpack.ml.ruleEditor.detectorDescriptionList.selectedAnomalyDescription": "实际 {actual}典型 {typical}", - "xpack.ml.ruleEditor.detectorDescriptionList.selectedAnomalyTitle": "已选异常", - "xpack.ml.ruleEditor.diffFromTypicalAppliesTypeText": "与典型的差异", - "xpack.ml.ruleEditor.editConditionLink.enterNumericValueForConditionAriaLabel": "输入条件的数值", - "xpack.ml.ruleEditor.editConditionLink.enterValuePlaceholder": "输入值", - "xpack.ml.ruleEditor.editConditionLink.updateLinkText": "更新", - "xpack.ml.ruleEditor.editConditionLink.updateRuleConditionFromText": "将规则条件从 {conditionValue} 更新为", - "xpack.ml.ruleEditor.excludeFilterTypeText": "不含于", - "xpack.ml.ruleEditor.greaterThanOperatorTypeText": "大于", - "xpack.ml.ruleEditor.greaterThanOrEqualToOperatorTypeText": "大于或等于", - "xpack.ml.ruleEditor.includeFilterTypeText": "传入", - "xpack.ml.ruleEditor.lessThanOperatorTypeText": "小于", - "xpack.ml.ruleEditor.lessThanOrEqualToOperatorTypeText": "小于或等于", - "xpack.ml.ruleEditor.ruleActionPanel.editRuleLinkText": "编辑规则", - "xpack.ml.ruleEditor.ruleActionPanel.ruleTitle": "规则", - "xpack.ml.ruleEditor.ruleDescription": "当{conditions}{filters} 时,跳过{actions}", - "xpack.ml.ruleEditor.ruleDescription.conditionsText": "{appliesTo} {operator} {value}", - "xpack.ml.ruleEditor.ruleDescription.filtersText": "{fieldName} 为 {filterType} {filterId}", - "xpack.ml.ruleEditor.ruleDescription.modelUpdateActionTypeText": "模型更新", - "xpack.ml.ruleEditor.ruleDescription.resultActionTypeText": "结果", - "xpack.ml.ruleEditor.ruleEditorFlyout.actionTitle": "操作", - "xpack.ml.ruleEditor.ruleEditorFlyout.addedItemToFilterListNotificationMessageDescription": "注意,更改将仅对新结果有效。", - "xpack.ml.ruleEditor.ruleEditorFlyout.addedItemToFilterListNotificationMessageTitle": "已将 {item} 添加到 {filterId}", - "xpack.ml.ruleEditor.ruleEditorFlyout.changesToJobDetectorRulesSavedNotificationMessageDescription": "注意,更改将仅对新结果有效。", - "xpack.ml.ruleEditor.ruleEditorFlyout.changesToJobDetectorRulesSavedNotificationMessageTitle": "对 {jobId} 检测工具规则的更改已保存", - "xpack.ml.ruleEditor.ruleEditorFlyout.closeButtonLabel": "关闭", - "xpack.ml.ruleEditor.ruleEditorFlyout.conditionsDescription": "添加应用规则的数值条件。多个条件可使用 AND 进行组合。", - "xpack.ml.ruleEditor.ruleEditorFlyout.conditionsNotSupportedTitle": "使用 {functionName} 函数的检测工具不支持条件", - "xpack.ml.ruleEditor.ruleEditorFlyout.conditionsTitle": "条件", - "xpack.ml.ruleEditor.ruleEditorFlyout.createRuleTitle": "创建规则", - "xpack.ml.ruleEditor.ruleEditorFlyout.editRulesTitle": "编辑规则", - "xpack.ml.ruleEditor.ruleEditorFlyout.editRuleTitle": "编辑规则", - "xpack.ml.ruleEditor.ruleEditorFlyout.errorWithAddingItemToFilterListNotificationMessage": "将 {item} 添加到筛选 {filterId} 时出错", - "xpack.ml.ruleEditor.ruleEditorFlyout.errorWithDeletingRuleFromJobDetectorNotificationMessage": "从 {jobId} 检测工具删除规则时出错", - "xpack.ml.ruleEditor.ruleEditorFlyout.errorWithLoadingFilterListsNotificationMesssage": "加载规则范围中使用的筛选列表时出错", - "xpack.ml.ruleEditor.ruleEditorFlyout.errorWithSavingChangesToJobDetectorRulesNotificationMessage": "保存对 {jobId} 检测工具规则的更改时出错", - "xpack.ml.ruleEditor.ruleEditorFlyout.howToApplyChangesToExistingResultsDescription": "要将这些更改应用到现有结果,必须克隆并重新运行作业。注意,重新运行作业可能会花费些时间,应在完成对此作业的规则的所有更改后再重新运行作业。", - "xpack.ml.ruleEditor.ruleEditorFlyout.rerunJobTitle": "重新运行作业", - "xpack.ml.ruleEditor.ruleEditorFlyout.ruleDeletedFromJobDetectorNotificationMessage": "规则已从 {jobId} 检测工具删除", - "xpack.ml.ruleEditor.ruleEditorFlyout.rulesDescription": "规则指示异常检测工具基于您提供的域特定知识更改其行为。创建规则时,您可以指定条件、范围和操作。满足规则的条件时,将会触发其操作。{learnMoreLink}", - "xpack.ml.ruleEditor.ruleEditorFlyout.rulesDescription.learnMoreLinkText": "了解详情", - "xpack.ml.ruleEditor.ruleEditorFlyout.saveButtonLabel": "保存", - "xpack.ml.ruleEditor.ruleEditorFlyout.unableToConfigureRulesNotificationMesssage": "无法配置规则,因为获取作业 ID {jobId} 的详细信息时出错", - "xpack.ml.ruleEditor.ruleEditorFlyout.whenChangesTakeEffectDescription": "对规则的更改仅对新结果有效。", - "xpack.ml.ruleEditor.scopeExpression.scopeFieldWhenLabel": "当", - "xpack.ml.ruleEditor.scopeExpression.scopeFilterTypeButtonLabel": "是 {filterType}", - "xpack.ml.ruleEditor.scopeExpression.scopeFilterTypePopoverTitle": "是", - "xpack.ml.ruleEditor.scopeSection.addFilterListLabel": "添加筛选列表可限制规则的应用位置。", - "xpack.ml.ruleEditor.scopeSection.createFilterListsDescription": "要配置范围,必须首先使用 “{filterListsLink}” 设置页面创建要在规则中包括或排除的值。", - "xpack.ml.ruleEditor.scopeSection.createFilterListsDescription.filterListsLinkText": "筛选列表", - "xpack.ml.ruleEditor.scopeSection.noFilterListsConfiguredTitle": "未配置任何筛选列表", - "xpack.ml.ruleEditor.scopeSection.noPermissionToViewFilterListsTitle": "您无权查看筛选列表", - "xpack.ml.ruleEditor.scopeSection.scopeTitle": "范围", - "xpack.ml.ruleEditor.selectRuleAction.createRuleLinkText": "创建规则", - "xpack.ml.ruleEditor.selectRuleAction.orText": "或 ", - "xpack.ml.ruleEditor.typicalAppliesTypeText": "典型", - "xpack.ml.sampleDataLinkLabel": "ML 作业", - "xpack.ml.settings.breadcrumbs.calendarManagement.createLabel": "创建", - "xpack.ml.settings.breadcrumbs.calendarManagement.editLabel": "编辑", - "xpack.ml.settings.breadcrumbs.calendarManagementLabel": "日历管理", - "xpack.ml.settings.breadcrumbs.filterLists.createLabel": "创建", - "xpack.ml.settings.breadcrumbs.filterLists.editLabel": "编辑", - "xpack.ml.settings.breadcrumbs.filterListsLabel": "筛选列表", - "xpack.ml.settings.calendarManagementButtonLabel": "日历管理", - "xpack.ml.settings.calendars.listHeader.calendarsDescription": "日志包含不想生成异常的已计划事件列表,例如已计划系统中断或公共假期。同一日历可分配给多个作业。{br}{learnMoreLink}", - "xpack.ml.settings.calendars.listHeader.calendarsDescription.learnMoreLinkText": "了解详情", - "xpack.ml.settings.calendars.listHeader.calendarsListTotalCount": "合计 {totalCount}", - "xpack.ml.settings.calendars.listHeader.calendarsTitle": "日历", - "xpack.ml.settings.calendars.listHeader.refreshButtonLabel": "刷新", - "xpack.ml.settings.filterLists.addItemPopover.addButtonLabel": "添加", - "xpack.ml.settings.filterLists.addItemPopover.addItemButtonLabel": "添加项", - "xpack.ml.settings.filterLists.addItemPopover.enterItemPerLineDescription": "每行输入一个项", - "xpack.ml.settings.filterLists.addItemPopover.itemsLabel": "项", - "xpack.ml.settings.filterLists.deleteFilterListModal.cancelButtonLabel": "取消", - "xpack.ml.settings.filterLists.deleteFilterListModal.confirmButtonLabel": "删除", - "xpack.ml.settings.filterLists.deleteFilterListModal.deleteButtonLabel": "删除", - "xpack.ml.settings.filterLists.deleteFilterListModal.deleteWarningMessage": "是否确定要删除{selectedFilterListsLength, plural, one {此筛选列表} other {这些筛选列表}}", - "xpack.ml.settings.filterLists.deleteFilterListModal.modalTitle": "删除 {selectedFilterListsLength, plural, one {{selectedFilterId}} other {# 个筛选列表}}", - "xpack.ml.settings.filterLists.deleteFilterLists.deletingErrorMessage": "删除筛选列表 {filterListId} 时出错。{respMessage}", - "xpack.ml.settings.filterLists.deleteFilterLists.deletingNotificationMessage": "正在删除 {filterListsToDeleteLength, plural, one {{filterListToDeleteId}} other {# 个筛选列表}}", - "xpack.ml.settings.filterLists.deleteFilterLists.filtersSuccessfullyDeletedNotificationMessage": "已删除 {filterListsToDeleteLength, plural, one {{filterListToDeleteId}} other {# 个筛选列表}}", - "xpack.ml.settings.filterLists.editDescriptionPopover.editDescriptionAriaLabel": "编辑描述", - "xpack.ml.settings.filterLists.editDescriptionPopover.filterListDescriptionAriaLabel": "筛选列表描述", - "xpack.ml.settings.filterLists.editFilterHeader.allowedCharactersDescription": "使用小写字母数字(a-z 和 0-9)、连字符或下划线;必须以字母数字字符开头和结尾", - "xpack.ml.settings.filterLists.editFilterHeader.createFilterListTitle": "新建筛选列表", - "xpack.ml.settings.filterLists.editFilterHeader.filterListIdAriaLabel": "筛选列表 ID", - "xpack.ml.settings.filterLists.editFilterHeader.filterListTitle": "筛选列表 {filterId}", - "xpack.ml.settings.filterLists.editFilterList.acrossText": "到", - "xpack.ml.settings.filterLists.editFilterList.addDescriptionText": "添加描述", - "xpack.ml.settings.filterLists.editFilterList.cancelButtonLabel": "取消", - "xpack.ml.settings.filterLists.editFilterList.duplicatedItemsInFilterListWarningMessage": "以下项已存在于筛选列表中:{alreadyInFilter}", - "xpack.ml.settings.filterLists.editFilterList.filterIsNotUsedInJobsDescription": "没有作业使用此筛选列表。", - "xpack.ml.settings.filterLists.editFilterList.filterIsUsedInJobsDescription": "此筛选列表用于", - "xpack.ml.settings.filterLists.editFilterList.loadingDetailsOfFilterErrorMessage": "加载筛选 {filterId} 详情时出错", - "xpack.ml.settings.filterLists.editFilterList.saveButtonLabel": "保存", - "xpack.ml.settings.filterLists.editFilterList.savingFilterErrorMessage": "保存筛选 {filterId} 时出错", - "xpack.ml.settings.filterLists.editFilterList.totalItemsDescription": "共 {totalItemCount, plural, one {# 个项} other {# 个项}}", - "xpack.ml.settings.filterLists.filterLists.loadingFilterListsErrorMessage": "加载筛选列表时出错", - "xpack.ml.settings.filterLists.filterWithIdExistsErrorMessage": "ID 为 {filterId} 的筛选已存在", - "xpack.ml.settings.filterLists.listHeader.filterListsContainsNotAllowedValuesDescription": "筛选列表包含可用于在 Machine Learning 分析中包含或排除事件的值。您可以在多个作业中使用相同的筛选列表。{br}{learnMoreLink}", - "xpack.ml.settings.filterLists.listHeader.filterListsContainsNotAllowedValuesDescription.learnMoreLinkText": "了解详情", - "xpack.ml.settings.filterLists.listHeader.filterListsDescription": "合计 {totalCount}", - "xpack.ml.settings.filterLists.listHeader.filterListsTitle": "筛选列表", - "xpack.ml.settings.filterLists.listHeader.refreshButtonLabel": "刷新", - "xpack.ml.settings.filterLists.table.descriptionColumnName": "描述", - "xpack.ml.settings.filterLists.table.idColumnName": "ID", - "xpack.ml.settings.filterLists.table.inUseAriaLabel": "使用中", - "xpack.ml.settings.filterLists.table.inUseColumnName": "使用中", - "xpack.ml.settings.filterLists.table.itemCountColumnName": "项计数", - "xpack.ml.settings.filterLists.table.newButtonLabel": "新建", - "xpack.ml.settings.filterLists.table.noFiltersCreatedTitle": "未创建任何筛选", - "xpack.ml.settings.filterLists.table.notInUseAriaLabel": "未在使用", - "xpack.ml.settings.filterLists.toolbar.deleteItemButtonLabel": "删除项", - "xpack.ml.settings.filterListsButtonLabel": "筛选列表", - "xpack.ml.settings.jobManagementTitle": "作业管理", - "xpack.ml.singleMetricViewerPageLabel": "Single Metric Viewer", - "xpack.ml.timeSeriesExplorer.allPartitionValuesLabel": "全部", - "xpack.ml.timeSeriesExplorer.annotationDescriptionList.createdByTitle": "创建者", - "xpack.ml.timeSeriesExplorer.annotationDescriptionList.createdTitle": "创建于", - "xpack.ml.timeSeriesExplorer.annotationDescriptionList.endTitle": "结束", - "xpack.ml.timeSeriesExplorer.annotationDescriptionList.jobIdTitle": "作业 ID", - "xpack.ml.timeSeriesExplorer.annotationDescriptionList.lastModifiedTitle": "最后修改时间", - "xpack.ml.timeSeriesExplorer.annotationDescriptionList.modifiedByTitle": "修改者", - "xpack.ml.timeSeriesExplorer.annotationDescriptionList.startTitle": "开始", - "xpack.ml.timeSeriesExplorer.annotationFlyout.addAnnotationTitle": "添加注释", - "xpack.ml.timeSeriesExplorer.annotationFlyout.annotationTextLabel": "注释文本", - "xpack.ml.timeSeriesExplorer.annotationFlyout.approachingMaxLengthWarning": "还剩 {charsRemaining, number} {charsRemaining, plural, one {个字符} other {个字符}}", - "xpack.ml.timeSeriesExplorer.annotationFlyout.cancelButtonLabel": "取消", - "xpack.ml.timeSeriesExplorer.annotationFlyout.createButtonLabel": "创建", - "xpack.ml.timeSeriesExplorer.annotationFlyout.deleteButtonLabel": "删除", - "xpack.ml.timeSeriesExplorer.annotationFlyout.editAnnotationTitle": "编辑注释", - "xpack.ml.timeSeriesExplorer.annotationFlyout.maxLengthError": "超过最大长度 ({maxChars} 个字符) {charsOver, number} {charsOver, plural, one {个字符} other {}}", - "xpack.ml.timeSeriesExplorer.annotationFlyout.noAnnotationTextError": "输入注释文本", - "xpack.ml.timeSeriesExplorer.annotationFlyout.updateButtonLabel": "更新", - "xpack.ml.timeSeriesExplorer.annotationsLabel": "注释", - "xpack.ml.timeSeriesExplorer.annotationsTitle": "注释", - "xpack.ml.timeSeriesExplorer.anomaliesTitle": "异常", - "xpack.ml.timeSeriesExplorer.autoSelectingFirstJobText": ",自动选择第一个作业", - "xpack.ml.timeSeriesExplorer.canNotViewRequestedJobsWarningMessage": "您无法在此仪表板中查看请求的 {invalidIdsCount, plural, one {作业} other {作业}} {invalidIds}", - "xpack.ml.timeSeriesExplorer.countDataInChartDetailsDescription": "{openBrace}{cardinalityValue} 个不同 {fieldName} {cardinality, plural, one {} other {值}}{closeBrace}", - "xpack.ml.timeSeriesExplorer.createNewSingleMetricJobLinkText": "创建新的单指标作业", - "xpack.ml.timeSeriesExplorer.dataNotChartableDescription": "没有为选定{entityCount, plural, one {实体} other {实体}}收集模型绘图\n,无法为此检测工具绘制源数据。", - "xpack.ml.timeSeriesExplorer.deleteAnnotationModal.cancelButtonLabel": "取消", - "xpack.ml.timeSeriesExplorer.deleteAnnotationModal.deleteAnnotationTitle": "删除此注释?", - "xpack.ml.timeSeriesExplorer.deleteAnnotationModal.deleteButtonLabel": "删除", - "xpack.ml.timeSeriesExplorer.detectorLabel": "检测工具", - "xpack.ml.timeSeriesExplorer.enterValuePlaceholder": "输入值", - "xpack.ml.timeSeriesExplorer.forecastingModal.closeButtonLabel": "关闭", - "xpack.ml.timeSeriesExplorer.forecastingModal.closingJobTitle": "正在关闭作业……", - "xpack.ml.timeSeriesExplorer.forecastingModal.dataContainsMorePartitionsMessage": "注意,此数据包含 {warnNumPartitions} 个以上分区,因此运行预测可能会花费很长时间,并消耗大量的资源", - "xpack.ml.timeSeriesExplorer.forecastingModal.errorWithClosingJobAfterRunningForecastErrorMessage": "运行预测后关闭作业时出错", - "xpack.ml.timeSeriesExplorer.forecastingModal.errorWithClosingJobErrorMessage": "关闭作业时出错", - "xpack.ml.timeSeriesExplorer.forecastingModal.errorWithLoadingStatsOfRunningForecastErrorMessage": "加载正在运行的预测的统计信息时出错。", - "xpack.ml.timeSeriesExplorer.forecastingModal.errorWithObtainingListOfPreviousForecastsErrorMessage": "获取之前的预测时出错", - "xpack.ml.timeSeriesExplorer.forecastingModal.errorWithOpeningJobBeforeRunningForecastErrorMessage": "在运行预测之前打开作业时出错", - "xpack.ml.timeSeriesExplorer.forecastingModal.forecastButtonLabel": "预测", - "xpack.ml.timeSeriesExplorer.forecastingModal.forecastDurationMustNotBeGreaterThanMaximumErrorMessage": "预测持续时间不得大于 {maximumForecastDurationDays} 天", - "xpack.ml.timeSeriesExplorer.forecastingModal.forecastDurationMustNotBeZeroErrorMessage": "预测持续时间不得为零", - "xpack.ml.timeSeriesExplorer.forecastingModal.forecastingNotAvailableForPopulationDetectorsMessage": "预测不可用于具有 over 字段的人口检测工具", - "xpack.ml.timeSeriesExplorer.forecastingModal.forecastingOnlyAvailableForJobsCreatedInSpecifiedVersionMessage": "预测仅可用于在版本 {minVersion} 或更高版本中创建的作业", - "xpack.ml.timeSeriesExplorer.forecastingModal.forecastingTitle": "预测", - "xpack.ml.timeSeriesExplorer.forecastingModal.invalidDurationFormatErrorMessage": "持续时间格式无效", - "xpack.ml.timeSeriesExplorer.forecastingModal.noProgressReportedForNewForecastErrorMessage": "有 {WarnNoProgressMs}ms 未报告新预测的进度。运行预测时可能发生了错误。", - "xpack.ml.timeSeriesExplorer.forecastingModal.openingJobTitle": "正在打开作业……", - "xpack.ml.timeSeriesExplorer.forecastingModal.runningForecastTitle": "正在运行预测……", - "xpack.ml.timeSeriesExplorer.forecastingModal.unexpectedResponseFromRunningForecastErrorMessage": "正在运行的预测有意外响应。请求可能已失败。", - "xpack.ml.timeSeriesExplorer.forecastsList.createdColumnName": "创建于", - "xpack.ml.timeSeriesExplorer.forecastsList.fromColumnName": "从", - "xpack.ml.timeSeriesExplorer.forecastsList.listsOfFiveRecentlyRunForecastsTooltip": "最多列出五个最近运行的预测。", - "xpack.ml.timeSeriesExplorer.forecastsList.previousForecastsTitle": "以前的预测", - "xpack.ml.timeSeriesExplorer.forecastsList.toColumnName": "到", - "xpack.ml.timeSeriesExplorer.forecastsList.viewColumnName": "查看", - "xpack.ml.timeSeriesExplorer.forecastsList.viewForecastAriaLabel": "查看在 {createdDate} 创建的预测", - "xpack.ml.timeSeriesExplorer.intervalLabel": "时间间隔", - "xpack.ml.timeSeriesExplorer.loadingLabel": "正在加载", - "xpack.ml.timeSeriesExplorer.noResultsFoundLabel": "找不到结果", - "xpack.ml.timeSeriesExplorer.noSingleMetricJobsFoundLabel": "未找到单指标作业", - "xpack.ml.timeSeriesExplorer.requestedDetectorIndexNotValidWarningMessage": "请求的检测工具索引 {detectorIndex} 对于作业 {jobId} 无效", - "xpack.ml.timeSeriesExplorer.runControls.durationLabel": "持续时间", - "xpack.ml.timeSeriesExplorer.runControls.forecastMaximumLengthHelpText": "预测时长,最多 {maximumForecastDurationDays} 天。使用 s 表示秒,m 表示分钟,h 表示小时,d 表示天,w 表示周。", - "xpack.ml.timeSeriesExplorer.runControls.forecastsCanNotBeRunOnJobsTooltip": "{jobState} 作业上不能运行预测", - "xpack.ml.timeSeriesExplorer.runControls.noMLNodesAvailableTooltip": "没有可用的 ML 节点。", - "xpack.ml.timeSeriesExplorer.runControls.runButtonLabel": "运行", - "xpack.ml.timeSeriesExplorer.runControls.runNewForecastTitle": "运行新的预测", - "xpack.ml.timeSeriesExplorer.severityThresholdLabel": "严重性阈值", - "xpack.ml.timeSeriesExplorer.showForecastLabel": "显示预测", - "xpack.ml.timeSeriesExplorer.showModelBoundsLabel": "显示模型边界", - "xpack.ml.timeSeriesExplorer.singleTimeSeriesAnalysisTitle": "{functionLabel} 的单时间序列分析", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.addedAnnotationNotificationMessage": "已为 ID {jobId} 的作业添加注释。", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.deletedAnnotationNotificationMessage": "已为 ID {jobId} 的作业删除注释。", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.errorWithCreatingAnnotationNotificationErrorMessage": "为 ID {jobId} 的作业创建注释时发生错误:{error}", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.errorWithDeletingAnnotationNotificationErrorMessage": "为 ID {jobId} 的作业删除注释时发生错误:{error}", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.errorWithUpdatingAnnotationNotificationErrorMessage": "为 ID {jobId} 的作业更新注释时发生错误:{error}", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.modelBoundsNotAvailableLabel": "模型边界不可用", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.updatedAnnotationNotificationMessage": "已为 ID {jobId} 的作业更新注释。", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.zoomAggregationIntervalLabel": "(聚合时间间隔:{focusAggInt},存储桶跨度:{bucketSpan})", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.zoomGroupAggregationIntervalLabel": "(聚合时间间隔:,存储桶跨度:)", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.zoomLabel": "缩放:", - "xpack.ml.timeSeriesExplorer.tryWideningTheTimeSelectionDescription": "请尝试扩大时间选择范围或进一步向后追溯。", - "xpack.ml.timeSeriesExplorer.youCanViewOneJobAtTimeWarningMessage": "在此仪表板中,一次仅可以查看一个作业", - "xpack.ml.tooltips.newJobDedicatedIndexTooltip": "选择可将结果存储在此作业的不同索引中。", - "xpack.ml.tooltips.newJobRecognizerJobPrefixTooltip": "将添加到每个作业 ID 开头的前缀。", - "xpack.ml.upgrade.upgradeWarning.upgradeInProgressWarningDescription": "当前正在升级与 Machine Learning 相关的索引。", - "xpack.ml.upgrade.upgradeWarning.upgradeInProgressWarningDescriptionExtra": "此次某些操作不可用。", - "xpack.ml.upgrade.upgradeWarning.upgradeInProgressWarningTitle": "正在进行索引迁移。", - "xpack.ml.validateJob.learnMoreLinkText": "了解详情", - "xpack.ml.validateJob.modal.closeButtonLabel": "关闭", - "xpack.ml.validateJob.modal.jobValidationDescriptionText": "作业验证对作业配置和基础源数据执行特定检查,并提供特定建议,让您了解如何调整设置,才更有可能产生有深刻洞察力的结果。", - "xpack.ml.validateJob.modal.linkToJobTipsText": "有关更多信息,请参阅 {mlJobTipsLink}。", - "xpack.ml.validateJob.modal.linkToJobTipsText.mlJobTipsLinkText": "Machine Learning 作业提示", - "xpack.ml.validateJob.modal.validateJobTitle": "验证作业 {title}", - "xpack.ml.validateJob.validateJobButtonLabel": "验证作业", - "xpack.ml.dataframe.analytics.create.advancedEditor.codeEditorAriaLabel": "高级分析作业编辑器", - "xpack.ml.dataframe.analytics.create.advancedEditor.configRequestBody": "配置请求正文", - "xpack.ml.dataframe.analytics.create.advancedEditor.jobIdExistsError": "已存在具有此 ID 的分析作业。", - "xpack.ml.dataframe.analytics.create.advancedEditor.jobIdInputAriaLabel": "选择唯一的分析作业 ID。", - "xpack.ml.dataframe.analytics.create.advancedEditor.jobIdInvalidError": "只能包含小写字母数字字符(a-z 和 0-9)、连字符和下划线,并且必须以字母数字字符开头和结尾。", - "xpack.ml.dataframe.analytics.create.advancedEditor.jobIdLabel": "分析作业 ID", - "xpack.ml.dataframe.analytics.create.advancedEditorMessage.destinationIndexNameEmpty": "目标索引名称不得为空。", - "xpack.ml.dataframe.analytics.create.advancedEditorMessage.destinationIndexNameValid": "目标索引名称无效。", - "xpack.ml.dataframe.analytics.create.advancedEditorMessage.sourceIndexNameEmpty": "源索引名称不得为空。", - "xpack.ml.dataframe.analytics.create.advancedEditorMessage.sourceIndexNameValid": "源索引名称无效。", - "xpack.ml.dataframe.analytics.create.createIndexPatternErrorMessage": "创建 Kibana 索引模式时发生错误:", - "xpack.ml.dataframe.analytics.create.createIndexPatternLabel": "创建索引模式", - "xpack.ml.dataframe.analytics.create.createIndexPatternSuccessMessage": "Kibana 索引模式 {indexPatternName} 已创建。", - "xpack.ml.dataframe.analytics.create.destinationIndexHelpText": "已存在具有此名称的索引。请注意,运行此分析作业将会修改此目标索引。", - "xpack.ml.dataframe.analytics.create.destinationIndexInputAriaLabel": "选择唯一目标索引名称。", - "xpack.ml.dataframe.analytics.create.destinationIndexInvalidError": "目标索引名称无效。", - "xpack.ml.dataframe.analytics.create.destinationIndexLabel": "目标 IP", - "xpack.ml.dataframe.analytics.create.duplicateIndexPatternErrorMessage": "创建 Kibana 索引模式时发生错误:", - "xpack.ml.dataframe.analytics.create.duplicateIndexPatternErrorMessageError": "索引模式 {indexPatternName} 已存在。", - "xpack.ml.dataframe.analytics.create.errorCreatingDataFrameAnalyticsJob": "创建数据帧分析作业时发生错误:", - "xpack.ml.dataframe.analytics.create.errorGettingDataFrameAnalyticsList": "获取现有数据帧分析作业 ID 时发生错误:", - "xpack.ml.dataframe.analytics.create.errorGettingDataFrameIndexNames": "获取现有索引名称时发生错误:", - "xpack.ml.dataframe.analytics.create.errorGettingIndexPatternTitles": "获取现有索引模式标题时发生错误:", - "xpack.ml.dataframe.analytics.create.errorStartingDataFrameAnalyticsJob": "启动数据帧分析作业时发生错误:", - "xpack.ml.dataframe.analytics.create.jobIdExistsError": "已存在具有此 ID 的分析作业。", - "xpack.ml.dataframe.analytics.create.jobIdInputAriaLabel": "选择唯一的分析作业 ID。", - "xpack.ml.dataframe.analytics.create.jobIdInvalidError": "只能包含小写字母数字字符(a-z 和 0-9)、连字符和下划线,并且必须以字母数字字符开头和结尾。", - "xpack.ml.dataframe.analytics.create.jobIdLabel": "作业 ID", - "xpack.ml.dataframe.analytics.create.jobIdPlaceholder": "作业 ID", - "xpack.ml.dataframe.analytics.create.jobTypeLabel": "作业类型", - "xpack.ml.dataframe.analytics.create.sourceIndexHelpText": "此索引模式不包含任何数值类型字段。分析作业可能无法提供任何离群值。", - "xpack.ml.dataframe.analytics.create.sourceIndexInputAriaLabel": "源索引模式或搜索。", - "xpack.ml.dataframe.analytics.create.sourceIndexInvalidError": "源索引名称无效,其不能包含空格或以下字符:{characterList}", - "xpack.ml.dataframe.analytics.create.sourceIndexLabel": "源索引", - "xpack.ml.dataframe.analytics.create.sourceIndexPlaceholder": "选择源索引模式或已保存搜索。", - "xpack.ml.dataframe.analytics.create.startDataFrameAnalyticsSuccessMessage": "数据帧分析 {jobId} 启动请求已确认。", - "xpack.ml.dataframe.analytics.exploration.experimentalBadgeLabel": "实验性", - "xpack.ml.dataframe.analytics.exploration.experimentalBadgeTooltipContent": "数据帧分析为实验功能。我们很乐意听取您的反馈意见。", - "xpack.ml.dataframe.analytics.exploration.fieldSelection": "已选择 {selectedFieldsLength, number} 个{docFieldsCount, plural, one {字段} other {字段}},共 {docFieldsCount, number} 个", - "xpack.ml.dataframe.analytics.exploration.indexArrayBadgeContent": "数组", - "xpack.ml.dataframe.analytics.exploration.indexArrayToolTipContent": "无法显示此基于数组的列的完整内容。", - "xpack.ml.dataframe.analytics.exploration.indexError": "加载索引数据时出错。", - "xpack.ml.dataframe.analytics.exploration.indexObjectBadgeContent": "对象", - "xpack.ml.dataframe.analytics.exploration.indexObjectToolTipContent": "无法显示此基于对象的列的完整内容。", - "xpack.ml.dataframe.analytics.exploration.jobIdTitle": "作业 ID {jobId}", - "xpack.ml.dataframe.analytics.exploration.noDataCalloutBody": "该索引的查询未返回结果。请确保索引包含文档且您的查询限制不过于严格。", - "xpack.ml.dataframe.analytics.exploration.selectColumnsAriaLabel": "选择列", - "xpack.ml.dataframe.analytics.exploration.selectFieldsPopoverTitle": "选择字段", - "xpack.ml.dataframe.analytics.exploration.title": "分析浏览", - "xpack.ml.dataframe.analyticsList.completeBatchAnalyticsToolTip": "{analyticsId} 为已完成的分析作业,无法重新启动。", - "xpack.ml.dataframe.analyticsList.createDataFrameAnalyticsButton": "创建分析作业", - "xpack.ml.dataframe.analyticsList.deleteActionDisabledToolTipContent": "停止数据帧分析,才能将其删除。", - "xpack.ml.dataframe.analyticsList.deleteActionName": "删除", - "xpack.ml.dataframe.analyticsList.deleteAnalyticsErrorMessage": "删除数据帧分析 {analyticsId} 时发生错误:{error}", - "xpack.ml.dataframe.analyticsList.deleteAnalyticsSuccessMessage": "数据帧分析 {analyticsId} 删除请求已确认。", - "xpack.ml.dataframe.analyticsList.deleteModalBody": "是否确定要删除此分析作业?分析作业的目标索引和可选 Kibana 索引模式将不会删除。", - "xpack.ml.dataframe.analyticsList.deleteModalCancelButton": "取消", - "xpack.ml.dataframe.analyticsList.deleteModalDeleteButton": "删除", - "xpack.ml.dataframe.analyticsList.deleteModalTitle": "删除 {analyticsId}", - "xpack.ml.dataframe.analyticsList.destinationIndex": "目标 IP", - "xpack.ml.dataFrame.analyticsList.emptyPromptButtonText": "创建您的首个数据帧分析作业", - "xpack.ml.dataFrame.analyticsList.emptyPromptTitle": "未找到任何数据帧分析作业", - "xpack.ml.dataFrame.analyticsList.errorPromptTitle": "获取数据帧分析列表时发生错误。", - "xpack.ml.dataframe.analyticsList.expandedRow.tabs.jobSettings.progress": "进度", - "xpack.ml.dataframe.analyticsList.expandedRow.tabs.jobSettings.state": "状态", - "xpack.ml.dataframe.analyticsList.expandedRow.tabs.jobSettings.stats": "统计", - "xpack.ml.dataframe.analyticsList.expandedRow.tabs.jobSettingsLabel": "作业详情", - "xpack.ml.dataframe.analyticsList.experimentalBadgeLabel": "实验性", - "xpack.ml.dataframe.analyticsList.experimentalBadgeTooltipContent": "数据帧分析为实验功能。我们很乐意听取您的反馈意见。", - "xpack.ml.dataframe.analyticsList.progress": "进度", - "xpack.ml.dataframe.analyticsList.refreshButtonLabel": "刷新", - "xpack.ml.dataframe.analyticsList.rowCollapse": "隐藏 {analyticsId} 的详情", - "xpack.ml.dataframe.analyticsList.rowExpand": "显示 {analyticsId} 的详情", - "xpack.ml.dataframe.analyticsList.sourceIndex": "源索引", - "xpack.ml.dataframe.analyticsList.startActionName": "开始", - "xpack.ml.dataframe.analyticsList.startAnalyticsErrorMessage": "启动数据帧分析 {analyticsId} 时发生错误:{error}", - "xpack.ml.dataframe.analyticsList.startAnalyticsSuccessMessage": "数据帧分析 {analyticsId} 启动请求已确认。", - "xpack.ml.dataframe.analyticsList.startModalBody": "数据帧分析作业将增加集群的搜索和索引负荷。如果负荷超载,请停止分析作业。是否确定要启动此分析作业?", - "xpack.ml.dataframe.analyticsList.startModalCancelButton": "取消", - "xpack.ml.dataframe.analyticsList.startModalStartButton": "开始", - "xpack.ml.dataframe.analyticsList.startModalTitle": "启动 {analyticsId}", - "xpack.ml.dataframe.analyticsList.status": "状态", - "xpack.ml.dataframe.analyticsList.statusFilter": "状态", - "xpack.ml.dataframe.analyticsList.stopActionName": "停止", - "xpack.ml.dataframe.analyticsList.stopAnalyticsErrorMessage": "停止数据帧分析 {analyticsId} 时发生错误:{error}", - "xpack.ml.dataframe.analyticsList.stopAnalyticsSuccessMessage": "数据帧分析 {analyticsId} 停止请求已确认。", - "xpack.ml.dataframe.analyticsList.tableActionLabel": "操作", - "xpack.ml.dataframe.analyticsList.title": "分析作业", - "xpack.ml.dataframe.analyticsList.type": "类型", - "xpack.ml.dataframe.analyticsList.viewActionName": "查看", - "xpack.ml.dataframe.analyticsList.viewAriaLabel": "查看", - "xpack.ml.datavisualizer.actionsPanel.advancedDescription": "使用全部选项为更高级的用例创建作业", - "xpack.ml.datavisualizer.actionsPanel.advancedTitle": "高级", - "xpack.ml.datavisualizer.actionsPanel.createJobDescription": "使用“高级作业”向导创建作业,以查找此数据中的异常:", - "xpack.ml.datavisualizer.actionsPanel.createJobTitle": "创建作业", - "xpack.ml.datavisualizer.dataLoader.internalServerErrorMessage": "加载索引 {index} 中的数据时出错。{message}。请求可能已超时。请尝试使用较小的样例大小或缩小时间范围。", - "xpack.ml.datavisualizer.fieldsPanel.fieldsCountDescription": "{wrappedCardsCount} {cardsCount, plural, one { 个字段存在} other { 个字段存在}}于文档中(共 {wrappedTotalFieldCount} 个)", - "xpack.ml.datavisualizer.fieldsPanel.filterFieldsPlaceholder": "筛选", - "xpack.ml.datavisualizer.fieldsPanel.searchBarError": "运行搜索时发生错误。{message}。", - "xpack.ml.datavisualizer.fieldsPanel.showAllCountDescription": "{wrappedCardsCount} {cardsCount, plural, one { 个字段} other { 个字段}}({wrappedPopulatedFieldCount} {populatedFieldCount, plural, one { 存在} other { 存在}}于文档中)", - "xpack.ml.datavisualizer.fieldsPanel.showEmptyFieldsLabel": "显示空字段", - "xpack.ml.datavisualizer.fieldTypesSelect.allFieldsTypeOptionLabel": "所有字段类型", - "xpack.ml.datavisualizer.fieldTypesSelect.selectAriaLabel": "选择要显示的字段类型", - "xpack.ml.datavisualizer.fieldTypesSelect.typeOptionLabel": "{fieldType} 类型", - "xpack.ml.datavisualizer.page.errorLoadingDataMessage": "加载索引 {index} 中的数据时出错。{message}", - "xpack.ml.datavisualizer.page.fieldsPanelTitle": "字段", - "xpack.ml.datavisualizer.page.metricsPanelTitle": "指标", - "xpack.ml.datavisualizer.searchPanel.allOptionLabel": "全部", - "xpack.ml.datavisualizer.searchPanel.documentsPerShardLabel": "每个分片的文档,共 {wrappedTotalCount} {totalCount, plural, one { 个文档 } other { 个文档}}", - "xpack.ml.datavisualizer.searchPanel.kqlEditOnlyLabel": "当前仅可以编辑 KQL 已保存搜索", - "xpack.ml.datavisualizer.searchPanel.queryBarPlaceholder": "选择较小的样例大小将减少查询运行时间和集群上的负载。", - "xpack.ml.datavisualizer.searchPanel.queryBarPlaceholderText": "搜索……(例如,status:200 AND extension:\"PHP\")", - "xpack.ml.datavisualizer.searchPanel.sampleLabel": "采样", - "xpack.ml.datavisualizer.searchPanel.sampleSizeAriaLabel": "选择要采样的文档数目", - "xpack.ml.dfAnalyticsList.analyticsDetails.messagesPane.errorMessage": "无法加载消息", - "xpack.ml.fieldDataCard.cardBoolean.documentsCountDescription": "{count, plural, zero {# 个文档} one {# 个文档} other {# 个文档}} ({docsPercent}%)", - "xpack.ml.fieldDataCard.cardDate.documentsCountDescription": "{count, plural, zero {# 个文档} one {# 个文档} other {# 个文档}} ({docsPercent}%)", - "xpack.ml.fieldDataCard.cardDate.earliestDescription": "最早的 {earliestFormatted}", - "xpack.ml.fieldDataCard.cardDate.latestDescription": "最新的 {latestFormatted}", - "xpack.ml.fieldDataCard.cardGeoPoint.distinctCountDescription": "{cardinality} 不同的 {cardinality, plural, zero {值} one {value} 其他 {values}}", - "xpack.ml.fieldDataCard.cardGeoPoint.documentsCountDescription": "{count, plural, zero {# 个文档} one {# 个文档} other {# 个文档}} ({docsPercent}%)", - "xpack.ml.fieldDataCard.cardIp.distinctCountDescription": "{cardinality} 不同的 {cardinality, plural, zero {值} one {value} 其他 {values}}", - "xpack.ml.fieldDataCard.cardIp.documentsCountDescription": "{count, plural, zero {# 个文档} one {# 个文档} other {# 个文档}} ({docsPercent}%)", - "xpack.ml.fieldDataCard.cardKeyword.distinctCountDescription": "{cardinality} 不同的 {cardinality, plural, zero {值} one {value} 其他 {values}}", - "xpack.ml.fieldDataCard.cardKeyword.documentsCountDescription": "{count, plural, zero {# 个文档} one {# 个文档} other {# 个文档}} ({docsPercent}%)", - "xpack.ml.fieldDataCard.cardNumber.displayingPercentilesLabel": "显示 {minPercent} - {maxPercent} 百分位数", - "xpack.ml.fieldDataCard.cardNumber.distinctCountDescription": "{cardinality} 不同的 {cardinality, plural, zero {值} one {value} 其他 {values}}", - "xpack.ml.fieldDataCard.cardNumber.documentsCountDescription": "{count, plural, zero {# 个文档} one {# 个文档} other {# 个文档}} ({docsPercent}%)", - "xpack.ml.fieldDataCard.cardNumber.selectMetricDetailsDisplayAriaLabel": "选择指标详情的显示选项", - "xpack.ml.fieldDataCard.cardOther.distinctCountDescription": "{cardinality} 不同的 {cardinality, plural, zero {值} one {value} 其他 {values}}", - "xpack.ml.fieldDataCard.cardOther.documentsCountDescription": "{count, plural, zero {# 个文档} one {# 个文档} other {# 个文档}} ({docsPercent}%)", - "xpack.ml.fieldDataCard.cardText.examplesTitle": "{numExamples, plural, one { 个值} other { 个示例}}", - "xpack.ml.fieldDataCard.cardText.fieldNotPresentDescription": "查询的文档的 {sourceParam} 字段中不存在此字段。", - "xpack.ml.fieldDataCard.cardText.noExamplesForFieldsTitle": "没有获取此字段的示例", - "xpack.ml.fieldDataCard.documentCountChart.seriesLabel": "文档计数", - "xpack.ml.fieldDataCard.fieldNotInDocsLabel": "此字段不会出现在所选时间范围的任何文档中", - "xpack.ml.fieldDataCard.metricDistributionChart.seriesName": "分布", - "xpack.ml.fieldDataCard.metricDistributionChart.tooltipValueBetweenLabel": "{percent}% 的文档具有介于 {minValFormatted} 和 {maxValFormatted} 之间的值", - "xpack.ml.fieldDataCard.metricDistributionChart.tooltipValueEqualLabel": "{percent}% 的文档的值为 {valFormatted}", - "xpack.ml.fieldDataCard.topValues.calculatedFromSampleDescription": "基于每个分片的 {topValuesSamplerShardSize} 文档样例计算", - "xpack.ml.jobSelector.noResultsForJobLabel": "无结果", - "xpack.ml.jobsList.analyticsSpacesLabel": "工作区", - "xpack.ml.jobsList.breadcrumb": "作业", - "xpack.ml.jobsList.jobDetails.datafeedTimingStatsTitle": "计时统计", - "xpack.ml.jobsList.spacesLabel": "工作区", - "xpack.ml.management.jobsList.accessDeniedTitle": "访问被拒绝", - "xpack.ml.management.jobsList.analyticsDocsLabel": "分析作业文档", - "xpack.ml.management.jobsList.analyticsTab": "分析", - "xpack.ml.management.jobsList.anomalyDetectionDocsLabel": "异常检测作业文档", - "xpack.ml.management.jobsList.anomalyDetectionTab": "异常检测", - "xpack.ml.management.jobsList.jobsListTagline": "查看 Machine Learning 分析和异常检测作业。", - "xpack.ml.management.jobsList.jobsListTitle": "Machine Learning", - "xpack.ml.management.jobsList.noGrantedPrivilegesDescription": "您无权管理 ML 作业", - "xpack.ml.management.jobsList.noPermissionToAccessLabel": "您需要访问 ML 作业的权限", - "xpack.ml.management.jobsListTitle": "作业列表", - "xpack.ml.management.mlTitle": "Machine Learning", - "xpack.ml.messagebarService.errorTitle": "发生了错误", - "xpack.ml.navMenu.dataFrameAnalyticsTabLinkText": "分析", - "xpack.ml.newJob.wizard.jobDetailsStep.additionalSection.calendarsSelection.title": "日历", - "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.enableModelPlot.description": "选择以存储用于绘制模型边境的其他模型信息。这会增加系统的性能开销,不建议用于高基数数据。", - "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.enableModelPlot.title": "启用模型绘图", - "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.modelMemoryLimit.description": "设置分析模型可使用的内存量预计上限。", - "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.modelMemoryLimit.title": "模型内存限制", - "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.useDedicatedIndex.description": "选择可将结果存储在此作业的不同索引中。", - "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.useDedicatedIndex.title": "使用专用索引", - "xpack.ml.newJob.wizard.jobDetailsStep.advancedSectionButton": "高级", - "xpack.ml.newJob.wizard.jobDetailsStep.jobDescription.description": "可选描述性文本", - "xpack.ml.newJob.wizard.jobDetailsStep.jobDescription.title": "作业描述", - "xpack.ml.newJob.wizard.jobDetailsStep.jobGroupSelect.description": " (可选)作业的分组。可以创建新组或从现有组列表中选取。", - "xpack.ml.newJob.wizard.jobDetailsStep.jobGroupSelect.placeholder": "选择或创建组", - "xpack.ml.newJob.wizard.jobDetailsStep.jobGroupSelect.title": "组", - "xpack.ml.newJob.wizard.jobDetailsStep.jobId.description": "作业的唯一标识符。不允许使用空格和字符 / ? , \" < > | *", - "xpack.ml.newJob.wizard.jobDetailsStep.jobId.title": "作业 ID", - "xpack.ml.newJob.wizard.nextStepButton": "下一步", - "xpack.ml.newJob.wizard.pickFieldsStep.bucketSpan.description": "设置时序分析的时间间隔,通常 15m 至 1h。", - "xpack.ml.newJob.wizard.pickFieldsStep.bucketSpan.placeholder": "存储桶跨度", - "xpack.ml.newJob.wizard.pickFieldsStep.bucketSpan.title": "存储桶跨度", - "xpack.ml.newJob.wizard.pickFieldsStep.bucketSpanEstimatorButton": "估计桶跨度", - "xpack.ml.newJob.wizard.pickFieldsStep.detectorTitle.placeholder": "{title} 由 {field} 分割", - "xpack.ml.newJob.wizard.pickFieldsStep.influencers.description": "选择对结果有影响的分类字段。您可能将异常“归咎”于谁/什么因素?建议 1-3 个影响因素。", - "xpack.ml.newJob.wizard.pickFieldsStep.influencers.title": "影响因素", - "xpack.ml.newJob.wizard.pickFieldsStep.multiMetricView.addMetric": "添加指标", - "xpack.ml.newJob.wizard.pickFieldsStep.populationField.description": "选定字段中的所有值将作为一个群体一起进行建模。建议将此分析类型用于高基数数据。", - "xpack.ml.newJob.wizard.pickFieldsStep.populationField.placeholder": "分割数据", - "xpack.ml.newJob.wizard.pickFieldsStep.populationField.title": "群体字段", - "xpack.ml.newJob.wizard.pickFieldsStep.populationView.addMetric": "添加指标", - "xpack.ml.newJob.wizard.pickFieldsStep.populationView.splitFieldTitle": "群体由 {field} 分割", - "xpack.ml.newJob.wizard.pickFieldsStep.singleMetricView.convertToMultiMetricButton": "转换成多指标作业", - "xpack.ml.newJob.wizard.pickFieldsStep.sparseData.description": "选择是否希望将空存储桶不视为异常。可用于计数和求和分析。", - "xpack.ml.newJob.wizard.pickFieldsStep.sparseData.title": "稀疏数据", - "xpack.ml.newJob.wizard.pickFieldsStep.splitCards.dataSplitBy": "按 {field} 分割数据", - "xpack.ml.newJob.wizard.pickFieldsStep.splitField.description": "选择用于分析分区依据的字段。此字段的每个值将独立进行建模。", - "xpack.ml.newJob.wizard.pickFieldsStep.splitField.title": "分割字段", - "xpack.ml.newJob.wizard.previousStepButton": "上一页", - "xpack.ml.newJob.wizard.step.jobDetailsTitle": "作业详情", - "xpack.ml.newJob.wizard.step.pickFieldsTitle": "选取字段", - "xpack.ml.newJob.wizard.step.summaryTitle": "总结", - "xpack.ml.newJob.wizard.step.timeRangeTitle": "时间范围", - "xpack.ml.newJob.wizard.step.validationTitle": "验证", - "xpack.ml.newJob.wizard.stepComponentWrapper.jobDetailsTitle": "作业详情", - "xpack.ml.newJob.wizard.stepComponentWrapper.pickFieldsTitle": "选取字段", - "xpack.ml.newJob.wizard.stepComponentWrapper.summaryTitleIndexPattern": "从索引模式 {title} 新建作业", - "xpack.ml.newJob.wizard.stepComponentWrapper.summaryTitleSavedSearch": "从已保存搜索 {title} 新建作业", - "xpack.ml.newJob.wizard.stepComponentWrapper.timeRangeTitle": "时间范围", - "xpack.ml.newJob.wizard.stepComponentWrapper.validationTitle": "验证", - "xpack.ml.newJob.wizard.summaryStep.convertToAdvancedButton": "转换成高级作业", - "xpack.ml.newJob.wizard.summaryStep.createJobButton": "创建作业", - "xpack.ml.newJob.wizard.summaryStep.createJobError": "作业创建错误", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.bucketSpan.title": "存储桶跨度", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.enableModelPlot.title": "启用模型绘图", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.groups.placeholder": "未选择组", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.groups.title": "组", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.influencers.placeholder": "未选择影响因素", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.influencers.title": "影响因素", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.jobDescription.placeholder": "未提供描述", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.jobDescription.title": "作业描述", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.jobDetails.title": "作业 ID", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.modelMemoryLimit.title": "模型内存限制", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.populationField.placeholder": "未选择群体字段", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.populationField.title": "群体字段", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.splitField.placeholder": "未选择分割字段", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.splitField.title": "分割字段", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.useDedicatedIndex.title": "使用专用索引", - "xpack.ml.newJob.wizard.summaryStep.postSaveOptions.createWatch": "创建监视", - "xpack.ml.newJob.wizard.summaryStep.postSaveOptions.startJobInRealTime": "启动实时运行的作业", - "xpack.ml.newJob.wizard.summaryStep.postSaveOptions.startJobInRealTimeError": "启动作业时出错", - "xpack.ml.newJob.wizard.summaryStep.postSaveOptions.startJobInRealTimeSuccess": "作业 {jobId} 已启动", - "xpack.ml.newJob.wizard.summaryStep.resetJobButton": "重置作业", - "xpack.ml.newJob.wizard.summaryStep.viewResultsButton": "查看结果", - "xpack.ml.newJob.wizard.timeRangeStep.timeRangePicker.endDateLabel": "结束日期", - "xpack.ml.newJob.wizard.timeRangeStep.timeRangePicker.startDateLabel": "开始日期", - "xpack.ml.newJob.wizard.validateJob.bucketSpanMustBeSetErrorMessage": "必须设置存储桶跨度", - "xpack.ml.newJob.wizard.validateJob.duplicatedDetectorsErrorMessage": "找到重复的检测工具。", - "xpack.ml.newJob.wizard.validateJob.groupNameAlreadyExists": "组 ID 已存在。组 ID 不能与现有作业或组相同。", - "xpack.ml.newJob.wizard.validateJob.jobGroupAllowedCharactersDescription": "作业组名称可以包含小写字母数字(a-z 和 0-9)、连字符或下划线;必须以字母数字字符开头和结尾", - "xpack.ml.newJob.wizard.validateJob.jobNameAllowedCharactersDescription": "作业名称可以包含小写字母数字(a-z 和 0-9)、连字符或下划线;必须以字母数字字符开头和结尾", - "xpack.ml.newJob.wizard.validateJob.jobNameAlreadyExists": "作业 ID 已存在。作业 ID 不能与现有作业或组相同。", - "xpack.ml.newJob.wizard.validateJob.modelMemoryLimitRangeInvalidErrorMessage": "模型内存限制不能高于最大值 {maxModelMemoryLimit}", - "xpack.ml.newJob.wizard.validateJob.modelMemoryLimitUnitsInvalidErrorMessage": "无法识别模型内存限制数据单元。必须为 {str}", - "xpack.ml.accessDenied.description": "您无权访问 ML 插件", - "xpack.ml.accessDenied.label": "权限不足", - "xpack.ml.anomalyDetection.anomalyExplorerLabel": "Anomaly Explorer", - "xpack.ml.anomalyDetection.jobManagementLabel": "作业管理", - "xpack.ml.anomalyDetection.singleMetricViewerLabel": "Single Metric Viewer", - "xpack.ml.anomalyDetectionBreadcrumbLabel": "异常检测", - "xpack.ml.dataframe.analytics.create.advancedEditorMessage.dependentVariableEmpty": "因变量字段不得为空。", - "xpack.ml.dataframe.analytics.create.dependentVariableInputAriaLabel": "输入要用作因变量的字段。", - "xpack.ml.dataframe.analytics.create.dependentVariableLabel": "因变量", - "xpack.ml.dataframe.analytics.create.dependentVariableOptionsFetchError": "获取字段时出现问题。请刷新页面并重试。", - "xpack.ml.dataframe.analytics.create.dependentVariablePlaceholder": "因变量", - "xpack.ml.dataframe.analytics.create.enableAdvancedEditorHelpText": "您不能从高级编辑器切回到此表单。", - "xpack.ml.dataframe.analytics.create.enableAdvancedEditorSwitch": "启用高级编辑器", - "xpack.ml.dataframe.analytics.create.flyoutCancelButton": "取消", - "xpack.ml.dataframe.analytics.create.flyoutCloseButton": "关闭", - "xpack.ml.dataframe.analytics.create.flyoutCreateButton": "创建", - "xpack.ml.dataframe.analytics.create.flyoutHeaderTitle": "创建分析作业", - "xpack.ml.dataframe.analytics.create.flyoutStartButton": "开始", - "xpack.ml.dataframe.analytics.create.indexPatternAlreadyExistsError": "具有此名称的索引模式已存在。", - "xpack.ml.dataframe.analytics.create.indexPatternExistsError": "具有此名称的索引模式已存在。", - "xpack.ml.dataframe.analytics.create.jobIdInvalidMaxLengthErrorMessage": "作业 ID 的长度不得超过 {maxLength, plural, one {# 个字符} other {# 个字符}}。", - "xpack.ml.dataframe.analytics.create.outlierDetectionHelpText": "离群值检测作业需要映射为类表数据结构的源索引,将仅分析数值和布尔值字段。请使用高级编辑器应用定制选项,如模型内存限制和分析类型。", - "xpack.ml.dataframe.analytics.create.outlierRegressionHelpText": "回归作业将仅分析数值字段。请使用高级编辑器来应用定制选项,如模型内存限制和预测字段名称。", - "xpack.ml.dataframe.analytics.create.trainingPercentLabel": "训练百分比", - "xpack.ml.dataframe.analytics.regressionExploration.evaluateError": "加载数据时出错。", - "xpack.ml.dataframe.analytics.regressionExploration.generalError": "加载数据时出错。", - "xpack.ml.dataframe.analytics.regressionExploration.generalizationErrorTitle": "泛化误差", - "xpack.ml.dataframe.analytics.regressionExploration.meanSquaredErrorText": "均方误差", - "xpack.ml.dataframe.analytics.regressionExploration.noDataCalloutBody": "该索引的查询未返回结果。请确保作业已完成且索引包含文档。", - "xpack.ml.dataframe.analytics.regressionExploration.noDataCalloutTitle": "空的索引查询结果。", - "xpack.ml.dataframe.analytics.regressionExploration.noIndexCalloutBody": "该索引的查询未返回结果。请确保目标索引存在且包含文档。", - "xpack.ml.dataframe.analytics.regressionExploration.rSquaredText": "R 平方", - "xpack.ml.dataframe.analytics.regressionExploration.trainingErrorTitle": "训练误差", - "xpack.ml.dataFrameAnalyticsBreadcrumbs.indexLabel": "索引", - "xpack.ml.datavisualizer.actionsPanel.selectKnownConfigurationDescription": "选择已识别数据的已知配置:", - "xpack.ml.dataVisualizer.fileBasedLabel": "文件", - "xpack.ml.datavisualizerBreadcrumbLabel": "数据可视化工具", - "xpack.ml.explorer.distributionChart.entityLabel": "实体", - "xpack.ml.jobsList.editJobFlyout.leaveAnywayButtonLabel": "离开", - "xpack.ml.jobsList.editJobFlyout.saveChangesButtonLabel": "保存更改", - "xpack.ml.jobsList.editJobFlyout.unsavedChangesDialogMessage": "如果未保存,您的更改将会丢失。", - "xpack.ml.jobsList.editJobFlyout.unsavedChangesDialogTitle": "离开前保存更改?", - "xpack.ml.models.jobValidation.messages.jobGroupIdInvalidMaxLengthErrorMessage": "作业组名称的长度不得超过 {maxLength, plural, one {# 个字符} other {# 个字符}}。", - "xpack.ml.models.jobValidation.messages.jobIdInvalidMaxLengthErrorMessage": "作业 ID 的长度不得超过 {maxLength, plural, one {# 个字符} other {# 个字符}}。", - "xpack.ml.navMenu.anomalyDetectionTabLinkText": "异常检测", - "xpack.ml.navMenu.overviewTabLinkText": "概览", - "xpack.ml.newJi18n(ob.recognize.jobsCreationFailed.resetButtonAriaLabel": "重置", - "xpack.ml.newJob.recognize.advancedLabel": "高级", - "xpack.ml.newJob.recognize.advancedSettingsAriaLabel": "高级设置", - "xpack.ml.newJob.recognize.alreadyExistsLabel": "(已存在)", - "xpack.ml.newJob.recognize.analysisRunningLabel": "分析正在运行", - "xpack.ml.newJob.recognize.createJobButtonAriaLabel": "创建作业", - "xpack.ml.newJob.recognize.createJobButtonLabel": "创建{numberOfJobs, plural, zero {作业} one {Job} other {Jobs}}", - "xpack.ml.newJob.recognize.dashboardsLabel": "仪表板", - "xpack.ml.newJob.recognize.datafeed.savedAriaLabel": "已保存", - "xpack.ml.newJob.recognize.datafeed.saveFailedAriaLabel": "保存失败", - "xpack.ml.newJob.recognize.datafeedLabel": "数据馈送", - "xpack.ml.newJob.recognize.indexPatternPageTitle": "索引模式 {indexPatternTitle}", - "xpack.ml.newJob.recognize.job.savedAriaLabel": "已保存", - "xpack.ml.newJob.recognize.job.saveFailedAriaLabel": "保存失败", - "xpack.ml.newJob.recognize.jobGroupAllowedCharactersDescription": "作业组名称可以包含小写字母数字(a-z 和 0-9)、连字符或下划线;必须以字母数字字符开头和结尾", - "xpack.ml.newJob.recognize.jobIdPrefixLabel": "作业 ID 前缀", - "xpack.ml.newJob.recognize.jobLabel": "作业名称", - "xpack.ml.newJob.recognize.jobLabelAllowedCharactersDescription": "作业标签可以包含小写字母数字(a-z 和 0-9)、连字符或下划线;必须以字母数字字符开头和结尾", - "xpack.ml.newJob.recognize.jobPrefixInvalidMaxLengthErrorMessage": "作业 ID 前缀的长度不得超过 {maxLength, plural, one {# 个字符} other {# 个字符}}。", - "xpack.ml.newJob.recognize.jobsCreatedTitle": "已创建作业", - "xpack.ml.newJob.recognize.jobSettingsTitle": "作业设置", - "xpack.ml.newJob.recognize.jobsTitle": "作业", - "xpack.ml.newJob.recognize.moduleCheckJobsExistWarningDescription": "尝试检查模块中的作业是否已创建时出错。", - "xpack.ml.newJob.recognize.moduleCheckJobsExistWarningTitle": "检查模块 {moduleId} 时出错", - "xpack.ml.newJob.recognize.moduleSetupFailedWarningDescription": "尝试创建模块中的{count, plural, one {作业} other {作业}}时出错。", - "xpack.ml.newJob.recognize.moduleSetupFailedWarningTitle": "设置模块 {moduleId} 时出错", - "xpack.ml.newJob.recognize.newJobFromTitle": "来自 {pageTitle} 的新作业", - "xpack.ml.newJob.recognize.results.savedAriaLabel": "已保存", - "xpack.ml.newJob.recognize.results.saveFailedAriaLabel": "保存失败", - "xpack.ml.newJob.recognize.running.startedAriaLabel": "已启动", - "xpack.ml.newJob.recognize.running.startFailedAriaLabel": "启动失败", - "xpack.ml.newJob.recognize.runningLabel": "正在运行", - "xpack.ml.newJob.recognize.savedSearchPageTitle": "已保存搜索 {savedSearchTitle}", - "xpack.ml.newJob.recognize.searchesLabel": "搜索", - "xpack.ml.newJob.recognize.searchWillBeOverwrittenLabel": "搜索将被覆盖", - "xpack.ml.newJob.recognize.someJobsCreationFailed.resetButtonLabel": "重置", - "xpack.ml.newJob.recognize.someJobsCreationFailedTitle": "部分作业未能创建", - "xpack.ml.newJob.recognize.startDatafeedAfterSaveLabel": "保存后启动数据馈送", - "xpack.ml.newJob.recognize.useDedicatedIndexLabel": "使用专用索引", - "xpack.ml.newJob.recognize.useFullDataLabel": "使用完整的 {indexPatternTitle} 数据", - "xpack.ml.newJob.recognize.usingSavedSearchDescription": "使用已保存搜索意味着在数据馈送中使用的查询会与我们在 {moduleId} 模块中提供的默认查询不同。", - "xpack.ml.newJob.recognize.viewResultsAriaLabel": "查看结果", - "xpack.ml.newJob.recognize.viewResultsLinkText": "查看结果", - "xpack.ml.newJob.recognize.visualizationsLabel": "可视化", - "xpack.ml.newJob.wizard.autoSetJobCreatorTimeRange.error": "检索索引的开始和结束时间", - "xpack.ml.newJob.wizard.datafeedPreviewFlyout.closeButton": "关闭", - "xpack.ml.newJob.wizard.datafeedPreviewFlyout.datafeedDoesNotExistLabel": "数据馈送不存在", - "xpack.ml.newJob.wizard.datafeedPreviewFlyout.showButton": "数据馈送预览", - "xpack.ml.newJob.wizard.datafeedPreviewFlyout.title": "数据馈送预览", - "xpack.ml.newJob.wizard.datafeedStep.frequency.description": "搜索的时间间隔。", - "xpack.ml.newJob.wizard.datafeedStep.frequency.title": "频率", - "xpack.ml.newJob.wizard.datafeedStep.query.title": "Elasticsearch 查询", - "xpack.ml.newJob.wizard.datafeedStep.queryDelay.description": "当前时间和最新输入数据时间之间的时间延迟(秒)。", - "xpack.ml.newJob.wizard.datafeedStep.queryDelay.title": "查询延迟", - "xpack.ml.newJob.wizard.datafeedStep.scrollSize.description": "为搜索请求的最大文档数目。", - "xpack.ml.newJob.wizard.datafeedStep.scrollSize.title": "滚动条大小", - "xpack.ml.newJob.wizard.datafeedStep.timeField.description": "索引模式的默认时间字段将被自动选择,但可以覆盖。", - "xpack.ml.newJob.wizard.datafeedStep.timeField.title": "时间字段", - "xpack.ml.newJob.wizard.editJsonButton": "编辑 JSON", - "xpack.ml.newJob.wizard.jsonFlyout.closeButton": "关闭", - "xpack.ml.newJob.wizard.jsonFlyout.datafeed.title": "数据馈送配置 JSON", - "xpack.ml.newJob.wizard.jsonFlyout.job.title": "作业配置 JSON", - "xpack.ml.newJob.wizard.jsonFlyout.saveButton": "保存", - "xpack.ml.newJob.wizard.pickFieldsStep.addDetectorButton": "添加检测工具", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorList.deleteButton": "删除", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorList.editButton": "编辑", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorList.title": "检测工具", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.aggSelect.description": "要执行的分析函数,例如 sum、count。", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.aggSelect.title": "函数", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.byFieldSelect.description": "通过与实体自身过去行为对比来检测异常的单个分析所必需。", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.byFieldSelect.title": "按字段", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.cancelButton": "取消", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.description.description": "使用检测工具分析内容的有意义描述覆盖默认检测工具描述。", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.description.title": "描述", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.excludeFrequent.description": "如果为 true,将自动识别并排除经常出现的实体,否则其可能影响结果。", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.excludeFrequent.title": "排除频繁", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.fieldSelect.description": "以下函数所必需:sum、mean、median、max、min、info_content、distinct_count。", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.fieldSelect.title": "字段", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.overFieldSelect.description": "通过与人口行为对比来检测异常的人口分析所必需。", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.overFieldSelect.title": "基于字段", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.partitionFieldSelect.description": "允许将建模分割成逻辑组。", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.partitionFieldSelect.title": "分区字段", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.saveButton": "保存", - "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.title": "创建检测工具", - "xpack.ml.newJob.wizard.pickFieldsStep.categorizationField.description": "可选,用于分析非结构化日志数据。建议使用文本数据类型。", - "xpack.ml.newJob.wizard.pickFieldsStep.categorizationField.title": "归类字段", - "xpack.ml.newJob.wizard.pickFieldsStep.noDetectorsCallout.message": "至少需要一个检测工具,才能创建作业。", - "xpack.ml.newJob.wizard.pickFieldsStep.noDetectorsCallout.title": "无检测工具", - "xpack.ml.newJob.wizard.pickFieldsStep.summaryCountField.description": "可选,用于输入数据已预汇总时,例如 \\{docCountParam\\}。", - "xpack.ml.newJob.wizard.pickFieldsStep.summaryCountField.title": "汇总计数字段", - "xpack.ml.newJob.wizard.previewJsonButton": "预览 JSON", - "xpack.ml.newJob.wizard.searchSelection.notFoundLabel": "未找到匹配的索引或已保存搜索。", - "xpack.ml.newJob.wizard.searchSelection.savedObjectType.indexPattern": "索引模式", - "xpack.ml.newJob.wizard.searchSelection.savedObjectType.search": "已保存搜索", - "xpack.ml.newJob.wizard.selectIndexPatternOrSavedSearch": "选择索引模式或已保存搜索", - "xpack.ml.newJob.wizard.step.configureDatafeedTitle": "配置数据馈送", - "xpack.ml.newJob.wizard.stepComponentWrapper.configureDatafeedTitle": "配置数据馈送", - "xpack.ml.newJob.wizard.summaryStep.datafeedConfig.title": "数据馈送配置", - "xpack.ml.newJob.wizard.summaryStep.datafeedDetails.frequency.title": "频率", - "xpack.ml.newJob.wizard.summaryStep.datafeedDetails.query.title": "滚动条大小", - "xpack.ml.newJob.wizard.summaryStep.datafeedDetails.queryDelay.title": "查询延迟", - "xpack.ml.newJob.wizard.summaryStep.datafeedDetails.scrollSize.title": "滚动条大小", - "xpack.ml.newJob.wizard.summaryStep.datafeedDetails.timeField.title": "时间字段", - "xpack.ml.newJob.wizard.summaryStep.defaultString": "默认值", - "xpack.ml.newJob.wizard.summaryStep.falseLabel": "False", - "xpack.ml.newJob.wizard.summaryStep.jobConfig.title": "作业配置", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.categorizationField.title": "归类字段", - "xpack.ml.newJob.wizard.summaryStep.jobDetails.summaryCountField.title": "汇总计数字段", - "xpack.ml.newJob.wizard.summaryStep.timeRange.end.title": "结束", - "xpack.ml.newJob.wizard.summaryStep.timeRange.start.title": "开始", - "xpack.ml.newJob.wizard.summaryStep.trueLabel": "True", - "xpack.ml.newJob.wizard.validateJob.frequencyInvalidTimeIntervalFormatErrorMessage": "{value} 不是有效的时间间隔格式,例如,{tenMinutes}、{oneHour}。还需要大于零。", - "xpack.ml.newJob.wizard.validateJob.jobGroupMaxLengthDescription": "作业组名称的长度不得超过 {maxLength, plural, one {# 个字符} other {# 个字符}}。", - "xpack.ml.newJob.wizard.validateJob.jobIdInvalidMaxLengthErrorMessage": "作业 ID 的长度不得超过 {maxLength, plural, one {# 个字符} other {# 个字符}}。", - "xpack.ml.newJob.wizard.validateJob.queryCannotBeEmpty": "数据馈送查询不能为空。", - "xpack.ml.newJob.wizard.validateJob.queryIsInvalidEsQuery": "数据馈送查询必须是有效的 Elasticsearch 查询。", - "xpack.ml.overview.analyticsList.createFirstJobMessage": "创建您的首个分析作业。", - "xpack.ml.overview.analyticsList.createJobButtonText": "创建作业", - "xpack.ml.overview.analyticsList.emptyPromptText": "数据帧分析允许您对数据执行不同的分析,并使用结果标注数据。分析作业将标注的数据以及源数据的副本存储在新的索引中。", - "xpack.ml.overview.analyticsList.errorPromptTitle": "获取数据帧分析列表时发生错误。", - "xpack.ml.overview.analyticsList.id": "ID", - "xpack.ml.overview.analyticsList.manageJobsButtonText": "管理作业", - "xpack.ml.overview.analyticsList.PanelTitle": "分析", - "xpack.ml.overview.analyticsList.reatedTimeColumnName": "创建时间", - "xpack.ml.overview.analyticsList.refreshJobsButtonText": "刷新", - "xpack.ml.overview.analyticsList.status": "状态", - "xpack.ml.overview.analyticsList.tableActionLabel": "操作", - "xpack.ml.overview.analyticsList.type": "类型", - "xpack.ml.overview.anomalyDetection.createFirstJobMessage": "创建您的首个异常检测作业。", - "xpack.ml.overview.anomalyDetection.createJobButtonText": "创建作业", - "xpack.ml.overview.anomalyDetection.emptyPromptText": "通过 Machine Learning,可以轻松检测 Elasticsearch 中存储的时序数据中的异常。跟踪单个机器的一个指标或数千个机器的数百个指标。开始自动发现数据中隐藏的异常并更快捷地解决问题。", - "xpack.ml.overview.anomalyDetection.errorPromptTitle": "获取异常检测作业列表时出错。", - "xpack.ml.overview.anomalyDetection.errorWithFetchingAnomalyScoreNotificationErrorMessage": "获取异常分数时出错:{error}", - "xpack.ml.overview.anomalyDetection.exploreActionName": "浏览", - "xpack.ml.overview.anomalyDetection.manageJobsButtonText": "管理作业", - "xpack.ml.overview.anomalyDetection.panelTitle": "异常检测", - "xpack.ml.overview.anomalyDetection.refreshJobsButtonText": "刷新", - "xpack.ml.overview.anomalyDetection.resultActions.openJobsInAnomalyExplorerText": "在 Anomaly Explorer 中打开 {jobsCount, plural, one {{jobId}} other {# 个作业}}", - "xpack.ml.overview.anomalyDetection.tableActionLabel": "操作", - "xpack.ml.overview.anomalyDetection.tableDocsProcessed": "已处理文档", - "xpack.ml.overview.anomalyDetection.tableId": "组 ID", - "xpack.ml.overview.anomalyDetection.tableLatestTimestamp": "最新时间戳", - "xpack.ml.overview.anomalyDetection.tableMaxScore": "最大异常分数", - "xpack.ml.overview.anomalyDetection.tableMaxScoreErrorTooltip": "加载最大异常分数时出现问题", - "xpack.ml.overview.anomalyDetection.tableMaxScoreTooltip": "最近 24 小时期间组中所有作业的最大分数", - "xpack.ml.overview.anomalyDetection.tableNumJobs": "组中的作业", - "xpack.ml.overview.feedbackSectionLink": "在线反馈", - "xpack.ml.overview.feedbackSectionText": "如果您对 Machine Learning 体验有任何建议,请随时{feedbackLink}。", - "xpack.ml.overview.feedbackSectionTitle": "反馈", - "xpack.ml.overview.gettingStartedSectionCreateJob": "创建新作业", - "xpack.ml.overview.gettingStartedSectionDocs": "文档", - "xpack.ml.overview.gettingStartedSectionTitle": "入门", - "xpack.ml.overview.statsBar.failedAnalyticsLabel": "失败", - "xpack.ml.overview.statsBar.runningAnalyticsLabel": "正在运行", - "xpack.ml.overview.statsBar.stoppedAnalyticsLabel": "已停止", - "xpack.ml.overview.statsBar.totalAnalyticsLabel": "分析作业总数", - "xpack.ml.overviewJobsList.statsBar.activeMLNodesLabel": "活动 ML 节点", - "xpack.ml.overviewJobsList.statsBar.closedJobsLabel": "已关闭的作业", - "xpack.ml.overviewJobsList.statsBar.failedJobsLabel": "失败的作业", - "xpack.ml.overviewJobsList.statsBar.openJobsLabel": "打开的作业", - "xpack.ml.overviewJobsList.statsBar.totalJobsLabel": "总计作业数", - "xpack.ml.settingsBreadcrumbLabel": "设置", - "xpack.ml.validateJob.allPassed": "所有验证检查都成功通过", - "xpack.ml.dataframe.stepCreateForm.createDataFrameAnalyticsSuccessMessage": "数据帧分析 {jobId} 创建请求已确认。", - "xpack.ml.explorer.distributionChart.anomalyScoreLabel": "异常分数", - "xpack.ml.explorer.distributionChart.typicalLabel": "典型", - "xpack.ml.explorer.distributionChart.unusualByFieldValuesLabel": "{ numberOfCauses, plural, one {# 个异常 {byFieldName} 值} other {#{plusSign} 个异常 {byFieldName} 值}}", - "xpack.ml.explorer.distributionChart.valueLabel": "值", - "xpack.ml.explorer.distributionChart.valueWithoutAnomalyScoreLabel": "值", - "xpack.ml.explorer.singleMetricChart.actualLabel": "实际", - "xpack.ml.explorer.singleMetricChart.anomalyScoreLabel": "异常分数", - "xpack.ml.explorer.singleMetricChart.multiBucketImpactLabel": "多存储桶影响", - "xpack.ml.explorer.singleMetricChart.scheduledEventsLabel": "已计划事件", - "xpack.ml.explorer.singleMetricChart.typicalLabel": "典型", - "xpack.ml.explorer.singleMetricChart.valueLabel": "值", - "xpack.ml.explorer.singleMetricChart.valueWithoutAnomalyScoreLabel": "值", - "xpack.ml.explorer.swimlane.maxAnomalyScoreLabel": "最大异常分数", - "xpack.ml.models.jobValidation.messages.jobGroupIdValidMessage": "小写字母数字(a-z 和 0-9)字符、连字符或下划线,以字母数字字符开头和结尾,且长度不超过 {maxLength, plural, one {# 个字符} other {# 个字符}}。", - "xpack.ml.models.jobValidation.messages.jobIdValidMessage": "小写字母数字(a-z 和 0-9)字符、连字符或下划线,以字母数字字符开头和结尾,且长度不超过 {maxLength, plural, one {# 个字符} other {# 个字符}}。", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.actualLabel": "实际", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.anomalyScoreLabel": "异常分数", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.modelPlotEnabled.lowerBoundsLabel": "下边界", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.modelPlotEnabled.upperBoundsLabel": "上边界", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.moreThanOneUnusualByFieldValuesLabel": "{numberOfCauses}{plusSign} 异常 {byFieldName} 值", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.multiBucketImpactLabel": "多存储桶影响", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.scheduledEventsLabel": "已计划事件{counter}", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.typicalLabel": "典型", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.valueLabel": "值", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.withoutAnomalyScore.predictionLabel": "预测", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.withoutAnomalyScore.valueLabel": "值", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.withoutAnomalyScoreAndModelPlotEnabled.lowerBoundsLabel": "下边界", - "xpack.ml.timeSeriesExplorer.timeSeriesChart.withoutAnomalyScoreAndModelPlotEnabled.upperBoundsLabel": "上边界", - "xpack.transform.capability.noPermission.createTransformTooltip": "您无权创建数据帧转换。", - "xpack.transform.capability.noPermission.deleteTransformTooltip": "您无权删除数据帧转换。", - "xpack.transform.models.transformService.allOtherRequestsCancelledDescription": "所有其他请求已取消。", - "xpack.transform.models.transformService.requestToActionTimedOutErrorMessage": "对 {action}“{id}”的请求超时。{extra}", - "xpack.transform.list.errorPromptTitle": "获取数据帧转换列表时发生错误。", - "xpack.transform.modeFilter": "模式", - "xpack.transform.multiTransformActionsMenu.managementActionsAriaLabel": "管理操作", - "xpack.transform.multiTransformActionsMenu.transformsCount": "已选择 {count} 个{count, plural, one {转换} other {转换}}", - "xpack.transform.statsBar.batchTransformsLabel": "批量", - "xpack.transform.statsBar.continuousTransformsLabel": "连续", - "xpack.transform.statsBar.failedTransformsLabel": "失败", - "xpack.transform.statsBar.startedTransformsLabel": "已启动", - "xpack.transform.statsBar.totalTransformsLabel": "转换总数", - "xpack.transform.statusFilter": "状态", - "xpack.transform.stepCreateForm.continuousModeLabel": "连续模式", - "xpack.transform.stepCreateForm.duplicateIndexPatternErrorMessage": "创建 Kibana 索引模式时发生错误 {indexPatternName}:该索引模式已存在。", - "xpack.transform.stepDefineForm.advancedEditorApplyButtonText": "应用更改", - "xpack.transform.stepDefineForm.advancedEditorAriaLabel": "高级数据透视表编辑器", - "xpack.transform.stepDefineForm.advancedEditorHelpText": "高级编辑器允许您编辑数据帧转换的数据透视表配置。", - "xpack.transform.stepDefineForm.advancedEditorHelpTextLink": "详细了解可用选项。", - "xpack.transform.stepDefineForm.advancedEditorLabel": "数据透视表配置对象", - "xpack.transform.stepDefineForm.advancedEditorSourceConfigSwitchLabel": "高级查询编辑器", - "xpack.transform.stepDefineForm.advancedEditorSwitchLabel": "高级数据透视表编辑器", - "xpack.transform.stepDefineForm.advancedEditorSwitchModalBodyText": "高级编辑器中的更改尚未应用。禁用高级编辑器将会使您的编辑丢失。", - "xpack.transform.stepDefineForm.advancedEditorSwitchModalCancelButtonText": "取消", - "xpack.transform.stepDefineForm.advancedEditorSwitchModalConfirmButtonText": "禁用高级编辑器", - "xpack.transform.stepDefineForm.advancedEditorSwitchModalTitle": "未应用的更改", - "xpack.transform.stepDefineForm.advancedSourceEditorApplyButtonText": "应用更改", - "xpack.transform.stepDefineForm.advancedSourceEditorAriaLabel": "高级查询编辑器", - "xpack.transform.stepDefineForm.advancedSourceEditorHelpText": "高级编辑器允许您编辑数据帧转换的源查询子句。", - "xpack.transform.stepDefineForm.advancedSourceEditorLabel": "源查询子句", - "xpack.transform.stepDefineForm.advancedSourceEditorSwitchModalBodyText": "切换回到 KQL 查询栏,您将会丢失编辑。", - "xpack.transform.stepDefineForm.advancedSourceEditorSwitchModalConfirmButtonText": "切换到 KQL", - "xpack.transform.stepDefineForm.advancedSourceEditorSwitchModalTitle": "编辑将会丢失", - "xpack.transform.stepDefineForm.queryPlaceholder": "例如,{example}", - "xpack.transform.stepDefineSummary.queryCodeBlockLabel": "查询", - "xpack.transform.stepDefineSummary.savedSearchLabel": "已保存搜索", - "xpack.transform.stepDetailsForm.continuousModeAriaLabel": "选择延迟。", - "xpack.transform.stepDetailsForm.continuousModeDateFieldHelpText": "选择可用于标识新文档的日期字段。", - "xpack.transform.stepDetailsForm.continuousModeDateFieldLabel": "日期字段", - "xpack.transform.stepDetailsForm.continuousModeDelayError": "延迟格式无效", - "xpack.transform.stepDetailsForm.continuousModeDelayHelpText": "当前时间和最新输入数据时间之间的时间延迟。", - "xpack.transform.stepDetailsForm.continuousModeDelayLabel": "延迟", - "xpack.transform.stepDetailsForm.continuousModeError": "连续模式不可用于没有日期字段的索引。", - "xpack.transform.stepDetailsForm.destinationIndexHelpText": "已存在具有此名称的索引。请注意,运行此转换将会修改此目标索引。", - "xpack.transform.stepDetailsForm.destinationIndexInputAriaLabel": "选择唯一目标索引名称。", - "xpack.transform.stepDetailsForm.destinationIndexInvalidError": "目标索引名称无效。", - "xpack.transform.stepDetailsForm.destinationIndexInvalidErrorLink": "详细了解索引名称限制。", - "xpack.transform.stepDetailsForm.destinationIndexLabel": "目标 IP", - "xpack.transform.stepDetailsForm.transformDescriptionHelpText": "(可选)描述性文本。", - "xpack.transform.stepDetailsForm.transformDescriptionInputAriaLabel": "选择可选的转换描述。", - "xpack.transform.stepDetailsForm.transformDescriptionLabel": "转换描述", - "xpack.transform.stepDetailsForm.transformIdExistsError": "已存在具有此 ID 的转换。", - "xpack.transform.stepDetailsForm.transformIdInvalidError": "只能包含小写字母数字字符(a-z 和 0-9)、连字符和下划线,并且必须以字母数字字符开头和结尾。", - "xpack.transform.stepDetailsSummary.continuousModeDateFieldLabel": "连续模式日期字段", - "xpack.transform.stepDetailsSummary.destinationIndexLabel": "目标 IP", - "xpack.transform.stepDetailsSummary.transformDescriptionLabel": "转换描述", - "xpack.transform.transformList.bulkDeleteModalBody": "是否确定要删除{count, plural, one {这} other {这}} {count} 个 {count, plural, one {转换} other {转换}}?转换的目标索引和可选 Kibana 索引模式将不会删除。", - "xpack.transform.transformList.bulkDeleteModalTitle": "删除 {count} 个 {count, plural, one {转换} other {转换}}?", - "xpack.transform.transformList.bulkStartModalTitle": "启动 {count} 个 {count, plural, one {转换} other {转换}}?", - "xpack.transform.transformList.completeBatchTransformBulkActionToolTip": "一个或多个转换为已完成批量转换,无法重新启动。", - "xpack.transform.transformList.deleteBulkActionDisabledToolTipContent": "一个或多个选定数据帧转换必须停止,才能删除。", - "xpack.transform.transformList.deleteTransformErrorMessage": "删除转换 {transformId} 时发生错误", - "xpack.transform.transformList.refreshButtonLabel": "刷新", - "xpack.transform.transformList.startedTransformBulkToolTip": "一个或多个选定数据帧转换已启动。", - "xpack.transform.transformList.startedTransformToolTip": "{transformId} 已启动。", - "xpack.transform.transformList.startModalBody": "转换将增加集群的搜索和索引负荷。如果负荷超载,请停止转换。是否确定要启动{count, plural, one {这} other {这}} {count} 个 {count, plural, one {转换} other {转换}}?", - "xpack.transform.transformList.startTransformErrorMessage": "启动转换 {transformId} 时发生错误", - "xpack.transform.transformList.stoppedTransformBulkToolTip": "一个或多个选定数据帧转换已停止。", - "xpack.transform.transformList.stoppedTransformToolTip": "{transformId} 已停止。", - "xpack.transform.transformList.stopTransformErrorMessage": "停止数据帧转换 {transformId} 时发生错误", - "xpack.transform.transformList.transformDetails.tabs.transformMessagesLabel": "消息", - "xpack.transform.transformList.transformDetails.tabs.transformPreviewLabel": "预览", - "xpack.transform.agg.popoverForm.aggLabel": "聚合", - "xpack.transform.agg.popoverForm.aggNameAlreadyUsedError": "其他聚合已使用该名称。", - "xpack.transform.agg.popoverForm.aggNameInvalidCharError": "名称无效。不允许使用字符“[”、“]”和“>”,且名称不得以空格字符开头或结束。", - "xpack.transform.agg.popoverForm.fieldLabel": "字段", - "xpack.transform.agg.popoverForm.nameLabel": "聚合名称", - "xpack.transform.agg.popoverForm.submitButtonLabel": "应用", - "xpack.transform.aggLabelForm.deleteItemAriaLabel": "删除项", - "xpack.transform.aggLabelForm.editAggAriaLabel": "编辑聚合", - "xpack.transform.stepDefineForm.aggExistsErrorMessage": "名称为“{aggName}”的聚合配置已存在。", - "xpack.transform.stepDefineForm.groupByExistsErrorMessage": "名称为“{aggName}”的分组依据配置已存在。", - "xpack.transform.stepDefineForm.nestedAggListConflictErrorMessage": "无法添加配置“{aggName}”,因为与“{aggListName}”有嵌套冲突。", - "xpack.transform.stepDefineForm.nestedConflictErrorMessage": "无法添加配置“{aggName}”,因为与“{aggNameCheck}”有嵌套冲突。", - "xpack.transform.stepDefineForm.nestedGroupByListConflictErrorMessage": "无法添加配置“{aggName}”,因为与“{groupByListName}”有嵌套冲突。", - "xpack.transform.stepDefineForm.aggregationsLabel": "聚合", - "xpack.transform.stepDefineForm.aggregationsPlaceholder": "添加聚合……", - "xpack.transform.stepDefineForm.formHelp": "转换是用于数据透视的可伸缩和自动化流程。至少选择一个分组依据和聚合,才能开始。", - "xpack.transform.stepDefineForm.groupByLabel": "分组依据", - "xpack.transform.stepDefineForm.groupByPlaceholder": "添加分组依据字段……", - "xpack.transform.stepDefineForm.indexPatternHelpText": "不支持此索引模式的可选查询。受支持索引字段数目为 {maxIndexFields},而此索引有 {numIndexFields} 个字段。", - "xpack.transform.stepDefineForm.indexPatternLabel": "索引模式", - "xpack.transform.stepDefineForm.queryHelpText": "使用查询字符串筛选源数据(可选)。", - "xpack.transform.stepDefineForm.queryLabel": "查询", - "xpack.transform.stepDefineForm.savedSearchLabel": "已保存搜索", - "xpack.transform.stepDefineSummary.aggregationsLabel": "聚合", - "xpack.transform.stepDefineSummary.groupByLabel": "分组依据", - "xpack.transform.stepDefineSummary.indexPatternLabel": "索引模式", - "xpack.transform.stepDefineSummary.queryLabel": "查询", - "xpack.transform.groupby.popoverForm.aggLabel": "聚合", - "xpack.transform.groupBy.popoverForm.aggNameAlreadyUsedError": "其他分组依据配置已使用该名称。", - "xpack.transform.groupBy.popoverForm.aggNameInvalidCharError": "名称无效。不允许使用字符“[”、“]”和“>”,且名称不得以空格字符开头或结束。", - "xpack.transform.groupBy.popoverForm.fieldLabel": "字段", - "xpack.transform.groupBy.popoverForm.intervalError": "时间间隔无效。", - "xpack.transform.groupBy.popoverForm.intervalLabel": "时间间隔", - "xpack.transform.groupBy.popoverForm.nameLabel": "分组依据名称", - "xpack.transform.groupBy.popoverForm.submitButtonLabel": "应用", - "xpack.transform.groupByLabelForm.deleteItemAriaLabel": "删除项", - "xpack.transform.groupByLabelForm.editIntervalAriaLabel": "编辑时间间隔", - "xpack.transform.stepCreateForm.copyTransformConfigToClipboardButton": "复制到剪贴板", - "xpack.transform.stepCreateForm.copyTransformConfigToClipboardDescription": "将用于创建作业的 Kibana 开发控制台命令复制到剪贴板。", - "xpack.transform.stepCreateForm.createIndexPatternLabel": "创建索引模式", - "xpack.transform.stepCreateForm.createTransformSuccessMessage": "创建转换 {transformId} 的请求已确认。", - "xpack.transform.stepCreateForm.creatingIndexPatternMessage": "正在创建 Kibana 索引模式......", - "xpack.transform.stepCreateForm.discoverCardDescription": "使用 Discover 浏览数据帧透视表。", - "xpack.transform.stepCreateForm.discoverCardTitle": "Discover", - "xpack.transform.stepCreateForm.transformListCardDescription": "返回数据帧作业管理页面。", - "xpack.transform.stepCreateForm.transformListCardTitle": "数据帧作业", - "xpack.transform.stepCreateForm.progressTitle": "进度", - "xpack.transform.stepCreateForm.createIndexPatternSuccessMessage": "Kibana 索引模式 {indexPatternName} 成功创建。", - "xpack.transform.stepCreateForm.startTransformSuccessMessage": "启动转换 {transformId} 的请求已确认。", - "xpack.transform.stepDetailsForm.indexPatternTitleError": "具有此名称的索引模式已存在。", - "xpack.transform.stepDetailsForm.transformIdInputAriaLabel": "选择唯一的作业 ID。", - "xpack.transform.stepDetailsForm.transformIdLabel": "作业 ID", - "xpack.transform.stepDetailsSummary.createIndexPatternMessage": "将为此作业创建 Kibana 索引模式。", - "xpack.transform.stepDetailsSummary.transformIdLabel": "作业 ID", - "xpack.transform.transformList.betaBadgeLabel": "公测版", - "xpack.transform.transformList.betaBadgeTooltipContent": "转换为公测版功能。我们很乐意听取您的反馈意见。", - "xpack.transform.transformList.completeBatchTransformToolTip": "{transformId} 为已完成批量转换,无法重新启动。", - "xpack.transform.transformList.deleteActionDisabledToolTipContent": "停止数据帧作业,以便将其删除。", - "xpack.transform.transformList.deleteActionName": "删除", - "xpack.transform.transformList.deleteTransformSuccessMessage": "删除转换 {transformId} 的请求已确认。", - "xpack.transform.transformList.deleteModalBody": "是否确定要删除此转换?转换的目标索引和可选 Kibana 索引模式将不会删除。", - "xpack.transform.transformList.deleteModalCancelButton": "取消", - "xpack.transform.transformList.deleteModalDeleteButton": "删除", - "xpack.transform.transformList.deleteModalTitle": "删除 {transformId}", - "xpack.transform.transformList.transformDetails.tabs.transformSettingsLabel": "作业详情", - "xpack.transform.transformList.rowCollapse": "隐藏 {transformId} 的详情", - "xpack.transform.transformList.rowExpand": "显示 {transformId} 的详情", - "xpack.transform.transformList.startActionName": "开始", - "xpack.transform.transformList.startTransformSuccessMessage": "启动转换 {transformId} 的请求已确认。", - "xpack.transform.transformList.startModalCancelButton": "取消", - "xpack.transform.transformList.startModalStartButton": "启动", - "xpack.transform.transformList.startModalTitle": "启动 {transformId}", - "xpack.transform.transformList.stopActionName": "停止", - "xpack.transform.transformList.stopTransformSuccessMessage": "停止数据帧转换 {transformId} 的请求已确认。", - "xpack.transform.pivotPreview.copyClipboardTooltip": "将透视预览的开发控制台语句复制到剪贴板。", - "xpack.transform.progress": "进度", - "xpack.transform.sourceIndex": "源索引", - "xpack.transform.sourceIndexPreview.copyClipboardTooltip": "将源索引预览的开发控制台语句复制到剪贴板。", - "xpack.transform.sourceIndexPreview.fieldSelection": "已选择 {selectedFieldsLength, number} 个{docFieldsCount, plural, one {字段} other {字段}},共 {docFieldsCount, number} 个", - "xpack.transform.sourceIndexPreview.rowCollapse": "折叠", - "xpack.transform.sourceIndexPreview.rowExpand": "展开", - "xpack.transform.sourceIndexPreview.selectColumnsAriaLabel": "选择列", - "xpack.transform.sourceIndexPreview.selectFieldsPopoverTitle": "选择字段", - "xpack.transform.sourceIndexPreview.sourceIndexPatternError": "加载源索引数据时出错。", - "xpack.transform.sourceIndexPreview.sourceIndexPatternTitle": "源索引 {indexPatternTitle}", - "xpack.transform.status": "状态", - "xpack.transform.tableActionLabel": "操作", - "xpack.transform.transformsWizard.betaBadgeLabel": "公测版", - "xpack.transform.transformsWizard.stepCreateTitle": "创建", - "xpack.transform.transformsWizard.stepDefineTitle": "定义透视", - "xpack.transform.transformsWizard.stepDetailsTitle": "作业详情", - "xpack.transform.wizard.nextStepButton": "下一个", - "xpack.transform.wizard.previousStepButton": "上一页", - "xpack.transform.agg.popoverForm.unsupportedAggregationHelpText": "在此表单中仅可以编辑聚合名称。请使用高级编辑器编辑聚合的其他部分。", - "xpack.transform.app.checkingPrivilegesDescription": "正在检查权限……", - "xpack.transform.app.checkingPrivilegesErrorMessage": "从服务器获取用户权限时出错。", - "xpack.transform.app.deniedPrivilegeDescription": "要使用“转换”的此部分,必须具有{privilegesCount, plural, one {以下集群权限} other {以下集群权限}}:{missingPrivileges}。", - "xpack.transform.app.deniedPrivilegeTitle": "您缺少集群权限", - "xpack.transform.appName": "数据帧作业", - "xpack.transform.capability.noPermission.startOrStopTransformTooltip": "您无权启动或停止转换。", - "xpack.transform.capability.pleaseContactAdministratorTooltip": "{message}请联系您的管理员。", - "xpack.transform.createTransform.breadcrumbTitle": "创建转换", - "xpack.transform.description": "描述", - "xpack.transform.destinationIndex": "目标 IP", - "xpack.transform.groupBy.popoverForm.unsupportedGroupByHelpText": "在此表单中仅可以编辑 group_by 名称。请使用高级编辑器编辑 group_by 配置的其他部分。", - "xpack.transform.home.breadcrumbTitle": "数据帧作业", - "xpack.transform.list.emptyPromptButtonText": "创建您的首个转换", - "xpack.transform.list.emptyPromptTitle": "找不到转换", - "xpack.transform.mode": "模式", - "xpack.transform.newTransform.chooseSourceTitle": "选择源", - "xpack.transform.newTransform.newTransformTitle": "新转换", - "xpack.transform.newTransform.searchSelection.notFoundLabel": "未找到匹配的索引或已保存搜索。", - "xpack.transform.newTransform.searchSelection.savedObjectType.indexPattern": "索引模式", - "xpack.transform.newTransform.searchSelection.savedObjectType.search": "已保存搜索", - "xpack.transform.pivotPreview.PivotPreviewError": "加载数据透视表预览时出错。", - "xpack.transform.pivotPreview.PivotPreviewIncompleteConfigCalloutBody": "请至少选择一个分组依据字段和聚合。", - "xpack.transform.pivotPreview.PivotPreviewNoDataCalloutBody": "预览请求未返回任何数据。请确保可选查询返回数据且存在分组依据和聚合字段使用的字段的值。", - "xpack.transform.pivotPreview.PivotPreviewNoDataCalloutTitle": "数据透视表预览不可用", - "xpack.transform.pivotPreview.PivotPreviewTitle": "转换数据透视表预览", - "xpack.transform.sourceIndexPreview.SourceIndexArrayBadgeContent": "数组", - "xpack.transform.sourceIndexPreview.SourceIndexArrayToolTipContent": "此基于数组的列的完整内容在展开的行中。", - "xpack.transform.sourceIndexPreview.SourceIndexNoDataCalloutBody": "源索引的查询未返回结果。请确保索引包含文档且您的查询限制不过于严格。", - "xpack.transform.sourceIndexPreview.SourceIndexNoDataCalloutTitle": "源索引查询结果为空。", - "xpack.transform.sourceIndexPreview.SourceIndexObjectBadgeContent": "对象", - "xpack.transform.sourceIndexPreview.SourceIndexObjectToolTipContent": "此基于对象的列的完整内容在展开的行中。", - "xpack.transform.stepCreateForm.createAndStartTransformButton": "创建并启动", - "xpack.transform.stepCreateForm.createAndStartTransformDescription": "创建并启动转换。转换将增加集群的搜索和索引负荷。如果负荷超载,请停止转换。转换启动后,系统将为您提供继续浏览转换的选项。", - "xpack.transform.stepCreateForm.createIndexPatternErrorMessage": "创建 Kibana 索引模式时发生错误 {indexPatternName}:", - "xpack.transform.stepCreateForm.createTransformButton": "创建", - "xpack.transform.stepCreateForm.createTransformDescription": "在不启动转换的情况下创建转换。您之后能够通过返回到转换列表,来启动转换。", - "xpack.transform.stepCreateForm.createTransformErrorMessage": "创建转换 {transformId} 时出错:", - "xpack.transform.stepCreateForm.progressErrorMessage": "获取进度百分比时出错:", - "xpack.transform.stepCreateForm.startTransformButton": "开始", - "xpack.transform.stepCreateForm.startTransformDescription": "启动转换。转换将增加集群的搜索和索引负荷。如果负荷超载,请停止转换。转换启动后,系统将为您提供继续浏览转换的选项。", - "xpack.transform.stepCreateForm.startTransformErrorMessage": "启动转换 {transformId} 时发生错误:", - "xpack.transform.stepDetailsForm.errorGettingIndexNames": "获取现有索引名称时发生错误:", - "xpack.transform.stepDetailsForm.errorGettingIndexPatternTitles": "获取现有索引模式标题时发生错误:", - "xpack.transform.stepDetailsForm.errorGettingTransformList": "获取现有转换 ID 时发生错误:", - "xpack.transform.toastText.closeModalButtonText": "关闭", - "xpack.transform.toastText.modalTitle": "错误详细信息", - "xpack.transform.toastText.openModalButtonText": "查看详情", - "xpack.transform.transformForm.sizeNotationPlaceholder": "示例:{example1}、{example2}、{example3}、{example4}", - "xpack.transform.transformList.createTransformButton": "创建转换", - "xpack.transform.transformList.deleteTransformGenericErrorMessage": "调用用于删除转换的 API 终端节点时发生错误。", - "xpack.transform.transformList.stepDetails.previewPane.errorMessage": "无法加载预览", - "xpack.transform.transformList.transformDetails.messagesPane.errorMessage": "无法加载消息", - "xpack.transform.transformList.transformDetails.messagesPane.messageLabel": "消息", - "xpack.transform.transformList.transformDetails.messagesPane.nodeLabel": "节点", - "xpack.transform.transformList.transformDetails.messagesPane.timeLabel": "时间", - "xpack.transform.transformList.transformTitle": "数据帧作业", - "xpack.transform.transformsWizard.betaBadgeTooltipContent": "转换为公测版功能。我们很乐意听取您的反馈意见。", - "xpack.transform.transformsWizard.createTransformTitle": "创建转换", - "xpack.monitoring.accessDenied.backToKibanaButtonLabel": "返回 Kibana", - "xpack.monitoring.accessDenied.clusterNotConfiguredDescription": "如果您尝试访问专用监测集群,则这可能是因为该监测集群上未配置您登录时所用的用户帐户。", - "xpack.monitoring.accessDenied.notAuthorizedDescription": "您无权访问 Monitoring。要使用 Monitoring,您同时需要 `{kibanaUser}` 和 `{monitoringUser}` 角色授予的权限。", - "xpack.monitoring.accessDeniedTitle": "访问被拒绝", - "xpack.monitoring.ajaxErrorHandler.httpErrorMessage": "HTTP {errStatus}", - "xpack.monitoring.ajaxErrorHandler.requestErrorNotificationTitle": "Monitoring 请求错误", - "xpack.monitoring.ajaxErrorHandler.requestFailedNotification.retryButtonLabel": "重试", - "xpack.monitoring.ajaxErrorHandler.requestFailedNotificationTitle": "Monitoring 请求失败", - "xpack.monitoring.alerts.categoryColumn.generalLabel": "常规", - "xpack.monitoring.alerts.categoryColumnTitle": "类别", - "xpack.monitoring.alerts.clusterAlertsTitle": "集群告警", - "xpack.monitoring.alerts.clusterOverviewLinkLabel": "« 集群概览", - "xpack.monitoring.alerts.filterAlertsPlaceholder": "筛选告警……", - "xpack.monitoring.alerts.highSeverityName": "高", - "xpack.monitoring.alerts.lastCheckedColumnTitle": "上次检查时间", - "xpack.monitoring.alerts.lowSeverityName": "低", - "xpack.monitoring.alerts.mediumSeverityName": "中", - "xpack.monitoring.alerts.messageColumnTitle": "消息", - "xpack.monitoring.alerts.notResolvedDescription": "未解决", - "xpack.monitoring.alerts.resolvedAgoDescription": "{duration}前", - "xpack.monitoring.alerts.resolvedColumnTitle": "已解决", - "xpack.monitoring.alerts.severityTitle": "{severity}紧急告警", - "xpack.monitoring.alerts.statusColumnTitle": "状态", - "xpack.monitoring.alerts.triggeredColumnTitle": "已触发", - "xpack.monitoring.alerts.triggeredColumnValue": "{timestamp}前", - "xpack.monitoring.apm.healthStatusLabel": "运行状况:{status}", - "xpack.monitoring.apm.instance.routeTitle": "{apm} - 实例", - "xpack.monitoring.apm.instance.status.lastEventDescription": "{timeOfLastEvent}前", - "xpack.monitoring.apm.instance.status.lastEventLabel": "最后事件", - "xpack.monitoring.apm.instance.status.nameLabel": "名称", - "xpack.monitoring.apm.instance.status.outputLabel": "输出", - "xpack.monitoring.apm.instance.status.uptimeLabel": "运行时间", - "xpack.monitoring.apm.instance.status.versionLabel": "版本", - "xpack.monitoring.apm.instance.statusDescription": "状态:{apmStatusIcon}", - "xpack.monitoring.apm.instances.allocatedMemoryTitle": "已分配内存", - "xpack.monitoring.apm.instances.bytesSentRateTitle": "已发送字节速率", - "xpack.monitoring.apm.instances.filterInstancesPlaceholder": "筛选实例……", - "xpack.monitoring.apm.instances.lastEventTitle": "最后事件", - "xpack.monitoring.apm.instances.lastEventValue": "{timeOfLastEvent}前", - "xpack.monitoring.apm.instances.nameTitle": "名称", - "xpack.monitoring.apm.instances.outputEnabledTitle": "已启用输出", - "xpack.monitoring.apm.instances.outputErrorsTitle": "输出错误", - "xpack.monitoring.apm.instances.routeTitle": "{apm} - 实例", - "xpack.monitoring.apm.instances.status.lastEventDescription": "{timeOfLastEvent}前", - "xpack.monitoring.apm.instances.status.lastEventLabel": "最后事件", - "xpack.monitoring.apm.instances.status.serversLabel": "服务器", - "xpack.monitoring.apm.instances.status.totalEventsLabel": "事件合计", - "xpack.monitoring.apm.instances.statusDescription": "状态:{apmStatusIcon}", - "xpack.monitoring.apm.instances.totalEventsRateTitle": "事件合计速率", - "xpack.monitoring.apm.instances.versionFilter": "版本", - "xpack.monitoring.apm.instances.versionTitle": "版本", - "xpack.monitoring.apmNavigation.instancesLinkText": "实例", - "xpack.monitoring.apmNavigation.overviewLinkText": "概览", - "xpack.monitoring.beats.filterBeatsPlaceholder": "筛选 Beats……", - "xpack.monitoring.beats.instance.bytesSentLabel": "已发送字节", - "xpack.monitoring.beats.instance.configReloadsLabel": "配置重载", - "xpack.monitoring.beats.instance.eventsDroppedLabel": "已丢弃事件", - "xpack.monitoring.beats.instance.eventsEmittedLabel": "已发出事件", - "xpack.monitoring.beats.instance.eventsTotalLabel": "事件合计", - "xpack.monitoring.beats.instance.handlesLimitHardLabel": "句柄限制(硬性)", - "xpack.monitoring.beats.instance.handlesLimitSoftLabel": "句柄限制(弹性)", - "xpack.monitoring.beats.instance.hostLabel": "主机", - "xpack.monitoring.beats.instance.nameLabel": "名称", - "xpack.monitoring.beats.instance.outputLabel": "输出", - "xpack.monitoring.beats.instance.routeTitle": "Beats - {instanceName} - 概览", - "xpack.monitoring.beats.instance.typeLabel": "类型", - "xpack.monitoring.beats.instance.uptimeLabel": "运行时间", - "xpack.monitoring.beats.instance.versionLabel": "版本", - "xpack.monitoring.beats.instances.allocatedMemoryTitle": "已分配内存", - "xpack.monitoring.beats.instances.bytesSentRateTitle": "已发送字节速率", - "xpack.monitoring.beats.instances.nameTitle": "名称", - "xpack.monitoring.beats.instances.outputEnabledTitle": "已启用输出", - "xpack.monitoring.beats.instances.outputErrorsTitle": "输出错误", - "xpack.monitoring.beats.instances.totalEventsRateTitle": "事件合计速率", - "xpack.monitoring.beats.instances.typeFilter": "类型", - "xpack.monitoring.beats.instances.typeTitle": "类型", - "xpack.monitoring.beats.instances.versionFilter": "版本", - "xpack.monitoring.beats.instances.versionTitle": "版本", - "xpack.monitoring.beats.overview.activeBeatsInLastDayTitle": "过去一天里的活动 Beats", - "xpack.monitoring.beats.overview.bytesSentLabel": "已发送字节", - "xpack.monitoring.beats.overview.latestActive.last1DayLabel": "过去 1 天", - "xpack.monitoring.beats.overview.latestActive.last1HourLabel": "过去 1 小时", - "xpack.monitoring.beats.overview.latestActive.last1MinuteLabel": "过去 1 分钟", - "xpack.monitoring.beats.overview.latestActive.last20MinutesLabel": "过去 20 分钟", - "xpack.monitoring.beats.overview.latestActive.last5MinutesLabel": "过去 5 分钟", - "xpack.monitoring.beats.overview.noActivityDescription": "您好!此区域将显示您最新的 Beats 活动,但似乎在过去一天内您没有任何活动。", - "xpack.monitoring.beats.overview.routeTitle": "Beats - 概览", - "xpack.monitoring.beats.overview.top5BeatTypesInLastDayTitle": "过去一天内排名前 5 的 Beat 类型", - "xpack.monitoring.beats.overview.top5VersionsInLastDayTitle": "过去一天里排名前 5 的版本", - "xpack.monitoring.beats.overview.totalBeatsLabel": "Beats 合计", - "xpack.monitoring.beats.overview.totalEventsLabel": "事件合计", - "xpack.monitoring.beats.routeTitle": "Beats", - "xpack.monitoring.beatsNavigation.instance.overviewLinkText": "概览", - "xpack.monitoring.beatsNavigation.instancesLinkText": "实例", - "xpack.monitoring.beatsNavigation.overviewLinkText": "概览", - "xpack.monitoring.breadcrumbs.apm.instancesLabel": "实例", - "xpack.monitoring.breadcrumbs.apmLabel": "APM", - "xpack.monitoring.breadcrumbs.beats.instancesLabel": "实例", - "xpack.monitoring.breadcrumbs.beatsLabel": "Beats", - "xpack.monitoring.breadcrumbs.clustersLabel": "集群", - "xpack.monitoring.breadcrumbs.es.ccrLabel": "CCR", - "xpack.monitoring.breadcrumbs.es.indicesLabel": "索引", - "xpack.monitoring.breadcrumbs.es.jobsLabel": "作业", - "xpack.monitoring.breadcrumbs.es.nodesLabel": "节点", - "xpack.monitoring.breadcrumbs.kibana.instancesLabel": "实例", - "xpack.monitoring.breadcrumbs.logstash.nodesLabel": "节点", - "xpack.monitoring.breadcrumbs.logstash.pipelinesLabel": "管道", - "xpack.monitoring.breadcrumbs.logstashLabel": "Logstash", - "xpack.monitoring.chart.horizontalLegend.notAvailableLabel": "不适用", - "xpack.monitoring.chart.horizontalLegend.toggleButtonAriaLabel": "切换按钮", - "xpack.monitoring.chart.infoTooltip.intervalLabel": "时间间隔", - "xpack.monitoring.chart.screenReaderUnaccessibleTitle": "此图表不支持屏幕阅读器读取", - "xpack.monitoring.chart.seriesScreenReaderListDescription": "时间间隔:{bucketSize}", - "xpack.monitoring.cluster.listing.alertsInticator.alertsTooltip": "告警", - "xpack.monitoring.cluster.listing.alertsInticator.clearStatusTooltip": "集群状态正常!", - "xpack.monitoring.cluster.listing.alertsInticator.clearTooltip": "清除", - "xpack.monitoring.cluster.listing.alertsInticator.highSeverityTooltip": "有一些紧急集群问题需要您立即关注!", - "xpack.monitoring.cluster.listing.alertsInticator.lowSeverityTooltip": "存在一些低紧急集群问题", - "xpack.monitoring.cluster.listing.alertsInticator.mediumSeverityTooltip": "有一些问题可能影响您的集群。", - "xpack.monitoring.cluster.listing.dataColumnTitle": "数据", - "xpack.monitoring.cluster.listing.incompatibleLicense.getLicenseLinkLabel": "获取具有完整功能的许可证", - "xpack.monitoring.cluster.listing.incompatibleLicense.infoMessage": "需要监测多个集群?{getLicenseInfoLink}以实现多集群监测。", - "xpack.monitoring.cluster.listing.incompatibleLicense.noMultiClusterSupportMessage": "基本许可不支持多集群监测。", - "xpack.monitoring.cluster.listing.incompatibleLicense.warningMessageTitle": "您无法查看 {clusterName} 集群", - "xpack.monitoring.cluster.listing.indicesColumnTitle": "索引", - "xpack.monitoring.cluster.listing.invalidLicense.getBasicLicenseLinkLabel": "获取免费的基本许可", - "xpack.monitoring.cluster.listing.invalidLicense.getLicenseLinkLabel": "获取具有完整功能的许可证", - "xpack.monitoring.cluster.listing.invalidLicense.infoMessage": "需要许可?{getBasicLicenseLink}或{getLicenseInfoLink}以实现多集群监测。", - "xpack.monitoring.cluster.listing.invalidLicense.invalidInfoMessage": "许可信息无效。", - "xpack.monitoring.cluster.listing.invalidLicense.warningMessageTitle": "您无法查看 {clusterName} 集群", - "xpack.monitoring.cluster.listing.kibanaColumnTitle": "Kibana", - "xpack.monitoring.cluster.listing.licenseColumnTitle": "许可证", - "xpack.monitoring.cluster.listing.logstashColumnTitle": "Logstash", - "xpack.monitoring.cluster.listing.nameColumnTitle": "名称", - "xpack.monitoring.cluster.listing.nodesColumnTitle": "节点", - "xpack.monitoring.cluster.listing.standaloneClusterCallOutDismiss": "消除", - "xpack.monitoring.cluster.listing.standaloneClusterCallOutLink": "查看这些实例。", - "xpack.monitoring.cluster.listing.standaloneClusterCallOutText": "或者,单击下表中的独立集群", - "xpack.monitoring.cluster.listing.standaloneClusterCallOutTitle": "似乎您具有未连接到 Elasticsearch 集群的实例。", - "xpack.monitoring.cluster.listing.statusColumnTitle": "状态", - "xpack.monitoring.cluster.overview.alertsPanel.lastCheckedTimeText": "上次检查时间是 {updateDateTime}(触发于 {duration}前)", - "xpack.monitoring.cluster.overview.alertsPanel.severityIconTitle": "{severityIconTitle}(已在 {time}前解决)", - "xpack.monitoring.cluster.overview.alertsPanel.topClusterTitle": "最亟需处理的集群告警", - "xpack.monitoring.cluster.overview.alertsPanel.viewAllButtonLabel": "查看所有告警", - "xpack.monitoring.cluster.overview.apmPanel.apmTitle": "APM", - "xpack.monitoring.cluster.overview.apmPanel.instancesTotalLinkAriaLabel": "APM 实例:{apmsTotal}", - "xpack.monitoring.cluster.overview.apmPanel.lastEventDescription": "{timeOfLastEvent}前", - "xpack.monitoring.cluster.overview.apmPanel.lastEventLabel": "最后事件", - "xpack.monitoring.cluster.overview.apmPanel.memoryUsageLabel": "内存利用率", - "xpack.monitoring.cluster.overview.apmPanel.overviewLinkAriaLabel": "APM 概览", - "xpack.monitoring.cluster.overview.apmPanel.overviewLinkLabel": "概览", - "xpack.monitoring.cluster.overview.apmPanel.processedEventsLabel": "已处理事件", - "xpack.monitoring.cluster.overview.apmPanel.serversTotalLinkLabel": "APM 服务器:{apmsTotal}", - "xpack.monitoring.cluster.overview.beatsPanel.beatsTitle": "Beats", - "xpack.monitoring.cluster.overview.beatsPanel.beatsTotalLinkLabel": "Beats:{beatsTotal}", - "xpack.monitoring.cluster.overview.beatsPanel.bytesSentLabel": "已发送字节", - "xpack.monitoring.cluster.overview.beatsPanel.instancesTotalLinkAriaLabel": "Beats 实例:{beatsTotal}", - "xpack.monitoring.cluster.overview.beatsPanel.overviewLinkAriaLabel": "Beats 概览", - "xpack.monitoring.cluster.overview.beatsPanel.overviewLinkLabel": "概览", - "xpack.monitoring.cluster.overview.beatsPanel.totalEventsLabel": "事件合计", - "xpack.monitoring.cluster.overview.esPanel.debugLogsTooltipText": "调试日志数", - "xpack.monitoring.cluster.overview.esPanel.diskAvailableLabel": "磁盘可用", - "xpack.monitoring.cluster.overview.esPanel.diskUsageLabel": "磁盘使用", - "xpack.monitoring.cluster.overview.esPanel.documentsLabel": "文档", - "xpack.monitoring.cluster.overview.esPanel.errorLogsTooltipText": "错误日志数", - "xpack.monitoring.cluster.overview.esPanel.fatalLogsTooltipText": "严重日志数", - "xpack.monitoring.cluster.overview.esPanel.indicesCountLinkAriaLabel": "Elasticsearch 索引:{indicesCount}", - "xpack.monitoring.cluster.overview.esPanel.indicesCountLinkLabel": "索引:{indicesCount}", - "xpack.monitoring.cluster.overview.esPanel.infoLogsTooltipText": "信息日志数", - "xpack.monitoring.cluster.overview.esPanel.jobsLabel": "作业", - "xpack.monitoring.cluster.overview.esPanel.jvmHeapLabel": "{javaVirtualMachine} 堆", - "xpack.monitoring.cluster.overview.esPanel.logsLinkAriaLabel": "Elasticsearch 日志", - "xpack.monitoring.cluster.overview.esPanel.logsLinkLabel": "Logs", - "xpack.monitoring.cluster.overview.esPanel.nodesTotalLinkLabel": "节点:{nodesTotal}", - "xpack.monitoring.cluster.overview.esPanel.overviewLinkAriaLabel": "Elasticsearch 概览", - "xpack.monitoring.cluster.overview.esPanel.overviewLinkLabel": "概览", - "xpack.monitoring.cluster.overview.esPanel.primaryShardsLabel": "主分片", - "xpack.monitoring.cluster.overview.esPanel.replicaShardsLabel": "副本分片", - "xpack.monitoring.cluster.overview.esPanel.uptimeLabel": "运行时间", - "xpack.monitoring.cluster.overview.esPanel.versionLabel": "版本", - "xpack.monitoring.cluster.overview.esPanel.versionNotAvailableDescription": "不适用", - "xpack.monitoring.cluster.overview.esPanel.warnLogsTooltipText": "警告日志数", - "xpack.monitoring.cluster.overview.healthStatusDescription": "运行状况为{status}", - "xpack.monitoring.cluster.overview.kibanaPanel.connectionsLabel": "连接", - "xpack.monitoring.cluster.overview.kibanaPanel.instancesCountLinkAriaLabel": "Kibana 实例:{instancesCount}", - "xpack.monitoring.cluster.overview.kibanaPanel.instancesCountLinkLabel": "实例:{instancesCount}", - "xpack.monitoring.cluster.overview.kibanaPanel.kibanaTitle": "Kibana", - "xpack.monitoring.cluster.overview.kibanaPanel.maxResponseTimeDescription": "{maxTime} 毫秒", - "xpack.monitoring.cluster.overview.kibanaPanel.maxResponseTimeLabel": "最大响应时间", - "xpack.monitoring.cluster.overview.kibanaPanel.memoryUsageLabel": "内存利用率", - "xpack.monitoring.cluster.overview.kibanaPanel.overviewLinkAriaLabel": "Kibana 概览", - "xpack.monitoring.cluster.overview.kibanaPanel.overviewLinkLabel": "概览", - "xpack.monitoring.cluster.overview.kibanaPanel.requestsLabel": "请求", - "xpack.monitoring.cluster.overview.licenseText.expireDateText": "将于 {expiryDate}过期", - "xpack.monitoring.cluster.overview.licenseText.toLicensePageLinkLabel": "{licenseType}许可{willExpireOn}", - "xpack.monitoring.cluster.overview.logsPanel.logTypeTitle": "{type}", - "xpack.monitoring.cluster.overview.logsPanel.noLogsFound": "未找到任何日志。", - "xpack.monitoring.cluster.overview.logstashPanel.betaFeatureTooltip": "公测版功能", - "xpack.monitoring.cluster.overview.logstashPanel.eventsEmittedLabel": "已发出事件", - "xpack.monitoring.cluster.overview.logstashPanel.eventsReceivedLabel": "已接收事件", - "xpack.monitoring.cluster.overview.logstashPanel.jvmHeapLabel": "{javaVirtualMachine} 堆", - "xpack.monitoring.cluster.overview.logstashPanel.logstashTitle": "Logstash", - "xpack.monitoring.cluster.overview.logstashPanel.nodesCountLinkAriaLabel": "Logstash 节点:{nodesCount}", - "xpack.monitoring.cluster.overview.logstashPanel.nodesCountLinkLabel": "节点:{nodesCount}", - "xpack.monitoring.cluster.overview.logstashPanel.overviewLinkAriaLabel": "Logstash 概览", - "xpack.monitoring.cluster.overview.logstashPanel.overviewLinkLabel": "概览", - "xpack.monitoring.cluster.overview.logstashPanel.pipelineCountLinkAriaLabel": "Logstash 管道(公测版功能):{pipelineCount}", - "xpack.monitoring.cluster.overview.logstashPanel.pipelinesCountLinkLabel": "管道:{pipelineCount}", - "xpack.monitoring.cluster.overview.logstashPanel.uptimeLabel": "运行时间", - "xpack.monitoring.cluster.overview.logstashPanel.withMemoryQueuesLabel": "内存队列", - "xpack.monitoring.cluster.overview.logstashPanel.withPersistentQueuesLabel": "持久性队列", - "xpack.monitoring.cluster.overviewTitle": "概览", - "xpack.monitoring.clusterAlerts.checkLicense.licenseIsBasicDescription": "如果禁用了 Watcher 或 [{clusterSource}] 集群的当前许可为基本许可,则“集群告警”将不会显示。", - "xpack.monitoring.clusterAlerts.checkLicense.licenseNotActiveDescription": "因为 [{clusterSource}] 集群的当前许可 [{type}] 未处于活动状态,所以“集群告警”将不会显示。", - "xpack.monitoring.clusterAlerts.checkLicense.licenseNotDeterminedDescription": "因为无法确定 [{clusterSource}] 集群的许可,所以“集群告警”将不会显示。", - "xpack.monitoring.clusterAlerts.checkLicense.watcherIsDisabledDescription": "因为禁用了 Watcher,所以“集群告警”未启用。", - "xpack.monitoring.clusterAlerts.clusterNeedsTSLEnabledDescription": "启用安全性时,需要配置 TLS,才能应用黄金或白金许可。", - "xpack.monitoring.clusterAlerts.disabledLicenseDescription": "“集群告警”功能已禁用。", - "xpack.monitoring.clusterAlerts.notDeterminedLicenseDescription": "无法确定“集群告警”功能的状态。", - "xpack.monitoring.clusterAlerts.seeDocumentationDescription": "有关详情,请参阅文档。", - "xpack.monitoring.clusterAlerts.unsupportedClusterAlertsDescription": "集群 [{clusterName}] 许可类型 [{licenseType}] 不支持“集群告警”", - "xpack.monitoring.clusterAlertsNavigation.clusterAlertsLinkText": "集群告警", - "xpack.monitoring.clustersNavigation.clustersLinkText": "集群", - "xpack.monitoring.clusterStats.uuidNotFoundErrorMessage": "在选定时间范围内找不到该集群。UUID:{clusterUuid}", - "xpack.monitoring.clusterStats.uuidNotSpecifiedErrorMessage": "{clusterUuid} 未指定", - "xpack.monitoring.elasticsearch.ccr.ccrListingTable.errorColumnTitle": "错误", - "xpack.monitoring.elasticsearch.ccr.ccrListingTable.followsColumnTitle": "跟随", - "xpack.monitoring.elasticsearch.ccr.ccrListingTable.indexColumnTitle": "索引", - "xpack.monitoring.elasticsearch.ccr.ccrListingTable.lastFetchTimeColumnTitle": "上次提取时间", - "xpack.monitoring.elasticsearch.ccr.ccrListingTable.opsSyncedColumnTitle": "已同步操作", - "xpack.monitoring.elasticsearch.ccr.ccrListingTable.syncLagOpsColumnTitle": "同步延迟(操作)", - "xpack.monitoring.elasticsearch.ccr.routeTitle": "Elasticsearch - CCR", - "xpack.monitoring.elasticsearch.ccr.shard.instanceTitle": "索引:{followerIndex} 分片:{shardId}", - "xpack.monitoring.elasticsearch.ccr.shard.routeTitle": "Elasticsearch - CCR - 分片", - "xpack.monitoring.elasticsearch.ccr.shardsTable.errorColumnTitle": "错误", - "xpack.monitoring.elasticsearch.ccr.shardsTable.lastFetchTimeColumnTitle": "上次提取时间", - "xpack.monitoring.elasticsearch.ccr.shardsTable.opsSyncedColumnTitle": "已同步操作", - "xpack.monitoring.elasticsearch.ccr.shardsTable.shardColumnTitle": "分片", - "xpack.monitoring.elasticsearch.ccr.shardsTable.syncLagOpsColumn.followerLagTooltip": "Follower 延迟:{syncLagOpsFollower}", - "xpack.monitoring.elasticsearch.ccr.shardsTable.syncLagOpsColumn.leaderLagTooltip": "Leader 延迟:{syncLagOpsLeader}", - "xpack.monitoring.elasticsearch.ccr.shardsTable.syncLagOpsColumnTitle": "同步延迟(操作)", - "xpack.monitoring.elasticsearch.ccrShard.errorsTable.reasonColumnTitle": "原因", - "xpack.monitoring.elasticsearch.ccrShard.errorsTable.typeColumnTitle": "类型", - "xpack.monitoring.elasticsearch.ccrShard.errorsTableTitle": "错误", - "xpack.monitoring.elasticsearch.ccrShard.latestStateAdvancedButtonLabel": "高级", - "xpack.monitoring.elasticsearch.ccrShard.status.failedFetchesLabel": "失败提取", - "xpack.monitoring.elasticsearch.ccrShard.status.followerIndexLabel": "Follower 索引", - "xpack.monitoring.elasticsearch.ccrShard.status.leaderIndexLabel": "Leader 索引", - "xpack.monitoring.elasticsearch.ccrShard.status.opsSyncedLabel": "已同步操作", - "xpack.monitoring.elasticsearch.ccrShard.status.shardIdLabel": "分片 ID", - "xpack.monitoring.elasticsearch.clusterStatus.dataLabel": "数据", - "xpack.monitoring.elasticsearch.clusterStatus.documentsLabel": "文档", - "xpack.monitoring.elasticsearch.clusterStatus.indicesLabel": "索引", - "xpack.monitoring.elasticsearch.clusterStatus.memoryLabel": "内存", - "xpack.monitoring.elasticsearch.clusterStatus.nodesLabel": "节点", - "xpack.monitoring.elasticsearch.clusterStatus.totalShardsLabel": "分片合计", - "xpack.monitoring.elasticsearch.clusterStatus.unassignedShardsLabel": "未分配分片", - "xpack.monitoring.elasticsearch.healthStatusLabel": "运行状况:{status}", - "xpack.monitoring.elasticsearch.indexDetailStatus.documentsTitle": "文档", - "xpack.monitoring.elasticsearch.indexDetailStatus.iconStatusLabel": "运行状况:{elasticsearchStatusIcon}", - "xpack.monitoring.elasticsearch.indexDetailStatus.primariesTitle": "主分片", - "xpack.monitoring.elasticsearch.indexDetailStatus.totalShardsTitle": "分片合计", - "xpack.monitoring.elasticsearch.indexDetailStatus.totalTitle": "合计", - "xpack.monitoring.elasticsearch.indexDetailStatus.unassignedShardsTitle": "未分配分片", - "xpack.monitoring.elasticsearch.indices.advanced.routeTitle": "Elasticsearch - 索引 - {indexName} - 高级", - "xpack.monitoring.elasticsearch.indices.dataTitle": "数据", - "xpack.monitoring.elasticsearch.indices.documentCountTitle": "文档计数", - "xpack.monitoring.elasticsearch.indices.howToShowSystemIndicesDescription": "如果您正在寻找系统索引(例如 .kibana),请尝试选中“显示系统索引”。", - "xpack.monitoring.elasticsearch.indices.indexRateTitle": "索引速率", - "xpack.monitoring.elasticsearch.indices.monitoringTablePlaceholder": "筛选索引……", - "xpack.monitoring.elasticsearch.indices.nameTitle": "名称", - "xpack.monitoring.elasticsearch.indices.noIndicesMatchYourSelectionDescription": "没有索引匹配您的选择。请尝试更改时间范围选择。", - "xpack.monitoring.elasticsearch.indices.overview.routeTitle": "Elasticsearch - 索引 - {indexName} - 概览", - "xpack.monitoring.elasticsearch.indices.routeTitle": "Elasticsearch - 索引", - "xpack.monitoring.elasticsearch.indices.searchRateTitle": "搜索速率", - "xpack.monitoring.elasticsearch.indices.statusTitle": "状态", - "xpack.monitoring.elasticsearch.indices.systemIndicesLabel": "系统索引", - "xpack.monitoring.elasticsearch.indices.unassignedShardsTitle": "未分配分片", - "xpack.monitoring.elasticsearch.mlJobListing.filterJobsPlaceholder": "筛选作业……", - "xpack.monitoring.elasticsearch.mlJobListing.forecastsTitle": "预测", - "xpack.monitoring.elasticsearch.mlJobListing.jobIdTitle": "作业 ID", - "xpack.monitoring.elasticsearch.mlJobListing.modelSizeTitle": "模型大小", - "xpack.monitoring.elasticsearch.mlJobListing.noDataLabel": "不适用", - "xpack.monitoring.elasticsearch.mlJobListing.nodeTitle": "节点", - "xpack.monitoring.elasticsearch.mlJobListing.noJobsDescription": "没有 Machine Learning 作业匹配您的查询。请尝试更改时间范围选择。", - "xpack.monitoring.elasticsearch.mlJobListing.processedRecordsTitle": "已处理记录", - "xpack.monitoring.elasticsearch.mlJobListing.stateTitle": "状态", - "xpack.monitoring.elasticsearch.mlJobListing.statusIconLabel": "作业状态:{status}", - "xpack.monitoring.elasticsearch.mlJobs.routeTitle": "Elasticsearch - Machine Learning 作业", - "xpack.monitoring.elasticsearch.node.advanced.routeTitle": "Elasticsearch - 节点 - {nodeSummaryName} - 高级", - "xpack.monitoring.elasticsearch.node.overview.routeTitle": "Elasticsearch - 节点 - {nodeName} - 概览", - "xpack.monitoring.elasticsearch.node.statusIconLabel": "状态:{status}", - "xpack.monitoring.elasticsearch.nodeDetailStatus.dataLabel": "数据", - "xpack.monitoring.elasticsearch.nodeDetailStatus.documentsLabel": "文档", - "xpack.monitoring.elasticsearch.nodeDetailStatus.freeDiskSpaceLabel": "可用磁盘空间", - "xpack.monitoring.elasticsearch.nodeDetailStatus.indicesLabel": "索引", - "xpack.monitoring.elasticsearch.nodeDetailStatus.jvmHeapLabel": "{javaVirtualMachine} 堆", - "xpack.monitoring.elasticsearch.nodeDetailStatus.shardsLabel": "分片", - "xpack.monitoring.elasticsearch.nodeDetailStatus.transportAddress": "传输地址", - "xpack.monitoring.elasticsearch.nodeDetailStatus.typeLabel": "类型", - "xpack.monitoring.elasticsearch.nodes.cells.maxText": "{metric} 最大值", - "xpack.monitoring.elasticsearch.nodes.cells.minText": "{metric} 最小值", - "xpack.monitoring.elasticsearch.nodes.cpuThrottlingColumnTitle": "CPU 限制", - "xpack.monitoring.elasticsearch.nodes.cpuUsageColumnTitle": "CPU 使用", - "xpack.monitoring.elasticsearch.nodes.diskFreeSpaceColumnTitle": "磁盘可用空间", - "xpack.monitoring.elasticsearch.nodes.jvmMemoryColumnTitle": "{javaVirtualMachine} 内存", - "xpack.monitoring.elasticsearch.nodes.loadAverageColumnTitle": "负载平均值", - "xpack.monitoring.elasticsearch.nodes.monitoringTablePlaceholder": "筛选节点……", - "xpack.monitoring.elasticsearch.nodes.nameColumnTitle": "名称", - "xpack.monitoring.elasticsearch.nodes.routeTitle": "Elasticsearch - 节点", - "xpack.monitoring.elasticsearch.nodes.shardsColumnTitle": "分片", - "xpack.monitoring.elasticsearch.nodes.statusColumn.offlineLabel": "脱机", - "xpack.monitoring.elasticsearch.nodes.statusColumn.onlineLabel": "联机", - "xpack.monitoring.elasticsearch.nodes.statusColumnTitle": "状态", - "xpack.monitoring.elasticsearch.shardActivity.completedRecoveriesLabel": "已完成恢复", - "xpack.monitoring.elasticsearch.shardActivity.noActiveShardRecoveriesMessage.completedRecoveriesLinkText": "已完成恢复", - "xpack.monitoring.elasticsearch.shardActivity.noActiveShardRecoveriesMessage.completedRecoveriesLinkTextProblem": "此集群没有活动的分片恢复。", - "xpack.monitoring.elasticsearch.shardActivity.noActiveShardRecoveriesMessage.completedRecoveriesLinkTextSolution": "尝试查看{shardActivityHistoryLink}。", - "xpack.monitoring.elasticsearch.shardActivity.noDataMessage": "选定时间范围没有历史分片活动记录。", - "xpack.monitoring.elasticsearch.shardActivity.progress.noTranslogProgressLabel": "不适用", - "xpack.monitoring.elasticsearch.shardActivity.recoveryIndex.recoveryTypeDescription": "恢复类型:{relocationType}", - "xpack.monitoring.elasticsearch.shardActivity.recoveryIndex.shardDescription": "分片:{shard}", - "xpack.monitoring.elasticsearch.shardActivity.snapshotTitle": "存储库:{repo} / 快照:{snapshot}", - "xpack.monitoring.elasticsearch.shardActivity.sourceTooltip": "复制自 {copiedFrom} 分片", - "xpack.monitoring.elasticsearch.shardActivity.sourceTooltip.primarySourceText": "主分片", - "xpack.monitoring.elasticsearch.shardActivity.sourceTooltip.replicaSourceText": "副本分片", - "xpack.monitoring.elasticsearch.shardActivity.totalTimeTooltip": "已启动:{startTime}", - "xpack.monitoring.elasticsearch.shardActivityTitle": "分片活动", - "xpack.monitoring.elasticsearch.shardAllocation.clusterViewDisplayName": "ClusterView", - "xpack.monitoring.elasticsearch.shardAllocation.decorateShards.relocatingFromTextMessage": "正在从 {nodeName} 迁移", - "xpack.monitoring.elasticsearch.shardAllocation.decorateShards.relocatingToTextMessage": "正在迁移至 {nodeName}", - "xpack.monitoring.elasticsearch.shardAllocation.initializingLabel": "正在初始化", - "xpack.monitoring.elasticsearch.shardAllocation.labels.indicesLabel": "索引", - "xpack.monitoring.elasticsearch.shardAllocation.labels.nodesLabel": "节点", - "xpack.monitoring.elasticsearch.shardAllocation.labels.unassignedLabel": "未分配", - "xpack.monitoring.elasticsearch.shardAllocation.labels.unassignedNodesLabel": "节点", - "xpack.monitoring.elasticsearch.shardAllocation.primaryLabel": "主分片", - "xpack.monitoring.elasticsearch.shardAllocation.relocatingLabel": "正在迁移", - "xpack.monitoring.elasticsearch.shardAllocation.replicaLabel": "副本分片", - "xpack.monitoring.elasticsearch.shardAllocation.shardDisplayName": "分片", - "xpack.monitoring.elasticsearch.shardAllocation.shardLegendTitle": "分片图例", - "xpack.monitoring.elasticsearch.shardAllocation.tableBody.noShardsAllocatedDescription": "未分配任何分片。", - "xpack.monitoring.elasticsearch.shardAllocation.tableBodyDisplayName": "TableBody", - "xpack.monitoring.elasticsearch.shardAllocation.tableHead.indicesLabel": "索引", - "xpack.monitoring.elasticsearch.shardAllocation.unassignedDisplayName": "未分配", - "xpack.monitoring.elasticsearch.shardAllocation.unassignedPrimaryLabel": "未分配主分片", - "xpack.monitoring.elasticsearch.shardAllocation.unassignedReplicaLabel": "未分配副本分片", - "xpack.monitoring.errors.connectionFaultErrorMessage": "检查 Elasticsearch Monitoring 集群网络连接,并参考 Kibana 日志以了解详情。", - "xpack.monitoring.errors.insufficientUserErrorMessage": "对监测数据没有足够的用户权限", - "xpack.monitoring.errors.invalidAuthErrorMessage": "监测集群的身份验证无效", - "xpack.monitoring.errors.noConnectionsErrorMessage": "检查 Elasticsearch Monitoring 集群网络连接,并参考 Kibana 日志以了解详情。", - "xpack.monitoring.errors.statusCodeErrorMessage": "检查 Elasticsearch Monitoring 集群网络连接或节点的负载水平。", - "xpack.monitoring.es.indices.deletedClosedStatusLabel": "已删除 / 已关闭", - "xpack.monitoring.es.indices.notAvailableStatusLabel": "不可用", - "xpack.monitoring.es.indices.unknownStatusLabel": "未知", - "xpack.monitoring.es.nodes.offlineNodeStatusLabel": "脱机节点", - "xpack.monitoring.es.nodes.offlineStatusLabel": "脱机", - "xpack.monitoring.es.nodes.onlineStatusLabel": "联机", - "xpack.monitoring.es.nodeType.clientNodeLabel": "客户端节点", - "xpack.monitoring.es.nodeType.dataOnlyNodeLabel": "纯数据节点", - "xpack.monitoring.es.nodeType.invalidNodeLabel": "无效节点", - "xpack.monitoring.es.nodeType.masterNodeLabel": "主节点", - "xpack.monitoring.es.nodeType.masterOnlyNodeLabel": "只作主节点的节点", - "xpack.monitoring.es.nodeType.nodeLabel": "节点", - "xpack.monitoring.esNavigation.ccrLinkText": "CCR", - "xpack.monitoring.esNavigation.indicesLinkText": "索引", - "xpack.monitoring.esNavigation.instance.advancedLinkText": "高级", - "xpack.monitoring.esNavigation.instance.overviewLinkText": "概览", - "xpack.monitoring.esNavigation.jobsLinkText": "作业", - "xpack.monitoring.esNavigation.nodesLinkText": "节点", - "xpack.monitoring.esNavigation.overviewLinkText": "概览", - "xpack.monitoring.euiTable.isFullyMigratedLabel": "Metricbeat 收集", - "xpack.monitoring.euiTable.isInternalCollectorLabel": "内部收集", - "xpack.monitoring.euiTable.isPartiallyMigratedLabel": "内部收集开启", - "xpack.monitoring.feature.reserved.description": "要向用户授予访问权限,还应分配 monitoring_user 角色。", - "xpack.monitoring.featureRegistry.monitoringFeatureName": "堆栈监测", - "xpack.monitoring.formatNumbers.notAvailableLabel": "不适用", - "xpack.monitoring.kibana.clusterStatus.connectionsLabel": "连接", - "xpack.monitoring.kibana.clusterStatus.instancesLabel": "实例", - "xpack.monitoring.kibana.clusterStatus.maxResponseTimeLabel": "最大响应时间", - "xpack.monitoring.kibana.clusterStatus.memoryLabel": "内存", - "xpack.monitoring.kibana.clusterStatus.requestsLabel": "请求", - "xpack.monitoring.kibana.detailStatus.osFreeMemoryLabel": "OS 可用内存", - "xpack.monitoring.kibana.detailStatus.transportAddressLabel": "传输地址", - "xpack.monitoring.kibana.detailStatus.uptimeLabel": "运行时间", - "xpack.monitoring.kibana.detailStatus.versionLabel": "版本", - "xpack.monitoring.kibana.listing.filterInstancesPlaceholder": "筛选实例……", - "xpack.monitoring.kibana.listing.instanceStatus.offlineLabel": "脱机", - "xpack.monitoring.kibana.listing.instanceStatusTitle": "实例状态:{kibanaStatus}", - "xpack.monitoring.kibana.listing.loadAverageColumnTitle": "负载平均值", - "xpack.monitoring.kibana.listing.memorySizeColumnTitle": "内存大小", - "xpack.monitoring.kibana.listing.nameColumnTitle": "名称", - "xpack.monitoring.kibana.listing.requestsColumnTitle": "请求", - "xpack.monitoring.kibana.listing.responseTimeColumnTitle": "响应时间", - "xpack.monitoring.kibana.listing.statusColumnTitle": "状态", - "xpack.monitoring.kibana.shardActivity.bytesTitle": "字节", - "xpack.monitoring.kibana.shardActivity.filesTitle": "文件", - "xpack.monitoring.kibana.shardActivity.indexTitle": "索引", - "xpack.monitoring.kibana.shardActivity.sourceDestinationTitle": "源 / 目标", - "xpack.monitoring.kibana.shardActivity.stageTitle": "阶段", - "xpack.monitoring.kibana.shardActivity.totalTimeTitle": "总时间", - "xpack.monitoring.kibana.shardActivity.translogTitle": "事务日志", - "xpack.monitoring.kibana.statusIconLabel": "运行状况:{status}", - "xpack.monitoring.kibanaNavigation.instancesLinkText": "实例", - "xpack.monitoring.kibanaNavigation.overviewLinkText": "概览", - "xpack.monitoring.license.howToUpdateLicenseDescription": "要更新此集群的许可,请通过 Elasticsearch {apiText} 提供许可文件:", - "xpack.monitoring.license.licenseRouteTitle": "许可证", - "xpack.monitoring.logs.listing.calloutLinkText": "Logs", - "xpack.monitoring.logs.listing.calloutTitle": "想要查看更多日志?", - "xpack.monitoring.logs.listing.clusterPageDescription": "显示此集群最新的日志,总共最多 {limit} 个日志。", - "xpack.monitoring.logs.listing.componentTitle": "组件", - "xpack.monitoring.logs.listing.indexPageDescription": "显示此索引最新的日志,总共最多 {limit} 个日志。", - "xpack.monitoring.logs.listing.levelTitle": "级别", - "xpack.monitoring.logs.listing.linkText": "访问 {link} 以更深入了解。", - "xpack.monitoring.logs.listing.messageTitle": "消息", - "xpack.monitoring.logs.listing.nodePageDescription": "显示此节点最新的日志,总共最多 {limit} 个日志。", - "xpack.monitoring.logs.listing.nodeTitle": "节点", - "xpack.monitoring.logs.listing.pageTitle": "最近日志", - "xpack.monitoring.logs.listing.timestampTitle": "时间戳", - "xpack.monitoring.logs.listing.typeTitle": "类型", - "xpack.monitoring.logs.reason.noClusterLink": "设置", - "xpack.monitoring.logs.reason.noClusterMessage": "确认您的 {link} 是否正确。", - "xpack.monitoring.logs.reason.noClusterTitle": "此集群没有日志", - "xpack.monitoring.logs.reason.noIndexMessage": "找到了日志,但没有此索引的日志。如果此问题持续存在,请确认您的 {link} 是否正确。", - "xpack.monitoring.logs.reason.noIndexPatternInTimePeriodMessage": "使用时间筛选调整时间范围。", - "xpack.monitoring.logs.reason.noIndexPatternInTimePeriodTitle": "没有选定时间的日志", - "xpack.monitoring.logs.reason.noIndexPatternLink": "Filebeat", - "xpack.monitoring.logs.reason.noIndexPatternMessage": "设置 {link},然后将 Elasticsearch 输出配置到您的监测集群。", - "xpack.monitoring.logs.reason.noIndexPatternTitle": "未找到任何日志数据", - "xpack.monitoring.logs.reason.noIndexTitle": "此索引没有任何日志", - "xpack.monitoring.logs.reason.noNodeLink": "设置", - "xpack.monitoring.logs.reason.noNodeMessage": "确认您的 {link} 是否正确。", - "xpack.monitoring.logs.reason.noNodeTitle": "此 Elasticsearch 节点没有任何日志", - "xpack.monitoring.logs.reason.noTypeLink": "这些方向", - "xpack.monitoring.logs.reason.noTypeMessage": "按照 {link} 设置 Elasticsearch。", - "xpack.monitoring.logs.reason.noTypeTitle": "Elasticsearch 没有任何日志", - "xpack.monitoring.logstash.clusterStatus.eventsEmittedLabel": "已发出事件", - "xpack.monitoring.logstash.clusterStatus.eventsReceivedLabel": "已接收事件", - "xpack.monitoring.logstash.clusterStatus.memoryLabel": "内存", - "xpack.monitoring.logstash.clusterStatus.nodesLabel": "节点", - "xpack.monitoring.logstash.detailStatus.batchSizeLabel": "批处理大小", - "xpack.monitoring.logstash.detailStatus.configReloadsLabel": "配置重载", - "xpack.monitoring.logstash.detailStatus.eventsEmittedLabel": "已发出事件", - "xpack.monitoring.logstash.detailStatus.eventsReceivedLabel": "已接收事件", - "xpack.monitoring.logstash.detailStatus.pipelineWorkersLabel": "管道工作线程", - "xpack.monitoring.logstash.detailStatus.queueTypeLabel": "队列类型", - "xpack.monitoring.logstash.detailStatus.transportAddressLabel": "传输地址", - "xpack.monitoring.logstash.detailStatus.uptimeLabel": "运行时间", - "xpack.monitoring.logstash.detailStatus.versionLabel": "版本", - "xpack.monitoring.logstash.filterNodesPlaceholder": "筛选节点……", - "xpack.monitoring.logstash.filterPipelinesPlaceholder": "筛选管道……", - "xpack.monitoring.logstash.node.advanced.routeTitle": "Logstash - {nodeName} - 高级", - "xpack.monitoring.logstash.node.pipelines.notAvailableDescription": "仅 Logstash 版本 6.0.0 或更高版本提供管道监测功能。此节点正在运行版本 {logstashVersion}。", - "xpack.monitoring.logstash.node.pipelines.routeTitle": "Logstash - {nodeName} - 管道", - "xpack.monitoring.logstash.node.routeTitle": "Logstash - {nodeName}", - "xpack.monitoring.logstash.nodes.configReloadsFailuresCountLabel": "{reloadsFailures} 失败", - "xpack.monitoring.logstash.nodes.configReloadsSuccessCountLabel": "{reloadsSuccesses} 成功", - "xpack.monitoring.logstash.nodes.configReloadsTitle": "配置重载", - "xpack.monitoring.logstash.nodes.cpuUsageTitle": "CPU 使用", - "xpack.monitoring.logstash.nodes.eventsIngestedTitle": "已采集事件", - "xpack.monitoring.logstash.nodes.jvmHeapUsedTitle": "已使用 {javaVirtualMachine} 堆", - "xpack.monitoring.logstash.nodes.loadAverageTitle": "负载平均值", - "xpack.monitoring.logstash.nodes.nameTitle": "名称", - "xpack.monitoring.logstash.nodes.versionTitle": "版本", - "xpack.monitoring.logstash.pipeline.detailDrawer.conditionalStatementDescription": "这是您的管道中的条件语句。", - "xpack.monitoring.logstash.pipeline.detailDrawer.eventsEmittedLabel": "已发出事件", - "xpack.monitoring.logstash.pipeline.detailDrawer.eventsEmittedRateLabel": "已发出事件速率", - "xpack.monitoring.logstash.pipeline.detailDrawer.eventsLatencyLabel": "事件延迟", - "xpack.monitoring.logstash.pipeline.detailDrawer.eventsReceivedLabel": "已接收事件", - "xpack.monitoring.logstash.pipeline.detailDrawer.noMetricsForIfDescription": "对于此 if 条件,当前没有可显示的指标。", - "xpack.monitoring.logstash.pipeline.detailDrawer.noMetricsForQueueDescription": "对于该队列,当前没有可显示的指标。", - "xpack.monitoring.logstash.pipeline.detailDrawer.specifyVertexIdDescription": "没有为此 {vertexType} 显式指定 ID。指定 ID 允许您跟踪管道更改间的差异。您可以为此插件显式指定 ID,如:", - "xpack.monitoring.logstash.pipeline.detailDrawer.structureDescription": "这是 Logstash 用来缓冲输入和管道其余部分之间的事件的内部结构。", - "xpack.monitoring.logstash.pipeline.detailDrawer.vertexIdDescription": "此 {vertexType} 的 ID 为 {vertexId}。", - "xpack.monitoring.logstash.pipeline.queue.noMetricsDescription": "队列指标不可用", - "xpack.monitoring.logstash.pipeline.relativeFirstSeenAgoLabel": "{relativeFirstSeen}前", - "xpack.monitoring.logstash.pipeline.relativeLastSeenAgoLabel": "直到 {relativeLastSeen}前", - "xpack.monitoring.logstash.pipeline.relativeLastSeenNowLabel": "现在", - "xpack.monitoring.logstash.pipeline.routeTitle": "Logstash - 管道", - "xpack.monitoring.logstash.pipelines.eventsEmittedRateTitle": "已发出事件速率", - "xpack.monitoring.logstash.pipelines.idTitle": "ID", - "xpack.monitoring.logstash.pipelines.numberOfNodesTitle": "节点数目", - "xpack.monitoring.logstash.pipelineStatement.viewDetailsAriaLabel": "查看详情", - "xpack.monitoring.logstash.pipelineViewer.filtersTitle": "筛选", - "xpack.monitoring.logstash.pipelineViewer.inputsTitle": "输入", - "xpack.monitoring.logstash.pipelineViewer.outputsTitle": "输出", - "xpack.monitoring.logstashNavigation.instance.advancedLinkText": "高级", - "xpack.monitoring.logstashNavigation.instance.overviewLinkText": "概览", - "xpack.monitoring.logstashNavigation.instance.pipelinesLinkText": "管道", - "xpack.monitoring.logstashNavigation.nodesLinkText": "节点", - "xpack.monitoring.logstashNavigation.overviewLinkText": "概览", - "xpack.monitoring.logstashNavigation.pipelinesLinkText": "管道", - "xpack.monitoring.logstashNavigation.pipelineVersionDescription": "活动版本 {relativeLastSeen} 和首次看到 {relativeFirstSeen}", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.configureMetricbeatDescription": "修改 {file} 以设置连接信息。", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.configureMetricbeatTitle": "配置 Metricbeat 以发送至监测集群", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.disableInternalCollectionDescription": "禁用 Elasticsearch 监测指标的内部收集。在生产集群中的每个服务器上将 {monospace} 设置为 false。", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.disableInternalCollectionTitle": "禁用 Elasticsearch 监测指标的内部收集", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.enableMetricbeatModuleDescription": "默认情况下,模块从 {url} 收集 Elasticsearch 指标。如果本地服务器有不同的地址,请在 {module} 中将其添加到主机设置。", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.enableMetricbeatModuleTitle": "在 Metricbeat 中启用并配置 Elasticsearch x-pack 模块", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.installMetricbeatLinkText": "按照此处的说明执行操作。", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.installMetricbeatTitle": "在安装 Elasticsearch 的同一台服务器上安装 Metricbeat", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.startMetricbeatLinkText": "按照此处的说明执行操作。", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.startMetricbeatTitle": "启动 Metricbeat", - "xpack.monitoring.metricbeatMigration.flyout.closeButtonLabel": "关闭", - "xpack.monitoring.metricbeatMigration.flyout.doneButtonLabel": "完成", - "xpack.monitoring.metricbeatMigration.flyout.nextButtonLabel": "下一个", - "xpack.monitoring.metricbeatMigration.flyout.step1.monitoringUrlHelpText": "通常为单个 URL。如果有多个 URL,请使用逗号分隔。\n 正在运行的 Metricbeat 实例必须能够与这些 Elasticsearch 服务器通信。", - "xpack.monitoring.metricbeatMigration.flyout.step1.monitoringUrlLabel": "监测集群 URL", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.configureMetricbeatDescription": "在 {file} 文件中进行这些更改。", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.configureMetricbeatTitle": "配置 Metricbeat 以发送至监测集群", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.disableInternalCollection.description": "将此设置添加到 {file}。", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.disableInternalCollection.note": "对于 {config},请保留默认值 ({defaultValue})。", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.disableInternalCollection.restartNote": "此步骤需要您重新启动 Kibana 服务器。在服务器再次运行之前应会看到错误。", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.disableInternalCollection.restartWarningTitle": "警告", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.disableInternalCollection.title": "禁用 Kibana 监测指标的内部收集", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.enableMetricbeatModuleDescription": "该模块将默认从 http://localhost:5601 收集 Kibana 监测指标。如果本地 Kibana 实例有不同的地址,则必须通过 {file} 文件中的 {hosts} 设置进行指定。", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.enableMetricbeatModuleTitle": "在 Metricbeat 中启用并配置 Kibana x-pack 模块", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.installMetricbeatLinkText": "按照此处的说明执行操作。", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.installMetricbeatTitle": "在安装 Kibana 的同一台服务器上安装 Metricbeat", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.startMetricbeatLinkText": "按照此处的说明执行操作。", - "xpack.monitoring.metricbeatMigration.kibanaInstructions.startMetricbeatTitle": "启动 Metricbeat", - "xpack.monitoring.metrics.apm.outputAckedEventsRate.ackedDescription": "输出处理的事件(包括重试)", - "xpack.monitoring.metrics.apm.outputAckedEventsRate.ackedLabel": "已确认", - "xpack.monitoring.metrics.apm.outputAckedEventsRateTitle": "输出已确认事件速率", - "xpack.monitoring.metrics.apm.outputActiveEventsRate.activeDescription": "输出处理的事件(包括重试)", - "xpack.monitoring.metrics.apm.outputActiveEventsRate.activeLabel": "有效", - "xpack.monitoring.metrics.apm.outputActiveEventsRateTitle": "输出活动事件速率", - "xpack.monitoring.metrics.apm.outputDroppedEventsRate.droppedDescription": "输出处理的事件(包括重试)", - "xpack.monitoring.metrics.apm.outputDroppedEventsRate.droppedLabel": "已丢弃", - "xpack.monitoring.metrics.apm.outputDroppedEventsRateTitle": "输出已丢弃事件速率", - "xpack.monitoring.metrics.apm.outputEventsRate.totalDescription": "输出处理的事件(包括重试)", - "xpack.monitoring.metrics.apm.outputEventsRate.totalLabel": "合计", - "xpack.monitoring.metrics.apm.outputEventsRateTitle": "输出事件速率", - "xpack.monitoring.metrics.apm.outputFailedEventsRate.failedDescription": "输出处理的事件(包括重试)", - "xpack.monitoring.metrics.apm.outputFailedEventsRate.failedLabel": "失败", - "xpack.monitoring.metrics.apm.outputFailedEventsRateTitle": "输出失败事件速率", - "xpack.monitoring.metrics.apm.perMinuteUnitLabel": "/分钟", - "xpack.monitoring.metrics.apm.processedEvents.transactionDescription": "已处理事务事件", - "xpack.monitoring.metrics.apm.processedEvents.transactionLabel": "事务", - "xpack.monitoring.metrics.apm.processedEventsTitle": "已处理事件", - "xpack.monitoring.metrics.apm.requests.requestedDescription": "服务器接收的 HTTP 请求", - "xpack.monitoring.metrics.apm.requests.requestedLabel": "已请求", - "xpack.monitoring.metrics.apm.requestsTitle": "请求计数摄入 API", - "xpack.monitoring.metrics.apm.response.acceptedDescription": "成功报告新事件的 HTTP 请求", - "xpack.monitoring.metrics.apm.response.acceptedLabel": "已接受", - "xpack.monitoring.metrics.apm.response.acceptedTitle": "已接受", - "xpack.monitoring.metrics.apm.response.okDescription": "200 OK 响应计数", - "xpack.monitoring.metrics.apm.response.okLabel": "确定", - "xpack.monitoring.metrics.apm.response.okTitle": "确定", - "xpack.monitoring.metrics.apm.responseCount.totalDescription": "服务器响应的 HTTP 请求", - "xpack.monitoring.metrics.apm.responseCount.totalLabel": "合计", - "xpack.monitoring.metrics.apm.responseCountTitle": "响应计数摄入 API", - "xpack.monitoring.metrics.apm.responseErrors.closedDescription": "服务器关闭期间拒绝的 HTTP 请求", - "xpack.monitoring.metrics.apm.responseErrors.closedLabel": "已关闭", - "xpack.monitoring.metrics.apm.responseErrors.closedTitle": "已关闭", - "xpack.monitoring.metrics.apm.responseErrors.concurrencyDescription": "由于违反总体并发限制而拒绝的 HTTP 请求", - "xpack.monitoring.metrics.apm.responseErrors.concurrencyLabel": "并发", - "xpack.monitoring.metrics.apm.responseErrors.concurrencyTitle": "并发", - "xpack.monitoring.metrics.apm.responseErrors.decodeDescription": "由于解码错误而拒绝的 HTTP 请求 - json 无效、实体的数据类型不正确", - "xpack.monitoring.metrics.apm.responseErrors.decodeLabel": "解码", - "xpack.monitoring.metrics.apm.responseErrors.decodeTitle": "解码", - "xpack.monitoring.metrics.apm.responseErrors.forbiddenDescription": "拒绝的已禁止 HTTP 请求 - CORS 违规、已禁用终端节点", - "xpack.monitoring.metrics.apm.responseErrors.forbiddenLabel": "已禁止", - "xpack.monitoring.metrics.apm.responseErrors.forbiddenTitle": "已禁止", - "xpack.monitoring.metrics.apm.responseErrors.internalDescription": "由于其他内部错误而拒绝的 HTTP 请求", - "xpack.monitoring.metrics.apm.responseErrors.internalLabel": "内部", - "xpack.monitoring.metrics.apm.responseErrors.internalTitle": "内部", - "xpack.monitoring.metrics.apm.responseErrors.methodDescription": "由于 HTTP 方法错误而拒绝的 HTTP 请求", - "xpack.monitoring.metrics.apm.responseErrors.methodLabel": "方法", - "xpack.monitoring.metrics.apm.responseErrors.methodTitle": "方法", - "xpack.monitoring.metrics.apm.responseErrors.queueDescription": "由于内部队列已填满而拒绝的 HTTP 请求", - "xpack.monitoring.metrics.apm.responseErrors.queueLabel": "队列", - "xpack.monitoring.metrics.apm.responseErrors.queueTitle": "队列", - "xpack.monitoring.metrics.apm.responseErrors.rateLimitDescription": "由于速率限制超出而拒绝的 HTTP 请求", - "xpack.monitoring.metrics.apm.responseErrors.rateLimitLabel": "速率限制", - "xpack.monitoring.metrics.apm.responseErrors.rateLimitTitle": "速率限制", - "xpack.monitoring.metrics.apm.responseErrors.tooLargeLabelDescription": "由于负载大小过大而拒绝的 HTTP 请求", - "xpack.monitoring.metrics.apm.responseErrors.tooLargeLabelTitle": "过大", - "xpack.monitoring.metrics.apm.responseErrors.unauthorizedDescription": "由于密钥令牌无效而拒绝的 HTTP 请求", - "xpack.monitoring.metrics.apm.responseErrors.unauthorizedLabel": "未授权", - "xpack.monitoring.metrics.apm.responseErrors.unauthorizedTitle": "未授权", - "xpack.monitoring.metrics.apm.responseErrors.validateDescription": "由于负载验证错误而拒绝的 HTTP 请求", - "xpack.monitoring.metrics.apm.responseErrors.validateLabel": "验证", - "xpack.monitoring.metrics.apm.responseErrors.validateTitle": "验证", - "xpack.monitoring.metrics.apm.responseErrorsTitle": "响应错误摄入 API", - "xpack.monitoring.metrics.apm.transformations.errorDescription": "已处理错误事件", - "xpack.monitoring.metrics.apm.transformations.errorLabel": "错误", - "xpack.monitoring.metrics.apm.transformations.metricDescription": "已处理指标事件", - "xpack.monitoring.metrics.apm.transformations.metricLabel": "指标", - "xpack.monitoring.metrics.apm.transformations.spanDescription": "已处理范围错误", - "xpack.monitoring.metrics.apm.transformations.spanLabel": "范围", - "xpack.monitoring.metrics.apm.transformationsTitle": "转换", - "xpack.monitoring.metrics.apmInstance.cpuUtilization.totalDescription": "为 APM 进程执行(用户+内核模式)所花费的 CPU 时间百分比", - "xpack.monitoring.metrics.apmInstance.cpuUtilization.totalLabel": "合计", - "xpack.monitoring.metrics.apmInstance.cpuUtilizationTitle": "CPU 使用率", - "xpack.monitoring.metrics.apmInstance.memory.allocatedMemoryDescription": "已分配内存", - "xpack.monitoring.metrics.apmInstance.memory.allocatedMemoryLabel": "已分配内存", - "xpack.monitoring.metrics.apmInstance.memory.gcNextDescription": "执行垃圾回收的已分配内存限制", - "xpack.monitoring.metrics.apmInstance.memory.gcNextLabel": "下一 GC", - "xpack.monitoring.metrics.apmInstance.memory.processTotalDescription": "APM 服务从 OS 保留的内存常驻集大小", - "xpack.monitoring.metrics.apmInstance.memory.processTotalLabel": "进程合计", - "xpack.monitoring.metrics.apmInstance.memoryTitle": "内存", - "xpack.monitoring.metrics.apmInstance.systemLoad.last15MinutesDescription": "过去 15 分钟的负载平均值", - "xpack.monitoring.metrics.apmInstance.systemLoad.last15MinutesLabel": "15 分钟", - "xpack.monitoring.metrics.apmInstance.systemLoad.last1MinuteDescription": "过去 1 分钟的负载平均值", - "xpack.monitoring.metrics.apmInstance.systemLoad.last1MinuteLabel": "1 分钟", - "xpack.monitoring.metrics.apmInstance.systemLoad.last5MinutesDescription": "过去 5 分钟的负载平均值", - "xpack.monitoring.metrics.apmInstance.systemLoad.last5MinutesLabel": "5 分钟", - "xpack.monitoring.metrics.apmInstance.systemLoadTitle": "系统负载", - "xpack.monitoring.metrics.beats.eventsRate.acknowledgedDescription": "输出确认的事件(包括输出丢弃的事件)", - "xpack.monitoring.metrics.beats.eventsRate.acknowledgedLabel": "已确认", - "xpack.monitoring.metrics.beats.eventsRate.emittedDescription": "输出处理的事件(包括重试)", - "xpack.monitoring.metrics.beats.eventsRate.emittedLabel": "已发出", - "xpack.monitoring.metrics.beats.eventsRate.queuedDescription": "添加到事件管道队列的事件", - "xpack.monitoring.metrics.beats.eventsRate.queuedLabel": "已排队", - "xpack.monitoring.metrics.beats.eventsRate.totalDescription": "发布管道中新创建的所有事件", - "xpack.monitoring.metrics.beats.eventsRate.totalLabel": "合计", - "xpack.monitoring.metrics.beats.eventsRateTitle": "事件速率", - "xpack.monitoring.metrics.beats.failRates.droppedInOutputDescription": "(致命丢弃)因“无效”而被输出丢弃的事件。 输出仍确认事件,以便 Beat 将其从队列中删除。", - "xpack.monitoring.metrics.beats.failRates.droppedInOutputLabel": "在输出中已丢弃", - "xpack.monitoring.metrics.beats.failRates.droppedInPipelineDescription": "N 次重试后丢弃的事件(N = max_retries 设置)", - "xpack.monitoring.metrics.beats.failRates.droppedInPipelineLabel": "在管道中已丢弃", - "xpack.monitoring.metrics.beats.failRates.failedInPipelineDescription": "将事件添加到发布管道前发生的失败(输出已禁用或发布器客户端已关闭)", - "xpack.monitoring.metrics.beats.failRates.failedInPipelineLabel": "在管道中失败", - "xpack.monitoring.metrics.beats.failRates.retryInPipelineDescription": "在管道中重新尝试发送到输出的事件", - "xpack.monitoring.metrics.beats.failRates.retryInPipelineLabel": "在管道中重试", - "xpack.monitoring.metrics.beats.failRatesTitle": "失败速率", - "xpack.monitoring.metrics.beats.outputErrors.receivingDescription": "从输出读取响应时的错误", - "xpack.monitoring.metrics.beats.outputErrors.receivingLabel": "接收", - "xpack.monitoring.metrics.beats.outputErrors.sendingDescription": "从输出写入响应时的错误", - "xpack.monitoring.metrics.beats.outputErrors.sendingLabel": "发送", - "xpack.monitoring.metrics.beats.outputErrorsTitle": "输出错误", - "xpack.monitoring.metrics.beats.perSecondUnitLabel": "/秒", - "xpack.monitoring.metrics.beats.throughput.bytesReceivedDescription": "作为响应从输出读取的字节", - "xpack.monitoring.metrics.beats.throughput.bytesReceivedLabel": "已接收字节", - "xpack.monitoring.metrics.beats.throughput.bytesSentDescription": "写入到输出的字节(包括网络标头和已压缩负载的大小)", - "xpack.monitoring.metrics.beats.throughput.bytesSentLabel": "已发送字节", - "xpack.monitoring.metrics.beats.throughputTitle": "吞吐量", - "xpack.monitoring.metrics.beatsInstance.cpuUtilization.totalDescription": "为 Beat 进程执行(用户+内核模式)所花费的 CPU 时间百分比", - "xpack.monitoring.metrics.beatsInstance.cpuUtilization.totalLabel": "合计", - "xpack.monitoring.metrics.beatsInstance.cpuUtilizationTitle": "CPU 使用率", - "xpack.monitoring.metrics.beatsInstance.eventsRate.acknowledgedDescription": "输出确认的事件(包括输出丢弃的事件)", - "xpack.monitoring.metrics.beatsInstance.eventsRate.acknowledgedLabel": "已确认", - "xpack.monitoring.metrics.beatsInstance.eventsRate.emittedDescription": "输出处理的事件(包括重试)", - "xpack.monitoring.metrics.beatsInstance.eventsRate.emittedLabel": "已发出", - "xpack.monitoring.metrics.beatsInstance.eventsRate.newDescription": "发送到发布管道的新事件", - "xpack.monitoring.metrics.beatsInstance.eventsRate.newLabel": "新建", - "xpack.monitoring.metrics.beatsInstance.eventsRate.queuedDescription": "添加到事件管道队列的事件", - "xpack.monitoring.metrics.beatsInstance.eventsRate.queuedLabel": "已排队", - "xpack.monitoring.metrics.beatsInstance.eventsRateTitle": "事件速率", - "xpack.monitoring.metrics.beatsInstance.failRates.droppedInOutputDescription": "(致命丢弃)因“无效”而被输出丢弃的事件。 输出仍确认事件,以便 Beat 将其从队列中删除。", - "xpack.monitoring.metrics.beatsInstance.failRates.droppedInOutputLabel": "在输出中已丢弃", - "xpack.monitoring.metrics.beatsInstance.failRates.droppedInPipelineDescription": "N 次重试后丢弃的事件(N = max_retries 设置)", - "xpack.monitoring.metrics.beatsInstance.failRates.droppedInPipelineLabel": "在管道中已丢弃", - "xpack.monitoring.metrics.beatsInstance.failRates.failedInPipelineDescription": "将事件添加到发布管道前发生的失败(输出已禁用或发布器客户端已关闭)", - "xpack.monitoring.metrics.beatsInstance.failRates.failedInPipelineLabel": "在管道中失败", - "xpack.monitoring.metrics.beatsInstance.failRates.retryInPipelineDescription": "在管道中重新尝试发送到输出的事件", - "xpack.monitoring.metrics.beatsInstance.failRates.retryInPipelineLabel": "在管道中重试", - "xpack.monitoring.metrics.beatsInstance.failRatesTitle": "失败速率", - "xpack.monitoring.metrics.beatsInstance.memory.activeDescription": "正被 Beat 频繁使用的专用内存", - "xpack.monitoring.metrics.beatsInstance.memory.activeLabel": "有效", - "xpack.monitoring.metrics.beatsInstance.memory.gcNextDescription": "执行垃圾回收的已分配内存限制", - "xpack.monitoring.metrics.beatsInstance.memory.gcNextLabel": "下一 GC", - "xpack.monitoring.metrics.beatsInstance.memory.processTotalDescription": "Beat 从 OS 保留的内存常驻集大小", - "xpack.monitoring.metrics.beatsInstance.memory.processTotalLabel": "进程合计", - "xpack.monitoring.metrics.beatsInstance.memoryTitle": "内存", - "xpack.monitoring.metrics.beatsInstance.openHandlesDescription": "打开的文件句柄计数", - "xpack.monitoring.metrics.beatsInstance.openHandlesLabel": "打开的句柄", - "xpack.monitoring.metrics.beatsInstance.openHandlesTitle": "打开的句柄", - "xpack.monitoring.metrics.beatsInstance.outputErrors.receivingDescription": "从输出读取响应时的错误", - "xpack.monitoring.metrics.beatsInstance.outputErrors.receivingLabel": "接收", - "xpack.monitoring.metrics.beatsInstance.outputErrors.sendingDescription": "从输出写入响应时的错误", - "xpack.monitoring.metrics.beatsInstance.outputErrors.sendingLabel": "发送", - "xpack.monitoring.metrics.beatsInstance.outputErrorsTitle": "输出错误", - "xpack.monitoring.metrics.beatsInstance.systemLoad.last15MinutesDescription": "过去 15 分钟的负载平均值", - "xpack.monitoring.metrics.beatsInstance.systemLoad.last15MinutesLabel": "15 分钟", - "xpack.monitoring.metrics.beatsInstance.systemLoad.last1MinuteDescription": "过去 1 分钟的负载平均值", - "xpack.monitoring.metrics.beatsInstance.systemLoad.last1MinuteLabel": "1 分钟", - "xpack.monitoring.metrics.beatsInstance.systemLoad.last5MinutesDescription": "过去 5 分钟的负载平均值", - "xpack.monitoring.metrics.beatsInstance.systemLoad.last5MinutesLabel": "5 分钟", - "xpack.monitoring.metrics.beatsInstance.systemLoadTitle": "系统负载", - "xpack.monitoring.metrics.beatsInstance.throughput.bytesReceivedDescription": "作为响应从输出读取的字节", - "xpack.monitoring.metrics.beatsInstance.throughput.bytesReceivedLabel": "已接收字节", - "xpack.monitoring.metrics.beatsInstance.throughput.bytesSentDescription": "写入到输出的字节(包括网络标头和已压缩负载的大小)", - "xpack.monitoring.metrics.beatsInstance.throughput.bytesSentLabel": "已发送字节", - "xpack.monitoring.metrics.beatsInstance.throughputTitle": "吞吐量", - "xpack.monitoring.metrics.es.indexingLatencyDescription": "索引文档的平均延迟,即索引文档所用时间除以索引文档的数目。这仅考虑主分片。", - "xpack.monitoring.metrics.es.indexingLatencyLabel": "索引延迟", - "xpack.monitoring.metrics.es.indexingRate.primaryShardsDescription": "为主分片索引的文档数目。", - "xpack.monitoring.metrics.es.indexingRate.primaryShardsLabel": "主分片", - "xpack.monitoring.metrics.es.indexingRate.totalShardsDescription": "为主分片和副本分片索引的文档数目。", - "xpack.monitoring.metrics.es.indexingRate.totalShardsLabel": "分片合计", - "xpack.monitoring.metrics.es.indexingRateTitle": "索引速率", - "xpack.monitoring.metrics.es.latencyMetricParamErrorMessage": "延迟指标参数必须是等于“index”或“query”的字符串", - "xpack.monitoring.metrics.es.msTimeUnitLabel": "ms", - "xpack.monitoring.metrics.es.nsTimeUnitLabel": "纳秒", - "xpack.monitoring.metrics.es.perSecondsUnitLabel": "/秒", - "xpack.monitoring.metrics.es.perSecondTimeUnitLabel": "/秒", - "xpack.monitoring.metrics.es.searchLatencyDescription": "搜索的平均延迟,即执行搜索所用的时间除以提交的搜索数目。这考虑主分片和副本分片。", - "xpack.monitoring.metrics.es.searchLatencyLabel": "搜索延迟", - "xpack.monitoring.metrics.es.searchRate.totalShardsDescription": "跨主分片和副本分片执行的搜索请求数目。可以对多个分片运行单个搜索!", - "xpack.monitoring.metrics.es.searchRate.totalShardsLabel": "分片合计", - "xpack.monitoring.metrics.es.searchRateTitle": "搜索速率", - "xpack.monitoring.metrics.es.secondsUnitLabel": "s", - "xpack.monitoring.metrics.esCcr.fetchDelayDescription": "Follower 索引落后 Leader 的时间量。", - "xpack.monitoring.metrics.esCcr.fetchDelayLabel": "提取延迟", - "xpack.monitoring.metrics.esCcr.fetchDelayTitle": "提取延迟", - "xpack.monitoring.metrics.esCcr.opsDelayDescription": "Follower 索引落后 Leader 的操作数目。", - "xpack.monitoring.metrics.esCcr.opsDelayLabel": "操作延迟", - "xpack.monitoring.metrics.esCcr.opsDelayTitle": "操作延迟", - "xpack.monitoring.metrics.esIndex.disk.mergesDescription": "主分片和副本分片上的合并大小。", - "xpack.monitoring.metrics.esIndex.disk.mergesLabel": "合并", - "xpack.monitoring.metrics.esIndex.disk.mergesPrimariesDescription": "主分片上的合并大小。", - "xpack.monitoring.metrics.esIndex.disk.mergesPrimariesLabel": "合并(主分片)", - "xpack.monitoring.metrics.esIndex.disk.storeDescription": "磁盘上主分片和副本分片的大小。", - "xpack.monitoring.metrics.esIndex.disk.storeLabel": "存储", - "xpack.monitoring.metrics.esIndex.disk.storePrimariesDescription": "磁盘上主分片的大小。", - "xpack.monitoring.metrics.esIndex.disk.storePrimariesLabel": "存储(主分片)", - "xpack.monitoring.metrics.esIndex.diskTitle": "磁盘", - "xpack.monitoring.metrics.esIndex.docValuesDescription": "文档值使用的堆大小。这是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esIndex.docValuesLabel": "文档值", - "xpack.monitoring.metrics.esIndex.fielddataDescription": "Fielddata(例如全局序号或文本字段上显式启用的 Fielddata)使用的堆内存。这用于相同的分片,但不是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esIndex.fielddataLabel": "Fielddata", - "xpack.monitoring.metrics.esIndex.fixedBitsetsDescription": "固定位组(例如深嵌套文档)使用的堆内存。这是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esIndex.fixedBitsetsLabel": "固定位组", - "xpack.monitoring.metrics.esIndex.indexingRate.primaryShardsDescription": "为主分片索引的文档数目。", - "xpack.monitoring.metrics.esIndex.indexingRate.primaryShardsLabel": "主分片", - "xpack.monitoring.metrics.esIndex.indexingRate.totalShardsDescription": "为主分片和副本分片索引的文档数目。", - "xpack.monitoring.metrics.esIndex.indexingRate.totalShardsLabel": "分片合计", - "xpack.monitoring.metrics.esIndex.indexingRateTitle": "索引速率", - "xpack.monitoring.metrics.esIndex.indexMemoryEs.queryCacheDescription": "查询缓存(例如缓存的筛选)使用的堆内存。这用于相同的分片,但不是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esIndex.indexMemoryEs.queryCacheLabel": "查询缓存", - "xpack.monitoring.metrics.esIndex.indexMemoryEsTitle": "索引内存 - {elasticsearch}", - "xpack.monitoring.metrics.esIndex.indexMemoryLucene1.luceneTotalDescription": "Lucene 用于当前索引的堆内存合计。这是主分片和副本分片的其他字段合计。", - "xpack.monitoring.metrics.esIndex.indexMemoryLucene1.luceneTotalLabel": "Lucene 合计", - "xpack.monitoring.metrics.esIndex.indexMemoryLucene1Title": "索引内存 - Lucene 1", - "xpack.monitoring.metrics.esIndex.indexMemoryLucene2.luceneTotalDescription": "Lucene 用于当前索引的堆内存合计。这是主分片和副本分片的其他字段合计。", - "xpack.monitoring.metrics.esIndex.indexMemoryLucene2.luceneTotalLabel": "Lucene 合计", - "xpack.monitoring.metrics.esIndex.indexMemoryLucene2Title": "索引内存 - Lucene 2", - "xpack.monitoring.metrics.esIndex.indexMemoryLucene3.luceneTotalDescription": "Lucene 用于当前索引的堆内存合计。这是主分片和副本分片的其他字段合计。", - "xpack.monitoring.metrics.esIndex.indexMemoryLucene3.luceneTotalLabel": "Lucene 合计", - "xpack.monitoring.metrics.esIndex.indexMemoryLucene3Title": "索引内存 - Lucene 3", - "xpack.monitoring.metrics.esIndex.indexWriterDescription": "索引编写器使用的堆内存。这不是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esIndex.indexWriterLabel": "索引编写器", - "xpack.monitoring.metrics.esIndex.latency.indexingLatencyDescription": "索引文档的平均延迟,即索引文档所用时间除以索引文档的数目。这仅考虑主分片。", - "xpack.monitoring.metrics.esIndex.latency.indexingLatencyLabel": "索引延迟", - "xpack.monitoring.metrics.esIndex.latency.searchLatencyDescription": "搜索的平均延迟,即执行搜索所用的时间除以提交的搜索数目。这考虑主分片和副本分片。", - "xpack.monitoring.metrics.esIndex.latency.searchLatencyLabel": "搜索延迟", - "xpack.monitoring.metrics.esIndex.latencyTitle": "延迟", - "xpack.monitoring.metrics.esIndex.luceneTotalDescription": "Lucene 用于当前索引的堆内存合计。这是主分片和副本分片的其他字段合计。", - "xpack.monitoring.metrics.esIndex.luceneTotalLabel": "Lucene 合计", - "xpack.monitoring.metrics.esIndex.normsDescription": "Norms(查询时间、文本评分的标准化因子)使用的堆内存。这是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esIndex.normsLabel": "Norms", - "xpack.monitoring.metrics.esIndex.pointsDescription": "Points(数字、IP 和地理数据)使用的堆内存。这是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esIndex.pointsLabel": "Points", - "xpack.monitoring.metrics.esIndex.refreshTime.primariesDescription": "对主分片执行刷新操作所花费的时间量。", - "xpack.monitoring.metrics.esIndex.refreshTime.primariesLabel": "主分片", - "xpack.monitoring.metrics.esIndex.refreshTime.totalDescription": "对主分片和副本分片执行刷新操作所花费的时间量。", - "xpack.monitoring.metrics.esIndex.refreshTime.totalLabel": "合计", - "xpack.monitoring.metrics.esIndex.refreshTimeTitle": "刷新时间", - "xpack.monitoring.metrics.esIndex.requestCacheDescription": "请求缓存(例如即时聚合)使用的堆内存。这用于相同的分片,但不是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esIndex.requestCacheLabel": "请求缓存", - "xpack.monitoring.metrics.esIndex.requestRate.indexTotalDescription": "索引操作数量。", - "xpack.monitoring.metrics.esIndex.requestRate.indexTotalLabel": "索引合计", - "xpack.monitoring.metrics.esIndex.requestRate.searchTotalDescription": "搜索操作数量(每分片)。", - "xpack.monitoring.metrics.esIndex.requestRate.searchTotalLabel": "搜索合计", - "xpack.monitoring.metrics.esIndex.requestRateTitle": "请求速率", - "xpack.monitoring.metrics.esIndex.requestTime.indexingDescription": "对主分片和副本分片执行索引操作所花费的时间量。", - "xpack.monitoring.metrics.esIndex.requestTime.indexingLabel": "索引", - "xpack.monitoring.metrics.esIndex.requestTime.indexingPrimariesDescription": "仅对主分片执行索引操作所花费的时间量。", - "xpack.monitoring.metrics.esIndex.requestTime.indexingPrimariesLabel": "索引(主分片)", - "xpack.monitoring.metrics.esIndex.requestTime.searchDescription": "执行搜索操作所花费的时间量(每分片)。", - "xpack.monitoring.metrics.esIndex.requestTime.searchLabel": "搜索", - "xpack.monitoring.metrics.esIndex.requestTimeTitle": "请求时间", - "xpack.monitoring.metrics.esIndex.searchRate.totalShardsDescription": "跨主分片和副本分片执行的搜索请求数目。可以对多个分片运行单个搜索!", - "xpack.monitoring.metrics.esIndex.searchRate.totalShardsLabel": "分片合计", - "xpack.monitoring.metrics.esIndex.searchRateTitle": "搜索速率", - "xpack.monitoring.metrics.esIndex.segmentCount.primariesDescription": "主分片的段数。", - "xpack.monitoring.metrics.esIndex.segmentCount.primariesLabel": "主分片", - "xpack.monitoring.metrics.esIndex.segmentCount.totalDescription": "主分片和副本分片的段数。", - "xpack.monitoring.metrics.esIndex.segmentCount.totalLabel": "合计", - "xpack.monitoring.metrics.esIndex.segmentCountTitle": "段计数", - "xpack.monitoring.metrics.esIndex.storedFieldsDescription": "存储字段(例如 _source)使用的堆内存。这是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esIndex.storedFieldsLabel": "存储字段", - "xpack.monitoring.metrics.esIndex.termsDescription": "词使用的堆内存(例如文本)。这是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esIndex.termsLabel": "词", - "xpack.monitoring.metrics.esIndex.termVectorsDescription": "字词向量使用的堆内存。这是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esIndex.termVectorsLabel": "字词向量", - "xpack.monitoring.metrics.esIndex.throttleTime.indexingDescription": "对主分片和副本分片限制索引操作所花费的时间量。", - "xpack.monitoring.metrics.esIndex.throttleTime.indexingLabel": "索引", - "xpack.monitoring.metrics.esIndex.throttleTime.indexingPrimariesDescription": "对主分片限制索引操作所花费的时间量。", - "xpack.monitoring.metrics.esIndex.throttleTime.indexingPrimariesLabel": "索引(主分片)", - "xpack.monitoring.metrics.esIndex.throttleTimeTitle": "限制时间", - "xpack.monitoring.metrics.esIndex.versionMapDescription": "版本控制(例如更新和删除)使用的堆内存。这不是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esIndex.versionMapLabel": "版本映射", - "xpack.monitoring.metrics.esNode.cgroupCfsStats.cgroupElapsedPeriodsDescription": "完全公平调度器 (CFS) 的采样期间数目。与限制的次数比较。", - "xpack.monitoring.metrics.esNode.cgroupCfsStats.cgroupElapsedPeriodsLabel": "Cgroup 已用期间", - "xpack.monitoring.metrics.esNode.cgroupCfsStats.cgroupThrottledCountDescription": "Cgroup 限制 CPU 的次数。", - "xpack.monitoring.metrics.esNode.cgroupCfsStats.cgroupThrottledCountLabel": "Cgroup 限制计数", - "xpack.monitoring.metrics.esNode.cgroupCfsStatsTitle": "Cgroup CFS 统计", - "xpack.monitoring.metrics.esNode.cgroupCpuPerformance.cgroupThrottlingDescription": "Cgroup 的限制时间量,以纳秒为单位。", - "xpack.monitoring.metrics.esNode.cgroupCpuPerformance.cgroupThrottlingLabel": "Cgroup 限制", - "xpack.monitoring.metrics.esNode.cgroupCpuPerformance.cgroupUsageDescription": "Cgroup 的使用,以纳秒为单位。将其与限制比较以发现问题。", - "xpack.monitoring.metrics.esNode.cgroupCpuPerformance.cgroupUsageLabel": "Cgroup 使用", - "xpack.monitoring.metrics.esNode.cgroupCpuPerformanceTitle": "Cgroup CPU 性能", - "xpack.monitoring.metrics.esNode.cpuUtilization.cgroupCpuUtilizationDescription": "与 CPU 配额相比较的 CPU 使用时间(显示为百分比)。如果未设置 CPU 配额,将不会显示任何数据。", - "xpack.monitoring.metrics.esNode.cpuUtilization.cgroupCpuUtilizationLabel": "Cgroup CPU 使用率", - "xpack.monitoring.metrics.esNode.cpuUtilizationDescription": "Elasticsearch 进程的 CPU 使用百分比。", - "xpack.monitoring.metrics.esNode.cpuUtilizationLabel": "CPU 使用率", - "xpack.monitoring.metrics.esNode.cpuUtilizationTitle": "CPU 使用率", - "xpack.monitoring.metrics.esNode.diskFreeSpaceDescription": "节点上的可用磁盘空间。", - "xpack.monitoring.metrics.esNode.diskFreeSpaceLabel": "磁盘可用空间", - "xpack.monitoring.metrics.esNode.documentCountDescription": "总文档数目,仅包括主分片。", - "xpack.monitoring.metrics.esNode.documentCountLabel": "文档计数", - "xpack.monitoring.metrics.esNode.docValuesDescription": "文档值使用的堆大小。这是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esNode.docValuesLabel": "文档值", - "xpack.monitoring.metrics.esNode.fielddataDescription": "Fielddata(例如全局序号或文本字段上显式启用的 Fielddata)使用的堆内存。这用于相同的分片,但不是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esNode.fielddataLabel": "Fielddata", - "xpack.monitoring.metrics.esNode.fixedBitsetsDescription": "固定位组(例如深嵌套文档)使用的堆内存。这是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esNode.fixedBitsetsLabel": "固定位组", - "xpack.monitoring.metrics.esNode.gcCount.oldDescription": "旧代垃圾回收的数目。", - "xpack.monitoring.metrics.esNode.gcCount.oldLabel": "旧代", - "xpack.monitoring.metrics.esNode.gcCount.youngDescription": "新代垃圾回收的数目。", - "xpack.monitoring.metrics.esNode.gcCount.youngLabel": "新代", - "xpack.monitoring.metrics.esNode.gcDuration.oldDescription": "执行旧代垃圾回收所花费的时间。", - "xpack.monitoring.metrics.esNode.gcDuration.oldLabel": "旧代", - "xpack.monitoring.metrics.esNode.gcDuration.youngDescription": "执行新代垃圾回收所花费的时间。", - "xpack.monitoring.metrics.esNode.gcDuration.youngLabel": "新代", - "xpack.monitoring.metrics.esNode.gsCountTitle": "GC 计数", - "xpack.monitoring.metrics.esNode.gsDurationTitle": "GC 持续时间", - "xpack.monitoring.metrics.esNode.indexingThreads.searchRejectionsDescription": "被拒绝(发生在队列已满时)的搜索操作数目。", - "xpack.monitoring.metrics.esNode.indexingThreads.searchRejectionsLabel": "搜索拒绝", - "xpack.monitoring.metrics.esNode.indexingThreads.writeQueueDescription": "队列中索引、批处理和写入操作的数目。批处理线程池已重命名以在 6.3 中写入,索引线程池已弃用。", - "xpack.monitoring.metrics.esNode.indexingThreads.writeQueueLabel": "写入队列", - "xpack.monitoring.metrics.esNode.indexingThreads.writeRejectionsDescription": "被拒绝(发生在队列已满时)的索引、批处理和写入操作数目。批处理线程池已重命名以在 6.3 中写入,索引线程池已弃用。", - "xpack.monitoring.metrics.esNode.indexingThreads.writeRejectionsLabel": "写入拒绝", - "xpack.monitoring.metrics.esNode.indexingThreadsTitle": "索引线程", - "xpack.monitoring.metrics.esNode.indexingTime.indexThrottlingTimeDescription": "因索引限制所花费的时间量,其表示节点上的磁盘运行缓慢。", - "xpack.monitoring.metrics.esNode.indexingTime.indexThrottlingTimeLabel": "索引限制时间", - "xpack.monitoring.metrics.esNode.indexingTime.indexTimeDescription": "索引操作所花费的时间量。", - "xpack.monitoring.metrics.esNode.indexingTime.indexTimeLabel": "索引时间", - "xpack.monitoring.metrics.esNode.indexingTimeTitle": "索引时间", - "xpack.monitoring.metrics.esNode.indexMemoryEs.queryCacheDescription": "查询缓存(例如缓存的筛选)使用的堆内存。这用于相同的分片,但不是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esNode.indexMemoryEs.queryCacheLabel": "查询缓存", - "xpack.monitoring.metrics.esNode.indexMemoryEsTitle": "索引内存 - {elasticsearch}", - "xpack.monitoring.metrics.esNode.indexMemoryLucene1.lucenceTotalDescription": "Lucene 用于当前索引的堆内存合计。这是此节点上主分片和副本分片的其他字段合计。", - "xpack.monitoring.metrics.esNode.indexMemoryLucene1.lucenceTotalLabel": "Lucene 合计", - "xpack.monitoring.metrics.esNode.indexMemoryLucene1Title": "索引内存 - Lucene 1", - "xpack.monitoring.metrics.esNode.indexMemoryLucene2.lucenceTotalDescription": "Lucene 用于当前索引的堆内存合计。这是此节点上主分片和副本分片的其他字段合计。", - "xpack.monitoring.metrics.esNode.indexMemoryLucene2.lucenceTotalLabel": "Lucene 合计", - "xpack.monitoring.metrics.esNode.indexMemoryLucene2Title": "索引内存 - Lucene 2", - "xpack.monitoring.metrics.esNode.indexMemoryLucene3.lucenceTotalDescription": "Lucene 用于当前索引的堆内存合计。这是此节点上主分片和副本分片的其他字段合计。", - "xpack.monitoring.metrics.esNode.indexMemoryLucene3.lucenceTotalLabel": "Lucene 合计", - "xpack.monitoring.metrics.esNode.indexMemoryLucene3Title": "索引内存 - Lucene 3", - "xpack.monitoring.metrics.esNode.indexThrottlingTimeDescription": "因索引限制所花费的时间量,其表示合并缓慢。", - "xpack.monitoring.metrics.esNode.indexThrottlingTimeLabel": "索引限制时间", - "xpack.monitoring.metrics.esNode.indexWriterDescription": "索引编写器使用的堆内存。这不是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esNode.indexWriterLabel": "索引编写器", - "xpack.monitoring.metrics.esNode.jvmHeap.maxHeapDescription": "可用于 JVM 中运行的 Elasticsearch 的堆合计。", - "xpack.monitoring.metrics.esNode.jvmHeap.maxHeapLabel": "最大堆", - "xpack.monitoring.metrics.esNode.jvmHeap.usedHeapDescription": "在 JVM 中运行的 Elasticsearch 使用的堆合计。", - "xpack.monitoring.metrics.esNode.jvmHeap.usedHeapLabel": "已用堆", - "xpack.monitoring.metrics.esNode.jvmHeapTitle": "{javaVirtualMachine} 堆", - "xpack.monitoring.metrics.esNode.latency.indexingDescription": "索引文档的平均延迟,即索引文档所用时间除以索引文档的数目。这考虑位于此节点上的任何分片,包括副本分片。", - "xpack.monitoring.metrics.esNode.latency.indexingLabel": "索引", - "xpack.monitoring.metrics.esNode.latency.searchDescription": "搜索的平均延迟,即执行搜索所用的时间除以提交的搜索数目。这考虑主分片和副本分片。", - "xpack.monitoring.metrics.esNode.latency.searchLabel": "搜索", - "xpack.monitoring.metrics.esNode.latencyTitle": "延迟", - "xpack.monitoring.metrics.esNode.luceneTotalDescription": "Lucene 用于当前索引的堆内存合计。这是此节点上主分片和副本分片的其他字段合计。", - "xpack.monitoring.metrics.esNode.luceneTotalLabel": "Lucene 合计", - "xpack.monitoring.metrics.esNode.mergeRateDescription": "已合并段的字节数。较大数值表示磁盘活动较密集。", - "xpack.monitoring.metrics.esNode.mergeRateLabel": "合并速率", - "xpack.monitoring.metrics.esNode.normsDescription": "Norms(查询时间、文本评分的标准化因子)使用的堆内存。这是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esNode.normsLabel": "Norms", - "xpack.monitoring.metrics.esNode.pointsDescription": "Points(数字、IP 和地理数据)使用的堆内存。这是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esNode.pointsLabel": "Points", - "xpack.monitoring.metrics.esNode.readThreads.getQueueDescription": "队列中的 GET 操作数目。", - "xpack.monitoring.metrics.esNode.readThreads.getQueueLabel": "GET 队列", - "xpack.monitoring.metrics.esNode.readThreads.getRejectionsDescription": "被拒绝(发生在队列已满时)的 GET 操作数目。", - "xpack.monitoring.metrics.esNode.readThreads.getRejectionsLabel": "GET 拒绝", - "xpack.monitoring.metrics.esNode.readThreads.searchQueueDescription": "队列中搜索操作的数目(例如分片级别搜索)。", - "xpack.monitoring.metrics.esNode.readThreads.searchQueueLabel": "搜索队列", - "xpack.monitoring.metrics.esNode.readThreadsTitle": "读取线程", - "xpack.monitoring.metrics.esNode.requestCacheDescription": "请求缓存(例如即时聚合)使用的堆内存。这用于相同的分片,但不是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esNode.requestCacheLabel": "请求缓存", - "xpack.monitoring.metrics.esNode.requestRate.indexingTotalDescription": "索引操作数量。", - "xpack.monitoring.metrics.esNode.requestRate.indexingTotalLabel": "索引合计", - "xpack.monitoring.metrics.esNode.requestRate.searchTotalDescription": "搜索操作数量(每分片)。", - "xpack.monitoring.metrics.esNode.requestRate.searchTotalLabel": "搜索合计", - "xpack.monitoring.metrics.esNode.requestRateTitle": "请求速率", - "xpack.monitoring.metrics.esNode.searchRate.totalShardsDescription": "跨主分片和副本分片执行的搜索请求数目。可以对多个分片运行单个搜索!", - "xpack.monitoring.metrics.esNode.searchRate.totalShardsLabel": "分片合计", - "xpack.monitoring.metrics.esNode.searchRateTitle": "搜索速率", - "xpack.monitoring.metrics.esNode.segmentCountDescription": "此节点上主分片和副本分片的最大段计数。", - "xpack.monitoring.metrics.esNode.segmentCountLabel": "段计数", - "xpack.monitoring.metrics.esNode.storedFieldsDescription": "存储字段(例如 _source)使用的堆内存。这是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esNode.storedFieldsLabel": "存储字段", - "xpack.monitoring.metrics.esNode.systemLoad.last1MinuteDescription": "过去 1 分钟的负载平均值。", - "xpack.monitoring.metrics.esNode.systemLoad.last1MinuteLabel": "1 分钟", - "xpack.monitoring.metrics.esNode.systemLoadTitle": "系统负载", - "xpack.monitoring.metrics.esNode.termsDescription": "词使用的堆内存(例如文本)。这是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esNode.termsLabel": "词", - "xpack.monitoring.metrics.esNode.termVectorsDescription": "字词向量使用的堆内存。这是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esNode.termVectorsLabel": "字词向量", - "xpack.monitoring.metrics.esNode.threadQueue.getDescription": "此节点上等候处理的 Get 操作数目。", - "xpack.monitoring.metrics.esNode.threadQueue.getLabel": "Get", - "xpack.monitoring.metrics.esNode.threadQueueTitle": "线程队列", - "xpack.monitoring.metrics.esNode.threadsQueued.bulkDescription": "此节点上等候处理的批处理索引操作数目。单个批处理请求可以创建多个批处理操作。", - "xpack.monitoring.metrics.esNode.threadsQueued.bulkLabel": "批处理", - "xpack.monitoring.metrics.esNode.threadsQueued.genericDescription": "此节点上等候处理的常规(内部)操作数目。", - "xpack.monitoring.metrics.esNode.threadsQueued.genericLabel": "常规", - "xpack.monitoring.metrics.esNode.threadsQueued.indexDescription": "此节点上等候处理的非批处理索引操作数目。", - "xpack.monitoring.metrics.esNode.threadsQueued.indexLabel": "索引", - "xpack.monitoring.metrics.esNode.threadsQueued.managementDescription": "此节点上等候处理的管理(内部)操作数目。", - "xpack.monitoring.metrics.esNode.threadsQueued.managementLabel": "管理", - "xpack.monitoring.metrics.esNode.threadsQueued.searchDescription": "此节点上等候处理的搜索操作数目。单个搜索请求可以创建多个搜索操作。", - "xpack.monitoring.metrics.esNode.threadsQueued.searchLabel": "搜索", - "xpack.monitoring.metrics.esNode.threadsQueued.watcherDescription": "此节点上等候处理的 Watcher 操作数目。", - "xpack.monitoring.metrics.esNode.threadsQueued.watcherLabel": "Watcher", - "xpack.monitoring.metrics.esNode.threadsRejected.bulkDescription": "批处理拒绝。队列已满时发生这些拒绝。", - "xpack.monitoring.metrics.esNode.threadsRejected.bulkLabel": "批处理", - "xpack.monitoring.metrics.esNode.threadsRejected.genericDescription": "常规(内部)拒绝。队列已满时发生这些拒绝。", - "xpack.monitoring.metrics.esNode.threadsRejected.genericLabel": "常规", - "xpack.monitoring.metrics.esNode.threadsRejected.getDescription": "Get 拒绝。队列已满时发生这些拒绝。", - "xpack.monitoring.metrics.esNode.threadsRejected.getLabel": "Get", - "xpack.monitoring.metrics.esNode.threadsRejected.indexDescription": "索引拒绝。队列已满时发生这些拒绝。应查看批处理索引。", - "xpack.monitoring.metrics.esNode.threadsRejected.indexLabel": "索引", - "xpack.monitoring.metrics.esNode.threadsRejected.managementDescription": "Get(内部)拒绝。队列已满时发生这些拒绝。", - "xpack.monitoring.metrics.esNode.threadsRejected.managementLabel": "管理", - "xpack.monitoring.metrics.esNode.threadsRejected.searchDescription": "搜索拒绝。队列已满时发生这些拒绝。这可能表明分片过量。", - "xpack.monitoring.metrics.esNode.threadsRejected.searchLabel": "搜索", - "xpack.monitoring.metrics.esNode.threadsRejected.watcherDescription": "监视拒绝。队列已满时发生这些拒绝。这可能表明监视堆积。", - "xpack.monitoring.metrics.esNode.threadsRejected.watcherLabel": "Watcher", - "xpack.monitoring.metrics.esNode.totalRefreshTimeDescription": "Elasticsearch 刷新主分片和副本分片所用的时间。", - "xpack.monitoring.metrics.esNode.totalRefreshTimeLabel": "总刷新时间", - "xpack.monitoring.metrics.esNode.versionMapDescription": "版本控制(例如更新和删除)使用的堆内存。这不是 Lucene 合计的组成部分。", - "xpack.monitoring.metrics.esNode.versionMapLabel": "版本映射", - "xpack.monitoring.metrics.kibana.clientRequestsDescription": "Kibana 实例接收的客户端请求总数。", - "xpack.monitoring.metrics.kibana.clientRequestsLabel": "客户端请求", - "xpack.monitoring.metrics.kibana.clientResponseTime.averageDescription": "Kibana 实例对客户端请求的平均响应时间。", - "xpack.monitoring.metrics.kibana.clientResponseTime.averageLabel": "平均值", - "xpack.monitoring.metrics.kibana.clientResponseTime.maxDescription": "Kibana 实例对客户端请求的最大响应时间。", - "xpack.monitoring.metrics.kibana.clientResponseTime.maxLabel": "最大值", - "xpack.monitoring.metrics.kibana.clientResponseTimeTitle": "客户端响应时间", - "xpack.monitoring.metrics.kibana.httpConnectionsDescription": "Kibana 实例打开的套接字连接总数。", - "xpack.monitoring.metrics.kibana.httpConnectionsLabel": "HTTP 连接", - "xpack.monitoring.metrics.kibana.msTimeUnitLabel": "ms", - "xpack.monitoring.metrics.kibanaInstance.clientRequestsDescription": "Kibana 实例接收的客户端请求总数。", - "xpack.monitoring.metrics.kibanaInstance.clientRequestsLabel": "客户端请求", - "xpack.monitoring.metrics.kibanaInstance.clientResponseTime.averageDescription": "Kibana 实例对客户端请求的平均响应时间。", - "xpack.monitoring.metrics.kibanaInstance.clientResponseTime.averageLabel": "平均值", - "xpack.monitoring.metrics.kibanaInstance.clientResponseTime.maxDescription": "Kibana 实例对客户端请求的最大响应时间。", - "xpack.monitoring.metrics.kibanaInstance.clientResponseTime.maxLabel": "最大值", - "xpack.monitoring.metrics.kibanaInstance.clientResponseTimeTitle": "客户端响应时间", - "xpack.monitoring.metrics.kibanaInstance.eventLoopDelayDescription": "Kibana 服务器事件循环中的延迟。较长的延迟可能表示在服务器线程中有阻止事件,例如同步函数占用大量的 CPU 时间。", - "xpack.monitoring.metrics.kibanaInstance.eventLoopDelayLabel": "事件循环延迟", - "xpack.monitoring.metrics.kibanaInstance.memorySize.heapSizeLimitDescription": "垃圾回收前的内存利用率限制。", - "xpack.monitoring.metrics.kibanaInstance.memorySize.heapSizeLimitLabel": "堆大小限制", - "xpack.monitoring.metrics.kibanaInstance.memorySizeDescription": "在 Node.js 中运行的 Kibana 使用的堆合计。", - "xpack.monitoring.metrics.kibanaInstance.memorySizeLabel": "内存大小", - "xpack.monitoring.metrics.kibanaInstance.memorySizeTitle": "内存大小", - "xpack.monitoring.metrics.kibanaInstance.systemLoad.last15MinutesDescription": "过去 15 分钟的负载平均值。", - "xpack.monitoring.metrics.kibanaInstance.systemLoad.last15MinutesLabel": "15 分钟", - "xpack.monitoring.metrics.kibanaInstance.systemLoad.last1MinuteDescription": "过去 1 分钟的负载平均值。", - "xpack.monitoring.metrics.kibanaInstance.systemLoad.last1MinuteLabel": "1 分钟", - "xpack.monitoring.metrics.kibanaInstance.systemLoad.last5MinutesDescription": "过去 5 分钟的负载平均值。", - "xpack.monitoring.metrics.kibanaInstance.systemLoad.last5MinutesLabel": "5 分钟", - "xpack.monitoring.metrics.kibanaInstance.systemLoadTitle": "系统负载", - "xpack.monitoring.metrics.logstash.eventLatencyDescription": "事件在筛选和输出阶段所花费的平均时间,即处理事件所用的总时间除以已发出事件数目。", - "xpack.monitoring.metrics.logstash.eventLatencyLabel": "事件延迟", - "xpack.monitoring.metrics.logstash.eventsEmittedRateDescription": "所有 Logstash 节点在输出阶段每秒发出的事件数目。", - "xpack.monitoring.metrics.logstash.eventsEmittedRateLabel": "已发出事件速率", - "xpack.monitoring.metrics.logstash.eventsPerSecondUnitLabel": "事件/秒", - "xpack.monitoring.metrics.logstash.eventsReceivedRateDescription": "所有 Logstash 节点在输入阶段每秒接收的事件数目。", - "xpack.monitoring.metrics.logstash.eventsReceivedRateLabel": "已接收事件速率", - "xpack.monitoring.metrics.logstash.msTimeUnitLabel": "ms", - "xpack.monitoring.metrics.logstash.nsTimeUnitLabel": "纳秒", - "xpack.monitoring.metrics.logstash.perSecondUnitLabel": "/秒", - "xpack.monitoring.metrics.logstash.systemLoadTitle": "系统负载", - "xpack.monitoring.metrics.logstashInstance.cgroupCfsStats.cgroupElapsedPeriodsDescription": "完全公平调度器 (CFS) 的采样期间数目。与限制的次数比较。", - "xpack.monitoring.metrics.logstashInstance.cgroupCfsStats.cgroupElapsedPeriodsLabel": "Cgroup 已用期间", - "xpack.monitoring.metrics.logstashInstance.cgroupCfsStats.cgroupThrottledCountDescription": "Cgroup 限制 CPU 的次数。", - "xpack.monitoring.metrics.logstashInstance.cgroupCfsStats.cgroupThrottledCountLabel": "Cgroup 限制计数", - "xpack.monitoring.metrics.logstashInstance.cgroupCfsStatsTitle": "Cgroup CFS 统计", - "xpack.monitoring.metrics.logstashInstance.cgroupCpuPerformance.cgroupThrottlingDescription": "Cgroup 的限制时间量,以纳秒为单位。", - "xpack.monitoring.metrics.logstashInstance.cgroupCpuPerformance.cgroupThrottlingLabel": "Cgroup 限制", - "xpack.monitoring.metrics.logstashInstance.cgroupCpuPerformance.cgroupUsageDescription": "Cgroup 的使用,以纳秒为单位。将其与限制比较以发现问题。", - "xpack.monitoring.metrics.logstashInstance.cgroupCpuPerformance.cgroupUsageLabel": "Cgroup 使用", - "xpack.monitoring.metrics.logstashInstance.cgroupCpuPerformanceTitle": "Cgroup CPU 性能", - "xpack.monitoring.metrics.logstashInstance.cgroupCpuUtilizationDescription": "与 CPU 配额相比较的 CPU 使用时间(显示为百分比)。如果未设置 CPU 配额,将不会显示任何数据。", - "xpack.monitoring.metrics.logstashInstance.cpuUtilization.cgroupCpuUtilizationLabel": "Cgroup CPU 使用率", - "xpack.monitoring.metrics.logstashInstance.cpuUtilizationDescription": "OS 报告的 CPU 使用百分比(100% 为最大值)。", - "xpack.monitoring.metrics.logstashInstance.cpuUtilizationLabel": "CPU 使用率", - "xpack.monitoring.metrics.logstashInstance.cpuUtilizationTitle": "CPU 使用率", - "xpack.monitoring.metrics.logstashInstance.eventLatencyDescription": "事件在筛选和输出阶段所花费的平均时间,即处理事件所用的总时间除以已发出事件数目。", - "xpack.monitoring.metrics.logstashInstance.eventLatencyLabel": "事件延迟", - "xpack.monitoring.metrics.logstashInstance.eventsEmittedRateDescription": "Logstash 节点在输出阶段每秒发出的事件数目。", - "xpack.monitoring.metrics.logstashInstance.eventsEmittedRateLabel": "已发出事件速率", - "xpack.monitoring.metrics.logstashInstance.eventsQueuedDescription": "在永久队列中等候筛选和输出阶段处理的平均事件数目。", - "xpack.monitoring.metrics.logstashInstance.eventsQueuedLabel": "已排队事件", - "xpack.monitoring.metrics.logstashInstance.eventsReceivedRateDescription": "Logstash 节点在输入阶段每秒接收的事件数目。", - "xpack.monitoring.metrics.logstashInstance.eventsReceivedRateLabel": "已接收事件速率", - "xpack.monitoring.metrics.logstashInstance.jvmHeap.maxHeapDescription": "可用于 JVM 中运行的 Logstash 的堆合计。", - "xpack.monitoring.metrics.logstashInstance.jvmHeap.maxHeapLabel": "最大堆", - "xpack.monitoring.metrics.logstashInstance.jvmHeap.usedHeapDescription": "JVM 中运行的 Logstash 使用的堆合计。", - "xpack.monitoring.metrics.logstashInstance.jvmHeap.usedHeapLabel": "已用堆", - "xpack.monitoring.metrics.logstashInstance.jvmHeapTitle": "{javaVirtualMachine} 堆", - "xpack.monitoring.metrics.logstashInstance.maxQueueSizeDescription": "为此节点上的持久队列设置的最大大小。", - "xpack.monitoring.metrics.logstashInstance.maxQueueSizeLabel": "最大队列大小", - "xpack.monitoring.metrics.logstashInstance.persistentQueueEventsTitle": "持久队列事件", - "xpack.monitoring.metrics.logstashInstance.persistentQueueSizeTitle": "持久队列大小", - "xpack.monitoring.metrics.logstashInstance.pipelineNodeCountDescription": "正在运行 Logstash 管道的节点数目。", - "xpack.monitoring.metrics.logstashInstance.pipelineNodeCountLabel": "管道节点计数", - "xpack.monitoring.metrics.logstashInstance.pipelineThroughputDescription": "Logstash 管道在输出阶段每秒发出的事件数目。", - "xpack.monitoring.metrics.logstashInstance.pipelineThroughputLabel": "管道吞吐量", - "xpack.monitoring.metrics.logstashInstance.queueSizeDescription": "此节点上 Logstash 管道中的所有持久队列的当前大小。", - "xpack.monitoring.metrics.logstashInstance.queueSizeLabel": "队列大小", - "xpack.monitoring.metrics.logstashInstance.systemLoad.last15MinutesDescription": "过去 15 分钟的负载平均值。", - "xpack.monitoring.metrics.logstashInstance.systemLoad.last15MinutesLabel": "15 分钟", - "xpack.monitoring.metrics.logstashInstance.systemLoad.last1MinuteDescription": "过去 1 分钟的负载平均值。", - "xpack.monitoring.metrics.logstashInstance.systemLoad.last1MinuteLabel": "1 分钟", - "xpack.monitoring.metrics.logstashInstance.systemLoad.last5MinutesDescription": "过去 5 分钟的负载平均值。", - "xpack.monitoring.metrics.logstashInstance.systemLoad.last5MinutesLabel": "5 分钟", - "xpack.monitoring.monitoringDescription": "跟踪 Elastic Stack 的实时运行状况和性能。", - "xpack.monitoring.monitoringTitle": "Monitoring", - "xpack.monitoring.noData.blurbs.changesNeededDescription": "要运行 Monitoring,请执行以下步骤", - "xpack.monitoring.noData.blurbs.changesNeededTitle": "您需要做些调整", - "xpack.monitoring.noData.blurbs.lookingForMonitoringDataDescription": "通过 Monitoring,可深入了解您的硬件性能和负载。", - "xpack.monitoring.noData.blurbs.lookingForMonitoringDataTitle": "我们正在寻找您的监测数据", - "xpack.monitoring.noData.blurbs.monitoringIsOffDescription": "通过 Monitoring,可深入了解您的硬件性能和负载。", - "xpack.monitoring.noData.blurbs.monitoringIsOffTitle": "Monitoring 当前已关闭", - "xpack.monitoring.noData.checkerErrors.checkEsSettingsErrorMessage": "尝试检查 Elasticsearch 设置时遇到一些错误。您需要管理员权限,才能检查设置以及根据需要启用监测收集设置。", - "xpack.monitoring.noData.explanations.collectionEnabled.monitoringTurnedOnDescription": "数据在您的集群中时,您的监测仪表板将显示在此处。这可能需要几秒钟的时间。", - "xpack.monitoring.noData.explanations.collectionEnabled.monitoringTurnedOnTitle": "成功!获取您的监测数据。", - "xpack.monitoring.noData.explanations.collectionEnabled.stillWaitingLinkText": "仍在等候?", - "xpack.monitoring.noData.explanations.collectionEnabled.turnItOnDescription": "是否要打开它?", - "xpack.monitoring.noData.explanations.collectionEnabled.turnOnMonitoringButtonLabel": "打开 Monitoring", - "xpack.monitoring.noData.explanations.collectionEnabledDescription": "我们已检查 {context} 设置,发现 {property} 已设置为 {data}。", - "xpack.monitoring.noData.explanations.collectionInterval.changeIntervalDescription": "是否希望我们更改该设置并启用 Monitoring?", - "xpack.monitoring.noData.explanations.collectionInterval.monitoringTurnedOnDescription": "监测数据一显示在集群中,该页面便会自动刷新您的监测仪表板。这只需要几秒的时间。", - "xpack.monitoring.noData.explanations.collectionInterval.monitoringTurnedOnTitle": "成功!请稍候。", - "xpack.monitoring.noData.explanations.collectionInterval.turnOnMonitoringButtonLabel": "打开 Monitoring", - "xpack.monitoring.noData.explanations.collectionInterval.wrongIntervalValueDescription": "收集时间间隔设置需要为正整数(推荐 10s),以便收集代理能够处于活动状态。", - "xpack.monitoring.noData.explanations.collectionIntervalDescription": "我们已检查 {context} 设置,发现 {property} 已设置为 {data}。", - "xpack.monitoring.noData.explanations.exporters.checkConfigDescription": "确认用于将统计信息发送到监测集群的导出器已启用,且监测集群主机匹配 {kibanaConfig} 中的 {monitoringEs} 设置,以查看此 Kibana 实例中的监测数据。", - "xpack.monitoring.noData.explanations.exporters.problemWithConfigDescription": "强烈推荐使用监测导出器将监测数据传输到远程监测集群,因为无论生产集群出现什么状况,该监测集群都可以确保监测数据的完整性。不过,因为此 Kibana 实例无法查找到任何监测数据,所以似乎 {property} 配置或 {kibanaConfig} 中的 {monitoringEs} 设置有问题。", - "xpack.monitoring.noData.explanations.exportersDescription": "我们已检查 {property} 的 {context} 设置并发现了原因:{data}。", - "xpack.monitoring.noData.explanations.pluginEnabledDescription": "我们已检查 {context} 设置,发现 {property} 已设置为 {data},这禁用了 Monitoring。将 {monitoringEnableFalse} 设置从您的配置中删除将会使默认值生效,并会启用 Monitoring。", - "xpack.monitoring.noData.reasons.couldNotActivateMonitoringTitle": "我们无法激活 Monitoring", - "xpack.monitoring.noData.reasons.explainWhyNoDataDescription": "存在将 {property} 设置为 {data} 的 {context} 设置。", - "xpack.monitoring.noData.reasons.ifDataInClusterDescription": "如果数据在您的集群中,您的监测仪表板将显示在此处。", - "xpack.monitoring.noData.reasons.noMonitoringDataFoundDescription": "找不到任何监测数据。尝试将时间筛选设置为“过去 1 小时”或检查是否有其他时段的数据。", - "xpack.monitoring.pageLoadingTitle": "正在加载……", - "xpack.monitoring.requestedClusters.uuidNotFoundErrorMessage": "在选定时间范围内找不到该集群。UUID:{clusterUuid}", - "xpack.monitoring.stackMonitoringDocTitle": "堆栈监测 {clusterName} {suffix}", - "xpack.monitoring.stackMonitoringTitle": "堆栈监测", - "xpack.monitoring.summaryStatus.statusDescription": "状态", - "xpack.monitoring.summaryStatus.statusIconLabel": "状态:{status}", - "xpack.monitoring.summaryStatus.statusIconTitle": "状态:{statusIcon}", - "xpack.monitoring.uiExportsDescription": "Elastic Stack 的 Monitoring 组件", - "xpack.monitoring.chart.timeSeries.zoomOut": "缩小", - "xpack.monitoring.errors.monitoringLicenseErrorDescription": "无法找到集群“{clusterId}”的许可信息。请在集群的主节点服务器日志中查看相关错误或警告。", - "xpack.monitoring.errors.monitoringLicenseErrorTitle": "监测许可错误", - "xpack.monitoring.logs.reason.defaultMessage": "我们未找到任何日志数据,我们无法诊断原因。{link}", - "xpack.monitoring.logs.reason.defaultMessageLink": "请确认您的设置正确。", - "xpack.monitoring.logs.reason.defaultTitle": "未找到任何日志数据", - "xpack.monitoring.metricbeatMigration.apmInstructions.configureMetricbeatDescription": "在 {file} 文件中进行这些更改。", - "xpack.monitoring.metricbeatMigration.apmInstructions.configureMetricbeatTitle": "配置 Metricbeat 以发送至监测集群", - "xpack.monitoring.metricbeatMigration.apmInstructions.disableInternalCollection.description": "在 APM Server 的配置文件 ({file}) 中添加以下设置:", - "xpack.monitoring.metricbeatMigration.apmInstructions.disableInternalCollection.note": "进行此更改后,需要重新启动 APM Server。", - "xpack.monitoring.metricbeatMigration.apmInstructions.disableInternalCollection.title": "禁用 APM Server 监测指标的内部收集", - "xpack.monitoring.metricbeatMigration.apmInstructions.enableMetricbeatModuleDescription": "该模块将默认从 http://localhost:5066 收集 APM Server 监测指标。如果本地 APM Server 有不同的地址,则必须通过 {file} 文件中的 {hosts} 设置进行指定。", - "xpack.monitoring.metricbeatMigration.apmInstructions.enableMetricbeatModuleTitle": "在 Metricbeat 中启用并配置 Beat x-pack 模块", - "xpack.monitoring.metricbeatMigration.apmInstructions.installMetricbeatLinkText": "按照此处的说明执行操作。", - "xpack.monitoring.metricbeatMigration.apmInstructions.installMetricbeatTitle": "在安装 APM Server 的同一台服务器上安装 Metricbeat", - "xpack.monitoring.metricbeatMigration.apmInstructions.startMetricbeatLinkText": "按照此处的说明执行操作。", - "xpack.monitoring.metricbeatMigration.apmInstructions.startMetricbeatTitle": "启动 Metricbeat", - "xpack.monitoring.metricbeatMigration.beatsInstructions.configureMetricbeatDescription": "在 {file} 文件中进行这些更改。", - "xpack.monitoring.metricbeatMigration.beatsInstructions.configureMetricbeatTitle": "配置 Metricbeat 以发送至监测集群", - "xpack.monitoring.metricbeatMigration.beatsInstructions.disableInternalCollection.description": "在 {beatType} 的配置文件 ({file}) 中添加以下设置:", - "xpack.monitoring.metricbeatMigration.beatsInstructions.disableInternalCollection.note": "进行此更改后,您需要重新启动 {beatType}。", - "xpack.monitoring.metricbeatMigration.beatsInstructions.disableInternalCollection.title": "禁用 {beatType} 监测指标的内部收集", - "xpack.monitoring.metricbeatMigration.beatsInstructions.enableMetricbeatModuleDescription": "该模块将默认从 http://localhost:5066 收集 {beatType} 监测指标。如果正在监测的 {beatType} 实例有不同的地址,则必须通过 {file} 文件中的 {hosts} 设置进行指定。", - "xpack.monitoring.metricbeatMigration.beatsInstructions.enableMetricbeatModuleHttpEnabledDirections": "要使 Metricbeat 从正在运行的 {beatType} 收集指标,需要{link}。", - "xpack.monitoring.metricbeatMigration.beatsInstructions.enableMetricbeatModuleHttpEnabledDirectionsLinkText": "为正在监测的 {beatType} 实例启用 HTTP 终端节点", - "xpack.monitoring.metricbeatMigration.beatsInstructions.enableMetricbeatModuleTitle": "在 Metricbeat 中启用并配置 Beat x-pack 模块", - "xpack.monitoring.metricbeatMigration.beatsInstructions.installMetricbeatLinkText": "按照此处的说明执行操作。", - "xpack.monitoring.metricbeatMigration.beatsInstructions.installMetricbeatTitle": "在安装此 {beatType} 的同一台服务器上安装 Metricbeat", - "xpack.monitoring.metricbeatMigration.beatsInstructions.startMetricbeatLinkText": "按照此处的说明执行操作。", - "xpack.monitoring.metricbeatMigration.beatsInstructions.startMetricbeatTitle": "启动 Metricbeat", - "xpack.monitoring.metricbeatMigration.flyout.noClusterUuidTitle": "未检测到集群", - "xpack.monitoring.metricbeatMigration.logstashInstructions.configureMetricbeatDescription": "在 {file} 文件中进行这些更改。", - "xpack.monitoring.metricbeatMigration.logstashInstructions.configureMetricbeatTitle": "配置 Metricbeat 以发送至监测集群", - "xpack.monitoring.metricbeatMigration.logstashInstructions.disableInternalCollection.description": "在 Logstash 配置文件 ({file}) 中添加以下设置:", - "xpack.monitoring.metricbeatMigration.logstashInstructions.disableInternalCollection.note": "进行此更改后,您需要重新启动 Logstash。", - "xpack.monitoring.metricbeatMigration.logstashInstructions.disableInternalCollection.title": "禁用 Logstash 监测指标的内部收集", - "xpack.monitoring.metricbeatMigration.logstashInstructions.enableMetricbeatModuleDescription": "该模块将默认从 http://localhost:9600 收集 Logstash 监测指标。如果本地 Logstash 实例有不同的地址,则必须通过 {file} 文件中的 {hosts} 设置进行指定。", - "xpack.monitoring.metricbeatMigration.logstashInstructions.enableMetricbeatModuleTitle": "在 Metricbeat 中启用并配置 Logstash x-pack 模块", - "xpack.monitoring.metricbeatMigration.logstashInstructions.installMetricbeatLinkText": "按照此处的说明执行操作。", - "xpack.monitoring.metricbeatMigration.logstashInstructions.installMetricbeatTitle": "在安装 Logstash 的同一台服务器上安装 Metricbeat", - "xpack.monitoring.metricbeatMigration.logstashInstructions.startMetricbeatLinkText": "按照此处的说明执行操作。", - "xpack.monitoring.metricbeatMigration.logstashInstructions.startMetricbeatTitle": "启动 Metricbeat", - "xpack.monitoring.noData.blurbs.cloudDeploymentDescription": "请返回到您的 ", - "xpack.monitoring.noData.blurbs.cloudDeploymentDescriptionMore": "有关在 Elastic Cloud 中监测的详情,请参阅 ", - "xpack.monitoring.noData.blurbs.cloudDeploymentTitle": "此处没有您的监测数据。", - "xpack.monitoring.noData.explanations.exportersCloudDescription": "在 Elastic Cloud 中,您的监测数据将存储在专用监测集群中。", - "xpack.monitoring.elasticsearch.nodes.metricbeatMigration.detectedNodeDescription": "以下节点未受监测。单击下面的“使用 Metricbeat 监测”以开始监测。", - "xpack.monitoring.elasticsearch.nodes.metricbeatMigration.detectedNodeTitle": "检测到 Elasticsearch 节点", - "xpack.monitoring.elasticsearch.nodes.metricbeatMigration.disableInternalCollectionDescription": "禁用内部收集以完成迁移。", - "xpack.monitoring.elasticsearch.nodes.metricbeatMigration.disableInternalCollectionMigrationButtonLabel": "禁用内部收集", - "xpack.monitoring.elasticsearch.nodes.metricbeatMigration.disableInternalCollectionTitle": "Metricbeat 现在正监测您的 Elasticsearch 节点", - "xpack.monitoring.euiSSPTable.setupNewButtonLabel": "为新的 {identifier} 设置监测", - "xpack.monitoring.euiTable.setupNewButtonLabel": "使用 Metricbeat 监测其他 {identifier}", - "xpack.monitoring.kibana.instances.metricbeatMigration.detectedNodeDescription": "以下实例未受监测。\n 单击下面的“使用 Metricbeat 监测”以开始监测。", - "xpack.monitoring.kibana.instances.metricbeatMigration.detectedNodeTitle": "检测到 Kibana 实例", - "xpack.monitoring.metricbeatMigration.disableInternalCollection.fullyMigratedStatusDescription": "我们未看到来自内部收集的任何文档。迁移完成!", - "xpack.monitoring.metricbeatMigration.disableInternalCollection.fullyMigratedStatusTitle": "恭喜您!", - "xpack.monitoring.metricbeatMigration.disableInternalCollection.partiallyMigratedStatusDescription": "上次内部收集是在 {secondsSinceLastInternalCollectionLabel}前。", - "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.enableMetricbeatModuleInstallDirectory": "从安装目录中,运行:", - "xpack.monitoring.metricbeatMigration.flyout.learnMore": "了解原因。", - "xpack.monitoring.metricbeatMigration.fullyMigratedStatusDescription": "Metricbeat 正在发送监测数据。", - "xpack.monitoring.metricbeatMigration.fullyMigratedStatusTitle": "恭喜您!", - "xpack.monitoring.metricbeatMigration.isInternalCollectorStatusTitle": "未检测到任何监测数据,但我们将继续检查。", - "xpack.monitoring.metricbeatMigration.migrationStatus": "迁移状态", - "xpack.monitoring.metricbeatMigration.monitoringStatus": "监测状态", - "xpack.monitoring.metricbeatMigration.partiallyMigratedStatusDescription": "最多需要 {secondsAgo} 秒钟检测到数据。", - "xpack.monitoring.metricbeatMigration.partiallyMigratedStatusTitle": "数据仍来自于内部收集", - "xpack.monitoring.metricbeatMigration.securitySetup": "如果启用了安全,可能需要{link}。", - "xpack.monitoring.metricbeatMigration.securitySetupLinkText": "其他设置", - "xpack.monitoring.metrics.esNode.ioRateTitle": "I/O 操作速率", - "xpack.monitoring.metrics.esNode.totalIoDescription": "I/O 总计。(此指标不支持所有平台,如果 I/O 数据不可用,可能显示“不可用”)", - "xpack.monitoring.metrics.esNode.totalIoLabel": "I/O 总计", - "xpack.monitoring.metrics.esNode.totalIoReadDescription": "读取 I/O 总计。(此指标不支持所有平台,如果 I/O 数据不可用,可能显示“不可用”)", - "xpack.monitoring.metrics.esNode.totalIoReadLabel": "读取 I/O 总计", - "xpack.monitoring.metrics.esNode.totalIoWriteDescription": "写入 I/O 总计。(此指标不支持所有平台,如果 I/O 数据不可用,可能显示“不可用”)", - "xpack.monitoring.metrics.esNode.totalIoWriteLabel": "写入 I/O 总计", - "xpack.monitoring.noData.collectionInterval.turnOnMonitoringButtonLabel": "使用 Metricbeat 设置监测", - "xpack.monitoring.noData.defaultLoadingMessage": "正在加载,请稍候", - "xpack.monitoring.noData.noMonitoringDataFound": "是否已设置监测?如果已设置,确保右上角所选的时间段包含监测数据。", - "xpack.monitoring.noData.noMonitoringDetected": "找不到任何监测数据", - "xpack.monitoring.noData.routeTitle": "设置监测", - "xpack.monitoring.noData.setupInternalInstead": "或,使用内部收集设置", - "xpack.monitoring.noData.setupMetricbeatInstead": "或,使用 Metricbeat 设置(推荐)", - "xpack.monitoring.setupMode.clickToDisableInternalCollection": "禁用内部收集(self monitoring)", - "xpack.monitoring.setupMode.clickToMonitorWithMetricbeat": "使用 Metricbeat 监测", - "xpack.monitoring.setupMode.description": "您处于设置模式。图标 ({flagIcon}) 表示配置选项。", - "xpack.monitoring.setupMode.detectedNodeDescription": "单击下面的“设置监测”以开始监测此 {identifier}。", - "xpack.monitoring.setupMode.detectedNodeTitle": "检测到 {product} {identifier}", - "xpack.monitoring.setupMode.disableInternalCollectionDescription": "Metricbeat 现在正监测您的 {product} {identifier}。禁用内部收集以完成迁移。", - "xpack.monitoring.setupMode.disableInternalCollectionTitle": "禁用内部收集(self monitoring)", - "xpack.monitoring.setupMode.exit": "退出设置模式", - "xpack.monitoring.setupMode.instance": "实例", - "xpack.monitoring.setupMode.instances": "实例", - "xpack.monitoring.setupMode.metricbeatAllNodes": "Metricbeat 正在监测所有 {identifier}。", - "xpack.monitoring.setupMode.migrateSomeToMetricbeatDescription": "某些 {product} {identifier} 通过内部收集进行监测。迁移到使用 Metricbeat 监测。", - "xpack.monitoring.setupMode.migrateToMetricbeat": "使用 Metricbeat 监测", - "xpack.monitoring.setupMode.migrateToMetricbeatDescription": "这些 {product} {identifier} 自我监测。\n 单击“使用 Metricbeat 监测”以迁移。", - "xpack.monitoring.setupMode.monitorAllNodes": "一些节点仅使用内部收集", - "xpack.monitoring.setupMode.netNewUserDescription": "单击“设置监测”以开始使用 Metricbeat 监测。", - "xpack.monitoring.setupMode.node": "节点", - "xpack.monitoring.setupMode.nodes": "节点", - "xpack.monitoring.setupMode.noMonitoringDataFound": "未检测到 {product} {identifier}", - "xpack.monitoring.setupMode.server": "服务器", - "xpack.monitoring.setupMode.servers": "服务器", - "xpack.monitoring.setupMode.tooltip.allSet": "Metricbeat 正在监测所有 {identifierPlural}。", - "xpack.monitoring.setupMode.tooltip.detected": "无监测", - "xpack.monitoring.setupMode.tooltip.disableInternal": "Metricbeat 正在监测所有 {identifierPlural}。单击以查看 {identifierPlural} 并禁用内部收集。", - "xpack.monitoring.setupMode.tooltip.mightExist": "我们检测到此产品的使用。单击以开始监测。", - "xpack.monitoring.setupMode.tooltip.noUsage": "无使用", - "xpack.monitoring.setupMode.tooltip.noUsageDetected": "我们未检测到任何使用。单击以查看 {identifier}。", - "xpack.monitoring.setupMode.tooltip.oneInternal": "至少一个 {identifier} 未使用 Metricbeat 进行监测。单击以查看状态。", - "xpack.monitoring.setupMode.unknown": "不可用", - "xpack.monitoring.setupMode.usingMetricbeatCollection": "已使用 Metricbeat 监测", - "xpack.monitoring.metricbeatMigration.flyout.flyoutTitle": "使用 Metricbeat 监测 `{instanceName}` {instanceIdentifier}", - "xpack.monitoring.metricbeatMigration.flyout.flyoutTitleNewUser": "使用 Metricbeat 监测 {instanceName} {instanceIdentifier}", - "xpack.monitoring.metricbeatMigration.flyout.noClusterUuidCheckboxLabel": "是的,我明白我将需要在独立集群中寻找\n 此 {productName} {instanceIdentifier}。", - "xpack.monitoring.metricbeatMigration.flyout.noClusterUuidDescription": "此 {productName} {instanceIdentifier} 未连接到 Elasticsearch 集群,因此完全迁移后,此 {productName} {instanceIdentifier} 将显示在独立集群中,而非此集群中。{link}", - "xpack.remoteClusters.addAction.clusterNameAlreadyExistsErrorMessage": "名为 “{clusterName}” 的集群已存在。", - "xpack.remoteClusters.addAction.errorTitle": "添加集群时出错", - "xpack.remoteClusters.addAction.failedDefaultErrorMessage": "请求失败,显示 {statusCode} 错误。{message}", - "xpack.remoteClusters.addAction.successTitle": "添加了远程集群“{name}”", - "xpack.remoteClusters.addBreadcrumbTitle": "添加", - "xpack.remoteClusters.addTitle": "添加远程集群", - "xpack.remoteClusters.appName": "远程集群", - "xpack.remoteClusters.appTitle": "远程集群", - "xpack.remoteClusters.configuredByNodeWarningTitle": "您无法编辑或删除此远程集群,因为它是在节点的 elasticsearch.yml 配置文件中定义的。", - "xpack.remoteClusters.connectedStatus.connectedAriaLabel": "已连接", - "xpack.remoteClusters.connectedStatus.notConnectedAriaLabel": "未连接", - "xpack.remoteClusters.connectedStatus.notConnectedToolTip": "确保已为种子节点配置远程集群的传输端口,而非 http 端口。", - "xpack.remoteClusters.detailPanel.closeButtonLabel": "关闭", - "xpack.remoteClusters.detailPanel.connectedLabel": "连接", - "xpack.remoteClusters.detailPanel.connectedNodesLabel": "已连接节点", - "xpack.remoteClusters.detailPanel.editButtonLabel": "编辑", - "xpack.remoteClusters.detailPanel.initialConnectTimeoutLabel": "初始连接超时", - "xpack.remoteClusters.detailPanel.maxConnectionsPerClusterLabel": "最大连接数", - "xpack.remoteClusters.detailPanel.notFoundLabel": "找不到远程集群", - "xpack.remoteClusters.detailPanel.removeButtonLabel": "删除", - "xpack.remoteClusters.detailPanel.seedsLabel": "种子", - "xpack.remoteClusters.detailPanel.skipUnavailableFalseValue": "否", - "xpack.remoteClusters.detailPanel.skipUnavailableLabel": "无法跳过", - "xpack.remoteClusters.detailPanel.skipUnavailableNullValue": "默认值", - "xpack.remoteClusters.detailPanel.skipUnavailableTrueValue": "是", - "xpack.remoteClusters.detailPanel.statusTitle": "状态", - "xpack.remoteClusters.edit.backToRemoteClustersButtonLabel": "返回远程集群", - "xpack.remoteClusters.edit.loadingErrorMessage": "远程集群“{name}”不存在。", - "xpack.remoteClusters.edit.loadingErrorTitle": "加载远程集群时出错", - "xpack.remoteClusters.edit.loadingLabel": "正在加载远程集群……", - "xpack.remoteClusters.edit.viewRemoteClustersButtonLabel": "查看远程集群", - "xpack.remoteClusters.editAction.errorTitle": "编辑集群时出错", - "xpack.remoteClusters.editAction.failedDefaultErrorMessage": "请求失败,显示 {statusCode} 错误。{message}", - "xpack.remoteClusters.editAction.successTitle": "已编辑远程集群“{name}”", - "xpack.remoteClusters.editBreadcrumbTitle": "编辑", - "xpack.remoteClusters.editTitle": "编辑远程集群", - "xpack.remoteClusters.form.errors.illegalCharacters": "从名称中删除{characterListLength, plural, one {字符} other {字符}} {characterList}。", - "xpack.remoteClusters.form.errors.illegalSpace": "名称中不允许使用空格。", - "xpack.remoteClusters.form.errors.nameMissing": "“名称”必填", - "xpack.remoteClusters.form.errors.seedMissing": "至少需要一个种子节点。", - "xpack.remoteClusters.listBreadcrumbTitle": "远程集群", - "xpack.remoteClusters.loadAction.errorTitle": "加载远程集群时出错", - "xpack.remoteClusters.readDocsButtonLabel": "远程集群文档", - "xpack.remoteClusters.refreshAction.errorTitle": "刷新远程集群时出错", - "xpack.remoteClusters.remoteClusterForm.actions.savingText": "正在保存", - "xpack.remoteClusters.remoteClusterForm.cancelButtonLabel": "取消", - "xpack.remoteClusters.remoteClusterForm.errorTitle": "继续前请解决错误。", - "xpack.remoteClusters.remoteClusterForm.fieldNameLabel": "名称", - "xpack.remoteClusters.remoteClusterForm.fieldNameLabelHelpText": "名称只能包含字母、数字、下划线和短划线。", - "xpack.remoteClusters.remoteClusterForm.fieldSeedsLabel": "种子节点", - "xpack.remoteClusters.remoteClusterForm.fieldSeedsPlaceholder": "host:port", - "xpack.remoteClusters.remoteClusterForm.localSeedError.duplicateMessage": "不允许存在重复的种子节点。", - "xpack.remoteClusters.remoteClusterForm.localSeedError.invalidCharactersMessage": "种子节点必须使用 host:port 格式。示例:127.0.0.1:9400,localhost:9400。主机只能由字母、数字和短划线构成。", - "xpack.remoteClusters.remoteClusterForm.localSeedError.invalidPortMessage": "“端口”必填。", - "xpack.remoteClusters.remoteClusterForm.saveButtonLabel": "保存", - "xpack.remoteClusters.remoteClusterForm.sectionNameDescription": "远程集群的唯一名称。", - "xpack.remoteClusters.remoteClusterForm.sectionNameTitle": "名称", - "xpack.remoteClusters.remoteClusterForm.sectionSeedsDescription1": "要查询集群状态的远程集群节点的列表。指定多个种子节点,以便在节点不可用时发现不会失败。", - "xpack.remoteClusters.remoteClusterForm.sectionSeedsHelpText": "IP 地址或主机名,后跟远程集群的 {transportPort}。", - "xpack.remoteClusters.remoteClusterForm.sectionSeedsHelpText.transportPortLinkText": "传输端口", - "xpack.remoteClusters.remoteClusterForm.sectionSeedsTitle": "用于集群发现的种子节点", - "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableDescription": "默认情况下,如果任何查询的远程集群不可用,请求将失败。要在此集群不可用时继续向其他远程集群发送请求,请启用 {optionName}。{learnMoreLink}", - "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableDescription.learnMoreLinkLabel": "了解详情。", - "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableDescription.optionNameLabel": "如果不可用,则跳过", - "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableLabel": "如果不可用,则跳过", - "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableResetLabel": "重置为默认值", - "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableTitle": "使远程集群可选", - "xpack.remoteClusters.remoteClusterList.connectButtonLabel": "添加远程集群", - "xpack.remoteClusters.remoteClusterList.emptyPrompt.connectButtonLabel": "添加远程集群", - "xpack.remoteClusters.remoteClusterList.emptyPromptDescription": "远程集群创建从本地集群到其他集群的单向连接。", - "xpack.remoteClusters.remoteClusterList.emptyPromptTitle": "添加您的第一个远程集群", - "xpack.remoteClusters.remoteClusterList.loadingErrorTitle": "加载远程集群时出错", - "xpack.remoteClusters.remoteClusterList.loadingTitle": "正在加载远程集群……", - "xpack.remoteClusters.remoteClusterList.noPermissionText": "您没有权限查看或添加远程集群。", - "xpack.remoteClusters.remoteClusterList.noPermissionTitle": "权限错误", - "xpack.remoteClusters.remoteClusterList.table.actionBlockedDeleteDescription": "无法删除在 elasticsearch.yml 中定义的远程集群", - "xpack.remoteClusters.remoteClusterList.table.actionBlockedEditDescription": "无法编辑在 elasticsearch.yml 中定义的远程集群", - "xpack.remoteClusters.remoteClusterList.table.actionDeleteDescription": "删除远程集群", - "xpack.remoteClusters.remoteClusterList.table.actionEditDescription": "编辑远程集群", - "xpack.remoteClusters.remoteClusterList.table.actionsColumnTitle": "操作", - "xpack.remoteClusters.remoteClusterList.table.connectedColumnTitle": "连接", - "xpack.remoteClusters.remoteClusterList.table.connectedNodesColumnTitle": "已连接节点", - "xpack.remoteClusters.remoteClusterList.table.isConfiguredByNodeMessage": "在 elasticsearch.yml 中定义", - "xpack.remoteClusters.remoteClusterList.table.nameColumnTitle": "名称", - "xpack.remoteClusters.remoteClusterList.table.removeButtonLabel": "删除 {count, plural, one { 个远程集群} other {{count} 个远程集群}}", - "xpack.remoteClusters.remoteClusterList.table.seedsColumnTitle": "种子", - "xpack.remoteClusters.remoteClusterListTitle": "远程集群", - "xpack.remoteClusters.removeAction.errorMultipleNotificationTitle": "删除 “{count}” 个远程集群时出错", - "xpack.remoteClusters.removeAction.errorSingleNotificationTitle": "删除远程集群 “{name}” 时出错", - "xpack.remoteClusters.removeAction.successMultipleNotificationTitle": "已删除 {count} 个远程集群", - "xpack.remoteClusters.removeAction.successSingleNotificationTitle": "已删除远程集群“{name}”", - "xpack.remoteClusters.removeButton.confirmModal.cancelButtonText": "取消", - "xpack.remoteClusters.removeButton.confirmModal.confirmButtonText": "删除", - "xpack.remoteClusters.removeButton.confirmModal.deleteSingleClusterTitle": "是否删除远程集群 “{name}”?", - "xpack.remoteClusters.removeButton.confirmModal.multipleDeletionDescription": "您即将删除以下远程集群:", - "xpack.remoteClusters.removeButton.confirmModal.multipleDeletionTitle": "是否删除 {count} 个远程集群?", - "xpack.remoteClusters.remoteClusterForm.hideRequestButtonLabel": "隐藏请求", - "xpack.remoteClusters.remoteClusterForm.inputLocalSeedErrorMessage": "“种子节点”字段无效。", - "xpack.remoteClusters.remoteClusterForm.inputNameErrorMessage": "“名称”字段无效。", - "xpack.remoteClusters.remoteClusterForm.inputSeedsErrorMessage": "“种子节点”字段无效。", - "xpack.remoteClusters.remoteClusterForm.showRequestButtonLabel": "显示请求", - "xpack.remoteClusters.requestFlyout.closeButtonLabel": "关闭", - "xpack.remoteClusters.requestFlyout.descriptionText": "此 Elasticsearch 请求将创建或更新此远程集群。", - "xpack.remoteClusters.requestFlyout.namedTitle": "对“{name}”的请求", - "xpack.remoteClusters.requestFlyout.unnamedTitle": "请求", - "xpack.reporting.breadcrumb": "Reporting", - "xpack.reporting.dashboard.csvDownloadStartedMessage": "您的 CSV 将很快下载。", - "xpack.reporting.dashboard.csvDownloadStartedTitle": "CSV 下载已开始", - "xpack.reporting.dashboard.downloadCsvPanelTitle": "下载 CSV", - "xpack.reporting.dashboard.failedCsvDownloadMessage": "我们此次无法生成 CSV。", - "xpack.reporting.dashboard.failedCsvDownloadTitle": "CSV 下载失败。", - "xpack.reporting.errorButton.showReportErrorAriaLabel": "显示报告错误", - "xpack.reporting.errorButton.unableToFetchReportContentTitle": "无法提取报告内容", - "xpack.reporting.errorButton.unableToGenerateReportTitle": "无法生成报告", - "xpack.reporting.exportTypes.csv_from_savedobject.executeJob.failedToDecryptReportJobDataErrorMessage": "无法解密报告作业数据。请确保已设置 {encryptionKey},然后重新生成此报告。{err}", - "xpack.reporting.exportTypes.csv.executeJob.failedToDecryptReportJobDataErrorMessage": "无法解密报告作业数据。请确保已设置 {encryptionKey},然后重新生成此报告。{err}", - "xpack.reporting.exportTypes.csv.hitIterator.expectedHitsErrorMessage": "在以下 Elasticsearch 响应中预期 {hits}:{response}", - "xpack.reporting.exportTypes.csv.hitIterator.expectedScrollIdErrorMessage": "在以下 Elasticsearch 响应中预期 {scrollId}:{response}", - "xpack.reporting.exportTypes.printablePdf.documentStreamIsNotgeneratedErrorMessage": "尚未生成文档流", - "xpack.reporting.exportTypes.printablePdf.logoDescription": "由 Elastic 提供支持", - "xpack.reporting.exportTypes.printablePdf.pagingDescription": "第 {currentPage} 页,共 {pageCount} 页", - "xpack.reporting.exportTypes.printablePdf.screenshots.unexpectedErrorMessage": "在页面上出现意外消息:{toastHeaderText}", - "xpack.reporting.jobStatuses.cancelledText": "已取消", - "xpack.reporting.jobStatuses.completedText": "已完成", - "xpack.reporting.jobStatuses.failedText": "失败", - "xpack.reporting.jobStatuses.pendingText": "待处理", - "xpack.reporting.jobStatuses.processingText": "正在处理", - "xpack.reporting.listing.reports.subtitle": "在此处查找 Kibana 应用程序中生成的报告", - "xpack.reporting.listing.reportstitle": "报告", - "xpack.reporting.listing.table.downloadReportAriaLabel": "下载报告", - "xpack.reporting.listing.table.loadingReportsDescription": "正在载入报告", - "xpack.reporting.listing.table.maxSizeReachedTooltip": "已达到最大大小,包含部分数据。", - "xpack.reporting.listing.table.noCreatedReportsDescription": "未创建任何报告", - "xpack.reporting.listing.table.requestFailedErrorMessage": "请求失败", - "xpack.reporting.listing.tableColumns.actionsTitle": "操作", - "xpack.reporting.listing.tableColumns.createdAtTitle": "创建于", - "xpack.reporting.listing.tableColumns.reportTitle": "报告", - "xpack.reporting.listing.tableColumns.statusTitle": "状态", - "xpack.reporting.listing.tableValue.createdAtDetail.maxSizeReachedText": " - 最大大小已达到", - "xpack.reporting.listing.tableValue.createdAtDetail.pendingStatusReachedText": "待处理 - 正在等候处理作业", - "xpack.reporting.listing.tableValue.createdAtDetail.statusTimestampText": "{statusTimestamp} 时为 {statusLabel}", - "xpack.reporting.management.reportingTitle": "Reporting", - "xpack.reporting.panelContent.copyUrlButtonLabel": "复制 POST URL", - "xpack.reporting.panelContent.generateButtonLabel": "生成 {reportingType}", - "xpack.reporting.panelContent.generationTimeDescription": "{reportingType} 可能会花费 1 或 2 分钟生成,取决于 {objectType} 的大小。", - "xpack.reporting.panelContent.howToCallGenerationDescription": "或者,复制此 POST URL 以从 Kibana 外部或从 Watcher 调用生成。", - "xpack.reporting.panelContent.noPermissionToGenerateReportDescription": "您无权生成此报告。", - "xpack.reporting.panelContent.notification.cantReachServerDescription": "无法访问服务器。请重试。", - "xpack.reporting.panelContent.notification.reportingErrorTitle": "报告错误", - "xpack.reporting.panelContent.saveWorkDescription": "请在生成报告之前保存您的工作。", - "xpack.reporting.panelContent.successfullyQueuedReportNotificationDescription": "在“管理”中跟踪其进度", - "xpack.reporting.panelContent.successfullyQueuedReportNotificationTitle": "已为 {objectType} 排队报告", - "xpack.reporting.panelContent.whatCanBeExportedWarningDescription": "请先保存您的工作", - "xpack.reporting.panelContent.whatCanBeExportedWarningTitle": "只会导出保存的 {objectType}", - "xpack.reporting.pdfFooterImageDescription": "PDF 的页脚中要使用的定制图片", - "xpack.reporting.pdfFooterImageLabel": "PDF 页脚图片", - "xpack.reporting.registerFeature.reportingDescription": "管理您从 Discover、Visualize 和 Dashboard 生成的报告。", - "xpack.reporting.registerFeature.reportingTitle": "Reporting", - "xpack.reporting.screenCapturePanelContent.optimizeForPrintingLabel": "打印优化", - "xpack.reporting.shareContextMenu.csvReportsButtonLabel": "CSV 报告", - "xpack.reporting.shareContextMenu.pdfReportsButtonLabel": "PDF 报告", - "xpack.rollupJobs.appTitle": "汇总/打包作业", - "xpack.rollupJobs.checkLicense.errorExpiredMessage": "您不能使用 {pluginName},因为您的 {licenseType} 许可证已过期", - "xpack.rollupJobs.checkLicense.errorUnavailableMessage": "您不能使用 {pluginName},因为许可证信息当前不可用。", - "xpack.rollupJobs.checkLicense.errorUnsupportedMessage": "您的 {licenseType} 许可证不支持 {pluginName}。请升级您的许可。", - "xpack.rollupJobs.create.backButton.label": "上一步", - "xpack.rollupJobs.create.dateTypeField": "日期", - "xpack.rollupJobs.create.errors.dateHistogramFieldMissing": "“日期”字段必填。", - "xpack.rollupJobs.create.errors.dateHistogramIntervalInvalidCalendarInterval": "“{unit}” 单位仅允许值为 1。请尝试 {suggestion}。", - "xpack.rollupJobs.create.errors.dateHistogramIntervalInvalidCalendarIntervalSuggestion": "1{unit}", - "xpack.rollupJobs.create.errors.dateHistogramIntervalInvalidFormat": "时间间隔格式无效。", - "xpack.rollupJobs.create.errors.dateHistogramIntervalMissing": "“时间间隔”必填。", - "xpack.rollupJobs.create.errors.histogramIntervalMissing": "汇总这些直方图字段需要一个时间间隔。", - "xpack.rollupJobs.create.errors.histogramIntervalWholeNumber": "时间间隔必须是整数。", - "xpack.rollupJobs.create.errors.histogramIntervalZero": "时间间隔值必须大于零。", - "xpack.rollupJobs.create.errors.idMissing": "“名称”必填", - "xpack.rollupJobs.create.errors.indexPatternIllegalCharacters": "从索引模式中删除 {characterList} 字符。", - "xpack.rollupJobs.create.errors.indexPatternMatchesRollupIndices": "索引模式不能与汇总/打包索引匹配。", - "xpack.rollupJobs.create.errors.indexPatternMissing": "索引模式必填。", - "xpack.rollupJobs.create.errors.indexPatternNoMatchingIndices": "索引模式不匹配任何索引。", - "xpack.rollupJobs.create.errors.indexPatternNoTimeFields": "索引模式必须匹配包含时间字段的索引。", - "xpack.rollupJobs.create.errors.indexPatternSameAsRollupIndex": "索引模式不能与汇总/打包索引相同。", - "xpack.rollupJobs.create.errors.indexPatternSpaces": "从索引模式中删除空格。", - "xpack.rollupJobs.create.errors.indexPatternValidationError": "验证此索引模式时出现问题:{statusCode} {error}", - "xpack.rollupJobs.create.errors.indexPatternValidationFatalErrorTitle": "汇总/打包作业向导索引模式验证", - "xpack.rollupJobs.create.errors.metricsTypesMissing": "选择这些字段的指标类型或将其删除:{allMissingTypes}。", - "xpack.rollupJobs.create.errors.rollupCronMissing": "Cron 模式或基本间隔必填。", - "xpack.rollupJobs.create.errors.rollupDelayInvalidCalendarInterval": "“{unit}” 单位仅允许值为 1。请尝试 {suggestion}。", - "xpack.rollupJobs.create.errors.rollupDelayInvalidCalendarIntervalSuggestion": "1{unit}", - "xpack.rollupJobs.create.errors.rollupDelayInvalidFormat": "延迟格式无效。", - "xpack.rollupJobs.create.errors.rollupIndexBeginningPeriod": "索引名称不能以句点开头。", - "xpack.rollupJobs.create.errors.rollupIndexCommas": "从汇总/打包索引名称中删除逗号。", - "xpack.rollupJobs.create.errors.rollupIndexIllegalCharacters": "从汇总/打包索引名称中删除字符 {characterList}。", - "xpack.rollupJobs.create.errors.rollupIndexMissing": "汇总/打包索引必填。", - "xpack.rollupJobs.create.errors.rollupIndexSameAsIndexPattern": "汇总/打包索引不能与索引模式相同。", - "xpack.rollupJobs.create.errors.rollupIndexSpaces": "从汇总/打包索引名称中删除空格。", - "xpack.rollupJobs.create.errors.rollupPageSizeGreaterThanZero": "页面大小必须大于零。", - "xpack.rollupJobs.create.errors.rollupPageSizeMissing": "“页面大小”必填。", - "xpack.rollupJobs.create.jobDetails.tabHistogramLabel": "Histogram", - "xpack.rollupJobs.create.jobDetails.tabJsonLabel": "JSON", - "xpack.rollupJobs.create.jobDetails.tabMetricsLabel": "指标", - "xpack.rollupJobs.create.jobDetails.tabSummaryLabel": "结论", - "xpack.rollupJobs.create.jobDetails.tabTermsLabel": "词", - "xpack.rollupJobs.create.keywordTypeField": "关键字", - "xpack.rollupJobs.create.navigation.savingText": "正在保存", - "xpack.rollupJobs.create.nextButton.label": "下一个", - "xpack.rollupJobs.create.numericTypeField": "数值", - "xpack.rollupJobs.create.saveButton.label": "保存", - "xpack.rollupJobs.create.stepDateHistogram.fieldDateFieldLabel": "日期字段", - "xpack.rollupJobs.create.stepDateHistogram.fieldDelay.helpExampleLabel": "示例值:30s、20m、24h、2d、1w、1M", - "xpack.rollupJobs.create.stepDateHistogram.fieldDelayLabel": "延迟缓冲(可选)", - "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.helpExampleLabel": "示例大小:1000ms、30s、20m、24h、2d、1w、1M、1y", - "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.preferFixedWarningDayLabel": "考虑使用 24h 代替 1d。这样会使查询更灵活。", - "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.preferFixedWarningHourLabel": "考虑使用 60m 代替 1h。这样会使查询更灵活。", - "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.preferFixedWarningMonthLabel": "考虑使用单位 d 代替 M。这样会使查询更灵活。", - "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.preferFixedWarningWeekLabel": "考虑使用单位 d 代替 w。这样会使查询更灵活。", - "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.preferFixedWarningYearLabel": "考虑使用单位 d 代替 y。这样会使查询更灵活。", - "xpack.rollupJobs.create.stepDateHistogram.fieldIntervalLabel": "时间桶大小", - "xpack.rollupJobs.create.stepDateHistogram.fieldTimeZoneLabel": "时区", - "xpack.rollupJobs.create.stepDateHistogram.readDocsButtonLabel": "日期直方图文档", - "xpack.rollupJobs.create.stepDateHistogram.sectionDataSourceDescription": "请注意,时间桶越小在比例上占用的空间越多。", - "xpack.rollupJobs.create.stepDateHistogramDescription": "定义 {link} 对汇总/打包数据的操作方式。", - "xpack.rollupJobs.create.stepDateHistogramDescription.aggregationsLinkLabel": "日期直方图聚合", - "xpack.rollupJobs.create.stepDateHistogramTitle": "Date histogram", - "xpack.rollupJobs.create.stepErrorTitle": "继续前请解决错误。", - "xpack.rollupJobs.create.stepHistogram.fieldHistogramIntervalLabel": "时间间隔", - "xpack.rollupJobs.create.stepHistogram.fieldsChooserLabel": "添加直方图字段", - "xpack.rollupJobs.create.stepHistogram.histogramDescription": "使用数字间隔选择要存储的字段。", - "xpack.rollupJobs.create.stepHistogram.readDocsButtonLabel": "直方图文档", - "xpack.rollupJobs.create.stepHistogram.sectionHistogramIntervalDescription": "这是在汇总/打包时生成的直方图桶的间隔,例如,5 表示将创建五个单位宽(0-5、5-10等)的桶。请注意,直方图组中只能指定一个间隔,这意味着通过直方图分组的所有字段必须共享相同的间隔。", - "xpack.rollupJobs.create.stepHistogram.sectionHistogramIntervalTitle": "直方图间隔", - "xpack.rollupJobs.create.stepHistogramTitle": "Histogram(可选)", - "xpack.rollupJobs.create.stepLogistics.fieldCron.helpReferenceLinkLabel": "详细了解 Cron 表达式", - "xpack.rollupJobs.create.stepLogistics.fieldCronLabel": "Cron 表达式", - "xpack.rollupJobs.create.stepLogistics.fieldIdLabel": "名称", - "xpack.rollupJobs.create.stepLogistics.fieldIndexPattern.helpAllowLabel": "使用通配符 ({asterisk}) 匹配多个索引。", - "xpack.rollupJobs.create.stepLogistics.fieldIndexPattern.helpDisallowLabel": "不允许使用空格和字符 {characterList}。", - "xpack.rollupJobs.create.stepLogistics.fieldIndexPattern.helpHasMatchesLabel": "成功!索引模式具有匹配的索引。", - "xpack.rollupJobs.create.stepLogistics.fieldIndexPattern.helpMustMatchLabel": "索引模式必须至少匹配一个不是汇总/打包的索引。", - "xpack.rollupJobs.create.stepLogistics.fieldIndexPattern.helpSearchingLabel": "正在寻找匹配的索引......", - "xpack.rollupJobs.create.stepLogistics.fieldIndexPatternLabel": "索引模式", - "xpack.rollupJobs.create.stepLogistics.fieldPageSizeLabel": "页面大小", - "xpack.rollupJobs.create.stepLogistics.fieldRollupIndex.helpDisallowLabel": "不允许出现空格、逗号和字符 {characterList}。", - "xpack.rollupJobs.create.stepLogistics.fieldRollupIndexLabel": "汇总/打包索引名称", - "xpack.rollupJobs.create.stepLogistics.logisticsDescription": "定义如何运行汇总/打包作业以及何时索引文档。", - "xpack.rollupJobs.create.stepLogistics.readDocsButtonLabel": "运筹文档", - "xpack.rollupJobs.create.stepLogistics.sectionDataFlowDescription": "您想要汇总/打包哪些索引以及您希望在何处存储数据?", - "xpack.rollupJobs.create.stepLogistics.sectionDataFlowTitle": "数据流", - "xpack.rollupJobs.create.stepLogistics.sectionDelayDescription": "延迟缓冲将延迟汇总/打包数据。通过允许可变的采集延迟,这将实现准确度更高的汇总/打包。默认情况下,汇总/打包作业会尝试汇总/打包所有可用的数据。", - "xpack.rollupJobs.create.stepLogistics.sectionDelayTitle": "汇总/打包作业在汇总/打包新数据之前需要等待多长时间?", - "xpack.rollupJobs.create.stepLogistics.sectionIdDescription": "此名称将用作此汇总/打包作业的唯一标识符。", - "xpack.rollupJobs.create.stepLogistics.sectionIdTitle": "名称", - "xpack.rollupJobs.create.stepLogistics.sectionPageSizeDescription": "较大的页面大小会更快地汇总/打包数据,但需要更多内存。", - "xpack.rollupJobs.create.stepLogistics.sectionPageSizeTitle": "您想一次汇总/打包多少文档?", - "xpack.rollupJobs.create.stepLogistics.sectionSchedule.buttonAdvancedLabel": "创建 Cron 表达式", - "xpack.rollupJobs.create.stepLogistics.sectionSchedule.buttonBasicLabel": "创建基本间隔", - "xpack.rollupJobs.create.stepLogistics.sectionScheduleDescription": "您要多久汇总/打包一次数据?", - "xpack.rollupJobs.create.stepLogistics.sectionScheduleTitle": "计划", - "xpack.rollupJobs.create.stepLogisticsTitle": "运筹", - "xpack.rollupJobs.create.stepMetrics.checkboxAverageLabel": "平均值", - "xpack.rollupJobs.create.stepMetrics.checkboxMaxLabel": "最大值", - "xpack.rollupJobs.create.stepMetrics.checkboxMinLabel": "最小值", - "xpack.rollupJobs.create.stepMetrics.checkboxSumLabel": "和", - "xpack.rollupJobs.create.stepMetrics.checkboxValueCountLabel": "值计数", - "xpack.rollupJobs.create.stepMetrics.fieldsChooserLabel": "添加指标字段", - "xpack.rollupJobs.create.stepMetrics.readDocsButtonLabel": "指标文档", - "xpack.rollupJobs.create.stepMetricsDescription": "选择在汇总数据时要收集的指标。默认情况下,每个组仅收集 doc_counts。", - "xpack.rollupJobs.create.stepMetricsTitle": "指标(可选)", - "xpack.rollupJobs.create.stepReviewTitle": "查看 “{jobId}” 的详情", - "xpack.rollupJobs.create.steps.stepDateHistogramTitle": "Date histogram", - "xpack.rollupJobs.create.steps.stepHistogramTitle": "Histogram", - "xpack.rollupJobs.create.steps.stepLogisticsTitle": "运筹", - "xpack.rollupJobs.create.steps.stepMetricsTitle": "指标", - "xpack.rollupJobs.create.steps.stepReviewTitle": "查看并保存", - "xpack.rollupJobs.create.steps.stepTermsTitle": "词", - "xpack.rollupJobs.create.stepTerms.fieldsChooserLabel": "添加字词字段", - "xpack.rollupJobs.create.stepTerms.readDocsButtonLabel": "字词文档", - "xpack.rollupJobs.create.stepTermsDescription": "使用字词聚合选择要存储的字段。如果时间桶稀疏,这对于诸如 IP 地址等的高基数字段可能会成本高昂。", - "xpack.rollupJobs.create.stepTermsTitle": "字词(可选)", - "xpack.rollupJobs.createAction.errorTitle": "创建汇总/打包作业时出错", - "xpack.rollupJobs.createAction.failedDefaultErrorMessage": "请求失败,显示 {statusCode} 错误。{message}", - "xpack.rollupJobs.createAction.jobIdAlreadyExistsErrorMessage": "ID 为 “{jobConfigId}” 的作业已存在。", - "xpack.rollupJobs.createBreadcrumbTitle": "创建", - "xpack.rollupJobs.createTitle": "创建汇总/打包作业", - "xpack.rollupJobs.deleteAction.errorTitle": "删除汇总/打包作业时出错", - "xpack.rollupJobs.deleteAction.successMultipleNotificationTitle": "已删除 {count} 个汇总/打包作业", - "xpack.rollupJobs.deleteAction.successSingleNotificationTitle": "已删除汇总/打包作业“{jobId}”", - "xpack.rollupJobs.detailPanel.jobActionMenu.buttonLabel": "管理", - "xpack.rollupJobs.detailPanel.loadingLabel": "正在加载汇总/打包作业……", - "xpack.rollupJobs.detailPanel.notFoundLabel": "未找到汇总/打包作业", - "xpack.rollupJobs.editorConfig.dateHistogram.customInterval.helpText": "必须是汇总/打包配置时间间隔的倍数:{interval}", - "xpack.rollupJobs.editorConfig.histogram.interval.helpText": "必须是汇总/打包配置时间间隔的倍数:{interval}", - "xpack.rollupJobs.editRollupIndexPattern.createIndex.defaultButtonDescription": "针对汇总数据执行有限聚合", - "xpack.rollupJobs.editRollupIndexPattern.createIndex.defaultButtonText": "汇总/打包索引模式", - "xpack.rollupJobs.editRollupIndexPattern.createIndex.defaultTypeName": "汇总/打包索引模式", - "xpack.rollupJobs.editRollupIndexPattern.createIndex.indexLabel": "汇总/打包", - "xpack.rollupJobs.editRollupIndexPattern.createIndex.noMatchError": "汇总/打包索引模式错误:必须匹配一个汇总/打包索引", - "xpack.rollupJobs.editRollupIndexPattern.createIndex.tooManyMatchesError": "汇总/打包索引模式错误:只能匹配一个汇总/打包索引", - "xpack.rollupJobs.editRollupIndexPattern.createIndex.uncaughtError": "汇总索引模式错误:{error}", - "xpack.rollupJobs.featureCatalogueDescription": "汇总历史数据并将其存储在较小的索引中以供将来分析。", - "xpack.rollupJobs.indexMgmtBadge.rollupLabel": "汇总/打包", - "xpack.rollupJobs.indexMgmtToggle.toggleLabel": "包括汇总索引", - "xpack.rollupJobs.jobActionMenu.buttonLabel": "管理 {jobCount, plural, one { 个作业} other { 个作业}}", - "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.cancelButtonText": "取消", - "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.confirmButtonText": "删除", - "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.deleteSingleJobDescription": "已启动此作业。", - "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.deleteSingleJobTitle": "是否删除汇总/打包作业 “{id}”?", - "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.multipleDeletionDescription": "您即将删除{isSingleSelection, plural, one {此作业} other {这些作业}}", - "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.multipleDeletionTitle": "是否删除 {count} 个汇总/打包作业?", - "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.startedMessage": "已启动", - "xpack.rollupJobs.jobActionMenu.deleteJobLabel": "删除 {isSingleSelection, plural, one { 个作业} other { 个作业}}", - "xpack.rollupJobs.jobActionMenu.jobActionMenuButtonAriaLabel": "作业选项", - "xpack.rollupJobs.jobActionMenu.panelTitle": "作业选项", - "xpack.rollupJobs.jobActionMenu.startJobLabel": "启动 {isSingleSelection, plural, one { 个作业} other { 个作业}}", - "xpack.rollupJobs.jobActionMenu.stopJobLabel": "停止 {isSingleSelection, plural, one { 个作业} other { 个作业}}", - "xpack.rollupJobs.jobActionMenu.updatingText": "正在更新", - "xpack.rollupJobs.jobDetails.tabHistogram.intervalLabel": "直方图间隔", - "xpack.rollupJobs.jobDetails.tabHistogram.nameColumnLabel": "字段", - "xpack.rollupJobs.jobDetails.tabMetrics.nameColumnLabel": "字段", - "xpack.rollupJobs.jobDetails.tabMetrics.typesColumnLabel": "类型", - "xpack.rollupJobs.jobDetails.tabSummary.itemCronLabel": "Cron", - "xpack.rollupJobs.jobDetails.tabSummary.itemCronTip": "汇总/打包数据的频率", - "xpack.rollupJobs.jobDetails.tabSummary.itemDelay.none": "无", - "xpack.rollupJobs.jobDetails.tabSummary.itemDelayLabel": "延迟", - "xpack.rollupJobs.jobDetails.tabSummary.itemDocumentsProcessedLabel": "已处理的文档", - "xpack.rollupJobs.jobDetails.tabSummary.itemIndexPatternLabel": "索引模式", - "xpack.rollupJobs.jobDetails.tabSummary.itemIntervalLabel": "时间间隔", - "xpack.rollupJobs.jobDetails.tabSummary.itemIntervalTip": "汇总/打包数据的时段间隔", - "xpack.rollupJobs.jobDetails.tabSummary.itemPagesProcessedLabel": "已处理的页面", - "xpack.rollupJobs.jobDetails.tabSummary.itemRollupIndexLabel": "汇总/打包索引", - "xpack.rollupJobs.jobDetails.tabSummary.itemRollupsIndexedLabel": "已编制索引的汇总/打包", - "xpack.rollupJobs.jobDetails.tabSummary.itemTimeFieldLabel": "时间字段", - "xpack.rollupJobs.jobDetails.tabSummary.itemTimezoneLabel": "时区", - "xpack.rollupJobs.jobDetails.tabSummary.itemTriggerCountLabel": "触发计数", - "xpack.rollupJobs.jobDetails.tabSummary.sectionDateHistogramLabel": "Date histogram", - "xpack.rollupJobs.jobDetails.tabSummary.sectionLogisticsLabel": "运筹", - "xpack.rollupJobs.jobDetails.tabSummary.sectionStatsTitle": "统计", - "xpack.rollupJobs.jobList.createButtonLabel": "创建汇总/打包作业", - "xpack.rollupJobs.jobList.emptyPrompt.createButtonLabel": "创建汇总/打包作业", - "xpack.rollupJobs.jobList.emptyPromptDescription": "汇总/打包作业可汇总历史数据并将其存储在较小的索引中以供将来分析。", - "xpack.rollupJobs.jobList.emptyPromptTitle": "创建您的首个汇总/打包作业", - "xpack.rollupJobs.jobList.loadingErrorTitle": "加载汇总/打包作业时出错", - "xpack.rollupJobs.jobList.loadingTitle": "正在加载汇总/打包作业……", - "xpack.rollupJobs.jobList.noPermissionText": "您没有权限查看或添加汇总/打包作业。", - "xpack.rollupJobs.jobList.noPermissionTitle": "权限错误", - "xpack.rollupJobs.jobListTitle": "汇总/打包作业", - "xpack.rollupJobs.jobStatus.abortingLabel": "正在中止", - "xpack.rollupJobs.jobStatus.indexingLabel": "索引", - "xpack.rollupJobs.jobStatus.startedLabel": "已开始", - "xpack.rollupJobs.jobStatus.stoppedLabel": "已停止", - "xpack.rollupJobs.jobTable.headers.delayHeader": "延迟", - "xpack.rollupJobs.jobTable.headers.groupsHeader": "组", - "xpack.rollupJobs.jobTable.headers.indexPatternHeader": "索引模式", - "xpack.rollupJobs.jobTable.headers.intervalHeader": "时间间隔", - "xpack.rollupJobs.jobTable.headers.metricsHeader": "指标", - "xpack.rollupJobs.jobTable.headers.nameHeader": "ID", - "xpack.rollupJobs.jobTable.headers.rollupIndexHeader": "汇总/打包索引", - "xpack.rollupJobs.jobTable.headers.statusHeader": "状态", - "xpack.rollupJobs.jobTable.noJobsMatchSearchMessage": "没有汇总作业匹配您的搜索", - "xpack.rollupJobs.jobTable.searchInputPlaceholder": "搜索", - "xpack.rollupJobs.listBreadcrumbTitle": "汇总/打包作业", - "xpack.rollupJobs.loadAction.errorTitle": "加载汇总/打包作业时出错", - "xpack.rollupJobs.refreshAction.errorTitle": "刷新汇总/打包作业时出错", - "xpack.rollupJobs.rollupIndexPatternsDescription": "启用用于捕获汇总/打包索引的索引模式的创建,\n 汇总/打包索引反过来基于汇总/打包数据启用可视化。刷新\n 页面以应用更改。", - "xpack.rollupJobs.rollupIndexPatternsTitle": "启用汇总索引模式", - "xpack.rollupJobs.startJobsAction.errorTitle": "启动汇总/打包作业时出错", - "xpack.rollupJobs.stopJobsAction.errorTitle": "停止汇总/打包作业时出错", - "xpack.rollupJobs.create.errors.idSameAsCloned": "名称不能与克隆名称相同:“{clonedId}。", - "xpack.rollupJobs.create.jobDetails.tabRequestLabel": "请求", - "xpack.rollupJobs.create.startJobLabel": "立即启动作业", - "xpack.rollupJobs.create.stepMetrics.allCheckbox": "全部", - "xpack.rollupJobs.create.stepMetrics.emptyListLabel": "未添加任何指标字段", - "xpack.rollupJobs.create.stepMetrics.fieldColumnLabel": "字段", - "xpack.rollupJobs.create.stepMetrics.metricsColumnHeader": "指标", - "xpack.rollupJobs.create.stepMetrics.selectAllPopoverButtonLabel": "选择指标", - "xpack.rollupJobs.create.stepMetrics.selectAllRowLabel": "全部", - "xpack.rollupJobs.create.stepMetrics.typeColumnLabel": "类型", - "xpack.rollupJobs.jobActionMenu.cloneJobLabel": "克隆作业", - "xpack.rollupJobs.jobDetails.tabRequest.descriptionText": "此 Elasticsearch 请求将创建此汇总/打包作业。", - "xpack.rollupJobs.jobStatus.stoppingLabel": "正在停止", - "xpack.rollupJobs.jobStatus.unknownLabel": "未知", - "xpack.searchProfiler.aggregationProfileTabTitle": "聚合配置文件", - "xpack.searchProfiler.basicLicenseTitle": "基础级", - "xpack.searchProfiler.formIndexLabel": "索引", - "xpack.searchProfiler.formProfileButtonLabel": "配置文件", - "xpack.searchProfiler.goldLicenseTitle": "黄金级", - "xpack.searchProfiler.highlightDetails.descriptionTitle": "描述", - "xpack.searchProfiler.highlightDetails.selfTimeTitle": "独自时间", - "xpack.searchProfiler.highlightDetails.selfTimeTooltip": "此查询组件单独花费的时间(不包括子项)", - "xpack.searchProfiler.highlightDetails.timingBreakdownTitle": "计时分解", - "xpack.searchProfiler.highlightDetails.totalTimeTitle": "总时间", - "xpack.searchProfiler.highlightDetails.totalTimeTooltip": "此查询组件花费的总时间(包括子项)", - "xpack.searchProfiler.highlightDetails.typeTitle": "类型", - "xpack.searchProfiler.licenseErrorMessageDescription": "分析器可视化需要有效的许可({licenseTypeList}或{platinumLicenseType},但在您的集群中未找到任何许可。", - "xpack.searchProfiler.licenseErrorMessageTitle": "许可错误", - "xpack.searchProfiler.licenseHasExpiredMessage": "Search Profiler 不可用 - 许可已过期。", - "xpack.searchProfiler.pageDisplayName": "Search Profiler", - "xpack.searchProfiler.platinumLicenseTitle": "白金级", - "xpack.searchProfiler.profileTree.cumulativeTimeTitle": "累计时间:", - "xpack.searchProfiler.profileTree.cumulativeTimeTooltip": "索引中所有分片的累计时间。注意:这不是时钟时间,因为分片可以并行执行。", - "xpack.searchProfiler.profileTree.header.selfTimeTitle": "独自时间", - "xpack.searchProfiler.profileTree.header.totalTimeTitle": "总时间", - "xpack.searchProfiler.profileTree.header.typeTitle": "类型和描述", - "xpack.searchProfiler.profileTree.indexTitle": "索引:", - "xpack.searchProfiler.queryProfileTabTitle": "查询配置文件", - "xpack.searchProfiler.registerLicenseDescription": "请{registerLicenseLink}以继续使用 Search Profiler", - "xpack.searchProfiler.registerLicenseLinkLabel": "注册许可", - "xpack.searchProfiler.registryProviderDescription": "快速检查任何 Elasticsearch 查询的性能。", - "xpack.searchProfiler.registryProviderTitle": "Search Profiler", - "xpack.searchProfiler.trialLicenseTitle": "试用", - "xpack.searchProfiler.unavailableLicenseInformationMessage": "Search Profiler 不可用 - 许可信息当前不可用。", - "xpack.searchProfiler.upgradeLicenseMessage": "Search Profiler 不可用于当前的{licenseInfo}许可。请升级您的许可。", - "xpack.searchProfiler.errorToastTitle": "JSON 解析错误", - "xpack.security.account.breadcrumb": "帐户管理", - "xpack.security.account.changePasswordDescription": "为您的帐户更改密码。", - "xpack.security.account.changePasswordForm.cancelButtonLabel": "重置", - "xpack.security.account.changePasswordForm.confirmPasswordLabel": "确认新密码", - "xpack.security.account.changePasswordForm.currentPasswordLabel": "当前密码", - "xpack.security.account.changePasswordForm.invalidPassword": "当前密码不正确。", - "xpack.security.account.changePasswordForm.newPasswordLabel": "新密码", - "xpack.security.account.changePasswordForm.passwordRequirements": "至少使用 6 个字符。", - "xpack.security.account.changePasswordForm.saveChangesButtonLabel": "更改密码", - "xpack.security.account.changePasswordNotSupportedText": "不能更改此帐户的密码。", - "xpack.security.account.changePasswordSuccess": "您的密码已更改。", - "xpack.security.account.changePasswordTitle": "密码", - "xpack.security.account.currentPasswordRequired": "当前密码必填。", - "xpack.security.account.noEmailMessage": "没有电子邮件地址", - "xpack.security.account.passwordLengthDescription": "密码过短。", - "xpack.security.account.passwordsDoNotMatch": "密码不匹配。", - "xpack.security.account.usernameGroupDescription": "不能更改此信息。", - "xpack.security.account.usernameGroupTitle": "用户名和电子邮件", - "xpack.security.components.sessionIdleTimeoutWarning.okButtonText": "确定", - "xpack.security.components.sessionIdleTimeoutWarning.title": "警告", - "xpack.security.loggedOut.login": "登录", - "xpack.security.loggedOut.title": "已成功退出", - "xpack.security.login.basicLoginForm.invalidUsernameOrPasswordErrorMessage": "用户名或密码无效。请重试。", - "xpack.security.login.basicLoginForm.logInButtonLabel": "登录", - "xpack.security.login.basicLoginForm.passwordFormRowLabel": "密码", - "xpack.security.login.basicLoginForm.unknownErrorMessage": "糟糕!错误。重试。", - "xpack.security.login.basicLoginForm.usernameFormRowLabel": "用户名", - "xpack.security.login.loggedOutDescription": "您已注销 Kibana。", - "xpack.security.login.sessionExpiredDescription": "您的会话已超时。请重新登录。", - "xpack.security.loginPage.esUnavailableMessage": "请参阅 Kibana 日志了解详情,然后尝试重新加载页面。", - "xpack.security.loginPage.esUnavailableTitle": "无法连接到 Elasticsearch 集群", - "xpack.security.loginPage.requiresSecureConnectionMessage": "请联系您的管理员。", - "xpack.security.loginPage.requiresSecureConnectionTitle": "登录需要安全连接", - "xpack.security.loginPage.unknownLayoutMessage": "请参阅 Kibana 日志了解详情,然后刷新以重试。", - "xpack.security.loginPage.unknownLayoutTitle": "登录窗体布局不支持。", - "xpack.security.loginPage.welcomeDescription": "您了解 Elastic Stack 的窗口", - "xpack.security.loginPage.welcomeTitle": "欢迎使用 Kibana", - "xpack.security.loginPage.xpackUnavailableMessage": "要使用此 Kibana 发行版中全部免费功能,请将 Elasticsearch 更新为默认发行版。", - "xpack.security.loginPage.xpackUnavailableTitle": "当前无法连接到为 Kibana 配置的 Elasticsearch 集群。", - "xpack.security.management.changePasswordForm.cancelButtonLabel": "取消", - "xpack.security.management.changePasswordForm.changePasswordLinkLabel": "更改密码", - "xpack.security.management.changePasswordForm.confirmPasswordLabel": "确认密码", - "xpack.security.management.changePasswordForm.currentPasswordLabel": "当前密码", - "xpack.security.management.changePasswordForm.incorrectPasswordDescription": "您输入的当前密码不正确。", - "xpack.security.management.changePasswordForm.newPasswordLabel": "新密码", - "xpack.security.management.changePasswordForm.passwordDontMatchDescription": "密码不匹配", - "xpack.security.management.changePasswordForm.passwordLabel": "密码", - "xpack.security.management.changePasswordForm.passwordLengthDescription": "密码长度必须至少为 6 个字符", - "xpack.security.management.changePasswordForm.saveChangesButtonLabel": "保存更改", - "xpack.security.management.changePasswordForm.updateAndRestartKibanaDescription": "更改 Kibana 用户的密码后,必须更新 kibana.yml 文件并重新启动 Kibana", - "xpack.security.management.editRole.cancelButtonLabel": "取消", - "xpack.security.management.editRole.changeAllPrivilegesLink": "(全部更改)", - "xpack.security.management.editRole.collapsiblePanel.hideLinkText": "隐藏", - "xpack.security.management.editRole.collapsiblePanel.showLinkText": "显示", - "xpack.security.management.editRole.createRoleText": "创建角色", - "xpack.security.management.editRole.createRoleTitle": "创建角色", - "xpack.security.management.editRole.deleteRoleButton.cancelButtonLabel": "不,不删除", - "xpack.security.management.editRole.deleteRoleButton.confirmButtonLabel": "是的,删除角色", - "xpack.security.management.editRole.deleteRoleButton.deleteRoleButtonLabel": "删除角色", - "xpack.security.management.editRole.deleteRoleButton.deleteRoleTitle": "删除角色", - "xpack.security.management.editRole.deleteRoleButton.deletingRoleConfirmationText": "是否确定要删除此角色?", - "xpack.security.management.editRole.deleteRoleButton.deletingRoleWarningText": "此操作无法撤消!", - "xpack.security.management.editRole.editRoleTitle": "编辑角色", - "xpack.security.management.editRole.elasticSearchPrivileges.addIndexPrivilegesButtonLabel": "添加索引权限", - "xpack.security.management.editRole.elasticSearchPrivileges.addUserTitle": "添加用户……", - "xpack.security.management.editRole.elasticSearchPrivileges.clusterPrivilegesTitle": "集群权限", - "xpack.security.management.editRole.elasticSearchPrivileges.controlAccessToClusterDataDescription": "控制对集群中数据的访问权限。", - "xpack.security.management.editRole.elasticSearchPrivileges.howToBeSubmittedOnBehalfOfOtherUsersDescription": "允许代表其他用户提交请求。", - "xpack.security.management.editRole.elasticSearchPrivileges.indexPrivilegesTitle": "索引权限", - "xpack.security.management.editRole.elasticSearchPrivileges.learnMoreLinkText": "了解详情", - "xpack.security.management.editRole.elasticSearchPrivileges.manageRoleActionsDescription": "管理此角色可以对您的集群执行的操作。", - "xpack.security.management.editRole.elasticSearchPrivileges.runAsPrivilegesTitle": "运行身份权限", - "xpack.security.management.editRole.featureTable.enabledRoleFeaturesEnabledColumnTitle": "权限", - "xpack.security.management.editRole.featureTable.enabledRoleFeaturesFeatureColumnTitle": "功能", - "xpack.security.management.editRole.indexPrivilegeForm.deleteSpacePrivilegeAriaLabel": "删除索引权限", - "xpack.security.management.editRole.indexPrivilegeForm.grantedDocumentsQueryFormRowLabel": "已授权文档查询", - "xpack.security.management.editRole.indexPrivilegeForm.grantReadPrivilegesLabel": "授予特定文档的读取权限", - "xpack.security.management.editRole.indexPrivilegeForm.indicesFormRowLabel": "索引", - "xpack.security.management.editRole.indexPrivilegeForm.privilegesFormRowLabel": "权限", - "xpack.security.management.editRole.modifyingReversedRolesDescription": "保留角色为内置角色,不能删除或修改。", - "xpack.security.management.editRole.returnToRoleListButtonLabel": "返回角色列表", - "xpack.security.management.editRole.reversedRoleBadge.reservedRolesCanNotBeModifiedTooltip": "保留角色为内置角色,不能删除或修改。", - "xpack.security.management.editRole.roleNameFormRowHelpText": "创建角色名称后无法更改。", - "xpack.security.management.editRole.roleNameFormRowTitle": "角色名称", - "xpack.security.management.editRole.roleSuccessfullyDeletedNotificationMessage": "删除角色", - "xpack.security.management.editRole.roleSuccessfullySavedNotificationMessage": "保存的角色", - "xpack.security.management.editRole.setPrivilegesToKibanaDescription": "设置 Elasticsearch 数据的权限并控制对 Kibana 的访问权限。", - "xpack.security.management.editRole.setPrivilegesToKibanaSpacesDescription": "设置 Elasticsearch 数据的权限并控制对 Kibana 空间的访问权限。", - "xpack.security.management.editRole.simplePrivilegeForm.allPrivilegeDropdown": "全部", - "xpack.security.management.editRole.simplePrivilegeForm.allPrivilegeDropdownDescription": "授予对 Kibana 全部功能的完全权限", - "xpack.security.management.editRole.simplePrivilegeForm.allPrivilegeInput": "全部", - "xpack.security.management.editRole.simplePrivilegeForm.customPrivilegeDropdown": "定制", - "xpack.security.management.editRole.simplePrivilegeForm.customPrivilegeDropdownDescription": "定制对 Kibana 的访问权限", - "xpack.security.management.editRole.simplePrivilegeForm.customPrivilegeInput": "定制", - "xpack.security.management.editRole.simplePrivilegeForm.kibanaPrivilegesTitle": "Kibana 权限", - "xpack.security.management.editRole.simplePrivilegeForm.noPrivilegeDropdown": "无", - "xpack.security.management.editRole.simplePrivilegeForm.noPrivilegeDropdownDescription": "没有对 Kibana 的访问权限", - "xpack.security.management.editRole.simplePrivilegeForm.noPrivilegeInput": "无", - "xpack.security.management.editRole.simplePrivilegeForm.readPrivilegeDropdown": "读取", - "xpack.security.management.editRole.simplePrivilegeForm.readPrivilegeDropdownDescription": "授予对 Kibana 全部功能的只读权限。", - "xpack.security.management.editRole.simplePrivilegeForm.readPrivilegeInput": "读取", - "xpack.security.management.editRole.simplePrivilegeForm.specifyPrivilegeForRoleDescription": "为此角色指定 Kibana 权限。", - "xpack.security.management.editRole.simplePrivilegeForm.unsupportedSpacePrivilegesWarning": "此角色包含工作区的权限定义,但在 Kibana 中未启用工作区。保存此角色将会移除这些权限。", - "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.effectivePrivilegeMessage": "已通过 {source} 授予。", - "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.globalBasePrivilegeSource": "全局基本权限", - "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.globalFeaturePrivilegeSource": "全局功能权限", - "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.privilegeSupercededMessage": "{supersededPrivilege} 的原始权限已为 {actualPrivilegeSource} 所覆盖", - "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.spaceBasePrivilegeSource": "工作区基本权限", - "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.spaceFeaturePrivilegeSource": "全局功能权限", - "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.unknownPrivilegeSource": "**未知**", - "xpack.security.management.editRole.spaceAwarePrivilegeForm.ensureAccountHasAllPrivilegesGrantedDescription": "请确保您的帐户具有 {kibanaUser} 角色授予的所有权限,然后重试。", - "xpack.security.management.editRole.spaceAwarePrivilegeForm.globalSpacesName": "* 全局(所有工作区)", - "xpack.security.management.editRole.spaceAwarePrivilegeForm.howToViewAllAvailableSpacesDescription": "您无权查看所有可用工作区。", - "xpack.security.management.editRole.spaceAwarePrivilegeForm.insufficientPrivilegesDescription": "权限不足", - "xpack.security.management.editRole.spaceAwarePrivilegeForm.kibanaUserTitle": "kibana_user", - "xpack.security.management.editRole.spacePrivilegeForm.allPrivilegeDetails": "授予对选定工作区所有功能的完全访问权限。", - "xpack.security.management.editRole.spacePrivilegeForm.allPrivilegeDisplay": "全部", - "xpack.security.management.editRole.spacePrivilegeForm.allPrivilegeDropdownDisplay": "全部", - "xpack.security.management.editRole.spacePrivilegeForm.customizeFeaturePrivilegeDescription": "按功能提高权限级别。某些功能可能被工作区隐藏或受全局工作区权限影响。", - "xpack.security.management.editRole.spacePrivilegeForm.customizeFeaturePrivileges": "按功能定制", - "xpack.security.management.editRole.spacePrivilegeForm.customPrivilegeDetails": "在选定工作区中按功能定制访问权限。", - "xpack.security.management.editRole.spacePrivilegeForm.customPrivilegeDisplay": "定制", - "xpack.security.management.editRole.spacePrivilegeForm.customPrivilegeDropdownDisplay": "定制", - "xpack.security.management.editRole.spacePrivilegeForm.featurePrivilegeSummaryDescription": "某些功能可能被工作区隐藏或受全局工作区权限影响。", - "xpack.security.management.editRole.spacePrivilegeForm.globalPrivilegeNotice": "这些权限将应用到所有当前和未来工作区。", - "xpack.security.management.editRole.spacePrivilegeForm.globalPrivilegeWarning": "创建全局权限可能会影响您的其他工作区权限。", - "xpack.security.management.editRole.spacePrivilegeForm.modalTitle": "工作区权限", - "xpack.security.management.editRole.spacePrivilegeForm.privilegeSelectorFormLabel": "权限", - "xpack.security.management.editRole.spacePrivilegeForm.readPrivilegeDetails": "授予对选定工作区所有功能的只读访问权限。", - "xpack.security.management.editRole.spacePrivilegeForm.readPrivilegeDisplay": "读取", - "xpack.security.management.editRole.spacePrivilegeForm.readPrivilegeDropdownDisplay": "读取", - "xpack.security.management.editRole.spacePrivilegeForm.spaceSelectorFormLabel": "工作区", - "xpack.security.management.editRole.spacePrivilegeForm.summaryOfFeaturePrivileges": "功能权限的摘要", - "xpack.security.management.editRole.spacePrivilegeMatrix.basePrivilegeText": "基本权限", - "xpack.security.management.editRole.spacePrivilegeMatrix.basePrivilegeTooltip": "所有功能的基本权限将自动授予。", - "xpack.security.management.editRole.spacePrivilegeMatrix.closeButton": "关闭", - "xpack.security.management.editRole.spacePrivilegeMatrix.featureColumnTitle": "功能", - "xpack.security.management.editRole.spacePrivilegeMatrix.globalSpaceName": "全局", - "xpack.security.management.editRole.spacePrivilegeMatrix.modalTitle": "权限摘要", - "xpack.security.management.editRole.spacePrivilegeMatrix.showAllSpacesLink": "(所有工作区)", - "xpack.security.management.editRole.spacePrivilegeMatrix.showNMoreSpacesLink": "另外 {count} 个", - "xpack.security.management.editRole.spacePrivilegeMatrix.showSummaryText": "查看权限摘要", - "xpack.security.management.editRole.spacePrivilegeSection.addSpacePrivilegeButton": "添加工作区权限", - "xpack.security.management.editRole.spacePrivilegeSection.noAccessToKibanaTitle": "此角色未授予对 Kibana 的访问权限", - "xpack.security.management.editRole.spacePrivilegeTable.deletePrivilegesLabel": "删除以下工作区的权限:{spaceNames}。", - "xpack.security.management.editRole.spacePrivilegeTable.editPrivilegesLabel": "编辑以下工作区的权限:{spaceNames}。", - "xpack.security.management.editRole.spacePrivilegeTable.showAllSpacesLink": "显示工作区", - "xpack.security.management.editRole.spacePrivilegeTable.showLessSpacesLink": "显示更少", - "xpack.security.management.editRole.spacePrivilegeTable.showNMoreSpacesLink": "另外 {count} 个", - "xpack.security.management.editRole.spaceSelectorLabel": "工作区", - "xpack.security.management.editRole.spacesPopoverList.findSpacePlaceholder": "查找工作区", - "xpack.security.management.editRole.spacesPopoverList.noSpacesFoundTitle": " 未找到工作区 ", - "xpack.security.management.editRole.spacesPopoverList.popoverTitle": "工作区", - "xpack.security.management.editRole.transformErrorSectionDescription": "此角色定义无效,无法通过此屏幕进行编辑。", - "xpack.security.management.editRole.transformErrorSectionTitle": "角色格式不正确", - "xpack.security.management.editRole.updateRoleText": "更新角色", - "xpack.security.management.editRole.validateRole.indicesTypeErrorMessage": "{elasticIndices} 应为数组", - "xpack.security.management.editRole.validateRole.nameAllowedCharactersWarningMessage": "名称必须以字母或下划线开头,且只能包含字母、下划线和数字。", - "xpack.security.management.editRole.validateRole.nameLengthWarningMessage": "名称不能超过 1024 个字符", - "xpack.security.management.editRole.validateRole.onePrivilegeRequiredWarningMessage": "至少需要一个权限", - "xpack.security.management.editRole.validateRole.oneSpaceRequiredWarningMessage": "至少需要一个工作区", - "xpack.security.management.editRole.validateRole.privilegeRequiredWarningMessage": "“权限”必填", - "xpack.security.management.editRole.validateRole.provideRoleNameWarningMessage": "请提供角色名称", - "xpack.security.management.editRole.viewingRoleTitle": "查看角色", - "xpack.security.management.editRoles.indexPrivilegeForm.deniedFieldsFormRowLabel": "已拒绝字段", - "xpack.security.management.editRoles.indexPrivilegeForm.grantedFieldsFormRowHelpText": "如果未授权任何字段,则分配到此角色的用户将无法查看此索引的任何数据。", - "xpack.security.management.editRoles.indexPrivilegeForm.grantedFieldsFormRowLabel": "已授权字段", - "xpack.security.management.editRoles.indexPrivilegeForm.grantFieldPrivilegesLabel": "授予对特定字段的访问权限", - "xpack.security.management.editRolespacePrivilegeForm.cancelButton": "取消", - "xpack.security.management.editRolespacePrivilegeForm.createGlobalPrivilegeButton": "创建全局权限", - "xpack.security.management.editRolespacePrivilegeForm.createPrivilegeButton": "创建工作区权限", - "xpack.security.management.editRolespacePrivilegeForm.updateGlobalPrivilegeButton": "更新全局权限", - "xpack.security.management.editRolespacePrivilegeForm.updatePrivilegeButton": "更新工作区权限", - "xpack.security.management.passwordForm.confirmPasswordLabel": "确认密码", - "xpack.security.management.passwordForm.passwordDontMatchDescription": "密码不匹配", - "xpack.security.management.passwordForm.passwordLabel": "密码", - "xpack.security.management.passwordForm.passwordLengthDescription": "密码长度必须至少为 6 个字符", - "xpack.security.management.roles.confirmDelete.cancelButtonLabel": "取消", - "xpack.security.management.roles.confirmDelete.deleteButtonLabel": "删除", - "xpack.security.management.roles.confirmDelete.removingRolesDescription": "您即将删除以下角色:", - "xpack.security.management.roles.confirmDelete.roleDeletingErrorNotificationMessage": "删除角色 {roleName} 时出错", - "xpack.security.management.roles.confirmDelete.roleSuccessfullyDeletedNotificationMessage": "删除角色 {roleName}", - "xpack.security.management.roles.createRoleButtonLabel": "创建角色", - "xpack.security.management.roles.deleteRoleTitle": "删除角色{value, plural, one {{roleName}} other {}}", - "xpack.security.management.roles.deleteSelectedRolesButtonLabel": "删除 {numSelected} 个角色{numSelected, plural, one {} other {}}", - "xpack.security.management.roles.deletingRolesWarningMessage": "此操作无法撤消。", - "xpack.security.management.roles.deniedPermissionTitle": "您需要用于管理角色的权限", - "xpack.security.management.roles.disabledTooltip": " (已禁用)", - "xpack.security.management.roles.fetchingRolesErrorMessage": "获取用户时出错:{message}", - "xpack.security.management.roles.nameColumnName": "角色", - "xpack.security.management.roles.noPermissionToManageRolesDescription": "请联系您的管理员。", - "xpack.security.management.roles.reservedColumnDescription": "保留角色为内置角色,不能编辑或移除。", - "xpack.security.management.roles.reservedColumnName": "保留", - "xpack.security.management.roles.reservedRoleIconLabel": "保留角色", - "xpack.security.management.roles.roleNotFound": "未找到任何“{roleName}”。", - "xpack.security.management.roles.roleTitle": "角色", - "xpack.security.management.roles.subtitle": "将角色应用到用户组并管理整个堆栈的权限。", - "xpack.security.management.rolesTitle": "角色", - "xpack.security.management.securityTitle": "安全性", - "xpack.security.management.users.confirmDelete.cancelButtonLabel": "取消", - "xpack.security.management.users.confirmDelete.confirmButtonLabel": "删除", - "xpack.security.management.users.confirmDelete.deleteMultipleUsersTitle": "删除 {userLength} 用户", - "xpack.security.management.users.confirmDelete.deleteOneUserTitle": "删除用户 {userLength}", - "xpack.security.management.users.confirmDelete.removingUsersDescription": "您即将删除以下用户:", - "xpack.security.management.users.confirmDelete.removingUsersWarningMessage": "此操作无法撤消。", - "xpack.security.management.users.confirmDelete.userDeletingErrorNotificationMessage": "删除用户 {username} 时出错", - "xpack.security.management.users.confirmDelete.userSuccessfullyDeletedNotificationMessage": "已删除用户 {username}", - "xpack.security.management.users.createNewUserButtonLabel": "创建用户", - "xpack.security.management.users.deleteUsersButtonLabel": "删除 {numSelected} 个用户{numSelected, plural, one { } other { 个用户}}", - "xpack.security.management.users.deniedPermissionTitle": "您需要用于管理用户的权限", - "xpack.security.management.users.editUser.addRolesPlaceholder": "添加角色", - "xpack.security.management.users.editUser.cancelButtonLabel": "取消", - "xpack.security.management.users.editUser.changePasswordButtonLabel": "更改密码", - "xpack.security.management.users.editUser.changePasswordExtraStepTitle": "需要额外的步骤", - "xpack.security.management.users.editUser.changePasswordUpdateKibanaTitle": "更改 Kibana 用户的密码后,必须更新 {kibana} 文件并重新启动 Kibana。", - "xpack.security.management.users.editUser.changingUserNameAfterCreationDescription": "用户名一经创建,将无法更改。", - "xpack.security.management.users.editUser.confirmPasswordFormRowLabel": "确认密码", - "xpack.security.management.users.editUser.createUserButtonLabel": "创建用户", - "xpack.security.management.users.editUser.deleteUserButtonLabel": "删除用户", - "xpack.security.management.users.editUser.editUserTitle": "编辑 {userName} 用户", - "xpack.security.management.users.editUser.emailAddressFormRowLabel": "电子邮件地址", - "xpack.security.management.users.editUser.errorLoadingRolesTitle": "加载角色时出错", - "xpack.security.management.users.editUser.errorLoadingUserTitle": "加载用户时出错", - "xpack.security.management.users.editUser.fullNameFormRowLabel": "全名", - "xpack.security.management.users.editUser.modifyingReservedUsersDescription": "保留的用户是内置的,无法删除或修改。只能更改密码。", - "xpack.security.management.users.editUser.newUserTitle": "新建用户", - "xpack.security.management.users.editUser.passwordDoNotMatchErrorMessage": "密码不匹配", - "xpack.security.management.users.editUser.passwordFormRowLabel": "密码", - "xpack.security.management.users.editUser.passwordLengthErrorMessage": "密码长度必须至少为 6 个字符", - "xpack.security.management.users.editUser.requiredUsernameErrorMessage": "“用户名”必填", - "xpack.security.management.users.editUser.returnToUserListButtonLabel": "返回到用户列表", - "xpack.security.management.users.editUser.rolesFormRowLabel": "角色", - "xpack.security.management.users.editUser.savingUserErrorMessage": "保存用户时出错:{message}", - "xpack.security.management.users.editUser.settingPasswordErrorMessage": "设置密码时出错:{message}", - "xpack.security.management.users.editUser.updateUserButtonLabel": "更新用户", - "xpack.security.management.users.editUser.usernameAllowedCharactersErrorMessage": "用户名必须以字母或下划线开头,并只能包含字母、下划线和数字", - "xpack.security.management.users.editUser.usernameFormRowLabel": "用户名", - "xpack.security.management.users.editUser.userSuccessfullySavedNotificationMessage": "已保存用户{message}", - "xpack.security.management.users.editUser.validEmailRequiredErrorMessage": "电子邮件地址无效", - "xpack.security.management.users.emailAddressColumnName": "电子邮件地址", - "xpack.security.management.users.fetchingUsersErrorMessage": "提取用户时出错:{message}", - "xpack.security.management.users.fullNameColumnName": "全名", - "xpack.security.management.users.permissionDeniedToManageUsersDescription": "请联系您的管理员。", - "xpack.security.management.users.reservedColumnDescription": "保留的用户是内置的,无法删除。只能更改密码。", - "xpack.security.management.users.reservedColumnName": "保留", - "xpack.security.management.users.rolesColumnName": "角色", - "xpack.security.management.users.userNameColumnName": "用户名", - "xpack.security.management.users.usersTitle": "用户", - "xpack.security.management.usersTitle": "用户", - "xpack.security.navControlComponent.accountMenuAriaLabel": "帐户菜单", - "xpack.security.navControlComponent.editProfileLinkText": "编辑配置文件", - "xpack.security.navControlComponent.logoutLinkText": "注销", - "xpack.security.overwrittenSession.continueAsUserText": "作为 {username} 继续", - "xpack.security.overwrittenSession.title": "您以前以其他用户身份登录。", - "xpack.security.registerFeature.securitySettingsDescription": "保护您的数据,并轻松管理谁有权限以用户和角色身份访问什么内容。", - "xpack.security.registerFeature.securitySettingsTitle": "安全性设置", - "xpack.security.roles.breadcrumb": "角色", - "xpack.security.roles.createBreadcrumb": "创建", - "xpack.security.users.breadcrumb": "用户", - "xpack.security.users.createBreadcrumb": "创建", - "xpack.security.management.editRole.featureTable.excludedFromBasePrivilegsTooltip": "使用“定制”权限来授予权限。{featureName} 不属于基础权限。", - "xpack.security.apiKeys.breadcrumb": "API 密钥", - "xpack.security.management.apiKeys.deniedPermissionTitle": "您需要管理 API 密钥的权限", - "xpack.security.management.apiKeys.invalidateApiKey.confirmModal.cancelButtonLabel": "取消", - "xpack.security.management.apiKeys.invalidateApiKey.confirmModal.confirmButtonLabel": "作废 {count, plural, one {API 密钥} other {API 密钥}}", - "xpack.security.management.apiKeys.invalidateApiKey.confirmModal.invalidateMultipleListDescription": "您即将作废以下 API 密钥:", - "xpack.security.management.apiKeys.invalidateApiKey.confirmModal.invalidateMultipleTitle": "作废 {count} API 密钥?", - "xpack.security.management.apiKeys.invalidateApiKey.confirmModal.invalidateSingleTitle": "作废 API 密钥“{name}”?", - "xpack.security.management.apiKeys.invalidateApiKey.errorMultipleNotificationTitle": "删除 {count} 个 api 密钥时出错", - "xpack.security.management.apiKeys.invalidateApiKey.errorSingleNotificationTitle": "删除 API 密钥“{name}”时出错", - "xpack.security.management.apiKeys.invalidateApiKey.successMultipleNotificationTitle": "已作废 {count} 个 API 密钥", - "xpack.security.management.apiKeys.invalidateApiKey.successSingleNotificationTitle": "已作废 API 密钥“{name}”", - "xpack.security.management.apiKeys.noPermissionToManageRolesDescription": "请联系您的管理员。", - "xpack.security.management.apiKeys.table.actionDeleteAriaLabel": "作废“{name}”", - "xpack.security.management.apiKeys.table.actionDeleteTooltip": "作废", - "xpack.security.management.apiKeys.table.actionsColumnName": "操作", - "xpack.security.management.apiKeys.table.adminText": "您是 API 密钥管理员。", - "xpack.security.management.apiKeys.table.apiKeysAllDescription": "查看并作废 API 密钥。API 密钥代表用户发送请求。", - "xpack.security.management.apiKeys.table.apiKeysDisabledErrorDescription": "请联系您的系统管理员并参阅{link}以启用 API 密钥。", - "xpack.security.management.apiKeys.table.apiKeysDisabledErrorLinkText": "文档", - "xpack.security.management.apiKeys.table.apiKeysDisabledErrorTitle": "Elasticsearch 中未启用 API 密钥", - "xpack.security.management.apiKeys.table.apiKeysOwnDescription": "查看并作废您的 API 密钥。API 密钥代表您发送请求。", - "xpack.security.management.apiKeys.table.apiKeysTableLoadingMessage": "正在加载 API 密钥……", - "xpack.security.management.apiKeys.table.apiKeysTitle": "API 密钥", - "xpack.security.management.apiKeys.table.creationDateColumnName": "创建时间", - "xpack.security.management.apiKeys.table.emptyPromptAdminTitle": "无 API 密钥", - "xpack.security.management.apiKeys.table.emptyPromptConsoleButtonMessage": "前往 Console", - "xpack.security.management.apiKeys.table.emptyPromptDescription": "您可以从 Console 创建 {link}。", - "xpack.security.management.apiKeys.table.emptyPromptDocsLinkMessage": "API 密钥", - "xpack.security.management.apiKeys.table.emptyPromptNonAdminTitle": "您未有任何 API 密钥", - "xpack.security.management.apiKeys.table.expirationDateColumnName": "过期", - "xpack.security.management.apiKeys.table.expirationDateNeverMessage": "永远不", - "xpack.security.management.apiKeys.table.invalidateApiKeyButton": "作废 {count, plural, one {API 密钥} other {API 密钥}}", - "xpack.security.management.apiKeys.table.loadingApiKeysDescription": "正在加载 API 密钥……", - "xpack.security.management.apiKeys.table.loadingApiKeysErrorTitle": "加载 API 密钥时出错", - "xpack.security.management.apiKeys.table.nameColumnName": "名称", - "xpack.security.management.apiKeys.table.realmColumnName": "Realm", - "xpack.security.management.apiKeys.table.realmFilterLabel": "Realm", - "xpack.security.management.apiKeys.table.reloadApiKeysButton": "重新加载", - "xpack.security.management.apiKeys.table.statusColumnName": "状态", - "xpack.security.management.apiKeys.table.userFilterLabel": "用户", - "xpack.security.management.apiKeys.table.userNameColumnName": "用户", - "xpack.security.management.apiKeysTitle": "API 密钥", - "xpack.server.checkLicense.errorExpiredMessage": "您不能使用 {pluginName},因为您的 {licenseType} 许可证已过期", - "xpack.server.checkLicense.errorUnavailableMessage": "您不能使用 {pluginName},因为许可证信息当前不可用。", - "xpack.server.checkLicense.errorUnsupportedMessage": "您的 {licenseType} 许可证不支持 {pluginName}。请升级您的许可。", - "xpack.siem.andOrBadge.and": "AND", - "xpack.siem.andOrBadge.or": "OR", - "xpack.siem.auditd.abortedAuditStartupDescription": "已中止审计启动", - "xpack.siem.auditd.accessErrorDescription": "访问错误", - "xpack.siem.auditd.accessPermissionDescription": "访问权限", - "xpack.siem.auditd.accessResultDescription": "访问结果", - "xpack.siem.auditd.acquiredCredentialsDescription": "已获得凭据 - 至", - "xpack.siem.auditd.adddedGroupAccountUsingDescription": "已添加组帐户 - 使用", - "xpack.siem.auditd.addedUserAccountDescription": "已添加用户帐户", - "xpack.siem.auditd.allocatedMemoryForDescription": "已分配内存 - 为", - "xpack.siem.auditd.asDescription": "作为", - "xpack.siem.auditd.assignedUserRoleToDescription": "已将用户角色分配给", - "xpack.siem.auditd.assignedVmIdDescription": "已分配 vm id", - "xpack.siem.auditd.assignedVMResourceDescription": "已分配 vm 资源", - "xpack.siem.auditd.attemptedLoginDescription": "已尝试登录 - 通过", - "xpack.siem.auditd.attemptedLoginFromUnusalPlaceDescription": "尝试异常位置的登录", - "xpack.siem.auditd.attemptedLoginFromUnusualHourDescription": "尝试异常时段的登录", - "xpack.siem.auditd.auditErrorDescription": "审计错误", - "xpack.siem.auditd.authenticatedToGroupDescription": "已验证到组", - "xpack.siem.auditd.authenticatedUsingDescription": "已验证 - 使用", - "xpack.siem.auditd.bootedSystemDescription": "已启动系统", - "xpack.siem.auditd.boundSocketFromDescription": "绑定套接字 - 来自", - "xpack.siem.auditd.causedMacPolicyErrorDescription": "已导致 mac 策略错误", - "xpack.siem.auditd.changedAuditConfigurationDescription": "已更改审计配置", - "xpack.siem.auditd.changedAuditFeatureDescription": "已更改审计功能", - "xpack.siem.auditd.changedConfigurationWIthDescription": "已更改配置", - "xpack.siem.auditd.ChangedFileAttributesOfDescription": "已更改文件属性 -", - "xpack.siem.auditd.changedFilePermissionOfDescription": "已更改文件权限 -", - "xpack.siem.auditd.changedGroupDescription": "已更改组", - "xpack.siem.auditd.changedGroupPasswordDescription": "已更改组密码", - "xpack.siem.auditd.changedIdentityUsingDescription": "已更改身份 - 使用", - "xpack.siem.auditd.changedLoginIdToDescription": "已将登录 id 更改为", - "xpack.siem.auditd.changedMacConfigurationDescription": "已更改 mac 配置", - "xpack.siem.auditd.changedPasswordWithDescription": "已更改密码 -", - "xpack.siem.auditd.changedRoleUsingDescription": "已更改角色 - 使用", - "xpack.siem.auditd.changedSeLinuxBooleanDescription": "已更改 selinux 布尔值", - "xpack.siem.auditd.changedSelinuxEnforcementDescription": "已 更改 selinux 强制", - "xpack.siem.auditd.changedSystemNameDescription": "已更改系统名称", - "xpack.siem.auditd.changedSystemTimeWithDescription": "已更改系统时间 -", - "xpack.siem.auditd.changedTimeStampOfDescription": "已更改时间戳 -", - "xpack.siem.auditd.changedToRunLevelWithDescription": "已更改到运行级别 -", - "xpack.siem.auditd.changedUserIdDescription": "已更改用户 id", - "xpack.siem.auditd.changeidleOwernshipOfDescription": "已更改文件所有权 -", - "xpack.siem.auditd.checkedFileSystemMetadataOfDescription": "已检查文件系统元数据 -", - "xpack.siem.auditd.checkedIntegrityOfDescription": "已更改完整性 -", - "xpack.siem.auditd.chedckedMetaDataOfDescription": "已更改元数据 -", - "xpack.siem.auditd.connectedUsingDescription": "已连接 - 使用", - "xpack.siem.auditd.crashedProgramDescription": "已崩溃程序", - "xpack.siem.auditd.createdDirectoryDescription": "已创建目录", - "xpack.siem.auditd.createdVmImageDescription": "已创建 vm 映像", - "xpack.siem.auditd.cryptoOfficerLoggedInDescription": "加密员已登录", - "xpack.siem.auditd.cryptoOfficerLoggedOutDescription": "加密员已注销", - "xpack.siem.auditd.deletedDescription": "已删除", - "xpack.siem.auditd.deletedGroupAccountUsingDescription": "已删除组帐户 - 使用", - "xpack.siem.auditd.deletedUserAccountUsingDescription": "已删除用户帐户 - 使用", - "xpack.siem.auditd.deletedVmImageDescription": "已删除 vm 映像", - "xpack.siem.auditd.disposedCredentialsDescription": "已将凭据处置到", - "xpack.siem.auditd.endedFromDescription": "结束自", - "xpack.siem.auditd.errorFromDescription": "错误来自", - "xpack.siem.auditd.executedDescription": "已执行", - "xpack.siem.auditd.executionOfForbiddenProgramDescription": "已禁止程序的执行", - "xpack.siem.auditd.failedLoginTooManyTimesDescription": "由于登录次数过多,登录失败", - "xpack.siem.auditd.inDescription": "传入", - "xpack.siem.auditd.initializedAuditSubsystemDescription": "已初始化审计子系统", - "xpack.siem.auditd.issuedVmControlDescription": "已签发 vm 控制", - "xpack.siem.auditd.killedProcessIdDescription": "已终止进程 id -", - "xpack.siem.auditd.ListeningForConnectionsUsingDescription": "正在侦听连接 - 使用", - "xpack.siem.auditd.loadedFirewallRuleDescription": "已加载防火墙规则", - "xpack.siem.auditd.loadedMacPolicyDescription": "已加载 mac 策略", - "xpack.siem.auditd.loadedSeLinuxPolicyDescription": "已加载 selinux 策略", - "xpack.siem.auditd.loaedKernelModuleOfDescription": "已加载内核模块 -", - "xpack.siem.auditd.lockedAccountDescription": "已锁定帐户", - "xpack.siem.auditd.loggedOutDescription": "已注销", - "xpack.siem.auditd.macPermissionDescription": "mac 权限", - "xpack.siem.auditd.madeDeviceWithDescription": "已制作设备 -", - "xpack.siem.auditd.migratedVmFromDescription": "已迁移 vm - 从", - "xpack.siem.auditd.migratedVmToDescription": "已将 vm 迁移至", - "xpack.siem.auditd.modifiedGroupAccountDescription": "已修改组帐户", - "xpack.siem.auditd.modifiedLevelOfDescription": "已修改级别 -", - "xpack.siem.auditd.modifiedRoleDescription": "已修改角色", - "xpack.siem.auditd.modifiedUserAccountDescription": "已修改用户帐户", - "xpack.siem.auditd.mountedDescription": "已安装", - "xpack.siem.auditd.negotiatedCryptoKeyDescription": "已协商加密密钥", - "xpack.siem.auditd.nonExistentDescription": "至未知进程", - "xpack.siem.auditd.OpenedFileDescription": "已打开文件", - "xpack.siem.auditd.openedTooManySessionsDescription": "已打开过多会话", - "xpack.siem.auditd.overrodeLabelOfDescription": "已覆盖标签 -", - "xpack.siem.auditd.promiscuousModeDescription": "已更改设备上的混杂模式 - 使用", - "xpack.siem.auditd.ranCommandDescription": "已运行命令", - "xpack.siem.auditd.receivedFromDescription": "已接收 - 从", - "xpack.siem.auditd.reconfiguredAuditDescription": "已重新配置审计", - "xpack.siem.auditd.refreshedCredentialsForDescription": "已刷新凭据 -", - "xpack.siem.auditd.relabeledFileSystemDescription": "已重新标记文件系统", - "xpack.siem.auditd.remoteAuditConnectedDescription": "远程审计已连接", - "xpack.siem.auditd.remoteAuditDisconnectedDescription": "远程审计已断开连接", - "xpack.siem.auditd.removedUserRoleFromDescription": "已移除用户角色 - 从", - "xpack.siem.auditd.renamedDescription": "已重命名", - "xpack.siem.auditd.resumedAuditLoggingDescription": "已恢复审计日志记录", - "xpack.siem.auditd.rotatedAuditLogsDescription": "rotated-audit-logs", - "xpack.siem.auditd.scheduledPolicyOFDescription": "已排定策略 -", - "xpack.siem.auditd.sentMessageDescription": "已发送消息", - "xpack.siem.auditd.sentTestDescription": "已发送测试", - "xpack.siem.auditd.sentToDescription": "已发送至", - "xpack.siem.auditd.sessionDescription": "会话", - "xpack.siem.auditd.shutDownAuditDescription": "关闭审计", - "xpack.siem.auditd.shutdownSystemDescription": "关闭系统", - "xpack.siem.auditd.startedAtDescription": "已启动", - "xpack.siem.auditd.startedAuditDescription": "已启动审计", - "xpack.siem.auditd.startedCryptoSessionDescription": "已启动加密会话", - "xpack.siem.auditd.startedServiceDescription": "已启动服务", - "xpack.siem.auditd.stoppedServiceDescription": "已停止服务", - "xpack.siem.auditd.suspiciousProgramDescription": "已使用可疑程序", - "xpack.siem.auditd.symLinkedDescription": "已象征性链接", - "xpack.siem.auditd.testedFileSystemIntegrityDescription": "已测试文件系统完整性", - "xpack.siem.auditd.unknownDescription": "未知", - "xpack.siem.auditd.unloadedKernelModuleOfDescription": "已加载内核模块", - "xpack.siem.auditd.unlockedAccountDescription": "已解锁帐户", - "xpack.siem.auditd.unmountedDescription": "已卸载", - "xpack.siem.auditd.usingDescription": "使用", - "xpack.siem.auditd.violatedAppArmorPolicyFromDescription": "已违反应用防护策略 - 来自", - "xpack.siem.auditd.violatedSeccompPolicyWithDescription": "已违反 seccomp 策略 -", - "xpack.siem.auditd.violatedSeLinuxPolicyDescription": "已违反 selinux 策略", - "xpack.siem.auditd.wasAuthorizedToUseDescription": "有权使用", - "xpack.siem.auditd.withResultDescription": ",结果为", - "xpack.siem.authenticationsTable.authenticationFailures": "身份验证", - "xpack.siem.authenticationsTable.failures": "失败", - "xpack.siem.authenticationsTable.lastFailedDestination": "上一失败目标", - "xpack.siem.authenticationsTable.lastFailedSource": "上一失败源", - "xpack.siem.authenticationsTable.lastFailedTime": "上次失败", - "xpack.siem.authenticationsTable.lastSuccessfulDestination": "上一成功目标", - "xpack.siem.authenticationsTable.lastSuccessfulSource": "上一成功源", - "xpack.siem.authenticationsTable.lastSuccessfulTime": "上次成功", - "xpack.siem.authenticationsTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", - "xpack.siem.authenticationsTable.successes": "成功", - "xpack.siem.authenticationsTable.uncommonProcessTable": "不常见进程", - "xpack.siem.authenticationsTable.unit": "{totalCount, plural, =1 {user} other {users}}", - "xpack.siem.authenticationsTable.user": "用户", - "xpack.siem.certificate.fingerprint.clientCertLabel": "客户端证书", - "xpack.siem.certificate.fingerprint.serverCertLabel": "服务器证书", - "xpack.siem.chart.dataNotAvailableTitle": "图表数据不可用", - "xpack.siem.clipboard.copied": "已复制", - "xpack.siem.clipboard.copy": "复制", - "xpack.siem.clipboard.to.the.clipboard": "至剪贴板", - "xpack.siem.components.flowControls.selectFlowDirection.bidirectionalButtonLabel": "双向", - "xpack.siem.components.flowControls.selectFlowDirection.unidirectionalButtonLabel": "单向", - "xpack.siem.components.flowControls.selectFlowTarget.clientDropDownOptionLabel": "客户端", - "xpack.siem.components.flowControls.selectFlowTarget.destinationDropDownOptionLabel": "目标", - "xpack.siem.components.flowControls.selectFlowTarget.serverDropDownOptionLabel": "服务器", - "xpack.siem.components.flowControls.selectFlowTarget.sourceDropDownOptionLabel": "源", - "xpack.siem.containers.errors.dataFetchFailureTitle": "数据提取失败", - "xpack.siem.containers.errors.networkFailureTitle": "网络故障", - "xpack.siem.dataProviders.and": "AND", - "xpack.siem.dataProviders.deleteDataProvider": "删除", - "xpack.siem.dataProviders.dropAnything": "放置任何内容", - "xpack.siem.dataProviders.dropHere": "放在此处", - "xpack.siem.dataProviders.dropHereToAddAnLabel": "放在此处以添加", - "xpack.siem.dataProviders.editMenuItem": "编辑筛选", - "xpack.siem.dataProviders.editTitle": "编辑筛选", - "xpack.siem.dataProviders.excludeDataProvider": "排除结果", - "xpack.siem.dataProviders.existsLabel": "存在", - "xpack.siem.dataProviders.filterForFieldPresentLabel": "筛留存在的字段", - "xpack.siem.dataProviders.hereToBuildAn": "在此处以构建", - "xpack.siem.dataProviders.highlighted": "已突出显示", - "xpack.siem.dataProviders.includeDataProvider": "包括结果", - "xpack.siem.dataProviders.not": "非", - "xpack.siem.dataProviders.or": "或", - "xpack.siem.dataProviders.query": "查询", - "xpack.siem.dataProviders.reEnableDataProvider": "重新启用", - "xpack.siem.dataProviders.removeDataProvider": "移除数据提供程序", - "xpack.siem.dataProviders.showOptionsDataProvider": "显示选项 - 适用于", - "xpack.siem.dataProviders.temporaryDisableDataProvider": "暂时禁用", - "xpack.siem.dataProviders.toBuildAn": "以构建", - "xpack.siem.dataProviders.toggle": "切换", - "xpack.siem.dataProviders.valueAriaLabel": "值", - "xpack.siem.dataProviders.valuePlaceholder": "值", - "xpack.siem.draggables.field.categoryLabel": "类别", - "xpack.siem.draggables.field.fieldLabel": "字段", - "xpack.siem.draggables.field.typeLabel": "类型", - "xpack.siem.draggables.field.viewCategoryTooltip": "查看类别", - "xpack.siem.editDataProvider.doesNotExistLabel": "不存在", - "xpack.siem.editDataProvider.existsLabel": "存在", - "xpack.siem.editDataProvider.fieldLabel": "字段", - "xpack.siem.editDataProvider.fieldPlaceholder": "选择字段", - "xpack.siem.editDataProvider.isLabel": "是", - "xpack.siem.editDataProvider.isNotLabel": "不是", - "xpack.siem.editDataProvider.operatorLabel": "运算符", - "xpack.siem.editDataProvider.saveButton": "保存", - "xpack.siem.editDataProvider.selectAnOperatorPlaceholder": "选择运算符", - "xpack.siem.editDataProvider.valueLabel": "值", - "xpack.siem.editDataProvider.valuePlaceholder": "值", - "xpack.siem.emptyString.emptyStringDescription": "空字符串", - "xpack.siem.eventDetails.copyToClipboard": "复制到剪贴板", - "xpack.siem.eventDetails.copyToClipboardTooltip": "复制到剪贴板", - "xpack.siem.eventDetails.description": "描述", - "xpack.siem.eventDetails.field": "字段", - "xpack.siem.eventDetails.filter.placeholder": "按字段、值或描述筛选......", - "xpack.siem.eventDetails.jsonView": "JSON 视图", - "xpack.siem.eventDetails.table": "表", - "xpack.siem.eventDetails.value": "值", - "xpack.siem.featureRegistry.linkSiemTitle": "SIEM", - "xpack.siem.fieldBrowser.categoriesCountTitle": "{totalCount} {totalCount, plural, =1 {category} other {categories}}", - "xpack.siem.fieldBrowser.categoriesTitle": "类别", - "xpack.siem.fieldBrowser.categoryLabel": "类别", - "xpack.siem.fieldBrowser.copyToClipboard": "复制到剪贴板", - "xpack.siem.fieldBrowser.customizeColumnsTitle": "定制列", - "xpack.siem.fieldBrowser.descriptionLabel": "描述", - "xpack.siem.fieldBrowser.fieldLabel": "字段", - "xpack.siem.fieldBrowser.fieldsCountTitle": "{totalCount} {totalCount, plural, =1 {field} other {fields}}", - "xpack.siem.fieldBrowser.fieldsTitle": "字段", - "xpack.siem.fieldBrowser.filterPlaceholder": "字段名称", - "xpack.siem.fieldBrowser.noFieldsMatchInputLabel": "没有字段匹配 {searchInput}", - "xpack.siem.fieldBrowser.noFieldsMatchLabel": "没有字段匹配", - "xpack.siem.fieldBrowser.resetFieldsLink": "重置字段", - "xpack.siem.fieldBrowser.viewCategoryTooltip": "查看所有 {categoryId} 字段", - "xpack.siem.fieldRenderers.moreLabel": "更多", - "xpack.siem.flyout.button.timeline": "时间线", - "xpack.siem.footer.autoRefreshActiveDescription": "自动刷新已启用", - "xpack.siem.footer.autoRefreshActiveTooltip": "自动刷新已启用时,时间线将显示匹配查询的最近 {numberOfItems} 个事件。", - "xpack.siem.footer.data": "数据", - "xpack.siem.footer.events": "事件", - "xpack.siem.footer.live": "实时", - "xpack.siem.footer.loadingLabel": "正在加载", - "xpack.siem.footer.loadingTimelineData": "正在加载 Timeline 数据", - "xpack.siem.footer.loadMoreLabel": "加载更多", - "xpack.siem.footer.of": "的", - "xpack.siem.footer.rows": "行", - "xpack.siem.footer.totalCountOfEvents": "匹配搜索条件的事件", - "xpack.siem.footer.updated": "已更新", - "xpack.siem.formatted.duration.aFewMillisecondsTooltip": "几毫秒", - "xpack.siem.formatted.duration.aFewNanosecondsTooltip": "几纳秒", - "xpack.siem.formatted.duration.aMillisecondTooltip": "一毫秒", - "xpack.siem.formatted.duration.aNanosecondTooltip": "一纳秒", - "xpack.siem.formatted.duration.aSecondTooltip": "一秒", - "xpack.siem.formatted.duration.invalidDurationTooltip": "持续时间无效", - "xpack.siem.formatted.duration.noDurationTooltip": "无持续时间", - "xpack.siem.formatted.duration.zeroNanosecondsTooltip": "零纳秒", - "xpack.siem.formattedDuration.tooltipLabel": "原始", - "xpack.siem.headerPage.pageSubtitle": "最后事件:{beat}", - "xpack.siem.host.details.architectureLabel": "架构", - "xpack.siem.host.details.firstSeenTitle": "首次看到时间", - "xpack.siem.host.details.lastSeenTitle": "最后看到时间", - "xpack.siem.host.details.overview.cloudProviderTitle": "云服务提供商", - "xpack.siem.host.details.overview.familyTitle": "系列", - "xpack.siem.host.details.overview.hostIdTitle": "主机 ID", - "xpack.siem.host.details.overview.instanceIdTitle": "实例 ID", - "xpack.siem.host.details.overview.ipAddressesTitle": "IP 地址", - "xpack.siem.host.details.overview.macAddressesTitle": "MAC 地址", - "xpack.siem.host.details.overview.machineTypeTitle": "机器类型", - "xpack.siem.host.details.overview.osTitle": "操作系统", - "xpack.siem.host.details.overview.platformTitle": "平台", - "xpack.siem.host.details.overview.regionTitle": "地区", - "xpack.siem.host.details.versionLabel": "版本", - "xpack.siem.hosts.emptyActionPrimary": "查看设置说明", - "xpack.siem.hosts.emptyActionSecondary": "前往文档", - "xpack.siem.hosts.emptyTitle": "似乎您在 SIEM 应用程序中没有与主机相关的索引", - "xpack.siem.hosts.kqlPlaceholder": "例如 host.name:“foo”", - "xpack.siem.hosts.pageTitle": "主机", - "xpack.siem.hostsTable.firstLastSeenToolTip": "相对于选定日期范围", - "xpack.siem.hostsTable.hostsTitle": "所有主机", - "xpack.siem.hostsTable.lastSeenTitle": "最后看到时间", - "xpack.siem.hostsTable.nameTitle": "名称", - "xpack.siem.hostsTable.osTitle": "操作系统", - "xpack.siem.hostsTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", - "xpack.siem.hostsTable.unit": "{totalCount, plural, =1 {host} other {hosts}}", - "xpack.siem.hostsTable.versionTitle": "版本", - "xpack.siem.ja3.fingerprint.ja3.fingerprintLabel": "ja3", - "xpack.siem.linkSecurityDescription": "浏览您的 SIEM 应用", - "xpack.siem.markdown.hint.boldLabel": "**粗体**", - "xpack.siem.markdown.hint.bulletLabel": "* 项目符号", - "xpack.siem.markdown.hint.codeLabel": "`code`", - "xpack.siem.markdown.hint.headingLabel": "# 标题", - "xpack.siem.markdown.hint.imageUrlLabel": "![image](url)", - "xpack.siem.markdown.hint.italicsLabel": "_italics_", - "xpack.siem.markdown.hint.preformattedLabel": "```preformatted```", - "xpack.siem.markdown.hint.quoteLabel": ">引用", - "xpack.siem.markdown.hint.strikethroughLabel": "删除线", - "xpack.siem.markdown.hint.urlLabel": "[链接](url)", - "xpack.siem.navigation.hosts": "主机", - "xpack.siem.navigation.network": "网络", - "xpack.siem.navigation.overview": "概览", - "xpack.siem.navigation.timelines": "时间线", - "xpack.siem.network.emptyActionPrimary": "查看设置说明", - "xpack.siem.network.emptyActionSecondary": "前往文档", - "xpack.siem.network.emptyTitle": "似乎您在 SIEM 应用程序中没有与网络相关的索引", - "xpack.siem.network.ipDetails.ipOverview.autonomousSystemTitle": "自治系统", - "xpack.siem.network.ipDetails.ipOverview.firstSeenTitle": "首次看到时间", - "xpack.siem.network.ipDetails.ipOverview.hostIdTitle": "主机 ID", - "xpack.siem.network.ipDetails.ipOverview.hostNameTitle": "主机名", - "xpack.siem.network.ipDetails.ipOverview.ipReputationTitle": "信誉", - "xpack.siem.network.ipDetails.ipOverview.lastSeenTitle": "最后看到时间", - "xpack.siem.network.ipDetails.ipOverview.locationTitle": "位置", - "xpack.siem.network.ipDetails.ipOverview.viewWhoisTitle": "iana.org", - "xpack.siem.network.ipDetails.ipOverview.whoIsTitle": "WhoIs", - "xpack.siem.network.ipDetails.tlsTable.columns.issuerTitle": "颁发者", - "xpack.siem.network.ipDetails.tlsTable.columns.ja3FingerPrintTitle": "JA3 指纹", - "xpack.siem.network.ipDetails.tlsTable.columns.sha1FingerPrintTitle": "SHA1 指纹", - "xpack.siem.network.ipDetails.tlsTable.columns.subjectTitle": "主题", - "xpack.siem.network.ipDetails.tlsTable.columns.validUntilTitle": "失效日期", - "xpack.siem.network.ipDetails.tlsTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", - "xpack.siem.network.ipDetails.tlsTable.transportLayerSecurityTitle": "传输层安全", - "xpack.siem.network.ipDetails.tlsTable.unit": "{totalCount, plural, =1 {issuer} other {issuers}}", - "xpack.siem.network.ipDetails.usersTable.columns.documentCountTitle": "文档计数", - "xpack.siem.network.ipDetails.usersTable.columns.groupIdTitle": "组 ID", - "xpack.siem.network.ipDetails.usersTable.columns.groupNameTitle": "组名称", - "xpack.siem.network.ipDetails.usersTable.columns.userIdTitle": "ID", - "xpack.siem.network.ipDetails.usersTable.columns.userNameTitle": "用户", - "xpack.siem.network.ipDetails.usersTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", - "xpack.siem.network.ipDetails.usersTable.unit": "{totalCount, plural, =1 {user} other {users}}", - "xpack.siem.network.ipDetails.usersTable.usersTitle": "用户", - "xpack.siem.network.kqlPlaceholder": "例如 source.ip:“foo”", - "xpack.siem.network.pageTitle": "网络", - "xpack.siem.networkDnsTable.column.bytesInTitle": "DNS 传入字节", - "xpack.siem.networkDnsTable.column.bytesOutTitle": "DNS 传出字节", - "xpack.siem.networkDnsTable.column.registeredDomain": "已注册域", - "xpack.siem.networkDnsTable.column.TotalQueriesTitle": "查询总数", - "xpack.siem.networkDnsTable.column.uniqueDomainsTitle": "唯一域", - "xpack.siem.networkDnsTable.helperTooltip": "其仅显示 DNS 协议流量,可用于捕获 DNS 数据外泄中使用的域。", - "xpack.siem.networkDnsTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", - "xpack.siem.networkDnsTable.select.includePtrRecords": "包括 PTR 记录", - "xpack.siem.networkDnsTable.title": "排名靠前的 DNS 域", - "xpack.siem.networkDnsTable.unit": "{totalCount, plural, =1 {domain} other {domains}}", - "xpack.siem.networkTopNFlowTable.column.destinationIpTitle": "目标 IP", - "xpack.siem.networkTopNFlowTable.column.sourceIpTitle": "源 IP", - "xpack.siem.networkTopNFlowTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", - "xpack.siem.networkTopNFlowTable.unit": "{totalCount, plural, =1 {IP} other {IPs}}", - "xpack.siem.notes.addANotePlaceholder": "添加备注", - "xpack.siem.notes.addedANoteLabel": "已添加备注", - "xpack.siem.notes.addNoteButtonLabel": "添加备注", - "xpack.siem.notes.cancelButtonLabel": "取消", - "xpack.siem.notes.copyToClipboardButtonLabel": "复制到剪贴板", - "xpack.siem.notes.noteLabel": "注释", - "xpack.siem.notes.notesTitle": "备注", - "xpack.siem.notes.previewMarkdownTitle": "预览 (Markdown)", - "xpack.siem.notes.search.FilterByUserOrNotePlaceholder": "按用户或备注筛选", - "xpack.siem.open.timeline.cancelButton": "取消", - "xpack.siem.open.timeline.collapseButton": "折叠", - "xpack.siem.open.timeline.deleteButton": "删除", - "xpack.siem.open.timeline.deleteSelectedButton": "删除选定", - "xpack.siem.open.timeline.deleteTimelineModalTitle": "删除“{title}”?", - "xpack.siem.open.timeline.deleteWarningLabel": "一旦删除,将无法恢复此时间线或其备注。", - "xpack.siem.open.timeline.descriptionTableHeader": "描述", - "xpack.siem.open.timeline.expandButton": "展开", - "xpack.siem.open.timeline.favoriteSelectedButton": "收藏所选", - "xpack.siem.open.timeline.favoritesTooltip": "收藏夹", - "xpack.siem.open.timeline.lastModifiedTableHeader": "最后修改时间", - "xpack.siem.open.timeline.missingSavedObjectIdTooltip": "缺失 savedObjectId", - "xpack.siem.open.timeline.modifiedByTableHeader": "修改者", - "xpack.siem.open.timeline.notesTooltip": "备注", - "xpack.siem.open.timeline.onlyFavoritesButtonLabel": "仅收藏夹", - "xpack.siem.open.timeline.openAsDuplicateTooltip": "作为时间线副本打开", - "xpack.siem.open.timeline.openTimelineButton": "打开时间线......", - "xpack.siem.open.timeline.openTimelineTitle": "打开时间线", - "xpack.siem.open.timeline.pinnedEventsTooltip": "置顶事件", - "xpack.siem.open.timeline.postedLabel": "已发表:", - "xpack.siem.open.timeline.searchPlaceholder": "例如时间线名称或描述", - "xpack.siem.open.timeline.showingNTimelinesLabel": "显示 {totalSearchResultsCount} {totalSearchResultsCount, plural, one {个时间线} other {个时间线}} {with}", - "xpack.siem.open.timeline.timelineNameTableHeader": "时间线名称", - "xpack.siem.open.timeline.untitledTimelineLabel": "未命名时间线", - "xpack.siem.open.timeline.withLabel": "具有", - "xpack.siem.open.timeline.zeroTimelinesMatchLabel": "0 个时间线匹配搜索条件", - "xpack.siem.overview.auditBeatAuditTitle": "Auditbeat 审计", - "xpack.siem.overview.auditBeatFimTitle": "Auditbeat 文件完整性模块", - "xpack.siem.overview.auditBeatLoginTitle": "Auditbeat 登录", - "xpack.siem.overview.auditBeatPackageTitle": "Auditbeat 软件包", - "xpack.siem.overview.auditBeatProcessTitle": "Auditbeat 进程", - "xpack.siem.overview.auditBeatSocketTitle": "Auditbeat 套接字", - "xpack.siem.overview.auditBeatUserTitle": "Auditbeat 用户", - "xpack.siem.overview.emptyActionPrimary": "查看设置说明", - "xpack.siem.overview.emptyActionSecondary": "前往文档", - "xpack.siem.overview.emptyTitle": "似乎您没有与 SIEM 应用程序相关的索引", - "xpack.siem.overview.feedbackText": "如果您对 Elastic SIEM 体验有任何建议,请随时{feedback}。", - "xpack.siem.overview.feedbackText.feedbackLinkText": "在线提交反馈", - "xpack.siem.overview.feedbackTitle": "反馈", - "xpack.siem.overview.filebeatCiscoTitle": "Filebeat Cisco", - "xpack.siem.overview.filebeatNetflowTitle": "Filebeat NetFlow", - "xpack.siem.overview.filebeatPanwTitle": "Filebeat Palo Alto Networks", - "xpack.siem.overview.fileBeatSuricataTitle": "Filebeat Suricata", - "xpack.siem.overview.filebeatSystemModuleTitle": "Filebeat 系统模块", - "xpack.siem.overview.fileBeatZeekTitle": "Filebeat Zeek", - "xpack.siem.overview.hostsAction": "查看主机", - "xpack.siem.overview.hostsSubtitle": "显示:过去 24 小时", - "xpack.siem.overview.hostsTitle": "主机事件", - "xpack.siem.overview.networkAction": "查看网络", - "xpack.siem.overview.networkSubtitle": "显示:过去 24 小时", - "xpack.siem.overview.networkTitle": "网络事件", - "xpack.siem.overview.packetBeatDnsTitle": "Packetbeat DNS", - "xpack.siem.overview.packetBeatFlowTitle": "Packetbeat 流", - "xpack.siem.overview.packetbeatTLSTitle": "Packetbeat TLS", - "xpack.siem.overview.pageBadgeLabel": "公测版", - "xpack.siem.overview.pageBadgeTooltip": "SIEM 仍为公测版。请通过在 Kibana 报告中报告问题或错误,帮助我们改进产品。", - "xpack.siem.overview.pageSubtitle": "Elastic Stack 的安全信息和事件管理功能", - "xpack.siem.overview.pageTitle": "SIEM", - "xpack.siem.overview.startedText": "欢迎使用安全信息和事件管理 (SIEM)。首先,查看我们的 {docs} 或 {data}。有关即将推出的功能和教程,确保查看我们的{siemSolution}页。", - "xpack.siem.overview.startedText.dataLinkText": "正在采集数据", - "xpack.siem.overview.startedText.docsLinkText": "文档", - "xpack.siem.overview.startedText.siemSolutionLinkText": "SIEM 解决方案", - "xpack.siem.overview.startedTitle": "入门", - "xpack.siem.overview.winlogbeatTitle": "Winlogbeat", - "xpack.siem.pages.fourohfour.noContentFoundDescription": "未找到任何内容", - "xpack.siem.securityDescription": "浏览您的 SIEM 应用", - "xpack.siem.source.destination.packetsLabel": "pkts", - "xpack.siem.system.acceptedDescription": "已接受该用户 - 通过", - "xpack.siem.system.attemptedLoginDescription": "已尝试登录 - 通过", - "xpack.siem.system.errorDescription": "遇到错误 - ", - "xpack.siem.system.existingPackageDescription": "正在使用现有软件包", - "xpack.siem.system.existingProcessDescription": "正在运行进程", - "xpack.siem.system.existingSocketDescription": "正在使用现有套接字 - 来自", - "xpack.siem.system.existingUserDescription": "是现有用户", - "xpack.siem.system.hostDescription": "主机信息", - "xpack.siem.system.invalidDescription": "已尝试无效使用", - "xpack.siem.system.loggedOutDescription": "已注销 - 通过", - "xpack.siem.system.packageInstalledDescription": "已安装软件包", - "xpack.siem.system.packageRemovedDescription": "已移除软件包", - "xpack.siem.system.packageSystemStartedDescription": "系统已启动", - "xpack.siem.system.packageUpdatedDescription": "已更新软件包", - "xpack.siem.system.processErrorDescription": "遇到进程错误 -", - "xpack.siem.system.processStartedDescription": "已启动进程", - "xpack.siem.system.processStoppedDescription": "已停止进程", - "xpack.siem.system.socketClosedDescription": "已关闭套接字 -", - "xpack.siem.system.socketOpenedDescription": "已打开套接字 -", - "xpack.siem.system.systemDescription": "系统", - "xpack.siem.system.userAddedDescription": "用户已添加", - "xpack.siem.system.userChangedDescription": "用户已更改", - "xpack.siem.system.userRemovedDescription": "已移除", - "xpack.siem.system.usingDescription": "使用", - "xpack.siem.system.wasAuthorizedToUseDescription": "有权使用", - "xpack.siem.system.withResultDescription": ",结果为", - "xpack.siem.tables.rowItemHelper.moreDescription": "未显示", - "xpack.siem.timeline.autosave.warning.description": "其他用户已更改此时间线。您所做的任何更改不会自动保存,直至您刷新了此时间线以吸收这些更改。", - "xpack.siem.timeline.autosave.warning.refresh.title": "刷新时间线", - "xpack.siem.timeline.autosave.warning.title": "刷新后才会启用自动保存", - "xpack.siem.timeline.body.actions.collapseAriaLabel": "折叠", - "xpack.siem.timeline.body.actions.expandAriaLabel": "展开", - "xpack.siem.timeline.body.copyToClipboardButtonLabel": "复制到剪贴板", - "xpack.siem.timeline.body.notes.addOrViewNotesForThisEventTooltip": "添加或查看此事件的备注", - "xpack.siem.timeline.body.pinning.pinnedTooltip": "该时间线持续出现此事件", - "xpack.siem.timeline.body.pinning.pinnnedWithNotesTooltip": "此事件无法固定,因为其有备注", - "xpack.siem.timeline.body.pinning.unpinnedTooltip": "该时间线未持续存在此事件", - "xpack.siem.timeline.categoryTooltip": "类别", - "xpack.siem.timeline.descriptionTooltip": "描述", - "xpack.siem.timeline.destination": "目标", - "xpack.siem.timeline.eventsSelect.actions.pinSelected": "固定所选", - "xpack.siem.timeline.eventsSelect.actions.selectAll": "全部", - "xpack.siem.timeline.eventsSelect.actions.selectNone": "无", - "xpack.siem.timeline.eventsSelect.actions.selectPinned": "已固定", - "xpack.siem.timeline.eventsSelect.actions.selectUnpinned": "取消固定", - "xpack.siem.timeline.eventsSelect.actions.unpinSelected": "取消固定所选", - "xpack.siem.timeline.expandableEvent.copyToClipboardToolTip": "复制到剪贴板", - "xpack.siem.timeline.expandableEvent.eventToolTipTitle": "时间", - "xpack.siem.timeline.fieldTooltip": "字段", - "xpack.siem.timeline.flyout.pane.closeTimelineButtonLabel": "关闭时间线", - "xpack.siem.timeline.flyout.pane.removeColumnButtonLabel": "删除列", - "xpack.siem.timeline.flyout.pane.timelinePropertiesAriaLabel": "时间线属性", - "xpack.siem.timeline.properties.descriptionPlaceholder": "描述", - "xpack.siem.timeline.properties.descriptionTooltip": "此时间线中事件和备注的摘要", - "xpack.siem.timeline.properties.favoriteTooltip": "收藏", - "xpack.siem.timeline.properties.historyLabel": "历史记录", - "xpack.siem.timeline.properties.historyToolTip": "与此时间线相关的操作历史记录(按时间顺序排列)", - "xpack.siem.timeline.properties.isViewingTooltip": "正在查看此时间线", - "xpack.siem.timeline.properties.lockDatePickerDescription": "将日期选取器锁定到全局日期选取器", - "xpack.siem.timeline.properties.lockDatePickerTooltip": "禁用当前查看的页面和您的时间线之间的日期/时间范围同步", - "xpack.siem.timeline.properties.newTimelineButtonLabel": "创建新的时间线", - "xpack.siem.timeline.properties.notAFavoriteTooltip": "取消收藏", - "xpack.siem.timeline.properties.notesButtonLabel": "备注", - "xpack.siem.timeline.properties.notesToolTip": "添加并复查此时间线的备注。也可以向事件添加备注。", - "xpack.siem.timeline.properties.streamLiveButtonLabel": "实时流式传输", - "xpack.siem.timeline.properties.streamLiveToolTip": "新数据到达时更新时间线", - "xpack.siem.timeline.properties.timelineDescription": "时间线描述", - "xpack.siem.timeline.properties.timelineTitleAriaLabel": "时间线标题", - "xpack.siem.timeline.properties.titleTitle": "标题", - "xpack.siem.timeline.properties.unlockDatePickerDescription": "从全局日期选取器解除锁定日期选取器", - "xpack.siem.timeline.properties.unlockDatePickerTooltip": "启用当前查看的页面和您的时间线之间的日期/时间范围同步", - "xpack.siem.timeline.properties.untitledTimelinePlaceholder": "未命名时间线", - "xpack.siem.timeline.protocol": "协议", - "xpack.siem.timeline.rangePicker.oneDay": "1 日", - "xpack.siem.timeline.rangePicker.oneMonth": "1 个月", - "xpack.siem.timeline.rangePicker.oneWeek": "1 周", - "xpack.siem.timeline.rangePicker.oneYear": "1 年", - "xpack.siem.timeline.searchOrFilter.filterDescription": "来自上述数据提供程序的事件按相邻 KQL 进行筛选", - "xpack.siem.timeline.searchOrFilter.filterKqlPlaceholder": "筛选事件", - "xpack.siem.timeline.searchOrFilter.filterKqlSelectedText": "筛选", - "xpack.siem.timeline.searchOrFilter.filterKqlTooltip": "来自上述数据提供程序的事件按此 KQL 进行筛选", - "xpack.siem.timeline.searchOrFilter.filterOrSearchWithKql": "使用 KQL 筛选或搜索", - "xpack.siem.timeline.searchOrFilter.searchDescription": "来自上述数据提供程序的事件与来自相邻 KQL 的结果合并", - "xpack.siem.timeline.searchOrFilter.searchKqlPlaceholder": "搜索事件", - "xpack.siem.timeline.searchOrFilter.searchKqlSelectedText": "搜索", - "xpack.siem.timeline.searchOrFilter.searchKqlTooltip": "来自上述数据提供程序的事件与来自此 KQL 的结果合并", - "xpack.siem.timeline.source": "源", - "xpack.siem.timeline.tcp": "TCP", - "xpack.siem.timeline.typeTooltip": "类型", - "xpack.siem.timelines.allTimelines.panelTitle": "所有时间线", - "xpack.siem.timelines.pageTitle": "时间线", - "xpack.siem.uiSettings.defaultIndexDescription": "

SIEM 应用要从其中搜索事件的 Elasticsearch 索引逗号分隔列表。

", - "xpack.siem.uiSettings.defaultIndexLabel": "默认索引", - "xpack.siem.uncommonProcessTable.hostsTitle": "主机", - "xpack.siem.uncommonProcessTable.lastCommandTitle": "上一命令", - "xpack.siem.uncommonProcessTable.lastUserTitle": "上一用户", - "xpack.siem.uncommonProcessTable.nameTitle": "名称", - "xpack.siem.uncommonProcessTable.numberOfHostsTitle": "主机数目", - "xpack.siem.uncommonProcessTable.numberOfInstances": "实例", - "xpack.siem.uncommonProcessTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", - "xpack.siem.uncommonProcessTable.unit": "{totalCount, plural, =1 {process} other {processes}}", - "xpack.siem.zeek.othDescription": "未看到 SYN,仅中游流量", - "xpack.siem.zeek.rejDescription": "已拒绝连接尝试", - "xpack.siem.zeek.rstoODescription": "连接已建立,发起方已中止(已发送 RST)", - "xpack.siem.zeek.rstosoDescription": "发起方已发送 SYN,后跟 RST,响应方未发送 SYN-ACK", - "xpack.siem.zeek.rstrDescription": "已建立,响应方已中止", - "xpack.siem.zeek.rstrhDescription": "响应方已发送 SYN ACK,后跟 RST,(假设)发起方未发送 SYN", - "xpack.siem.zeek.s0Description": "已看到连接尝试,无答复", - "xpack.siem.zeek.s1Description": "连接已建立,未终止", - "xpack.siem.zeek.s2Description": "连接已建立,已看到发起方的关闭尝试(但没有响应方的答复)", - "xpack.siem.zeek.s3Description": "连接已建立,已看到响应方的关闭尝试(但没有发起方的答复)", - "xpack.siem.zeek.sfDescription": "正常 SYN/FIN 完成", - "xpack.siem.zeek.shDescription": "发起方已发送 SYN,后跟 FIN,响应方未发送 SYN ACK", - "xpack.siem.zeek.shrDescription": "响应方已发送 SYN ACK,后跟 FIN,发起方未发送 SYN", - "xpack.siem.anomaliesTable.table.anomaliesTooltip": "异常表无法通过 SIEM 全局 KQL 搜索进行筛选。", - "xpack.siem.anomaliesTable.table.unit": "{totalCount, plural, =1 {anomaly} other {anomalies}}", - "xpack.siem.clipboard.copy.to.the.clipboard": "复制到剪贴板", - "xpack.siem.components.embeddables.indexPatternsMissingPrompt.errorButtonLabel": "配置索引模式", - "xpack.siem.components.embeddables.indexPatternsMissingPrompt.errorTitle": "未配置所需的索引模式", - "xpack.siem.components.ml.anomaly.errors.anomaliesTableFetchFailureTitle": "异常表提取失败", - "xpack.siem.components.ml.api.errors.networkErrorFailureTitle": "网络错误:", - "xpack.siem.components.ml.api.errors.statusCodeFailureTitle": "状态代码:", - "xpack.siem.components.ml.permissions.errors.machineLearningPermissionsFailureTitle": "Machine Learning 权限错误", - "xpack.siem.components.mlPopup.anomalyDetectionButtonLabel": "异常检测", - "xpack.siem.components.mlPopup.anomalyDetectionDescription": "运行以下任何 Machine Learning 作业以查看该 SIEM 应用程序的所有异常事件。我们提供若干可让您入门的常规检测作业。如果您希望添加自己的定制作业,只需从用于纳入定制作业的 {machineLearning} 应用程序中创建定制作业并使用“SIEM”标记它们。", - "xpack.siem.components.mlPopup.anomalyDetectionTitle": "异常检测设置", - "xpack.siem.components.mlPopup.errors.createJobFailureTitle": "创建作业失败", - "xpack.siem.components.mlPopup.errors.startJobFailureTitle": "启动作业失败", - "xpack.siem.components.mlPopup.hooks.errors.indexPatternFetchFailureTitle": "索引模式提取失败", - "xpack.siem.components.mlPopup.hooks.errors.siemJobFetchFailureTitle": "SIEM 作业提取失败", - "xpack.siem.components.mlPopup.jobsTable.createCustomJobButtonLabel": "创建定制作业", - "xpack.siem.components.mlPopup.jobsTable.jobNameColumn": "作业名称", - "xpack.siem.components.mlPopup.jobsTable.noItemsDescription": "未找到任何 SIEM Machine Learning 作业", - "xpack.siem.components.mlPopup.jobsTable.runJobColumn": "运行作业", - "xpack.siem.components.mlPopup.machineLearningLink": "Machine Learning", - "xpack.siem.components.mlPopup.showingLabel": "显示:{filterResultsLength} 个 {filterResultsLength, plural, one {作业} other {作业}}", - "xpack.siem.components.mlPopup.upgradeButtonLabel": "订阅选项", - "xpack.siem.components.mlPopup.upgradeTitle": "升级 Elastic 白金级", - "xpack.siem.containers.errors.stopJobFailureTitle": "停止作业失败", - "xpack.siem.eventDetails.blank": " ", - "xpack.siem.eventDetails.toggleColumnTooltip": "切换列", - "xpack.siem.eventsViewer.eventsLabel": "事件", - "xpack.siem.eventsViewer.showingLabel": "显示", - "xpack.siem.eventsViewer.unit": "{totalCount, plural, =1 {event} other {events}}", - "xpack.siem.fieldBrowser.toggleColumnTooltip": "切换列", - "xpack.siem.hosts.navigation.allHostsTitle": "所有主机", - "xpack.siem.hosts.navigation.anomaliesTitle": "异常", - "xpack.siem.hosts.navigation.authenticationsTitle": "身份验证", - "xpack.siem.hosts.navigation.eventsTitle": "事件", - "xpack.siem.hosts.navigation.uncommonProcessesTitle": "不常见进程", - "xpack.siem.inspect.modal.indexPatternDescription": "连接到 Elasticsearch 索引的索引模式。可以在“Kibana”>“高级设置”中配置这些索引。", - "xpack.siem.inspect.modal.indexPatternLabel": "索引模式", - "xpack.siem.inspect.modal.queryTimeDescription": "处理查询所花费的时间。不包括发送请求或在浏览器中解析它的时间。", - "xpack.siem.inspect.modal.queryTimeLabel": "查询时间", - "xpack.siem.inspect.modal.reqTimestampDescription": "记录请求启动的时间", - "xpack.siem.inspect.modal.reqTimestampLabel": "请求时间戳", - "xpack.siem.inspect.modal.somethingWentWrongDescription": "抱歉,出现问题。", - "xpack.siem.kpiHosts.hosts.title": "主机", - "xpack.siem.kpiHosts.uniqueIps.destinationChartLabel": "目标", - "xpack.siem.kpiHosts.uniqueIps.destinationUnitLabel": "目标", - "xpack.siem.kpiHosts.uniqueIps.sourceChartLabel": "源", - "xpack.siem.kpiHosts.uniqueIps.sourceUnitLabel": "源", - "xpack.siem.kpiHosts.uniqueIps.title": "唯一 IP", - "xpack.siem.kpiHosts.userAuthentications.failChartLabel": "失败", - "xpack.siem.kpiHosts.userAuthentications.failUnitLabel": "失败", - "xpack.siem.kpiHosts.userAuthentications.successChartLabel": "成功", - "xpack.siem.kpiHosts.userAuthentications.successUnitLabel": "成功", - "xpack.siem.kpiHosts.userAuthentications.title": "用户身份验证", - "xpack.siem.kpiNetwork.dnsQueries.title": "DNS 查询", - "xpack.siem.kpiNetwork.networkEvents.title": "网络事件", - "xpack.siem.kpiNetwork.tlsHandshakes.title": "TLS 握手", - "xpack.siem.kpiNetwork.uniqueFlowIds.title": "唯一流 ID", - "xpack.siem.kpiNetwork.uniquePrivateIps.destinationChartLabel": "目标", - "xpack.siem.kpiNetwork.uniquePrivateIps.destinationUnitLabel": "目标", - "xpack.siem.kpiNetwork.uniquePrivateIps.sourceChartLabel": "源", - "xpack.siem.kpiNetwork.uniquePrivateIps.sourceUnitLabel": "源", - "xpack.siem.kpiNetwork.uniquePrivateIps.title": "唯一专用 IP", - "xpack.siem.ml.score.anomalousEntityTitle": "异常实体", - "xpack.siem.ml.table.timestampTitle": "时间戳", - "xpack.siem.modalAllErrors.close.button": "关闭", - "xpack.siem.modalAllErrors.seeAllErrors.button": "请参阅完整的错误信息", - "xpack.siem.modalAllErrors.title": "您的可视化有错误", - "xpack.siem.networkTopNFlowTable.column.asTitle": "自治系统", - "xpack.siem.networkTopNFlowTable.column.bytesInTitle": "传入字节", - "xpack.siem.networkTopNFlowTable.column.bytesOutTitle": "传出字节", - "xpack.siem.networkTopNFlowTable.column.domainTitle": "域", - "xpack.siem.networkTopNFlowTable.column.IpTitle": "IP", - "xpack.siem.networkTopNFlowTable.destinationIps": "目标 IP", - "xpack.siem.networkTopNFlowTable.flows": "Flows", - "xpack.siem.networkTopNFlowTable.sourceIps": "源 IP", - "xpack.siem.paginatedTable.rowsButtonLabel": "每页行数", - "xpack.siem.paginatedTable.showingSubtitle": "显示", - "xpack.siem.paginatedTable.tooManyResultsToastText": "缩减您的查询范围,以更好地筛选结果", - "xpack.siem.paginatedTable.tooManyResultsToastTitle": " - 结果过多", - "xpack.siem.timeline.callOut.unauthorized.message.description": "您需要在 SIEM 内自动保存时间线的权限,但您可以继续使用该时间线搜索和筛选安全事件", - "xpack.siem.uiSettings.defaultAnomalyScoreDescription": "

在显示异常之前要超过的默认异常分数阈值。

有效值:0 到 100。

", - "xpack.siem.uiSettings.defaultAnomalyScoreLabel": "默认异常阈值", - "xpack.siem.uiSettings.defaultRefreshIntervalDescription": "

SIEM 时间筛选的默认刷新时间间隔(毫秒)。

", - "xpack.siem.uiSettings.defaultRefreshIntervalLabel": "时间筛选刷新时间间隔", - "xpack.siem.uiSettings.defaultTimeRangeDescription": "

SIEM 时间筛选中的默认时间期间。

", - "xpack.siem.uiSettings.defaultTimeRangeLabel": "时间筛选默认值", - "xpack.siem.host.details.overview.maxAnomalyScoreByJobTitle": "最大异常分数(按作业)", - "xpack.siem.ml.score.anomalyJobTitle": "作业", - "xpack.siem.ml.table.detectorTitle": "作业名称", - "xpack.siem.ml.table.hostNameTitle": "主机名", - "xpack.siem.ml.table.influencedByTitle": "影响因素", - "xpack.siem.ml.table.scoreTitle": "异常分数", - "xpack.siem.network.ipDetails.ipOverview.maxAnomalyScoreByJobTitle": "最大异常分数(按作业)", - "xpack.siem.chart.dataAllValuesZerosTitle": "所有值返回零", - "xpack.siem.components.embeddables.embeddedMap.destinationLayerLabel": "目标点", - "xpack.siem.components.embeddables.embeddedMap.embeddablePanelTitle": "源 -> 目标点对点地图", - "xpack.siem.components.embeddables.embeddedMap.errorConfiguringEmbeddableApiTitle": "配置可嵌入 API 时出错", - "xpack.siem.components.embeddables.embeddedMap.errorCreatingMapEmbeddableTitle": "创建地图可嵌入对象时出错", - "xpack.siem.components.embeddables.embeddedMap.lineLayerLabel": "折线图", - "xpack.siem.components.embeddables.embeddedMap.sourceLayerLabel": "源点", - "xpack.siem.components.embeddables.mapToolTip.errorTitle": "加载地图特征时出错", - "xpack.siem.components.embeddables.mapToolTip.filterForValueHoverAction": "筛留值", - "xpack.siem.components.embeddables.mapToolTip.footerLabel": "{currentFeature} / {totalFeatures} {totalFeatures, plural, =1 {feature} other {features}}", - "xpack.siem.components.embeddables.mapToolTip.lineContent.destinationLabel": "目标", - "xpack.siem.components.embeddables.mapToolTip.lineContent.sourceLabel": "源", - "xpack.siem.components.embeddables.mapToolTip.pointContent.asnTitle": "ASN", - "xpack.siem.components.embeddables.mapToolTip.pointContent.destinationDomainTitle": "目标域", - "xpack.siem.components.embeddables.mapToolTip.pointContent.destinationIPTitle": "目标 IP", - "xpack.siem.components.embeddables.mapToolTip.pointContent.hostTitle": "主机", - "xpack.siem.components.embeddables.mapToolTip.pointContent.locationTitle": "位置", - "xpack.siem.components.embeddables.mapToolTip.pointContent.sourceDomainTitle": "源域", - "xpack.siem.components.embeddables.mapToolTip.pointContent.sourceIPTitle": "源 IP", - "xpack.siem.components.mlPopover.jobsTable.filters.groupsLabel": "组", - "xpack.siem.components.mlPopover.jobsTable.filters.noGroupsAvailableDescription": "没有可用的组", - "xpack.siem.components.mlPopover.jobsTable.filters.searchFilterPlaceholder": "例如 rare_process_linux", - "xpack.siem.components.mlPopover.jobsTable.filters.showAllJobsLabel": "Elastic 作业", - "xpack.siem.components.mlPopover.jobsTable.filters.showSiemJobsLabel": "定制作业", - "xpack.siem.components.mlPopup.cloudLink": "云部署", - "xpack.siem.components.mlPopup.jobsTable.tagsColumn": "组", - "xpack.siem.components.mlPopup.licenseButtonLabel": "管理许可", - "xpack.siem.components.mlPopup.moduleNotCompatibleTitle": "{incompatibleJobCount} {incompatibleJobCount, plural, =1 {job} other {jobs}}当前不可用。", - "xpack.siem.eventsOverTime.eventCountFrequencyByActionTitle": "事件计数 - 按操作", - "xpack.siem.eventsOverTime.showing": "显示", - "xpack.siem.eventsOverTime.unit": "{totalCount, plural, =1 {event} other {events}}", - "xpack.siem.flyout.button.text": "时间线", - "xpack.siem.network.navigation.anomaliesTitle": "异常", - "xpack.siem.network.navigation.dnsTitle": "DNS", - "xpack.siem.network.navigation.flowsTitle": "Flows", - "xpack.siem.network.navigation.tlsTitle": "TLS", - "xpack.siem.networkTopCountriesTable.column.bytesInTitle": "传入字节", - "xpack.siem.networkTopCountriesTable.column.bytesOutTitle": "传出字节", - "xpack.siem.networkTopCountriesTable.column.countryTitle": "国家/地区", - "xpack.siem.networkTopCountriesTable.column.destinationIps": "目标 IP", - "xpack.siem.networkTopCountriesTable.column.flows": "Flows", - "xpack.siem.networkTopCountriesTable.column.sourceIps": "源 IP", - "xpack.siem.networkTopCountriesTable.heading.destinationCountries": "目标国家/地区", - "xpack.siem.networkTopCountriesTable.heading.sourceCountries": "源国家/地区", - "xpack.siem.networkTopCountriesTable.heading.unit": "{totalCount, plural, =1 {Country} other {Countries}}", - "xpack.siem.networkTopCountriesTable.rows": "{numRows} {numRows, plural, =0 {rows} =1 {row} other {rows}}", - "xpack.siem.overview.endgameDnsTitle": "Endgame DNS", - "xpack.siem.overview.endgameFileTitle": "Endgame 文件", - "xpack.siem.overview.endgameImageLoadTitle": "Endgame 图像加载", - "xpack.siem.overview.endgameNetworkTitle": "Endgame 网络", - "xpack.siem.overview.endgameProcessTitle": "Endgame 进程", - "xpack.siem.overview.endgameRegistryTitle": "Endgame 注册表", - "xpack.siem.overview.endgameSecurityTitle": "Endgame 安全", - "xpack.siem.system.acceptedAConnectionViaDescription": "已接受连接,通过", - "xpack.siem.system.createdFileDescription": "已创建文件", - "xpack.siem.system.deletedFileDescription": "已删除文件", - "xpack.siem.system.disconnectedViaDescription": "已断开连接,通过", - "xpack.siem.system.terminatedProcessDescription": "已终止进程", - "xpack.siem.system.viaDescription": "通过", - "xpack.siem.system.viaParentProcessDescription": "通过父进程", - "xpack.siem.system.withExitCodeDescription": "退出代码为", - "xpack.siem.timeline.body.renderers.dns.askedForDescription": "请求过", - "xpack.siem.timeline.body.renderers.dns.responseCodeDescription": "响应代码:", - "xpack.siem.timeline.body.renderers.dns.viaDescription": "通过", - "xpack.siem.timeline.body.renderers.dns.whichResolvedToDescription": ",其已解析为", - "xpack.siem.timeline.body.renderers.dns.withQuestionTypeDescription": ",问题类型为", - "xpack.siem.timeline.body.renderers.endgame.aLoginWasAttemptedUsingExplicitCredentialsDescription": "已使用显式凭据尝试登录", - "xpack.siem.timeline.body.renderers.endgame.asRequestedBySubjectDescription": ",如主语所请求", - "xpack.siem.timeline.body.renderers.endgame.loggedOffDescription": "已注销", - "xpack.siem.timeline.body.renderers.endgame.logonTypeBatchDescription": "批量", - "xpack.siem.timeline.body.renderers.endgame.logonTypeCachedInteractiveDescription": "缓存交互", - "xpack.siem.timeline.body.renderers.endgame.logonTypeInteractiveDescription": "交互", - "xpack.siem.timeline.body.renderers.endgame.logonTypeNetworkCleartextDescription": "网络明文", - "xpack.siem.timeline.body.renderers.endgame.logonTypeNetworkDescription": "网络", - "xpack.siem.timeline.body.renderers.endgame.logonTypeNewCredentialsDescription": "新凭据", - "xpack.siem.timeline.body.renderers.endgame.logonTypeRemoteInteractiveDescription": "远程交互", - "xpack.siem.timeline.body.renderers.endgame.logonTypeServiceDescription": "服务", - "xpack.siem.timeline.body.renderers.endgame.logonTypeUnlockDescription": "解锁", - "xpack.siem.timeline.body.renderers.endgame.subjectLogonIdDescription": "主语登录 ID", - "xpack.siem.timeline.body.renderers.endgame.successfullyLoggedInDescription": "已成功登录", - "xpack.siem.timeline.body.renderers.endgame.targetLogonIdDescription": "目标登录 ID", - "xpack.siem.timeline.body.renderers.endgame.toDescription": "到", - "xpack.siem.timeline.body.renderers.endgame.usingLogonTypeDescription": "使用登录类型", - "xpack.siem.timeline.body.renderers.endgame.viaDescription": "通过", - "xpack.siem.timeline.body.renderers.endgame.withSpecialPrivilegesDescription": "使用特殊权限,", - "xpack.siem.components.mlPopup.upgradeDescription": "要访问 SIEM 的异常检测功能,必须将您的许可更新到白金级、开始 30 天免费试用或在 AWS、GCP 或 Azurein 实施{cloudLink}。然后便可以运行 Machine Learning 作业并查看异常。", - "xpack.snapshotRestore.addRepository.breadcrumbTitle": "添加存储库", - "xpack.snapshotRestore.addRepository.savingRepositoryErrorTitle": "无法注册新存储库", - "xpack.snapshotRestore.addRepositoryButtonLabel": "注册存储库", - "xpack.snapshotRestore.addRepositoryTitle": "注册存储库", - "xpack.snapshotRestore.appName": "快照存储库", - "xpack.snapshotRestore.dataPlaceholderLabel": "-", - "xpack.snapshotRestore.deleteRepository.confirmModal.cancelButtonLabel": "取消", - "xpack.snapshotRestore.deleteRepository.confirmModal.confirmMultipleButtonLabel": "移除存储库", - "xpack.snapshotRestore.deleteRepository.confirmModal.confirmSingleButtonLabel": "移除存储库", - "xpack.snapshotRestore.deleteRepository.confirmModal.deleteMultipleDescription": "这些存储库中的快照仍将存在,但 Elasticsearch 将无法访问它们。调整使用这些存储库的策略,以防止排定的快照失败。", - "xpack.snapshotRestore.deleteRepository.confirmModal.deleteMultipleListDescription": "您即将移除以下存储库:", - "xpack.snapshotRestore.deleteRepository.confirmModal.deleteMultipleTitle": "移除 {count} 个存储库", - "xpack.snapshotRestore.deleteRepository.confirmModal.deleteSingleDescription": "此存储库中的快照仍将存在,但 Elasticsearch 将无法访问它们。调整使用此存储库的策略,以防止排定的快照失败。", - "xpack.snapshotRestore.deleteRepository.confirmModal.deleteSingleTitle": "移除存储库“{name}”?", - "xpack.snapshotRestore.deleteRepository.errorMultipleNotificationTitle": "移除 {count} 个存储库时出错", - "xpack.snapshotRestore.deleteRepository.errorSingleNotificationTitle": "移除存储库“{name}”时出错", - "xpack.snapshotRestore.deleteRepository.successMultipleNotificationTitle": "已移除 {count} 个存储库", - "xpack.snapshotRestore.deleteRepository.successSingleNotificationTitle": "已移除存储库“{name}”", - "xpack.snapshotRestore.editRepository.breadcrumbTitle": "编辑存储库", - "xpack.snapshotRestore.editRepository.loadingRepositoryDescription": "正在加载存储库详情……", - "xpack.snapshotRestore.editRepository.loadingRepositoryErrorTitle": "加载存储库详情时出错", - "xpack.snapshotRestore.editRepository.managedRepositoryWarningTitle": "这是托管存储库。更改此存储库可能会影响使用它的其他系统。请谨慎操作。", - "xpack.snapshotRestore.editRepository.repositoryNotFoundErrorMessage": "存储库“{name}”不存在。", - "xpack.snapshotRestore.editRepository.savingRepositoryErrorTitle": "无法保存存储库", - "xpack.snapshotRestore.editRepositoryTitle": "编辑存储库", - "xpack.snapshotRestore.emptyPrompt.noSnapshotsDocLinkText": "了解如何创建快照", - "xpack.snapshotRestore.home.breadcrumbTitle": "快照存储库", - "xpack.snapshotRestore.home.repositoriesTabTitle": "存储库", - "xpack.snapshotRestore.home.snapshotRestoreDescription": "使用存储库存储 Elasticsearch 索引和集群的备份。", - "xpack.snapshotRestore.home.snapshotRestoreDocsLinkText": "快照文档", - "xpack.snapshotRestore.home.snapshotRestoreTitle": "快照存储库", - "xpack.snapshotRestore.home.snapshotsTabTitle": "快照", - "xpack.snapshotRestore.repositoryDetails.closeButtonLabel": "关闭", - "xpack.snapshotRestore.repositoryDetails.editButtonLabel": "编辑", - "xpack.snapshotRestore.repositoryDetails.genericSettingsDescription": "存储库“{name}”的只读设置", - "xpack.snapshotRestore.repositoryDetails.loadingRepositoryDescription": "正在加载存储库……", - "xpack.snapshotRestore.repositoryDetails.loadingRepositoryErrorTitle": "加载存储库时出错", - "xpack.snapshotRestore.repositoryDetails.managedRepositoryWarningTitle": "这是其他系统使用的托管存储库。您所做的任何更改可能会影响这些系统的运行方式。", - "xpack.snapshotRestore.repositoryDetails.noSnapshotInformationDescription": "无快照信息", - "xpack.snapshotRestore.repositoryDetails.removeButtonLabel": "删除", - "xpack.snapshotRestore.repositoryDetails.removeManagedRepositoryButtonTitle": "您无法删除托管存储库。", - "xpack.snapshotRestore.repositoryDetails.repositoryNotFoundErrorMessage": "存储库“{name}”不存在。", - "xpack.snapshotRestore.repositoryDetails.repositoryTypeDocLink": "存储库文档", - "xpack.snapshotRestore.repositoryDetails.settingsTitle": "设置", - "xpack.snapshotRestore.repositoryDetails.snapshotsDescription": "找到 {count} 个 {count, plural, one {快照} other {快照}}", - "xpack.snapshotRestore.repositoryDetails.snapshotsTitle": "快照", - "xpack.snapshotRestore.repositoryDetails.typeAzure.basePathLabel": "基路径", - "xpack.snapshotRestore.repositoryDetails.typeAzure.chunkSizeLabel": "块大小", - "xpack.snapshotRestore.repositoryDetails.typeAzure.clientLabel": "客户端", - "xpack.snapshotRestore.repositoryDetails.typeAzure.compressLabel": "快照压缩", - "xpack.snapshotRestore.repositoryDetails.typeAzure.containerLabel": "容器", - "xpack.snapshotRestore.repositoryDetails.typeAzure.locationModeLabel": "位置模式", - "xpack.snapshotRestore.repositoryDetails.typeAzure.maxRestoreBytesLabel": "每秒最大还原字节数", - "xpack.snapshotRestore.repositoryDetails.typeAzure.maxSnapshotBytesLabel": "每秒最大快照字节数", - "xpack.snapshotRestore.repositoryDetails.typeAzure.readonlyLabel": "只读", - "xpack.snapshotRestore.repositoryDetails.typeFS.chunkSizeLabel": "块大小", - "xpack.snapshotRestore.repositoryDetails.typeFS.compressLabel": "快照压缩", - "xpack.snapshotRestore.repositoryDetails.typeFS.locationLabel": "位置", - "xpack.snapshotRestore.repositoryDetails.typeFS.maxRestoreBytesLabel": "每秒最大还原字节数", - "xpack.snapshotRestore.repositoryDetails.typeFS.maxSnapshotBytesLabel": "每秒最大快照字节数", - "xpack.snapshotRestore.repositoryDetails.typeFS.readonlyLabel": "只读", - "xpack.snapshotRestore.repositoryDetails.typeGCS.basePathLabel": "基路径", - "xpack.snapshotRestore.repositoryDetails.typeGCS.bucketLabel": "存储桶", - "xpack.snapshotRestore.repositoryDetails.typeGCS.chunkSizeLabel": "块大小", - "xpack.snapshotRestore.repositoryDetails.typeGCS.clientLabel": "客户端", - "xpack.snapshotRestore.repositoryDetails.typeGCS.compressLabel": "快照压缩", - "xpack.snapshotRestore.repositoryDetails.typeGCS.maxRestoreBytesLabel": "每秒最大还原字节数", - "xpack.snapshotRestore.repositoryDetails.typeGCS.maxSnapshotBytesLabel": "每秒最大快照字节数", - "xpack.snapshotRestore.repositoryDetails.typeGCS.readonlyLabel": "只读", - "xpack.snapshotRestore.repositoryDetails.typeHDFS.chunkSizeLabel": "块大小", - "xpack.snapshotRestore.repositoryDetails.typeHDFS.compressLabel": "快照压缩", - "xpack.snapshotRestore.repositoryDetails.typeHDFS.loadDefaultsLabel": "加载默认值", - "xpack.snapshotRestore.repositoryDetails.typeHDFS.maxRestoreBytesLabel": "每秒最大还原字节数", - "xpack.snapshotRestore.repositoryDetails.typeHDFS.maxSnapshotBytesLabel": "每秒最大快照字节数", - "xpack.snapshotRestore.repositoryDetails.typeHDFS.pathLabel": "路径", - "xpack.snapshotRestore.repositoryDetails.typeHDFS.readonlyLabel": "只读", - "xpack.snapshotRestore.repositoryDetails.typeHDFS.securityPrincipalLabel": "安全主体", - "xpack.snapshotRestore.repositoryDetails.typeHDFS.uriLabel": "URI", - "xpack.snapshotRestore.repositoryDetails.typeReadonly.urlLabel": "URL", - "xpack.snapshotRestore.repositoryDetails.typeS3.basePathLabel": "基路径", - "xpack.snapshotRestore.repositoryDetails.typeS3.bucketLabel": "存储桶", - "xpack.snapshotRestore.repositoryDetails.typeS3.bufferSizeLabel": "缓冲区大小", - "xpack.snapshotRestore.repositoryDetails.typeS3.cannedAclLabel": "标准 ACL", - "xpack.snapshotRestore.repositoryDetails.typeS3.chunkSizeLabel": "块大小", - "xpack.snapshotRestore.repositoryDetails.typeS3.clientLabel": "客户端", - "xpack.snapshotRestore.repositoryDetails.typeS3.compressLabel": "快照压缩", - "xpack.snapshotRestore.repositoryDetails.typeS3.maxRestoreBytesLabel": "每秒最大还原字节数", - "xpack.snapshotRestore.repositoryDetails.typeS3.maxSnapshotBytesLabel": "每秒最大快照字节数", - "xpack.snapshotRestore.repositoryDetails.typeS3.readonlyLabel": "只读", - "xpack.snapshotRestore.repositoryDetails.typeS3.serverSideEncryptionLabel": "服务器端加密", - "xpack.snapshotRestore.repositoryDetails.typeS3.storageClassLabel": "存储类", - "xpack.snapshotRestore.repositoryDetails.typeTitle": "存储库类型", - "xpack.snapshotRestore.repositoryDetails.verificationDetailsTitle": "详情", - "xpack.snapshotRestore.repositoryDetails.verificationTitle": "验证状态", - "xpack.snapshotRestore.repositoryDetails.verifyButtonLabel": "验证存储库", - "xpack.snapshotRestore.repositoryDetails.zeroSnapshotsDescription": "存储库没有快照", - "xpack.snapshotRestore.repositoryFor.typeFS.locationDescription": "必须在所有主节点和数据节点上的 {settingKey} 设置中注册该位置。", - "xpack.snapshotRestore.repositoryForm.backButtonLabel": "上一步", - "xpack.snapshotRestore.repositoryForm.errorUnknownRepositoryTypesMessage": "存储库类型“{type}”不受支持。", - "xpack.snapshotRestore.repositoryForm.errorUnknownRepositoryTypesTitle": "未知的存储库类型", - "xpack.snapshotRestore.repositoryForm.fields.cloudTypeDescription": "Elasticsearch 为定制存储库提供核心插件。{docLink}", - "xpack.snapshotRestore.repositoryForm.fields.defaultTypeDescription": "Elasticsearch 支持文件系统和只读 URL 存储库。其他类型需要插件。{docLink}", - "xpack.snapshotRestore.repositoryForm.fields.nameDescription": "存储库的唯一名称。", - "xpack.snapshotRestore.repositoryForm.fields.nameDescriptionTitle": "存储库名称", - "xpack.snapshotRestore.repositoryForm.fields.nameLabel": "名称", - "xpack.snapshotRestore.repositoryForm.fields.settingsTitle": "{repositoryName} 设置", - "xpack.snapshotRestore.repositoryForm.fields.sourceOnlyDescription": "创建仅限于源的快照,其最多占用 50% 空间。{docLink}", - "xpack.snapshotRestore.repositoryForm.fields.sourceOnlyDescriptionTitle": "仅限于源的快照", - "xpack.snapshotRestore.repositoryForm.fields.sourceOnlyDocLinkText": "详细了解仅限于源的存储库。", - "xpack.snapshotRestore.repositoryForm.fields.sourceOnlyLabel": "仅限于源的快照", - "xpack.snapshotRestore.repositoryForm.fields.typeDescriptionTitle": "存储库类型", - "xpack.snapshotRestore.repositoryForm.fields.typeDocsLinkText": "了解详情", - "xpack.snapshotRestore.repositoryForm.fields.typePluginsDocLinkText": "详细了解插件。", - "xpack.snapshotRestore.repositoryForm.loadingRepositoryTypesDescription": "正在加载存储库类型……", - "xpack.snapshotRestore.repositoryForm.loadingRepositoryTypesErrorMessage": "加载存储库类型时出错", - "xpack.snapshotRestore.repositoryForm.nextButtonLabel": "下一个", - "xpack.snapshotRestore.repositoryForm.noRepositoryTypesErrorMessage": "您可以安装插件以启用不同的存储库类型。{docLink}", - "xpack.snapshotRestore.repositoryForm.noRepositoryTypesErrorTitle": "没有可用的存储库类型", - "xpack.snapshotRestore.repositoryForm.registerButtonLabel": "注册", - "xpack.snapshotRestore.repositoryForm.repositoryTypeDocLink": "{repositoryType} 存储库文档", - "xpack.snapshotRestore.repositoryForm.saveButtonLabel": "保存", - "xpack.snapshotRestore.repositoryForm.savingButtonLabel": "正在保存……", - "xpack.snapshotRestore.repositoryForm.typeAzure.basePathDescription": "存储库数据的容器路径。", - "xpack.snapshotRestore.repositoryForm.typeAzure.basePathLabel": "基路径", - "xpack.snapshotRestore.repositoryForm.typeAzure.basePathTitle": "基路径", - "xpack.snapshotRestore.repositoryForm.typeAzure.chunkSizeDescription": "拍取快照时,将文件拆分成更小的单位。", - "xpack.snapshotRestore.repositoryForm.typeAzure.chunkSizeLabel": "块大小", - "xpack.snapshotRestore.repositoryForm.typeAzure.chunkSizeTitle": "块大小", - "xpack.snapshotRestore.repositoryForm.typeAzure.clientDescription": "Azure 客户端的名称。", - "xpack.snapshotRestore.repositoryForm.typeAzure.clientLabel": "客户端", - "xpack.snapshotRestore.repositoryForm.typeAzure.clientTitle": "客户端", - "xpack.snapshotRestore.repositoryForm.typeAzure.compressDescription": "压缩快照的索引映射和设置文件。数据文件未压缩。", - "xpack.snapshotRestore.repositoryForm.typeAzure.compressLabel": "压缩快照", - "xpack.snapshotRestore.repositoryForm.typeAzure.compressTitle": "快照压缩", - "xpack.snapshotRestore.repositoryForm.typeAzure.containerDescription": "要用于快照的 Azure 容器的名称。", - "xpack.snapshotRestore.repositoryForm.typeAzure.containerLabel": "容器", - "xpack.snapshotRestore.repositoryForm.typeAzure.containerTitle": "容器", - "xpack.snapshotRestore.repositoryForm.typeAzure.locationModeDescription": "主要位置或辅助位置。如果为辅助位置,则只读为 true。", - "xpack.snapshotRestore.repositoryForm.typeAzure.locationModeLabel": "位置模式", - "xpack.snapshotRestore.repositoryForm.typeAzure.locationModeTitle": "位置模式", - "xpack.snapshotRestore.repositoryForm.typeAzure.maxRestoreBytesDescription": "每个节点的快照还原速率。", - "xpack.snapshotRestore.repositoryForm.typeAzure.maxRestoreBytesLabel": "每秒最大还原字节数", - "xpack.snapshotRestore.repositoryForm.typeAzure.maxRestoreBytesTitle": "每秒最大还原字节数", - "xpack.snapshotRestore.repositoryForm.typeAzure.maxSnapshotBytesDescription": "为每个节点创建快照的速率。", - "xpack.snapshotRestore.repositoryForm.typeAzure.maxSnapshotBytesLabel": "每秒最大快照字节数", - "xpack.snapshotRestore.repositoryForm.typeAzure.maxSnapshotBytesTitle": "每秒最大快照字节数", - "xpack.snapshotRestore.repositoryForm.typeAzure.readonlyDescription": "仅一个集群应对此存储库有写权限。所有其他集群应为只读。", - "xpack.snapshotRestore.repositoryForm.typeAzure.readonlyLabel": "只读存储库", - "xpack.snapshotRestore.repositoryForm.typeAzure.readonlyTitle": "只读", - "xpack.snapshotRestore.repositoryForm.typeFS.chunkSizeDescription": "拍取快照时,将文件拆分成更小的单位。", - "xpack.snapshotRestore.repositoryForm.typeFS.chunkSizeLabel": "块大小", - "xpack.snapshotRestore.repositoryForm.typeFS.chunkSizeTitle": "块大小", - "xpack.snapshotRestore.repositoryForm.typeFS.compressDescription": "压缩快照的索引映射和设置文件。数据文件未压缩。", - "xpack.snapshotRestore.repositoryForm.typeFS.compressLabel": "压缩快照", - "xpack.snapshotRestore.repositoryForm.typeFS.compressTitle": "快照压缩", - "xpack.snapshotRestore.repositoryForm.typeFS.locationLabel": "位置(必填)", - "xpack.snapshotRestore.repositoryForm.typeFS.locationTitle": "文件系统位置", - "xpack.snapshotRestore.repositoryForm.typeFS.maxRestoreBytesDescription": "每个节点的快照还原速率。", - "xpack.snapshotRestore.repositoryForm.typeFS.maxRestoreBytesLabel": "每秒最大还原字节数", - "xpack.snapshotRestore.repositoryForm.typeFS.maxRestoreBytesTitle": "每秒最大还原字节数", - "xpack.snapshotRestore.repositoryForm.typeFS.maxSnapshotBytesDescription": "为每个节点创建快照的速率。", - "xpack.snapshotRestore.repositoryForm.typeFS.maxSnapshotBytesLabel": "每秒最大快照字节数", - "xpack.snapshotRestore.repositoryForm.typeFS.maxSnapshotBytesTitle": "每秒最大快照字节数", - "xpack.snapshotRestore.repositoryForm.typeFS.readonlyDescription": "仅一个集群应对此存储库有写权限。所有其他集群应为只读。", - "xpack.snapshotRestore.repositoryForm.typeFS.readonlyLabel": "只读存储库", - "xpack.snapshotRestore.repositoryForm.typeFS.readonlyTitle": "只读", - "xpack.snapshotRestore.repositoryForm.typeGCS.basePathDescription": "存储库数据的存储桶路径。", - "xpack.snapshotRestore.repositoryForm.typeGCS.basePathLabel": "基路径", - "xpack.snapshotRestore.repositoryForm.typeGCS.basePathTitle": "基路径", - "xpack.snapshotRestore.repositoryForm.typeGCS.bucketDescription": "要用于快照的 Google Cloud Storage 存储桶的名称。", - "xpack.snapshotRestore.repositoryForm.typeGCS.bucketLabel": "存储桶(必填)", - "xpack.snapshotRestore.repositoryForm.typeGCS.bucketTitle": "存储桶", - "xpack.snapshotRestore.repositoryForm.typeGCS.chunkSizeDescription": "拍取快照时,将文件拆分成更小的单位。", - "xpack.snapshotRestore.repositoryForm.typeGCS.chunkSizeLabel": "块大小", - "xpack.snapshotRestore.repositoryForm.typeGCS.chunkSizeTitle": "块大小", - "xpack.snapshotRestore.repositoryForm.typeGCS.clientDescription": "Google Cloud Storage 客户端的名称。", - "xpack.snapshotRestore.repositoryForm.typeGCS.clientLabel": "客户端", - "xpack.snapshotRestore.repositoryForm.typeGCS.clientTitle": "客户端", - "xpack.snapshotRestore.repositoryForm.typeGCS.compressDescription": "压缩快照的索引映射和设置文件。数据文件未压缩。", - "xpack.snapshotRestore.repositoryForm.typeGCS.compressLabel": "压缩快照", - "xpack.snapshotRestore.repositoryForm.typeGCS.compressTitle": "压缩快照", - "xpack.snapshotRestore.repositoryForm.typeGCS.maxRestoreBytesDescription": "每个节点的快照还原速率。", - "xpack.snapshotRestore.repositoryForm.typeGCS.maxRestoreBytesLabel": "每秒最大还原字节数", - "xpack.snapshotRestore.repositoryForm.typeGCS.maxRestoreBytesTitle": "每秒最大还原字节数", - "xpack.snapshotRestore.repositoryForm.typeGCS.maxSnapshotBytesDescription": "为每个节点创建快照的速率。", - "xpack.snapshotRestore.repositoryForm.typeGCS.maxSnapshotBytesLabel": "每秒最大快照字节数", - "xpack.snapshotRestore.repositoryForm.typeGCS.maxSnapshotBytesTitle": "每秒最大快照字节数", - "xpack.snapshotRestore.repositoryForm.typeGCS.readonlyDescription": "仅一个集群应对此存储库有写权限。所有其他集群应为只读。", - "xpack.snapshotRestore.repositoryForm.typeGCS.readonlyLabel": "只读存储库", - "xpack.snapshotRestore.repositoryForm.typeGCS.readonlyTitle": "只读", - "xpack.snapshotRestore.repositoryForm.typeHDFS.chunkSizeDescription": "拍取快照时,将文件拆分成更小的单位。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.chunkSizeLabel": "块大小", - "xpack.snapshotRestore.repositoryForm.typeHDFS.chunkSizeTitle": "块大小", - "xpack.snapshotRestore.repositoryForm.typeHDFS.compressDescription": "压缩快照的索引映射和设置文件。数据文件未压缩。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.compressLabel": "压缩快照", - "xpack.snapshotRestore.repositoryForm.typeHDFS.compressTitle": "快照压缩", - "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationAriaLabel": "HDFS 存储桶“{name}”的其他配置", - "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationDescription": "要添加到 Hadoop 配置的其他 JSON 格式配置参数。仅会识别 Hadoop core 和 HDFS 文件的面向客户端的属性。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationFormatError": "JSON 格式无效", - "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationKeyDescription": "键的格式应为 {confKeyFormat}。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationLabel": "配置", - "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationTitle": "配置", - "xpack.snapshotRestore.repositoryForm.typeHDFS.loadDefaultsDescription": "加载默认的 Hadoop 配置。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.loadDefaultsLabel": "加载默认值", - "xpack.snapshotRestore.repositoryForm.typeHDFS.loadDefaultsTitle": "加载默认值", - "xpack.snapshotRestore.repositoryForm.typeHDFS.maxRestoreBytesDescription": "每个节点的快照还原速率。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.maxRestoreBytesLabel": "每秒最大还原字节数", - "xpack.snapshotRestore.repositoryForm.typeHDFS.maxRestoreBytesTitle": "每秒最大还原字节数", - "xpack.snapshotRestore.repositoryForm.typeHDFS.maxSnapshotBytesDescription": "为每个节点创建快照的速率。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.maxSnapshotBytesLabel": "每秒最大快照字节数", - "xpack.snapshotRestore.repositoryForm.typeHDFS.maxSnapshotBytesTitle": "每秒最大快照字节数", - "xpack.snapshotRestore.repositoryForm.typeHDFS.pathDescription": "存储数据的文件路径。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.pathLabel": "路径(必填)", - "xpack.snapshotRestore.repositoryForm.typeHDFS.pathTitle": "路径", - "xpack.snapshotRestore.repositoryForm.typeHDFS.readonlyDescription": "仅一个集群应对此存储库有写权限。所有其他集群应为只读。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.readonlyLabel": "只读存储库", - "xpack.snapshotRestore.repositoryForm.typeHDFS.readonlyTitle": "只读", - "xpack.snapshotRestore.repositoryForm.typeHDFS.securityPrincipalDescription": "连接到安全 HDFS 集群时要使用的 Kerberos 主体。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.securityPrincipalLabel": "安全主体", - "xpack.snapshotRestore.repositoryForm.typeHDFS.securityPrincipalTitle": "安全主体", - "xpack.snapshotRestore.repositoryForm.typeHDFS.uriDescription": "HDFS 的 URI 地址。", - "xpack.snapshotRestore.repositoryForm.typeHDFS.uriLabel": "URI(必填)", - "xpack.snapshotRestore.repositoryForm.typeHDFS.uriTitle": "URI", - "xpack.snapshotRestore.repositoryForm.typeReadonly.urlDescription": "快照的位置。", - "xpack.snapshotRestore.repositoryForm.typeReadonly.urlFilePathDescription": "必须在 {settingKey} 设置中注册此文件位置。", - "xpack.snapshotRestore.repositoryForm.typeReadonly.urlLabel": "路径(必填)", - "xpack.snapshotRestore.repositoryForm.typeReadonly.urlSchemeLabel": "方案", - "xpack.snapshotRestore.repositoryForm.typeReadonly.urlTitle": "URL", - "xpack.snapshotRestore.repositoryForm.typeReadonly.urlWhitelistDescription": "必须在 {settingKey} 设置中注册此 URL。", - "xpack.snapshotRestore.repositoryForm.typeS3.basePathDescription": "存储库数据的存储桶路径。", - "xpack.snapshotRestore.repositoryForm.typeS3.basePathLabel": "基路径", - "xpack.snapshotRestore.repositoryForm.typeS3.basePathTitle": "基路径", - "xpack.snapshotRestore.repositoryForm.typeS3.bucketDescription": "要用于快照的 AWS S3 存储桶的名称。", - "xpack.snapshotRestore.repositoryForm.typeS3.bucketLabel": "存储桶(必填)", - "xpack.snapshotRestore.repositoryForm.typeS3.bucketTitle": "存储桶", - "xpack.snapshotRestore.repositoryForm.typeS3.bufferSizeDescription": "超过此最小阈值后,S3 存储库将使用 AWS 分段上传 API 将块拆分成多个部分,并分别使用请求上传各个部分。", - "xpack.snapshotRestore.repositoryForm.typeS3.bufferSizeLabel": "缓冲区大小", - "xpack.snapshotRestore.repositoryForm.typeS3.bufferSizeTitle": "缓冲区大小", - "xpack.snapshotRestore.repositoryForm.typeS3.cannedAclDescription": "要添加到新 S3 存储库和对象的标准 ACL。", - "xpack.snapshotRestore.repositoryForm.typeS3.cannedAclLabel": "标准 ACL", - "xpack.snapshotRestore.repositoryForm.typeS3.cannedAclTitle": "标准 ACL", - "xpack.snapshotRestore.repositoryForm.typeS3.chunkSizeDescription": "拍取快照时,将文件拆分成更小的单位。", - "xpack.snapshotRestore.repositoryForm.typeS3.chunkSizeLabel": "块大小", - "xpack.snapshotRestore.repositoryForm.typeS3.chunkSizeTitle": "块大小", - "xpack.snapshotRestore.repositoryForm.typeS3.clientDescription": "AWS S3 客户端的名称。", - "xpack.snapshotRestore.repositoryForm.typeS3.clientLabel": "客户端", - "xpack.snapshotRestore.repositoryForm.typeS3.clientTitle": "客户端", - "xpack.snapshotRestore.repositoryForm.typeS3.compressDescription": "压缩快照的索引映射和设置文件。数据文件未压缩。", - "xpack.snapshotRestore.repositoryForm.typeS3.compressLabel": "压缩快照", - "xpack.snapshotRestore.repositoryForm.typeS3.compressTitle": "快照压缩", - "xpack.snapshotRestore.repositoryForm.typeS3.maxRestoreBytesDescription": "每个节点的快照还原速率。", - "xpack.snapshotRestore.repositoryForm.typeS3.maxRestoreBytesLabel": "每秒最大还原字节数", - "xpack.snapshotRestore.repositoryForm.typeS3.maxRestoreBytesTitle": "每秒最大还原字节数", - "xpack.snapshotRestore.repositoryForm.typeS3.maxSnapshotBytesDescription": "为每个节点创建快照的速率。", - "xpack.snapshotRestore.repositoryForm.typeS3.maxSnapshotBytesLabel": "每秒最大快照字节数", - "xpack.snapshotRestore.repositoryForm.typeS3.maxSnapshotBytesTitle": "每秒最大快照字节数", - "xpack.snapshotRestore.repositoryForm.typeS3.readonlyDescription": "仅一个集群应对此存储库有写权限。所有其他集群应为只读。", - "xpack.snapshotRestore.repositoryForm.typeS3.readonlyLabel": "只读存储库", - "xpack.snapshotRestore.repositoryForm.typeS3.readonlyTitle": "只读", - "xpack.snapshotRestore.repositoryForm.typeS3.serverSideEncryptionDescription": "使用 AES256 算法加密服务器上的文件。", - "xpack.snapshotRestore.repositoryForm.typeS3.serverSideEncryptionLabel": "服务器端加密", - "xpack.snapshotRestore.repositoryForm.typeS3.serverSideEncryptionTitle": "服务器端加密", - "xpack.snapshotRestore.repositoryForm.typeS3.storageClassDescription": "S3 存储库中新对象的存储类。", - "xpack.snapshotRestore.repositoryForm.typeS3.storageClassLabel": "存储类", - "xpack.snapshotRestore.repositoryForm.typeS3.storageClassTitle": "存储类", - "xpack.snapshotRestore.repositoryForm.validationErrorTitle": "继续前请解决错误。", - "xpack.snapshotRestore.repositoryList.addRepositoryButtonLabel": "注册存储库", - "xpack.snapshotRestore.repositoryList.emptyPromptDescription": "您需要用来存储快照的存储库。", - "xpack.snapshotRestore.repositoryList.emptyPromptTitle": "您未有任何存储库", - "xpack.snapshotRestore.repositoryList.loadingRepositoriesDescription": "正在加载存储库……", - "xpack.snapshotRestore.repositoryList.LoadingRepositoriesErrorMessage": "加载存储库时出错", - "xpack.snapshotRestore.repositoryList.table.actionEditAriaLabel": "编辑存储库 `{name}`", - "xpack.snapshotRestore.repositoryList.table.actionEditTooltip": "编辑", - "xpack.snapshotRestore.repositoryList.table.actionRemoveAriaLabel": "移除存储库 `{name}`", - "xpack.snapshotRestore.repositoryList.table.actionRemoveTooltip": "删除", - "xpack.snapshotRestore.repositoryList.table.actionsColumnTitle": "操作", - "xpack.snapshotRestore.repositoryList.table.deleteManagedRepositoryTooltip": "您无法删除托管存储库。", - "xpack.snapshotRestore.repositoryList.table.deleteMultipleRepositoriesButton": "移除存储库", - "xpack.snapshotRestore.repositoryList.table.deleteSingleRepositoryButton": "移除存储库", - "xpack.snapshotRestore.repositoryList.table.managedRepositoryBadgeLabel": "受管", - "xpack.snapshotRestore.repositoryList.table.nameColumnTitle": "名称", - "xpack.snapshotRestore.repositoryList.table.reloadRepositoriesButton": "重新加载", - "xpack.snapshotRestore.repositoryList.table.typeColumnTitle": "类型", - "xpack.snapshotRestore.repositoryType.azureTypeName": "Azure", - "xpack.snapshotRestore.repositoryType.fileSystemTypeName": "共享文件系统", - "xpack.snapshotRestore.repositoryType.gcsTypeName": "Google Cloud Storage", - "xpack.snapshotRestore.repositoryType.hdfsTypeName": "Hadoop HDFS", - "xpack.snapshotRestore.repositoryType.readonlyTypeName": "只读 URL", - "xpack.snapshotRestore.repositoryType.s3TypeName": "AWS S3", - "xpack.snapshotRestore.repositoryType.sourceTypeName": "仅源", - "xpack.snapshotRestore.repositoryValidation.bucketRequired": "“存储桶”必填", - "xpack.snapshotRestore.repositoryValidation.delegateTypeRequired": "“类型”必填", - "xpack.snapshotRestore.repositoryValidation.locationRequired": "“位置”必填。", - "xpack.snapshotRestore.repositoryValidation.nameRequired": "“存储库名称”必填。", - "xpack.snapshotRestore.repositoryValidation.nameValidation.errorSpace": "名称中不允许使用空格。", - "xpack.snapshotRestore.repositoryValidation.nameValidation.invalidCharacter": "名称中不允许使用字符“{char}”。", - "xpack.snapshotRestore.repositoryValidation.pathRequired": "“路径”必填", - "xpack.snapshotRestore.repositoryValidation.uriRequired": "“URI”必填。", - "xpack.snapshotRestore.repositoryValidation.urlRequired": "“URL”必填", - "xpack.snapshotRestore.repositoryVerification.verificationErrorValue": "未连接", - "xpack.snapshotRestore.repositoryVerification.verificationSuccessfulValue": "已连接", - "xpack.snapshotRestore.repositoryVerification.verificationUnknownValue": "未知", - "xpack.snapshotRestore.repositoryWarningDescription": "快照可能加载缓慢。前往 {repositoryLink} 以修复错误。", - "xpack.snapshotRestore.repositoryWarningLinkText": "存储库", - "xpack.snapshotRestore.repositoryWarningTitle": "一些存储库包含错误", - "xpack.snapshotRestore.snapshotDetails.closeButtonLabel": "关闭", - "xpack.snapshotRestore.snapshotDetails.errorLoadingRepositoryTitle": "加载存储库时出错", - "xpack.snapshotRestore.snapshotDetails.errorSnapshotNotFound": "快照“{snapshotId}”在存储库“{repositoryName}”中不存在或该存储库不存在。", - "xpack.snapshotRestore.snapshotDetails.failureShardTitle": "分片 {shardId}", - "xpack.snapshotRestore.snapshotDetails.failuresTabTitle": "失败的索引 ({failuresCount})", - "xpack.snapshotRestore.snapshotDetails.itemDurationLabel": "持续时间", - "xpack.snapshotRestore.snapshotDetails.itemDurationValueLabel": "{seconds} {seconds, plural, one {秒} other {秒}}", - "xpack.snapshotRestore.snapshotDetails.itemEndTimeLabel": "结束时间", - "xpack.snapshotRestore.snapshotDetails.itemIncludeGlobalStateLabel": "包括全局状态", - "xpack.snapshotRestore.snapshotDetails.itemIncludeGlobalStateNoLabel": "否", - "xpack.snapshotRestore.snapshotDetails.itemIncludeGlobalStateYesLabel": "是", - "xpack.snapshotRestore.snapshotDetails.itemIndicesLabel": "索引 ({indicesCount})", - "xpack.snapshotRestore.snapshotDetails.itemIndicesNoneLabel": "-", - "xpack.snapshotRestore.snapshotDetails.itemStartTimeLabel": "开始时间", - "xpack.snapshotRestore.snapshotDetails.itemStateLabel": "状态", - "xpack.snapshotRestore.snapshotDetails.itemUuidLabel": "UUID", - "xpack.snapshotRestore.snapshotDetails.itemVersionLabel": "版本 / 版本 ID", - "xpack.snapshotRestore.snapshotDetails.loadingSnapshotDescription": "正在加载快照……", - "xpack.snapshotRestore.snapshotDetails.noIndexFailuresMessage": "所有索引成功存储。", - "xpack.snapshotRestore.snapshotDetails.repositoryTitle": "“{repositoryName}”存储库", - "xpack.snapshotRestore.snapshotDetails.snapshotIsBeingCreatedMessage": "正在创建快照。", - "xpack.snapshotRestore.snapshotDetails.summaryTabTitle": "结论", - "xpack.snapshotRestore.snapshotList.emptyPrompt.errorRepositoriesTitle": "一些存储库包含错误", - "xpack.snapshotRestore.snapshotList.emptyPrompt.noRepositoriesAddButtonLabel": "注册存储库", - "xpack.snapshotRestore.snapshotList.emptyPrompt.noRepositoriesDescription": "首先为您的快照注册存储库。", - "xpack.snapshotRestore.snapshotList.emptyPrompt.noRepositoriesTitle": "您尚未有任何快照或存储库", - "xpack.snapshotRestore.snapshotList.emptyPrompt.noSnapshotsDescription": "使用 Elasticsearch API 创建快照", - "xpack.snapshotRestore.snapshotList.emptyPrompt.noSnapshotsTitle": "您尚未有任何快照", - "xpack.snapshotRestore.snapshotList.emptyPrompt.repositoryWarningDescription": "前往 {repositoryLink} 以修复错误。", - "xpack.snapshotRestore.snapshotList.loadingSnapshotsDescription": "正在加载快照……", - "xpack.snapshotRestore.snapshotList.loadingSnapshotsErrorMessage": "加载快照时出错", - "xpack.snapshotRestore.snapshotList.table.durationColumnTitle": "持续时间", - "xpack.snapshotRestore.snapshotList.table.durationColumnValueLabel": "{seconds} 秒", - "xpack.snapshotRestore.snapshotList.table.failedShardsColumnTitle": "失败的分片", - "xpack.snapshotRestore.snapshotList.table.indicesColumnTitle": "索引", - "xpack.snapshotRestore.snapshotList.table.reloadSnapshotsButton": "重新加载", - "xpack.snapshotRestore.snapshotList.table.repositoryColumnTitle": "存储库", - "xpack.snapshotRestore.snapshotList.table.shardsColumnTitle": "分片", - "xpack.snapshotRestore.snapshotList.table.snapshotColumnTitle": "快照", - "xpack.snapshotRestore.snapshotList.table.startTimeColumnTitle": "创建日期", - "xpack.snapshotRestore.snapshotState.completeLabel": "快照完成", - "xpack.snapshotRestore.snapshotState.failedLabel": "快照失败", - "xpack.snapshotRestore.snapshotState.incompatibleLabel": "不兼容版本", - "xpack.snapshotRestore.snapshotState.incompatibleTipDescription": "创建快照所用的 Elasticsearch 版本与集群的版本不兼容。", - "xpack.snapshotRestore.snapshotState.inProgressLabel": "正在拍取快照……", - "xpack.snapshotRestore.snapshotState.partialLabel": "部分失败", - "xpack.snapshotRestore.snapshotState.partialTipDescription": "全局集群状态已存储,但至少一个分片未成功存储。请参阅“失败的索引”选项卡。", - "xpack.snapshotRestore.addPolicy.breadcrumbTitle": "添加策略", - "xpack.snapshotRestore.addPolicy.loadingIndicesDescription": "正在加载可用索引……", - "xpack.snapshotRestore.addPolicy.LoadingIndicesErrorMessage": "加载可用索引时出错", - "xpack.snapshotRestore.addPolicy.savingPolicyErrorTitle": "无法创建新策略", - "xpack.snapshotRestore.addPolicyTitle": "创建策略", - "xpack.snapshotRestore.app.checkingPrivilegesDescription": "正在检查权限……", - "xpack.snapshotRestore.app.checkingPrivilegesErrorMessage": "从服务器获取用户权限时出错。", - "xpack.snapshotRestore.app.deniedPrivilegeDescription": "要使用“快照和还原”,必须具有{privilegesCount, plural, one {以下集群权限} other {以下集群权限}}:{missingPrivileges}。", - "xpack.snapshotRestore.app.deniedPrivilegeTitle": "您缺少集群权限", - "xpack.snapshotRestore.createPolicyButton": "创建策略", - "xpack.snapshotRestore.deletePolicy.confirmModal.cancelButtonLabel": "取消", - "xpack.snapshotRestore.deletePolicy.confirmModal.confirmButtonLabel": "删除{count, plural, one {策略} other {策略}}", - "xpack.snapshotRestore.deletePolicy.confirmModal.deleteMultipleListDescription": "您即将删除以下策略:", - "xpack.snapshotRestore.deletePolicy.confirmModal.deleteMultipleTitle": "删除 {count} 个策略?", - "xpack.snapshotRestore.deletePolicy.confirmModal.deleteSingleTitle": "删除策略“{name}”?", - "xpack.snapshotRestore.deletePolicy.errorMultipleNotificationTitle": "删除 {count} 个策略时出错", - "xpack.snapshotRestore.deletePolicy.errorSingleNotificationTitle": "删除策略“{name}”时出错", - "xpack.snapshotRestore.deletePolicy.successMultipleNotificationTitle": "已删除 {count} 个策略", - "xpack.snapshotRestore.deletePolicy.successSingleNotificationTitle": "已删除策略“{name}”", - "xpack.snapshotRestore.editPolicy.breadcrumbTitle": "编辑策略", - "xpack.snapshotRestore.editPolicy.loadingIndicesDescription": "正在加载可用索引……", - "xpack.snapshotRestore.editPolicy.LoadingIndicesErrorMessage": "加载可用索引时出错", - "xpack.snapshotRestore.editPolicy.loadingPolicyDescription": "正在加载策略详细信息……", - "xpack.snapshotRestore.editPolicy.loadingPolicyErrorTitle": "加载策略详细信息时出错", - "xpack.snapshotRestore.editPolicy.policyNotFoundErrorMessage": "策略“{name}”不存在。", - "xpack.snapshotRestore.editPolicy.savingPolicyErrorTitle": "无法保存策略", - "xpack.snapshotRestore.editPolicyTitle": "编辑策略", - "xpack.snapshotRestore.emptyPrompt.usePolicyDocLinkText": "Elasticsearch API", - "xpack.snapshotRestore.executePolicy.confirmModal.cancelButtonLabel": "取消", - "xpack.snapshotRestore.executePolicy.confirmModal.confirmButtonLabel": "运行策略", - "xpack.snapshotRestore.executePolicy.confirmModal.executePolicyTitle": "立即运行“{name}”?", - "xpack.snapshotRestore.executePolicy.errorNotificationTitle": "运行策略“{name}”时出错", - "xpack.snapshotRestore.executePolicy.successNotificationTitle": "策略“{name}”正在运行", - "xpack.snapshotRestore.home.policiesTabTitle": "策略", - "xpack.snapshotRestore.policies.breadcrumbTitle": "策略", - "xpack.snapshotRestore.policyDetails.allIndicesLabel": "所有索引", - "xpack.snapshotRestore.policyDetails.closeButtonLabel": "关闭", - "xpack.snapshotRestore.policyDetails.deleteButtonLabel": "删除", - "xpack.snapshotRestore.policyDetails.editButtonLabel": "编辑", - "xpack.snapshotRestore.policyDetails.executeButtonLabel": "立即运行", - "xpack.snapshotRestore.policyDetails.historyTabTitle": "历史记录", - "xpack.snapshotRestore.policyDetails.ignoreUnavailableFalseLabel": "否", - "xpack.snapshotRestore.policyDetails.ignoreUnavailableLabel": "忽略不可用索引", - "xpack.snapshotRestore.policyDetails.ignoreUnavailableTrueLabel": "是", - "xpack.snapshotRestore.policyDetails.includeGlobalStateFalseLabel": "否", - "xpack.snapshotRestore.policyDetails.includeGlobalStateLabel": "包括全局状态", - "xpack.snapshotRestore.policyDetails.includeGlobalStateTrueLabel": "是", - "xpack.snapshotRestore.policyDetails.indicesCollapseAllLink": "隐藏 {count, plural, one {# 个索引} other {# 个索引}}", - "xpack.snapshotRestore.policyDetails.indicesLabel": "索引", - "xpack.snapshotRestore.policyDetails.indicesShowAllLink": "再显示 {count} 个 {count, plural, one {索引} other {索引}}", - "xpack.snapshotRestore.policyDetails.inProgressSnapshotLinkText": "“{snapshotName}”正在进行中", - "xpack.snapshotRestore.policyDetails.lastFailure.dateLabel": "日期", - "xpack.snapshotRestore.policyDetails.lastFailure.detailsAriaLabel": "策略“{name}”的上次失败详情", - "xpack.snapshotRestore.policyDetails.lastFailure.detailsLabel": "详情", - "xpack.snapshotRestore.policyDetails.lastFailure.snapshotNameLabel": "快照名称", - "xpack.snapshotRestore.policyDetails.lastFailureTitle": "上次快照失败", - "xpack.snapshotRestore.policyDetails.lastSuccess.dateLabel": "日期", - "xpack.snapshotRestore.policyDetails.lastSuccess.snapshotNameLabel": "快照名称", - "xpack.snapshotRestore.policyDetails.lastSuccessTitle": "上次成功快照", - "xpack.snapshotRestore.policyDetails.loadingPolicyDescription": "正在加载策略……", - "xpack.snapshotRestore.policyDetails.loadingPolicyErrorTitle": "加载策略时出错", - "xpack.snapshotRestore.policyDetails.manageButtonLabel": "管理策略", - "xpack.snapshotRestore.policyDetails.managePanelTitle": "策略选项", - "xpack.snapshotRestore.policyDetails.modifiedDateLabel": "最后修改时间", - "xpack.snapshotRestore.policyDetails.nextExecutionLabel": "下一快照", - "xpack.snapshotRestore.policyDetails.noHistoryMessage": "此策略将在 {date} {time}运行。", - "xpack.snapshotRestore.policyDetails.partialFalseLabel": "否", - "xpack.snapshotRestore.policyDetails.partialLabel": "允许部分分片", - "xpack.snapshotRestore.policyDetails.partialTrueLabel": "是", - "xpack.snapshotRestore.policyDetails.policyNotFoundErrorMessage": "策略“{name}”不存在。", - "xpack.snapshotRestore.policyDetails.reloadButtonAriaLabel": "重新加载", - "xpack.snapshotRestore.policyDetails.repositoryLabel": "存储库", - "xpack.snapshotRestore.policyDetails.scheduleLabel": "计划", - "xpack.snapshotRestore.policyDetails.snapshotNameLabel": "快照名称", - "xpack.snapshotRestore.policyDetails.summaryTabTitle": "总结", - "xpack.snapshotRestore.policyDetails.versionLabel": "版本", - "xpack.snapshotRestore.policyForm.addRepositoryButtonLabel": "注册存储库", - "xpack.snapshotRestore.policyForm.backButtonLabel": "上一步", - "xpack.snapshotRestore.policyForm.cancelButtonLabel": "取消", - "xpack.snapshotRestore.policyForm.createButtonLabel": "创建策略", - "xpack.snapshotRestore.policyForm.loadingRepositoriesDescription": "正在加载存储库……", - "xpack.snapshotRestore.policyForm.loadingRepositoriesErrorMessage": "加载存储库时出错", - "xpack.snapshotRestore.policyForm.navigation.stepLogisticsName": "运筹", - "xpack.snapshotRestore.policyForm.navigation.stepReviewName": "复查", - "xpack.snapshotRestore.policyForm.navigation.stepSettingsName": "快照设置", - "xpack.snapshotRestore.policyForm.nextButtonLabel": "下一步", - "xpack.snapshotRestore.policyForm.noRepositoriesErrorMessage": "必须注册存储库,才能存储快照。", - "xpack.snapshotRestore.policyForm.noRepositoriesErrorTitle": "您未有任何存储库", - "xpack.snapshotRestore.policyForm.reloadRepositoriesButtonLabel": "重新加载存储库", - "xpack.snapshotRestore.policyForm.saveButtonLabel": "保存策略", - "xpack.snapshotRestore.policyForm.savingButtonLabel": "正在保存……", - "xpack.snapshotRestore.policyForm.stepLogistics.docsButtonLabel": "运筹文档", - "xpack.snapshotRestore.policyForm.stepLogistics.nameDescription": "此策略的唯一标识符。", - "xpack.snapshotRestore.policyForm.stepLogistics.nameDescriptionTitle": "策略名称", - "xpack.snapshotRestore.policyForm.stepLogistics.nameLabel": "名称", - "xpack.snapshotRestore.policyForm.stepLogistics.namePlaceholder": "每日快照", - "xpack.snapshotRestore.policyForm.stepLogistics.policyRepositoryLabel": "存储库", - "xpack.snapshotRestore.policyForm.stepLogistics.policyScheduleButtonAdvancedLabel": "创建 Cron 表达式", - "xpack.snapshotRestore.policyForm.stepLogistics.policyScheduleButtonBasicLabel": "创建基本间隔", - "xpack.snapshotRestore.policyForm.stepLogistics.policyScheduleHelpText": "使用 Cron 表达式。{docLink}", - "xpack.snapshotRestore.policyForm.stepLogistics.policyScheduleHelpTextDocLink": "了解详情。", - "xpack.snapshotRestore.policyForm.stepLogistics.policyScheduleLabel": "计划", - "xpack.snapshotRestore.policyForm.stepLogistics.policySnapshotNameHelpText": "支持日期匹配表达式。{docLink}", - "xpack.snapshotRestore.policyForm.stepLogistics.policySnapshotNameHelpTextDocLink": "了解详情。", - "xpack.snapshotRestore.policyForm.stepLogistics.policySnapshotNameLabel": "快照名称", - "xpack.snapshotRestore.policyForm.stepLogistics.policySnapshotNamePlaceholder": "<daily-snap-\\{now \\}>", - "xpack.snapshotRestore.policyForm.stepLogistics.repositoryDescription": "要用于存储快照的存储库。", - "xpack.snapshotRestore.policyForm.stepLogistics.repositoryDescriptionTitle": "存储库", - "xpack.snapshotRestore.policyForm.stepLogistics.scheduleDescription": "拍取快照的频率。", - "xpack.snapshotRestore.policyForm.stepLogistics.scheduleDescriptionTitle": "计划", - "xpack.snapshotRestore.policyForm.stepLogistics.snapshotNameDescription": "快照的名称。唯一标识符将自动添加到每个名称中。", - "xpack.snapshotRestore.policyForm.stepLogistics.snapshotNameDescriptionTitle": "快照名称", - "xpack.snapshotRestore.policyForm.stepLogisticsTitle": "运筹", - "xpack.snapshotRestore.policyForm.stepReview.requestTabTitle": "请求", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.allIndicesValue": "所有索引", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.editStepTooltip": "编辑", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.ignoreUnavailableFalseLabel": "否", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.ignoreUnavailableLabel": "忽略不可用索引", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.ignoreUnavailableTrueLabel": "是", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.includeGlobalStateFalseLabel": "否", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.includeGlobalStateLabel": "包括全局状态", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.includeGlobalStateTrueLabel": "是", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.indicesCollapseAllLink": "隐藏 {count, plural, one {# 个索引} other {# 个索引}}", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.indicesLabel": "索引", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.indicesShowAllLink": "再显示 {count} 个 {count, plural, one {索引} other {索引}}", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.nameLabel": "策略名称", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.partialFalseLabel": "否", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.partialLabel": "允许部分分片", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.partialTrueLabel": "是", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.repositoryLabel": "存储库", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.scheduleLabel": "计划", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.sectionLogisticsTitle": "运筹", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.sectionSettingsTitle": "快照设置", - "xpack.snapshotRestore.policyForm.stepReview.summaryTab.snapshotNameLabel": "快照名称", - "xpack.snapshotRestore.policyForm.stepReview.summaryTabTitle": "总结", - "xpack.snapshotRestore.policyForm.stepReviewTitle": "复查策略", - "xpack.snapshotRestore.policyForm.stepSettings.allIndicesLabel": "所有索引,包括系统索引", - "xpack.snapshotRestore.policyForm.stepSettings.deselectAllIndicesLink": "取消全选", - "xpack.snapshotRestore.policyForm.stepSettings.docsButtonLabel": "快照设置文档", - "xpack.snapshotRestore.policyForm.stepSettings.ignoreUnavailableDescription": "拍取快照时忽略不可用的索引。否则,整个快照将失败。", - "xpack.snapshotRestore.policyForm.stepSettings.ignoreUnavailableDescriptionTitle": "忽略不可用索引", - "xpack.snapshotRestore.policyForm.stepSettings.ignoreUnavailableLabel": "忽略不可用索引", - "xpack.snapshotRestore.policyForm.stepSettings.includeGlobalStateDescription": "将集群的全局状态存储为快照的一部分。", - "xpack.snapshotRestore.policyForm.stepSettings.includeGlobalStateDescriptionTitle": "包括全局状态", - "xpack.snapshotRestore.policyForm.stepSettings.indicesDescription": "要备份的索引。", - "xpack.snapshotRestore.policyForm.stepSettings.indicesPatternLabel": "索引模式", - "xpack.snapshotRestore.policyForm.stepSettings.indicesPatternPlaceholder": "输入索引模式,例如 logstash-*", - "xpack.snapshotRestore.policyForm.stepSettings.indicesTitle": "索引", - "xpack.snapshotRestore.policyForm.stepSettings.indicesToggleCustomLink": "使用索引模式", - "xpack.snapshotRestore.policyForm.stepSettings.indicesToggleListLink": "选择索引", - "xpack.snapshotRestore.policyForm.stepSettings.partialDescription": "允许具有不可用主分片的索引的快照。否则,整个快照将失败。", - "xpack.snapshotRestore.policyForm.stepSettings.partialDescriptionTitle": "允许部分索引", - "xpack.snapshotRestore.policyForm.stepSettings.policyIncludeGlobalStateLabel": "包括全局状态", - "xpack.snapshotRestore.policyForm.stepSettings.selectAllIndicesLink": "全选", - "xpack.snapshotRestore.policyForm.stepSettings.selectIndicesHelpText": "将备份 {count} 个 {count, plural, one {索引} other {索引}}。{selectOrDeselectAllLink}", - "xpack.snapshotRestore.policyForm.stepSettings.selectIndicesLabel": "选择索引", - "xpack.snapshotRestore.policyForm.stepSettingsTitle": "快照设置", - "xpack.snapshotRestore.policyList.deniedPrivilegeDescription": "要管理快照生命周期策略,必须具有{privilegesCount, plural, one {以下集群权限} other {以下集群权限}}:{missingPrivileges}。", - "xpack.snapshotRestore.policyList.deniedPrivilegeTitle": "您缺少集群权限", - "xpack.snapshotRestore.policyList.emptyPromptDescription": "创建自动备份集群的策略。", - "xpack.snapshotRestore.policyList.emptyPromptTitle": "您尚未有任何快照策略", - "xpack.snapshotRestore.policyList.loadingPoliciesDescription": "正在加载策略……", - "xpack.snapshotRestore.policyList.LoadingPoliciesErrorMessage": "加载策略时出错", - "xpack.snapshotRestore.policyList.table.actionDeleteAriaLabel": "删除策略“{name}”", - "xpack.snapshotRestore.policyList.table.actionDeleteTooltip": "删除", - "xpack.snapshotRestore.policyList.table.actionEditAriaLabel": "编辑策略“{name}”", - "xpack.snapshotRestore.policyList.table.actionEditTooltip": "编辑", - "xpack.snapshotRestore.policyList.table.actionExecuteAriaLabel": "立即运行“{name}”", - "xpack.snapshotRestore.policyList.table.actionExecuteDisabledTooltip": "策略正在运行", - "xpack.snapshotRestore.policyList.table.actionExecuteTooltip": "立即运行", - "xpack.snapshotRestore.policyList.table.actionsColumnTitle": "操作", - "xpack.snapshotRestore.policyList.table.addPolicyButton": "创建策略", - "xpack.snapshotRestore.policyList.table.deletePolicyButton": "删除{count, plural, one {策略} other {策略}}", - "xpack.snapshotRestore.policyList.table.inProgressTooltip": "快照进行中", - "xpack.snapshotRestore.policyList.table.nextExecutionColumnTitle": "下一快照", - "xpack.snapshotRestore.policyList.table.policyNameColumnTitle": "政策", - "xpack.snapshotRestore.policyList.table.reloadPoliciesButton": "重新加载", - "xpack.snapshotRestore.policyList.table.repositoryColumnTitle": "存储库", - "xpack.snapshotRestore.policyList.table.repositoryFilterLabel": "存储库", - "xpack.snapshotRestore.policyList.table.scheduleColumnTitle": "计划", - "xpack.snapshotRestore.policyList.table.snapshotNameColumnTitle": "快照名称", - "xpack.snapshotRestore.policyScheduleWarningDescription": "一次仅可以拍取一个快照。要避免快照失败,请编辑或删除策略。", - "xpack.snapshotRestore.policyScheduleWarningTitle": "两个或更多策略有相同的计划", - "xpack.snapshotRestore.repositories.breadcrumbTitle": "存储库", - "xpack.snapshotRestore.repositoryList.table.typeFilterLabel": "类型", - "xpack.snapshotRestore.restoreForm.stepLogistics.indicesPatternLabel": "索引模式", - "xpack.snapshotRestore.restoreForm.stepLogistics.indicesPatternPlaceholder": "输入索引模式,例如 logstash-*", - "xpack.snapshotRestore.restoreForm.stepLogistics.indicesToggleCustomLink": "使用索引模式", - "xpack.snapshotRestore.restoreForm.stepLogistics.indicesToggleListLink": "选择索引", - "xpack.snapshotRestore.restoreList.deniedPrivilegeDescription": "要查看快照还原状态,必须对一个或多个索引具有{privilegesCount, plural, one {以下索引权限} other {以下索引权限}}:{missingPrivileges}.", - "xpack.snapshotRestore.restoreList.deniedPrivilegeTitle": "您缺少索引权限", - "xpack.snapshotRestore.restoreList.loadingRestoresErrorMessage": "加载还原时出错", - "xpack.snapshotRestore.restoreStatus.breadcrumbTitle": "还原状态", - "xpack.snapshotRestore.restoreValidation.indexPatternRequiredError": "至少需要一个索引模式。", - "xpack.snapshotRestore.snapshotDetails.createdByLabel": "创建者", - "xpack.snapshotRestore.snapshotList.emptyPrompt.addPolicyText": "创建策略", - "xpack.snapshotRestore.snapshotList.emptyPrompt.goToPoliciesText": "查看策略", - "xpack.snapshotRestore.snapshotList.emptyPrompt.usePolicyDescription": "运行快照生命周期策略以创建快照。还可以使用 {docLink} 创建快照。", - "xpack.snapshotRestore.snapshotList.table.repositoryFilterLabel": "存储库", - "xpack.snapshotRestore.snapshots.breadcrumbTitle": "快照", - "xpack.snapshotRestore.restoreForm.stepLogistics.docsButtonLabel": "快照和还原文档", - "xpack.snapshotRestore.restoreForm.stepLogisticsTitle": "还原详情", - "xpack.snapshotRestore.restoreSnapshot.executeRestoreErrorTitle": "无法还原快照", - "xpack.snapshotRestore.executeRetention.confirmModal.cancelButtonLabel": "取消", - "xpack.snapshotRestore.executeRetention.confirmModal.confirmButtonLabel": "运行保留", - "xpack.snapshotRestore.executeRetention.confirmModal.executeRetentionTitle": "立即运行快照保留?", - "xpack.snapshotRestore.executeRetention.errorMessage": "运行保留时出错", - "xpack.snapshotRestore.executeRetention.successMessage": "保留正在运行", - "xpack.snapshotRestore.policyDetails.expireAfterLabel": "在指定时间后删除:", - "xpack.snapshotRestore.policyDetails.generalTitle": "常规", - "xpack.snapshotRestore.policyDetails.maxCountLabel": "最大计数", - "xpack.snapshotRestore.policyDetails.minCountLabel": "最小计数", - "xpack.snapshotRestore.policyDetails.retentionTitle": "保留", - "xpack.snapshotRestore.policyDetails.snapshotDeletionFailuresStat": "删除失败", - "xpack.snapshotRestore.policyDetails.snapshotsDeletedStat": "已删除", - "xpack.snapshotRestore.policyDetails.snapshotsFailedStat": "失败", - "xpack.snapshotRestore.policyDetails.snapshotsTakenStat": "快照", - "xpack.snapshotRestore.policyForm.navigation.stepRetentionName": "快照保留", - "xpack.snapshotRestore.policyForm.stepRetention.countDescription": "在您的集群中要存储的最小和最大快照数目。", - "xpack.snapshotRestore.policyForm.stepRetention.countTitle": "要保留的快照", - "xpack.snapshotRestore.policyForm.stepRetention.docsButtonLabel": "快照保留文档", - "xpack.snapshotRestore.policyForm.stepRetention.expirationDescription": "删除快照前要等候的时间。", - "xpack.snapshotRestore.policyForm.stepRetention.expirationTitle": "到期", - "xpack.snapshotRestore.policyForm.stepRetention.expireAfterLabel": "在指定时间后删除:", - "xpack.snapshotRestore.policyForm.stepRetention.maxCountLabel": "最大计数", - "xpack.snapshotRestore.policyForm.stepRetention.minCountLabel": "最小计数", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionAddTitle": "添加保留计划", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionAdvancedLabel": "创建 Cron 表达式", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionBasicLabel": "创建基本间隔", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionCancelButtonLabel": "取消", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionEditButtonLabel": "保存更改", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionEditTitle": "编辑保留计划", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionErrorTitle": "保存保留计划时出错", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionHelpText": "使用 Cron 表达式。{docLink}", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionHelpTextDocLinkText": "了解详情。", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionSaveButtonLabel": "计划", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionScheduleFieldErrorMessage": "保留计划必填。", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionScheduleLabel": "保留计划", - "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionSuccessMessage": "保留计划已更新", - "xpack.snapshotRestore.policyForm.stepRetentionTitle": "快照保留(可选)", - "xpack.snapshotRestore.policyForm.stepReview.editIconAriaLabel": "编辑步长", - "xpack.snapshotRestore.policyForm.stepReview.retentionTab.expireAfterLabel": "在指定时间后删除:", - "xpack.snapshotRestore.policyForm.stepReview.retentionTab.maxCountLabel": "最大计数", - "xpack.snapshotRestore.policyForm.stepReview.retentionTab.minCountLabel": "最小计数", - "xpack.snapshotRestore.policyForm.stepReview.retentionTab.sectionRetentionTitle": "快照保留", - "xpack.snapshotRestore.policyForm.stepSettings.partialIndicesToggleSwitch": "允许部分索引", - "xpack.snapshotRestore.policyList.table.lastSnapshotFailedTooltip": "上次快照失败", - "xpack.snapshotRestore.policyList.table.retentionColumnAriaLabel": "已配置保留", - "xpack.snapshotRestore.policyList.table.retentionColumnTitle": "保留", - "xpack.snapshotRestore.policyRetentionSchedulePanel.addButtonLabel": "计划", - "xpack.snapshotRestore.policyRetentionSchedulePanel.errorFetchingRetentionScheduleReloadButtonLabel": "重新加载", - "xpack.snapshotRestore.policyRetentionSchedulePanel.errorFetchingRetentionScheduleTitle": "获取保留计划时出错", - "xpack.snapshotRestore.policyRetentionSchedulePanel.executeButtonLabel": "立即运行", - "xpack.snapshotRestore.policyRetentionSchedulePanel.managePanelTitle": "保留选项", - "xpack.snapshotRestore.policyRetentionSchedulePanel.manageRetentionButtonLabel": "管理保留", - "xpack.snapshotRestore.policyRetentionSchedulePanel.noScheduleConfiguredWarningDescription": "一个或多个策略具有保留期间,但未计划保留。", - "xpack.snapshotRestore.policyRetentionSchedulePanel.noScheduleConfiguredWarningTitle": "保留未计划", - "xpack.snapshotRestore.policyRetentionSchedulePanel.retentionScheduleDescription": "保留快照的 cron 计划是:{cronSchedule}。", - "xpack.snapshotRestore.policyRetentionSchedulePanel.retentionScheduleEditLinkAriaLabel": "编辑保留计划", - "xpack.snapshotRestore.policyRetentionSchedulePanel.retentionScheduleEditLinkTooltip": "编辑保留计划", - "xpack.snapshotRestore.policyRetentionSchedulePanel.retentionScheduleExecuteLinkAriaLabel": "立即运行保留", - "xpack.snapshotRestore.policyRetentionSchedulePanel.retentionScheduleExecuteLinkTooltip": "立即运行保留", - "xpack.snapshotRestore.policyValidation.indexPatternRequiredErrorMessage": "至少需要一个索引模式。", - "xpack.snapshotRestore.policyValidation.indicesRequiredErrorMessage": "必须至少选择一个索引。", - "xpack.snapshotRestore.policyValidation.invalidMinCountErrorMessage": "最小计数不能大于最大计数。", - "xpack.snapshotRestore.policyValidation.nameRequiredErroMessage": "策略名称必填。", - "xpack.snapshotRestore.policyValidation.repositoryRequiredErrorMessage": "存储库必填。", - "xpack.snapshotRestore.policyValidation.scheduleRequiredErrorMessage": "计划必填。", - "xpack.snapshotRestore.policyValidation.snapshotNameRequiredErrorMessage": "快照名称必填。", - "xpack.spaces.defaultSpaceDescription": "这是您的默认工作区!", - "xpack.spaces.defaultSpaceTitle": "默认值", - "xpack.spaces.displayName": "工作区", - "xpack.spaces.featureDescription": "将仪表板和其他已保存的对象管理为有意义的类别。", - "xpack.spaces.management.advancedSettingsSubtitle.applyingSettingsOnPageToSpaceDescription": "除非已指定,否则此页面上的设置适用于 {spaceName} 空间。", - "xpack.spaces.management.advancedSettingsTitle.settingsTitle": "设置", - "xpack.spaces.management.collapsiblePanel.hideLinkDescription": "隐藏 {title}", - "xpack.spaces.management.collapsiblePanel.hideLinkText": "隐藏", - "xpack.spaces.management.collapsiblePanel.showLinkDescription": "显示 {title}", - "xpack.spaces.management.collapsiblePanel.showLinkText": "显示", - "xpack.spaces.management.confirmAlterActiveSpaceModal.cancelButton": "取消", - "xpack.spaces.management.confirmAlterActiveSpaceModal.reloadWarningMessage": "您已更新此工作区中的可见功能。保存后,您的页面将重新加载。", - "xpack.spaces.management.confirmAlterActiveSpaceModal.title": "确认更新工作区", - "xpack.spaces.management.confirmAlterActiveSpaceModal.updateSpaceButton": "更新工作区", - "xpack.spaces.management.confirmDeleteModal.allContentsText": "所有内容", - "xpack.spaces.management.confirmDeleteModal.cancelButtonLabel": "取消", - "xpack.spaces.management.confirmDeleteModal.confirmDeleteSpaceButtonLabel": "删除空间 {spaceName}", - "xpack.spaces.management.confirmDeleteModal.confirmSpaceNameFormRowLabel": "确认要删除的工作区名称", - "xpack.spaces.management.confirmDeleteModal.deleteSpaceAndAllContentsButtonLabel": " 删除空间及其所有内容", - "xpack.spaces.management.confirmDeleteModal.deletingSpaceWarningMessage": "删除空间会永久删除空间及其 {allContents}。此操作无法撤消。", - "xpack.spaces.management.confirmDeleteModal.redirectAfterDeletingCurrentSpaceWarningMessage": "您即将删除当前空间 {name}。如果继续,系统会将您重定向到选择其他空间的位置。", - "xpack.spaces.management.confirmDeleteModal.spaceNamesDoNoMatchErrorMessage": "空间名称不匹配。", - "xpack.spaces.management.customizeSpaceAvatar.colorFormRowLabel": "颜色", - "xpack.spaces.management.customizeSpaceAvatar.initialItemsFormRowLabel": "名字缩写(最多两个字符)", - "xpack.spaces.management.deleteSpacesButton.deleteSpaceAriaLabel": "删除此空间", - "xpack.spaces.management.deleteSpacesButton.deleteSpaceButtonLabel": "删除空间", - "xpack.spaces.management.deleteSpacesButton.deleteSpaceErrorTitle": "删除空间时出错:{errorMessage}", - "xpack.spaces.management.deleteSpacesButton.spaceSuccessfullyDeletedNotificationMessage": "已删除 {spaceName} 空间。", - "xpack.spaces.management.enabledSpaceFeatures.allFeaturesEnabledMessage": "(所有可见功能)", - "xpack.spaces.management.enabledSpaceFeatures.enabledFeaturesSectionMessage": "定制功能显示", - "xpack.spaces.management.enabledSpaceFeatures.enableFeaturesInSpaceMessage": "控制哪些功能在此工作区中可见。", - "xpack.spaces.management.enabledSpaceFeatures.goToRolesLink": "想保护访问?前往 {rolesLink}。", - "xpack.spaces.management.enabledSpaceFeatures.noFeaturesEnabledMessage": "(没有可见功能)", - "xpack.spaces.management.enabledSpaceFeatures.notASecurityMechanismMessage": "该功能在 UI 中已隐藏,但未禁用。", - "xpack.spaces.management.enabledSpaceFeatures.rolesLinkText": "角色", - "xpack.spaces.management.enabledSpaceFeatures.someFeaturesEnabledMessage": "({enabledCount} / {featureCount} 个功能可见)", - "xpack.spaces.management.enabledSpaceFeaturesEnabledColumnTitle": "显示?", - "xpack.spaces.management.enabledSpaceFeaturesFeatureColumnTitle": "功能", - "xpack.spaces.management.hideAllFeaturesText": "全部隐藏", - "xpack.spaces.management.manageSpacePage.avatarFormRowLabel": "头像", - "xpack.spaces.management.manageSpacePage.awesomeSpacePlaceholder": "超卓的空间", - "xpack.spaces.management.manageSpacePage.cancelSpaceButton": "取消", - "xpack.spaces.management.manageSpacePage.clickToCustomizeTooltip": "单击可定制此工作区头像", - "xpack.spaces.management.manageSpacePage.createSpaceButton": "创建工作区", - "xpack.spaces.management.manageSpacePage.createSpaceTitle": "创建一个空间", - "xpack.spaces.management.manageSpacePage.customizeSpacePanelDescription": "命名您的工作区并定制其头像。", - "xpack.spaces.management.manageSpacePage.customizeSpacePanelUrlIdentifierEditable": "记下 URL 标识符。创建工作区后,将不能更改它。", - "xpack.spaces.management.manageSpacePage.customizeSpacePanelUrlIdentifierNotEditable": "URL 标识符无法更改。", - "xpack.spaces.management.manageSpacePage.customizeSpaceTitle": "定制您的工作区", - "xpack.spaces.management.manageSpacePage.customizeVisibleFeatures": "定制可见功能", - "xpack.spaces.management.manageSpacePage.errorLoadingSpaceTitle": "加载空间时出错:{message}", - "xpack.spaces.management.manageSpacePage.errorSavingSpaceTitle": "保存空间时出错:{message}", - "xpack.spaces.management.manageSpacePage.manageDescription": "将已保存对象组织到有意义的类别中。", - "xpack.spaces.management.manageSpacePage.nameFormRowLabel": "名称", - "xpack.spaces.management.manageSpacePage.spaceDescriptionFormRowLabel": "描述(可选)", - "xpack.spaces.management.manageSpacePage.spaceDescriptionHelpText": "描述显示在”工作区选择“屏幕上。", - "xpack.spaces.management.manageSpacePage.spaceSuccessfullySavedNotificationMessage": "空间 “{name}” 已保存。", - "xpack.spaces.management.manageSpacePage.updateSpaceButton": "更新工作区", - "xpack.spaces.management.reversedSpaceBadge.reversedSpacesCanBePartiallyModifiedTooltip": "保留的空间是内置的,只能进行部分修改。", - "xpack.spaces.management.secureSpaceMessage.howToAssignRoleToSpaceDescription": "想要为工作区分配角色?前往 {rolesLink}。", - "xpack.spaces.management.secureSpaceMessage.rolesLinkText": "角色", - "xpack.spaces.management.secureSpaceMessage.rolesLinkTextAriaLabel": "角色管理页面", - "xpack.spaces.management.showAllFeaturesText": "全部显示", - "xpack.spaces.management.spaceIdentifier.customizeSpaceLinkText": "[定制]", - "xpack.spaces.management.spaceIdentifier.customizeSpaceNameLinkLabel": "定制 URL 标识符", - "xpack.spaces.management.spaceIdentifier.emptySpaceIdentifierText": "awesome-space", - "xpack.spaces.management.spaceIdentifier.kibanaURLForSpaceIdentifierDescription": "示例:https://my-kibana.example{spaceIdentifier}/app/kibana。", - "xpack.spaces.management.spaceIdentifier.resetSpaceNameLinkLabel": "重置 URL 标识符", - "xpack.spaces.management.spaceIdentifier.resetSpaceNameLinkText": "[重置]", - "xpack.spaces.management.spaceIdentifier.urlIdentifierGeneratedFromSpaceNameTooltip": "awesome-space", - "xpack.spaces.management.spaceIdentifier.urlIdentifierLabel": "URL 标识符 ", - "xpack.spaces.management.spaceIdentifier.urlIdentifierTitle": "URL 标识符", - "xpack.spaces.management.spacesGridPage.actionsColumnName": "操作", - "xpack.spaces.management.spacesGridPage.allFeaturesEnabled": "所有可见功能", - "xpack.spaces.management.spacesGridPage.createSpaceButtonLabel": "创建一个空间", - "xpack.spaces.management.spacesGridPage.deleteActionName": "删除 {spaceName}。", - "xpack.spaces.management.spacesGridPage.descriptionColumnName": "描述", - "xpack.spaces.management.spacesGridPage.editSpaceActionName": "编辑 {spaceName}。", - "xpack.spaces.management.spacesGridPage.errorDeletingSpaceErrorMessage": "删除空间时出错:{errorMessage}", - "xpack.spaces.management.spacesGridPage.featuresColumnName": "功能", - "xpack.spaces.management.spacesGridPage.identifierColumnName": "标识符", - "xpack.spaces.management.spacesGridPage.loadingTitle": "正在加载……", - "xpack.spaces.management.spacesGridPage.noFeaturesEnabled": "没有可见功能", - "xpack.spaces.management.spacesGridPage.searchPlaceholder": "搜索", - "xpack.spaces.management.spacesGridPage.someFeaturesEnabled": "{enabledFeatureCount} / {totalFeatureCount} 个功能可见", - "xpack.spaces.management.spacesGridPage.spaceColumnName": "工作区", - "xpack.spaces.management.spacesGridPage.spacesTitle": "工作区", - "xpack.spaces.management.spacesGridPage.spaceSuccessfullyDeletedNotificationMessage": "已删除 “{spaceName}” 空间。", - "xpack.spaces.management.toggleAllFeaturesLink": "(全部更改)", - "xpack.spaces.management.unauthorizedPrompt.permissionDeniedDescription": "您没有权限管理空间。", - "xpack.spaces.management.unauthorizedPrompt.permissionDeniedTitle": "权限被拒绝", - "xpack.spaces.management.validateSpace.describeMaxLengthErrorMessage": "描述不能超过 2000 个字符。", - "xpack.spaces.management.validateSpace.nameMaxLengthErrorMessage": "名称不能超过 1024 个字符。", - "xpack.spaces.management.validateSpace.requiredNameErrorMessage": "“名称”必填", - "xpack.spaces.management.validateSpace.urlIdentifierAllowedCharactersErrorMessage": "URL 标识符只能包含 a-z、0-9 和字符“_”及“-”。", - "xpack.spaces.management.validateSpace.urlIdentifierRequiredErrorMessage": "“URL 标识符”必填。", - "xpack.spaces.manageSpacesButton.manageSpacesButtonLabel": "管理空间", - "xpack.spaces.navControl.spacesMenu.changeCurrentSpaceTitle": "更改当前空间", - "xpack.spaces.navControl.spacesMenu.findSpacePlaceholder": "查找工作区", - "xpack.spaces.navControl.spacesMenu.noSpacesFoundTitle": " 未找到工作区 ", - "xpack.spaces.spaceSelector.changeSpaceAnytimeAvailabilityText": "您可以随时更改您的空间", - "xpack.spaces.spaceSelector.findSpacePlaceholder": "查找工作区", - "xpack.spaces.spaceSelector.noSpacesMatchSearchCriteriaDescription": "没有匹配搜索条件的空间", - "xpack.spaces.spaceSelector.selectSpacesTitle": "选择您的空间", - "xpack.spaces.spacesTitle": "工作区", - "xpack.spaces.management.customizeSpaceAvatar.imageUrl": "定制图像", - "xpack.spaces.management.customizeSpaceAvatar.removeImage": "删除定制图像", - "xpack.spaces.management.customizeSpaceAvatar.selectImageUrl": "选择图像文件", - "telemetry.callout.appliesSettingTitle": "此设置适用于{allOfKibanaText}", - "telemetry.callout.appliesSettingTitle.allOfKibanaText": "所有 Kibana。", - "telemetry.callout.clusterStatisticsDescription": "这是我们将收集的基本集群统计信息的示例。其包括索引、分片和节点的数目。还包括概括性的使用情况统计信息,例如监测是否打开。", - "telemetry.callout.clusterStatisticsTitle": "集群统计信息", - "telemetry.callout.errorLoadingClusterStatisticsDescription": "尝试提取集群统计信息时发生意外错误。发生此问题的原因可能是 Elasticsearch 出故障、Kibana 出故障或者有网络错误。检查 Kibana,然后重新加载页面并重试。", - "telemetry.callout.errorLoadingClusterStatisticsTitle": "加载集群统计信息时出错", - "telemetry.callout.errorUnprivilegedUserDescription": "您无权查看未加密的集群统计信息。", - "telemetry.callout.errorUnprivilegedUserTitle": "显示集群统计信息时出错", - "telemetry.readOurUsageDataPrivacyStatementLinkText": "阅读我们的使用情况数据隐私声明", - "telemetry.seeExampleOfWhatWeCollectLinkText": "查看我们收集的内容示例", - "telemetry.telemetryConfigDescription": "通过提供基本功能的使用情况统计信息,来帮助我们改进 Elastic Stack。我们不会在 Elastic 之外共享此数据。", - "telemetry.telemetryConfigTitle": "遥测选择加入", - "telemetry.telemetryErrorNotificationMessageDescription.tryAgainText": "确认 Kibana 和 Elasticsearch 仍在运行,然后重试。", - "telemetry.telemetryErrorNotificationMessageDescription.unableToSaveTelemetryPreferenceText": "无法保存遥测首选项。", - "telemetry.telemetryErrorNotificationMessageTitle": "遥测错误", - "telemetry.usageDataTitle": "使用情况数据", - "telemetry.welcomeBanner.telemetryConfigDetailsDescription.telemetryPrivacyStatementLinkText": "遥测隐私声明", - "telemetry.optInErrorToastText": "尝试设置使用统计信息首选项时发生错误。", - "telemetry.optInErrorToastTitle": "错误", - "telemetry.welcomeBanner.title": "帮助我们改进 Elastic Stack!", - "xpack.upgradeAssistant.appTitle": "{version} 升级助手", - "xpack.upgradeAssistant.checkupTab.backUpCallout.calloutBody.calloutDetail": "使用 {snapshotRestoreDocsButton} 备份您的数据。", - "xpack.upgradeAssistant.checkupTab.backUpCallout.calloutBody.snapshotRestoreDocsButtonLabel": "快照和还原 API", - "xpack.upgradeAssistant.checkupTab.backUpCallout.calloutTitle": "立即备份索引", - "xpack.upgradeAssistant.checkupTab.changeFiltersShowMoreLabel": "更改筛选以显示更多内容。", - "xpack.upgradeAssistant.checkupTab.clusterTabLabel": "集群", - "xpack.upgradeAssistant.checkupTab.controls.collapseAllButtonLabel": "折叠全部", - "xpack.upgradeAssistant.checkupTab.controls.expandAllButtonLabel": "展开全部", - "xpack.upgradeAssistant.checkupTab.controls.filterBar.allButtonLabel": "全部", - "xpack.upgradeAssistant.checkupTab.controls.filterBar.criticalButtonLabel": "紧急", - "xpack.upgradeAssistant.checkupTab.controls.groupByBar.byIndexLabel": "按索引", - "xpack.upgradeAssistant.checkupTab.controls.groupByBar.byIssueLabel": "按问题", - "xpack.upgradeAssistant.checkupTab.controls.refreshButtonLabel": "刷新", - "xpack.upgradeAssistant.checkupTab.controls.searchBarPlaceholder": "筛选", - "xpack.upgradeAssistant.checkupTab.deprecations.criticalActionTooltip": "请解决此问题后再升级。", - "xpack.upgradeAssistant.checkupTab.deprecations.criticalLabel": "紧急", - "xpack.upgradeAssistant.checkupTab.deprecations.documentationButtonLabel": "文档", - "xpack.upgradeAssistant.checkupTab.deprecations.indexTable.detailsColumnLabel": "详情", - "xpack.upgradeAssistant.checkupTab.deprecations.indexTable.indexColumnLabel": "索引", - "xpack.upgradeAssistant.checkupTab.deprecations.warningActionTooltip": "建议在升级之前先解决此问题,但这不是必需的。", - "xpack.upgradeAssistant.checkupTab.deprecations.warningLabel": "警告", - "xpack.upgradeAssistant.checkupTab.indexLabel": "索引", - "xpack.upgradeAssistant.checkupTab.indicesBadgeLabel": "{numIndices, plural, one { 个索引} other { 个索引}}", - "xpack.upgradeAssistant.checkupTab.indicesTabLabel": "索引", - "xpack.upgradeAssistant.checkupTab.noDeprecationsLabel": "无弃用内容", - "xpack.upgradeAssistant.checkupTab.noIssues.nextStepsDetail": "选中 {overviewTabButton} 以执行后续步骤。", - "xpack.upgradeAssistant.checkupTab.noIssues.nextStepsDetail.overviewTabButtonLabel": "“概述”选项卡", - "xpack.upgradeAssistant.checkupTab.noIssues.noIssuesLabel": "您没有 {strongCheckupLabel} 问题。", - "xpack.upgradeAssistant.checkupTab.noIssues.noIssuesTitle": "全部清除!", - "xpack.upgradeAssistant.checkupTab.numDeprecationsShownLabel": "显示 {numShown} 个,共 {total} 个", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.cancelButtonLabel": "取消", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.closeButtonLabel": "关闭", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.continueButtonLabel": "继续重新索引", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.insufficientPrivilegeCallout.calloutTitle": "您没有足够的权限来重新索引此索引", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.readonlyCallout.backgroundResumeDetail": "重新索引将在后台继续,但如果 Kibana 关闭或重新启动,您将需要返回此页,才能恢复重新索引。", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.readonlyCallout.calloutTitle": "在重新索引时,索引无法采集、更新或删除文档", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.readonlyCallout.cantStopDetail": "如果您无法停止文档更新或需要重新索引到新的集群中,请考虑使用不同的升级策略。", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexButton.doneLabel": "已完成!", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexButton.reindexingLabel": "正在重新索引……", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexButton.resumeLabel": "恢复", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexButton.runReindexLabel": "运行重新索引", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexButton.tryAgainLabel": "重试", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.aliasSwapStepTitle": "正在交换具有别名的原始索引", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.cancelButton.cancelLabel": "取消", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.cancelButton.cancelledLabel": "已取消", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.cancelButton.cancellingLabel": "正在取消……", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.cancelButton.errorLabel": "无法取消", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.createIndexStepTitle": "正在创建新索引", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.pauseMlStepTitle": "正在暂停 Machine Learning 作业", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.readonlyStepTitle": "正在将旧索引设置为只读", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.reindexingDocumentsStepTitle": "正在重新索引文档", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.resumeMlStepTitle": "正在恢复 Machine Learning 作业", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.resumeWatcherStepTitle": "正在恢复 Watcher", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.stopWatcherStepTitle": "正在停止 Watcher", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklistTitle": "重新索引过程", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.flyoutHeader": "重新索引 {indexName}", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.warningsStep.apmReindexWarningDetail": "从版本 7.0.0 开始,将以 Elastic Common Schema 格式表示 APM 数据。只有重新索引历史 APM 数据后,其才可见。", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.warningsStep.apmReindexWarningTitle": "此索引将转换成 ECS 格式", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.warningsStep.destructiveCallout.calloutDetail": "备份您的索引,然后通过接受每个重大更改来继续重新索引。", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.warningsStep.destructiveCallout.calloutTitle": "此索引需要无法撤消的破坏性更改", - "xpack.upgradeAssistant.checkupTab.reindexing.flyout.warningsStep.documentationLinkLabel": "文档", - "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.cancelledLabel": "已取消", - "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.doneLabel": "完成", - "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.failedLabel": "失败", - "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.loadingLabel": "正在加载……", - "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.pausedLabel": "已暂停", - "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.reindexLabel": "重新索引", - "xpack.upgradeAssistant.checkupTab.tabDetail": "需要注意这些 {strongCheckupLabel} 问题。在升级到 Elasticsearch {nextEsVersion} 之前先解决这些问题。", - "xpack.upgradeAssistant.forbiddenErrorCallout.calloutTitle": "您没有足够的权限来查看此页。", - "xpack.upgradeAssistant.genericErrorCallout.calloutTitle": "检索检查结果时出错。", - "xpack.upgradeAssistant.overviewTab.overviewTabTitle": "概览", - "xpack.upgradeAssistant.overviewTab.steps.clusterStep.issuesRemainingStepTitle": "检查集群是否存在问题", - "xpack.upgradeAssistant.overviewTab.steps.clusterStep.noIssuesRemainingStepTitle": "您的集群设置已就绪", - "xpack.upgradeAssistant.overviewTab.steps.clusterStep.noRemainingIssuesLabel": "没有其余已弃用设置。", - "xpack.upgradeAssistant.overviewTab.steps.clusterStep.remainingIssuesDetail": "必须解决 {numIssues} 个问题。", - "xpack.upgradeAssistant.overviewTab.steps.clusterStep.todo.clusterTabButtonLabel": "“集群”选项卡", - "xpack.upgradeAssistant.overviewTab.steps.clusterStep.todo.todoDetail": "转到 {clusterTabButton} 并更新已弃用的设置。", - "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.deprecationLogs.deprecationLogsDocButtonLabel": "弃用日志", - "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.deprecationLogs.logsDetail": "请参阅 {deprecationLogsDocButton},了解您的应用程序使用的功能是否未在 {nextEsVersion} 中提供。您可能需要启用弃用日志。", - "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.enableDeprecationLoggingLabel": "是否启用弃用日志?", - "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.enableDeprecationLoggingToggleSwitch.disabledLabel": "关闭", - "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.enableDeprecationLoggingToggleSwitch.enabledLabel": "开启", - "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.enableDeprecationLoggingToggleSwitch.errorLabel": "无法加载日志状态", - "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.stepTitle": "查看 Elasticsearch 弃用日志", - "xpack.upgradeAssistant.overviewTab.steps.indicesStep.issuesRemainingStepTitle": "检查索引是否存在问题", - "xpack.upgradeAssistant.overviewTab.steps.indicesStep.noIssuesRemainingStepTitle": "您的索引设置已就绪", - "xpack.upgradeAssistant.overviewTab.steps.indicesStep.noRemainingIssuesLabel": "没有其余已弃用设置。", - "xpack.upgradeAssistant.overviewTab.steps.indicesStep.remainingIssuesDetail": "必须解决 {numIssues} 个问题。", - "xpack.upgradeAssistant.overviewTab.steps.indicesStep.todo.indicesTabButtonLabel": "“索引”选项卡", - "xpack.upgradeAssistant.overviewTab.steps.indicesStep.todo.todoDetail": "转到 {indicesTabButton} 并更新已弃用的设置。", - "xpack.upgradeAssistant.overviewTab.steps.startUpgradeStep.stepTitle": "开始升级", - "xpack.upgradeAssistant.overviewTab.steps.startUpgradeStepCloud.stepDetail.goToCloudDashboardDetail": "转到 Elastic Cloud 仪表板上的“部署”部分开始升级。", - "xpack.upgradeAssistant.overviewTab.steps.startUpgradeStepOnPrem.stepDetail.followInstructionsDetail": "按照 {instructionButton} 开始升级。", - "xpack.upgradeAssistant.overviewTab.steps.startUpgradeStepOnPrem.stepDetail.instructionButtonLabel": "以下说明", - "xpack.upgradeAssistant.overviewTab.steps.waitForReleaseStep.stepDetail": "版本发布后,请升级到最新的 {currentEsMajorVersion} 版本,然后返回此处,继续升级到 {nextEsMajorVersion}。", - "xpack.upgradeAssistant.overviewTab.steps.waitForReleaseStep.stepTitle": "等待 Elasticsearch {nextEsVersion} 发布版", - "xpack.upgradeAssistant.overviewTab.tabDetail": "此助理将帮助您为 Elasticsearch {nextEsVersion} 准备集群和索引。有关需要注意的其他问题,请参阅 Elasticsearch 日志。", - "xpack.upgradeAssistant.tabs.checkupTab.clusterLabel": "集群", - "xpack.upgradeAssistant.tabs.incompleteCallout.calloutBody.breackingChangesDocButtonLabel": "弃用内容和重大更改", - "xpack.upgradeAssistant.tabs.incompleteCallout.calloutBody.calloutDetail": "Elasticsearch {nextEsVersion} 中的 {breakingChangesDocButton} 完整列表将在最终的 {currentEsVersion} 次要版本中提供。完成列表后,此警告将消失。", - "xpack.upgradeAssistant.tabs.incompleteCallout.calloutTitle": "问题列表可能不完整", - "xpack.upgradeAssistant.tabs.upgradingInterstitial.upgradeCompleteDescription": "所有 Elasticsearch 节点已升级。可以现在升级 Kibana。", - "xpack.upgradeAssistant.tabs.upgradingInterstitial.upgradeCompleteTitle": "您的集群已升级", - "xpack.upgradeAssistant.tabs.upgradingInterstitial.upgradingDescription": "一个或多个 Elasticsearch 节点的 Elasticsearch 版本比 Kibana 版本新。所有节点升级后,请升级 Kibana。", - "xpack.upgradeAssistant.tabs.upgradingInterstitial.upgradingTitle": "您的集群正在升级", - "xpack.uptime.apmIntegrationAction.description": "在 APM 中搜索此监测", - "xpack.uptime.apmIntegrationAction.text": "在 APM 中查找域", - "xpack.uptime.badge.readOnly.text": "只读", - "xpack.uptime.badge.readOnly.tooltip": "无法保存", - "xpack.uptime.breadcrumbs.overviewBreadcrumbText": "运行时间", - "xpack.uptime.emptyState.configureHeartbeatLinkText": "配置 Heartbeat", - "xpack.uptime.emptyState.configureHeartbeatToGetStartedMessage": "{configureHeartbeatLink}以开始收集运行时间数据。", - "xpack.uptime.emptyState.loadingMessage": "正在加载……", - "xpack.uptime.emptyState.noDataTitle": "没有可用的运行时间数据", - "xpack.uptime.emptyStateError.title": "错误", - "xpack.uptime.errorMessage": "错误:{message}", - "xpack.uptime.featureCatalogueDescription": "执行终端节点运行状况检查和运行时间监测。", - "xpack.uptime.featureRegistry.uptimeFeatureName": "运行时间", - "xpack.uptime.filterBar.filterDownLabel": "关闭", - "xpack.uptime.filterBar.filterUpLabel": "运行", - "xpack.uptime.filterBar.options.location.name": "位置", - "xpack.uptime.filterBar.options.portLabel": "端口", - "xpack.uptime.filterBar.options.schemeLabel": "方案", - "xpack.uptime.integrationLink.missingDataMessage": "未找到此集成的所需数据。", - "xpack.uptime.monitorCharts.checkStatus.series.downCountLabel": "关闭计数", - "xpack.uptime.monitorCharts.checkStatus.series.upCountLabel": "运行计数", - "xpack.uptime.monitorCharts.checkStatus.title": "检查状态", - "xpack.uptime.monitorCharts.loadingMessage": "正在加载……", - "xpack.uptime.monitorCharts.monitorDuration.titleLabel": "监测持续时间(毫秒)", - "xpack.uptime.monitorList.downLineSeries.downLabel": "关闭", - "xpack.uptime.monitorList.infraIntegrationAction.container.message": "显示容器指标", - "xpack.uptime.monitorList.infraIntegrationAction.docker.description": "在 Infrastructure UI 上查找此监测的容器 ID", - "xpack.uptime.monitorList.infraIntegrationAction.docker.tooltip": "在 Infrastructure UI 上查找容器 ID“{containerId}”", - "xpack.uptime.monitorList.infraIntegrationAction.ip.ariaLabel": "在 Infrastructure UI 上查找此监测的 IP 地址", - "xpack.uptime.monitorList.infraIntegrationAction.ip.message": "显示主机指标", - "xpack.uptime.monitorList.infraIntegrationAction.ip.tooltip": "在 Infrastructure UI 上查找 IP“{ip}”", - "xpack.uptime.monitorList.infraIntegrationAction.kubernetes.description": "在 Infrastructure UI 上查找此监测的 Pod UID", - "xpack.uptime.monitorList.infraIntegrationAction.kubernetes.message": "显示 Pod 指标", - "xpack.uptime.monitorList.infraIntegrationAction.kubernetes.tooltip": "在 Infrastructure UI 上查找 Pod UID“{podUid}”", - "xpack.uptime.monitorList.integrationGroup.emptyMessage": "没有可用的集成应用程序", - "xpack.uptime.monitorList.loggingIntegrationAction.container.id": "显示容器日志", - "xpack.uptime.monitorList.loggingIntegrationAction.container.message": "显示容器日志", - "xpack.uptime.monitorList.loggingIntegrationAction.container.tooltip": "在 Logging UI 上查找容器 ID“{containerId}”", - "xpack.uptime.monitorList.loggingIntegrationAction.kubernetes.ariaLabel": "显示 Pod 日志", - "xpack.uptime.monitorList.loggingIntegrationAction.kubernetes.message": "显示 Pod 日志", - "xpack.uptime.monitorList.loggingIntegrationAction.kubernetes.tooltip": "查找 Pod UID“{podUid}”的日志", - "xpack.uptime.monitorList.monitorHistoryColumnLabel": "中断历史记录", - "xpack.uptime.monitorList.monitoringStatusTitle": "检测状态", - "xpack.uptime.monitorList.observabilityIntegrationsColumn.apmIntegrationLink.tooltip": "点击此处以在 APM 中查找“{domain}”。", - "xpack.uptime.monitorList.observabilityIntegrationsColumn.popoverIconButton.ariaLabel": "打开 url {monitorUrl} 的监测的集成弹出式窗口", - "xpack.uptime.monitorList.statusColumn.downLabel": "关闭", - "xpack.uptime.monitorList.statusColumn.upLabel": "运行", - "xpack.uptime.monitorList.statusColumnLabel": "状态", - "xpack.uptime.monitorStatusBar.durationTextAriaLabel": "监测持续时间(毫秒)", - "xpack.uptime.monitorStatusBar.healthStatusMessage.downLabel": "关闭", - "xpack.uptime.monitorStatusBar.healthStatusMessage.upLabel": "运行", - "xpack.uptime.monitorStatusBar.healthStatusMessageAriaLabel": "检测状态", - "xpack.uptime.monitorStatusBar.loadingMessage": "正在加载……", - "xpack.uptime.monitorStatusBar.monitorUrlLinkAriaLabel": "监测 URL 链接", - "xpack.uptime.monitorStatusBar.timestampFromNowTextAriaLabel": "自上次检查以来经过的时间", - "xpack.uptime.overviewPage.headerText": "概览", - "xpack.uptime.pingList.checkHistoryTitle": "历史记录", - "xpack.uptime.pingList.durationMsColumnLabel": "持续时间", - "xpack.uptime.pingList.errorTypeColumnLabel": "错误类型", - "xpack.uptime.pingList.ipAddressColumnLabel": "IP", - "xpack.uptime.pingList.recencyMessage": "{fromNow}已检查", - "xpack.uptime.pingList.responseCodeColumnLabel": "响应代码", - "xpack.uptime.pingList.statusColumnHealthDownLabel": "关闭", - "xpack.uptime.pingList.statusColumnHealthUpLabel": "运行", - "xpack.uptime.pingList.statusColumnLabel": "状态", - "xpack.uptime.pingList.statusLabel": "状态", - "xpack.uptime.pingList.statusOptions.allStatusOptionLabel": "全部", - "xpack.uptime.pingList.statusOptions.downStatusOptionLabel": "关闭", - "xpack.uptime.pingList.statusOptions.upStatusOptionLabel": "运行", - "xpack.uptime.pluginDescription": "运行时间监测", - "xpack.uptime.snapshot.noDataDescription": "抱歉,没有可用于该直方图的数据", - "xpack.uptime.snapshot.noDataTitle": "没有可用的直方图数据", - "xpack.uptime.snapshotHistogram.series.downLabel": "关闭", - "xpack.uptime.snapshotHistogram.series.upLabel": "运行", - "xpack.uptime.uptimeFeatureCatalogueTitle": "运行时间", - "xpack.uptime.emptyState.noDataMessage": "未找到任何运行时间数据", - "xpack.uptime.pingList.collapseRow": "折叠", - "xpack.uptime.pingList.durationMsColumnFormatting": "{millis} 毫秒", - "xpack.uptime.pingList.expandedRow.bodySize": "正文大小为 {bodyBytes}。", - "xpack.uptime.pingList.expandedRow.error": "错误", - "xpack.uptime.pingList.expandedRow.response_body": "响应正文", - "xpack.uptime.pingList.expandedRow.truncated": "显示前 {contentBytes} 字节。", - "xpack.uptime.pingList.expandRow": "展开", - "xpack.uptime.snapshot.pingsOverTimeTitle": "时移 Ping 数", - "xpack.uptime.snapshotHistogram.yAxis.title": "Ping", - "xpack.uptime.snapshot.donutChart.ariaLabel": "显示当前状态的饼图。{down} 个监测已关闭,共 {total} 个。", - "xpack.uptime.snapshot.donutChart.legend.downRowLabel": "关闭", - "xpack.uptime.snapshot.donutChart.legend.upRowLabel": "运行", - "xpack.uptime.durationChart.emptyPrompt.description": "在选定时间范围内此监测从未{emphasizedText}。", - "xpack.uptime.durationChart.emptyPrompt.title": "没有持续时间数据", - "xpack.uptime.emptyStateError.notAuthorized": "您无权查看 Uptime 数据,请联系系统管理员。", - "xpack.uptime.emptyStateError.notFoundPage": "未找到页面", - "xpack.uptime.filterPopout.loadingMessage": "正在加载……", - "xpack.uptime.filterPopout.searchMessage": "搜索 {title}", - "xpack.uptime.kueryBar.indexPatternMissingWarningMessage": "检索索引模式时出错。", - "xpack.uptime.kueryBar.searchPlaceholder": "搜索监测 ID、名称和协议类型......", - "xpack.uptime.monitorList.noItemForSelectedFiltersMessage": "未找到匹配选定筛选条件的监测", - "xpack.uptime.monitorList.table.description": "具有“状态”、“名称”、“URL”、“IP”、“中断历史记录”和“集成”列的“监测状态”表。该表当前显示 {length} 个项目。", - "xpack.uptime.notFountPage.homeLinkText": "返回主页", - "xpack.uptime.overviewPageLink.disabled.ariaLabel": "禁用的分页按钮表示在监测列表中无法进行进一步导航。", - "xpack.uptime.overviewPageLink.next.ariaLabel": "下页结果", - "xpack.uptime.overviewPageLink.prev.ariaLabel": "上页结果", - "xpack.uptime.overviewPageParsingErrorCallout.content": "解析筛选查询时出错。{content}", - "xpack.uptime.overviewPageParsingErrorCallout.noMessage": "没有错误消息", - "xpack.uptime.overviewPageParsingErrorCallout.title": "解析错误", - "xpack.uptime.snapshot.downCountsMessage": "{down}/{total} 个监测已关闭", - "xpack.uptime.snapshotHistogram.description": "显示从 {startTime} 到 {endTime} 的运行时间时移状态的条形图。", - "xpack.watcher.constants.actionStates.acknowledgedStateText": "已确认", - "xpack.watcher.constants.actionStates.configErrorStateText": "配置错误", - "xpack.watcher.constants.actionStates.errorStateText": "错误", - "xpack.watcher.constants.actionStates.firingStateText": "正在发送", - "xpack.watcher.constants.actionStates.okStateText": "确定", - "xpack.watcher.constants.actionStates.throttledStateText": "已限制", - "xpack.watcher.constants.watchStateComments.acknowledgedStateCommentText": "已确认", - "xpack.watcher.constants.watchStateComments.executionFailingStateCommentText": "执行失败", - "xpack.watcher.constants.watchStateComments.partiallyAcknowledgedStateCommentText": "已部分确认", - "xpack.watcher.constants.watchStateComments.partiallyThrottledStateCommentText": "已部分限制", - "xpack.watcher.constants.watchStateComments.throttledStateCommentText": "已限制", - "xpack.watcher.constants.watchStates.configErrorStateText": "配置错误", - "xpack.watcher.constants.watchStates.disabledStateText": "已禁用", - "xpack.watcher.constants.watchStates.errorStateText": "错误!", - "xpack.watcher.constants.watchStates.firingStateText": "正在发送", - "xpack.watcher.constants.watchStates.okStateText": "确定", - "xpack.watcher.models.actionStatus.notDetermineActionStatusBadImplementationMessage": "无法确定操作状态;操作 = {actionStatusJson}", - "xpack.watcher.models.baseAction.selectMessageText": "执行操作。", - "xpack.watcher.models.baseAction.simulateButtonLabel": "立即模拟此操作", - "xpack.watcher.models.baseAction.simulateMessage": "已成功模拟操作 {id}", - "xpack.watcher.models.baseAction.typeName": "操作", - "xpack.watcher.models.baseWatch.createUnknownActionTypeErrorMessage": "尝试创建的操作类型 {type} 未知。", - "xpack.watcher.models.baseWatch.displayName": "新建监视", - "xpack.watcher.models.baseWatch.idPropertyMissingBadRequestMessage": "json 参数必须包含 {id} 属性", - "xpack.watcher.models.baseWatch.selectMessageText": "设置新监视。", - "xpack.watcher.models.baseWatch.typeName": "监视", - "xpack.watcher.models.baseWatch.watchJsonPropertyMissingBadRequestMessage": "json 参数必须包含 {watchJson} 属性", - "xpack.watcher.models.baseWatch.watchStatusJsonPropertyMissingBadRequestMessage": "json 参数必须包含 {watchStatusJson} 属性", - "xpack.watcher.models.emailAction.actionJsonEmailPropertyMissingBadRequestMessage": "json 参数必须包含 {actionJsonEmail} 属性", - "xpack.watcher.models.emailAction.actionJsonEmailToPropertyMissingBadRequestMessage": "json 参数必须包含 {actionJsonEmailTo} 属性", - "xpack.watcher.models.emailAction.selectMessageText": "从您的服务器发送电子邮件。", - "xpack.watcher.models.emailAction.simulateButtonLabel": "立即试发电子邮件", - "xpack.watcher.models.emailAction.simulateFailMessage": "无法将电子邮件发至 {toList}。", - "xpack.watcher.models.emailAction.simulateMessage": "已发至 {toList} 的电子邮件示例", - "xpack.watcher.models.emailAction.typeName": "电子邮件", - "xpack.watcher.models.fields.fieldsPropertyMissingBadRequestMessage": "json 参数必须包含 {fields} 属性", - "xpack.watcher.models.indexAction.simulateFailMessage": "无法索引 {index}", - "xpack.watcher.models.indexAction.simulateMessage": "已对索引 {index} 进行索引。", - "xpack.watcher.models.jiraAction.simulateFailMessage": "无法创建 Jira 问题。", - "xpack.watcher.models.jiraAction.simulateMessage": "Jira 问题已创建。", - "xpack.watcher.models.jsonWatch.selectMessageText": "以原始 JSON 格式设置定制监视。", - "xpack.watcher.models.jsonWatch.typeName": "高级监视", - "xpack.watcher.models.loggingAction.actionJsonLoggingPropertyMissingBadRequestMessage": "json 参数必须包含 {actionJsonLogging} 属性", - "xpack.watcher.models.loggingAction.actionJsonLoggingTextPropertyMissingBadRequestMessage": "json 参数必须包含 {actionJsonLoggingText} 属性", - "xpack.watcher.models.loggingAction.selectMessageText": "向日志添加新项。", - "xpack.watcher.models.loggingAction.simulateButtonLabel": "立即记录示例消息", - "xpack.watcher.models.loggingAction.simulateFailMessage": "无法记录示例消息。", - "xpack.watcher.models.loggingAction.simulateMessage": "示例消息已记录", - "xpack.watcher.models.loggingAction.typeName": "日志", - "xpack.watcher.models.monitoringWatch.formatVisualizeDataCalledBadRequestMessage": "为监测监视而调用的 {formatVisualizeData}", - "xpack.watcher.models.monitoringWatch.fromDownstreamJsonCalledBadRequestMessage": "为监测监视而调用的 {fromDownstreamJson}", - "xpack.watcher.models.monitoringWatch.getVisualizeQueryCalledBadRequestMessage": "为监测监视而调用的 {getVisualizeQuery}", - "xpack.watcher.models.monitoringWatch.upstreamJsonCalledBadRequestMessage": "为监测监视而调用的 {upstreamJson}", - "xpack.watcher.models.pagerDutyAction.simulateFailMessage": "无法发送 Hipchat 事件。", - "xpack.watcher.models.pagerDutyAction.simulateMessage": "PagerDuty 事件已发送。", - "xpack.watcher.models.slackAction.actionJsonSlackMessagePropertyMissingBadRequestMessage": "json 参数必须包含 {actionJsonSlackMessage} 属性", - "xpack.watcher.models.slackAction.actionJsonSlackPropertyMissingBadRequestMessage": "json 参数必须包含 {actionJsonSlack} 属性", - "xpack.watcher.models.slackAction.selectMessageText": "向 slack 用户或渠道发送消息。", - "xpack.watcher.models.slackAction.simulateButtonLabel": "立即发送示例消息", - "xpack.watcher.models.slackAction.simulateFailMessage": "无法将示例 Slack 消息发至 {toList}。", - "xpack.watcher.models.slackAction.simulateMessage": "已发送至 {toList} 的示例 Slack 消息。", - "xpack.watcher.models.slackAction.TypeName": "Slack", - "xpack.watcher.models.thresholdWatch.selectMessageText": "在特定条件下发送告警", - "xpack.watcher.models.thresholdWatch.sendAlertOnSpecificConditionTitleDescription": "满足特定条件时发送告警。", - "xpack.watcher.models.thresholdWatch.thresholdWatchIntervalTitleDescription": "这将每 {triggerIntervalSize} {timeUnitLabel}运行一次。", - "xpack.watcher.models.thresholdWatch.typeName": "阈值告警", - "xpack.watcher.models.unknownAction.actionJsonPropertyMissingBadRequestMessage": "json 参数必须包含 {actionJson} 属性", - "xpack.watcher.models.watch.typePropertyMissingBadRequestMessage": "json 参数必须包含 {type} 属性", - "xpack.watcher.models.watch.unknownWatchTypeLoadingAttemptBadRequestMessage": "尝试加载的类型 {jsonType} 未知", - "xpack.watcher.models.watch.watchJsonPropertyMissingBadRequestMessage": "json 参数必须包含 {watchJson} 属性", - "xpack.watcher.models.watchHistoryItem.idPropertyMissingBadRequestMessage": "json 参数必须包含 {id} 属性", - "xpack.watcher.models.watchHistoryItem.watchHistoryItemJsonPropertyMissingBadRequestMessage": "json 参数必须包含 {watchHistoryItemJson} 属性", - "xpack.watcher.models.watchHistoryItem.watchIdPropertyMissingBadRequestMessage": "json 参数必须包含 {watchId} 属性", - "xpack.watcher.models.watchStatus.idPropertyMissingBadRequestMessage": "json 参数必须包含 {id} 属性", - "xpack.watcher.models.watchStatus.watchStatusJsonPropertyMissingBadRequestMessage": "json 参数必须包含 {watchStatusJson} 属性", - "xpack.watcher.models.webhookAction.simulateFailMessage": "无法将请求发送至 {fullPath}", - "xpack.watcher.models.webhookAction.simulateMessage": "样例请求已发送到 {fullPath}", - "xpack.watcher.sections.watchEdit.json.editTabLabel": "编辑", - "xpack.watcher.sections.watchEdit.json.saveSuccessNotificationText": "已保存“{watchDisplayName}”", - "xpack.watcher.sections.watchEdit.json.simulateTabLabel": "模拟", - "xpack.watcher.sections.watchEdit.threshold.saveButtonLabel": "保存", - "xpack.watcher.sections.watchEdit.titlePanel.howToBroadenSearchQueryDescription": "使用 * 拓宽您的搜索查询", - "xpack.watcher.sections.watchEdit.titlePanel.indicesToQueryLabel": "要查询的索引", - "xpack.watcher.sections.watchEdit.titlePanel.timeFieldLabel": "时间字段", - "xpack.watcher.sections.watchEdit.titlePanel.timeFieldOptionLabel": "选择字段", - "xpack.watcher.sections.watchEdit.titlePanel.watchIntervalLabel": "运行监视的频率", - "xpack.watcher.sections.watchEdit.titlePanel.watchNameLabel": "名称", - "xpack.watcher.sections.watchList.createAdvancedWatchButtonLabel": "创建高级监视", - "xpack.watcher.sections.watchList.createAdvancedWatchTooltip": "以原始 JSON 格式设置定制监视", - "xpack.watcher.sections.watchList.createThresholdAlertButtonLabel": "创建阈值告警", - "xpack.watcher.sections.watchList.createThresholdAlertButtonTooltip": "在特定条件下发送告警", - "xpack.watcher.sections.watchList.header": "创建阈值告警", - "xpack.watcher.sections.watchList.managementSection.editDisplayName": "编辑", - "xpack.watcher.sections.watchList.managementSection.newWatchDisplayName": "新建监视", - "xpack.watcher.sections.watchList.managementSection.statusDisplayName": "状态", - "xpack.watcher.sections.watchList.managementSection.watcherDisplayName": "Watcher", - "xpack.watcher.sections.watchList.managementSection.watchesDisplayName": "监视", - "xpack.watcher.sections.watchList.subhead": "特定参数命中时,发出电子邮件、Slack 消息和日志事件", - "xpack.watcher.thresholdPreviewChart.dataDoesNotExistTextMessage": "您的索引和条件未返回任何数据", - "xpack.watcher.thresholdWatchExpression.comparators.isAboveLabel": "高于", - "xpack.watcher.thresholdWatchExpression.comparators.isBelowLabel": "低于", - "xpack.watcher.thresholdWatchExpression.fixErrorInExpressionBelowValidationMessage": "请解决如下表达式中的错误。", - "xpack.watcher.thresholdWatchExpression.groupBy.requiredFieldValidationMessage": "请选择字段。", - "xpack.watcher.thresholdWatchExpression.groupByLabel.allDocumentsLabel": "所有文档", - "xpack.watcher.thresholdWatchExpression.groupByLabel.topLabel": "顶部", - "xpack.watcher.thresholdWatchExpression.thresholdLevel.valueIsRequiredValidationMessage": "需要值。", - "xpack.watcher.thresholdWatchExpression.timeWindow.durationSizeIsRequiredValidationMessage": "“窗口持续时间大小”必填。", - "xpack.watcher.watchActions.logging.logTextIsRequiredValidationMessage": "“日志文本”必填。", - "xpack.watcher.watcherDescription": "通过创建、管理和监测警报来检测数据中的更改。", - "xpack.watcher.requestFlyout.closeButtonLabel": "关闭", - "xpack.watcher.requestFlyout.descriptionText": "此 Elasticsearch 请求将创建或更新此监视。", - "xpack.watcher.requestFlyout.namedTitle": "对“{id}”的请求", - "xpack.watcher.requestFlyout.unnamedTitle": "请求", - "xpack.watcher.sections.watchEdit.json.hideRequestButtonLabel": "隐藏请求", - "xpack.watcher.sections.watchEdit.json.showRequestButtonLabel": "显示请求", - "esUi.cronEditor.cronDaily.fieldHour.textAtLabel": "在", - "esUi.cronEditor.cronDaily.fieldTimeLabel": "时间", - "esUi.cronEditor.cronHourly.fieldMinute.textAtLabel": "在", - "esUi.cronEditor.cronHourly.fieldTimeLabel": "分钟", - "esUi.cronEditor.cronMonthly.fieldDateLabel": "日期", - "esUi.cronEditor.cronMonthly.fieldHour.textAtLabel": "在", - "esUi.cronEditor.cronMonthly.fieldTimeLabel": "时间", - "esUi.cronEditor.cronMonthly.textOnTheLabel": "处于", - "esUi.cronEditor.cronWeekly.fieldDateLabel": "天", - "esUi.cronEditor.cronWeekly.fieldHour.textAtLabel": "在", - "esUi.cronEditor.cronWeekly.fieldTimeLabel": "时间", - "esUi.cronEditor.cronWeekly.textOnLabel": "开启", - "esUi.cronEditor.cronYearly.fieldDate.textOnTheLabel": "处于", - "esUi.cronEditor.cronYearly.fieldDateLabel": "日期", - "esUi.cronEditor.cronYearly.fieldHour.textAtLabel": "在", - "esUi.cronEditor.cronYearly.fieldMonth.textInLabel": "于", - "esUi.cronEditor.cronYearly.fieldMonthLabel": "月", - "esUi.cronEditor.cronYearly.fieldTimeLabel": "时间", - "esUi.cronEditor.day.friday": "星期五", - "esUi.cronEditor.day.monday": "星期一", - "esUi.cronEditor.day.saturday": "星期六", - "esUi.cronEditor.day.sunday": "星期日", - "esUi.cronEditor.day.thursday": "星期四", - "esUi.cronEditor.day.tuesday": "星期二", - "esUi.cronEditor.day.wednesday": "星期三", - "esUi.cronEditor.fieldFrequencyLabel": "频率", - "esUi.cronEditor.month.april": "四月", - "esUi.cronEditor.month.august": "八月", - "esUi.cronEditor.month.december": "十二月", - "esUi.cronEditor.month.february": "二月", - "esUi.cronEditor.month.january": "一月", - "esUi.cronEditor.month.july": "七月", - "esUi.cronEditor.month.june": "六月", - "esUi.cronEditor.month.march": "三月", - "esUi.cronEditor.month.may": "五月", - "esUi.cronEditor.month.november": "十一月", - "esUi.cronEditor.month.october": "十月", - "esUi.cronEditor.month.september": "九月", - "esUi.cronEditor.textEveryLabel": "所有", - "esUi.cronEditor.cronDaily.hourSelectLabel": "小时", - "esUi.cronEditor.cronDaily.minuteSelectLabel": "分钟", - "esUi.cronEditor.cronMonthly.hourSelectLabel": "小时", - "esUi.cronEditor.cronMonthly.minuteSelectLabel": "分钟", - "esUi.cronEditor.cronWeekly.hourSelectLabel": "小时", - "esUi.cronEditor.cronWeekly.minuteSelectLabel": "分钟", - "esUi.cronEditor.cronYearly.hourSelectLabel": "小时", - "esUi.cronEditor.cronYearly.minuteSelectLabel": "分钟", - "esUi.forms.comboBoxField.placeHolderText": "键入内容然后按“ENTER”键", - "esUi.forms.fieldValidation.indexNameInvalidCharactersError": "索引名称包含无效的{characterListLength, plural, one {字符} other {字符}} { characterList }。", - "esUi.forms.fieldValidation.indexNameSpacesError": "索引名称不能包含空格。", - "esUi.forms.fieldValidation.indexNameStartsWithDotError": "索引名称不能以点 (.) 开头。", - "esUi.forms.fieldValidation.indexPatternInvalidCharactersError": "索引模式包含无效的{characterListLength, plural, one {字符} other {字符}} { characterList }。", - "esUi.forms.fieldValidation.indexPatternSpacesError": "索引模式不能包含空格。", - "visTypeMarkdown.tabs.dataText": "数据", - "visTypeMarkdown.tabs.optionsText": "选项", - "visTypeMarkdown.params.fontSizeLabel": "基础字体大小(磅)", - "xpack.actions.actionTypeRegistry.get.missingActionTypeErrorMessage": "未注册操作类型“{id}”。", - "xpack.actions.actionTypeRegistry.register.duplicateActionTypeErrorMessage": "操作类型“{id}”已注册。", - "xpack.actions.builtin.slack.unexpectedNullResponseErrorMessage": "来自 slack 的异常空响应", - "xpack.actions.builtin.webhook.webhookConfigurationError": "配置 Webhook 操作时出错:{message}", - "xpack.actions.urlWhitelistConfigurationError": "目标 {field}“{value}”不在 Kibana 白名单中", - "xpack.advancedUiActions.customizePanelTimeRange.modal.addToPanelButtonTitle": "添加到面板", - "xpack.advancedUiActions.customizePanelTimeRange.modal.cancelButtonTitle": "取消", - "xpack.advancedUiActions.customizePanelTimeRange.modal.optionsMenuForm.panelTitleFormRowLabel": "时间范围", - "xpack.advancedUiActions.customizePanelTimeRange.modal.removeButtonTitle": "删除", - "xpack.advancedUiActions.customizePanelTimeRange.modal.updatePanelTimeRangeButtonTitle": "更新", - "xpack.advancedUiActions.customizeTimeRange.modal.headerTitle": "定制面板时间范围", - "xpack.advancedUiActions.customizeTimeRangeMenuItem.displayName": "定制时间范围", - "xpack.fileUpload.fileParser.errorReadingFile": "读取文件时出错", - "xpack.fileUpload.fileParser.noFileProvided": "错误,未提供任何文件", - "xpack.fileUpload.fileParser.noFeaturesDetected": "错误,未检测到功能", - "xpack.fileUpload.jsonIndexFilePicker.fileParseError": "检测到文件解析错误:{error}", - "xpack.fileUpload.jsonIndexFilePicker.fileProcessingError": "文件处理错误:{errorMessage}", - "xpack.fileUpload.jsonIndexFilePicker.fileSizeError": "文件大小错误:{errorMessage}", - "xpack.fileUpload.jsonUploadAndParse.indexingComplete": "索引完成!", - "xpack.fileUpload.patternReader.featuresOmitted": "不具有几何形状的一些特征已省略", - "xpack.fileUpload.jsonIndexFilePicker.acceptableFileSize": "文件大小 {fileSize} 超过最大文件大小 {maxFileSize}", - "xpack.fileUpload.jsonIndexFilePicker.parsingFile": "{featuresProcessed} 特征已解析......", + "timelion.badge.readOnly.text": "只读", + "timelion.badge.readOnly.tooltip": "无法保存 Timelion 工作表", + "timelion.breadcrumbs.create": "创建", + "timelion.breadcrumbs.root": "Timelion", + "timelion.cells.actions.fullscreenAriaLabel": "全屏图表", + "timelion.cells.actions.fullscreenTooltip": "全屏", + "timelion.cells.actions.removeAriaLabel": "删除图表", + "timelion.cells.actions.removeTooltip": "删除", + "timelion.cells.actions.reorderAriaLabel": "拖动以重新排序", + "timelion.cells.actions.reorderTooltip": "拖动以重新排序", + "timelion.chart.seriesList.noSchemaWarning": "没有此类面板类型:{renderType}", + "timelion.emptyExpressionErrorMessage": "Timelion 错误:未提供表达式", + "timelion.expressionInputAriaLabel": "Timelion 表达式", + "timelion.expressionInputPlaceholder": "请尝试使用 {esQuery} 查询", + "timelion.expressionSuggestions.arg.infoTitle": "信息", + "timelion.expressionSuggestions.arg.listTitle": "参数:", + "timelion.expressionSuggestions.arg.nameTitle": "参数类型", + "timelion.expressionSuggestions.arg.typesTitle": "接受的类型", + "timelion.expressionSuggestions.func.description.chainableText": "{help}(可链接)", + "timelion.expressionSuggestions.func.description.dataSourceText": "{help}(数据源)", + "timelion.fitFunctions.carry.downSampleErrorMessage": "请勿使用“carry”拟合方法下采样,而是使用“scale”或“average”", + "timelion.fullscreen.exitAriaLabel": "退出全屏", + "timelion.fullscreen.exitTooltip": "退出全屏", + "timelion.function.help": "Timelion 可视化", + "timelion.help.configuration.firstTimeConfigurationLinkText": "首次配置", + "timelion.help.configuration.notValid.advancedSettingsPathText": "管理/Kibana/高级设置", + "timelion.help.configuration.notValid.notValidSettingsErrorMessage": "无法验证 Elasticsearch 设置:{reason}。请检查您的高级设置,然后重试。({count})", + "timelion.help.configuration.notValid.paragraph1": "如果使用的是 Logstash,则无需配置任何内容即可开始使用 Timelion 浏览日志数据。要搜索其他索引,请转到 {advancedSettingsPath},然后配置 {esDefaultIndex} 和 {esTimefield} 设置以匹配您的索引。", + "timelion.help.configuration.notValid.paragraph2": "您还会看到一些其他 Timelion 设置。您现在无需担心这些设置。稍后就会发现,您可以根据需要即时设置其中大部分的设置。", + "timelion.help.configuration.notValid.validateButtonLabel": "验证配置", + "timelion.help.configuration.notValidTitle": "首次配置", + "timelion.help.configuration.valid.advancedSettingsPathText": "管理/Kibana/高级设置", + "timelion.help.configuration.valid.intervalIsAutoText": "全部准备就绪!", + "timelion.help.configuration.valid.intervals.content.intervalIsNotAutoText": "将其设为 {auto} 以允许 Timelion 选择适当的间隔。", + "timelion.help.configuration.valid.intervalsTextPart1": "输入栏右侧的间隔选择器可让您控制采样频率。当前设为 {interval}。", + "timelion.help.configuration.valid.intervalsTextPart2": "如果 Timelion 认为您的时间范围和间隔组合生成的数据点过多,将引发一个错误。您可以通过在 {advancedSettingsPath} 中配置 {maxBuckets} 来调整该限制。", + "timelion.help.configuration.valid.intervalsTitle": "间隔", + "timelion.help.configuration.valid.paragraph1Part1": "我们已验证您的默认索引、时间字段及所有设置均正确无误。我们找到了范围介于 {statsMin} 到 {statsMax} 之间的数据。您大概已准备就绪。如果有错误,请参阅", + "timelion.help.configuration.valid.paragraph1Part2": ",了解有关配置 Elasticsearch 数据源的信息。", + "timelion.help.configuration.valid.paragraph2": "您应该能看到一个图表,但还需要做一些调整才能看到所有感兴趣的数据:", + "timelion.help.configuration.valid.paragraph3": "现在,您应看到一个数据点计数随时间变化的折线图。", + "timelion.help.configuration.valid.timeRangeText": "使用 Kibana 工具栏中的时间选择器,选择包含要可视化数据的时间段。请确保选择包含上述所示的全部或部分时间范围的时间段。", + "timelion.help.configuration.valid.timeRangeTitle": "时间范围", + "timelion.help.configuration.validTitle": "真棒,Elasticsearch 配置正确!", + "timelion.help.dataTransforming.functionReferenceLinkText": "函数引用", + "timelion.help.dataTransforming.paragraph1": "至此,您已经掌握了基础知识,接下来开始体验 Timelion 的强大功能。让我们来计算一段时间内部分数据子集占整体数量的百分比。例如,我们的 Web 流量中有多少来自美国?", + "timelion.help.dataTransforming.paragraph2": "首先,我们需要查找包含 US 的所有事件:{esUsQuery}。", + "timelion.help.dataTransforming.paragraph3": "接下来,要计算 US 事件与所有事件之比。要将 {us} 除以总值,我们可以使用 {divide} 函数:{divideDataQuery}。", + "timelion.help.dataTransforming.paragraph4": "还不错,但这是一个介于 0 到 1 之间的数字。要将其转换为百分比,只需乘以 100:{multiplyDataQuery}。", + "timelion.help.dataTransforming.paragraph5": "现在,我们知道了其中美国流量所占的百分比,并且可以看到其随时间的变化情况!Timelion 具有很多内置算术函数,例如 {sum}、{subtract}、{multiply} 和 {divide}。其中很多函数可以采用一个序列或一个数字。此外,还有其他有用的数据转换函数,例如 {movingaverage}、{abs} 和 {derivative}。", + "timelion.help.dataTransforming.paragraph6Part1": "现在您已熟悉了语法,然后,请参阅", + "timelion.help.dataTransforming.paragraph6Part2": ",了解如何使用所有可用的 Timelion 函数。您可以单击 Kibana 工具栏上的 \\{Docs\\},随时查看参考资料。要返回此教程,请单击参考资料顶部的 \\{Tutorial\\} 链接。", + "timelion.help.dataTransformingTitle": "转换您的数据:真正的乐趣所在!", + "timelion.help.dontShowHelpButtonLabel": "不再显示此内容", + "timelion.help.expressions.examples.customStylingDescription": "{descriptionTitle}将第一个序列着色为红色,并为第二个序列使用 1 像素宽的条。", + "timelion.help.expressions.examples.customStylingDescriptionTitle": "定制样式。", + "timelion.help.expressions.examples.groupedExpressionsDescription": "{descriptionTitle}您还可以将表达式组链接到函数。这里两个序列都显示为圈点,而不是线。", + "timelion.help.expressions.examples.groupedExpressionsDescriptionTitle": "将表达式分组。", + "timelion.help.expressions.examples.namedArgumentsDescription": "{descriptionTitle}请不要尝试记住指定参数所需的顺序,使用命名参数可使表达式更易于读写。", + "timelion.help.expressions.examples.namedArgumentsDescriptionTitle": "命名参数。", + "timelion.help.expressions.examples.twoExpressionsDescription": "{descriptionTitle}同一个图表上的两个表达式。", + "timelion.help.expressions.examples.twoExpressionsDescriptionTitle": "乐趣倍增。", + "timelion.help.expressions.functionReferenceLinkText": "函数引用", + "timelion.help.expressions.paragraph1": "每个表达式都以一个数据源函数开头。接着,您可以对数据源附加新函数,以对其进行转换和增强。", + "timelion.help.expressions.paragraph2": "对了,从现在开始,您可能比我们更了解自己的数据。可以随意将示例查询替换为更有意义的内容!", + "timelion.help.expressions.paragraph3": "接下来我们开始进行实验,请单击 Kibana 工具栏中的 {strongAdd} 添加另一个或第三个图表。然后,选择一个图表,复制下列其中一个表达式,粘贴到输入栏,然后按 Enter 键。清除,再重复上述操作来尝试其他表达式。", + "timelion.help.expressions.paragraph4": "Timelion 还提供了很多视图转换函数,可用于定制图表的外观。有关完整列表,请参阅", + "timelion.help.expressions.strongAddText": "添加", + "timelion.help.expressionsTitle": "使用表达式表达您自己", + "timelion.help.functions.absHelpText": "返回序列列表中每个值的绝对值", + "timelion.help.functions.aggregate.args.functionHelpText": "以下选项之一:{functions}", + "timelion.help.functions.aggregateHelpText": "基于对序列中所有点的处理结果创建静态线。可用函数:{functions}", + "timelion.help.functions.bars.args.stackHelpText": "条应堆叠,默认情况下为 true", + "timelion.help.functions.bars.args.widthHelpText": "条宽(以像素为单位)", + "timelion.help.functions.barsHelpText": "将 seriesList 显示为条", + "timelion.help.functions.color.args.colorHelpText": "序列颜色,以十六进制为单位,例如,#c6c6c6 表示雅致的浅灰色。如果您指定多种颜色,并有多个序列,可生成渐变色,例如,“#00B1CC:#00FF94:#FF3A39:#CC1A6F”", + "timelion.help.functions.colorHelpText": "更改序列颜色", + "timelion.help.functions.common.args.fitHelpText": "用于将序列拟合到目标时间跨度和间隔的算法。可用:{fitFunctions}", + "timelion.help.functions.common.args.offsetHelpText": "通过日期表达式(例如 -1M)偏移序列检索,使一个月前的事件看起来好像正在发生一样。通过使用值“timerange”,可以相对于图表整体时间范围来偏移序列。例如,“timerange:-2”将指定一个是过去图表整体时间范围两倍的偏移量。", + "timelion.help.functions.condition.args.elseHelpText": "比较为 false 时要将该点设置成的值。如果在此处传递 seriesList,将使用第一个序列", + "timelion.help.functions.condition.args.ifHelpText": "要与该点进行比较的值。如果在此处传递 seriesList,将使用第一个序列", + "timelion.help.functions.condition.args.operator.suggestions.eqHelpText": "等于", + "timelion.help.functions.condition.args.operator.suggestions.gteHelpText": "大于等于", + "timelion.help.functions.condition.args.operator.suggestions.gtHelpText": "大于", + "timelion.help.functions.condition.args.operator.suggestions.lteHelpText": "小于等于", + "timelion.help.functions.condition.args.operator.suggestions.ltHelpText": "小于", + "timelion.help.functions.condition.args.operator.suggestions.neHelpText": "不等于", + "timelion.help.functions.condition.args.operatorHelpText": "用于比较的比较运算符,有效运算符包括 eq(等于)、ne(不等于)、lt(小于)、lte(小于等于)、gt(大于)、gte(大于等于)", + "timelion.help.functions.condition.args.thenHelpText": "比较为 true 时要将该点设置成的值。如果在此处传递 seriesList,将使用第一个序列", + "timelion.help.functions.conditionHelpText": "使用运算符将每个点与另一个序列中的数字或相同点进行比较,然后在条件证明为 true 时将其值设置为该结果,且使用可选的 else。", + "timelion.help.functions.cusum.args.baseHelpText": "起始数字。基本上只会将此值添加到序列的开头", + "timelion.help.functions.cusumHelpText": "从基数开始,返回序列的累计和。", + "timelion.help.functions.derivativeHelpText": "绘制值随时间的变化。", + "timelion.help.functions.divide.args.divisorHelpText": "要除以的数字或序列。具有多个序列的 seriesList 将按标签方式应用。", + "timelion.help.functions.divideHelpText": "将 seriesList 中一个或多个序列的值除以输入 seriesList 的每个序列中的每个位置", + "timelion.help.functions.es.args.indexHelpText": "要查询的索引,接受通配符。在提供 metrics、split 和 timefield 参数建议之前,请先提供脚本字段的索引模式名称和字段名称类型。", + "timelion.help.functions.es.args.intervalHelpText": "**DO NOT USE THIS**.调试拟合函数很有趣,但建议您应使用间隔选择器", + "timelion.help.functions.es.args.kibanaHelpText": "在 Kibana 仪表板上使用筛选。仅当在 Kibana 仪表板上使用时才有效", + "timelion.help.functions.es.args.metricHelpText": "Elasticsearch 指标汇总:avg、sum、min、max、percentiles 或 cardinality,后跟一个字段。例如,“sum:bytes”、“percentiles:bytes:95,99,99.9”,或仅“count”", + "timelion.help.functions.es.args.qHelpText": "采用 lucene 查询字符串语法的查询", + "timelion.help.functions.es.args.splitHelpText": "Elasticsearch 字段用于拆分序列和设置限制。例如,“{hostnameSplitArg}” 用于获取前 10 个主机名", + "timelion.help.functions.es.args.timefieldHelpText": "用于 X 轴的“date”类型的字段", + "timelion.help.functions.esHelpText": "从 Elasticsearch 实例拉取数据", + "timelion.help.functions.firstHelpText": "这是内部函数,只返回输入 seriesList。请勿使用此选项", + "timelion.help.functions.fit.args.modeHelpText": "用于将序列拟合到目标的算法。以下选项之一:{fitFunctions}", + "timelion.help.functions.fitHelpText": "使用已定义的拟合函数填充 null 值", + "timelion.help.functions.graphite.args.metricHelpText": "要拉取的 Graphite 指标,例如 {metricExample}", + "timelion.help.functions.graphiteHelpText": "[实验] 从 Graphite 拉取数据。在 Kibana 的“高级设置”中配置 Graphite 服务器", + "timelion.help.functions.hide.args.hideHelpText": "隐藏或取消隐藏序列", + "timelion.help.functions.hideHelpText": "默认隐藏序列", + "timelion.help.functions.holt.args.alphaHelpText": "\n 平滑权重,0 到 1。\n 增加 alpha 值会使新序列更接近原始序列。\n 降低 alpha 值会使序列更平滑", + "timelion.help.functions.holt.args.betaHelpText": "\n 趋势权重,0 到 1。\n 增加 beta 值会使上升/下降的线条继续上升/下降更长。\n 降低 beta 值会使函数更快地学习新趋势", + "timelion.help.functions.holt.args.gammaHelpText": "季节性权重,0 到 1。您的数据是不是看起来像波形?\n 增加此值会使最近的季节更加重要,从而更快地改变波形。\n 降低此值会使新季节的重要性下降,使历史数据更加重要。", + "timelion.help.functions.holt.args.sampleHelpText": "\n 在季节性序列中开始“预测”前要采样的季节数。\n (仅适用于 gamma,默认值:all)", + "timelion.help.functions.holt.args.seasonHelpText": "季节的时长,例如,如果模式每周重复一次,则为 1w。(仅适用于 gamma)", + "timelion.help.functions.holtHelpText": "\n 对序列开头采样,并通过多个可选参数用它来\n 预测后续事件。通常,此方法不会真正预测未来,\n 而是根据过去的数据预测当前会发生的事件,\n 这对于异常检测很有帮助。注意,将使用预测值填充 null 值。", + "timelion.help.functions.label.args.labelHelpText": "序列的图例值。您可以在字符串中使用 $1、$2 等来匹配正则表达式捕获组", + "timelion.help.functions.label.args.regexHelpText": "支持捕获组的正则表达式", + "timelion.help.functions.labelHelpText": "更改序列标签。使用 %s 引用现有标签", + "timelion.help.functions.legend.args.columnsHelpText": "要将图例划分为的列数", + "timelion.help.functions.legend.args.position.suggestions.falseHelpText": "禁用图例", + "timelion.help.functions.legend.args.position.suggestions.neHelpText": "将图例放在东北角", + "timelion.help.functions.legend.args.position.suggestions.nwHelpText": "将图例放在西北角", + "timelion.help.functions.legend.args.position.suggestions.seHelpText": "将图例放在东南角", + "timelion.help.functions.legend.args.position.suggestions.swHelpText": "将图例放在西南角", + "timelion.help.functions.legend.args.positionHelpText": "放置图例的角:nw、ne、se 或 sw。您还可以传递 false 来禁用图例", + "timelion.help.functions.legend.args.showTimeHelpText": "悬停在图表上方时在图例中显示时间值。默认值:true", + "timelion.help.functions.legend.args.timeFormatHelpText": "moment.js 格式模式。默认值:{defaultTimeFormat}", + "timelion.help.functions.legendHelpText": "设置绘图上图例的位置和样式", + "timelion.help.functions.lines.args.fillHelpText": "介于 0 到 10 之间的数字。用于绘制面积图", + "timelion.help.functions.lines.args.showHelpText": "显示或隐藏线条", + "timelion.help.functions.lines.args.stackHelpText": "堆叠线条,通常会产生误导。如果使用此选项,请至少使用一些填充色。", + "timelion.help.functions.lines.args.stepsHelpText": "以步长显示线条,例如,不在点之间内插", + "timelion.help.functions.lines.args.widthHelpText": "线条粗细", + "timelion.help.functions.linesHelpText": "将 seriesList 显示为线条", + "timelion.help.functions.log.args.baseHelpText": "设置对数底数,默认为 10", + "timelion.help.functions.logHelpText": "返回序列列表中每个值的对数值(默认底数:10)", + "timelion.help.functions.max.args.valueHelpText": "将点设置为较大的值,即现有值或传递的值。如果传递 seriesList,则其必须只包含 1 个序列。", + "timelion.help.functions.maxHelpText": "将 seriesList 中的一个或多个序列的最大值加到输入 seriesList 的每个序列中的每个位置", + "timelion.help.functions.min.args.valueHelpText": "将点设置为较小的值,即现有值或传递的值。如果传递 seriesList,则其必须只包含 1 个序列。", + "timelion.help.functions.minHelpText": "seriesList 中一个或多个序列的最小值加到输入 seriesList 的每个序列中的每个位置", + "timelion.help.functions.movingaverage.args.positionHelpText": "平均点相对于结果时间的位置。以下选项之一:{validPositions}", + "timelion.help.functions.movingaverage.args.windowHelpText": "点数量,或用于求平均值的日期数学表达式(例如,1d、1M)。如果指定了日期数学表达式,函数将尽可能接近当前选择的间隔。如果日期数学表达式不能按间隔均分,结果可能会显示异常。", + "timelion.help.functions.movingaverageHelpText": "计算给定窗口的移动平均值。适合平滑干扰序列", + "timelion.help.functions.movingstd.args.positionHelpText": "窗口切片相对于结果时间的位置。选项为 {positions}。默认值:{defaultPosition}", + "timelion.help.functions.movingstd.args.windowHelpText": "要用于计算标准偏差的点数量。", + "timelion.help.functions.movingstdHelpText": "计算特定窗口的移动标准偏差。使用朴素的扫描两遍算法。对于极长的序列,或数量极大的序列,舍入错误可能会变得更明显。", + "timelion.help.functions.multiply.args.multiplierHelpText": "要乘以的数字或序列。具有多个序列的 seriesList 将按标签方式应用。", + "timelion.help.functions.multiplyHelpText": "将 seriesList 中一个或多个序列的值乘以输入 seriesList 的每个序列中的每个位置", + "timelion.help.functions.notAllowedGraphiteUrl": "在 kibana.yml 文件中未配置此 Graphite URL。\n 请在 kibana.yml 文件中“timelion.graphiteUrls”下配置 Graphite 服务器列表,并\n 从 Kibana 的高级设置中选择一个", + "timelion.help.functions.points.args.fillColorHelpText": "用于填充点的颜色", + "timelion.help.functions.points.args.fillHelpText": "介于 0 到 10 之间的数字,代表填充的不透明度", + "timelion.help.functions.points.args.radiusHelpText": "点大小", + "timelion.help.functions.points.args.showHelpText": "显示或不显示点", + "timelion.help.functions.points.args.symbolHelpText": "点符号。以下选项之一:{validSymbols}", + "timelion.help.functions.points.args.weightHelpText": "围绕点的线条粗细", + "timelion.help.functions.pointsHelpText": "将序列显示为点", + "timelion.help.functions.precision.args.precisionHelpText": "将每个值舍入到的小数位数", + "timelion.help.functions.precisionHelpText": "将值的小数部分舍入到的小数位数", + "timelion.help.functions.props.args.globalHelpText": "在 seriesList 与每个序列上设置属性", + "timelion.help.functions.propsHelpText": "在序列上可设置任意属性,但请自担风险。例如 {example}", + "timelion.help.functions.quandl.args.codeHelpText": "要绘图的 quandl 代码。可以在 quandl.com 找到这些内容。", + "timelion.help.functions.quandl.args.positionHelpText": "某些 quandl 源会返回多个序列,我该使用哪一个?基于 1 的索引。", + "timelion.help.functions.quandlHelpText": "\n [实验]\n 使用 quandl 代码从 quandl.com 拉取数据。在 Kibana 的“高级设置”中将 {quandlKeyField} 设置为\n 可用 API 密钥。API 在没有密钥的情况下,会有非常低的速率限制。", + "timelion.help.functions.range.args.maxHelpText": "新的最大值", + "timelion.help.functions.range.args.minHelpText": "新的最小值", + "timelion.help.functions.rangeHelpText": "保持形状不变的同时更改序列的最大值和最小值", + "timelion.help.functions.scaleInterval.args.intervalHelpText": "采用日期数学表示法的新间隔,例如,1 秒对应于 1s。1m、5m、1M、1w、1y 等。", + "timelion.help.functions.scaleIntervalHelpText": "更改会将值(通常是求和或计数)缩放到一个新间隔。例如,每秒速率", + "timelion.help.functions.static.args.labelHelpText": "一种快速设置序列标签的方法。您还可以使用 .label() 函数", + "timelion.help.functions.static.args.valueHelpText": "要显示的单个值,您还可以传递多个值,我会将这些值平均内插到您的时间范围内。", + "timelion.help.functions.staticHelpText": "跨图表绘制单个值", + "timelion.help.functions.subtract.args.termHelpText": "要从输入中减去的数字或序列。具有多个序列的 seriesList 将按标签方式应用。", + "timelion.help.functions.subtractHelpText": "将 seriesList 中一个或多个序列的值减去输入 seriesList 的每个序列中的每个位置", + "timelion.help.functions.sum.args.termHelpText": "要与输入序列求和的数字或序列。具有多个序列的 seriesList 将按标签方式应用。", + "timelion.help.functions.sumHelpText": "将 seriesList 中一个或多个序列的值加到输入 seriesList 的每个序列中的每个位置", + "timelion.help.functions.title.args.titleHelpText": "绘图标题。", + "timelion.help.functions.titleHelpText": "在绘图顶部添加一个标题。如果在多个 seriesList 上调用,则将使用最后一个调用。", + "timelion.help.functions.trend.args.endHelpText": "距开头或结尾停止计算的位置。例如,-10 将从距结尾 10 个点的位置停止计算,+15 将在距开头 15 个点的位置停止计算。默认值:0", + "timelion.help.functions.trend.args.modeHelpText": "用于生成趋势线的算法。以下值之一:{validRegressions}", + "timelion.help.functions.trend.args.startHelpText": "距开头或结尾开始计算的位置。例如,-10 将从距结尾 10 个点的位置开始计算,+15 将在距开头 15 个点的位置开始计算。默认值:0", + "timelion.help.functions.trendHelpText": "使用指定回归算法绘制趋势线", + "timelion.help.functions.trim.args.endHelpText": "从序列结尾剪裁的桶。默认值:1", + "timelion.help.functions.trim.args.startHelpText": "从序列开头剪裁的桶。默认值:1", + "timelion.help.functions.trimHelpText": "将序列开头或结尾的 N 个桶设为 null,以拟合“部分桶问题”", + "timelion.help.functions.worldbank.args.codeHelpText": "Worldbank API 路径。这通常是指在域之后、查询字符串之前的所有内容。例如:{apiPathExample}。", + "timelion.help.functions.worldbankHelpText": "\n [实验]\n 使用序列路径从 {worldbankUrl} 拉取数据。\n 世界银行主要提供年度数据,但通常不提供当年数据。\n 如果未获得最近时间范围的任何数据,请尝试使用 {offsetQuery}。", + "timelion.help.functions.worldbankIndicators.args.countryHelpText": "世界银行国家/地区标识符。通常使用国家/地区的两字母代码", + "timelion.help.functions.worldbankIndicators.args.indicatorHelpText": "要使用的指标代码。您必须在 {worldbankUrl} 上查看此代码。通常会比较迟钝。例如,{indicatorExample} 为人口", + "timelion.help.functions.worldbankIndicatorsHelpText": "\n [实验]\n 使用国家/地区名和指标从 {worldbankUrl} 拉取数据。世界银行主要提供\n 年度数据,但通常不提供当年数据。如果未获得最近时间范围的任何数据,请尝试使用 {offsetQuery}\n 。", + "timelion.help.functions.yaxis.args.colorHelpText": "轴标签的颜色", + "timelion.help.functions.yaxis.args.labelHelpText": "轴标签", + "timelion.help.functions.yaxis.args.maxHelpText": "最大值", + "timelion.help.functions.yaxis.args.minHelpText": "最小值", + "timelion.help.functions.yaxis.args.positionHelpText": "左或右", + "timelion.help.functions.yaxis.args.tickDecimalsHelpText": "Y 轴刻度标记的小数位数。", + "timelion.help.functions.yaxis.args.unitsHelpText": "用于设置 Y 轴标签格式的函数。以下选项之一:{formatters}", + "timelion.help.functions.yaxis.args.yaxisHelpText": "用于绘制此序列的带编号的 Y 轴,例如,.yaxis(2) 对应于第 2 个 Y 轴。", + "timelion.help.functions.yaxisHelpText": "配置各种 Y 轴选项,其中最重要的选项可能是添加第 N 个(例如第 2 个)Y 轴的功能", + "timelion.help.mainPage.functionReference.detailsTable.acceptedTypesColumnLabel": "接受的类型", + "timelion.help.mainPage.functionReference.detailsTable.argumentNameColumnLabel": "参数类型", + "timelion.help.mainPage.functionReference.detailsTable.informationColumnLabel": "信息", + "timelion.help.mainPage.functionReference.gettingStartedText": "请单击任何函数以了解更多信息。马上开始使用?", + "timelion.help.mainPage.functionReference.noArgumentsFunctionErrorMessage": "此函数不接受任何参数。嗯,这很简单,不是吗?", + "timelion.help.mainPage.functionReference.welcomePageLinkText": "查看教程", + "timelion.help.mainPage.functionReferenceTitle": "函数引用", + "timelion.help.mainPage.keyboardTips.autoComplete.downArrowDescription": "将焦点切换到自动完成菜单。使用箭头进一步选择词", + "timelion.help.mainPage.keyboardTips.autoComplete.downArrowLabel": "向下箭头", + "timelion.help.mainPage.keyboardTips.autoComplete.enterTabDescription": "选择自动完成菜单中当前选定的词或最顶部的词", + "timelion.help.mainPage.keyboardTips.autoComplete.escDescription": "关闭自动完成菜单", + "timelion.help.mainPage.keyboardTips.autoCompleteTitle": "当自动完成可见时", + "timelion.help.mainPage.keyboardTips.generalEditing.submitRequestText": "提交请求", + "timelion.help.mainPage.keyboardTips.generalEditingTitle": "常规编辑", + "timelion.help.mainPage.keyboardTipsTitle": "键盘提示", + "timelion.help.mainPageTitle": "帮助", + "timelion.help.nextPageButtonLabel": "下一个", + "timelion.help.previousPageButtonLabel": "上一页", + "timelion.help.querying.countMetricAggregationLinkText": "Elasticsearch 指标聚合", + "timelion.help.querying.countTextPart1": "除了具有卓越的事件计数功能,Elasticsearch 数据源还支持任何返回单个值的", + "timelion.help.querying.countTextPart2": "。其中最有用是 {min}、{max}、{avg}、{sum} 和 {cardinality}。假设您需要 {srcIp} 字段的唯一计数。只需使用 {cardinality} 指标:{esCardinalityQuery}。如需获取 {bytes} 字段的平均值,则可以使用 {avg} 指标:{esAvgQuery}。", + "timelion.help.querying.countTitle": "不只是计数", + "timelion.help.querying.esAsteriskQueryDescriptionText": "嗨 Elasticsearch,请在我的默认索引中查找所有内容", + "timelion.help.querying.esIndexQueryDescriptionText": "使用 * 作为 logstash-* 索引的 q (query)", + "timelion.help.querying.luceneQueryLinkText": "Lucene 查询字符串", + "timelion.help.querying.paragraph1": "至此,我们已验证您的 Elasticsearch 数据源工作正常,接下来,可以开始提交查询了。如果是初学者,请在输入栏中输入 {esPattern},然后按 Enter 键。", + "timelion.help.querying.paragraph2Part1": "这个意思是说 {esAsteriskQueryDescription}。如果要查找子集,可以输入 {htmlQuery} 之类的内容以算出与 {html} 匹配的事件个数,或输入 {bobQuery} 来查找在 {user} 字段中包含 {bob} 且 {bytes} 字段大于 100 的事件。注意,此查询需要用单引号引住,因为其包含空格。您可以输入任何", + "timelion.help.querying.paragraph2Part2": "作为 {esQuery} 函数的第一个参数。", + "timelion.help.querying.passingArgumentsText": "Timelion 具有很多快捷键,可以轻松完成各种常见操作。对于不包含空格或特殊字符的简单参数,无需使用引号。而且很多函数都具有默认值。例如,{esEmptyQuery} 和 {esStarQuery} 作用相同。参数也有名称,您无需为其指定特定顺序。例如,可以输入 {esLogstashQuery} 告知 Elasticsearch 数据源 {esIndexQueryDescription}。", + "timelion.help.querying.passingArgumentsTitle": "传递参数", + "timelion.help.queryingTitle": "查询 Elasticsearch 数据源", + "timelion.help.unknownErrorMessage": "未知错误", + "timelion.help.welcome.content.emphasizedEverythingText": "所有内容", + "timelion.help.welcome.content.functionReferenceLinkText": "跳到函数引用", + "timelion.help.welcome.content.paragraph1": "Timelion 是抓取精准、适用于所有内容的可插拔时间序列接口{emphasizedEverything}。如果您的数据存储可以生成时间序列,就能够随意使用 Timelion 的所有强大功能。借助 Timelion,可使用易于掌握的表达式语法,对跨多个数据源的数据集进行比较、合并和整理。尽管本教程主要介绍 Elasticsearch,但您很快会发现,本文所介绍的内容适用于 Timelion 支持的任何数据源。", + "timelion.help.welcome.content.paragraph2": "准备好开始了吗?单击 {strongNext}。想要跳过教程并查看文档?", + "timelion.help.welcome.content.strongNextText": "下一个", + "timelion.help.welcomeTitle": "欢迎来到 {strongTimelionLabel}!", + "timelion.intervals.customIntervalAriaLabel": "定制时间间隔", + "timelion.intervals.selectIntervalAriaLabel": "选择时间间隔", + "timelion.noFunctionErrorMessage": "没有此类函数:{name}", + "timelion.panels.noRenderFunctionErrorMessage": "面板必须具有渲染函数", + "timelion.panels.timechart.unknownIntervalErrorMessage": "时间间隔未知", + "timelion.registerFeatureDescription": "使用表达式语言分析时间序列数据,并将结果可视化。", + "timelion.requestHandlerErrorTitle": "Timelion 请求错误", + "timelion.saveExpression.successNotificationText": "已保存表达式“{title}”", + "timelion.saveSheet.successNotificationText": "已保存工作表“{title}”", + "timelion.search.submitAriaLabel": "搜索", + "timelion.searchErrorTitle": "Timelion 请求错误", + "timelion.serverSideErrors.argumentsOverflowErrorMessage": "太多参数传递到:{functionName}", + "timelion.serverSideErrors.bucketsOverflowErrorMessage": "超过了最大桶数:允许 {bucketCount}/{maxBuckets} 个。选择较大的时间间隔或较短的时间范围", + "timelion.serverSideErrors.colorFunction.colorNotProvidedErrorMessage": "未提供颜色", + "timelion.serverSideErrors.conditionFunction.unknownOperatorErrorMessage": "运算符未知", + "timelion.serverSideErrors.conditionFunction.wrongArgTypeErrorMessage": "必须为数字或 seriesList", + "timelion.serverSideErrors.esFunction.indexNotFoundErrorMessage": "找不到 Elasticsearch 索引:{index}", + "timelion.serverSideErrors.holtFunction.missingParamsErrorMessage": "必须指定季节长度,示例大小 >= 2", + "timelion.serverSideErrors.holtFunction.notEnoughPointsErrorMessage": "您需要至少 2 个点才能使用双指数平滑法", + "timelion.serverSideErrors.movingaverageFunction.notValidPositionErrorMessage": "有效位置为:{validPositions}", + "timelion.serverSideErrors.movingstdFunction.notValidPositionErrorMessage": "有效位置为:{validPositions}", + "timelion.serverSideErrors.pointsFunction.notValidSymbolErrorMessage": "有效符号为:{validSymbols}", + "timelion.serverSideErrors.quandlFunction.unsupportedIntervalErrorMessage": "quandl() 不支持的时间间隔:{interval}。quandl() 支持:{intervals}", + "timelion.serverSideErrors.sheetParseErrorMessage": "应为:字符位置 {column} 的{expectedDescription}", + "timelion.serverSideErrors.unknownArgumentErrorMessage": "{functionName} 的未知参数:{argumentName}", + "timelion.serverSideErrors.unknownArgumentTypeErrorMessage": "不支持的参数类型:{argument}", + "timelion.serverSideErrors.worldbankFunction.noDataErrorMessage": "世界银行请求成功,但 {code} 没有数据", + "timelion.serverSideErrors.wrongFunctionArgumentTypeErrorMessage": "{functionName}({argumentName}) 必须是 {requiredTypes} 之一。得到:{actualType}", + "timelion.serverSideErrors.yaxisFunction.notSupportedUnitTypeErrorMessage": "{units} 为不受支持的单元类型。", + "timelion.serverSideErrors.yaxisFunction.notValidCurrencyFormatErrorMessage": "货币必须使用三个字母的代码", + "timelion.timelionDescription": "使用函数表达式构建时间序列", + "timelion.topNavMenu.addChartButtonAriaLabel": "添加图表", + "timelion.topNavMenu.addChartButtonLabel": "添加", + "timelion.topNavMenu.delete.modal.confirmButtonLabel": "删除", + "timelion.topNavMenu.delete.modal.successNotificationText": "已删除“{title}”", + "timelion.topNavMenu.delete.modal.warningText": "您无法恢复已删除的工作表。", + "timelion.topNavMenu.delete.modalTitle": "是否删除 Timelion 工作表 “{title}”?", + "timelion.topNavMenu.deleteSheetButtonAriaLabel": "删除当前工作表", + "timelion.topNavMenu.deleteSheetButtonLabel": "删除", + "timelion.topNavMenu.helpButtonAriaLabel": "帮助", + "timelion.topNavMenu.helpButtonLabel": "帮助", + "timelion.topNavMenu.newSheetButtonAriaLabel": "新建工作表", + "timelion.topNavMenu.newSheetButtonLabel": "新建", + "timelion.topNavMenu.openSheetButtonAriaLabel": "打开工作表", + "timelion.topNavMenu.openSheetButtonLabel": "打开", + "timelion.topNavMenu.openSheetTitle": "打开工作表", + "timelion.topNavMenu.options.columnsCountLabel": "列(列数必须均分为 12)", + "timelion.topNavMenu.options.rowsCountLabel": "行(这是基于当前窗口高度的目标)", + "timelion.topNavMenu.optionsButtonAriaLabel": "选项", + "timelion.topNavMenu.optionsButtonLabel": "选项", + "timelion.topNavMenu.save.saveAsDashboardPanel.inputPlaceholder": "命名此面板", + "timelion.topNavMenu.save.saveAsDashboardPanel.selectedExpressionLabel": "当前选择的表达式", + "timelion.topNavMenu.save.saveAsDashboardPanel.submitButtonLabel": "保存", + "timelion.topNavMenu.save.saveAsDashboardPanelDescription": "是否需要将图表添加到 Kibana 仪表板?我们可以做到这一点!此选项会将当前选择的表达式另存为一个面板,可像添加任何其他内容一样添加到 Kibana 仪表板。注意,如果使用对其他面板的引用,则需要删除该引用,方法是:将引用的表达式直接复制到要保存的表达式中即可。单击图表可选择要保存的其他表达式。", + "timelion.topNavMenu.save.saveAsDashboardPanelLabel": "将表达式另存为", + "timelion.topNavMenu.save.saveAsDashboardPanelTitle": "将当前表达式另存为 Kibana 仪表板面板", + "timelion.topNavMenu.save.saveEntireSheet.inputAriaLabel": "名称", + "timelion.topNavMenu.save.saveEntireSheet.inputPlaceholder": "命名此工作表......", + "timelion.topNavMenu.save.saveEntireSheet.submitButtonLabel": "保存", + "timelion.topNavMenu.save.saveEntireSheetDescription": "如果您主要在 Timelion 应用中使用 Timelion 表达式,且不需要将 Timelion 图表添加到 Kibana 仪表板,则需要使用此选项。如果您使用对其他面板的引用,可能也需要此选项。", + "timelion.topNavMenu.save.saveEntireSheetLabel": "将工作表另存为", + "timelion.topNavMenu.save.saveEntireSheetTitle": "保存整个 Timelion 工作表", + "timelion.topNavMenu.saveSheetButtonAriaLabel": "保存工作表", + "timelion.topNavMenu.saveSheetButtonLabel": "保存", + "timelion.topNavMenu.sheetOptionsTitle": "工作表选项", + "timelion.topNavMenu.statsDescription": "查询时间 {queryTime}ms /处理时间 {processingTime}ms", + "timelion.uiSettings.defaultColumnsDescription": "默认情况下 Timelion 工作表上的列数目", + "timelion.uiSettings.defaultColumnsLabel": "默认列", + "timelion.uiSettings.defaultIndexDescription": "要使用 {esParam} 搜索的默认 Elasticsearch 索引", + "timelion.uiSettings.defaultIndexLabel": "默认索引", + "timelion.uiSettings.defaultRowsDescription": "默认情况下 Timelion 工作表上的行数目", + "timelion.uiSettings.defaultRowsLabel": "默认行数", + "timelion.uiSettings.experimentalLabel": "实验性", + "timelion.uiSettings.graphiteURLDescription": "{experimentalLabel} Graphite 主机的 URL", + "timelion.uiSettings.graphiteURLLabel": "Graphite URL", + "timelion.uiSettings.maximumBucketsDescription": "单个数据源可以返回的最大存储桶数目", + "timelion.uiSettings.maximumBucketsLabel": "最大存储桶数", + "timelion.uiSettings.minimumIntervalDescription": "使用“自动”时将计算的最小时间间隔", + "timelion.uiSettings.minimumIntervalLabel": "最小时间间隔", + "timelion.uiSettings.quandlKeyDescription": "{experimentalLabel} 来自 www.quandl.com 的 API 密钥", + "timelion.uiSettings.quandlKeyLabel": "Quandl 密钥", + "timelion.uiSettings.showTutorialDescription": "进入 Timelion 应用时我是否应该默认显示教程?", + "timelion.uiSettings.showTutorialLabel": "显示教程", + "timelion.uiSettings.targetBucketsDescription": "使用自动时间间隔时想要的存储桶数目", + "timelion.uiSettings.targetBucketsLabel": "目标存储桶", + "timelion.uiSettings.timeFieldDescription": "使用 {esParam} 时包含时间戳的默认字段", + "timelion.uiSettings.timeFieldLabel": "时间字段", + "timelion.vis.expressionLabel": "Timelion 表达式", + "timelion.vis.intervalLabel": "时间间隔", "uiActions.actionPanel.title": "选项", "uiActions.errors.incompatibleAction": "操作不兼容", + "visTypeMarkdown.function.font.help": "字体设置。", + "visTypeMarkdown.function.help": "Markdown 可视化", + "visTypeMarkdown.function.markdown.help": "要渲染的 Markdown", + "visTypeMarkdown.function.openLinksInNewTab.help": "在新标签页中打开链接", + "visTypeMarkdown.markdownDescription": "使用 Markdown 语法创建文档", + "visTypeMarkdown.params.fontSizeLabel": "基础字体大小(磅)", + "visTypeMarkdown.params.helpLinkLabel": "帮助", + "visTypeMarkdown.params.openLinksLabel": "在新标签页中打开链接", + "visTypeMarkdown.tabs.dataText": "数据", + "visTypeMarkdown.tabs.optionsText": "选项", + "visTypeMetric.colorModes.backgroundOptionLabel": "背景", + "visTypeMetric.colorModes.labelsOptionLabel": "标签", + "visTypeMetric.colorModes.noneOptionLabel": "无", + "visTypeMetric.function.bgFill.help": "将颜色表示为 html 十六进制代码 (#123456)、html 颜色(red、blue)或 rgba 值 (rgba(255,255,255,1))。", + "visTypeMetric.function.bucket.help": "存储桶维度配置", + "visTypeMetric.function.colorMode.help": "指标的哪部分要上色", + "visTypeMetric.function.colorRange.help": "指定应将不同颜色应用到的值组的范围对象。", + "visTypeMetric.function.colorScheme.help": "要使用的颜色方案", + "visTypeMetric.function.font.help": "字体设置。", + "visTypeMetric.function.help": "指标可视化", + "visTypeMetric.function.invertColors.help": "反转颜色范围", + "visTypeMetric.function.metric.help": "指标维度配置", + "visTypeMetric.function.percentage.help": "以百分比模式显示指标。需要设置 colorRange。", + "visTypeMetric.function.showLabels.help": "在指标值下显示标签。", + "visTypeMetric.function.subText.help": "要在指标下显示的定制文本", + "visTypeMetric.function.useRanges.help": "已启用颜色范围。", + "visTypeMetric.metricDescription": "将计算结果显示为单个数字", + "visTypeMetric.metricTitle": "指标", + "visTypeMetric.params.color.useForLabel": "将颜色用于", + "visTypeMetric.params.percentageModeLabel": "百分比模式", + "visTypeMetric.params.rangesTitle": "范围", + "visTypeMetric.params.settingsTitle": "设置", + "visTypeMetric.params.showTitleLabel": "显示标题", + "visTypeMetric.params.style.fontSizeLabel": "指标字体大小(磅)", + "visTypeMetric.params.style.styleTitle": "样式", + "visTypeMetric.schemas.metricTitle": "指标", + "visTypeMetric.schemas.splitGroupTitle": "拆分组", + "visTypeTable.aggTable.exportLabel": "导出:", + "visTypeTable.aggTable.formattedLabel": "格式化", + "visTypeTable.aggTable.rawLabel": "原始", + "visTypeTable.directives.tableCellFilter.filterForValueTooltip": "筛留值", + "visTypeTable.directives.tableCellFilter.filterOutValueTooltip": "筛除值", + "visTypeTable.function.help": "表可视化", + "visTypeTable.params.defaultPercentageCol": "不显示", + "visTypeTable.params.PercentageColLabel": "百分比列", + "visTypeTable.params.percentageTableColumnName": "{title} 百分比", + "visTypeTable.params.perPageLabel": "每页行数", + "visTypeTable.params.showMetricsLabel": "显示每个桶/级别的指标", + "visTypeTable.params.showPartialRowsLabel": "显示部分行", + "visTypeTable.params.showPartialRowsTip": "显示具有部分数据的行。这仍将计算每个桶/级别的指标,即使它们未显示。", + "visTypeTable.params.showTotalLabel": "显示汇总", + "visTypeTable.params.totalFunctionLabel": "汇总函数", + "visTypeTable.tableVisDescription": "在表中显示值", + "visTypeTable.tableVisEditorConfig.schemas.bucketTitle": "拆分行", + "visTypeTable.tableVisEditorConfig.schemas.metricTitle": "指标", + "visTypeTable.tableVisEditorConfig.schemas.splitTitle": "拆分表", + "visTypeTable.tableVisTitle": "数据表", + "visTypeTable.totalAggregations.averageText": "平均值", + "visTypeTable.totalAggregations.countText": "计数", + "visTypeTable.totalAggregations.maxText": "最大值", + "visTypeTable.totalAggregations.minText": "最小值", + "visTypeTable.totalAggregations.sumText": "和", + "visTypeTable.vis.noResultsFoundTitle": "找不到结果", + "visTypeTagCloud.feedbackMessage.tooSmallContainerDescription": "容器太小,无法显示整个云。标记可能被裁剪或省略。", + "visTypeTagCloud.feedbackMessage.truncatedTagsDescription": "标记数量已截断,以避免绘制时间过长。", + "visTypeTagCloud.function.bucket.help": "存储桶维度配置", + "visTypeTagCloud.function.help": "标签云图可视化", + "visTypeTagCloud.function.metric.help": "指标维度配置", + "visTypeTagCloud.function.orientation.help": "标签云图内的字方向", + "visTypeTagCloud.function.scale.help": "缩放以确定字体大小", + "visTypeTagCloud.vis.editorConfig.orientations.multipleText": "多个", + "visTypeTagCloud.vis.editorConfig.orientations.rightAngledText": "直角", + "visTypeTagCloud.vis.editorConfig.orientations.singleText": "单个", + "visTypeTagCloud.vis.editorConfig.scales.linearText": "线性", + "visTypeTagCloud.vis.editorConfig.scales.logText": "对数", + "visTypeTagCloud.vis.editorConfig.scales.squareRootText": "平方根", + "visTypeTagCloud.vis.schemas.metricTitle": "标记大小", + "visTypeTagCloud.vis.schemas.segmentTitle": "标记", + "visTypeTagCloud.vis.tagCloudDescription": "一组字词,可根据其重要性调整大小", + "visTypeTagCloud.vis.tagCloudTitle": "标签云图", + "visTypeTagCloud.visParams.fontSizeLabel": "字体大小范围(像素)", + "visTypeTagCloud.visParams.orientationsLabel": "方向", + "visTypeTagCloud.visParams.showLabelToggleLabel": "显示标签", + "visTypeTagCloud.visParams.textScaleLabel": "文本比例", "visTypeTimeseries.addDeleteButtons.addButtonDefaultTooltip": "添加", "visTypeTimeseries.addDeleteButtons.cloneButtonDefaultTooltip": "克隆", "visTypeTimeseries.addDeleteButtons.deleteButtonDefaultTooltip": "删除", @@ -12626,7 +3730,1913 @@ "visTypeTimeseries.visPicker.timeSeriesLabel": "时间序列", "visTypeTimeseries.visPicker.topNLabel": "排名前 N", "visTypeTimeseries.yesButtonLabel": "是", + "visTypeVega.editor.formatError": "格式化规范时出错", + "visTypeVega.editor.reformatAsHJSONButtonLabel": "重新格式化为 HJSON", + "visTypeVega.editor.reformatAsJSONButtonLabel": "重新格式化为 JSON,删除注释", + "visTypeVega.editor.vegaDocumentationLinkText": "Vega 文档", + "visTypeVega.editor.vegaEditorOptionsButtonAriaLabel": "Vega 编辑器选项", + "visTypeVega.editor.vegaHelpButtonAriaLabel": "Vega 帮助", + "visTypeVega.editor.vegaHelpLinkText": "Kibana Vega 帮助", + "visTypeVega.editor.vegaLiteDocumentationLinkText": "Vega-Lite 文档", + "visTypeVega.emsFileParser.emsFileNameDoesNotExistErrorMessage": "{emsfile} {emsfileName} 不存在", + "visTypeVega.emsFileParser.missingNameOfFileErrorMessage": "具有 {dataUrlParamValue} 的 {dataUrlParam} 需要 {nameParam} 参数(文件名)", + "visTypeVega.esQueryParser.autointervalValueTypeErrorMessage": "{autointerval} 必须为 {trueValue} 或数字", + "visTypeVega.esQueryParser.dataUrlMustNotHaveLegacyAndBodyQueryValuesAtTheSameTimeErrorMessage": "{dataUrlParam} 不得同时具有旧的 {legacyContext} 和 {bodyQueryConfigName} 值", + "visTypeVega.esQueryParser.dataUrlMustNotHaveLegacyContextTogetherWithContextOrTimefieldErrorMessage": "{dataUrlParam} 不得同时具有 {legacyContext} 与 {context} 或 {timefield}", + "visTypeVega.esQueryParser.legacyContextCanBeTrueErrorMessage": "旧 {legacyContext} 可以为 {trueValue}(忽略时间范围选取器),也可以为时间字段的名称,例如 {timestampParam}", + "visTypeVega.esQueryParser.legacyUrlShouldChangeToWarningMessage": "旧 {urlParam}:{legacyUrl} 应更改为 {result}", + "visTypeVega.esQueryParser.shiftMustValueTypeErrorMessage": "{shiftParam} 必须为数值", + "visTypeVega.esQueryParser.timefilterValueErrorMessage": "{timefilter} 属性必须设置为 {trueValue}、{minValue} 或 {maxValue}", + "visTypeVega.esQueryParser.unknownUnitValueErrorMessage": "{unitParamName} 值未知。必须为以下值之一:[{unitParamValues}]", + "visTypeVega.esQueryParser.urlBodyValueTypeErrorMessage": "{configName} 必须为对象", + "visTypeVega.esQueryParser.urlContextAndUrlTimefieldMustNotBeUsedErrorMessage": "设置了 {queryParam} 时,不得使用 {urlContext} 和 {timefield}", + "visTypeVega.function.help": "Vega 可视化", + "visTypeVega.mapView.mapStyleNotFoundWarningMessage": "找不到 {mapStyleParam}", + "visTypeVega.mapView.minZoomAndMaxZoomHaveBeenSwappedWarningMessage": "已交换 {minZoomPropertyName} 和 {maxZoomPropertyName}", + "visTypeVega.mapView.resettingPropertyToMaxValueWarningMessage": "将 {name} 重置为 {max}", + "visTypeVega.mapView.resettingPropertyToMinValueWarningMessage": "将 {name} 重置为 {min}", + "visTypeVega.type.vegaDescription": "使用 Vega 和 Vega-Lite 创建定制可视化", + "visTypeVega.urlParser.dataUrlRequiresUrlParameterInFormErrorMessage": "{dataUrlParam} 需要以“{formLink}”形式的 {urlParam} 参数", + "visTypeVega.urlParser.urlShouldHaveQuerySubObjectWarningMessage": "使用 {urlObject} 应具有 {subObjectName} 子对象", + "visTypeVega.vegaParser.baseView.externalUrlsAreNotEnabledErrorMessage": "未启用外部 URL。将 {enableExternalUrls} 添加到 {kibanaConfigFileName}", + "visTypeVega.vegaParser.baseView.functionIsNotDefinedForGraphErrorMessage": "没有为此图表定义 {funcName}", + "visTypeVega.vegaParser.baseView.timeValuesTypeErrorMessage": "设置时间筛选时出错:时间值必须为相对日期或绝对日期。{start}、{end}", + "visTypeVega.vegaParser.centerOnMarkConfigValueTypeErrorMessage": "{configName} 应为 {trueValue}、{falseValue} 或数字", + "visTypeVega.vegaParser.dataExceedsSomeParamsUseTimesLimitErrorMessage": "数据不得包含 {urlParam}、{valuesParam} 和 {sourceParam} 中的多个值", + "visTypeVega.vegaParser.hostConfigIsDeprecatedWarningMessage": "{deprecatedConfigName} 已弃用。请改用 {newConfigName}。", + "visTypeVega.vegaParser.hostConfigValueTypeErrorMessage": "如果存在,{configName} 必须为对象", + "visTypeVega.vegaParser.inputSpecDoesNotSpecifySchemaWarningMessage": "输入规范未指定 {schemaParam},其默认值为 {defaultSchema}", + "visTypeVega.vegaParser.invalidVegaSpecErrorMessage": "Vega 规范无效", + "visTypeVega.vegaParser.kibanaConfigValueTypeErrorMessage": "如果存在,{configName} 必须为对象", + "visTypeVega.vegaParser.mapStyleValueTypeWarningMessage": "{mapStyleConfigName} 可能为 {mapStyleConfigFirstAllowedValue} 或 {mapStyleConfigSecondAllowedValue}", + "visTypeVega.vegaParser.maxBoundsValueTypeWarningMessage": "{maxBoundsConfigName} 必须为具有四个数字的数组", + "visTypeVega.vegaParser.notSupportedUrlTypeErrorMessage": "不支持 {urlObject}", + "visTypeVega.vegaParser.notValidLibraryVersionForInputSpecWarningMessage": "输入规范使用 {schemaLibrary} {schemaVersion},但 {schemaLibrary} 的当前版本为 {libraryVersion}。", + "visTypeVega.vegaParser.paddingConfigValueTypeErrorMessage": "{configName} 应为数字", + "visTypeVega.vegaParser.someKibanaConfigurationIsNoValidWarningMessage": "{configName} 无效", + "visTypeVega.vegaParser.someKibanaParamValueTypeWarningMessage": "{configName} 必须为布尔值", + "visTypeVega.vegaParser.unexpectedValueForPositionConfigurationErrorMessage": "意外的 {configurationName} 配置值", + "visTypeVega.vegaParser.unrecognizedControlsLocationValueErrorMessage": "无法识别的 {controlsLocationParam} 值。应为 [{locToDirMap}] 之一", + "visTypeVega.vegaParser.unrecognizedDirValueErrorMessage": "{dirParam} 值无法识别。应为 [{expectedValues}] 之一", + "visTypeVega.vegaParser.VLCompilerShouldHaveGeneratedSingleProtectionObjectErrorMessage": "内部错误:Vega-Lite 编译器应已生成单个投影对象", + "visTypeVega.vegaParser.widthAndHeightParamsAreIgnoredWithAutosizeFitWarningMessage": "使用 {autosizeParam} 时,将忽略 {widthParam} 和 {heightParam} 参数", + "visTypeVega.visualization.indexNotFoundErrorMessage": "找不到索引 {index}", + "visTypeVega.visualization.renderErrorTitle": "Vega 错误", + "visTypeVega.visualization.unableToFindDefaultIndexErrorMessage": "找不到默认索引", + "visTypeVega.visualization.unableToRenderWithoutDataWarningMessage": "没有数据时无法渲染", + "xpack.actions.actionTypeRegistry.get.missingActionTypeErrorMessage": "未注册操作类型“{id}”。", + "xpack.actions.actionTypeRegistry.register.duplicateActionTypeErrorMessage": "操作类型“{id}”已注册。", + "xpack.actions.builtin.slack.unexpectedNullResponseErrorMessage": "来自 slack 的异常空响应", + "xpack.actions.builtin.webhook.webhookConfigurationError": "配置 Webhook 操作时出错:{message}", + "xpack.actions.urlWhitelistConfigurationError": "目标 {field}“{value}”不在 Kibana 白名单中", + "xpack.advancedUiActions.customizePanelTimeRange.modal.addToPanelButtonTitle": "添加到面板", + "xpack.advancedUiActions.customizePanelTimeRange.modal.cancelButtonTitle": "取消", + "xpack.advancedUiActions.customizePanelTimeRange.modal.optionsMenuForm.panelTitleFormRowLabel": "时间范围", + "xpack.advancedUiActions.customizePanelTimeRange.modal.removeButtonTitle": "删除", + "xpack.advancedUiActions.customizePanelTimeRange.modal.updatePanelTimeRangeButtonTitle": "更新", + "xpack.advancedUiActions.customizeTimeRange.modal.headerTitle": "定制面板时间范围", + "xpack.advancedUiActions.customizeTimeRangeMenuItem.displayName": "定制时间范围", "xpack.alerting.alertsClient.validateActions.invalidGroups": "无效操作组:{groups}", + "xpack.alerting.alertTypeRegistry.get.missingAlertTypeError": "未注册告警类型“{id}”。", + "xpack.alerting.alertTypeRegistry.register.duplicateAlertTypeError": "已注册告警类型“{id}”。", + "xpack.apm.agentMetrics.java.gcRate": "GC 速率", + "xpack.apm.agentMetrics.java.gcRateChartTitle": "每分钟垃圾回收率", + "xpack.apm.agentMetrics.java.gcTime": "GC 时间", + "xpack.apm.agentMetrics.java.gcTimeChartTitle": "每分钟花费的垃圾回收时间", + "xpack.apm.agentMetrics.java.heapMemoryChartTitle": "堆内存", + "xpack.apm.agentMetrics.java.heapMemorySeriesCommitted": "已提交平均值", + "xpack.apm.agentMetrics.java.heapMemorySeriesMax": "限制平均值", + "xpack.apm.agentMetrics.java.heapMemorySeriesUsed": "已使用平均值", + "xpack.apm.agentMetrics.java.nonHeapMemoryChartTitle": "非堆内存", + "xpack.apm.agentMetrics.java.nonHeapMemorySeriesCommitted": "已提交平均值", + "xpack.apm.agentMetrics.java.nonHeapMemorySeriesUsed": "已使用平均值", + "xpack.apm.agentMetrics.java.threadCount": "平均计数", + "xpack.apm.agentMetrics.java.threadCountChartTitle": "线程计数", + "xpack.apm.agentMetrics.java.threadCountMax": "最大计数", + "xpack.apm.apmDescription": "自动从您的应用程序内收集深入全面的性能指标和错误。", + "xpack.apm.apmForESDescription": "Elastic Stack 的 APM", + "xpack.apm.applyFilter": "应用 {title} 筛选", + "xpack.apm.applyOptions": "应用选项", + "xpack.apm.breadcrumb.errorsTitle": "错误", + "xpack.apm.breadcrumb.listSettingsTitle": "璁剧疆", + "xpack.apm.breadcrumb.metricsTitle": "指标", + "xpack.apm.breadcrumb.nodesTitle": "JVM", + "xpack.apm.breadcrumb.serviceMapTitle": "服务地图", + "xpack.apm.breadcrumb.servicesTitle": "服务", + "xpack.apm.breadcrumb.tracesTitle": "追溯", + "xpack.apm.breadcrumb.transactionsTitle": "事务", + "xpack.apm.chart.cpuSeries.processAverageLabel": "进程平均值", + "xpack.apm.chart.cpuSeries.processMaxLabel": "进程最大值", + "xpack.apm.chart.cpuSeries.systemAverageLabel": "系统平均值", + "xpack.apm.chart.cpuSeries.systemMaxLabel": "系统最大值", + "xpack.apm.chart.memorySeries.systemAverageLabel": "平均值", + "xpack.apm.chart.memorySeries.systemMaxLabel": "最大值", + "xpack.apm.clearFilters": "清除筛选", + "xpack.apm.datePicker.last15MinutesLabel": "过去 15 分钟", + "xpack.apm.datePicker.last1HourLabel": "过去 1 小时", + "xpack.apm.datePicker.last1YearLabel": "过去 1 年", + "xpack.apm.datePicker.last24HoursLabel": "过去 24 小时", + "xpack.apm.datePicker.last30DaysLabel": "过去 30 天", + "xpack.apm.datePicker.last30MinutesLabel": "过去 30 分钟", + "xpack.apm.datePicker.last7DaysLabel": "过去 7 天", + "xpack.apm.datePicker.last90DaysLabel": "过去 90 天", + "xpack.apm.emptyMessage.noDataFoundDescription": "尝试其他时间范围或重置搜索筛选。", + "xpack.apm.emptyMessage.noDataFoundLabel": "未找到任何数据", + "xpack.apm.error.prompt.body": "有关详情,请查看您的浏览器开发者控制台。", + "xpack.apm.error.prompt.title": "抱歉,发生错误 :(", + "xpack.apm.errorGroupDetails.culpritLabel": "原因", + "xpack.apm.errorGroupDetails.errorGroupTitle": "错误组 {errorGroupId}", + "xpack.apm.errorGroupDetails.errorOccurrenceTitle": "错误发生", + "xpack.apm.errorGroupDetails.exceptionMessageLabel": "异常消息", + "xpack.apm.errorGroupDetails.logMessageLabel": "日志消息", + "xpack.apm.errorGroupDetails.noErrorsLabel": "未找到任何错误", + "xpack.apm.errorGroupDetails.occurrencesChartLabel": "发生次数", + "xpack.apm.errorGroupDetails.occurrencesLongLabel": "{occCount} 次发生", + "xpack.apm.errorGroupDetails.occurrencesShortLabel": "{occCount} 次发生", + "xpack.apm.errorGroupDetails.relatedTransactionSample": "相关的事务样本", + "xpack.apm.errorGroupDetails.unhandledLabel": "未处理", + "xpack.apm.errorGroupDetails.viewOccurrencesInDiscoverButtonLabel": "在 Discover 查看 {occurrencesCount} 个 {occurrencesCount, plural, one {匹配项} other {匹配项}}。", + "xpack.apm.errorsTable.errorMessageAndCulpritColumnLabel": "错误消息和原因", + "xpack.apm.errorsTable.groupIdColumnLabel": "组 ID", + "xpack.apm.errorsTable.latestOccurrenceColumnLabel": "最新一次发生", + "xpack.apm.errorsTable.noErrorsLabel": "未找到任何错误", + "xpack.apm.errorsTable.occurrencesColumnLabel": "发生次数", + "xpack.apm.errorsTable.unhandledLabel": "未处理", + "xpack.apm.featureRegistry.apmFeatureName": "APM", + "xpack.apm.fetcher.error.status": "错误", + "xpack.apm.fetcher.error.title": "提取资源时出错", + "xpack.apm.fetcher.error.url": "URL", + "xpack.apm.filter.environment.allLabel": "全部", + "xpack.apm.filter.environment.label": "环境", + "xpack.apm.filter.environment.notDefinedLabel": "未定义", + "xpack.apm.filter.environment.selectEnvironmentLabel": "选择环境", + "xpack.apm.formatters.hoursTimeUnitLabel": "h", + "xpack.apm.formatters.microsTimeUnitLabel": "μs", + "xpack.apm.formatters.millisTimeUnitLabel": "ms", + "xpack.apm.formatters.minutesTimeUnitLabel": "分钟", + "xpack.apm.formatters.requestsPerMinLabel": "rpm", + "xpack.apm.formatters.secondsTimeUnitLabel": "s", + "xpack.apm.formatters.transactionsPerMinLabel": "tpm", + "xpack.apm.header.badge.readOnly.text": "只读", + "xpack.apm.header.badge.readOnly.tooltip": "无法保存", + "xpack.apm.helpMenu.upgradeAssistantLink": "升级助手", + "xpack.apm.home.serviceMapTabLabel": "服务地图", + "xpack.apm.home.servicesTabLabel": "服务", + "xpack.apm.home.tracesTabLabel": "追溯", + "xpack.apm.invalidLicense.licenseManagementLink": "管理您的许可", + "xpack.apm.invalidLicense.message": "APM UI 不可用,因为您当前的许可已过期或不再有效。", + "xpack.apm.invalidLicense.title": "许可无效", + "xpack.apm.jvmsTable.cpuColumnLabel": "CPU 平均值", + "xpack.apm.jvmsTable.explainServiceNodeNameMissing": "无法识别这些指标属于哪些 JVM。这可能因为运行的 APM Server 版本低于 7.5。如果升级到 APM Server 7.5 或更高版本,应可解决此问题。", + "xpack.apm.jvmsTable.heapMemoryColumnLabel": "堆内存平均值", + "xpack.apm.jvmsTable.nameColumnLabel": "名称", + "xpack.apm.jvmsTable.nameExplanation": "默认情况下,JVM 名称是容器 ID(如果适用)或主机名,但其可以通过代理的“service_node_name”配置手动进行配置。", + "xpack.apm.jvmsTable.noJvmsLabel": "未找到任何 JVM", + "xpack.apm.jvmsTable.nonHeapMemoryColumnLabel": "非堆内存平均值", + "xpack.apm.jvmsTable.threadCountColumnLabel": "线程计数最大值", + "xpack.apm.localFilters.titles.agentName": "代理名称", + "xpack.apm.localFilters.titles.containerId": "容器 ID", + "xpack.apm.localFilters.titles.host": "主机", + "xpack.apm.localFilters.titles.podName": "Pod", + "xpack.apm.localFilters.titles.transactionResult": "事务结果", + "xpack.apm.localFilters.titles.transactionType": "事务类型", + "xpack.apm.localFiltersTitle": "筛选", + "xpack.apm.metadataTable.section.agentLabel": "代理", + "xpack.apm.metadataTable.section.containerLabel": "容器", + "xpack.apm.metadataTable.section.customLabel": "定制", + "xpack.apm.metadataTable.section.errorLabel": "错误", + "xpack.apm.metadataTable.section.hostLabel": "主机", + "xpack.apm.metadataTable.section.httpLabel": "HTTP", + "xpack.apm.metadataTable.section.labelsLabel": "标签", + "xpack.apm.metadataTable.section.pageLabel": "页", + "xpack.apm.metadataTable.section.processLabel": "进程", + "xpack.apm.metadataTable.section.serviceLabel": "服务", + "xpack.apm.metadataTable.section.spanLabel": "范围", + "xpack.apm.metadataTable.section.traceLabel": "跟踪", + "xpack.apm.metadataTable.section.transactionLabel": "事务", + "xpack.apm.metadataTable.section.urlLabel": "URL", + "xpack.apm.metadataTable.section.userAgentLabel": "用户代理", + "xpack.apm.metadataTable.section.userLabel": "用户", + "xpack.apm.metrics.durationByCountryMap.avgPageLoadByCountryLabel": "页面加载平均时长分布(按国家/地区)", + "xpack.apm.metrics.durationByCountryMap.RegionMapChart.ToolTip.avgPageLoadDuration": "页面加载平均时长:", + "xpack.apm.metrics.durationByCountryMap.RegionMapChart.ToolTip.countPageLoads": "{docCount} 个页面加载", + "xpack.apm.metrics.plot.noDataLabel": "此时间范围内没有数据。", + "xpack.apm.metrics.transactionChart.machineLearningLabel": "Machine Learning", + "xpack.apm.metrics.transactionChart.machineLearningTooltip": "环绕平均持续时间的流显示预期边界。对 >= 75 的异常分数显示标注。", + "xpack.apm.metrics.transactionChart.pageLoadTimesLabel": "页面加载时间", + "xpack.apm.metrics.transactionChart.requestsPerMinuteLabel": "每分钟请求数", + "xpack.apm.metrics.transactionChart.routeChangeTimesLabel": "路由更改时间", + "xpack.apm.metrics.transactionChart.transactionDurationLabel": "事务持续时间", + "xpack.apm.metrics.transactionChart.transactionsPerMinuteLabel": "每分钟事务数", + "xpack.apm.notAvailableLabel": "不适用", + "xpack.apm.percentOfParent": "({value} 的 {parentType, select, transaction {事务} trace {trace} })", + "xpack.apm.propertiesTable.agentFeature.noDataAvailableLabel": "没有可用数据", + "xpack.apm.propertiesTable.tabs.exceptionStacktraceLabel": "异常堆栈追溯", + "xpack.apm.propertiesTable.tabs.logStacktraceLabel": "日志堆栈追溯", + "xpack.apm.propertiesTable.tabs.metadataLabel": "元数据", + "xpack.apm.propertiesTable.tabs.timelineLabel": "时间线", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.callout.jobExistsDescription": "当前有 {serviceName}({transactionType})的作业正在运行。", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.callout.jobExistsDescription.viewJobLinkText": "查看现有作业", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.callout.jobExistsTitle": "作业已存在", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.createMLJobDescription": "在这里可以创建 Machine Learning 作业以基于 {serviceName} 服务内 APM 事务的持续时间计算异常分数。启用后,一旦异常分数 >=75,{transactionDurationGraphText}将显示预期边界并标注图表。", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.createMLJobDescription.transactionDurationGraphText": "事务持续时间图表", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.createNewJobButtonLabel": "创建新作业", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.enableAnomalyDetectionTitle": "启用异常检测", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.jobCreatedNotificationText": "现在正在运行对 {serviceName}({transactionType})的分析。可能要花费点时间,才会将结果添加响应时间图表。", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.jobCreatedNotificationText.viewJobLinkText": "查看作业", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.jobCreatedNotificationTitle": "作业已成功创建", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.jobCreationFailedNotificationText": "您当前的许可可能不允许创建 Machine Learning 作业,或者此作业可能已存在。", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.jobCreationFailedNotificationTitle": "作业创建失败", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.manageMLJobDescription": "可以创建每个服务 + 事务类型组合的作业。创建作业后,可以在 {mlJobsPageLink}中管理作业以及查看更多详细信息。", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.manageMLJobDescription.mlJobsPageLinkText": "Machine Learning 作业管理页面", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.manageMLJobDescription.noteText": "注意:可能要过几分钟后,作业才会开始计算结果。", + "xpack.apm.serviceDetails.enableAnomalyDetectionPanel.selectTransactionTypeLabel": "为此作业选择事务类型", + "xpack.apm.serviceDetails.enableErrorReportsPanel.actionsDescription": "可以通过电子邮件发送报告或将报告发布到 Slack 频道。每个报告将包括按发生次数排序的前 10 个错误。", + "xpack.apm.serviceDetails.enableErrorReportsPanel.actionsTitle": "操作", + "xpack.apm.serviceDetails.enableErrorReportsPanel.conditionTitle": "条件", + "xpack.apm.serviceDetails.enableErrorReportsPanel.createWatchButtonLabel": "创建监视", + "xpack.apm.serviceDetails.enableErrorReportsPanel.dailyReportHelpText": "每日报告将在 {dailyTimeFormatted} / {dailyTime12HourFormatted} 发送。", + "xpack.apm.serviceDetails.enableErrorReportsPanel.dailyReportRadioButtonLabel": "每日报告", + "xpack.apm.serviceDetails.enableErrorReportsPanel.emailSubjectText": "{serviceName} 具有超过阈值的错误组", + "xpack.apm.serviceDetails.enableErrorReportsPanel.emailTemplateText": "您的服务 {serviceName} 具有在 {timeRange}内发生次数超过 {threshold} 次的错误组{br}{br}{errorGroupsBuckets}{br}{errorLogMessage}{br}{errorCulprit}不适用{slashErrorCulprit}{br}{docCountParam} 次{br}{slashErrorGroupsBucket}", + "xpack.apm.serviceDetails.enableErrorReportsPanel.enableErrorReportsTitle": "启用错误报告", + "xpack.apm.serviceDetails.enableErrorReportsPanel.formDescription": "此表单将帮助创建从此服务向您通知错误发生次数的监视。要详细了解 Watcher,请阅读我们的恶{documentationLink}", + "xpack.apm.serviceDetails.enableErrorReportsPanel.formDescription.documentationLinkText": "文档", + "xpack.apm.serviceDetails.enableErrorReportsPanel.intervalHelpText": "报告时间间隔。", + "xpack.apm.serviceDetails.enableErrorReportsPanel.intervalRadioButtonLabel": "时间间隔", + "xpack.apm.serviceDetails.enableErrorReportsPanel.intervalUnit.hrsLabel": "小时", + "xpack.apm.serviceDetails.enableErrorReportsPanel.intervalUnit.minsLabel": "分钟", + "xpack.apm.serviceDetails.enableErrorReportsPanel.occurrencesThresholdHelpText": "要将错误组包括在报告中所要达到的阈值。", + "xpack.apm.serviceDetails.enableErrorReportsPanel.occurrencesThresholdLabel": "每错误组的发生次数阈值", + "xpack.apm.serviceDetails.enableErrorReportsPanel.recipientsHelpText": "如果未配置电子邮件,请参阅{documentationLink}", + "xpack.apm.serviceDetails.enableErrorReportsPanel.recipientsHelpText.documentationLinkText": "文档", + "xpack.apm.serviceDetails.enableErrorReportsPanel.recipientsLabel": "接收人(逗号分隔)", + "xpack.apm.serviceDetails.enableErrorReportsPanel.sendEmailLabel": "发送电子邮件", + "xpack.apm.serviceDetails.enableErrorReportsPanel.sendSlackNotificationLabel": "发送 Slack 通知", + "xpack.apm.serviceDetails.enableErrorReportsPanel.slackTemplateText": "您的服务 {serviceName} 具有在 {timeRange}内发生次数超过 {threshold} 次的错误组\n{errorGroupsBuckets}\n{errorLogMessage}\n{errorCulprit}不适用{slashErrorCulprit}\n{docCountParam} 次发生\n{slashErrorGroupsBucket}", + "xpack.apm.serviceDetails.enableErrorReportsPanel.slackWebhookURLHelpText": "要获取 Slack Webhook,请参阅{documentationLink}", + "xpack.apm.serviceDetails.enableErrorReportsPanel.slackWebhookURLHelpText.documentationLinkText": "文档", + "xpack.apm.serviceDetails.enableErrorReportsPanel.slackWebhookURLLabel": "Slack Webhook URL", + "xpack.apm.serviceDetails.enableErrorReportsPanel.triggerScheduleDescription": "选择阈值达到时报告的时间间隔。", + "xpack.apm.serviceDetails.enableErrorReportsPanel.triggerScheduleTitle": "触发排定", + "xpack.apm.serviceDetails.enableErrorReportsPanel.triggerText": "必须在触发器部分更改此值", + "xpack.apm.serviceDetails.enableErrorReportsPanel.watchCreatedNotificationText": "监视已就绪,将发送 {serviceName} 的错误报告。", + "xpack.apm.serviceDetails.enableErrorReportsPanel.watchCreatedNotificationText.viewWatchLinkText": "查看监视", + "xpack.apm.serviceDetails.enableErrorReportsPanel.watchCreatedNotificationTitle": "新监视已创建!", + "xpack.apm.serviceDetails.enableErrorReportsPanel.watchCreationFailedNotificationText": "确保您的用户有权创建监视。", + "xpack.apm.serviceDetails.enableErrorReportsPanel.watchCreationFailedNotificationTitle": "监视创建失败", + "xpack.apm.serviceDetails.errorsTabLabel": "错误", + "xpack.apm.serviceDetails.integrationsMenu.enableMLAnomalyDetectionButtonLabel": "启用 ML 异常检测", + "xpack.apm.serviceDetails.integrationsMenu.enableMLAnomalyDetectionButtonTooltip": "为此服务设置 Machine Learning 作业", + "xpack.apm.serviceDetails.integrationsMenu.enableWatcherErrorReportsButtonLabel": "启用 Watcher 错误报告", + "xpack.apm.serviceDetails.integrationsMenu.integrationsButtonLabel": "集成", + "xpack.apm.serviceDetails.integrationsMenu.viewWatchesButtonLabel": "查看现有监视", + "xpack.apm.serviceDetails.metrics.cpuUsageChartTitle": "CPU 使用", + "xpack.apm.serviceDetails.metrics.errorOccurrencesChartTitle": "错误发生次数", + "xpack.apm.serviceDetails.metrics.memoryUsageChartTitle": "系统内存使用", + "xpack.apm.serviceDetails.metricsTabLabel": "指标", + "xpack.apm.serviceDetails.nodesTabLabel": "JVM", + "xpack.apm.serviceDetails.transactionsTabLabel": "事务", + "xpack.apm.serviceMap.fullscreen": "全屏", + "xpack.apm.serviceMap.zoomIn": "放大", + "xpack.apm.serviceMap.zoomOut": "缩小", + "xpack.apm.serviceNodeMetrics.containerId": "容器 ID", + "xpack.apm.serviceNodeMetrics.host": "主机", + "xpack.apm.serviceNodeMetrics.unidentifiedServiceNodesWarningDocumentationLink": "APM Server 的文档", + "xpack.apm.serviceNodeMetrics.unidentifiedServiceNodesWarningText": "无法识别这些指标属于哪些 JVM。这可能因为运行的 APM Server 版本低于 7.5。如果升级到 APM Server 7.5 或更高版本,应可解决此问题。有关升级的详细信息,请参阅{link}。或者,也可以使用 Kibana 查询栏按主机名、容器 ID 或其他字段筛选。", + "xpack.apm.serviceNodeMetrics.unidentifiedServiceNodesWarningTitle": "找不到 JVM", + "xpack.apm.serviceNodeNameMissing": "(空)", + "xpack.apm.serviceOverview.toastText": "您正在运行 Elastic Stack 7.0+,我们检测到来自以前 6.x 版本的不兼容数据。如果想在 APM 中查看,您应迁移这些数据。在以下位置查看更多: ", + "xpack.apm.serviceOverview.toastTitle": "在选定时间范围中检测到旧数据", + "xpack.apm.serviceOverview.upgradeAssistantLink": "升级助手", + "xpack.apm.servicesTable.7xOldDataMessage": "可能还有需要迁移的旧数据。", + "xpack.apm.servicesTable.7xUpgradeServerMessage": "从 7.x 之前的版本升级?确保您已将\n APM 服务器实例升级到至少 7.0。", + "xpack.apm.servicesTable.agentColumnLabel": "代理", + "xpack.apm.servicesTable.avgResponseTimeColumnLabel": "平均响应时间", + "xpack.apm.servicesTable.environmentColumnLabel": "环境", + "xpack.apm.servicesTable.environmentCount": "{environmentCount, plural, one {1 个环境} other {# 个环境}}", + "xpack.apm.servicesTable.errorsPerMinuteColumnLabel": "每分钟错误数", + "xpack.apm.servicesTable.errorsPerMinuteUnitLabel": "错误", + "xpack.apm.servicesTable.nameColumnLabel": "名称", + "xpack.apm.servicesTable.noServicesLabel": "似乎您没有安装任何 APM 服务。让我们添加一些!", + "xpack.apm.servicesTable.notFoundLabel": "未找到任何服务", + "xpack.apm.servicesTable.transactionsPerMinuteColumnLabel": "每分钟事务数", + "xpack.apm.servicesTable.transactionsPerMinuteUnitLabel": "tpm", + "xpack.apm.servicesTable.UpgradeAssistantLink": "通过访问 Kibana 升级助手来了解详情", + "xpack.apm.settings.agentConf.allOptionLabel": "全部", + "xpack.apm.settings.agentConf.cancelButtonLabel": "取消", + "xpack.apm.settings.agentConf.configTable.appliedTooltipMessage": "已至少由一个代理应用", + "xpack.apm.settings.agentConf.configTable.captureBodyColumnLabel": "捕获正文", + "xpack.apm.settings.agentConf.configTable.configTable.failurePromptText": "无法获取代理配置列表。您的用户可能没有足够的权限。", + "xpack.apm.settings.agentConf.configTable.createConfigButtonLabel": "创建配置", + "xpack.apm.settings.agentConf.configTable.editButtonDescription": "编辑此配置", + "xpack.apm.settings.agentConf.configTable.editButtonLabel": "编辑", + "xpack.apm.settings.agentConf.configTable.emptyPromptText": "让我们改动一下!可以直接从 Kibana 微调代理配置,无需重新部署。首先创建您的第一个配置。", + "xpack.apm.settings.agentConf.configTable.emptyPromptTitle": "未找到任何配置。", + "xpack.apm.settings.agentConf.configTable.environmentColumnLabel": "服务环境", + "xpack.apm.settings.agentConf.configTable.lastUpdatedColumnLabel": "最后更新时间", + "xpack.apm.settings.agentConf.configTable.notAppliedTooltipMessage": "尚未由任何代理应用", + "xpack.apm.settings.agentConf.configTable.sampleRateColumnLabel": "采样速率", + "xpack.apm.settings.agentConf.configTable.serviceNameColumnLabel": "服务名称", + "xpack.apm.settings.agentConf.configTable.transactionMaxSpansColumnLabel": "事务最大跨度数", + "xpack.apm.settings.agentConf.configurationsPanelTitle": "代理远程配置", + "xpack.apm.settings.agentConf.createConfigButtonLabel": "创建配置", + "xpack.apm.settings.agentConf.createConfigTitle": "创建配置", + "xpack.apm.settings.agentConf.editConfigTitle": "编辑配置", + "xpack.apm.settings.agentConf.flyout.deleteSection.buttonLabel": "删除", + "xpack.apm.settings.agentConf.flyout.deleteSection.deleteConfigFailedText": "为“{serviceName}”删除配置时出现问题。错误:“{errorMessage}”", + "xpack.apm.settings.agentConf.flyout.deleteSection.deleteConfigFailedTitle": "配置无法删除", + "xpack.apm.settings.agentConf.flyout.deleteSection.deleteConfigSucceededText": "您已成功为“{serviceName}”删除配置。将需要一些时间才能传播到代理。", + "xpack.apm.settings.agentConf.flyout.deleteSection.deleteConfigSucceededTitle": "配置已删除", + "xpack.apm.settings.agentConf.flyOut.serviceSection.alreadyConfiguredOption": "已配置", + "xpack.apm.settings.agentConf.flyOut.serviceSection.selectPlaceholder": "选择", + "xpack.apm.settings.agentConf.flyOut.serviceSection.serviceEnvironmentSelectHelpText": "每个配置仅支持单个环境。", + "xpack.apm.settings.agentConf.flyOut.serviceSection.serviceEnvironmentSelectLabel": "环境", + "xpack.apm.settings.agentConf.flyOut.serviceSection.serviceNameSelectHelpText": "选择要配置的服务。", + "xpack.apm.settings.agentConf.flyOut.serviceSection.serviceNameSelectLabel": "名称", + "xpack.apm.settings.agentConf.flyOut.serviceSection.title": "服务", + "xpack.apm.settings.agentConf.flyOut.settingsSection.captureBodyInputHelpText": "有关属于 HTTP 请求的事务,代理可以选择性地捕获请求正文(例如 POST 变量)。默认为“off”。", + "xpack.apm.settings.agentConf.flyOut.settingsSection.captureBodyInputLabel": "捕获正文", + "xpack.apm.settings.agentConf.flyOut.settingsSection.captureBodyInputPlaceholderText": "选择选项", + "xpack.apm.settings.agentConf.flyOut.settingsSection.sampleRateConfigurationInputErrorText": "采样速率必须介于 0.000 和 1 之间", + "xpack.apm.settings.agentConf.flyOut.settingsSection.sampleRateConfigurationInputHelpText": "选择 0.000 和 1.0 之间的速率。默认为 1.0(100% 的跟踪)。", + "xpack.apm.settings.agentConf.flyOut.settingsSection.sampleRateConfigurationInputLabel": "事务采样速率", + "xpack.apm.settings.agentConf.flyOut.settingsSection.sampleRateConfigurationInputPlaceholderText": "设置采样速率", + "xpack.apm.settings.agentConf.flyOut.settingsSection.title": "选项", + "xpack.apm.settings.agentConf.flyOut.settingsSection.transactionMaxSpansConfigInputErrorText": "必须介于 0 和 32000 之间", + "xpack.apm.settings.agentConf.flyOut.settingsSection.transactionMaxSpansConfigInputHelpText": "限制每个事务记录的跨度数量。默认值为 500。", + "xpack.apm.settings.agentConf.flyOut.settingsSection.transactionMaxSpansConfigInputLabel": "事务最大跨度数", + "xpack.apm.settings.agentConf.flyOut.settingsSection.transactionMaxSpansConfigInputPlaceholderText": "设置事务最大跨度数", + "xpack.apm.settings.agentConf.saveConfig.failed.text": "编辑“{serviceName}”的配置时出现问题。错误:“{errorMessage}”", + "xpack.apm.settings.agentConf.saveConfig.failed.title": "配置无法编辑", + "xpack.apm.settings.agentConf.saveConfig.succeeded.text": "“{serviceName}”的配置已保存。将需要一些时间才能传播到代理。", + "xpack.apm.settings.agentConf.saveConfig.succeeded.title": "配置已保存", + "xpack.apm.settings.agentConf.saveConfigurationButtonLabel": "保存", + "xpack.apm.settingsLinkLabel": "璁剧疆", + "xpack.apm.setupInstructionsButtonLabel": "设置说明", + "xpack.apm.stacktraceTab.localVariablesToogleButtonLabel": "本地变量", + "xpack.apm.stacktraceTab.noStacktraceAvailableLabel": "没有可用的堆栈追溯信息。", + "xpack.apm.toggleHeight.showLessButtonLabel": "显示较少行", + "xpack.apm.toggleHeight.showMoreButtonLabel": "显示更多行", + "xpack.apm.tracesTable.avgResponseTimeColumnLabel": "平均响应时间", + "xpack.apm.tracesTable.impactColumnDescription": "服务中最常用的和最慢的终端节点。其计算方法是相对平均持续时间乘以每分钟事务数。", + "xpack.apm.tracesTable.impactColumnLabel": "影响", + "xpack.apm.tracesTable.nameColumnLabel": "名称", + "xpack.apm.tracesTable.notFoundLabel": "未找到与此查询的任何追溯信息", + "xpack.apm.tracesTable.originatingServiceColumnLabel": "发起服务", + "xpack.apm.tracesTable.tracesPerMinuteColumnLabel": "每分钟追溯次数", + "xpack.apm.tracesTable.tracesPerMinuteUnitLabel": "tpm", + "xpack.apm.transactionActionMenu.actionsButtonLabel": "操作", + "xpack.apm.transactionActionMenu.actionsLabel": "操作", + "xpack.apm.transactionActionMenu.showContainerLogsLinkLabel": "显示容器日志", + "xpack.apm.transactionActionMenu.showContainerMetricsLinkLabel": "显示容器指标", + "xpack.apm.transactionActionMenu.showHostLogsLinkLabel": "显示主机日志", + "xpack.apm.transactionActionMenu.showHostMetricsLinkLabel": "显示主机指标", + "xpack.apm.transactionActionMenu.showPodLogsLinkLabel": "显示 Pod 日志", + "xpack.apm.transactionActionMenu.showPodMetricsLinkLabel": "显示 Pod 指标", + "xpack.apm.transactionActionMenu.showTraceLogsLinkLabel": "显示跟踪日志", + "xpack.apm.transactionActionMenu.viewInUptime": "查看监测状态", + "xpack.apm.transactionActionMenu.viewSampleDocumentLinkLabel": "查看样例文档", + "xpack.apm.transactionBreakdown.chartTitle": "跨度类型花费的时间", + "xpack.apm.transactionBreakdown.hideChart": "隐藏图表", + "xpack.apm.transactionBreakdown.noData": "此时间范围内没有数据。", + "xpack.apm.transactionBreakdown.showChart": "显示图表", + "xpack.apm.transactionDetails.errorCount": "{errorCount, number} 个 {errorCount, plural, one {错误} other {错误}}", + "xpack.apm.transactionDetails.errorsOverviewLinkTooltip": "{errorCount, plural, one {查看 1 个相关错误} other {查看 # 个相关错误}}", + "xpack.apm.transactionDetails.notFoundLabel": "未找到任何事务。", + "xpack.apm.transactionDetails.noTraceParentButtonTooltip": "找不到上级追溯", + "xpack.apm.transactionDetails.percentOfTraceLabelExplanation": "{parentType, select, transaction {事务} trace {trace} } 的 % 超过 100%,因为此{childType, select, span {跨度} transaction {transaction} }比根事务花费更长时间。", + "xpack.apm.transactionDetails.requestMethodLabel": "请求方法", + "xpack.apm.transactionDetails.resultLabel": "结果", + "xpack.apm.transactionDetails.serviceLabel": "服务", + "xpack.apm.transactionDetails.servicesTitle": "服务", + "xpack.apm.transactionDetails.spanFlyout.databaseStatementTitle": "数据库语句", + "xpack.apm.transactionDetails.spanFlyout.nameLabel": "名称", + "xpack.apm.transactionDetails.spanFlyout.spanAction": "操作", + "xpack.apm.transactionDetails.spanFlyout.spanDetailsTitle": "跨度详情", + "xpack.apm.transactionDetails.spanFlyout.spanSubtype": "子类型", + "xpack.apm.transactionDetails.spanFlyout.spanType": "类型", + "xpack.apm.transactionDetails.spanFlyout.spanType.navigationTimingLabel": "导航定时", + "xpack.apm.transactionDetails.spanFlyout.stackTraceTabLabel": "堆栈追溯", + "xpack.apm.transactionDetails.spanFlyout.viewSpanInDiscoverButtonLabel": "在 Discover 中查看跨度", + "xpack.apm.transactionDetails.statusCode": "状态代码", + "xpack.apm.transactionDetails.traceNotFound": "找不到所选跟踪", + "xpack.apm.transactionDetails.traceSampleTitle": "跟踪样例", + "xpack.apm.transactionDetails.transactionLabel": "事务", + "xpack.apm.transactionDetails.transactionsDurationDistributionChart.noSampleTooltip": "此存储桶没有可用样例", + "xpack.apm.transactionDetails.transactionsDurationDistributionChart.requestTypeUnitLongLabel": "{transCount, plural, =0 {# 个请求} one {# 个请求} other {# 个请求}}", + "xpack.apm.transactionDetails.transactionsDurationDistributionChart.transactionTypeUnitLongLabel": "{transCount, plural, =0 {# 个事务} one {# 个事务} other {# 个事务}}", + "xpack.apm.transactionDetails.transactionsDurationDistributionChart.unitShortLabel": "{transCount} 个{transType, select, request {请求} other {事务}}", + "xpack.apm.transactionDetails.transactionsDurationDistributionChartTitle": "事务持续时间分布", + "xpack.apm.transactionDetails.transactionsDurationDistributionChartTooltip.samplingDescription": "每个存储桶将显示一个样例事务。如果没有可用的样例,很可能是在代理配置设置了采样限制。", + "xpack.apm.transactionDetails.transactionsDurationDistributionChartTooltip.samplingLabel": "采样", + "xpack.apm.transactionDetails.transFlyout.callout.agentDroppedSpansMessage": "报告此事务的 APM 代理基于其配置丢弃了 {dropped} 个跨度。", + "xpack.apm.transactionDetails.transFlyout.callout.learnMoreAboutDroppedSpansLinkText": "详细了解丢弃的跨度。", + "xpack.apm.transactionDetails.transFlyout.transactionDetailsTitle": "事务详情", + "xpack.apm.transactionDetails.userAgentAndVersionLabel": "用户代理和版本", + "xpack.apm.transactionDetails.viewFullTraceButtonLabel": "查看完整追溯信息", + "xpack.apm.transactionDetails.viewingFullTraceButtonTooltip": "当前正在查看完整追溯信息", + "xpack.apm.transactionDurationLabel": "持续时间", + "xpack.apm.transactions.chart.95thPercentileLabel": "第 95 个百分位", + "xpack.apm.transactions.chart.99thPercentileLabel": "第 99 个百分位", + "xpack.apm.transactions.chart.anomalyBoundariesLabel": "异常边界", + "xpack.apm.transactions.chart.anomalyScoreLabel": "异常分数", + "xpack.apm.transactions.chart.averageLabel": "平均", + "xpack.apm.transactionsTable.95thPercentileColumnLabel": "第 95 个百分位", + "xpack.apm.transactionsTable.avgDurationColumnLabel": "平均持续时间", + "xpack.apm.transactionsTable.impactColumnDescription": "服务中最常用的和最慢的终端节点。其计算方法是相对平均持续时间乘以每分钟事务数。", + "xpack.apm.transactionsTable.impactColumnLabel": "影响", + "xpack.apm.transactionsTable.nameColumnLabel": "名称", + "xpack.apm.transactionsTable.notFoundLabel": "未找到任何事务。", + "xpack.apm.transactionsTable.transactionsPerMinuteColumnLabel": "每分钟事务数", + "xpack.apm.transactionsTable.transactionsPerMinuteUnitLabel": "tpm", + "xpack.apm.waterfall.exceedsMax": "此跟踪中的项目数超过显示的项目数", + "xpack.beatsManagement.beat.actionSectionTypeLabel": "类型:{beatType}。", + "xpack.beatsManagement.beat.actionSectionVersionLabel": "版本:{beatVersion}。", + "xpack.beatsManagement.beat.beatNameAndIdTitle": "Beat:{nameOrNoName}(ID:{id})", + "xpack.beatsManagement.beat.beatNotFoundErrorMessage": "未找到 Beat", + "xpack.beatsManagement.beat.beatNotFoundErrorTitle": "未找到 Beat", + "xpack.beatsManagement.beat.beatNotFoundMessage": "未找到 Beat", + "xpack.beatsManagement.beat.configTabLabel": "配置", + "xpack.beatsManagement.beat.configurationTagsTabLabel": "配置标记", + "xpack.beatsManagement.beat.detailsConfigurationDescription": "可以将多个配置应用到单个标记。这些配置类型可以根据需要进行重复或混合。例如,您可以同时使用三个 Metricbeat 配置和一个输入和 Filebeat 配置。", + "xpack.beatsManagement.beat.detailsConfigurationTitle": "配置", + "xpack.beatsManagement.beat.lastConfigUpdateMessage": "上次配置更新:{lastUpdateTime}。", + "xpack.beatsManagement.beat.loadingTitle": "正在加载", + "xpack.beatsManagement.beatConfigurations.descriptionColumnName": "描述", + "xpack.beatsManagement.beatConfigurations.moduleColumnName": "模块", + "xpack.beatsManagement.beatConfigurations.tagColumnName": "标签", + "xpack.beatsManagement.beatConfigurations.typeColumnName": "类型", + "xpack.beatsManagement.beats.addedNotificationDescription": "将标记 {tag} 添加到 {assignmentsLength, plural, one {个 Beat {beatName}} other {# 个 Beats}}。", + "xpack.beatsManagement.beats.addedNotificationTitle": "{assignmentsLength, plural, one {个标记} other {个标记}}已添加", + "xpack.beatsManagement.beats.beatDisenrolledNotificationDescription": "ID 为 {firstBeatId} 的 Beat 已除名。", + "xpack.beatsManagement.beats.beatDisenrolledNotificationTitle": "{firstBeatNameOrId} 已除名", + "xpack.beatsManagement.beats.configurationTagsTabTitle": "配置标记", + "xpack.beatsManagement.beats.disenrolledBeatsNotificationTitle": "{beatsLength} 个 Beats 已除名", + "xpack.beatsManagement.beats.enrollBeatsButtonLabel": "注册 Beats", + "xpack.beatsManagement.beats.enrolledBeatsTabTitle": "已注册 Beats", + "xpack.beatsManagement.beats.enrollNewBeatsTitle": "注册新 Beat", + "xpack.beatsManagement.beats.installBeatsLearningButtonLabel": "了解如何安装 Beats", + "xpack.beatsManagement.beats.removedNotificationDescription": "已从 {assignmentsLength, plural, one {Beat {beatName}} other {# 个 Beat}} 移除标记 {tag}", + "xpack.beatsManagement.beats.removedNotificationTitle": "{assignmentsLength, plural, one {个标记} other {个标记}}已删除", + "xpack.beatsManagement.beatsListAssignmentOptions.setTagsButtonLabel": "设置标记", + "xpack.beatsManagement.beatsListAssignmentOptions.unenrollBeatsWarninigMessage": "选定的 Beats 将不再使用集中管理", + "xpack.beatsManagement.beatsListAssignmentOptions.unenrollBeatsWarninigTitle": "取消注册选定的 Beats?", + "xpack.beatsManagement.beatsListAssignmentOptions.unenrollButtonLabel": "取消注册选定", + "xpack.beatsManagement.beatsTable.beatNameTitle": "Beat 名称", + "xpack.beatsManagement.beatsTable.configErrorStatusLabel": "配置错误", + "xpack.beatsManagement.beatsTable.configStatus.errorTooltip": "此 Beat 有错误,请查看此主机的日志。", + "xpack.beatsManagement.beatsTable.configStatus.noConnectionTooltip": "此 Beat 未连接到 Kibana 的时间已超过 10 分钟", + "xpack.beatsManagement.beatsTable.configStatus.notStartedLabel": "未开始", + "xpack.beatsManagement.beatsTable.configStatus.notStartedTooltip": "此 Beat 尚未启动。", + "xpack.beatsManagement.beatsTable.configStatus.offlineLabel": "脱机", + "xpack.beatsManagement.beatsTable.configStatus.okLabel": "确定", + "xpack.beatsManagement.beatsTable.configStatus.okTooltip": "Beat 成功应用最新的配置", + "xpack.beatsManagement.beatsTable.configStatus.progressTooltip": "此 Beat 当前正在从 CM 重新加载配置。", + "xpack.beatsManagement.beatsTable.configStatus.runningTooltip": "此 Beat 正在运行,没有任何问题。", + "xpack.beatsManagement.beatsTable.configStatus.startingTooltip": "此 Beat 正在启动。", + "xpack.beatsManagement.beatsTable.configStatusTitle": "配置状态", + "xpack.beatsManagement.beatsTable.disenrollSelectedLabel": "取消注册选定", + "xpack.beatsManagement.beatsTable.failedStatusLabel": "错误", + "xpack.beatsManagement.beatsTable.runningStatusLabel": "正在运行", + "xpack.beatsManagement.beatsTable.startingStatusLabel": "正在启动", + "xpack.beatsManagement.beatsTable.stoppedStatusLabel": "已停止", + "xpack.beatsManagement.beatsTable.tagsTitle": "标记", + "xpack.beatsManagement.beatsTable.typeLabel": "类型", + "xpack.beatsManagement.beatsTable.typeTitle": "类型", + "xpack.beatsManagement.beatsTable.updatingStatusLabel": "正在更新", + "xpack.beatsManagement.beatTagsTable.addTagLabel": "添加标记", + "xpack.beatsManagement.beatTagsTable.lastUpdateTitle": "上次更新", + "xpack.beatsManagement.beatTagsTable.removeSelectedLabel": "删除选定", + "xpack.beatsManagement.beatTagsTable.tagNameTitle": "标记名称", + "xpack.beatsManagement.breadcrumb.beatDetails": "{beatId} 的 Beat 详情", + "xpack.beatsManagement.breadcrumb.beatTags": "{beatId} 的 Beat 标记", + "xpack.beatsManagement.breadcrumb.configurationTags": "配置标记", + "xpack.beatsManagement.breadcrumb.enrolledBeats": "已注册 Beats", + "xpack.beatsManagement.centralManagementLinkLabel": "集中管理", + "xpack.beatsManagement.centralManagementSectionLabel": "Beats", + "xpack.beatsManagement.config.other.error": "使用有效的 YAML 格式", + "xpack.beatsManagement.config.otherConfigDescription": "使用 YAML 格式指定 Filebeat 输入的其他设置", + "xpack.beatsManagement.config.otherConfigLabel": "其他配置", + "xpack.beatsManagement.confirmModal.cancelButtonLabel": "取消", + "xpack.beatsManagement.confirmModal.confirmButtonLabel": "确认", + "xpack.beatsManagement.confirmModal.confirmWarningTitle": "确认", + "xpack.beatsManagement.createTag.errorSavingTagTitle": "保存标记时出错", + "xpack.beatsManagement.createTag.saveAndContinueButtonLabel": "保存并继续", + "xpack.beatsManagement.disabledSecurityDescription": "必须在 Kibana 和 Elasticsearch 启用安全性,才能使用 Beats 集中管理。", + "xpack.beatsManagement.disabledSecurityTitle": "安全性未启用", + "xpack.beatsManagement.enrollBeat.assignTagToBeatInvalidURLNoTagFoundTitle": "URL 无效,未找到 createdTag", + "xpack.beatsManagement.enrollBeat.assignTagToBeatInvalidURLNoTokenFountTitle": "URL 无效,未找到 enrollmentToken", + "xpack.beatsManagement.enrollBeat.assignTagToBeatNotEnrolledProperlyTitle": "错误:Beat 未正确注册", + "xpack.beatsManagement.enrollBeat.beatEnrolledTitle": "该 Beat 当前已在集中管理中注册:", + "xpack.beatsManagement.enrollBeat.beatsCentralManagementDescription": "在集中位置管理您的配置。", + "xpack.beatsManagement.enrollBeat.beatTypeColumnName": "Beat 类型", + "xpack.beatsManagement.enrollBeat.beatTypeTitle": "Beat 类型:", + "xpack.beatsManagement.enrollBeat.copyButtonLabel": "复制命令", + "xpack.beatsManagement.enrollBeat.createTagStepLabel": "创建标记", + "xpack.beatsManagement.enrollBeat.enrollBeatButtonLabel": "注册 Beat", + "xpack.beatsManagement.enrollBeat.enrollBeatStepLabel": "注册 Beat", + "xpack.beatsManagement.enrollBeat.finishStepLabel": "完成", + "xpack.beatsManagement.enrollBeat.firstBeatEnrollingDoneButtonLabel": "完成", + "xpack.beatsManagement.enrollBeat.getStartedBeatsCentralManagementTitle": "开始使用 Beats 集中管理", + "xpack.beatsManagement.enrollBeat.hostnameColumnName": "主机名", + "xpack.beatsManagement.enrollBeat.nextStepDescription": "启动您的 Beat 以检查是否有配置错误,然后单击“完成”。", + "xpack.beatsManagement.enrollBeat.nextStepTitle": "您的 Beat 已注册。后续操作", + "xpack.beatsManagement.enrollBeat.platformTitle": "平台:", + "xpack.beatsManagement.enrollBeat.versionColumnName": "版本", + "xpack.beatsManagement.enrollBeat.waitingBeatTypeToEnrollTitle": "正在等待注册 {beatType}……", + "xpack.beatsManagement.enrollBeat.yourBeatTypeHostTitle": "在安装您的 {beatType} 的主机上,运行:", + "xpack.beatsManagement.filebeatInputConfig.otherConfigDescription": "使用 YAML 格式指定 Filebeat 输入的其他设置", + "xpack.beatsManagement.filebeatInputConfig.otherConfigErrorMessage": "使用有效的 YAML 格式", + "xpack.beatsManagement.filebeatInputConfig.otherConfigLabel": "其他配置", + "xpack.beatsManagement.filebeatInputConfig.pathsDescription": "将每个路径放置在单独的行上", + "xpack.beatsManagement.filebeatInputConfig.pathsErrorMessage": "每行一个文件路径", + "xpack.beatsManagement.filebeatInputConfig.pathsLabel": "路径", + "xpack.beatsManagement.filebeatModuleConfig.moduleDescription": "使用 YAML 格式指定 Filebeat 模块的其他设置", + "xpack.beatsManagement.filebeatModuleConfig.moduleErrorMessage": "请选择模块", + "xpack.beatsManagement.filebeatModuleConfig.moduleLabel": "模块", + "xpack.beatsManagement.filebeatModuleConfig.otherConfigErrorMessage": "使用有效的 YAML 格式", + "xpack.beatsManagement.filebeatModuleConfig.otherConfigLabel": "其他配置", + "xpack.beatsManagement.invalidLicenseDescription": "您当前的许可已过期。已注册 Beats 将继续工作,但您需要有效的许可,才能访问 Beats 管理 UI。", + "xpack.beatsManagement.invalidLicenseTitle": "已过期许可", + "xpack.beatsManagement.management.breadcrumb": "管理", + "xpack.beatsManagement.metricbeatModuleConfig.hostsDescription": "将每个路径放置在单独的行上", + "xpack.beatsManagement.metricbeatModuleConfig.hostsErrorMessage": "每行一个文件主机", + "xpack.beatsManagement.metricbeatModuleConfig.hostsLabel": "主机", + "xpack.beatsManagement.metricbeatModuleConfig.moduleErrorMessage": "请选择模块", + "xpack.beatsManagement.metricbeatModuleConfig.moduleLabel": "模块", + "xpack.beatsManagement.metricbeatModuleConfig.otherConfigDescription": "使用 YAML 格式指定 Metricbeat 模块的其他设置", + "xpack.beatsManagement.metricbeatModuleConfig.otherConfigErrorMessage": "使用有效的 YAML 格式", + "xpack.beatsManagement.metricbeatModuleConfig.otherConfigLabel": "其他配置", + "xpack.beatsManagement.metricbeatModuleConfig.periodErrorMessage": "期间无效,10 秒的格式必须为 `10s`。", + "xpack.beatsManagement.metricbeatModuleConfig.periodLabel": "期间", + "xpack.beatsManagement.noAccess.accessDeniedDescription": "您无权访问 Beats 集中管理。要使用 Beats 集中管理,您需要 {beatsAdminRole} 角色授予的权限。", + "xpack.beatsManagement.noAccess.accessDeniedTitle": "访问被拒绝", + "xpack.beatsManagement.noContentFoundErrorMessage": "未找到任何内容", + "xpack.beatsManagement.outputConfig.hostsErrorMessage": "每行一个文件主机", + "xpack.beatsManagement.outputConfig.hostsLabel": "主机", + "xpack.beatsManagement.outputConfig.outputTypeErrorMessage": "请选择输出类型", + "xpack.beatsManagement.outputConfig.outputTypeLabel": "输出类型", + "xpack.beatsManagement.outputConfig.passwordErrorMessage": "无法处理的密码", + "xpack.beatsManagement.outputConfig.passwordLabel": "密码", + "xpack.beatsManagement.outputConfig.usernameErrorMessage": "无法处理的用户名", + "xpack.beatsManagement.outputConfig.usernameLabel": "用户名", + "xpack.beatsManagement.overview.betaBadgeText": "公测版", + "xpack.beatsManagement.table.filterResultsPlaceholder": "筛选结果", + "xpack.beatsManagement.table.selectOptionLabel": "请选择选项", + "xpack.beatsManagement.table.selectThisBeatTooltip": "选择此 Beat", + "xpack.beatsManagement.tag.addConfigurationButtonLabel": "添加配置块", + "xpack.beatsManagement.tag.beatsAssignedToTagTitle": "具有此标记的 Beats", + "xpack.beatsManagement.tag.cancelButtonLabel": "取消", + "xpack.beatsManagement.tag.createTagTitle": "创建标记", + "xpack.beatsManagement.tag.saveButtonLabel": "保存", + "xpack.beatsManagement.tag.tagColorLabel": "标记颜色", + "xpack.beatsManagement.tag.tagConfigurationsDescription": "标记可以有不同类型 Beats 的配置块。例如,标记可以有两个 Metricbeat 配置块和一个 Filebeat 输入配置块。", + "xpack.beatsManagement.tag.tagConfigurationsTitle": "配置块", + "xpack.beatsManagement.tag.tagDetailsDescription": "标记是可以应用到一个或多个 Beats 的一组配置块。", + "xpack.beatsManagement.tag.tagDetailsTitle": "标记详情", + "xpack.beatsManagement.tag.tagName.validationErrorMessage": "标记名称只能由字母、数字和短划线构成", + "xpack.beatsManagement.tag.tagNameLabel": "标记名称", + "xpack.beatsManagement.tag.tagNamePlaceholder": "标记名称(必填)", + "xpack.beatsManagement.tag.updateTagTitle": "创建标记:{tagId}", + "xpack.beatsManagement.tagConfig.addConfigurationTitle\"": "添加配置块", + "xpack.beatsManagement.tagConfig.closeButtonLabel": "关闭", + "xpack.beatsManagement.tagConfig.configurationTypeText": "{configType} 配置", + "xpack.beatsManagement.tagConfig.descriptionLabel": "描述", + "xpack.beatsManagement.tagConfig.descriptionPlaceholder": "描述(可选)", + "xpack.beatsManagement.tagConfig.editConfigurationTitle": "编辑配置块", + "xpack.beatsManagement.tagConfig.filebeatInputLabel": "Filebeat 输入", + "xpack.beatsManagement.tagConfig.filebeatModuleLabel": "Filebeat 模块", + "xpack.beatsManagement.tagConfig.invalidSchema": "错误:此配置无效,其不受 Beats 支持,应移除", + "xpack.beatsManagement.tagConfig.metricbeatModuleLabel": "Metricbeat 模块", + "xpack.beatsManagement.tagConfig.outputLabel": "输出", + "xpack.beatsManagement.tagConfig.saveButtonLabel": "保存", + "xpack.beatsManagement.tagConfig.typeLabel": "类型", + "xpack.beatsManagement.tagConfig.viewConfigurationTitle\"": "查看配置块", + "xpack.beatsManagement.tagConfigAssignmentOptions.removeTagsButtonLabel": "删除标记", + "xpack.beatsManagement.tagConfigAssignmentOptions.removeTagsWarninigMessage": "从选定 Beats 删除该标记?", + "xpack.beatsManagement.tagConfigAssignmentOptions.removeTagsWarninigTitle": "删除标记", + "xpack.beatsManagement.tagListAssignmentOptions.removeTagsButtonLabel": "删除选定", + "xpack.beatsManagement.tagListAssignmentOptions.removeTagsWarninigTitle": "删除标记", + "xpack.beatsManagement.tagListAssignmentOptions.removeTagWarninigMessage": "删除标记?", + "xpack.beatsManagement.tags.addTagButtonLabel": "添加标记", + "xpack.beatsManagement.tags.someTagsMightBeAssignedToBeatsTitle": "以下部分标记可能已分配给 Beats。请确保正要删除的标记未分配", + "xpack.beatsManagement.tagsTable.lastUpdateTitle": "上次更新", + "xpack.beatsManagement.tagsTable.removeSelectedLabel": "删除选定", + "xpack.beatsManagement.tagsTable.tagNameTitle": "标记名称", + "xpack.beatsManagement.tagTable.actions.removeButtonAriaLabel": "删除", + "xpack.beatsManagement.tagTable.actions.removeTooltip": "从标记删除此配置", + "xpack.beatsManagement.tagTable.actionsColumnName": "操作", + "xpack.beatsManagement.tagTable.descriptionColumnName": "描述", + "xpack.beatsManagement.tagTable.moduleColumn.notAvailibaleLabel": "不适用", + "xpack.beatsManagement.tagTable.moduleColumnName": "模块", + "xpack.beatsManagement.tagTable.typeColumnName": "类型", + "xpack.beatsManagement.walkthrough.initial.betaBadgeText": "公测版", + "xpack.canvas.app.loadErrorMessage": "消息:{error}", + "xpack.canvas.app.loadErrorTitle": "Canvas 加载失败", + "xpack.canvas.app.loadingMessage": "Canvas 正在加载", + "xpack.canvas.appDescription": "以最佳像素展示您的数据。", + "xpack.canvas.argAddPopover.addAriaLabel": "添加参数", + "xpack.canvas.argFormAdvancedFailure.applyButtonLabel": "应用", + "xpack.canvas.argFormAdvancedFailure.resetButtonLabel": "重置", + "xpack.canvas.argFormAdvancedFailure.rowErrorMessage": "表达式无效", + "xpack.canvas.argFormArgSimpleForm.removeAriaLabel": "删除", + "xpack.canvas.argFormArgSimpleForm.requiredTooltip": "此参数为必需,应指定值。", + "xpack.canvas.argFormPendingArgValue.loadingMessage": "正在加载", + "xpack.canvas.argFormSimpleFailure.failureTooltip": "此参数的接口无法解析该值,因此将使用回退输入", + "xpack.canvas.asset.copyAssetTooltip": "将 ID 复制到剪贴板", + "xpack.canvas.asset.createImageTooltip": "创建图像元素", + "xpack.canvas.asset.deleteAssetTooltip": "删除", + "xpack.canvas.asset.downloadAssetTooltip": "下载", + "xpack.canvas.asset.thumbnailAltText": "资产缩略图", + "xpack.canvas.assetManager.confirmModalButtonLabel": "删除", + "xpack.canvas.assetManager.confirmModalDetail": "确定要删除此资产?", + "xpack.canvas.assetManager.confirmModalTitle": "删除资产", + "xpack.canvas.assetManager.manageButtonLabel": "管理资产", + "xpack.canvas.assetModal.emptyAssetsDescription": "导入您的资产以开始", + "xpack.canvas.assetModal.filePickerPromptText": "选择或拖放图像", + "xpack.canvas.assetModal.loadingText": "正在上传图像", + "xpack.canvas.assetModal.modalCloseButtonLabel": "关闭", + "xpack.canvas.assetModal.modalDescription": "以下为此 Workpad 中的图像资产。此时无法确定当前在用的任何资产。要回收空间,请删除资产。", + "xpack.canvas.assetModal.modalTitle": "管理 Workpad 资产", + "xpack.canvas.assetModal.spacedUsedText": "{percentageUsed}% 空间已用", + "xpack.canvas.assetpicker.assetAltText": "资产缩略图", + "xpack.canvas.badge.readOnly.text": "只读", + "xpack.canvas.badge.readOnly.tooltip": "无法保存 {canvas} Workpad", + "xpack.canvas.colorManager.addAriaLabel": "添加颜色", + "xpack.canvas.colorManager.codePlaceholder": "颜色代码", + "xpack.canvas.colorManager.removeAriaLabel": "删除颜色", + "xpack.canvas.customElementModal.cancelButtonLabel": "取消", + "xpack.canvas.customElementModal.descriptionInputLabel": "描述", + "xpack.canvas.customElementModal.elementPreviewTitle": "元素预览", + "xpack.canvas.customElementModal.imageFilePickerPlaceholder": "选择或拖放图像", + "xpack.canvas.customElementModal.imageInputDescription": "对您的元素进行截屏并将截图上传到此处。也可以在保存之后执行此操作。", + "xpack.canvas.customElementModal.imageInputLabel": "缩略图", + "xpack.canvas.customElementModal.nameInputLabel": "名称", + "xpack.canvas.customElementModal.remainingCharactersDescription": "剩余 {numberOfRemainingCharacter} 个字符", + "xpack.canvas.customElementModal.saveButtonLabel": "保存", + "xpack.canvas.datasourceDatasourceComponent.changeButtonLabel": "更改您的数据源", + "xpack.canvas.datasourceDatasourceComponent.previewButtonLabel": "预览", + "xpack.canvas.datasourceDatasourceComponent.saveButtonLabel": "保存", + "xpack.canvas.datasourceDatasourcePreview.emptyFirstLineDescription": "找不到与您的搜索条件匹配的任何文档。", + "xpack.canvas.datasourceDatasourcePreview.emptySecondLineDescription": "请检查您的数据源设置并重试。", + "xpack.canvas.datasourceDatasourcePreview.emptyTitle": "找不到文档", + "xpack.canvas.datasourceDatasourcePreview.modalDescription": "单击侧栏中“{saveLabel}”以保存此数据。", + "xpack.canvas.datasourceDatasourcePreview.modalTitle": "数据源预览", + "xpack.canvas.datasourceNoDatasource.panelDescription": "此元素未附加数据源。通常这是因为该元素为图像或其他静态资产。否则,您可能需要检查表达式,以确保其格式正确。", + "xpack.canvas.datasourceNoDatasource.panelTitle": "数据源不存在", + "xpack.canvas.elementConfig.failedLabel": "失败", + "xpack.canvas.elementConfig.loadedLabel": "已加载", + "xpack.canvas.elementConfig.progressLabel": "进度", + "xpack.canvas.elementConfig.title": "元素", + "xpack.canvas.elementConfig.totalLabel": "合计", + "xpack.canvas.elementControls.deleteAriaLabel": "删除元素", + "xpack.canvas.elementControls.deleteToolTip": "删除", + "xpack.canvas.elementControls.editAriaLabel": "编辑元素", + "xpack.canvas.elementControls.editToolTip": "编辑", + "xpack.canvas.elements.areaChartDisplayName": "面积图", + "xpack.canvas.elements.areaChartHelpText": "已填充主体的折线图", + "xpack.canvas.elements.bubbleChartDisplayName": "气泡图", + "xpack.canvas.elements.bubbleChartHelpText": "可定制的气泡图", + "xpack.canvas.elements.debugDisplayName": "“Debug”(故障排查)", + "xpack.canvas.elements.debugHelpText": "只需丢弃元素的配置", + "xpack.canvas.elements.donutChartDisplayName": "圆环图", + "xpack.canvas.elements.donutChartHelpText": "可定制的圆环图", + "xpack.canvas.elements.dropdownFilterDisplayName": "下拉列表筛选", + "xpack.canvas.elements.dropdownFilterHelpText": "可以从其中为“完全”筛选选择值的下拉列表", + "xpack.canvas.elements.horizontalBarChartDisplayName": "水平条形图", + "xpack.canvas.elements.horizontalBarChartHelpText": "可定制的水平条形图", + "xpack.canvas.elements.horizontalProgressBarDisplayName": "水平进度条", + "xpack.canvas.elements.horizontalProgressBarHelpText": "将进度显示为水平条的一部分", + "xpack.canvas.elements.horizontalProgressPillDisplayName": "水平进度胶囊", + "xpack.canvas.elements.horizontalProgressPillHelpText": "将进度显示为水平胶囊的一部分", + "xpack.canvas.elements.imageDisplayName": "图像", + "xpack.canvas.elements.imageHelpText": "静态图像", + "xpack.canvas.elements.lineChartDisplayName": "折线图", + "xpack.canvas.elements.lineChartHelpText": "可定制的折线图", + "xpack.canvas.elements.markdownDisplayName": "Markdown", + "xpack.canvas.elements.markdownHelpText": "来自 Markdown 的标记", + "xpack.canvas.elements.metricDisplayName": "指标", + "xpack.canvas.elements.metricHelpText": "具有标签的数字", + "xpack.canvas.elements.pieDisplayName": "饼图", + "xpack.canvas.elements.pieHelpText": "饼图", + "xpack.canvas.elements.plotDisplayName": "坐标图", + "xpack.canvas.elements.plotHelpText": "混合的折线图、条形图或点图", + "xpack.canvas.elements.progressGaugeDisplayName": "进度仪表", + "xpack.canvas.elements.progressGaugeHelpText": "将进度显示为仪表的一部分", + "xpack.canvas.elements.progressSemicircleDisplayName": "进度半圆", + "xpack.canvas.elements.progressSemicircleHelpText": "将进度显示为半圆的一部分", + "xpack.canvas.elements.progressWheelDisplayName": "进度轮盘", + "xpack.canvas.elements.progressWheelHelpText": "将进度显示为轮盘的一部分", + "xpack.canvas.elements.repeatImageDisplayName": "图像重复", + "xpack.canvas.elements.repeatImageHelpText": "使图像重复 N 次", + "xpack.canvas.elements.revealImageDisplayName": "图像显示", + "xpack.canvas.elements.revealImageHelpText": "显示图像特定百分比", + "xpack.canvas.elements.shapeDisplayName": "形状", + "xpack.canvas.elements.shapeHelpText": "可定制的形状", + "xpack.canvas.elements.tableDisplayName": "数据表", + "xpack.canvas.elements.tableHelpText": "用于以表格形式显示数据的可滚动网格", + "xpack.canvas.elements.tiltedPieDisplayName": "斜饼图", + "xpack.canvas.elements.tiltedPieHelpText": "可定制的斜饼图", + "xpack.canvas.elements.timeFilterDisplayName": "时间筛选", + "xpack.canvas.elements.timeFilterHelpText": "设置时间窗口", + "xpack.canvas.elements.verticalBarChartDisplayName": "垂直条形图", + "xpack.canvas.elements.verticalBarChartHelpText": "可定制的垂直条形图", + "xpack.canvas.elements.verticalProgressBarDisplayName": "垂直进度条", + "xpack.canvas.elements.verticalProgressBarHelpText": "将进度显示为垂直条的一部分", + "xpack.canvas.elements.verticalProgressPillDisplayName": "垂直进度胶囊", + "xpack.canvas.elements.verticalProgressPillHelpText": "将进度显示为垂直胶囊的一部分", + "xpack.canvas.elementSettings.dataTabLabel": "数据", + "xpack.canvas.elementSettings.displayTabLabel": "显示", + "xpack.canvas.elementTypes.addNewElementDescription": "分组并保存 Workpad 元素以创建新元素", + "xpack.canvas.elementTypes.addNewElementTitle": "添加新元素", + "xpack.canvas.elementTypes.cancelButtonLabel": "取消", + "xpack.canvas.elementTypes.deleteButtonLabel": "删除", + "xpack.canvas.elementTypes.deleteElementDescription": "确定要删除此元素?", + "xpack.canvas.elementTypes.deleteElementTitle": "删除元素“{elementName}”?", + "xpack.canvas.elementTypes.editElementTitle": "编辑元素", + "xpack.canvas.elementTypes.elementsTitle": "元素", + "xpack.canvas.elementTypes.findElementPlaceholder": "查找元素", + "xpack.canvas.elementTypes.myElementsTitle": "我的元素", + "xpack.canvas.embedObject.noMatchingObjectsMessage": "未找到任何匹配对象。", + "xpack.canvas.embedObject.titleText": "嵌入对象", + "xpack.canvas.error.actionsElements.invaludArgIndexErrorMessage": "无效的参数索引:{index}", + "xpack.canvas.error.downloadWorkpad.downloadFailureErrorMessage": "无法下载 Workpad", + "xpack.canvas.error.downloadWorkpad.downloadRenderedWorkpadFailureErrorMessage": "无法下载已呈现 Workpad", + "xpack.canvas.error.downloadWorkpad.downloadRuntimeFailureErrorMessage": "无法下载 Shareable Runtime", + "xpack.canvas.error.downloadWorkpad.downloadZippedRuntimeFailureErrorMessage": "无法下载 ZIP 文件", + "xpack.canvas.error.esPersist.saveFailureTitle": "无法将您的更改保存到 Elasticsearch", + "xpack.canvas.error.esPersist.tooLargeErrorMessage": "服务器响应 Workpad 数据过大。这通常表示上传的图像资产对于 Kibana 或代理过大。请尝试移除资产管理器中的一些资产。", + "xpack.canvas.error.esPersist.updateFailureTitle": "无法更新 Workpad", + "xpack.canvas.error.esService.defaultIndexFetchErrorMessage": "无法提取默认索引", + "xpack.canvas.error.esService.fieldsFetchErrorMessage": "无法为“{index}”提取 Elasticsearch 字段", + "xpack.canvas.error.esService.indicesFetchErrorMessage": "无法提取 Elasticsearch 索引", + "xpack.canvas.error.RenderWithFn.renderErrorMessage": "呈现“{functionName}”失败", + "xpack.canvas.error.repeatImage.missingMaxArgument": "如果提供 {emptyImageArgument},则必须设置 {maxArgument}", + "xpack.canvas.error.workpadLoader.cloneFailureErrorMessage": "无法克隆 Workpad", + "xpack.canvas.error.workpadLoader.deleteFailureErrorMessage": "无法删除所有 Workpad", + "xpack.canvas.error.workpadLoader.findFailureErrorMessage": "无法查找 Workpad", + "xpack.canvas.error.workpadLoader.uploadFailureErrorMessage": "无法上传 Workpad", + "xpack.canvas.error.workpadRoutes.createFailureErrorMessage": "无法创建 Workpad", + "xpack.canvas.error.workpadRoutes.loadFailureErrorMessage": "无法加载具有以下 ID 的 Workpad", + "xpack.canvas.error.workpadUpload.acceptJSONOnlyErrorMessage": "仅接受 {JSON} 文件", + "xpack.canvas.error.workpadUpload.fileUploadFailureWithoutFileNameErrorMessage": "无法上传文件", + "xpack.canvas.error.workpadUpload.missingPropertiesErrorMessage": "{CANVAS} Workpad 所需的某些属性缺失。 编辑 {JSON} 文件以提供正确的属性值,然后重试。", + "xpack.canvas.errorComponent.description": "表达式失败,并显示消息:", + "xpack.canvas.errorComponent.title": "哎哟!表达式失败", + "xpack.canvas.errors.workpadUpload.fileUploadFileWithFileNameErrorMessage": "无法上传“{fileName}”", + "xpack.canvas.expression.cancelButtonLabel": "取消", + "xpack.canvas.expression.closeButtonLabel": "关闭", + "xpack.canvas.expression.learnLinkText": "学习表达式语法", + "xpack.canvas.expression.maximizeButtonLabel": "最大化编辑器", + "xpack.canvas.expression.minimizeButtonLabel": "最小化编辑器", + "xpack.canvas.expression.runButtonLabel": "运行", + "xpack.canvas.expression.runTooltip": "运行表达式", + "xpack.canvas.expressionElementNotSelected.closeButtonLabel": "关闭", + "xpack.canvas.expressionElementNotSelected.selectDescription": "选择元素以显示表达式输入", + "xpack.canvas.expressionInput.argReferenceAliasesDetail": "{BOLD_MD_TOKEN}别名{BOLD_MD_TOKEN}:{aliases}", + "xpack.canvas.expressionInput.argReferenceDefaultDetail": "{BOLD_MD_TOKEN}默认{BOLD_MD_TOKEN}:{defaultVal}", + "xpack.canvas.expressionInput.argReferenceRequiredDetail": "{BOLD_MD_TOKEN}必需{BOLD_MD_TOKEN}:{required}", + "xpack.canvas.expressionInput.argReferenceTypesDetail": "{BOLD_MD_TOKEN}类型{BOLD_MD_TOKEN}:{types}", + "xpack.canvas.expressionInput.functionReferenceAccepts": "{BOLD_MD_TOKEN}接受{BOLD_MD_TOKEN}:{acceptTypes}", + "xpack.canvas.expressionInput.functionReferenceReturns": "{BOLD_MD_TOKEN}返回{BOLD_MD_TOKEN}:{returnType}", + "xpack.canvas.expressionTypes.argTypes.colorDisplayName": "颜色", + "xpack.canvas.expressionTypes.argTypes.colorHelp": "颜色选取器", + "xpack.canvas.expressionTypes.argTypes.containerStyle.appearanceTitle": "外观", + "xpack.canvas.expressionTypes.argTypes.containerStyle.borderTitle": "边框", + "xpack.canvas.expressionTypes.argTypes.containerStyle.colorLabel": "颜色", + "xpack.canvas.expressionTypes.argTypes.containerStyle.opacityLabel": "图层透明度", + "xpack.canvas.expressionTypes.argTypes.containerStyle.overflowHiddenDropDown": "隐藏", + "xpack.canvas.expressionTypes.argTypes.containerStyle.overflowLabel": "溢出", + "xpack.canvas.expressionTypes.argTypes.containerStyle.overflowVisibleDropDown": "可见", + "xpack.canvas.expressionTypes.argTypes.containerStyle.paddingLabel": "填充", + "xpack.canvas.expressionTypes.argTypes.containerStyle.radiusLabel": "半径", + "xpack.canvas.expressionTypes.argTypes.containerStyle.styleLabel": "样式", + "xpack.canvas.expressionTypes.argTypes.containerStyle.thicknessLabel": "厚度", + "xpack.canvas.expressionTypes.argTypes.containerStyleLabel": "调整元素容器的外观", + "xpack.canvas.expressionTypes.argTypes.containerStyleTitle": "容器样式", + "xpack.canvas.expressionTypes.argTypes.fontHelpLabel": "设置字体、大小和颜色", + "xpack.canvas.expressionTypes.argTypes.fontTitle": "文本设置", + "xpack.canvas.expressionTypes.argTypes.seriesStyle.barLabel": "条形图", + "xpack.canvas.expressionTypes.argTypes.seriesStyle.colorLabel": "颜色", + "xpack.canvas.expressionTypes.argTypes.seriesStyle.lineLabel": "折线图", + "xpack.canvas.expressionTypes.argTypes.seriesStyle.noneDropDown": "无", + "xpack.canvas.expressionTypes.argTypes.seriesStyle.noSeriesTooltip": "数据没有要应用样式的序列,请添加颜色维度", + "xpack.canvas.expressionTypes.argTypes.seriesStyle.pointLabel": "点", + "xpack.canvas.expressionTypes.argTypes.seriesStyle.removeAriaLabel": "移除序列颜色", + "xpack.canvas.expressionTypes.argTypes.seriesStyle.selectSeriesDropDown": "选择序列", + "xpack.canvas.expressionTypes.argTypes.seriesStyle.seriesIdentifierLabel": "序列标识符", + "xpack.canvas.expressionTypes.argTypes.seriesStyle.styleLabel": "样式", + "xpack.canvas.expressionTypes.argTypes.seriesStyleLabel": "设置选定已命名序列的样式", + "xpack.canvas.expressionTypes.argTypes.seriesStyleTitle": "序列样式", + "xpack.canvas.expressionTypes.datasources.esdocs.ascendingDropDown": "升序", + "xpack.canvas.expressionTypes.datasources.esdocs.descendingDropDown": "降序", + "xpack.canvas.expressionTypes.datasources.esdocs.fieldsLabel": "要提取的字段。Kibana 脚本字段当前不可用", + "xpack.canvas.expressionTypes.datasources.esdocs.fieldsTitle": "字段", + "xpack.canvas.expressionTypes.datasources.esdocs.fieldsWarningLabel": "字段不超过 10 个时,此数据源性能最佳", + "xpack.canvas.expressionTypes.datasources.esdocs.indexLabel": "输入索引名称或选择索引模式", + "xpack.canvas.expressionTypes.datasources.esdocs.indexTitle": "索引", + "xpack.canvas.expressionTypes.datasources.esdocs.queryLabel": "{lucene} 查询字符串语法", + "xpack.canvas.expressionTypes.datasources.esdocs.queryTitle": "查询", + "xpack.canvas.expressionTypes.datasources.esdocs.sortFieldLabel": "文档排序字段", + "xpack.canvas.expressionTypes.datasources.esdocs.sortFieldTitle": "排序字段", + "xpack.canvas.expressionTypes.datasources.esdocs.sortOrderLabel": "文档排序顺序", + "xpack.canvas.expressionTypes.datasources.esdocs.sortOrderTitle": "排序顺序", + "xpack.canvas.expressionTypes.datasources.esdocs.warningTitle": "务必谨慎操作", + "xpack.canvas.expressionTypes.datasources.esdocsLabel": "从 Elasticsearch 拉取原始文档", + "xpack.canvas.expressionTypes.datasources.esdocsTitle": "Elasticsearch 原始文档", + "xpack.canvas.functionForm.contextError": "错误:{errorMessage}", + "xpack.canvas.functionForm.functionUnknown.unknownArgumentTypeError": "表达式类型“{expressionType}”未知", + "xpack.canvas.functions.all.args.conditionHelpText": "要检查的条件。", + "xpack.canvas.functions.allHelpText": "如果满足所有条件,则返回 {BOOLEAN_TRUE}。另见 {anyFn}。", + "xpack.canvas.functions.alterColumn.args.columnHelpText": "要更改的列的名称。", + "xpack.canvas.functions.alterColumn.args.nameHelpText": "结果列名称。留空将不重命名。", + "xpack.canvas.functions.alterColumn.args.typeHelpText": "将列转换成的类型。留空将不更改类型。", + "xpack.canvas.functions.alterColumn.cannotConvertTypeErrorMessage": "无法连接到“{type}”", + "xpack.canvas.functions.alterColumn.columnNotFoundErrorMessage": "找不到列:“{column}”", + "xpack.canvas.functions.alterColumnHelpText": "在核心类型(包括 {list})和 {end} 之间转换并重命名列。另见 {mapColumnFn} 和 {staticColumnFn}。", + "xpack.canvas.functions.any.args.conditionHelpText": "要检查的条件。", + "xpack.canvas.functions.anyHelpText": "至少满足一个条件时,则返回 {BOOLEAN_TRUE}。另见 {all_fn}。", + "xpack.canvas.functions.as.args.nameHelpText": "要给予列的名称。", + "xpack.canvas.functions.asHelpText": "使用单个值创建 {DATATABLE}。另见 {getCellFn}。", + "xpack.canvas.functions.asset.args.id": "要检索的资产的 ID。", + "xpack.canvas.functions.asset.invalidAssetId": "无法通过以下 ID 获取资产:“{assetId}”", + "xpack.canvas.functions.assetHelpText": "检索要作为参数值来提供的 Canvas Workpad 资产对象。通常为图像。", + "xpack.canvas.functions.axisConfig.args.maxHelpText": "轴上显示的最大值。必须为数字或自 Epoch 起毫秒数表示的日期或 {ISO8601} 字符串。", + "xpack.canvas.functions.axisConfig.args.minHelpText": "轴上显示的最小值。必须为数字或自 Epoch 起毫秒数表示的日期或 {ISO8601} 字符串。", + "xpack.canvas.functions.axisConfig.args.positionHelpText": "轴标签的位置。例如 {list} 或 {end}。", + "xpack.canvas.functions.axisConfig.args.showHelpText": "显示轴标签?", + "xpack.canvas.functions.axisConfig.args.tickSizeHelpText": "刻度间的增量大小。仅用于`数值`轴", + "xpack.canvas.functions.axisConfig.invalidMaxPositionErrorMessage": "日期字符串无效:“{max}”。“max”必须是数值、以毫秒为单位的日期或 ISO8601 日期字符串", + "xpack.canvas.functions.axisConfig.invalidMinDateStringErrorMessage": "日期字符串无效:“{min}”。“min”必须是数值、以毫秒为单位的日期或 ISO8601 日期字符串", + "xpack.canvas.functions.axisConfig.invalidPositionErrorMessage": "无效的位置:“{position}”", + "xpack.canvas.functions.axisConfigHelpText": "配置可视化的轴。仅用于 {plotFn}。", + "xpack.canvas.functions.case.args.ifHelpText": "此值表示条件是否满足,通常使用子表达式。{IF_ARG} 和 {WHEN_ARG} 参数都提供时,前者将覆盖后者。", + "xpack.canvas.functions.case.args.thenHelpText": "条件得到满足时要返回的值。", + "xpack.canvas.functions.case.args.whenHelpText": "与 {CONTEXT} 比较的值,通过比较来确定它们是否相等。同时指定 {WHEN_ARG} 和 {IF_ARG} 时,将忽略前者。", + "xpack.canvas.functions.caseHelpText": "构建要传递给 {switchFn} 函数的 {case},包括条件/结果。", + "xpack.canvas.functions.clearHelpText": "清除 {CONTEXT},然后返回 {TYPE_NULL}。", + "xpack.canvas.functions.columns.args.excludeHelpText": "要从 {DATATABLE} 中移除的列名称逗号分隔列表。", + "xpack.canvas.functions.columns.args.includeHelpText": "要在 {DATATABLE} 中保留的列名称逗号分隔列表。", + "xpack.canvas.functions.columnsHelpText": "在/从 {DATATABLE} 中包括或排除列。两个参数都指定时,将首先移除排除的列。", + "xpack.canvas.functions.compare.args.opHelpText": "要用于比较的运算符:{eq}(等于)、{gt}(大于)、{gte}(大于或等于)、{lt}(小于)、{lte}(小于或等于)、{ne} 或 {neq}(不等于)。", + "xpack.canvas.functions.compare.args.toHelpText": "与 {CONTEXT} 比较的值。", + "xpack.canvas.functions.compare.invalidCompareOperatorErrorMessage": "无效的比较运算符:“{op}”。使用 {ops}", + "xpack.canvas.functions.compareHelpText": "将 {CONTEXT} 与指定值比较,以确定 {BOOLEAN_TRUE} 或 {BOOLEAN_FALSE}。通常与 `{ifFn}` 或 `{caseFn}` 一起使用。这仅适用于基元类型,如 {examples}。另见 `{eqFn}`、`{gtFn}`、`{gteFn}`、`{ltFn}`、`{lteFn}`、`{neqFn}`", + "xpack.canvas.functions.containerStyle.args.backgroundColorHelpText": "有效的 {CSS} 背景色。", + "xpack.canvas.functions.containerStyle.args.backgroundImageHelpText": "有效的 {CSS} 背景图。", + "xpack.canvas.functions.containerStyle.args.backgroundRepeatHelpText": "有效的 {CSS} 背景重复。", + "xpack.canvas.functions.containerStyle.args.backgroundSizeHelpText": "有效的 {CSS} 背景大小。", + "xpack.canvas.functions.containerStyle.args.borderHelpText": "有效的 {CSS} 边框。", + "xpack.canvas.functions.containerStyle.args.borderRadiusHelpText": "设置圆角时要使用的像素数。", + "xpack.canvas.functions.containerStyle.args.opacityHelpText": "0 和 1 之间的数值,表示元素的透明度。", + "xpack.canvas.functions.containerStyle.args.overflowHelpText": "有效的 {CSS} 溢出。", + "xpack.canvas.functions.containerStyle.args.paddingHelpText": "内容与边框的距离(像素)。", + "xpack.canvas.functions.containerStyle.invalidBackgroundImageErrorMessage": "无效的背景图。请提供资产或 URL。", + "xpack.canvas.functions.containerStyleHelpText": "创建用于为元素容器提供样式的对象,包括背景、边框和透明度。", + "xpack.canvas.functions.contextHelpText": "返回传入该函数的任何内容。需要将 {CONTEXT} 用作充当子表达式的参数时,这会非常有用。", + "xpack.canvas.functions.csv.args.dataHelpText": "要使用的 {CSV} 数据。", + "xpack.canvas.functions.csv.args.delimeterHelpText": "数据分隔字符。", + "xpack.canvas.functions.csv.args.newlineHelpText": "行分隔字符。", + "xpack.canvas.functions.csv.invalidInputCSVErrorMessage": "解析输入 CSV 时出错。", + "xpack.canvas.functions.csvHelpText": "从 {CSV} 输入创建 {DATATABLE}。", + "xpack.canvas.functions.date.args.formatHelpText": "用于解析指定日期字符串的 {MOMENTJS}。请参见 {url}。", + "xpack.canvas.functions.date.args.valueHelpText": "解析成自 Epoch 起毫秒数的可选日期字符串。日期字符串可以是有效的 {JS} {date} 输入,也可以是要使用 {formatArg} 参数解析的字符串。必须为 {ISO8601} 字符串,或必须提供该格式。", + "xpack.canvas.functions.date.invalidDateInputErrorMessage": "无效的日期输入:{date}", + "xpack.canvas.functions.dateHelpText": "将当前时间或从指定字符串解析的时间返回为自 Epoch 起毫秒数。", + "xpack.canvas.functions.demodata.args.typeHelpText": "要使用的演示数据集的名称。", + "xpack.canvas.functions.demodata.invalidDataSetErrorMessage": "无效的数据集:“{arg}”,请使用“{ci}”或“{shirts}”。", + "xpack.canvas.functions.demodataHelpText": "包含项目 {ci} 时间以及用户名、国家/地区以及运行阶段的模拟数据集。", + "xpack.canvas.functions.do.args.fnHelpText": "要执行的子表达式。这些子表达式的返回值在根管道中不可用,因为此函数仅返回原始 {CONTEXT}。", + "xpack.canvas.functions.doHelpText": "执行多个子表达式,然后返回原始 {CONTEXT}。用于运行产生操作或副作用时不会更改原始 {CONTEXT} 的函数。", + "xpack.canvas.functions.dropdownControl.args.filterColumnHelpText": "要筛选的列或字段。", + "xpack.canvas.functions.dropdownControl.args.filterGroupHelpText": "筛选的组名称。", + "xpack.canvas.functions.dropdownControl.args.valueColumnHelpText": "从其中提取下拉列表唯一值的列或字段。", + "xpack.canvas.functions.dropdownControlHelpText": "配置下拉列表筛选控制元素。", + "xpack.canvas.functions.eq.args.valueHelpText": "与 {CONTEXT} 比较的值。", + "xpack.canvas.functions.eqHelpText": "返回 {CONTEXT} 是否等于参数。", + "xpack.canvas.functions.escount.args.indexHelpText": "索引或索引模式。例如:{example}。", + "xpack.canvas.functions.escount.args.queryHelpText": "{LUCENE} 查询字符串。", + "xpack.canvas.functions.escountHelpText": "在 {ELASTICSEARCH} 中查询匹配指定查询的命中数。", + "xpack.canvas.functions.esdocs.args.countHelpText": "要检索的文档数目。要获取更佳的性能,请使用较小的数据集。", + "xpack.canvas.functions.esdocs.args.fieldsHelpText": "字段逗号分隔列表。要获取更佳的性能,请使用较少的字段。", + "xpack.canvas.functions.esdocs.args.indexHelpText": "索引或索引模式。例如:{example}。", + "xpack.canvas.functions.esdocs.args.metaFieldsHelpText": "元字段逗号分隔列表。例如:{example}。", + "xpack.canvas.functions.esdocs.args.queryHelpText": "{LUCENE} 查询字符串。", + "xpack.canvas.functions.esdocs.args.sortHelpText": "格式为 {directions} 的排序方向。例如 {example1} 或 {example2}。", + "xpack.canvas.functions.esdocsHelpText": "在 {ELASTICSEARCH} 中查询原始文档。指定要检索的字段,特别是需要大量的行。", + "xpack.canvas.functions.essql.args.countHelpText": "要检索的文档数目。要获取更佳的性能,请使用较小的数据集。", + "xpack.canvas.functions.essql.args.queryHelpText": "{ELASTICSEARCH} {SQL} 查询。", + "xpack.canvas.functions.essql.args.timezoneHelpText": "要用于日期操作的时区。有效的 {ISO8601} 格式和 {UTC} 偏倚均适用。", + "xpack.canvas.functions.essqlHelpText": "使用 {ELASTICSEARCH} {SQL} 查询 {ELASTICSEARCH}。", + "xpack.canvas.functions.exactly.args.columnHelpText": "要筛选的列或字段。", + "xpack.canvas.functions.exactly.args.filterGroupHelpText": "筛选的组名称。", + "xpack.canvas.functions.exactly.args.valueHelpText": "要完全匹配的值,包括空格和大写。", + "xpack.canvas.functions.exactlyHelpText": "创建使给定列匹配确切值的筛选。", + "xpack.canvas.functions.filterrows.args.fnHelpText": "传递到 {DATATABLE} 中每一行的表达式。表达式应返回 {TYPE_BOOLEAN}。{BOOLEAN_TRUE} 值保留行,{BOOLEAN_FALSE} 值删除行。", + "xpack.canvas.functions.filterrowsHelpText": "根据子表达式的返回值筛选 {DATATABLE} 中的行。", + "xpack.canvas.functions.filters.args.group": "要使用的筛选组的名称。", + "xpack.canvas.functions.filters.args.ungrouped": "排除属于筛选组的筛选?", + "xpack.canvas.functions.filtersHelpText": "聚合 Workpad 的元素筛选以用于他处,通常用于数据源。", + "xpack.canvas.functions.formatdate.args.formatHelpText": "{MOMENTJS} 格式。例如:{example}。请参见 {url}。", + "xpack.canvas.functions.formatdateHelpText": "使用 {MOMENTJS} 格式化 {ISO8601} 日期字符串或自 Epoch 起以毫秒表示的日期。请参见 {url}。", + "xpack.canvas.functions.formatnumber.args.formatHelpText": "{NUMERALJS} 格式字符串。例如 {example1} 或 {example2}。请参见 {url}。", + "xpack.canvas.functions.formatnumberHelpText": "使用 {NUMERALJS} 将数字格式化为带格式数字字符串。请参见 {url}。", + "xpack.canvas.functions.getCell.args.columnHelpText": "从其中提取值的列的名称。如果未提供,将从第一列检索值。", + "xpack.canvas.functions.getCell.args.rowHelpText": "行编号,从 0 开始。", + "xpack.canvas.functions.getCell.columnNotFoundErrorMessage": "找不到列:“{column}”", + "xpack.canvas.functions.getCell.rowNotFoundErrorMessage": "找不到行:“{row}”", + "xpack.canvas.functions.getCellHelpText": "从 {DATATABLE} 提取单个单元格。", + "xpack.canvas.functions.gt.args.valueHelpText": "与 {CONTEXT} 比较的值。", + "xpack.canvas.functions.gte.args.valueHelpText": "与 {CONTEXT} 比较的值。", + "xpack.canvas.functions.gteHelpText": "返回 {CONTEXT} 是否大于或等于参数。", + "xpack.canvas.functions.gtHelpText": "返回 {CONTEXT} 是否大于参数。", + "xpack.canvas.functions.head.args.countHelpText": "要从 {DATATABLE} 的起始位置检索的行数目。", + "xpack.canvas.functions.headHelpText": "从 {DATATABLE} 检索前 {n} 行。另见 {tailFn}", + "xpack.canvas.functions.if.args.conditionHelpText": "表示条件是否满足的 {BOOLEAN_TRUE} 或 {BOOLEAN_FALSE},通常由子表达式返回。未指定时,将返回原始 {CONTEXT}。", + "xpack.canvas.functions.if.args.elseHelpText": "条件为 {BOOLEAN_FALSE} 时的返回值。未指定且条件未满足时,将返回原始 {CONTEXT}。", + "xpack.canvas.functions.if.args.thenHelpText": "条件为 {BOOLEAN_TRUE} 时的返回值。未指定且条件满足时,将返回原始 {CONTEXT}。", + "xpack.canvas.functions.ifHelpText": "执行条件逻辑", + "xpack.canvas.functions.image.args.dataurlHelpText": "图像的 {https} {URL} 或 {BASE64} 数据 {URL}。", + "xpack.canvas.functions.image.args.modeHelpText": "{contain} 将显示整个图像,图像缩放至适合大小。{cover} 将使用该图像填充容器,根据需要在两边或底部裁剪图像。{stretch} 将图像的高和宽调整为容器的 100%。", + "xpack.canvas.functions.image.invalidImageModeErrorMessage": "“mode”必须为“{contain}”、“{cover}”或“{stretch}”", + "xpack.canvas.functions.imageHelpText": "显示图像。将图像资产作为 {BASE64} 数据 {URL} 提供或传入子表达式。", + "xpack.canvas.functions.joinRows.args.columnHelpText": "要用于联接值的列", + "xpack.canvas.functions.joinRows.args.distinctHelpText": "移除重复值?", + "xpack.canvas.functions.joinRows.args.quoteHelpText": "引起值的引号字符", + "xpack.canvas.functions.joinRows.args.separatorHelpText": "用于分隔行值的分隔符", + "xpack.canvas.functions.joinRows.columnNotFoundErrorMessage": "找不到列:“{column}”", + "xpack.canvas.functions.joinRowsHelpText": "将数据库中的行的值联接成字符串", + "xpack.canvas.functions.locationHelpText": "使用浏览器的 {geolocationAPI} 查找您的当前位置。性能可能会因浏览器而异,但相当准确。请参见 {url}。", + "xpack.canvas.functions.lt.args.valueHelpText": "与 {CONTEXT} 比较的值。", + "xpack.canvas.functions.lte.args.valueHelpText": "与 {CONTEXT} 比较的值。", + "xpack.canvas.functions.lteHelpText": "返回 {CONTEXT} 是否小于或等于参数。", + "xpack.canvas.functions.ltHelpText": "返回 {CONTEXT} 是否小于参数。", + "xpack.canvas.functions.mapColumn.args.expressionHelpText": "作为单行 {DATATABLE} 传递到每一行的 {CANVAS} 表达式。", + "xpack.canvas.functions.mapColumn.args.nameHelpText": "结果列的名称。", + "xpack.canvas.functions.mapColumnHelpText": "添加计算为其他列的结果的列。只有提供参数时,才会进行更改。另请参见 {mapColumnFn} 和 {staticColumnFn}。", + "xpack.canvas.functions.markdown.args.contentHelpText": "包含 {MARKDOWN} 的文本字符串。要进行串联,请传递 {stringFn} 函数多次。", + "xpack.canvas.functions.markdown.args.fontHelpText": "内容的 {CSS} 字体属性。例如:{fontFamily} 或 {fontWeight}。", + "xpack.canvas.functions.markdownHelpText": "添加呈现 {MARKDOWN} 文本的元素。提示:将 {markdownFn} 函数用于单个数字、指标和文本段落。", + "xpack.canvas.functions.math.args.expressionHelpText": "已计算的 {TINYMATH} 表达式。请参阅 {TINYMATH_URL}。", + "xpack.canvas.functions.math.emptyDatatableErrorMessage": "空数据表", + "xpack.canvas.functions.math.emptyExpressionErrorMessage": "空表达式", + "xpack.canvas.functions.math.executionFailedErrorMessage": "无法执行数学表达式。检查您的列名称", + "xpack.canvas.functions.math.tooManyResultsErrorMessage": "表达式必须返回单个数字。尝试将您的表达式包装在 {mean} 或 {sum} 中", + "xpack.canvas.functions.mathHelpText": "通过将数字或 {DATATABLE} 用作 {CONTEXT} 来解析 {TINYMATH} 数学表达式。{DATATABLE} 列可通过列名来使用。如果 {CONTEXT} 是数字,其可用作 {value}。", + "xpack.canvas.functions.metric.args.labelFontHelpText": "标签的 {CSS} 字体属性。例如 {FONT_FAMILY} 或 {FONT_WEIGHT}。", + "xpack.canvas.functions.metric.args.labelHelpText": "描述指标的文本。", + "xpack.canvas.functions.metric.args.metricFontHelpText": "指标的 {CSS} 字体属性。例如 {FONT_FAMILY} 或 {FONT_WEIGHT}。", + "xpack.canvas.functions.metric.args.metricFormatHelpText": "{NUMERALJS} 格式字符串。例如 {example1} 或 {example2}。请参见 {url}。", + "xpack.canvas.functions.metricHelpText": "在标签上显示数字。", + "xpack.canvas.functions.neq.args.valueHelpText": "与 {CONTEXT} 比较的值。", + "xpack.canvas.functions.neqHelpText": "返回 {CONTEXT} 是否不等于参数。", + "xpack.canvas.functions.palette.args.colorHelpText": "调色板颜色。接受 {html} 颜色名称、{hex}、{hsl}、{hsla}、{rgb} 或 {rgba}。", + "xpack.canvas.functions.palette.args.gradientHelpText": "受支持时提供渐变的调色板?", + "xpack.canvas.functions.palette.args.reverseHelpText": "反转调色板?", + "xpack.canvas.functions.paletteHelpText": "创建颜色调色板。", + "xpack.canvas.functions.pie.args.fontHelpText": "标签的 {CSS} 字体属性。例如 {FONT_FAMILY} 或 {FONT_WEIGHT}。", + "xpack.canvas.functions.pie.args.holeHelpText": "在饼图中绘制介于 `0` and `100`(饼图半径的百分比)之间的孔洞。", + "xpack.canvas.functions.pie.args.labelRadiusHelpText": "要用作标签圆形半径的容器面积百分比。", + "xpack.canvas.functions.pie.args.labelsHelpText": "显示饼图标签?", + "xpack.canvas.functions.pie.args.legendHelpText": "图例位置。例如 {positions} 或 {BOOLEAN_FALSE}。为 {BOOLEAN_FALSE} 时,图例隐藏。", + "xpack.canvas.functions.pie.args.paletteHelpText": "用于描述要在饼图上使用的颜色的 {palette} 对象。请参见 {paletteFn}。", + "xpack.canvas.functions.pie.args.radiusHelpText": "饼图的半径,表示为可用空间的百分比(介于 `0` 和 `1` 之间)。要自动设置半径,请使用 {auto}。", + "xpack.canvas.functions.pie.args.seriesStyleHelpText": "特定序列的样式", + "xpack.canvas.functions.pie.args.tiltHelpText": "倾斜百分比,其中 `1` 为完全垂直,`0` 为完全水平。", + "xpack.canvas.functions.pieHelpText": "配置饼图元素。", + "xpack.canvas.functions.plot.args.defaultStyleHelpText": "要用于每个序列的默认样式。", + "xpack.canvas.functions.plot.args.fontHelpText": "标签的 {CSS} 字体属性。例如 {FONT_FAMILY} 或 {FONT_WEIGHT}。", + "xpack.canvas.functions.plot.args.legendHelpText": "图例位置。例如 {positions} 或 {BOOLEAN_FALSE}。为 {BOOLEAN_FALSE} 时,图例隐藏。", + "xpack.canvas.functions.plot.args.paletteHelpText": "用于描述要在此图表上使用的颜色的 {palette} 对象。请参见 {paletteFn}。", + "xpack.canvas.functions.plot.args.seriesStyleHelpText": "特定序列的样式", + "xpack.canvas.functions.plot.args.xaxisHelpText": "轴配置。为 {BOOLEAN_FALSE} 时,轴隐藏。", + "xpack.canvas.functions.plot.args.yaxisHelpText": "轴配置。为 {BOOLEAN_FALSE} 时,轴隐藏。", + "xpack.canvas.functions.plotHelpText": "配置图表元素", + "xpack.canvas.functions.ply.args.byHelpText": "用于细分 {DATATABLE} 的列。", + "xpack.canvas.functions.ply.args.expressionHelpText": "要将每个结果 {DATATABLE} 传入的表达式。提示:表达式必须返回 {DATATABLE}。使用 `{asFn}` 将文本转成 {DATATABLE}。多个表达式必须返回相同数量的行。如果需要返回不同的行数,请导向另一个 {plyFn} 实例。如果多个表达式返回同名的列,最后一列将胜出。", + "xpack.canvas.functions.ply.columnNotFoundErrorMessage": "找不到列:“{by}”", + "xpack.canvas.functions.ply.rowCountMismatchErrorMessage": "所有表达式必须返回相同数目的行", + "xpack.canvas.functions.plyHelpText": "通过指定列的唯一值细分 {DATATABLE},并将生成的表传入表达式,然后合并每个表达式的输出", + "xpack.canvas.functions.pointseries.args.colorHelpText": "要用于确定标记颜色的表达式。", + "xpack.canvas.functions.pointseries.args.sizeHelpText": "标记的大小。仅适用于支持的元素。", + "xpack.canvas.functions.pointseries.args.textHelpText": "要在标记上显示的文本。仅适用于支持的元素。", + "xpack.canvas.functions.pointseries.args.xHelpText": "X 轴上的值。", + "xpack.canvas.functions.pointseries.args.yHelpText": "Y 轴上的值。", + "xpack.canvas.functions.pointseries.unwrappedExpressionErrorMessage": "表达式必须包装在函数中,例如 {fn}", + "xpack.canvas.functions.pointseriesHelpText": "将 {DATATABLE} 转成点序列模型。当前我们通过寻找 {TINYMATH} 表达式来区分度量和维度。请参阅 {TINYMATH_URL}。如果在参数中输入 {TINYMATH} 表达式,我们将该参数视为度量,否则该参数为维度。维度将进行组合以创建唯一键。然后,这些键使用指定的 {TINYMATH} 函数消除重复的度量", + "xpack.canvas.functions.progress.args.barColorHelpText": "背景条形的颜色。", + "xpack.canvas.functions.progress.args.barWeightHelpText": "背景条形的粗细。", + "xpack.canvas.functions.progress.args.fontHelpText": "标签的 {CSS} 字体属性。例如 {FONT_FAMILY} 或 {FONT_WEIGHT}。", + "xpack.canvas.functions.progress.args.labelHelpText": "要显示或隐藏标签,请使用 {BOOLEAN_TRUE} 或 {BOOLEAN_FALSE}。或者,提供要显示为标签的字符串。", + "xpack.canvas.functions.progress.args.maxHelpText": "进度元素的最大值。", + "xpack.canvas.functions.progress.args.shapeHelpText": "选择 {list} 或 {end}。", + "xpack.canvas.functions.progress.args.valueColorHelpText": "进度条的颜色。", + "xpack.canvas.functions.progress.args.valueWeightHelpText": "进度条的粗细。", + "xpack.canvas.functions.progress.invalidMaxValueErrorMessage": "无效的 {arg} 值:“{max, number}”。“{arg}”必须大于 0", + "xpack.canvas.functions.progress.invalidValueErrorMessage": "无效的值:“{value, number}”。值必须介于 0 和 {max, number} 之间", + "xpack.canvas.functions.progressHelpText": "配置进度元素。", + "xpack.canvas.functions.render.args.asHelpText": "要呈现的元素类型。您可能需要专门的函数,例如 {plotFn} 或 {shapeFn}。", + "xpack.canvas.functions.render.args.containerStyleHelpText": "容器的样式,包括背景、边框和透明度。", + "xpack.canvas.functions.render.args.cssHelpText": "要限定于元素的任何定制 {CSS} 块。", + "xpack.canvas.functions.renderHelpText": "将 {CONTEXT} 呈现为特定元素并设置元素级别选项,例如背景和边框样式。", + "xpack.canvas.functions.repeatImage.args.emptyImageHelpText": "使用图像在 {CONTEXT} 和元素的 {maxArg} 参数之间填充差异。以 {BASE64} 数据 {URL} 方式提供图像资产,或传入子表达式。", + "xpack.canvas.functions.repeatImage.args.imageHelpText": "要重复的图像。将图像资产作为 {BASE64} 数据 {URL} 提供或传入子表达式。", + "xpack.canvas.functions.repeatImage.args.maxHelpText": "图像可以重复的最大次数。", + "xpack.canvas.functions.repeatImage.args.sizeHelpText": "图像的最大高度或宽度,以像素为单位。图像的高大于宽时,此函数将限制高度。", + "xpack.canvas.functions.repeatImageHelpText": "配置重复图像元素。", + "xpack.canvas.functions.replace.args.flagsHelpText": "指定标志。请参见 {url}。", + "xpack.canvas.functions.replace.args.patternHelpText": "{JS} 正则表达式的文本或模式。例如:{example}。您可以在此处使用捕获组。", + "xpack.canvas.functions.replace.args.replacementHelpText": "字符串匹配部分的替代。捕获组可以通过其索引进行访问。例如:{example}。", + "xpack.canvas.functions.replaceImageHelpText": "使用正则表达式替换字符串各部分。", + "xpack.canvas.functions.revealImage.args.emptyImageHelpText": "要显示的可选背景图像。将图像资产作为 {BASE64} 数据 {URL} 提供或传入子表达式。", + "xpack.canvas.functions.revealImage.args.imageHelpText": "要显示的图像。将图像资产作为 {BASE64} 数据 {URL} 提供或传入子表达式。", + "xpack.canvas.functions.revealImage.args.originHelpText": "要开始图像填充的位置。例如 {list} 或 {end}。", + "xpack.canvas.functions.revealImage.invalidPercentErrorMessage": "无效的值:“{percent}”。百分比必须介于 0 和 1 之间", + "xpack.canvas.functions.revealImageHelpText": "配置图像显示元素。", + "xpack.canvas.functions.rounddate.args.formatHelpText": "用于存储桶存储的 {MOMENTJS} 格式。例如,{example} 将每个日期舍入到月份。请参见 {url}。", + "xpack.canvas.functions.rounddateHelpText": "使用 {MOMENTJS} 格式字符串舍入自 Epoch 起毫秒数,并返回自 Epoch 起毫秒数。", + "xpack.canvas.functions.rowCountHelpText": "返回行数。与 {plyFn} 搭配,可获取唯一行值的计数或唯一行值的组合。", + "xpack.canvas.functions.savedMapHelpText": "为已保存地图对象返回可嵌入对象", + "xpack.canvas.functions.savedSearchHelpText": "为已保存搜索对象返回可嵌入对象", + "xpack.canvas.functions.savedVisualizationHelpText": "为已保存可视化对象返回可嵌入对象", + "xpack.canvas.functions.seriesStyle.args.barsHelpText": "条形的宽度。", + "xpack.canvas.functions.seriesStyle.args.colorHelpText": "线条颜色。", + "xpack.canvas.functions.seriesStyle.args.fillHelpText": "应该填入点吗?", + "xpack.canvas.functions.seriesStyle.args.horizontalBarsHelpText": "将图表中的条形方向设置为横向。", + "xpack.canvas.functions.seriesStyle.args.labelHelpText": "要加上样式的序列的名称。", + "xpack.canvas.functions.seriesStyle.args.linesHelpText": "线条的宽度。", + "xpack.canvas.functions.seriesStyle.args.pointsHelpText": "折线上的点大小", + "xpack.canvas.functions.seriesStyle.args.stackHelpText": "指定是否应堆叠序列。编号为堆叠 ID。具有相同堆叠 ID 的序列将堆叠在一起。", + "xpack.canvas.functions.seriesStyleHelpText": "创建用于在图表上描述序列属性的对象。在图表绘制函数(如 {plotFn} 或 {pieFn})中使用 {seriesStyleFn}。", + "xpack.canvas.functions.shape.args.borderHelpText": "形状轮廓边框的 {SVG} 颜色。", + "xpack.canvas.functions.shape.args.borderWidthHelpText": "边框的粗细。", + "xpack.canvas.functions.shape.args.fillHelpText": "填充形状的 {SVG} 颜色。", + "xpack.canvas.functions.shape.args.maintainAspectHelpText": "维持形状的原始纵横比?", + "xpack.canvas.functions.shape.args.shapeHelpText": "选取形状。", + "xpack.canvas.functions.shapeHelpText": "创建形状。", + "xpack.canvas.functions.sort.args.byHelpText": "排序要依据的列。未指定时,将按第一列排序 `{DATATABLE}`。", + "xpack.canvas.functions.sort.args.reverseHelpText": "反转排序顺序。未指定时,将升序排序 `{DATATABLE}`。", + "xpack.canvas.functions.sortHelpText": "按指定列排序数据库。", + "xpack.canvas.functions.staticColumn.args.nameHelpText": "新列的名称。", + "xpack.canvas.functions.staticColumn.args.valueHelpText": "在每一行新列中要插入的值。提示:使用子表达式将其他列汇总为静态值。", + "xpack.canvas.functions.staticColumnHelpText": "在每一行添加具有相同静态值的列。另见 {alterColumnFn} 和 {mapColumnFn}。", + "xpack.canvas.functions.string.args.valueHelpText": "要连结成一个字符串的值。根据需要加入空格。", + "xpack.canvas.functions.stringHelpText": "将所有参数串联成单个字符串。", + "xpack.canvas.functions.switch.args.caseHelpText": "要检查的条件", + "xpack.canvas.functions.switch.args.defaultHelpText": "未满足任何条件时返回的值。未指定且没有条件满足时,将返回原始 {CONTEXT}。", + "xpack.canvas.functions.switchHelpText": "执行具有多个条件的条件逻辑。另见 {caseFn},其用于构建要传递到 {switchFn} 函数的 {case}。", + "xpack.canvas.functions.table.args.fontHelpText": "表内容的 {CSS} 字体属性。例如 {FONT_FAMILY} 或 {FONT_WEIGHT}。", + "xpack.canvas.functions.table.args.paginateHelpText": "显示分页控件?为 {BOOLEAN_FALSE} 时,仅显示第一页。", + "xpack.canvas.functions.table.args.perPageHelpText": "要在每页上显示的行数目。", + "xpack.canvas.functions.table.args.showHeaderHelpText": "显示/隐藏具有每列标题的标题行。", + "xpack.canvas.functions.tableHelpText": "配置表元素", + "xpack.canvas.functions.tail.args.countHelpText": "要从 {DATATABLE} 的结尾位置检索的行数目。", + "xpack.canvas.functions.tailHelpText": "从 {DATATABLE} 结尾检索后 N 行。另见 {headFn}。", + "xpack.canvas.functions.timefilter.args.columnHelpText": "要筛选的列或字段。", + "xpack.canvas.functions.timefilter.args.filterGroupHelpText": "筛选的组名称。", + "xpack.canvas.functions.timefilter.args.fromHelpText": "以 {ISO8601} 或 {ELASTICSEARCH} {DATEMATH} 格式表示的范围起始", + "xpack.canvas.functions.timefilter.args.toHelpText": "以 {ISO8601} 或 {ELASTICSEARCH} {DATEMATH} 格式表示的范围结束", + "xpack.canvas.functions.timefilter.invalidStringErrorMessage": "无效的日期/时间字符串:“{str}”", + "xpack.canvas.functions.timefilterControl.args.columnHelpText": "要筛选的列或字段。", + "xpack.canvas.functions.timefilterControl.args.compactHelpText": "将时间筛选显示为触发弹出框的按钮。", + "xpack.canvas.functions.timefilterControlHelpText": "配置时间筛选控制元素。", + "xpack.canvas.functions.timefilterHelpText": "创建用于查询源的时间筛选。", + "xpack.canvas.functions.timelion.args.from": "表示时间范围起始的 {ELASTICSEARCH} {DATEMATH} 字符串。", + "xpack.canvas.functions.timelion.args.interval": "时间序列的存储桶间隔。", + "xpack.canvas.functions.timelion.args.query": "Timelion 查询", + "xpack.canvas.functions.timelion.args.timezone": "时间范围的时区。请参阅 {MOMENTJS_TIMEZONE_URL}。", + "xpack.canvas.functions.timelion.args.to": "表示时间范围结束的 {ELASTICSEARCH} {DATEMATH} 字符串。", + "xpack.canvas.functions.timelionHelpText": "使用 Timelion 从多个源中提取一个或多个时间序列。", + "xpack.canvas.functions.to.args.type": "表达式语言中的已知数据类型。", + "xpack.canvas.functions.to.missingType": "必须指定转换类型", + "xpack.canvas.functions.toHelpText": "将 {CONTEXT} 的类型显式转换为指定类型。", + "xpack.canvas.functions.urlparam.args.defaultHelpText": "未指定 {URL} 参数时返回的值。", + "xpack.canvas.functions.urlparam.args.paramHelpText": "要检索的 {URL} 哈希参数。", + "xpack.canvas.functions.urlparamHelpText": "检索要在表达式中使用的 {URL} 参数。{urlparamFn} 函数始终返回 {TYPE_STRING}。例如,从 {URL} 的参数 {myVar} 检索值 {value} ({example})。", + "xpack.canvas.groupSettings.multipleElementsActionsDescription": "取消选择这些元素以编辑各自的设置,按 ({gKey}) 以对它们进行分组,或将此选择另存为新元素,以在整个 Workpad 中重复使用。", + "xpack.canvas.groupSettings.multipleElementsDescription": "当前选择了多个元素。", + "xpack.canvas.groupSettings.saveGroupDescription": "将此组另存为新元素,以在整个 Workpad 重复使用。", + "xpack.canvas.groupSettings.ungroupDescription": "取消分组 ({uKey}) 以编辑各个元素设置。", + "xpack.canvas.helpMenu.description": "有关 {CANVAS} 特定信息", + "xpack.canvas.helpMenu.documentationLinkLabel": "{CANVAS} 文档", + "xpack.canvas.helpMenu.keyboardShortcutsLinkLabel": "快捷键", + "xpack.canvas.keyboardShortcuts.bringFowardShortcutHelpText": "置前", + "xpack.canvas.keyboardShortcuts.bringToFrontShortcutHelpText": "前移", + "xpack.canvas.keyboardShortcuts.cloneShortcutHelpText": "克隆", + "xpack.canvas.keyboardShortcuts.copyShortcutHelpText": "复制", + "xpack.canvas.keyboardShortcuts.cutShortcutHelpText": "剪切", + "xpack.canvas.keyboardShortcuts.deleteShortcutHelpText": "删除", + "xpack.canvas.keyboardShortcuts.editingShortcutHelpText": "切换编辑模式", + "xpack.canvas.keyboardShortcuts.fullscreenExitShortcutHelpText": "退出演示模式", + "xpack.canvas.keyboardShortcuts.fullscreenShortcutHelpText": "进入演示模式", + "xpack.canvas.keyboardShortcuts.gridShortcutHelpText": "显示网格", + "xpack.canvas.keyboardShortcuts.groupShortcutHelpText": "组", + "xpack.canvas.keyboardShortcuts.ignoreSnapShortcutHelpText": "移动、调整大小及旋转时不对齐", + "xpack.canvas.keyboardShortcuts.multiselectShortcutHelpText": "选择多个元素", + "xpack.canvas.keyboardShortcuts.namespace.editorDisplayName": "编辑器控件", + "xpack.canvas.keyboardShortcuts.namespace.elementDisplayName": "元素控件", + "xpack.canvas.keyboardShortcuts.namespace.expressionDisplayName": "表达式控件", + "xpack.canvas.keyboardShortcuts.namespace.presentationDisplayName": "演示控件", + "xpack.canvas.keyboardShortcuts.nextShortcutHelpText": "前往下一页", + "xpack.canvas.keyboardShortcuts.nudgeDownShortcutHelpText": "下移 {ELEMENT_NUDGE_OFFSET}px", + "xpack.canvas.keyboardShortcuts.nudgeLeftShortcutHelpText": "左移 {ELEMENT_NUDGE_OFFSET}px", + "xpack.canvas.keyboardShortcuts.nudgeRightShortcutHelpText": "右移 {ELEMENT_NUDGE_OFFSET}px", + "xpack.canvas.keyboardShortcuts.nudgeUpShortcutHelpText": "上移 {ELEMENT_NUDGE_OFFSET}px", + "xpack.canvas.keyboardShortcuts.pageCycleToggleShortcutHelpText": "切换页面循环播放", + "xpack.canvas.keyboardShortcuts.pasteShortcutHelpText": "粘贴", + "xpack.canvas.keyboardShortcuts.prevShortcutHelpText": "前往上一页", + "xpack.canvas.keyboardShortcuts.redoShortcutHelpText": "恢复上一操作", + "xpack.canvas.keyboardShortcuts.resizeFromCenterShortcutHelpText": "从中心调整大小", + "xpack.canvas.keyboardShortcuts.runShortcutHelpText": "运行整个表达式", + "xpack.canvas.keyboardShortcuts.selectBehindShortcutHelpText": "在下面选择元素", + "xpack.canvas.keyboardShortcuts.sendBackwardShortcutHelpText": "后移", + "xpack.canvas.keyboardShortcuts.sendToBackShortcutHelpText": "置后", + "xpack.canvas.keyboardShortcuts.shiftDownShortcutHelpText": "下移 {ELEMENT_SHIFT_OFFSET}px", + "xpack.canvas.keyboardShortcuts.shiftLeftShortcutHelpText": "左移 {ELEMENT_SHIFT_OFFSET}px", + "xpack.canvas.keyboardShortcuts.shiftRightShortcutHelpText": "右移 {ELEMENT_SHIFT_OFFSET}px", + "xpack.canvas.keyboardShortcuts.shiftUpShortcutHelpText": "上移 {ELEMENT_SHIFT_OFFSET}px", + "xpack.canvas.keyboardShortcuts.ShortcutHelpText": "刷新 Workpad", + "xpack.canvas.keyboardShortcuts.undoShortcutHelpText": "撤消上一操作", + "xpack.canvas.keyboardShortcuts.ungroupShortcutHelpText": "取消分组", + "xpack.canvas.keyboardShortcuts.zoomInShortcutHelpText": "放大", + "xpack.canvas.keyboardShortcuts.zoomOutShortcutHelpText": "缩小", + "xpack.canvas.keyboardShortcuts.zoomResetShortcutHelpText": "将缩放比例重置为 100%", + "xpack.canvas.keyboardShortcutsDoc.flyout.closeButtonAriaLabel": "关闭快捷键参考", + "xpack.canvas.keyboardShortcutsDoc.flyoutHeaderTitle": "快捷键", + "xpack.canvas.keyboardShortcutsDoc.shortcutListSeparator": "或", + "xpack.canvas.link.errorMessage": "链接错误:{message}", + "xpack.canvas.pageConfig.backgroundColorDescription": "接受 HEX、RGB 或 HTML 颜色名称", + "xpack.canvas.pageConfig.backgroundColorLabel": "背景色", + "xpack.canvas.pageConfig.title": "页", + "xpack.canvas.pageConfig.transitionLabel": "切换", + "xpack.canvas.pageConfig.transitionPreviewLabel": "预览", + "xpack.canvas.pageConfig.transitions.noneDropDownOptionLabel": "无", + "xpack.canvas.pageManager.pageNumberAriaLabel": "加载页码 {pageNumber}", + "xpack.canvas.pagePreviewPageControls.clonePageAriaLabel": "克隆页面", + "xpack.canvas.pagePreviewPageControls.clonePageTooltip": "克隆", + "xpack.canvas.pagePreviewPageControls.deletePageAriaLabel": "删除页面", + "xpack.canvas.pagePreviewPageControls.deletePageTooltip": "删除", + "xpack.canvas.renderer.advancedFilter.applyButtonLabel": "应用", + "xpack.canvas.renderer.advancedFilter.displayName": "高级筛选", + "xpack.canvas.renderer.advancedFilter.helpDescription": "呈现 Canvas 筛选表达式", + "xpack.canvas.renderer.advancedFilter.inputPlaceholder": "输入筛选表达式", + "xpack.canvas.renderer.debug.displayName": "故障排查", + "xpack.canvas.renderer.debug.helpDescription": "将故障排查输出呈现为带格式的 {JSON}", + "xpack.canvas.renderer.dropdownFilter.displayName": "下拉列表筛选", + "xpack.canvas.renderer.dropdownFilter.helpDescription": "可以从其中为“{exactly}”筛选选择值的下拉列表", + "xpack.canvas.renderer.dropdownFilter.matchAllOptionLabel": "任意", + "xpack.canvas.renderer.embeddable.displayName": "可嵌入", + "xpack.canvas.renderer.embeddable.helpDescription": "从 Kibana 的其他部分呈现可嵌入的已保存对象", + "xpack.canvas.renderer.error.displayName": "错误信息", + "xpack.canvas.renderer.error.helpDescription": "以用户友好的方式呈现错误数据", + "xpack.canvas.renderer.image.displayName": "图像", + "xpack.canvas.renderer.image.helpDescription": "呈现图像", + "xpack.canvas.renderer.markdown.displayName": "Markdown", + "xpack.canvas.renderer.markdown.helpDescription": "使用 {MARKDOWN} 输入呈现 {HTML}", + "xpack.canvas.renderer.metric.displayName": "指标", + "xpack.canvas.renderer.metric.helpDescription": "在标签上呈现数字", + "xpack.canvas.renderer.pie.displayName": "饼图", + "xpack.canvas.renderer.pie.helpDescription": "根据您的数据呈现饼图", + "xpack.canvas.renderer.plot.displayName": "坐标图", + "xpack.canvas.renderer.plot.helpDescription": "根据您的数据呈现 XY 坐标图", + "xpack.canvas.renderer.progress.displayName": "进度指示", + "xpack.canvas.renderer.progress.helpDescription": "呈现显示元素百分比的进度指示", + "xpack.canvas.renderer.repeatImage.displayName": "图像重复", + "xpack.canvas.renderer.repeatImage.helpDescription": "重复图像给定次数", + "xpack.canvas.renderer.revealImage.displayName": "图像显示", + "xpack.canvas.renderer.revealImage.helpDescription": "显示一定百分比的图像,以制作定制的仪表样式图表", + "xpack.canvas.renderer.shape.displayName": "形状", + "xpack.canvas.renderer.shape.helpDescription": "呈现基本形状", + "xpack.canvas.renderer.table.displayName": "数据表", + "xpack.canvas.renderer.table.helpDescription": "将表格数据呈现为 {HTML}", + "xpack.canvas.renderer.text.displayName": "纯文本", + "xpack.canvas.renderer.text.helpDescription": "将输出呈现为纯文本", + "xpack.canvas.renderer.timeFilter.displayName": "时间筛选", + "xpack.canvas.renderer.timeFilter.helpDescription": "设置时间窗口以筛选数据", + "xpack.canvas.shareWebsiteFlyout.description": "按照以下步骤在外部网站上共享此 Workpad 的静态版本。其将是当前 Workpad 的可视化快照,对实时数据没有访问权限。", + "xpack.canvas.shareWebsiteFlyout.flyoutCalloutDescription": "要尝试共享,可以{link},其包含此 Workpad、{CANVAS} Shareable Workpad Runtime 及示例 {HTML} 文件。", + "xpack.canvas.shareWebsiteFlyout.flyoutTitle": "在网站上共享", + "xpack.canvas.shareWebsiteFlyout.runtimeStep.description": "要呈现可共享 Workpad,还需要加入 {CANVAS} Shareable Workpad Runtime。如果您的网站已包含该运行时,则可以跳过此步骤。", + "xpack.canvas.shareWebsiteFlyout.runtimeStep.downloadLabel": "下载运行时", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.addSnippetsTitle": "将代码段添加到网站", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.autoplayParameterDescription": "该运行时是否应自动播放 Workpad 的所有页面?", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.callRuntimeLabel": "调用运行时", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.description": "通过使用 {HTML} 占位符,Workpad 将置于站点的 {HTML} 内。将内联包含运行时的参数。请在下面参阅参数的完整列表。可以在页面上包含多个 Workpad。", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.downloadRuntimeTitle": "下载运行时", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.downloadWorkpadTitle": "下载 Workpad", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.heightParameterDescription": "Workpad 的高度。默认为 Workpad 高度。", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.includeRuntimeLabel": "包含运行时", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.intervalParameterDescription": "页面前进的间隔,时间格式(例如 {twoSeconds}、{oneMinute}", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.pageParameterDescription": "要显示的页面。默认为 Workpad 指定的页面。", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.parametersDescription": "有很多可用于配置可共享 Workpad 的内联参数。", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.parametersLabel": "参数", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.placeholderLabel": "占位符", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.requiredLabel": "必需", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.shareableParameterDescription": "可共享对象的类型。在这种情况下,为 {CANVAS} Workpad。", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.toolbarParameterDescription": "工具栏是否应隐藏?", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.urlParameterDescription": "可共享 Workpad {JSON} 文件的 {URL}", + "xpack.canvas.shareWebsiteFlyout.snippetsStep.widthParameterDescription": "Workdpad 的宽度。默认为 Workpad 宽度。", + "xpack.canvas.shareWebsiteFlyout.workpadStep.description": "Workpad 将导出为单个 {JSON} 文件,以在其他站点上共享。", + "xpack.canvas.shareWebsiteFlyout.workpadStep.downloadLabel": "下载 Workpad", + "xpack.canvas.shareWebsiteFlyout.zipDownloadLinkLabel": "下载示例 {ZIP} 文件", + "xpack.canvas.sidebarContent.groupedElementSidebarTitle": "已分组元素", + "xpack.canvas.sidebarContent.multiElementSidebarTitle": "多个元素", + "xpack.canvas.sidebarContent.singleElementSidebarTitle": "选定元素", + "xpack.canvas.sidebarHeader.alignmentMenuItemLabel": "对齐方式", + "xpack.canvas.sidebarHeader.bottomAlignMenuItemLabel": "下", + "xpack.canvas.sidebarHeader.bringForwardArialLabel": "将元素上移一层", + "xpack.canvas.sidebarHeader.bringToFrontArialLabel": "将元素移到顶层", + "xpack.canvas.sidebarHeader.centerAlignMenuItemLabel": "中", + "xpack.canvas.sidebarHeader.contextMenuAriaLabel": "元素选项", + "xpack.canvas.sidebarHeader.createElementModalTitle": "创建新元素", + "xpack.canvas.sidebarHeader.distributionMenutItemLabel": "分布", + "xpack.canvas.sidebarHeader.groupMenuItemLabel": "分组", + "xpack.canvas.sidebarHeader.horizontalDistributionMenutItemLabel": "水平", + "xpack.canvas.sidebarHeader.leftAlignMenuItemLabel": "左", + "xpack.canvas.sidebarHeader.middleAlignMenuItemLabel": "中", + "xpack.canvas.sidebarHeader.orderMenuItemLabel": "顺序", + "xpack.canvas.sidebarHeader.rightAlignMenuItemLabel": "右", + "xpack.canvas.sidebarHeader.savedElementMenuItemLabel": "另存为新元素", + "xpack.canvas.sidebarHeader.sendBackwardArialLabel": "将元素下移一层", + "xpack.canvas.sidebarHeader.sendToBackArialLabel": "将元素移到底层", + "xpack.canvas.sidebarHeader.topAlignMenuItemLabel": "上", + "xpack.canvas.sidebarHeader.ungroupMenuItemLabel": "取消分组", + "xpack.canvas.sidebarHeader.verticalDistributionMenutItemLabel": "垂直", + "xpack.canvas.tags.chartTag": "图表", + "xpack.canvas.tags.filterTag": "筛选", + "xpack.canvas.tags.graphicTag": "图形", + "xpack.canvas.tags.presentationTag": "演示", + "xpack.canvas.tags.proportionTag": "比例", + "xpack.canvas.tags.reportTag": "报告", + "xpack.canvas.tags.textTag": "文本", + "xpack.canvas.templates.darkHelp": "深色主题的演示幻灯片", + "xpack.canvas.templates.darkName": "深色", + "xpack.canvas.templates.lightHelp": "浅色主题的演示幻灯片", + "xpack.canvas.templates.lightName": "浅色", + "xpack.canvas.templates.pitchHelp": "具有大尺寸照片的冠名演示", + "xpack.canvas.templates.pitchName": "推销演示", + "xpack.canvas.templates.statusHelp": "具有动态图表的文档式报告", + "xpack.canvas.templates.statusName": "状态", + "xpack.canvas.templates.summaryDisplayName": "总结", + "xpack.canvas.templates.summaryHelp": "具有动态图表的信息图式报告", + "xpack.canvas.textStylePicker.alignCenterOption": "中间对齐", + "xpack.canvas.textStylePicker.alignLeftOption": "左对齐", + "xpack.canvas.textStylePicker.alignRightOption": "右对齐", + "xpack.canvas.textStylePicker.styleBoldOption": "粗体", + "xpack.canvas.textStylePicker.styleItalicOption": "斜体", + "xpack.canvas.textStylePicker.styleUnderlineOption": "下划线", + "xpack.canvas.timePicker.applyButtonLabel": "应用", + "xpack.canvas.toolbar.editorButtonLabel": "表达式编辑器", + "xpack.canvas.toolbar.nextPageAriaLabel": "下一页", + "xpack.canvas.toolbar.pageButtonLabel": "页 {pageNum}{rest}", + "xpack.canvas.toolbar.previousPageAriaLabel": "上一页", + "xpack.canvas.toolbar.workpadManagerCloseButtonLabel": "关闭", + "xpack.canvas.toolbarTray.closeTrayAriaLabel": "关闭托盘", + "xpack.canvas.transitions.fade.displayName": "淡化", + "xpack.canvas.transitions.fade.help": "从一页淡入到下一页", + "xpack.canvas.transitions.rotate.displayName": "旋转", + "xpack.canvas.transitions.rotate.help": "从一页旋转到下一页", + "xpack.canvas.transitions.slide.displayName": "滑动", + "xpack.canvas.transitions.slide.help": "从一页滑到下一页", + "xpack.canvas.transitions.zoom.displayName": "缩放", + "xpack.canvas.transitions.zoom.help": "从一页缩放到下一页", + "xpack.canvas.uis.arguments.axisConfig.position.options.bottomDropDown": "下", + "xpack.canvas.uis.arguments.axisConfig.position.options.leftDropDown": "左", + "xpack.canvas.uis.arguments.axisConfig.position.options.rightDropDown": "右", + "xpack.canvas.uis.arguments.axisConfig.position.options.topDropDown": "上", + "xpack.canvas.uis.arguments.axisConfig.positionLabel": "位置", + "xpack.canvas.uis.arguments.axisConfigLabel": "可视化轴配置", + "xpack.canvas.uis.arguments.axisConfigTitle": "轴配置", + "xpack.canvas.uis.arguments.dataColumn.options.averageDropDown": "平均值", + "xpack.canvas.uis.arguments.dataColumn.options.countDropDown": "计数", + "xpack.canvas.uis.arguments.dataColumn.options.firstDropDown": "第一", + "xpack.canvas.uis.arguments.dataColumn.options.lastDropDown": "最后", + "xpack.canvas.uis.arguments.dataColumn.options.maxDropDown": "最大值", + "xpack.canvas.uis.arguments.dataColumn.options.medianDropDown": "中值", + "xpack.canvas.uis.arguments.dataColumn.options.minDropDown": "最小值", + "xpack.canvas.uis.arguments.dataColumn.options.sumDropDown": "和", + "xpack.canvas.uis.arguments.dataColumn.options.uniqueDropDown": "唯一", + "xpack.canvas.uis.arguments.dataColumn.options.valueDropDown": "值", + "xpack.canvas.uis.arguments.dataColumnLabel": "选择数据列", + "xpack.canvas.uis.arguments.dataColumnTitle": "列", + "xpack.canvas.uis.arguments.dateFormatLabel": "选择或输入 {momentJS} 格式", + "xpack.canvas.uis.arguments.dateFormatTitle": "日期格式", + "xpack.canvas.uis.arguments.filterGroup.createNewGroupLinkText": "创建新组", + "xpack.canvas.uis.arguments.filterGroupLabel": "创建或选择筛选组", + "xpack.canvas.uis.arguments.filterGroupTitle": "筛选组", + "xpack.canvas.uis.arguments.imageUpload.fileUploadPromptLabel": "选择或拖放图像", + "xpack.canvas.uis.arguments.imageUpload.imageUploadingLabel": "图像上传", + "xpack.canvas.uis.arguments.imageUpload.urlFieldPlaceholder": "图像 {url}", + "xpack.canvas.uis.arguments.imageUpload.urlTypes.assetDropDown": "资产", + "xpack.canvas.uis.arguments.imageUpload.urlTypes.fileDropDown": "导入", + "xpack.canvas.uis.arguments.imageUpload.urlTypes.linkDropDown": "链接", + "xpack.canvas.uis.arguments.imageUploadLabel": "选择或上传图像", + "xpack.canvas.uis.arguments.imageUploadTitle": "图像上传", + "xpack.canvas.uis.arguments.numberFormat.format.bytesDropDown": "字节", + "xpack.canvas.uis.arguments.numberFormat.format.currencyDropDown": "货币", + "xpack.canvas.uis.arguments.numberFormat.format.durationDropDown": "持续时间", + "xpack.canvas.uis.arguments.numberFormat.format.numberDropDown": "数字", + "xpack.canvas.uis.arguments.numberFormat.format.percentDropDown": "百分比", + "xpack.canvas.uis.arguments.numberFormatLabel": "选择或输入有效的 {numeralJS} 格式", + "xpack.canvas.uis.arguments.numberFormatTitle": "数字格式", + "xpack.canvas.uis.arguments.numberLabel": "输入数字", + "xpack.canvas.uis.arguments.numberTitle": "数字", + "xpack.canvas.uis.arguments.paletteLabel": "选择调色板", + "xpack.canvas.uis.arguments.paletteTitle": "调色板", + "xpack.canvas.uis.arguments.percentageLabel": "百分比滑块 ", + "xpack.canvas.uis.arguments.percentageTitle": "百分比", + "xpack.canvas.uis.arguments.rangeLabel": "范围内的值滑块", + "xpack.canvas.uis.arguments.rangeTitle": "范围", + "xpack.canvas.uis.arguments.selectLabel": "从具有多个选项的下拉列表中选择", + "xpack.canvas.uis.arguments.selectTitle": "选择", + "xpack.canvas.uis.arguments.shapeLabel": "形状选取器", + "xpack.canvas.uis.arguments.shapeTitle": "形状", + "xpack.canvas.uis.arguments.stringLabel": "输入短字符串", + "xpack.canvas.uis.arguments.stringTitle": "字符串", + "xpack.canvas.uis.arguments.textareaLabel": "输入长字符串", + "xpack.canvas.uis.arguments.textareaTitle": "文本区域", + "xpack.canvas.uis.arguments.toggleLabel": "True/False 切换开关", + "xpack.canvas.uis.arguments.toggleTitle": "切换", + "xpack.canvas.uis.dataSources.demoData.headingTitle": "您正在使用演示数据", + "xpack.canvas.uis.dataSources.demoDataLabel": "使用用户名、价格、项目、国家/地区和阶段模拟数据集", + "xpack.canvas.uis.dataSources.demoDataTitle": "演示数据", + "xpack.canvas.uis.dataSources.essqlLabel": "使用 {elasticsearch} {sql} 以获取数据表", + "xpack.canvas.uis.dataSources.essqlTitle": "{elasticsearch} {sql}", + "xpack.canvas.uis.dataSources.timelion.intervalTitle": "时间间隔", + "xpack.canvas.uis.dataSources.timelion.queryLabel": "{lucene} 查询字符串语法", + "xpack.canvas.uis.dataSources.timelion.queryTitle": "查询", + "xpack.canvas.uis.dataSources.timelion.tips.functions": "一些 {timelion} 函数(如 {functionExample})不转换成 {canvas} 数据表。任何与数据操作有关的内容都适用。", + "xpack.canvas.uis.dataSources.timelion.tips.time": "{timelion} 需要时间范围,您应将时间筛选元素添加到页面上的某个位置,或使用代码编辑器传入时间筛选。", + "xpack.canvas.uis.dataSources.timelionLabel": "使用 {timelion} 语法检索时间序列", + "xpack.canvas.uis.models.math.args.valueLabel": "要用于从数据源提取值的函数和列", + "xpack.canvas.uis.models.math.args.valueTitle": "值", + "xpack.canvas.uis.models.mathTitle": "度量", + "xpack.canvas.uis.models.pointSeries.args.colorLabel": "确定标记或序列的颜色", + "xpack.canvas.uis.models.pointSeries.args.colorTitle": "颜色", + "xpack.canvas.uis.models.pointSeries.args.sizeLabel": "确定标记的大小", + "xpack.canvas.uis.models.pointSeries.args.sizeTitle": "大小", + "xpack.canvas.uis.models.pointSeries.args.textLabel": "设置要用作标记或用在标记旁的文本", + "xpack.canvas.uis.models.pointSeries.args.textTitle": "文本", + "xpack.canvas.uis.models.pointSeries.args.xaxisLabel": "横轴上的数据。通常为数字、字符串或日期", + "xpack.canvas.uis.models.pointSeries.args.xaxisTitle": "X 轴", + "xpack.canvas.uis.models.pointSeries.args.yaxisLabel": "竖轴上的数据。通常为数字", + "xpack.canvas.uis.models.pointSeries.args.yaxisTitle": "Y 轴", + "xpack.canvas.uis.models.pointSeriesTitle": "维度和度量", + "xpack.canvas.uis.transforms.formatDate.args.formatTitle": "格式", + "xpack.canvas.uis.transforms.formatDateTitle": "日期格式", + "xpack.canvas.uis.transforms.formatNumber.args.formatTitle": "格式", + "xpack.canvas.uis.transforms.formatNumberTitle": "数字格式", + "xpack.canvas.uis.transforms.roundDate.args.formatLabel": "选择或输入 {momentJs} 格式以舍入日期", + "xpack.canvas.uis.transforms.roundDate.args.formatTitle": "格式", + "xpack.canvas.uis.transforms.roundDateTitle": "舍入日期", + "xpack.canvas.uis.transforms.sort.args.reverseToggleSwitch": "降序", + "xpack.canvas.uis.transforms.sort.args.sortFieldTitle": "排序字段", + "xpack.canvas.uis.transforms.sortTitle": "数据表排序", + "xpack.canvas.uis.views.dropdownControl.args.filterColumnLabel": "从下拉列表中选择的值应用到的列", + "xpack.canvas.uis.views.dropdownControl.args.filterColumnTitle": "筛选列", + "xpack.canvas.uis.views.dropdownControl.args.filterGroupLabel": "将选定组名称应用到元素的筛选函数,以定位该筛选", + "xpack.canvas.uis.views.dropdownControl.args.filterGroupTitle": "筛选组", + "xpack.canvas.uis.views.dropdownControl.args.valueColumnLabel": "从其中提取下拉列表可用值的列", + "xpack.canvas.uis.views.dropdownControl.args.valueColumnTitle": "值列", + "xpack.canvas.uis.views.dropdownControlTitle": "下拉列表筛选", + "xpack.canvas.uis.views.getCellLabel": "获取第一行和第一列", + "xpack.canvas.uis.views.getCellTitle": "下拉列表筛选", + "xpack.canvas.uis.views.image.args.mode.containDropDown": "包含", + "xpack.canvas.uis.views.image.args.mode.coverDropDown": "覆盖", + "xpack.canvas.uis.views.image.args.mode.stretchDropDown": "拉伸", + "xpack.canvas.uis.views.image.args.modeLabel": "注意:拉伸填充可能不适用于矢量图。", + "xpack.canvas.uis.views.image.args.modeTitle": "填充模式", + "xpack.canvas.uis.views.imageTitle": "图像", + "xpack.canvas.uis.views.markdown.args.contentLabel": "{markdown} 格式文本", + "xpack.canvas.uis.views.markdown.args.contentTitle": "{markdown} 内容", + "xpack.canvas.uis.views.markdownLabel": "使用 {markdown} 生成标记", + "xpack.canvas.uis.views.metric.args.labelArgLabel": "描述指标", + "xpack.canvas.uis.views.metric.args.labelArgTitle": "标签", + "xpack.canvas.uis.views.metric.args.labelFontLabel": "字体、对齐和颜色", + "xpack.canvas.uis.views.metric.args.labelFontTitle": "标签文本设置", + "xpack.canvas.uis.views.metric.args.metricFontLabel": "字体、对齐和颜色", + "xpack.canvas.uis.views.metric.args.metricFontTitle": "指标文本设置", + "xpack.canvas.uis.views.metric.args.metricFormatLabel": "字体、对齐和颜色", + "xpack.canvas.uis.views.metric.args.metricFormatTitle": "指标格式", + "xpack.canvas.uis.views.metricTitle": "指标", + "xpack.canvas.uis.views.numberArgTitle": "数字", + "xpack.canvas.uis.views.pie.args.holeLabel": "孔洞半径", + "xpack.canvas.uis.views.pie.args.holeTitle": "内半径", + "xpack.canvas.uis.views.pie.args.labelRadiusLabel": "标签到饼图中心的距离", + "xpack.canvas.uis.views.pie.args.labelRadiusTitle": "标签半径", + "xpack.canvas.uis.views.pie.args.labelsTitle": "标签", + "xpack.canvas.uis.views.pie.args.labelsToggleSwitch": "显示/隐藏标签", + "xpack.canvas.uis.views.pie.args.legendLabel": "禁用或定位图例", + "xpack.canvas.uis.views.pie.args.legendTitle": "图例位置", + "xpack.canvas.uis.views.pie.args.radiusLabel": "饼图半径", + "xpack.canvas.uis.views.pie.args.radiusTitle": "半径", + "xpack.canvas.uis.views.pie.args.tiltLabel": "倾斜百分比,其中 100 为完全垂直,0 为完全水平", + "xpack.canvas.uis.views.pie.args.tiltTitle": "倾斜角度", + "xpack.canvas.uis.views.pieTitle": "图表样式", + "xpack.canvas.uis.views.plot.args.defaultStyleLabel": "设置每个序列默认使用的样式,除非被覆盖", + "xpack.canvas.uis.views.plot.args.defaultStyleTitle": "默认样式", + "xpack.canvas.uis.views.plot.args.legendLabel": "禁用或定位图例", + "xpack.canvas.uis.views.plot.args.legendTitle": "图例位置", + "xpack.canvas.uis.views.plot.args.xaxisLabel": "配置或禁用 X 轴", + "xpack.canvas.uis.views.plot.args.xaxisTitle": "X 轴", + "xpack.canvas.uis.views.plot.args.yaxisLabel": "配置或禁用 Y 轴", + "xpack.canvas.uis.views.plot.args.yaxisTitle": "Y 轴", + "xpack.canvas.uis.views.plotTitle": "图表样式", + "xpack.canvas.uis.views.progress.args.barColorLabel": "接受 HEX、RGB 或 HTML 颜色名称", + "xpack.canvas.uis.views.progress.args.barColorTitle": "背景色", + "xpack.canvas.uis.views.progress.args.barWeightLabel": "背景条形的粗细", + "xpack.canvas.uis.views.progress.args.barWeightTitle": "背景权重", + "xpack.canvas.uis.views.progress.args.fontLabel": "标签的字体设置。通常,也可以添加其他样式", + "xpack.canvas.uis.views.progress.args.fontTitle": "标签设置", + "xpack.canvas.uis.views.progress.args.labelArgLabel": "设置 {true}/{false} 以显示/隐藏标签或提供显示为标签的字符串", + "xpack.canvas.uis.views.progress.args.labelArgTitle": "标签", + "xpack.canvas.uis.views.progress.args.maxLabel": "进度元素的最大值", + "xpack.canvas.uis.views.progress.args.maxTitle": "最大值", + "xpack.canvas.uis.views.progress.args.shapeLabel": "进度指示的形状", + "xpack.canvas.uis.views.progress.args.shapeTitle": "形状", + "xpack.canvas.uis.views.progress.args.valueColorLabel": "接受 {hex}、{rgb} 或 {html} 颜色名称", + "xpack.canvas.uis.views.progress.args.valueColorTitle": "进度颜色", + "xpack.canvas.uis.views.progress.args.valueWeightLabel": "进度条的粗细", + "xpack.canvas.uis.views.progress.args.valueWeightTitle": "进度权重", + "xpack.canvas.uis.views.progressTitle": "进度", + "xpack.canvas.uis.views.render.args.css.applyButtonLabel": "应用样式表", + "xpack.canvas.uis.views.render.args.cssLabel": "适用于您的元素的 {css} 样式表", + "xpack.canvas.uis.views.renderLabel": "您的元素的容器设置", + "xpack.canvas.uis.views.renderTitle": "元素样式", + "xpack.canvas.uis.views.repeatImage.args.emptyImageLabel": "填补值与最大计数之间差异的图像", + "xpack.canvas.uis.views.repeatImage.args.emptyImageTitle": "空图像", + "xpack.canvas.uis.views.repeatImage.args.imageLabel": "要重复的图像", + "xpack.canvas.uis.views.repeatImage.args.imageTitle": "图像", + "xpack.canvas.uis.views.repeatImage.args.maxLabel": "重复图像的最大数目", + "xpack.canvas.uis.views.repeatImage.args.maxTitle": "最大计数", + "xpack.canvas.uis.views.repeatImage.args.sizeLabel": "图像最大维度的大小。例如,如果图像高而不宽,则其为高度", + "xpack.canvas.uis.views.repeatImage.args.sizeTitle": "图像大小", + "xpack.canvas.uis.views.repeatImageTitle": "重复图像", + "xpack.canvas.uis.views.revealImage.args.emptyImageLabel": "背景图像。例如,空杯子", + "xpack.canvas.uis.views.revealImage.args.emptyImageTitle": "背景图像", + "xpack.canvas.uis.views.revealImage.args.imageLabel": "显示给定函数输入的图像。例如,满杯子", + "xpack.canvas.uis.views.revealImage.args.imageTitle": "图像", + "xpack.canvas.uis.views.revealImage.args.origin.bottomDropDown": "下", + "xpack.canvas.uis.views.revealImage.args.origin.leftDropDown": "左", + "xpack.canvas.uis.views.revealImage.args.origin.rightDropDown": "右", + "xpack.canvas.uis.views.revealImage.args.origin.topDropDown": "上", + "xpack.canvas.uis.views.revealImage.args.originLabel": "开始显示的方向", + "xpack.canvas.uis.views.revealImage.args.originTitle": "显示自", + "xpack.canvas.uis.views.revealImageTitle": "显示图像", + "xpack.canvas.uis.views.shape.args.borderLabel": "接受 HEX、RGB 或 HTML 颜色名称", + "xpack.canvas.uis.views.shape.args.borderTitle": "边框", + "xpack.canvas.uis.views.shape.args.borderWidthLabel": "边框宽度", + "xpack.canvas.uis.views.shape.args.borderWidthTitle": "边框宽度", + "xpack.canvas.uis.views.shape.args.fillLabel": "接受 HEX、RGB 或 HTML 颜色名称", + "xpack.canvas.uis.views.shape.args.fillTitle": "填充", + "xpack.canvas.uis.views.shape.args.maintainAspectTitle": "保持纵横比", + "xpack.canvas.uis.views.shape.args.shapeTitle": "选择形状", + "xpack.canvas.uis.views.shapeTitle": "形状", + "xpack.canvas.uis.views.table.args.paginateLabel": "显示或隐藏分页控制。如果禁用,仅第一页显示", + "xpack.canvas.uis.views.table.args.paginateTitle": "分页", + "xpack.canvas.uis.views.table.args.perPageLabel": "每个表页面要显示的行数", + "xpack.canvas.uis.views.table.args.perPageTitle": "每页行数", + "xpack.canvas.uis.views.table.args.showHeaderLabel": "显示或隐藏具有每列标题的标题行", + "xpack.canvas.uis.views.table.args.showHeaderTitle": "标题", + "xpack.canvas.uis.views.tableLabel": "设置表元素的样式", + "xpack.canvas.uis.views.tableTitle": "表样式", + "xpack.canvas.uis.views.timefilter.args.columnConfirmButtonLabel": "设置", + "xpack.canvas.uis.views.timefilter.args.columnLabel": "应用选定时间的列", + "xpack.canvas.uis.views.timefilter.args.columnTitle": "列", + "xpack.canvas.uis.views.timefilter.args.filterGroupLabel": "将选定组名称应用到元素的筛选函数,以定位该筛选", + "xpack.canvas.uis.views.timefilter.args.filterGroupTitle": "筛选组名称", + "xpack.canvas.uis.views.timefilterTitle": "时间筛选", + "xpack.canvas.units.quickRange.dayBeforeYesterday": "前天", + "xpack.canvas.units.quickRange.last12Hours": "过去 12 小时", + "xpack.canvas.units.quickRange.last15Minutes": "过去 15 分钟", + "xpack.canvas.units.quickRange.last1Hour": "过去 1 小时", + "xpack.canvas.units.quickRange.last1Year": "过去 1 年", + "xpack.canvas.units.quickRange.last24Hours": "过去 24 小时", + "xpack.canvas.units.quickRange.last2Weeks": "过去 2 周", + "xpack.canvas.units.quickRange.last2Years": "过去 2 年", + "xpack.canvas.units.quickRange.last30Days": "过去 30 天", + "xpack.canvas.units.quickRange.last30Minutes": "过去 30 分钟", + "xpack.canvas.units.quickRange.last4Hours": "过去 4 小时", + "xpack.canvas.units.quickRange.last5Years": "过去 5 年", + "xpack.canvas.units.quickRange.last60Days": "过去 60 天", + "xpack.canvas.units.quickRange.last6Months": "过去 6 个月", + "xpack.canvas.units.quickRange.last7Days": "过去 7 天", + "xpack.canvas.units.quickRange.last90Days": "过去 90 天", + "xpack.canvas.units.quickRange.monthToDate": "本月迄今为止", + "xpack.canvas.units.quickRange.previousMonth": "上一月", + "xpack.canvas.units.quickRange.previousWeek": "上一周", + "xpack.canvas.units.quickRange.previousYear": "上一年", + "xpack.canvas.units.quickRange.theDaySoFar": "今天迄今为止", + "xpack.canvas.units.quickRange.thisDayLastWeek": "上周本日", + "xpack.canvas.units.quickRange.thisMonth": "本月", + "xpack.canvas.units.quickRange.thisWeek": "本周", + "xpack.canvas.units.quickRange.thisYear": "本年", + "xpack.canvas.units.quickRange.today": "今日", + "xpack.canvas.units.quickRange.weekToDate": "本周迄今为止", + "xpack.canvas.units.quickRange.yearToDate": "本年迄今为止", + "xpack.canvas.units.quickRange.yesterday": "昨天", + "xpack.canvas.units.time.days": "{days, plural, one {# 天} other {# 天}}", + "xpack.canvas.units.time.hours": "{hours, plural, one {# 小时} other {# 小时}}", + "xpack.canvas.units.time.minutes": "{minutes, plural, one {# 分钟} other {# 分钟}}", + "xpack.canvas.units.time.seconds": "{seconds, plural, one {# 秒} other {# 秒}}", + "xpack.canvas.workpadConfig.applyStylesheetButtonLabel": "应用样式表", + "xpack.canvas.workpadConfig.globalCSSLabel": "全局 CSS 覆盖", + "xpack.canvas.workpadConfig.globalCSSTooltip": "将样式应用到此 Workpad 中的所有页面", + "xpack.canvas.workpadConfig.heightLabel": "高", + "xpack.canvas.workpadConfig.nameLabel": "名称", + "xpack.canvas.workpadConfig.pageSizeBadgeAriaLabel": "预设页面大小:{sizeName}", + "xpack.canvas.workpadConfig.pageSizeBadgeOnClickAriaLabel": "将页面大小设置为 {sizeName}", + "xpack.canvas.workpadConfig.swapDimensionsAriaLabel": "交换页面的宽和高", + "xpack.canvas.workpadConfig.swapDimensionsTooltip": "交换宽高", + "xpack.canvas.workpadConfig.title": "Workpad", + "xpack.canvas.workpadConfig.USLetterButtonLabel": "美国信函", + "xpack.canvas.workpadConfig.widthLabel": "宽", + "xpack.canvas.workpadCreate.createButtonLabel": "创建 Workpad", + "xpack.canvas.workpadHeader.addElementButtonLabel": "添加元素", + "xpack.canvas.workpadHeader.addElementModalCloseButtonLabel": "关闭", + "xpack.canvas.workpadHeader.cycleIntervalDaysText": "每 {days} {days, plural, one {天} other {天}}", + "xpack.canvas.workpadHeader.cycleIntervalHoursText": "每 {hours} {hours, plural, one {小时} other {小时}}", + "xpack.canvas.workpadHeader.cycleIntervalMinutesText": "每 {minutes} {minutes, plural, one {分钟} other {分钟}}", + "xpack.canvas.workpadHeader.cycleIntervalSecondsText": "每 {seconds} {seconds, plural, one {秒} other {秒}}", + "xpack.canvas.workpadHeader.embedObjectButtonLabel": "嵌入对象", + "xpack.canvas.workpadHeader.fullscreenButtonAriaLabel": "全屏查看", + "xpack.canvas.workpadHeader.fullscreenTooltip": "进入全屏模式", + "xpack.canvas.workpadHeader.hideEditControlTooltip": "隐藏编辑控件", + "xpack.canvas.workpadHeader.noWritePermissionTooltip": "您无权编辑此 Workpad", + "xpack.canvas.workpadHeader.showEditControlTooltip": "显示编辑控件", + "xpack.canvas.workpadHeaderAutoRefreshControls.disableTooltip": "禁用自动刷新", + "xpack.canvas.workpadHeaderAutoRefreshControls.intervalFormLabel": "更改自动刷新时间间隔", + "xpack.canvas.workpadHeaderAutoRefreshControls.refreshListDurationManualText": "手动", + "xpack.canvas.workpadHeaderAutoRefreshControls.refreshListTitle": "刷新元素", + "xpack.canvas.workpadHeaderControlSettings.settingsTooltip": "控制设置", + "xpack.canvas.workpadHeaderCustomInterval.confirmButtonLabel": "设置", + "xpack.canvas.workpadHeaderCustomInterval.formDescription": "使用速记表示法,如 {secondsExample}、{minutesExample} 或 {hoursExample}", + "xpack.canvas.workpadHeaderCustomInterval.formLabel": "设置定制时间间隔", + "xpack.canvas.workpadHeaderKioskControl.controlTitle": "循环播放全屏页面", + "xpack.canvas.workpadHeaderKioskControl.cycleFormLabel": "更改循环播放时间间隔", + "xpack.canvas.workpadHeaderKioskControl.cycleToggleSwitch": "自动循环播放幻灯片", + "xpack.canvas.workpadHeaderRefreshControlSettings.refreshAriaLabel": "刷新元素", + "xpack.canvas.workpadHeaderRefreshControlSettings.refreshTooltip": "刷新数据", + "xpack.canvas.workpadHeaderWorkpadExport.copyPDFMessage": "{PDF} 生成 {URL} 已复制到剪贴板", + "xpack.canvas.workpadHeaderWorkpadExport.copyReportingConfigMessage": "已将报告配置复制到剪贴板", + "xpack.canvas.workpadHeaderWorkpadExport.copyShareConfigMessage": "已将共享标记复制到剪贴板", + "xpack.canvas.workpadHeaderWorkpadExport.exportPDFErrorMessage": "无法为“{workpadName}”创建 {PDF}", + "xpack.canvas.workpadHeaderWorkpadExport.exportPDFMessage": "正在导出 {PDF}。可以在“管理”中跟踪进度。", + "xpack.canvas.workpadHeaderWorkpadExport.exportPDFTitle": "Workpad“{workpadName}”的 {PDF} 导出", + "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelCopyAriaLabel": "或者,也可以从脚本或使用 {URL} 通过 Watcher 生成 {PDF}。按 Enter 键可将 {URL} 复制到剪贴板。", + "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelCopyButtonLabel": "复制 {POST} {URL}", + "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelCopyDescription": "或者,复制此 {POST} {URL} 以从 {KIBANA} 外部或从 Watcher 调用生成。", + "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelDisabledDescription": "导出到 PDF 已禁用。必须配置报告,才能使用 Chromium 浏览器。将其添加到您的 {fileName} 文件中。", + "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelGenerateButtonLabel": "生成 {PDF}", + "xpack.canvas.workpadHeaderWorkpadExport.pdfPanelGenerateDescription": "{PDF} 可能会花费 1 或 2 分钟生成,取决于 Workpad 的大小。", + "xpack.canvas.workpadHeaderWorkpadExport.shareDownloadJSONTitle": "下载为 {JSON}", + "xpack.canvas.workpadHeaderWorkpadExport.shareDownloadPDFTitle": "{PDF} 报告", + "xpack.canvas.workpadHeaderWorkpadExport.shareWebsiteErrorTitle": "无法为“{workpadName}”创建 {ZIP} 文件。Workpad 可能过大。您将需要分别下载文件。", + "xpack.canvas.workpadHeaderWorkpadExport.shareWebsiteTitle": "在网站上共享", + "xpack.canvas.workpadHeaderWorkpadExport.shareWorkpadMessage": "共享此 Workpad", + "xpack.canvas.workpadHeaderWorkpadExport.unknownExportErrorMessage": "未知导出类型:{type}", + "xpack.canvas.workpadHeaderWorkpadExport.unsupportedRendererWarning": "此 Workpad 包含 {CANVAS} Shareable Workpad Runtime 不支持的呈现函数。将不会呈现以下元素:", + "xpack.canvas.workpadHeaderWorkpadZoom.zoomControlsAriaLabel": "缩放控制", + "xpack.canvas.workpadHeaderWorkpadZoom.zoomControlsTooltip": "缩放控制", + "xpack.canvas.workpadHeaderWorkpadZoom.zoomFitToWindowText": "适应窗口大小", + "xpack.canvas.workpadHeaderWorkpadZoom.zoomInText": "放大", + "xpack.canvas.workpadHeaderWorkpadZoom.zoomOutText": "缩小", + "xpack.canvas.workpadHeaderWorkpadZoom.zoomPanelTitle": "缩放", + "xpack.canvas.workpadHeaderWorkpadZoom.zoomPrecentageValue": "重置", + "xpack.canvas.workpadHeaderWorkpadZoom.zoomResetText": "{scalePercentage}%", + "xpack.canvas.workpadLoader.clonedWorkpadName": "{workpadName} 的副本", + "xpack.canvas.workpadLoader.cloneTooltip": "克隆 Workpad", + "xpack.canvas.workpadLoader.createWorkpadLoadingDescription": "正在创建 Workpad......", + "xpack.canvas.workpadLoader.deleteButtonAriaLabel": "删除 {numberOfWorkpads} 个 Workpad", + "xpack.canvas.workpadLoader.deleteButtonLabel": "删除 ({numberOfWorkpads})", + "xpack.canvas.workpadLoader.deleteModalConfirmButtonLabel": "删除", + "xpack.canvas.workpadLoader.deleteModalDescription": "您无法恢复删除的 Workpad。", + "xpack.canvas.workpadLoader.deleteMultipleWorkpadsModalTitle": "删除 {numberOfWorkpads} 个 Workpad?", + "xpack.canvas.workpadLoader.deleteSingleWorkpadModalTitle": "删除 Workpad“{workpadName}”?", + "xpack.canvas.workpadLoader.emptyPromptGettingStartedDescription": "创建新的 Workpad、从模板入手或通过将 Workpad {JSON} 文件拖放到此处来导入。", + "xpack.canvas.workpadLoader.emptyPromptNewUserDescription": "{CANVAS} 新手?", + "xpack.canvas.workpadLoader.emptyPromptTitle": "添加您的首个 Workpad", + "xpack.canvas.workpadLoader.exportButtonAriaLabel": "导出 {numberOfWorkpads} 个 Workpad", + "xpack.canvas.workpadLoader.exportButtonLabel": "导出 ({numberOfWorkpads})", + "xpack.canvas.workpadLoader.exportTooltip": "导出 Workpad", + "xpack.canvas.workpadLoader.fetchLoadingDescription": "正在获取 Workpad......", + "xpack.canvas.workpadLoader.filePickerPlaceholder": "导入 Workpad {JSON} 文件", + "xpack.canvas.workpadLoader.loadWorkpadArialLabel": "加载 Workpad“{workpadName}”", + "xpack.canvas.workpadLoader.noPermissionToCloneToolTip": "您无权克隆 Workpad", + "xpack.canvas.workpadLoader.noPermissionToCreateToolTip": "您无权创建 Workpad", + "xpack.canvas.workpadLoader.noPermissionToDeleteToolTip": "您无权删除 Workpad", + "xpack.canvas.workpadLoader.noPermissionToUploadToolTip": "您无权上传 Workpad", + "xpack.canvas.workpadLoader.sampleDataLinkLabel": "添加您的首个 Workpad", + "xpack.canvas.workpadLoader.table.createdColumnTitle": "创建时间", + "xpack.canvas.workpadLoader.table.nameColumnTitle": "Workpad 名称", + "xpack.canvas.workpadLoader.table.updatedColumnTitle": "更新时间", + "xpack.canvas.workpadManager.modalTitle": "{CANVAS} Workpad", + "xpack.canvas.workpadManager.myWorkpadsTabLabel": "我的 Workpad", + "xpack.canvas.workpadManager.workpadTemplatesTabLabel": "模板", + "xpack.canvas.workpadSearch.searchPlaceholder": "查找 Workpad", + "xpack.canvas.workpadTemplate.cloneTemplateLinkAriaLabel": "克隆 Workpad 模板“{templateName}”", + "xpack.canvas.workpadTemplate.searchPlaceholder": "查找模板", + "xpack.canvas.workpadTemplates.table.descriptionColumnTitle": "描述", + "xpack.canvas.workpadTemplates.table.nameColumnTitle": "模板名称", + "xpack.canvas.workpadTemplates.table.tagsColumnTitle": "标记", + "xpack.crossClusterReplication.addAutoFollowPatternButtonLabel": "创建自动跟随模式", + "xpack.crossClusterReplication.addBreadcrumbTitle": "添加", + "xpack.crossClusterReplication.addFollowerButtonLabel": "创建 Follower 索引", + "xpack.crossClusterReplication.app.checkPermissionsFatalErrorTitle": "跨集群复制应用", + "xpack.crossClusterReplication.app.deniedPermissionDescription": "要使用跨集群复制,您必须具有{clusterPrivilegesCount, plural, one {以下集群权限} other {以下集群权限}}:{clusterPrivileges}。", + "xpack.crossClusterReplication.app.deniedPermissionTitle": "您缺少集群权限", + "xpack.crossClusterReplication.app.permissionCheckErrorTitle": "检查权限时出错", + "xpack.crossClusterReplication.app.permissionCheckTitle": "正在检查权限......", + "xpack.crossClusterReplication.appTitle": "跨集群复制", + "xpack.crossClusterReplication.autoFollowPattern.addAction.successNotificationTitle": "已添加自动跟随模式“{name}”", + "xpack.crossClusterReplication.autoFollowPattern.addTitle": "添加自动跟随模式", + "xpack.crossClusterReplication.autoFollowPattern.editTitle": "编辑自动跟随模式", + "xpack.crossClusterReplication.autoFollowPattern.leaderIndexPatternValidation.illegalCharacters": "从索引模式中删除{characterListLength, plural, one {字符} other {字符}} {characterList}。", + "xpack.crossClusterReplication.autoFollowPattern.leaderIndexPatternValidation.isEmpty": "至少需要一个 Leader 索引模式。", + "xpack.crossClusterReplication.autoFollowPattern.leaderIndexPatternValidation.noEmptySpace": "索引模式中不允许使用空格。", + "xpack.crossClusterReplication.autoFollowPattern.nameValidation.errorComma": "名称中不允许使用逗号。", + "xpack.crossClusterReplication.autoFollowPattern.nameValidation.errorEmptyName": "“名称”必填", + "xpack.crossClusterReplication.autoFollowPattern.nameValidation.errorSpace": "名称中不允许使用空格。", + "xpack.crossClusterReplication.autoFollowPattern.nameValidation.errorUnderscore": "名称不能以下划线开头。", + "xpack.crossClusterReplication.autoFollowPattern.prefixValidation.beginsWithPeriod": "前缀不能以逗点开头。", + "xpack.crossClusterReplication.autoFollowPattern.prefixValidation.illegalCharacters": "从前缀中删除{characterListLength, plural, one {字符} other {字符}} {characterList}。", + "xpack.crossClusterReplication.autoFollowPattern.prefixValidation.noEmptySpace": "前缀中不能使用空格。", + "xpack.crossClusterReplication.autoFollowPattern.removeAction.errorMultipleNotificationTitle": "删除 {count} 个自动跟随模式时出错", + "xpack.crossClusterReplication.autoFollowPattern.removeAction.errorSingleNotificationTitle": "删除 “{name}” 自动跟随模式时出错", + "xpack.crossClusterReplication.autoFollowPattern.removeAction.successMultipleNotificationTitle": "{count} 个自动跟随模式已删除", + "xpack.crossClusterReplication.autoFollowPattern.removeAction.successSingleNotificationTitle": "自动跟随模式 “{name}” 已删除", + "xpack.crossClusterReplication.autoFollowPattern.suffixValidation.illegalCharacters": "从后缀中删除{characterListLength, plural, one {字符} other {字符}} {characterList}。", + "xpack.crossClusterReplication.autoFollowPattern.suffixValidation.noEmptySpace": "后缀中不能使用空格。", + "xpack.crossClusterReplication.autoFollowPattern.updateAction.successNotificationTitle": "自动跟随模式 “{name}” 已成功更新", + "xpack.crossClusterReplication.autoFollowPatternCreateForm.loadingRemoteClustersMessage": "正在加载远程集群……", + "xpack.crossClusterReplication.autoFollowPatternCreateForm.saveButtonLabel": "创建", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.closeButtonLabel": "关闭", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.deleteButtonLabel": "删除", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.editButtonLabel": "编辑", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.leaderPatternsLabel": "Leader 模式", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.notFoundLabel": "未找到自动跟随模式", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.prefixEmptyValue": "无前缀", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.prefixLabel": "前缀", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.recentErrorsTitle": "最近错误", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.remoteClusterLabel": "远程集群", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.statusTitle": "设置", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.suffixEmptyValue": "无后缀", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.suffixLabel": "后缀", + "xpack.crossClusterReplication.autoFollowPatternDetailPanel.viewIndicesLink": "在“索引管理”中查看您的 Follower 索引", + "xpack.crossClusterReplication.autoFollowPatternEditForm.loadingErrorMessage": "自动跟随模式“{name}”不存在。", + "xpack.crossClusterReplication.autoFollowPatternEditForm.loadingErrorTitle": "加载自动跟随模式时出错", + "xpack.crossClusterReplication.autoFollowPatternEditForm.loadingRemoteClustersMessage": "正在加载远程集群……", + "xpack.crossClusterReplication.autoFollowPatternEditForm.loadingTitle": "正在加载自动跟随模式……", + "xpack.crossClusterReplication.autoFollowPatternEditForm.saveButtonLabel": "更新", + "xpack.crossClusterReplication.autoFollowPatternEditForm.viewAutoFollowPatternsButtonLabel": "查看自动跟随模式", + "xpack.crossClusterReplication.autoFollowPatternForm.actions.savingText": "正在保存", + "xpack.crossClusterReplication.autoFollowPatternForm.autoFollowPattern.fieldPrefixLabel": "前缀", + "xpack.crossClusterReplication.autoFollowPatternForm.autoFollowPattern.fieldSuffixLabel": "后缀", + "xpack.crossClusterReplication.autoFollowPatternForm.autoFollowPatternName.fieldNameLabel": "名称", + "xpack.crossClusterReplication.autoFollowPatternForm.cancelButtonLabel": "取消", + "xpack.crossClusterReplication.autoFollowPatternForm.currentRemoteClusterNotConnectedCallOutDescription": "可以通过编辑远程集群来解决此问题。", + "xpack.crossClusterReplication.autoFollowPatternForm.currentRemoteClusterNotConnectedCallOutTitle": "无法编辑自动跟随模式,因为远程集群“{name}”未连接", + "xpack.crossClusterReplication.autoFollowPatternForm.currentRemoteClusterNotFoundCallOutDescription": "要编辑此自动跟随模式,您必须添加名为“{name}”的远程集群。", + "xpack.crossClusterReplication.autoFollowPatternForm.emptyRemoteClustersCallOutDescription": "自动跟随模式捕获远程集群上的索引。", + "xpack.crossClusterReplication.autoFollowPatternForm.fieldFollowerIndicesHelpLabel": "不允许使用空格和字符 {characterList}。", + "xpack.crossClusterReplication.autoFollowPatternForm.fieldLeaderIndexPatternsHelpLabel": "不允许使用空格和字符 {characterList}。", + "xpack.crossClusterReplication.autoFollowPatternForm.fieldLeaderIndexPatternsLabel": "索引模式", + "xpack.crossClusterReplication.autoFollowPatternForm.fieldLeaderIndexPatternsPlaceholder": "键入并按 ENTER 键", + "xpack.crossClusterReplication.autoFollowPatternForm.hideRequestButtonLabel": "隐藏请求", + "xpack.crossClusterReplication.autoFollowPatternForm.indicesPreviewDescription": "上述设置将生成类似下面的索引名称:", + "xpack.crossClusterReplication.autoFollowPatternForm.indicesPreviewTitle": "索引名称示例", + "xpack.crossClusterReplication.autoFollowPatternForm.leaderIndexPatternError.duplicateMessage": "不允许重复的 Leader 索引模式。", + "xpack.crossClusterReplication.autoFollowPatternForm.requestFlyout.closeButtonLabel": "关闭", + "xpack.crossClusterReplication.autoFollowPatternForm.requestFlyout.createDescriptionText": "此 Elasticsearch 请求将创建此自动跟随模式。", + "xpack.crossClusterReplication.autoFollowPatternForm.requestFlyout.editDescriptionText": "此 Elasticsearch 请求将更新此自动跟随模式。", + "xpack.crossClusterReplication.autoFollowPatternForm.requestFlyout.namedTitle": "对“{name}”的请求", + "xpack.crossClusterReplication.autoFollowPatternForm.requestFlyout.unnamedTitle": "请求", + "xpack.crossClusterReplication.autoFollowPatternForm.savingErrorTitle": "无法创建自动跟随模式", + "xpack.crossClusterReplication.autoFollowPatternForm.sectionAutoFollowPatternDescription": "应用于 Follower 索引名称的定制前缀或后缀,以便您可以更容易辨识复制的索引。默认情况下,Follower 索引与 Leader 索引有相同的名称。", + "xpack.crossClusterReplication.autoFollowPatternForm.sectionAutoFollowPatternNameDescription": "自动跟随模式的唯一名称。", + "xpack.crossClusterReplication.autoFollowPatternForm.sectionAutoFollowPatternNameTitle": "名称", + "xpack.crossClusterReplication.autoFollowPatternForm.sectionAutoFollowPatternTitle": "Follower 索引(可选)", + "xpack.crossClusterReplication.autoFollowPatternForm.sectionLeaderIndexPatternsDescription1": "用于标识要从远程集群复制的索引的一个或多个索引模式。创建匹配这些模式的新索引时,它们将会复制到本地集群上的 Follower 索引。", + "xpack.crossClusterReplication.autoFollowPatternForm.sectionLeaderIndexPatternsDescription2": "{note}不会复制已存在的索引。", + "xpack.crossClusterReplication.autoFollowPatternForm.sectionLeaderIndexPatternsDescription2.noteLabel": "注意:", + "xpack.crossClusterReplication.autoFollowPatternForm.sectionLeaderIndexPatternsTitle": "Leader 索引", + "xpack.crossClusterReplication.autoFollowPatternForm.sectionRemoteClusterDescription": "要从其中复制 Leader 索引的远程索引。", + "xpack.crossClusterReplication.autoFollowPatternForm.sectionRemoteClusterTitle": "远程集群", + "xpack.crossClusterReplication.autoFollowPatternForm.validationErrorTitle": "继续前请解决错误。", + "xpack.crossClusterReplication.autoFollowPatternFormm.showRequestButtonLabel": "显示请求", + "xpack.crossClusterReplication.autoFollowPatternList.addAutoFollowPatternButtonLabel": "创建自动跟随模式", + "xpack.crossClusterReplication.autoFollowPatternList.autoFollowPatternsDescription": "自动跟随模式从远程集群复制 Leader 索引,将它们复制到本地集群上的 Follower 索引。", + "xpack.crossClusterReplication.autoFollowPatternList.autoFollowPatternsTitle": "自动跟随模式", + "xpack.crossClusterReplication.autoFollowPatternList.crossClusterReplicationTitle": "跨集群复制", + "xpack.crossClusterReplication.autoFollowPatternList.emptyPromptDescription": "使用自动跟随模式自动从远程集群复制索引。", + "xpack.crossClusterReplication.autoFollowPatternList.emptyPromptTitle": "创建第一个自动跟随模式", + "xpack.crossClusterReplication.autoFollowPatternList.followerIndicesTitle": "Follower 索引", + "xpack.crossClusterReplication.autoFollowPatternList.loadingErrorTitle": "加载自动跟随模式时出错", + "xpack.crossClusterReplication.autoFollowPatternList.loadingTitle": "正在加载自动跟随模式……", + "xpack.crossClusterReplication.autoFollowPatternList.noPermissionText": "您无权查看或添加自动跟随模式。", + "xpack.crossClusterReplication.autoFollowPatternList.permissionErrorTitle": "权限错误", + "xpack.crossClusterReplication.autoFollowPatternList.table.actionDeleteDescription": "删除自动跟随模式", + "xpack.crossClusterReplication.autoFollowPatternList.table.actionEditDescription": "编辑自动跟随模式", + "xpack.crossClusterReplication.autoFollowPatternList.table.actionsColumnTitle": "操作", + "xpack.crossClusterReplication.autoFollowPatternList.table.clusterColumnTitle": "远程集群", + "xpack.crossClusterReplication.autoFollowPatternList.table.leaderPatternsColumnTitle": "Leader 模式", + "xpack.crossClusterReplication.autoFollowPatternList.table.nameColumnTitle": "名称", + "xpack.crossClusterReplication.autoFollowPatternList.table.prefixColumnTitle": "Follower 索引前缀", + "xpack.crossClusterReplication.autoFollowPatternList.table.suffixColumnTitle": "Follower 索引后缀", + "xpack.crossClusterReplication.checkLicense.errorExpiredMessage": "您不能使用 {pluginName},因为您的 {licenseType} 许可证已过期", + "xpack.crossClusterReplication.checkLicense.errorUnavailableMessage": "您不能使用 {pluginName},因为许可证信息当前不可用。", + "xpack.crossClusterReplication.checkLicense.errorUnsupportedMessage": "您的 {licenseType} 许可证不支持 {pluginName}。请升级您的许可。", + "xpack.crossClusterReplication.deleteAutoFollowPattern.confirmModal.cancelButtonText": "取消", + "xpack.crossClusterReplication.deleteAutoFollowPattern.confirmModal.confirmButtonText": "删除", + "xpack.crossClusterReplication.deleteAutoFollowPattern.confirmModal.deleteMultipleTitle": "是否删除 {count} 个自动跟随模式?", + "xpack.crossClusterReplication.deleteAutoFollowPattern.confirmModal.deleteSingleTitle": "是否删除自动跟随模式 {name}?", + "xpack.crossClusterReplication.deleteAutoFollowPattern.confirmModal.multipleDeletionDescription": "您即将删除以下自动跟随模式:", + "xpack.crossClusterReplication.deleteAutoFollowPatternButtonLabel": "删除自动跟随 {total, plural, one { 个模式} other { 个模式}}", + "xpack.crossClusterReplication.editBreadcrumbTitle": "编辑", + "xpack.crossClusterReplication.followerIndex.addAction.successNotificationTitle": "已添加 Follower 索引“{name}”", + "xpack.crossClusterReplication.followerIndex.addTitle": "添加 Follower 索引", + "xpack.crossClusterReplication.followerIndex.advancedSettingsForm.showSwitchLabel": "自定义高级设置", + "xpack.crossClusterReplication.followerIndex.contextMenu.buttonLabel": "管理 Follower {followerIndicesLength, plural, one {索引} other {索引}}", + "xpack.crossClusterReplication.followerIndex.contextMenu.editLabel": "编辑 Follower 索引", + "xpack.crossClusterReplication.followerIndex.contextMenu.pauseLabel": "暂停复制", + "xpack.crossClusterReplication.followerIndex.contextMenu.resumeLabel": "恢复复制", + "xpack.crossClusterReplication.followerIndex.contextMenu.title": "Follower {followerIndicesLength, plural, one {索引} other {索引}}选项", + "xpack.crossClusterReplication.followerIndex.contextMenu.unfollowLabel": "取消跟随 Leader {followerIndicesLength, plural, one {索引} other {索引}}", + "xpack.crossClusterReplication.followerIndex.editTitle": "编辑 Follower 索引", + "xpack.crossClusterReplication.followerIndex.indexNameValidation.noEmptySpace": "名称中不允许使用空格。", + "xpack.crossClusterReplication.followerIndex.leaderIndexValidation.noEmptySpace": "Leader 索引中不允许使用空格。", + "xpack.crossClusterReplication.followerIndex.pauseAction.errorMultipleNotificationTitle": "暂停 {count} 个 Follower 索引时出错", + "xpack.crossClusterReplication.followerIndex.pauseAction.errorSingleNotificationTitle": "暂停 Follower 索引“{name}”时出错", + "xpack.crossClusterReplication.followerIndex.pauseAction.successMultipleNotificationTitle": "{count} 个 Follower 索引已暂停", + "xpack.crossClusterReplication.followerIndex.pauseAction.successSingleNotificationTitle": "Follower 索引“{name}”已暂停", + "xpack.crossClusterReplication.followerIndex.resumeAction.errorMultipleNotificationTitle": "恢复 {count} 个 Follower 索引时出错", + "xpack.crossClusterReplication.followerIndex.resumeAction.errorSingleNotificationTitle": "恢复 Follower 索引“{name}”时出错", + "xpack.crossClusterReplication.followerIndex.resumeAction.successMultipleNotificationTitle": "{count} 个 Follower 索引已恢复", + "xpack.crossClusterReplication.followerIndex.resumeAction.successSingleNotificationTitle": "Follower 索引“{name}”已恢复", + "xpack.crossClusterReplication.followerIndex.unfollowAction.errorMultipleNotificationTitle": "取消跟随 {count} 个 Follower 索引的 Leader 索引时出错", + "xpack.crossClusterReplication.followerIndex.unfollowAction.errorSingleNotificationTitle": "取消跟随 Follower 索引“{name}”的 Leader 索引时出错", + "xpack.crossClusterReplication.followerIndex.unfollowAction.notOpenWarningMultipleNotificationTitle": "无法重新打开 {count} 个索引", + "xpack.crossClusterReplication.followerIndex.unfollowAction.notOpenWarningSingleNotificationTitle": "无法重新打开索引“{name}”", + "xpack.crossClusterReplication.followerIndex.unfollowAction.successMultipleNotificationTitle": "已取消跟随 {count} 个 Follower 索引的 Leader 索引", + "xpack.crossClusterReplication.followerIndex.unfollowAction.successSingleNotificationTitle": "已取消跟随 Follower 索引“{name}”的 Leader 索引", + "xpack.crossClusterReplication.followerIndex.updateAction.successNotificationTitle": "Follower 索引“{name}”已成功更新", + "xpack.crossClusterReplication.followerIndexCreateForm.loadingRemoteClustersMessage": "正在加载远程集群……", + "xpack.crossClusterReplication.followerIndexCreateForm.saveButtonLabel": "创建", + "xpack.crossClusterReplication.followerIndexDetailPanel.activeStatus": "有效", + "xpack.crossClusterReplication.followerIndexDetailPanel.closeButtonLabel": "关闭", + "xpack.crossClusterReplication.followerIndexDetailPanel.leaderIndexLabel": "Leader 索引", + "xpack.crossClusterReplication.followerIndexDetailPanel.loadingLabel": "正在加载 Follower 索引......", + "xpack.crossClusterReplication.followerIndexDetailPanel.manageButtonLabel": "管理", + "xpack.crossClusterReplication.followerIndexDetailPanel.notFoundLabel": "找不到 Follower 索引", + "xpack.crossClusterReplication.followerIndexDetailPanel.pausedFollowerCalloutTitle": "暂停的 Follower 索引不具有设置或分片统计。", + "xpack.crossClusterReplication.followerIndexDetailPanel.pausedStatus": "已暂停", + "xpack.crossClusterReplication.followerIndexDetailPanel.remoteClusterLabel": "远程集群", + "xpack.crossClusterReplication.followerIndexDetailPanel.settingsTitle": "设置", + "xpack.crossClusterReplication.followerIndexDetailPanel.shardStatsTitle": "分片 {id} 统计", + "xpack.crossClusterReplication.followerIndexDetailPanel.statusLabel": "状态", + "xpack.crossClusterReplication.followerIndexDetailPanel.viewIndexLink": "在“索引管理”中查看", + "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.cancelButtonText": "取消", + "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.confirmAndResumeButtonText": "更新并恢复", + "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.confirmButtonText": "更新", + "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.description": "该 Follower 索引先被暂停,然后被恢复。如果更新失败,请尝试手动恢复复制。", + "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.resumeDescription": "更新 Follower 索引可恢复其 Leader 索引的复制。", + "xpack.crossClusterReplication.followerIndexEditForm.confirmModal.title": "更新 Follower 索引“{id}”?", + "xpack.crossClusterReplication.followerIndexEditForm.loadingErrorMessage": "该 Follower 索引“{name}”不存在。", + "xpack.crossClusterReplication.followerIndexEditForm.loadingErrorTitle": "加载 Follower 索引时出错", + "xpack.crossClusterReplication.followerIndexEditForm.loadingFollowerIndexTitle": "正在加载 Follower 索引......", + "xpack.crossClusterReplication.followerIndexEditForm.loadingRemoteClustersMessage": "正在加载远程集群……", + "xpack.crossClusterReplication.followerIndexEditForm.saveButtonLabel": "更新", + "xpack.crossClusterReplication.followerIndexEditForm.viewFollowerIndicesButtonLabel": "查看 Follower 索引", + "xpack.crossClusterReplication.followerIndexForm.actions.savingText": "正在保存", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.byteUnitsHelpText": "示例值:10b、1024kb、1mb、5gb、2tb、1pb。{link}", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.byteUnitsHelpTextLinkMessage": "了解详情", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingReadRequestsDescription": "来自远程集群的未完成读请求最大数目。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingReadRequestsLabel": "未完成读请求最大数", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingReadRequestsTitle": "未完成读请求最大数", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingWriteRequestsDescription": "Follower 上未完成写请求最大数目。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingWriteRequestsLabel": "未完成写请求最大数", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxOutstandingWriteRequestsTitle": "未完成写请求最大数", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestOperationCountDescription": "从远程集群每次读取所拉取的最大操作数目。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestOperationCountLabel": "读请求操作最大计数", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestOperationCountTitle": "读请求操作最大计数", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestSizeDescription": "从远程集群拉取的批量操作的每次读取最大大小(字节)。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestSizeLabel": "读请求最大大小", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxReadRequestSizeTitle": "读请求最大大小", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxRetryDelayDescription": "重试异常失败的操作前要等待的最长时间;重试时采用了指数退避策略。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxRetryDelayLabel": "最大重试延迟", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxRetryDelayTitle": "最大重试延迟", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferCountDescription": "可排队等待写入的最大操作数目;当此限制达到时,将会延迟从远程集群的读取,直到已排队操作的数目低于该限制。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferCountLabel": "最大写缓冲区计数", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferCountTitle": "最大写缓冲区计数", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferSizeDescription": "可排队等待写入的操作的最大总字节数;当此限制达到时,将会延迟从远程集群的读取,直到已排队操作的总字节数低于此限制。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferSizeLabel": "最大写缓冲区大小", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteBufferSizeTitle": "最大写缓冲区大小", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestOperationCountDescription": "在 Follower 上执行的每个批量写请求的最大操作数目。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestOperationCountLabel": "最大写请求操作计数", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestOperationCountTitle": "最大写请求操作计数", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestSizeDescription": "在 Follower 上执行的每个批量写请求的最大操作总字节数。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestSizeLabel": "最大写请求大小", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.maxWriteRequestSizeTitle": "最大写请求大小", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.readPollTimeoutDescription": "当 Follower 索引与 Leader 索引同步时等待远程集群上的新操作的最长时间;当超时结束时,对操作的轮询将返回到 Follower,以便其可以更新某些统计,然后 Follower 将立即尝试再次从 Leader 读取。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.readPollTimeoutLabel": "读取轮询超时", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.readPollTimeoutTitle": "读取轮询超时", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.timeUnitsHelpText": "示例值:2d、24h、20m、30s、500ms、10000micros、80000nanos。{link}", + "xpack.crossClusterReplication.followerIndexForm.advancedSettings.timeUnitsHelpTextLinkMessage": "了解详情", + "xpack.crossClusterReplication.followerIndexForm.advancedSettingsDescription": "高级设置控制复制的速率。您可以定制这些设置或使用默认值。", + "xpack.crossClusterReplication.followerIndexForm.advancedSettingsTitle": "高级设置(可选)", + "xpack.crossClusterReplication.followerIndexForm.cancelButtonLabel": "取消", + "xpack.crossClusterReplication.followerIndexForm.currentRemoteClusterNotConnectedCallOutDescription": "可以通过编辑远程集群来解决此问题。", + "xpack.crossClusterReplication.followerIndexForm.currentRemoteClusterNotConnectedCallOutTitle": "无法编辑 Follower 索引,因为远程集群“{name}”未连接", + "xpack.crossClusterReplication.followerIndexForm.currentRemoteClusterNotFoundCallOutDescription": "要编辑此 Follower 索引,您必须添加名为“{name}”的远程集群。", + "xpack.crossClusterReplication.followerIndexForm.emptyRemoteClustersCallOutDescription": "复制需要远程集群上有 Leader 索引。", + "xpack.crossClusterReplication.followerIndexForm.errors.leaderIndexIllegalCharactersMessage": "从 Leader 索引中删除 {characterList} 字符。", + "xpack.crossClusterReplication.followerIndexForm.errors.leaderIndexMissingMessage": "Leader 索引必填。", + "xpack.crossClusterReplication.followerIndexForm.errors.nameBeginsWithPeriodMessage": "名称不能以句点开头。", + "xpack.crossClusterReplication.followerIndexForm.errors.nameIllegalCharactersMessage": "从名称中删除 {characterList} 字符。", + "xpack.crossClusterReplication.followerIndexForm.errors.nameMissingMessage": "“名称”必填", + "xpack.crossClusterReplication.followerIndexForm.hideRequestButtonLabel": "隐藏请求", + "xpack.crossClusterReplication.followerIndexForm.indexAlreadyExistError": "同名索引已存在。", + "xpack.crossClusterReplication.followerIndexForm.indexNameHelpLabel": "不允许使用空格和字符 {characterList}。", + "xpack.crossClusterReplication.followerIndexForm.indexNameValidatingLabel": "正在检查可用性......", + "xpack.crossClusterReplication.followerIndexForm.indexNameValidationFatalErrorTitle": "Follower 索引表单索引名称验证", + "xpack.crossClusterReplication.followerIndexForm.leaderIndexNotFoundError": "Leader 索引“{leaderIndex}”不存在。", + "xpack.crossClusterReplication.followerIndexForm.requestFlyout.closeButtonLabel": "关闭", + "xpack.crossClusterReplication.followerIndexForm.requestFlyout.descriptionText": "此 Elasticsearch 请求将创建此 Follower 索引。", + "xpack.crossClusterReplication.followerIndexForm.requestFlyout.title": "请求", + "xpack.crossClusterReplication.followerIndexForm.resetFieldButtonLabel": "重置为默认值", + "xpack.crossClusterReplication.followerIndexForm.savingErrorTitle": "无法创建 Follower 索引", + "xpack.crossClusterReplication.followerIndexForm.sectionFollowerIndexNameDescription": "索引的唯一名称。", + "xpack.crossClusterReplication.followerIndexForm.sectionFollowerIndexNameTitle": "Follower 索引", + "xpack.crossClusterReplication.followerIndexForm.sectionLeaderIndexDescription": "远程群集上要复制到 Follower 索引的索引。", + "xpack.crossClusterReplication.followerIndexForm.sectionLeaderIndexDescription2": "{note}Leader 索引必须已存在。", + "xpack.crossClusterReplication.followerIndexForm.sectionLeaderIndexDescription2.noteLabel": "注意:", + "xpack.crossClusterReplication.followerIndexForm.sectionLeaderIndexTitle": "Leader 索引", + "xpack.crossClusterReplication.followerIndexForm.sectionRemoteClusterDescription": "包含要复制的索引的集群。", + "xpack.crossClusterReplication.followerIndexForm.sectionRemoteClusterTitle": "远程集群", + "xpack.crossClusterReplication.followerIndexForm.showRequestButtonLabel": "显示请求", + "xpack.crossClusterReplication.followerIndexForm.validationErrorTitle": "继续前请解决错误。", + "xpack.crossClusterReplication.followerIndexList.addFollowerButtonLabel": "创建 Follower 索引", + "xpack.crossClusterReplication.followerIndexList.emptyPromptDescription": "使用 Follower 索引复制远程集群上的 Leader 索引。", + "xpack.crossClusterReplication.followerIndexList.emptyPromptTitle": "创建首个 Follower 索引", + "xpack.crossClusterReplication.followerIndexList.followerIndicesDescription": "Follower 索引复制远程集群上的 Leader 索引。", + "xpack.crossClusterReplication.followerIndexList.loadingErrorTitle": "加载 Follower 索引时出错", + "xpack.crossClusterReplication.followerIndexList.loadingTitle": "正在加载 Follower 索引......", + "xpack.crossClusterReplication.followerIndexList.noPermissionText": "您无权查看或添加 Follower 索引。", + "xpack.crossClusterReplication.followerIndexList.permissionErrorTitle": "权限错误", + "xpack.crossClusterReplication.followerIndexList.table.actionEditDescription": "编辑 Follower 索引", + "xpack.crossClusterReplication.followerIndexList.table.actionPauseDescription": "暂停复制", + "xpack.crossClusterReplication.followerIndexList.table.actionResumeDescription": "恢复复制", + "xpack.crossClusterReplication.followerIndexList.table.actionsColumnTitle": "操作", + "xpack.crossClusterReplication.followerIndexList.table.actionUnfollowDescription": "取消跟随 Leader 索引", + "xpack.crossClusterReplication.followerIndexList.table.clusterColumnTitle": "远程集群", + "xpack.crossClusterReplication.followerIndexList.table.leaderIndexColumnTitle": "Leader 索引", + "xpack.crossClusterReplication.followerIndexList.table.nameColumnTitle": "名称", + "xpack.crossClusterReplication.followerIndexList.table.statusColumn.activeLabel": "有效", + "xpack.crossClusterReplication.followerIndexList.table.statusColumn.pausedLabel": "已暂停", + "xpack.crossClusterReplication.followerIndexList.table.statusColumnTitle": "状态", + "xpack.crossClusterReplication.homeBreadcrumbTitle": "跨集群复制", + "xpack.crossClusterReplication.indexMgmtBadge.followerLabel": "Follower", + "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.cancelButtonText": "取消", + "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.confirmButtonText": "暂停复制", + "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.multiplePauseDescription": "复制将在以下 Follower 索引上暂停:", + "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.multiplePauseDescriptionWithSettingWarning": "暂停复制到 Follower 索引可清除其定制高级设置。", + "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.pauseMultipleTitle": "暂停复制到 {count} 个 Follower 索引?", + "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.pauseSingleTitle": "暂停复制到 Follower 索引“{name}”?", + "xpack.crossClusterReplication.pauseFollowerIndex.confirmModal.singlePauseDescriptionWithSettingWarning": "暂停复制到此 Follower 索引可清除其定制高级设置。", + "xpack.crossClusterReplication.readDocsAutoFollowPatternButtonLabel": "自动跟随模式文档", + "xpack.crossClusterReplication.readDocsFollowerIndexButtonLabel": "Follower 索引文档", + "xpack.crossClusterReplication.remoteClustersFormField.addRemoteClusterButtonLabel": "添加远程集群", + "xpack.crossClusterReplication.remoteClustersFormField.currentRemoteClusterNotConnectedCallOutDescription": "编辑远程集群或选择连接的集群。", + "xpack.crossClusterReplication.remoteClustersFormField.currentRemoteClusterNotConnectedCallOutTitle": "远程集群“{name}”未连接", + "xpack.crossClusterReplication.remoteClustersFormField.emptyRemoteClustersCallOutDescription": "至少需要一个远程集群才能创建 Follower 索引。", + "xpack.crossClusterReplication.remoteClustersFormField.emptyRemoteClustersCallOutTitle": "您没有任何远程集群", + "xpack.crossClusterReplication.remoteClustersFormField.fieldClusterLabel": "远程集群", + "xpack.crossClusterReplication.remoteClustersFormField.invalidRemoteClusterError": "远程集群无效", + "xpack.crossClusterReplication.remoteClustersFormField.remoteClusterDropdownNotConnected": "{name}(未连接)", + "xpack.crossClusterReplication.remoteClustersFormField.remoteClusterNotFoundTitle": "找不到远程集群“{name}”", + "xpack.crossClusterReplication.remoteClustersFormField.validRemoteClusterRequired": "需要连接的远程集群。", + "xpack.crossClusterReplication.remoteClustersFormField.viewRemoteClusterButtonLabel": "编辑远程集群", + "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.cancelButtonText": "取消", + "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.confirmButtonText": "恢复复制", + "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.multipleResumeDescription": "复制将在以下 Follower 索引上恢复:", + "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.multipleResumeDescriptionWithSettingWarning": "复制将恢复使用默认高级设置。", + "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.resumeMultipleTitle": "恢复复制到 {count} 个 Follower 索引?", + "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.resumeSingleTitle": "恢复复制到 Follower 索引“{name}”?", + "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.singleResumeDescription": "复制将恢复使用默认高级设置。要使用定制高级设置,请{editLink}。", + "xpack.crossClusterReplication.resumeFollowerIndex.confirmModal.singleResumeEditLink": "编辑 Follower 索引", + "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.cancelButtonText": "取消", + "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.confirmButtonText": "取消跟随 Leader", + "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.multipleUnfollowDescription": "Follower 索引将转换为标准索引。它们不再显示在跨集群复制中,但您可以在“索引管理”中管理它们。此操作无法撤消。", + "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.singleUnfollowDescription": "Follower 索引将转换为标准索引。它不再显示在跨集群复制中,但您可以在“索引管理”中管理它。此操作无法撤消。", + "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.unfollowMultipleTitle": "取消跟随 {count} 个 Leader 索引?", + "xpack.crossClusterReplication.unfollowLeaderIndex.confirmModal.unfollowSingleTitle": "取消跟随“{name}”的 Leader 索引?", + "xpack.dashboardMode.dashboardViewer.dashboardDescription": "仪表板查看器", + "xpack.dashboardMode.dashboardViewer.dashboardTitle": "仪表板", + "xpack.dashboardMode.dashboardViewerDescription": "查看仪表板", + "xpack.dashboardMode.dashboardViewerTitle": "仪表板查看器", + "xpack.dashboardMode.uiSettings.dashboardsOnlyRolesDescription": "属于“仅查看仪表板”模式的角色", + "xpack.dashboardMode.uiSettings.dashboardsOnlyRolesTitle": "仅限仪表板的角色", "xpack.features.advancedSettingsFeatureName": "高级设置", "xpack.features.dashboardFeatureName": "仪表板", "xpack.features.devToolsFeatureName": "开发工具", @@ -12635,6 +5645,1158 @@ "xpack.features.indexPatternFeatureName": "索引模式管理", "xpack.features.savedObjectsManagementFeatureName": "已保存对象管理", "xpack.features.visualizeFeatureName": "Visualize", + "xpack.fileUpload.enterIndexName": "输入索引名称", + "xpack.fileUpload.fileParser.errorReadingFile": "读取文件时出错", + "xpack.fileUpload.fileParser.noFeaturesDetected": "错误,未检测到功能", + "xpack.fileUpload.fileParser.noFileProvided": "错误,未提供任何文件", + "xpack.fileUpload.fileParser.transformDetailsNotDefined": "未定义 {transformDetails} 的索引选项", + "xpack.fileUpload.httpService.fetchError": "执行提取时出错:{error}", + "xpack.fileUpload.httpService.noUrl": "未提供 URL", + "xpack.fileUpload.indexingService.errorCreatingIndex": "创建索引时出错", + "xpack.fileUpload.indexingService.noFileImported": "未导入任何文件。", + "xpack.fileUpload.indexingService.noHandlingForTransform": "没有为转换 {transform} 定义任何处理方式", + "xpack.fileUpload.indexingService.noIndexingDetailsForDatatype": "没有为数据类型 {dataType} 定义任何索引详情", + "xpack.fileUpload.indexingService.noTransformDefined": "未定义任何转换", + "xpack.fileUpload.indexingService.transformResultError": "转换数据时出错:{error}", + "xpack.fileUpload.indexingService.unknownTransformError": "执行转换 {transform} 时出现未知错误", + "xpack.fileUpload.indexNameReqField": "索引名称,必填字段", + "xpack.fileUpload.indexSettings.enterIndexNameLabel": "索引名称", + "xpack.fileUpload.indexSettings.enterIndexTypeLabel": "索引类型", + "xpack.fileUpload.indexSettings.guidelines.cannotBe": "不能为 . 或 ..", + "xpack.fileUpload.indexSettings.guidelines.cannotInclude": "不能包含 \\\\、/、*、?、\"、<、>、|、 “ ”(空格字符)、,(逗号)、#", + "xpack.fileUpload.indexSettings.guidelines.cannotStartWith": "不能以 -、_、+ 开头", + "xpack.fileUpload.indexSettings.guidelines.length": "不能长于 255 字节(注意是字节, 因此多字节字符将更快达到 255 字节限制)", + "xpack.fileUpload.indexSettings.guidelines.lowercaseOnly": "仅小写", + "xpack.fileUpload.indexSettings.guidelines.mustBeNewIndex": "必须是新索引", + "xpack.fileUpload.indexSettings.indexNameAlreadyExistsErrorMessage": "索引名称或模式已存在。", + "xpack.fileUpload.indexSettings.indexNameContainsIllegalCharactersErrorMessage": "索引名称包含非法字符。", + "xpack.fileUpload.indexSettings.indexNameGuidelines": "索引名称指引", + "xpack.fileUpload.jsonImport.indexingResponse": "索引响应", + "xpack.fileUpload.jsonImport.indexingStatus": "索引状态", + "xpack.fileUpload.jsonImport.indexMgmtLink": "索引管理", + "xpack.fileUpload.jsonImport.indexModsMsg": "要进一步做索引修改,可以使用\n", + "xpack.fileUpload.jsonImport.indexPatternResponse": "索引模式响应", + "xpack.fileUpload.jsonIndexFilePicker.acceptableFileSize": "文件大小 {fileSize} 超过最大文件大小 {maxFileSize}", + "xpack.fileUpload.jsonIndexFilePicker.acceptableTypesError": "文件不是可接受类型之一:{types}", + "xpack.fileUpload.jsonIndexFilePicker.fileParseError": "检测到文件解析错误:{error}", + "xpack.fileUpload.jsonIndexFilePicker.filePicker": "上传文件", + "xpack.fileUpload.jsonIndexFilePicker.filePickerLabel": "选择文件进行上传", + "xpack.fileUpload.jsonIndexFilePicker.fileProcessingError": "文件处理错误:{errorMessage}", + "xpack.fileUpload.jsonIndexFilePicker.fileSizeError": "文件大小错误:{errorMessage}", + "xpack.fileUpload.jsonIndexFilePicker.formatsAccepted": "接受的格式:.json、.geojson", + "xpack.fileUpload.jsonIndexFilePicker.maxSize": "最大大小:{maxFileSize}", + "xpack.fileUpload.jsonIndexFilePicker.noFileNameError": "未提供任何文件名称", + "xpack.fileUpload.jsonIndexFilePicker.parsingFile": "{featuresProcessed} 特征已解析......", + "xpack.fileUpload.jsonIndexFilePicker.unableParseFile": "无法解析文件:{error}", + "xpack.fileUpload.jsonUploadAndParse.creatingIndexPattern": "正在创建索引模式", + "xpack.fileUpload.jsonUploadAndParse.dataIndexingError": "数据索引错误", + "xpack.fileUpload.jsonUploadAndParse.dataIndexingStarted": "数据索引已启动", + "xpack.fileUpload.jsonUploadAndParse.indexingComplete": "索引完成!", + "xpack.fileUpload.jsonUploadAndParse.indexPatternComplete": "索引模式完成", + "xpack.fileUpload.jsonUploadAndParse.indexPatternError": "索引模式错误", + "xpack.fileUpload.jsonUploadAndParse.writingToIndex": "正在写入索引", + "xpack.fileUpload.noIndexSuppliedErrorMessage": "未提供任何索引。", + "xpack.fileUpload.patternReader.featuresOmitted": "不具有几何形状的一些特征已省略", + "xpack.graph.badge.readOnly.text": "只读", + "xpack.graph.badge.readOnly.tooltip": "无法保存 Graph 工作空间", + "xpack.graph.bar.exploreLabel": "Graph", + "xpack.graph.bar.pickFieldsLabel": "添加字段", + "xpack.graph.bar.pickSourceLabel": "选择数据源", + "xpack.graph.bar.pickSourceTooltip": "选择数据源以开始绘制关系图。", + "xpack.graph.bar.searchFieldPlaceholder": "搜索数据并将其添加到图表", + "xpack.graph.blacklist.noEntriesDescription": "您没有任何已阻止字词。选择顶点并单击右侧控制面板上的 {stopSign} 以阻止它们。匹配已阻止字词的文档将不再被浏览,与它们的关系将隐藏。", + "xpack.graph.blacklist.removeButtonAriaLabel": "删除", + "xpack.graph.clearWorkspace.confirmButtonLabel": "更改数据源", + "xpack.graph.clearWorkspace.confirmText": "如果更改数据源,您当前的字段和顶点将会重置。", + "xpack.graph.clearWorkspace.modalTitle": "未保存更改", + "xpack.graph.drilldowns.description": "使用向下钻取以链接到其他应用程序。选定的顶点成为 URL 的一部分。", + "xpack.graph.errorToastTitle": "Graph 错误", + "xpack.graph.exploreGraph.timedOutWarningText": "浏览超时", + "xpack.graph.featureRegistry.graphFeatureName": "Graph", + "xpack.graph.fieldManager.cancelLabel": "取消", + "xpack.graph.fieldManager.colorLabel": "颜色", + "xpack.graph.fieldManager.deleteFieldLabel": "取消选择字段", + "xpack.graph.fieldManager.deleteFieldTooltipContent": "此字段的新顶点将不会发现。 现有顶点仍在图表中。", + "xpack.graph.fieldManager.disabledFieldBadgeDescription": "已禁用字段 {field}:单击以配置。按 Shift 键并单击可启用", + "xpack.graph.fieldManager.disableFieldLabel": "禁用字段", + "xpack.graph.fieldManager.disableFieldTooltipContent": "关闭此字段顶点的发现。还可以按 Shift 键并单击字段可将其禁用。", + "xpack.graph.fieldManager.enableFieldLabel": "启用字段", + "xpack.graph.fieldManager.enableFieldTooltipContent": "打开此字段顶点的发现。还可以按 Shift 键并单击字段可将其启用。", + "xpack.graph.fieldManager.fieldBadgeDescription": "字段 {field}:单击以配置。按 Shift 键并单击可禁用", + "xpack.graph.fieldManager.fieldLabel": "字段", + "xpack.graph.fieldManager.fieldSearchPlaceholder": "筛选依据", + "xpack.graph.fieldManager.iconLabel": "图标", + "xpack.graph.fieldManager.maxTermsPerHopDescription": "控制要为每个搜索步长返回的字词最大数目。", + "xpack.graph.fieldManager.maxTermsPerHopLabel": "每跃点字词数", + "xpack.graph.fieldManager.settingsFormTitle": "编辑", + "xpack.graph.fieldManager.settingsLabel": "编辑设置", + "xpack.graph.fieldManager.updateLabel": "保存更改", + "xpack.graph.fillWorkspaceError": "获取排名最前字词失败:{message}", + "xpack.graph.guidancePanel.datasourceItem.indexPatternButtonLabel": "选择数据源。", + "xpack.graph.guidancePanel.fieldsItem.fieldsButtonLabel": "添加字段。", + "xpack.graph.guidancePanel.nodesItem.description": "在搜索栏中输入查询以开始浏览。不知道如何入手?{topTerms}。", + "xpack.graph.guidancePanel.nodesItem.topTermsButtonLabel": "将排名最前字词绘入图表", + "xpack.graph.guidancePanel.title": "绘制图表的三个步骤", + "xpack.graph.home.breadcrumb": "Graph", + "xpack.graph.icon.areaChart": "面积图", + "xpack.graph.icon.at": "@ 符号", + "xpack.graph.icon.automobile": "汽车", + "xpack.graph.icon.bank": "银行", + "xpack.graph.icon.barChart": "条形图", + "xpack.graph.icon.bolt": "闪电", + "xpack.graph.icon.cube": "立方", + "xpack.graph.icon.desktop": "台式机", + "xpack.graph.icon.exclamation": "惊叹号", + "xpack.graph.icon.externalLink": "外部链接", + "xpack.graph.icon.eye": "眼睛", + "xpack.graph.icon.file": "文件打开", + "xpack.graph.icon.fileText": "文件", + "xpack.graph.icon.flag": "旗帜", + "xpack.graph.icon.folderOpen": "文件夹打开", + "xpack.graph.icon.font": "字体", + "xpack.graph.icon.globe": "地球", + "xpack.graph.icon.google": "Google", + "xpack.graph.icon.heart": "心形", + "xpack.graph.icon.home": "主页", + "xpack.graph.icon.industry": "工业", + "xpack.graph.icon.info": "信息", + "xpack.graph.icon.key": "钥匙", + "xpack.graph.icon.lineChart": "折线图", + "xpack.graph.icon.list": "列表", + "xpack.graph.icon.mapMarker": "地图标记", + "xpack.graph.icon.music": "音乐", + "xpack.graph.icon.phone": "电话", + "xpack.graph.icon.pieChart": "饼图", + "xpack.graph.icon.plane": "飞机", + "xpack.graph.icon.question": "问号", + "xpack.graph.icon.shareAlt": "Share alt", + "xpack.graph.icon.table": "桌子", + "xpack.graph.icon.tachometer": "转速表", + "xpack.graph.icon.user": "用户", + "xpack.graph.icon.users": "用户", + "xpack.graph.inspect.requestTabTitle": "请求", + "xpack.graph.inspect.responseTabTitle": "响应", + "xpack.graph.inspect.title": "检查", + "xpack.graph.leaveWorkspace.confirmButtonLabel": "离开", + "xpack.graph.leaveWorkspace.confirmText": "如果现在离开,将丢失未保存的更改。", + "xpack.graph.leaveWorkspace.modalTitle": "未保存更改", + "xpack.graph.listing.createNewGraph.combineDataViewFromKibanaAppDescription": "发现 Elasticsearch 索引中的模式和关系。", + "xpack.graph.listing.createNewGraph.createButtonLabel": "创建图表", + "xpack.graph.listing.createNewGraph.newToKibanaDescription": "Kibana 新手?从 {sampleDataInstallLink} 入手。", + "xpack.graph.listing.createNewGraph.sampleDataInstallLinkText": "样例数据", + "xpack.graph.listing.createNewGraph.title": "创建您的首个图表", + "xpack.graph.listing.graphsTitle": "图表", + "xpack.graph.listing.noDataSource.newToKibanaDescription": "Kibana 新手?还可以使用我们的{sampleDataInstallLink}。", + "xpack.graph.listing.noDataSource.sampleDataInstallLinkText": "样例数据", + "xpack.graph.listing.noItemsMessage": "似乎您没有任何图表。", + "xpack.graph.listing.table.descriptionColumnName": "描述", + "xpack.graph.listing.table.entityName": "图表", + "xpack.graph.listing.table.entityNamePlural": "图表", + "xpack.graph.listing.table.titleColumnName": "标题", + "xpack.graph.loadWorkspace.missingIndexPatternErrorMessage": "未找到索引模式", + "xpack.graph.missingWorkspaceErrorMessage": "缺少工作空间", + "xpack.graph.newGraphTitle": "未保存图表", + "xpack.graph.noDataSourceNotificationMessageText": "未找到数据源。前往 {managementIndexPatternsLink},为您的 Elasticsearch 索引创建索引模式。", + "xpack.graph.noDataSourceNotificationMessageText.managementIndexPatternLinkText": "管理 > 索引模式", + "xpack.graph.noDataSourceNotificationMessageTitle": "无数据源", + "xpack.graph.outlinkEncoders.esqPlainDescription": "使用标准 URL 编码的 JSON", + "xpack.graph.outlinkEncoders.esqPlainTitle": "Elasticsearch 查询(纯编码)", + "xpack.graph.outlinkEncoders.esqRisonDescription": "rison 编码的 JSON,minimum_should_match=2,与大部分 Kibana URL 兼容", + "xpack.graph.outlinkEncoders.esqRisonLooseDescription": "rison 编码的 JSON,minimum_should_match=1,与大部分 Kibana URL 兼容", + "xpack.graph.outlinkEncoders.esqRisonLooseTitle": "Elasticsearch OR 查询(rison 编码)", + "xpack.graph.outlinkEncoders.esqRisonTitle": "Elasticsearch AND 查询(rison 编码)", + "xpack.graph.outlinkEncoders.esqSimilarRisonDescription": "rison 编码的 JSON“like this but not this”类型的查询,用于查找缺少的文档", + "xpack.graph.outlinkEncoders.esqSimilarRisonTitle": "Elasticsearch“more like this”查询(rison 编码)", + "xpack.graph.outlinkEncoders.kqlLooseDescription": "KQL 查询,与 Discover、Visualize 和仪表板兼容", + "xpack.graph.outlinkEncoders.kqlLooseTitle": "KQL OR 查询", + "xpack.graph.outlinkEncoders.kqlTitle": "KQL AND 查询", + "xpack.graph.outlinkEncoders.textLuceneDescription": "所选顶点标签的文本,已对 Lucene 特殊字符进行了编码", + "xpack.graph.outlinkEncoders.textLuceneTitle": "Lucene 转义文本", + "xpack.graph.outlinkEncoders.textPlainDescription": "所选顶点标签的文本,采用纯 URL 编码的字符串形式", + "xpack.graph.outlinkEncoders.textPlainTitle": "纯文本", + "xpack.graph.pluginDescription": "显示并分析 Elasticsearch 数据中的相关关系。", + "xpack.graph.savedWorkspace.workspaceNameTitle": "新建 Graph 工作空间", + "xpack.graph.savedWorkspaces.graphWorkspaceLabel": "Graph 工作空间", + "xpack.graph.savedWorkspaces.graphWorkspacesLabel": "Graph 工作空间", + "xpack.graph.saveWorkspace.savingErrorMessage": "无法保存工作空间:{message}", + "xpack.graph.saveWorkspace.successNotification.noDataSavedText": "配置会被保存,但不保存数据", + "xpack.graph.saveWorkspace.successNotificationTitle": "已保存“{workspaceTitle}”", + "xpack.graph.serverSideErrors.unavailableGraphErrorMessage": "Graph 不可用", + "xpack.graph.serverSideErrors.unavailableLicenseInformationErrorMessage": "Graph 不可用 - 许可信息当前不可用。", + "xpack.graph.settings.advancedSettings.certaintyInputHelpText": "在引入相关字词之前作为证据所需的最小文档数量。", + "xpack.graph.settings.advancedSettings.certaintyInputLabel": "确定性", + "xpack.graph.settings.advancedSettings.diversityFieldInputHelpText1": "为避免文档示例过于雷同,请选取有助于识别偏差来源的字段。", + "xpack.graph.settings.advancedSettings.diversityFieldInputHelpText2": "此字段必须为单字字段,否则会拒绝搜索,并发生错误。", + "xpack.graph.settings.advancedSettings.diversityFieldInputLabel": "多元化字段", + "xpack.graph.settings.advancedSettings.diversityFieldInputOptionLabel": "[没有多元化]", + "xpack.graph.settings.advancedSettings.maxValuesInputHelpText": "示例中可以包含相同", + "xpack.graph.settings.advancedSettings.maxValuesInputHelpText.fieldText": "字段", + "xpack.graph.settings.advancedSettings.maxValuesInputLabel": "每个字段的最大文档数量", + "xpack.graph.settings.advancedSettings.sampleSizeInputHelpText": "字词从最相关的文档样本中进行识别。较大样本不一定更好—因为较大的样本会更慢且相关性更差。", + "xpack.graph.settings.advancedSettings.sampleSizeInputLabel": "示例大小", + "xpack.graph.settings.advancedSettings.significantLinksCheckboxHelpText": "识别“重要”而不只是常用的字词。", + "xpack.graph.settings.advancedSettings.significantLinksCheckboxLabel": "重要链接", + "xpack.graph.settings.advancedSettings.timeoutInputHelpText": "请求可以运行的最大时间(以毫秒为单位)。", + "xpack.graph.settings.advancedSettings.timeoutInputLabel": "超时 (ms)", + "xpack.graph.settings.advancedSettings.timeoutUnit": "ms", + "xpack.graph.settings.advancedSettingsTitle": "高级设置", + "xpack.graph.settings.blacklist.blacklistHelpText": "这些字词当前已列入黑名单,不允许重新显示在工作空间中。", + "xpack.graph.settings.blacklist.clearButtonLabel": "清除", + "xpack.graph.settings.blacklistTitle": "黑名单", + "xpack.graph.settings.closeLabel": "关闭", + "xpack.graph.settings.drillDowns.cancelButtonLabel": "取消", + "xpack.graph.settings.drillDowns.defaultUrlTemplateTitle": "原始文档", + "xpack.graph.settings.drillDowns.invalidUrlWarningText": "URL 必须包含 {placeholder} 字符串。", + "xpack.graph.settings.drillDowns.kibanaUrlWarningConvertOptionLinkText": "转换它。", + "xpack.graph.settings.drillDowns.kibanaUrlWarningText": "这会类似于 Kibana URL。是否要将其转换为模板?", + "xpack.graph.settings.drillDowns.newSaveButtonLabel": "保存向下钻取", + "xpack.graph.settings.drillDowns.removeButtonLabel": "删除", + "xpack.graph.settings.drillDowns.resetButtonLabel": "重置", + "xpack.graph.settings.drillDowns.toolbarIconPickerLabel": "工具栏图标", + "xpack.graph.settings.drillDowns.updateSaveButtonLabel": "更新向下钻取", + "xpack.graph.settings.drillDowns.urlDescriptionInputLabel": "标题", + "xpack.graph.settings.drillDowns.urlDescriptionInputPlaceholder": "在 Google 上搜索", + "xpack.graph.settings.drillDowns.urlEncoderInputLabel": "URL 参数类型", + "xpack.graph.settings.drillDowns.urlInputHelpText": "使用插入选定顶点字词的 {gquery} 定义模板 URL。", + "xpack.graph.settings.drillDowns.urlInputLabel": "URL", + "xpack.graph.settings.drillDownsTitle": "向下钻取", + "xpack.graph.settings.title": "设置", + "xpack.graph.sidebar.displayLabelHelpText": "更改此顶点的标签。", + "xpack.graph.sidebar.displayLabelLabel": "显示标签", + "xpack.graph.sidebar.drillDowns.noDrillDownsHelpText": "从设置菜单配置向下钻取", + "xpack.graph.sidebar.drillDownsTitle": "向下钻取", + "xpack.graph.sidebar.groupButtonLabel": "组", + "xpack.graph.sidebar.groupButtonTooltip": "将当前选定的项分组成 {latestSelectionLabel}", + "xpack.graph.sidebar.linkSummary.bothTermsCountTooltip": "{count} 个文档同时具有这两个字词", + "xpack.graph.sidebar.linkSummary.leftTermCountTooltip": "{count} 个文档具有字词 {term}", + "xpack.graph.sidebar.linkSummary.mergeTerm1ToTerm2ButtonTooltip": "将 {term1} 合并到 {term2}", + "xpack.graph.sidebar.linkSummary.mergeTerm2ToTerm1ButtonTooltip": "将 {term2} 合并到 {term1}", + "xpack.graph.sidebar.linkSummary.rightTermCountTooltip": "{count} 个文档具有字词 {term}", + "xpack.graph.sidebar.linkSummaryTitle": "链接摘要", + "xpack.graph.sidebar.selections.invertSelectionButtonLabel": "反向", + "xpack.graph.sidebar.selections.invertSelectionButtonTooltip": "反向选择", + "xpack.graph.sidebar.selections.noSelectionsHelpText": "无选择。点击顶点以添加。", + "xpack.graph.sidebar.selections.selectAllButtonLabel": "全部", + "xpack.graph.sidebar.selections.selectAllButtonTooltip": "全选", + "xpack.graph.sidebar.selections.selectNeighboursButtonLabel": "已链接", + "xpack.graph.sidebar.selections.selectNeighboursButtonTooltip": "选择邻居", + "xpack.graph.sidebar.selections.selectNoneButtonLabel": "无", + "xpack.graph.sidebar.selections.selectNoneButtonTooltip": "不选择任何内容", + "xpack.graph.sidebar.selectionsTitle": "选择的内容", + "xpack.graph.sidebar.styleVerticesTitle": "样式选择的顶点", + "xpack.graph.sidebar.topMenu.addLinksButtonTooltip": "在现有字词之间添加链接", + "xpack.graph.sidebar.topMenu.blacklistButtonTooltip": "返回工作空间时选择的黑名单", + "xpack.graph.sidebar.topMenu.customStyleButtonTooltip": "定制样式选择的顶点", + "xpack.graph.sidebar.topMenu.drillDownButtonTooltip": "向下钻取", + "xpack.graph.sidebar.topMenu.expandSelectionButtonTooltip": "展开选择内容", + "xpack.graph.sidebar.topMenu.pauseLayoutButtonTooltip": "暂停布局", + "xpack.graph.sidebar.topMenu.redoButtonTooltip": "重做", + "xpack.graph.sidebar.topMenu.removeVerticesButtonTooltip": "从工作空间删除顶点", + "xpack.graph.sidebar.topMenu.runLayoutButtonTooltip": "运行布局", + "xpack.graph.sidebar.topMenu.undoButtonTooltip": "撤消", + "xpack.graph.sidebar.ungroupButtonLabel": "取消分组", + "xpack.graph.sidebar.ungroupButtonTooltip": "取消分组 {latestSelectionLabel}", + "xpack.graph.sourceModal.notFoundLabel": "未找到数据源。", + "xpack.graph.sourceModal.savedObjectType.indexPattern": "索引模式", + "xpack.graph.sourceModal.title": "选择数据源", + "xpack.graph.templates.addLabel": "新向下钻取", + "xpack.graph.templates.newTemplateFormLabel": "添加向下钻取", + "xpack.graph.topNavMenu.inspectAriaLabel": "检查", + "xpack.graph.topNavMenu.inspectLabel": "检查", + "xpack.graph.topNavMenu.newWorkspaceAriaLabel": "新建工作空间", + "xpack.graph.topNavMenu.newWorkspaceLabel": "新建", + "xpack.graph.topNavMenu.newWorkspaceTooltip": "新建工作空间", + "xpack.graph.topNavMenu.save.descriptionInputLabel": "描述", + "xpack.graph.topNavMenu.save.objectType": "图表", + "xpack.graph.topNavMenu.save.saveConfigurationOnlyText": "将清除此工作空间的数据,仅保存配置。", + "xpack.graph.topNavMenu.save.saveConfigurationOnlyWarning": "将清除此工作空间的数据,仅保存配置。", + "xpack.graph.topNavMenu.save.saveGraphContentCheckboxLabel": "保存 Graph 内容", + "xpack.graph.topNavMenu.saveWorkspace.disabledTooltip": "当前保存策略不允许对已保存的工作空间做任何更改", + "xpack.graph.topNavMenu.saveWorkspace.enabledAriaLabel": "保存工作空间", + "xpack.graph.topNavMenu.saveWorkspace.enabledLabel": "保存", + "xpack.graph.topNavMenu.saveWorkspace.enabledTooltip": "保存此工作空间", + "xpack.graph.topNavMenu.settingsAriaLabel": "设置", + "xpack.graph.topNavMenu.settingsLabel": "设置", + "xpack.grokDebugger.customPatterns.callOutTitle": "每行输入一个自定义模式。例如:", + "xpack.grokDebugger.customPatternsButtonLabel": "自定义模式", + "xpack.grokDebugger.displayName": "Grok Debugger", + "xpack.grokDebugger.grokPatternLabel": "Grok 模式", + "xpack.grokDebugger.licenseHasExpiredMessage": "您不能使用 {grokLogParsingTool} Debugger,因为您的 {licenseType} 许可证已过期。", + "xpack.grokDebugger.patternsErrorMessage": "提供的 {grokLogParsingTool} 模式不匹配输入中的数据", + "xpack.grokDebugger.registryProviderDescription": "采集时模拟和调试用于数据转换的 {grokLogParsingTool} 模式。", + "xpack.grokDebugger.registryProviderTitle": "{grokLogParsingTool} Debugger", + "xpack.grokDebugger.sampleDataLabel": "样例数据", + "xpack.grokDebugger.simulateButtonLabel": "模拟", + "xpack.grokDebugger.structuredDataLabel": "结构化数据", + "xpack.grokDebugger.unavailableLicenseInformationMessage": "您不能使用 {grokLogParsingTool} Debugger,因为许可证信息当前不可用。", + "xpack.idxMgmt.appTitle": "索引管理", + "xpack.idxMgmt.badgeAriaLabel": "{label}。选择以基于此选项进行筛选。", + "xpack.idxMgmt.breadcrumb.cloneTemplateLabel": "克隆模板", + "xpack.idxMgmt.breadcrumb.createTemplateLabel": "创建模板", + "xpack.idxMgmt.breadcrumb.editTemplateLabel": "编辑模板", + "xpack.idxMgmt.breadcrumb.homeLabel": "索引管理", + "xpack.idxMgmt.breadcrumb.templatesLabel": "模板", + "xpack.idxMgmt.clearCacheIndicesAction.successMessage": "已成功清除缓存:[{indexNames}]", + "xpack.idxMgmt.closeIndicesAction.successfullyClosedIndicesMessage": "已成功关闭:[{indexNames}]", + "xpack.idxMgmt.createRoute.duplicateTemplateIdErrorMessage": "已有名称为“{name}”的模板。", + "xpack.idxMgmt.createTemplate.cloneTemplatePageTitle": "克隆模板“{name}”", + "xpack.idxMgmt.createTemplate.createTemplatePageTitle": "创建模板", + "xpack.idxMgmt.deleteIndicesAction.successfullyDeletedIndicesMessage": "已成功删除:[{indexNames}]", + "xpack.idxMgmt.deleteTemplatesModal.cancelButtonLabel": "取消", + "xpack.idxMgmt.deleteTemplatesModal.confirmButtonLabel": "删除{numTemplatesToDelete, plural, one {模板} other {模板} }", + "xpack.idxMgmt.deleteTemplatesModal.confirmDeleteCheckboxLabel": "我了解删除系统模板的后果", + "xpack.idxMgmt.deleteTemplatesModal.deleteDescription": "您即将删除{numTemplatesToDelete, plural, one {以下模板} other {以下模板} }:", + "xpack.idxMgmt.deleteTemplatesModal.errorNotificationMessageText": "删除模板“{name}”时出错", + "xpack.idxMgmt.deleteTemplatesModal.modalTitleText": "删除 {numTemplatesToDelete, plural, one { 个模板} other {# 个模板}}", + "xpack.idxMgmt.deleteTemplatesModal.multipleErrorsNotificationMessageText": "删除 {count} 个模板时出错", + "xpack.idxMgmt.deleteTemplatesModal.proceedWithCautionCallOutDescription": "系统模板对内部操作至关重要。如果删除此模板,将无法恢复。", + "xpack.idxMgmt.deleteTemplatesModal.proceedWithCautionCallOutTitle": "删除系统模板会使 Kibana 无法运行", + "xpack.idxMgmt.deleteTemplatesModal.successDeleteMultipleNotificationMessageText": "已删除 {numSuccesses, plural, one {# 个模板} other {# 个模板}}", + "xpack.idxMgmt.deleteTemplatesModal.successDeleteSingleNotificationMessageText": "已删除模板“{templateName}”", + "xpack.idxMgmt.deleteTemplatesModal.systemTemplateLabel": "系统模板", + "xpack.idxMgmt.detailPanel.manageContextMenuLabel": "管理", + "xpack.idxMgmt.detailPanel.missingIndexMessage": "此索引不存在。它可能已被正在运行的作业或其他系统删除。", + "xpack.idxMgmt.detailPanel.missingIndexTitle": "缺少索引", + "xpack.idxMgmt.detailPanel.tabEditSettingsLabel": "编辑设置", + "xpack.idxMgmt.detailPanel.tabMappingLabel": "映射", + "xpack.idxMgmt.detailPanel.tabSettingsLabel": "设置", + "xpack.idxMgmt.detailPanel.tabStatsLabel": "统计", + "xpack.idxMgmt.detailPanel.tabSummaryLabel": "结论", + "xpack.idxMgmt.editIndexSettingsAction.successfullySavedSettingsForIndicesMessage": "已成功保存 {indexName} 的设置", + "xpack.idxMgmt.editSettingsJSON.saveJSONButtonLabel": "保存", + "xpack.idxMgmt.editSettingsJSON.saveJSONDescription": "编辑并保存您的 JSON", + "xpack.idxMgmt.editSettingsJSON.settingsReferenceLinkText": "设置参考", + "xpack.idxMgmt.editTemplate.editTemplatePageTitle": "编辑模板“{name}”", + "xpack.idxMgmt.flushIndicesAction.successfullyFlushedIndicesMessage": "已成功清空:[{indexNames}]", + "xpack.idxMgmt.forceMergeIndicesAction.successfullyForceMergedIndicesMessage": "已成功强制合并:[{indexNames}]", + "xpack.idxMgmt.freezeIndicesAction.successfullyFrozeIndicesMessage": "成功冻结:[{indexNames}]", + "xpack.idxMgmt.frozenBadgeLabel": "已冻结", + "xpack.idxMgmt.home.appTitle": "索引管理", + "xpack.idxMgmt.home.idxMgmtDescription": "单个或批量更新您的 Elasticsearch 索引。", + "xpack.idxMgmt.home.idxMgmtDocsLinkText": "索引管理文档", + "xpack.idxMgmt.home.indexTemplatesDescription": "使用模板可将设置、映射和别名自动应用到索引。", + "xpack.idxMgmt.home.indexTemplatesTabTitle": "索引模板", + "xpack.idxMgmt.home.indicesTabTitle": "索引", + "xpack.idxMgmt.indexActionsMenu.clearIndexCacheLabel": "清除 {selectedIndexCount, plural, one { 个索引} other { 个索引} } 缓存", + "xpack.idxMgmt.indexActionsMenu.closeIndex.checkboxLabel": "我了解关闭系统索引的后果", + "xpack.idxMgmt.indexActionsMenu.closeIndex.closeDescription": "您将要关闭{selectedIndexCount, plural, one {以下索引} other {以下索引} }:", + "xpack.idxMgmt.indexActionsMenu.closeIndex.confirmModal.confirmButtonText": "关闭 {selectedIndexCount, plural, one { 个索引} other { 个索引} }", + "xpack.idxMgmt.indexActionsMenu.closeIndex.confirmModal.modalTitle": "关闭 {selectedIndexCount, plural, one { 个索引} other {# 个索引} }", + "xpack.idxMgmt.indexActionsMenu.closeIndex.proceedWithCautionCallOutDescription": "系统索引对内部操作至关重要。您可以使用 Open Index API 重新打开此索引。", + "xpack.idxMgmt.indexActionsMenu.closeIndex.proceedWithCautionCallOutTitle": "关闭系统索引会使 Kibana 出现故障", + "xpack.idxMgmt.indexActionsMenu.closeIndex.systemIndexLabel": "系统索引", + "xpack.idxMgmt.indexActionsMenu.closeIndexLabel": "关闭 {selectedIndexCount, plural, one { 个索引} other { 个索引} }", + "xpack.idxMgmt.indexActionsMenu.deleteIndex.checkboxLabel": "我了解删除系统索引的后果", + "xpack.idxMgmt.indexActionsMenu.deleteIndex.confirmModal.cancelButtonText": "取消", + "xpack.idxMgmt.indexActionsMenu.deleteIndex.confirmModal.confirmButtonText": "删除 {selectedIndexCount, plural, one { 个索引} other { 个索引} }", + "xpack.idxMgmt.indexActionsMenu.deleteIndex.confirmModal.modalTitle": "确认删除 {selectedIndexCount, plural, one { 个索引} other { 个索引} }", + "xpack.idxMgmt.indexActionsMenu.deleteIndex.deleteDescription": "您将要删除{selectedIndexCount, plural, one {以下索引} other {以下索引} }:", + "xpack.idxMgmt.indexActionsMenu.deleteIndex.deleteWarningDescription": "此操作无法撤消。确保您有适当的备份。", + "xpack.idxMgmt.indexActionsMenu.deleteIndex.proceedWithCautionCallOutDescription": "系统索引对内部操作至关重要。如果删除系统索引,将无法恢复。确保您有适当的备份。", + "xpack.idxMgmt.indexActionsMenu.deleteIndex.proceedWithCautionCallOutTitle": "谨慎操作!", + "xpack.idxMgmt.indexActionsMenu.deleteIndex.systemIndexLabel": "系统索引", + "xpack.idxMgmt.indexActionsMenu.deleteIndexLabel": "删除 {selectedIndexCount, plural, one { 个索引} other { 个索引} }", + "xpack.idxMgmt.indexActionsMenu.editIndexSettingsLabel": "编辑 {selectedIndexCount, plural, one { 个索引} other { 个索引} }设置", + "xpack.idxMgmt.indexActionsMenu.flushIndexLabel": "清空 {selectedIndexCount, plural, one { 个索引} other { 个索引} }", + "xpack.idxMgmt.indexActionsMenu.forceMerge.confirmModal.cancelButtonText": "取消", + "xpack.idxMgmt.indexActionsMenu.forceMerge.confirmModal.confirmButtonText": "强制合并", + "xpack.idxMgmt.indexActionsMenu.forceMerge.confirmModal.modalTitle": "强制合并", + "xpack.idxMgmt.indexActionsMenu.forceMerge.forceMergeDescription": "您将要强制合并{selectedIndexCount, plural, one {以下索引} other {以下索引} }:", + "xpack.idxMgmt.indexActionsMenu.forceMerge.forceMergeSegmentsHelpText": "合并索引中的段,直到段数减至此数目或更小数目。默认值为 1。", + "xpack.idxMgmt.indexActionsMenu.forceMerge.forceMergeWarningDescription": " 强制合并大型索引或非只读索引可能会使未正确运行(根据非只读索引运行)或在高峰时段运行的集群出现性能和稳定性问题。", + "xpack.idxMgmt.indexActionsMenu.forceMerge.maximumNumberOfSegmentsFormRowLabel": "每分片最大段数", + "xpack.idxMgmt.indexActionsMenu.forceMerge.proceedWithCautionCallOutTitle": "谨慎操作!", + "xpack.idxMgmt.indexActionsMenu.forceMergeIndexLabel": "强制合并 {selectedIndexCount, plural, one { 个索引} other { 个索引} }", + "xpack.idxMgmt.indexActionsMenu.freezeEntity.confirmModal.cancelButtonText": "取消", + "xpack.idxMgmt.indexActionsMenu.freezeEntity.freezeDescription": "您将要冻结{count, plural, one {以下索引} other {以下索引}}:", + "xpack.idxMgmt.indexActionsMenu.freezeEntity.freezeEntityWarningDescription": " 冻结的索引在集群上有很少的开销,已被阻止进行写操作。您可以搜索冻结的索引,但查询应会较慢。", + "xpack.idxMgmt.indexActionsMenu.freezeEntity.proceedWithCautionCallOutTitle": "谨慎操作", + "xpack.idxMgmt.indexActionsMenu.freezeIndexLabel": "冻结 {selectedIndexCount, plural, one { 个索引} other {} }", + "xpack.idxMgmt.indexActionsMenu.manageButtonAriaLabel": "{selectedIndexCount, plural, one { 个索引} other { 个索引} }选项", + "xpack.idxMgmt.indexActionsMenu.manageButtonLabel": "管理 {selectedIndexCount, plural, one { 个索引} other { 个索引}}", + "xpack.idxMgmt.indexActionsMenu.openIndexLabel": "打开 {selectedIndexCount, plural, one { 个索引} other { 个索引} }", + "xpack.idxMgmt.indexActionsMenu.panelTitle": "{selectedIndexCount, plural, one { 个索引} other { 个索引} }选项", + "xpack.idxMgmt.indexActionsMenu.refreshIndexLabel": "刷新 {selectedIndexCount, plural, one {个索引} other {个索引} }", + "xpack.idxMgmt.indexActionsMenu.segmentsNumberErrorMessage": "段数必须大于零。", + "xpack.idxMgmt.indexActionsMenu.showIndexMappingLabel": "显示 {selectedIndexCount, plural, one { 个索引} other { 个索引} }映射", + "xpack.idxMgmt.indexActionsMenu.showIndexSettingsLabel": "显示 {selectedIndexCount, plural, one { 个索引} other { 个索引} }设置", + "xpack.idxMgmt.indexActionsMenu.showIndexStatsLabel": "显示 {selectedIndexCount, plural, one { 个索引} other { 个索引} }统计信息", + "xpack.idxMgmt.indexActionsMenu.unfreezeIndexLabel": "取消冻结 {selectedIndexCount, plural, one { 个索引} other { 个索引} }", + "xpack.idxMgmt.indexStatusLabels.clearingCacheStatusLabel": "正在清除缓存......", + "xpack.idxMgmt.indexStatusLabels.closedStatusLabel": "已关闭", + "xpack.idxMgmt.indexStatusLabels.closingStatusLabel": "正在关闭...", + "xpack.idxMgmt.indexStatusLabels.flushingStatusLabel": "正在清空...", + "xpack.idxMgmt.indexStatusLabels.forcingMergeStatusLabel": "正在强制合并...", + "xpack.idxMgmt.indexStatusLabels.mergingStatusLabel": "正在合并...", + "xpack.idxMgmt.indexStatusLabels.openingStatusLabel": "正在打开...", + "xpack.idxMgmt.indexStatusLabels.refreshingStatusLabel": "正在刷新...", + "xpack.idxMgmt.indexTable.captionText": "下面是包含 {count, plural, one {# 行} other {# 行}}(共 {total} 行)的索引表。", + "xpack.idxMgmt.indexTable.headers.documentsHeader": "文档计数", + "xpack.idxMgmt.indexTable.headers.healthHeader": "运行状况", + "xpack.idxMgmt.indexTable.headers.nameHeader": "名称", + "xpack.idxMgmt.indexTable.headers.primaryHeader": "主分片", + "xpack.idxMgmt.indexTable.headers.replicaHeader": "副本分片", + "xpack.idxMgmt.indexTable.headers.statusHeader": "状态", + "xpack.idxMgmt.indexTable.headers.storageSizeHeader": "存储大小", + "xpack.idxMgmt.indexTable.invalidSearchErrorMessage": "无效搜索:{errorMessage}", + "xpack.idxMgmt.indexTable.reloadIndicesButton": "重载索引", + "xpack.idxMgmt.indexTable.selectAllIndicesAriaLabel": "选择所有行", + "xpack.idxMgmt.indexTable.selectIndexAriaLabel": "选择此行", + "xpack.idxMgmt.indexTable.serverErrorTitle": "加载索引时出错", + "xpack.idxMgmt.indexTable.systemIndicesSearchIndicesAriaLabel": "搜索索引", + "xpack.idxMgmt.indexTable.systemIndicesSearchInputPlaceholder": "搜索", + "xpack.idxMgmt.indexTable.systemIndicesSwitchLabel": "包括系统索引", + "xpack.idxMgmt.indexTemplatesList.emptyPrompt.noIndexTemplatesTitle": "您尚未有任何模板", + "xpack.idxMgmt.indexTemplatesList.loadingIndexTemplatesDescription": "正在加载模板……", + "xpack.idxMgmt.indexTemplatesList.loadingIndexTemplatesErrorMessage": "加载模板时出错", + "xpack.idxMgmt.indexTemplatesTable.systemIndexTemplatesSwitchLabel": "包括系统模板", + "xpack.idxMgmt.mappingsEditor.formatError": "JSON 格式错误", + "xpack.idxMgmt.mappingsEditor.mappingsEditorAriaLabel": "索引映射编辑器", + "xpack.idxMgmt.noMatch.noIndicesDescription": "没有要显示的索引", + "xpack.idxMgmt.openIndicesAction.successfullyOpenedIndicesMessage": "已成功打开:[{indexNames}]", + "xpack.idxMgmt.pageErrorForbidden.title": "您无权使用“索引管理”", + "xpack.idxMgmt.refreshIndicesAction.successfullyRefreshedIndicesMessage": "已成功刷新:[{indexNames}]", + "xpack.idxMgmt.reloadIndicesAction.indicesPageRefreshFailureMessage": "无法刷新当前页面的索引。", + "xpack.idxMgmt.summary.headers.aliases": "别名", + "xpack.idxMgmt.summary.headers.deletedDocumentsHeader": "文档已删除", + "xpack.idxMgmt.summary.headers.documentsHeader": "文档计数", + "xpack.idxMgmt.summary.headers.healthHeader": "运行状况", + "xpack.idxMgmt.summary.headers.primaryHeader": "主分片", + "xpack.idxMgmt.summary.headers.primaryStorageSizeHeader": "主存储大小", + "xpack.idxMgmt.summary.headers.replicaHeader": "副本分片", + "xpack.idxMgmt.summary.headers.statusHeader": "状态", + "xpack.idxMgmt.summary.headers.storageSizeHeader": "存储大小", + "xpack.idxMgmt.summary.summaryTitle": "常规", + "xpack.idxMgmt.templateCreate.loadingTemplateToCloneDescription": "正在加载要克隆的模板……", + "xpack.idxMgmt.templateCreate.loadingTemplateToCloneErrorMessage": "加载要克隆的模板时出错", + "xpack.idxMgmt.templateDetails.aliasesTab.noAliasesTitle": "未定义任何别名。", + "xpack.idxMgmt.templateDetails.aliasesTabTitle": "别名", + "xpack.idxMgmt.templateDetails.cloneButtonLabel": "克隆", + "xpack.idxMgmt.templateDetails.closeButtonLabel": "关闭", + "xpack.idxMgmt.templateDetails.deleteButtonLabel": "删除", + "xpack.idxMgmt.templateDetails.editButtonLabel": "编辑", + "xpack.idxMgmt.templateDetails.loadingIndexTemplateDescription": "正在加载模板……", + "xpack.idxMgmt.templateDetails.loadingIndexTemplateErrorMessage": "加载模板时出错", + "xpack.idxMgmt.templateDetails.manageButtonLabel": "管理", + "xpack.idxMgmt.templateDetails.manageContextMenuPanelTitle": "模板选项", + "xpack.idxMgmt.templateDetails.managedTemplateInfoDescription": "托管模板对内部操作至关重要。", + "xpack.idxMgmt.templateDetails.managedTemplateInfoTitle": "不允许编辑托管模板", + "xpack.idxMgmt.templateDetails.mappingsTab.noMappingsTitle": "未定义任何映射。", + "xpack.idxMgmt.templateDetails.mappingsTabTitle": "映射", + "xpack.idxMgmt.templateDetails.settingsTab.noSettingsTitle": "未定义任何设置。", + "xpack.idxMgmt.templateDetails.settingsTabTitle": "设置", + "xpack.idxMgmt.templateDetails.summaryTab.ilmPolicyDescriptionListTitle": "ILM 策略", + "xpack.idxMgmt.templateDetails.summaryTab.indexPatternsDescriptionListTitle": "索引{numIndexPatterns, plural, one {模式} other {模式}}", + "xpack.idxMgmt.templateDetails.summaryTab.noneDescriptionText": "无", + "xpack.idxMgmt.templateDetails.summaryTab.orderDescriptionListTitle": "顺序", + "xpack.idxMgmt.templateDetails.summaryTab.versionDescriptionListTitle": "版本", + "xpack.idxMgmt.templateDetails.summaryTabTitle": "总结", + "xpack.idxMgmt.templateEdit.loadingIndexTemplateDescription": "正在加载模板……", + "xpack.idxMgmt.templateEdit.loadingIndexTemplateErrorMessage": "加载模板时出错", + "xpack.idxMgmt.templateEdit.managedTemplateWarningDescription": "托管模板对内部操作至关重要。", + "xpack.idxMgmt.templateEdit.managedTemplateWarningTitle": "不允许编辑托管模板", + "xpack.idxMgmt.templateEdit.systemTemplateWarningDescription": "系统模板对内部操作至关重要。", + "xpack.idxMgmt.templateEdit.systemTemplateWarningTitle": "编辑系统模板会使 Kibana 无法运行", + "xpack.idxMgmt.templateForm.backButtonLabel": "上一步", + "xpack.idxMgmt.templateForm.createButtonLabel": "创建模板", + "xpack.idxMgmt.templateForm.nextButtonLabel": "下一步", + "xpack.idxMgmt.templateForm.saveButtonLabel": "保存模板", + "xpack.idxMgmt.templateForm.saveTemplateError": "无法创建模板", + "xpack.idxMgmt.templateForm.savingButtonLabel": "正在保存……", + "xpack.idxMgmt.templateForm.stepAliases.aliasesDescription": "设置要与索引关联的别名。", + "xpack.idxMgmt.templateForm.stepAliases.aliasesEditorHelpText": "使用 JSON 格式:{code}", + "xpack.idxMgmt.templateForm.stepAliases.docsButtonLabel": "索引模板文档", + "xpack.idxMgmt.templateForm.stepAliases.fieldAliasesAriaLabel": "别名代码编辑器", + "xpack.idxMgmt.templateForm.stepAliases.fieldAliasesLabel": "别名", + "xpack.idxMgmt.templateForm.stepAliases.stepTitle": "别名(可选)", + "xpack.idxMgmt.templateForm.stepLogistics.docsButtonLabel": "索引模板文档", + "xpack.idxMgmt.templateForm.stepLogistics.fieldIndexPatternsHelpText": "不允许使用空格和字符 {invalidCharactersList}。", + "xpack.idxMgmt.templateForm.stepLogistics.fieldIndexPatternsLabel": "索引模式", + "xpack.idxMgmt.templateForm.stepLogistics.fieldNameLabel": "名称", + "xpack.idxMgmt.templateForm.stepLogistics.fieldOrderLabel": "顺序(可选)", + "xpack.idxMgmt.templateForm.stepLogistics.fieldVersionLabel": "版本(可选)", + "xpack.idxMgmt.templateForm.stepLogistics.indexPatternsDescription": "要应用于模板的索引模式。", + "xpack.idxMgmt.templateForm.stepLogistics.indexPatternsTitle": "索引模式", + "xpack.idxMgmt.templateForm.stepLogistics.nameDescription": "此模板的唯一标识符。", + "xpack.idxMgmt.templateForm.stepLogistics.nameTitle": "名称", + "xpack.idxMgmt.templateForm.stepLogistics.orderDescription": "多个模板匹配一个索引时的合并顺序。", + "xpack.idxMgmt.templateForm.stepLogistics.orderTitle": "合并顺序", + "xpack.idxMgmt.templateForm.stepLogistics.stepTitle": "运筹", + "xpack.idxMgmt.templateForm.stepLogistics.versionDescription": "在外部管理系统中标识该模板的编号。", + "xpack.idxMgmt.templateForm.stepLogistics.versionTitle": "版本", + "xpack.idxMgmt.templateForm.stepMappings.docsButtonLabel": "映射文档", + "xpack.idxMgmt.templateForm.stepMappings.fieldMappingsAriaLabel": "映射编辑器", + "xpack.idxMgmt.templateForm.stepMappings.fieldMappingsLabel": "映射", + "xpack.idxMgmt.templateForm.stepMappings.mappingsDescription": "定义如何存储和索引文档。", + "xpack.idxMgmt.templateForm.stepMappings.mappingsEditorHelpText": "使用 JSON 格式:{code}", + "xpack.idxMgmt.templateForm.stepMappings.stepTitle": "映射(可选)", + "xpack.idxMgmt.templateForm.stepReview.requestTab.descriptionText": "此请求将创建以下索引模板。", + "xpack.idxMgmt.templateForm.stepReview.requestTabTitle": "请求", + "xpack.idxMgmt.templateForm.stepReview.stepTitle": "查看 “{templateName}” 的详情", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.aliasesLabel": "别名", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.indexPatternsLabel": "索引{numIndexPatterns, plural, one {模式} other {模式}}", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.indexPatternsWarningDescription": "您创建的所有新索引将使用此模板。", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.indexPatternsWarningLinkText": "编辑索引模式。", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.indexPatternsWarningTitle": "此模板将通配符 (*) 用作索引模式。", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.mappingLabel": "映射", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.noDescriptionText": "否", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.noneDescriptionText": "无", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.orderLabel": "顺序", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.settingsLabel": "索引设置", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.versionLabel": "版本", + "xpack.idxMgmt.templateForm.stepReview.summaryTab.yesDescriptionText": "是", + "xpack.idxMgmt.templateForm.stepReview.summaryTabTitle": "总结", + "xpack.idxMgmt.templateForm.steps.aliasesStepName": "别名", + "xpack.idxMgmt.templateForm.steps.logisticsStepName": "运筹", + "xpack.idxMgmt.templateForm.steps.mappingsStepName": "映射", + "xpack.idxMgmt.templateForm.steps.settingsStepName": "索引设置", + "xpack.idxMgmt.templateForm.steps.summaryStepName": "复查模板", + "xpack.idxMgmt.templateForm.stepSettings.docsButtonLabel": "索引设置文档", + "xpack.idxMgmt.templateForm.stepSettings.fieldIndexSettingsAriaLabel": "索引设置编辑器", + "xpack.idxMgmt.templateForm.stepSettings.fieldIndexSettingsLabel": "索引设置", + "xpack.idxMgmt.templateForm.stepSettings.settingsDescription": "定义索引的行为。", + "xpack.idxMgmt.templateForm.stepSettings.settingsEditorHelpText": "使用 JSON 格式:{code}", + "xpack.idxMgmt.templateForm.stepSettings.stepTitle": "索引设置(可选)", + "xpack.idxMgmt.templateList.table.actionCloneDescription": "克隆此模板", + "xpack.idxMgmt.templateList.table.actionCloneTitle": "克隆", + "xpack.idxMgmt.templateList.table.actionColumnTitle": "操作", + "xpack.idxMgmt.templateList.table.actionDeleteDecription": "删除此模板", + "xpack.idxMgmt.templateList.table.actionDeleteText": "删除", + "xpack.idxMgmt.templateList.table.actionEditDecription": "编辑此模板", + "xpack.idxMgmt.templateList.table.actionEditText": "编辑", + "xpack.idxMgmt.templateList.table.aliasesColumnTitle": "别名", + "xpack.idxMgmt.templateList.table.createTemplatesButtonLabel": "创建模板", + "xpack.idxMgmt.templateList.table.deleteManagedTemplateTooltip": "您无法删除托管模板。", + "xpack.idxMgmt.templateList.table.deleteTemplatesButtonLabel": "删除{count, plural, one {模板} other {模板} }", + "xpack.idxMgmt.templateList.table.ilmPolicyColumnDescription": "“{policyName}”索引生命周期策略", + "xpack.idxMgmt.templateList.table.ilmPolicyColumnTitle": "ILM 策略", + "xpack.idxMgmt.templateList.table.indexPatternsColumnTitle": "索引模式", + "xpack.idxMgmt.templateList.table.mappingsColumnTitle": "映射", + "xpack.idxMgmt.templateList.table.nameColumnTitle": "名称", + "xpack.idxMgmt.templateList.table.noIndexTemplatesMessage": "未找到任何模板", + "xpack.idxMgmt.templateList.table.orderColumnTitle": "顺序", + "xpack.idxMgmt.templateList.table.reloadTemplatesButtonLabel": "重新加载", + "xpack.idxMgmt.templateList.table.settingsColumnTitle": "设置", + "xpack.idxMgmt.templateValidation.indexPatternsRequiredError": "至少需要一个索引模式。", + "xpack.idxMgmt.templateValidation.templateNameInvalidaCharacterError": "模板名称不得包含字符“{invalidChar}”", + "xpack.idxMgmt.templateValidation.templateNamePeriodError": "模板名称不得以句点开头。", + "xpack.idxMgmt.templateValidation.templateNameRequiredError": "模板名称必填。", + "xpack.idxMgmt.templateValidation.templateNameSpacesError": "模板名称不允许包含空格。", + "xpack.idxMgmt.templateValidation.templateNameUnderscoreError": "模板名称不得以下划线开头。", + "xpack.idxMgmt.unfreezeIndicesAction.successfullyUnfrozeIndicesMessage": "成功取消冻结:[{indexNames}]", + "xpack.idxMgmt.updateIndexSettingsAction.settingsSuccessUpdateMessage": "已成功更新索引 {indexName} 的设置", + "xpack.idxMgmt.validators.string.invalidJSONError": "JSON 格式无效。", + "xpack.indexLifecycleMgmt.activePhaseMessage": "有效", + "xpack.indexLifecycleMgmt.addLifecyclePolicyActionButtonLabel": "添加生命周期策略", + "xpack.indexLifecycleMgmt.appTitle": "索引生命周期策略", + "xpack.indexLifecycleMgmt.checkLicense.errorExpiredMessage": "您不能使用 {pluginName},因为您的 {licenseType} 许可已过期。", + "xpack.indexLifecycleMgmt.checkLicense.errorUnavailableMessage": "您不能使用 {pluginName},因为许可证信息当前不可用。", + "xpack.indexLifecycleMgmt.checkLicense.errorUnsupportedMessage": "您的 {licenseType} 许可证不支持 {pluginName}。请升级您的许可。", + "xpack.indexLifecycleMgmt.coldPhase.freezeIndexLabel": "冻结索引", + "xpack.indexLifecycleMgmt.coldPhase.numberOfReplicasLabel": "副本分片数目", + "xpack.indexLifecycleMgmt.coldPhase.replicaCountHelpText": "默认情况下,副本分片数目仍一样。", + "xpack.indexLifecycleMgmt.confirmDelete.cancelButton": "取消", + "xpack.indexLifecycleMgmt.confirmDelete.deleteButton": "删除", + "xpack.indexLifecycleMgmt.confirmDelete.errorMessage": "删除策略 {policyName} 时出错", + "xpack.indexLifecycleMgmt.confirmDelete.successMessage": "已删除策略 {policyName}", + "xpack.indexLifecycleMgmt.confirmDelete.title": "删除策略“{name}”", + "xpack.indexLifecycleMgmt.confirmDelete.undoneWarning": "无法恢复删除的策略。", + "xpack.indexLifecycleMgmt.editPolicy.cancelButton": "取消", + "xpack.indexLifecycleMgmt.editPolicy.coldPhase.activateWarmPhaseSwitchLabel": "激活冷阶段", + "xpack.indexLifecycleMgmt.editPolicy.coldPhase.coldPhaseDescriptionText": "您查询自己索引的频率较低,因此您可以在效率较低的硬件上分配分片。因为您的查询较为缓慢,所以您可以减少副本分片数目。", + "xpack.indexLifecycleMgmt.editPolicy.coldPhase.coldPhaseLabel": "冷阶段", + "xpack.indexLifecycleMgmt.editPolicy.coldPhase.freezeIndexExplanationText": "冻结的索引在集群上有很少的开销,已被阻止进行写操作。您可以搜索冻结的索引,但查询应会较慢。", + "xpack.indexLifecycleMgmt.editPolicy.coldPhase.freezeText": "冻结", + "xpack.indexLifecycleMgmt.editPolicy.createdMessage": "创建于", + "xpack.indexLifecycleMgmt.editPolicy.createPolicyMessage": "创建索引生命周期策略", + "xpack.indexLifecycleMgmt.editPolicy.creationDaysOptionLabel": "天(自索引创建)", + "xpack.indexLifecycleMgmt.editPolicy.creationHoursOptionLabel": "小时(自索引创建)", + "xpack.indexLifecycleMgmt.editPolicy.deletePhase.activateWarmPhaseSwitchLabel": "激活删除阶段", + "xpack.indexLifecycleMgmt.editPolicy.deletePhase.deletePhaseDescriptionText": "您不再需要自己的索引。 您可以定义安全删除它的时间。", + "xpack.indexLifecycleMgmt.editPolicy.deletePhase.deletePhaseLabel": "删除阶段", + "xpack.indexLifecycleMgmt.editPolicy.differentPolicyNameRequiredError": "策略名称必须不同。", + "xpack.indexLifecycleMgmt.editPolicy.editingExistingPolicyExplanationMessage": "所做的任何更改将影响附加到此策略的索引。或者,您可以在新策略中保存这些更改。", + "xpack.indexLifecycleMgmt.editPolicy.editingExistingPolicyMessage": "您正在编辑现有策略", + "xpack.indexLifecycleMgmt.editPolicy.editPolicyMessage": "编辑索引生命周期策略 {originalPolicyName}", + "xpack.indexLifecycleMgmt.editPolicy.formErrorsMessage": "请修复此页面上的错误。", + "xpack.indexLifecycleMgmt.editPolicy.hidePolicyJsonButto": "隐藏请求", + "xpack.indexLifecycleMgmt.editPolicy.hotPhase.hotPhaseDescriptionMessage": "此阶段为必需。您正频繁地查询并写到您的索引。 为了获取更快的更新,在索引变得过大或过旧时,您可以滚动更新索引。", + "xpack.indexLifecycleMgmt.editPolicy.hotPhase.hotPhaseLabel": "热阶段", + "xpack.indexLifecycleMgmt.editPolicy.hotPhase.learnAboutRolloverLinkText": "了解滚动更新", + "xpack.indexLifecycleMgmt.editPolicy.hotPhase.rolloverDescriptionMessage": "滚动更新创建的新索引将添加到索引别名,并被指定为写索引。", + "xpack.indexLifecycleMgmt.editPolicy.indexPriorityText": "索引优先级", + "xpack.indexLifecycleMgmt.editPolicy.learnAboutIndexLifecycleManagementLinkText": "了解索引生命周期。", + "xpack.indexLifecycleMgmt.editPolicy.learnAboutIndexTemplatesLink": "了解索引模板", + "xpack.indexLifecycleMgmt.editPolicy.learnAboutShardAllocationLink": "了解分片分配", + "xpack.indexLifecycleMgmt.editPolicy.learnAboutTimingText": "了解计时", + "xpack.indexLifecycleMgmt.editPolicy.lifecyclePolicyDescriptionText": "使用索引策略自动化索引生命周期的四个阶段,从频繁地写入到索引到删除索引。", + "xpack.indexLifecycleMgmt.editPolicy.loadPolicyErrorMessage": "加载策略时出错", + "xpack.indexLifecycleMgmt.editPolicy.maximumAgeMissingError": "最大存在时间必填。", + "xpack.indexLifecycleMgmt.editPolicy.maximumDocumentsMissingError": "最大文档数必填。", + "xpack.indexLifecycleMgmt.editPolicy.maximumIndexSizeMissingError": "最大索引大小必填。", + "xpack.indexLifecycleMgmt.editPolicy.nameLabel": "名称", + "xpack.indexLifecycleMgmt.editPolicy.nodeAllocationLabel": "选择节点属性来控制分片分配", + "xpack.indexLifecycleMgmt.editPolicy.nodeAttributesMissingDescription": "没有节点属性,将无法控制分片分配。", + "xpack.indexLifecycleMgmt.editPolicy.nodeAttributesMissingLabel": "elasticsearch.yml 中未配置任何节点属性", + "xpack.indexLifecycleMgmt.editPolicy.nodeDetailErrorMessage": "加载节点属性详细信息时出错", + "xpack.indexLifecycleMgmt.editPolicy.nodeInfoErrorMessage": "加载节点属性信息时出错", + "xpack.indexLifecycleMgmt.editPolicy.numberRequiredError": "数字必填。", + "xpack.indexLifecycleMgmt.editPolicy.phaseCold.minimumAgeLabel": "冷阶段计时", + "xpack.indexLifecycleMgmt.editPolicy.phaseCold.minimumAgeUnitsAriaLabel": "冷阶段计时单位", + "xpack.indexLifecycleMgmt.editPolicy.phaseDelete.minimumAgeLabel": "删除阶段计时", + "xpack.indexLifecycleMgmt.editPolicy.phaseDelete.minimumAgeUnitsAriaLabel": "删除阶段计时单位", + "xpack.indexLifecycleMgmt.editPolicy.phaseErrorMessage": "修复错误", + "xpack.indexLifecycleMgmt.editPolicy.phaseWarm.minimumAgeLabel": "温阶段计时", + "xpack.indexLifecycleMgmt.editPolicy.phaseWarm.minimumAgeUnitsAriaLabel": "温阶段计时单位", + "xpack.indexLifecycleMgmt.editPolicy.policyNameAlreadyUsedError": "该策略名称已被使用。", + "xpack.indexLifecycleMgmt.editPolicy.policyNameContainsCommaError": "策略名称不能包含逗号。", + "xpack.indexLifecycleMgmt.editPolicy.policyNameContainsSpaceError": "策略名称不能包含空格。", + "xpack.indexLifecycleMgmt.editPolicy.policyNameLabel": "策略名称", + "xpack.indexLifecycleMgmt.editPolicy.policyNameRequiredError": "策略名称必填。", + "xpack.indexLifecycleMgmt.editPolicy.policyNameStartsWithUnderscoreError": "策略名称不能以下划线开头。", + "xpack.indexLifecycleMgmt.editPolicy.policyNameTooLongError": "策略名称的长度不能大于 255 字节。", + "xpack.indexLifecycleMgmt.editPolicy.positiveNumberAboveZeroRequiredError": "仅允许使用 0 以上的数字。", + "xpack.indexLifecycleMgmt.editPolicy.positiveNumberRequiredError": "仅允许使用正数。", + "xpack.indexLifecycleMgmt.editPolicy.rolloverDaysOptionLabel": "天(自滚动更新)", + "xpack.indexLifecycleMgmt.editPolicy.rolloverHoursOptionLabel": "小时(自滚动更新)", + "xpack.indexLifecycleMgmt.editPolicy.saveAsNewButton": "另存为新策略", + "xpack.indexLifecycleMgmt.editPolicy.saveAsNewPolicyMessage": "另存为新策略", + "xpack.indexLifecycleMgmt.editPolicy.saveButton": "保存策略", + "xpack.indexLifecycleMgmt.editPolicy.saveErrorMessage": "保存生命周期策略 {lifecycleName} 时出错", + "xpack.indexLifecycleMgmt.editPolicy.showPolicyJsonButto": "显示请求", + "xpack.indexLifecycleMgmt.editPolicy.successfulSaveMessage": "{verb}生命周期策略“{lifecycleName}”", + "xpack.indexLifecycleMgmt.editPolicy.updatedMessage": "已更新", + "xpack.indexLifecycleMgmt.editPolicy.validPolicyNameMessage": "策略名称不能以下划线开头,且不能包含问号或空格。", + "xpack.indexLifecycleMgmt.editPolicy.viewNodeDetailsButton": "查看附加到此配置的节点列表", + "xpack.indexLifecycleMgmt.editPolicy.warmPhase.activateWarmPhaseSwitchLabel": "激活温阶段", + "xpack.indexLifecycleMgmt.editPolicy.warmPhase.forceMergeDataExplanationText": "通过合并较小文件并清除已删除文件,来减少分片中的段数目。", + "xpack.indexLifecycleMgmt.editPolicy.warmPhase.forceMergeDataText": "强制合并", + "xpack.indexLifecycleMgmt.editPolicy.warmPhase.indexPriorityExplanationText": "设置在节点重新启动后恢复索引的优先级。较高优先级的索引会在较低优先级的索引之前恢复。", + "xpack.indexLifecycleMgmt.editPolicy.warmPhase.shrinkIndexExplanationText": "将索引缩小成具有较少主分片的新索引。", + "xpack.indexLifecycleMgmt.editPolicy.warmPhase.shrinkText": "缩小", + "xpack.indexLifecycleMgmt.editPolicy.warmPhase.warmPhaseDescriptionMessage": "您仍在查询自己的索引,但其为只读。您可以将分片分配给效率较低的硬件。为了获取更快的搜索,您可以减少分片数目并强制合并段。", + "xpack.indexLifecycleMgmt.editPolicy.warmPhase.warmPhaseLabel": "温阶段", + "xpack.indexLifecycleMgmt.hotPhase.daysLabel": "天", + "xpack.indexLifecycleMgmt.hotPhase.enableRolloverLabel": "启用滚动更新", + "xpack.indexLifecycleMgmt.hotPhase.gigabytesLabel": "千兆字节", + "xpack.indexLifecycleMgmt.hotPhase.hoursLabel": "小时", + "xpack.indexLifecycleMgmt.hotPhase.maximumAgeLabel": "最大存在时间", + "xpack.indexLifecycleMgmt.hotPhase.maximumAgeUnitsAriaLabel": "最大存在时间单位", + "xpack.indexLifecycleMgmt.hotPhase.maximumDocumentsLabel": "最大文档数", + "xpack.indexLifecycleMgmt.hotPhase.maximumIndexSizeLabel": "最大索引大小", + "xpack.indexLifecycleMgmt.hotPhase.maximumIndexSizeUnitsAriaLabel": "最大索引大小单位", + "xpack.indexLifecycleMgmt.hotPhase.megabytesLabel": "兆字节", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.actionStatusTitle": "操作状态", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.headers.currentActionHeader": "当前操作", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.headers.currentActionTimeHeader": "当前操作名称", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.headers.currentPhaseHeader": "当前阶段", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.headers.failedStepHeader": "失败的步骤", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.headers.lifecyclePolicyHeader": "生命周期策略", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.phaseDefinitionTitle": "阶段定义", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.showPhaseDefinitionButton": "显示阶段定义", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.showPhaseDefinitionDescriptionTitle": "阶段定义", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.stackTraceButton": "堆栈追溯", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.summaryErrorMessage": "索引生命周期错误", + "xpack.indexLifecycleMgmt.indexLifecycleMgmtSummary.summaryTitle": "索引生命周期管理", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.addPolicyButtonText": "添加策略", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.addPolicyToIndexError": "向索引添加策略时出错", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.addPolicyToIndexSuccess": "已将策略 “{policyName}” 添加到索引 “{indexName}”。", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.cancelButtonText": "取消", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.chooseAliasLabel": "索引滚动更新别名", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.chooseAliasMessage": "选择别名", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.choosePolicyLabel": "生命周期策略", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.choosePolicyMessage": "选择生命周期策略", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.defineLifecyclePolicyLinkText": "定义生命周期策略", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.indexHasNoAliasesWarningMessage": "已为滚动更新配置策略 “{policyName}”,但索引 “{indexName}” 没有滚动更新所需的别名。", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.indexHasNoAliasesWarningTitle": "索引没有别名", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.loadPolicyError": "加载策略列表时出错", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.modalTitle": "将生命周期策略添加到“{indexName}”", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.noPoliciesWarningTitle": "未定义任何索引生命周期策略", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyConfirmModal.noPolicySelectedErrorMessage": "必须选择策略。", + "xpack.indexLifecycleMgmt.indexManagementTable.addLifecyclePolicyToTemplateConfirmModal.indexHasNoAliasesWarningMessage": "策略 “{existingPolicyName}” 已附加到此索引模板。添加此策略将覆盖该配置。", + "xpack.indexLifecycleMgmt.indexManagementTable.removeLifecyclePolicyConfirmModal.cancelButtonText": "取消", + "xpack.indexLifecycleMgmt.indexManagementTable.removeLifecyclePolicyConfirmModal.removePolicyButtonText": "删除策略", + "xpack.indexLifecycleMgmt.indexManagementTable.removeLifecyclePolicyConfirmModal.removePolicyToIndexError": "删除策略时出错", + "xpack.indexLifecycleMgmt.indexMgmtBanner.errorMessage": "{ numIndicesWithLifecycleErrors, number}\n {numIndicesWithLifecycleErrors, plural, one { 个索引已} other { 个索引已} }\n 生命周期错误", + "xpack.indexLifecycleMgmt.indexMgmtBanner.filterLabel": "显示错误", + "xpack.indexLifecycleMgmt.indexMgmtFilter.lifecycleStatusLabel": "生命周期状态", + "xpack.indexLifecycleMgmt.indexMgmtFilter.managedLabel": "受管", + "xpack.indexLifecycleMgmt.indexMgmtFilter.unmanagedLabel": "未受管", + "xpack.indexLifecycleMgmt.indexPriorityLabel": "索引优先级", + "xpack.indexLifecycleMgmt.learnMore": "了解详情", + "xpack.indexLifecycleMgmt.nodeAttrDetails.hostField": "主机", + "xpack.indexLifecycleMgmt.nodeAttrDetails.idField": "ID", + "xpack.indexLifecycleMgmt.nodeAttrDetails.nameField": "名称", + "xpack.indexLifecycleMgmt.nodeAttrDetails.title": "包含属性 {selectedNodeAttrs} 的节点", + "xpack.indexLifecycleMgmt.noMatch.noPolicicesDescription": "没有要显示的策略", + "xpack.indexLifecycleMgmt.optionalMessage": " (可选)", + "xpack.indexLifecycleMgmt.policyJsonFlyout.closeButtonLabel": "关闭", + "xpack.indexLifecycleMgmt.policyJsonFlyout.descriptionText": "此 Elasticsearch 请求将创建或更新此索引生命周期策略。", + "xpack.indexLifecycleMgmt.policyJsonFlyout.namedTitle": "对“{policyName}”的请求", + "xpack.indexLifecycleMgmt.policyJsonFlyout.unnamedTitle": "请求", + "xpack.indexLifecycleMgmt.policyTable.actionsButtonText": "操作", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.cancelButton": "取消", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.chooseTemplateLabel": "索引模板", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.chooseTemplateMessage": "选择索引模板", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.confirmButton": "添加策略", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.errorMessage": "向索引模板 “{templateName}” 添加策略 “{policyName}” 时出错", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.explanationText": "这会将生命周期策略应用到匹配索引模板的所有索引。", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.noTemplateSelectedErrorMessage": "必须选择索引模板。", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.rolloverAliasLabel": "滚动更新索引的别名", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.successMessage": "已将策略 “{policyName}” 添加到索引模板 “{templateName}”。", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.templateHasPolicyWarningTitle": "模板已有策略", + "xpack.indexLifecycleMgmt.policyTable.addLifecyclePolicyToTemplateConfirmModal.title": "将策略 “{name}” 添加到索引模板", + "xpack.indexLifecycleMgmt.policyTable.addPolicyToTemplateButtonText": "将策略添加到索引模板", + "xpack.indexLifecycleMgmt.policyTable.captionText": "下面是包含 {count, plural, one {# 行} other {# 行}}(共 {total} 行)的索引生命周期策略表。", + "xpack.indexLifecycleMgmt.policyTable.deletedPoliciesText": "已删除 {numSelected} 个{numSelected, plural, one {策略} other {策略}}", + "xpack.indexLifecycleMgmt.policyTable.deletePolicyButtonDisabledTooltip": "您无法删除索引正在使用的策略", + "xpack.indexLifecycleMgmt.policyTable.deletePolicyButtonText": "删除策略", + "xpack.indexLifecycleMgmt.policyTable.emptyPrompt.createButtonLabel": "创建策略", + "xpack.indexLifecycleMgmt.policyTable.emptyPromptDescription": " 索引生命周期策略帮助您管理变旧的索引", + "xpack.indexLifecycleMgmt.policyTable.emptyPromptTitle": "创建您的首个索引生命周期索引", + "xpack.indexLifecycleMgmt.policyTable.headers.linkedIndicesHeader": "已链接索引", + "xpack.indexLifecycleMgmt.policyTable.headers.modifiedDateHeader": "上次修改日期", + "xpack.indexLifecycleMgmt.policyTable.headers.nameHeader": "名称", + "xpack.indexLifecycleMgmt.policyTable.headers.versionHeader": "版本", + "xpack.indexLifecycleMgmt.policyTable.policyActionsMenu.panelTitle": "策略选项", + "xpack.indexLifecycleMgmt.policyTable.sectionDescription": "管理变旧的索引。 附加策略以自动化何时以及如何在索引整个生命周期中变迁索引。", + "xpack.indexLifecycleMgmt.policyTable.sectionHeading": "索引生命周期策略", + "xpack.indexLifecycleMgmt.policyTable.systempoliciesSearchInputAriaLabel": "搜索策略", + "xpack.indexLifecycleMgmt.policyTable.systempoliciesSearchInputPlaceholder": "搜索", + "xpack.indexLifecycleMgmt.policyTable.viewIndicesButtonText": "查看链接到策略的索引", + "xpack.indexLifecycleMgmt.removeIndexLifecycleActionButtonLabel": "删除生命周期策略", + "xpack.indexLifecycleMgmt.retryIndexLifecycleAction.retriedLifecycleMessage": "已为以下索引调用重试生命周期步骤:{indexNames}", + "xpack.indexLifecycleMgmt.retryIndexLifecycleActionButtonLabel": "重试生命周期步骤", + "xpack.indexLifecycleMgmt.warmPhase.forceMergeDataLabel": "强制合并数据", + "xpack.indexLifecycleMgmt.warmPhase.moveToWarmPhaseOnRolloverLabel": "滚动更新时移到温阶段", + "xpack.indexLifecycleMgmt.warmPhase.numberOfPrimaryShardsLabel": "主分片数目", + "xpack.indexLifecycleMgmt.warmPhase.numberOfReplicasLabel": "副本分片数目", + "xpack.indexLifecycleMgmt.warmPhase.numberOfSegmentsLabel": "段数目", + "xpack.indexLifecycleMgmt.warmPhase.replicaCountHelpText": "默认情况下,副本分片数目仍一样。", + "xpack.indexLifecycleMgmt.warmPhase.shrinkIndexLabel": "缩小索引", + "xpack.infra.analysisSetup.actionStepTitle": "创建 ML 作业", + "xpack.infra.analysisSetup.analysisSetupDescription": "使用 Machine Learning 自动检测异常日志速率计数。", + "xpack.infra.analysisSetup.analysisSetupTitle": "启用 Machine Learning 分析", + "xpack.infra.analysisSetup.configurationStepTitle": "配置", + "xpack.infra.analysisSetup.createMlJobButton": "创建 ML 作业", + "xpack.infra.analysisSetup.deleteAnalysisResultsWarning": "这将移除以前检测到的异常。", + "xpack.infra.analysisSetup.endTimeDefaultDescription": "无限期", + "xpack.infra.analysisSetup.endTimeLabel": "结束时间", + "xpack.infra.analysisSetup.indicesSelectionDescription": "默认情况下,Machine Learning 分析为源配置的所有日志索引中的日志消息。可以选择仅分析一部分索引名称。每个选定索引名称必须至少匹配一个具有日志条目的索引。", + "xpack.infra.analysisSetup.indicesSelectionLabel": "索引", + "xpack.infra.analysisSetup.indicesSelectionTitle": "选择索引", + "xpack.infra.analysisSetup.indicesSelectionTooFewSelectedIndicesDescription": "至少选择一个索引名称。", + "xpack.infra.analysisSetup.recreateMlJobButton": "重新创建 ML 作业", + "xpack.infra.analysisSetup.startTimeDefaultDescription": "日志索引的开始时间", + "xpack.infra.analysisSetup.startTimeLabel": "开始时间", + "xpack.infra.analysisSetup.steps.setupProcess.errorCalloutTitle": "发生错误", + "xpack.infra.analysisSetup.steps.setupProcess.failureText": "创建必需的 ML 作业时出现问题。请确保所有选定日志索引存在。", + "xpack.infra.analysisSetup.steps.setupProcess.loadingText": "正在创建 ML 作业......", + "xpack.infra.analysisSetup.steps.setupProcess.successText": "ML 作业已设置成功", + "xpack.infra.analysisSetup.steps.setupProcess.tryAgainButton": "重试", + "xpack.infra.analysisSetup.steps.setupProcess.viewResultsButton": "查看结果", + "xpack.infra.analysisSetup.timeRangeDescription": "默认情况下,Machine Learning 分析日志索引中 4 周前的日志消息,并无限持续下去。您可以指定不同的开始日期或/和结束日期。", + "xpack.infra.analysisSetup.timeRangeTitle": "选择时间范围", + "xpack.infra.chartSection.missingMetricDataBody": "此图表的数据缺失。", + "xpack.infra.chartSection.missingMetricDataText": "缺失数据", + "xpack.infra.chartSection.notEnoughDataPointsToRenderText": "没有足够的数据点来呈现图表,请尝试增大时间范围。", + "xpack.infra.chartSection.notEnoughDataPointsToRenderTitle": "没有足够的数据", + "xpack.infra.common.tabBetaBadgeLabel": "Beta", + "xpack.infra.common.tabBetaBadgeTooltipContent": "我们正在开发此功能。将会有更多的功能,某些功能可能有变更。", + "xpack.infra.configureSourceActionLabel": "更改源配置", + "xpack.infra.errorPage.errorOccurredTitle": "发生错误", + "xpack.infra.errorPage.tryAgainButtonLabel": "重试", + "xpack.infra.errorPage.tryAgainDescription ": "请点击后退按钮,然后重试。", + "xpack.infra.errorPage.unexpectedErrorTitle": "糟糕!", + "xpack.infra.featureRegistry.linkInfrastructureTitle": "指标", + "xpack.infra.featureRegistry.linkLogsTitle": "鏃ュ織", + "xpack.infra.groupByDisplayNames.availabilityZone": "可用区", + "xpack.infra.groupByDisplayNames.hostName": "主机", + "xpack.infra.groupByDisplayNames.kubernetesNamespace": "命名空间", + "xpack.infra.groupByDisplayNames.kubernetesNodeName": "节点", + "xpack.infra.groupByDisplayNames.machineType": "机器类型", + "xpack.infra.groupByDisplayNames.projectID": "项目 ID", + "xpack.infra.groupByDisplayNames.provider": "云服务提供商", + "xpack.infra.groupByDisplayNames.serviceType": "服务类型", + "xpack.infra.header.badge.readOnly.text": "只读", + "xpack.infra.header.badge.readOnly.tooltip": "无法更改源配置", + "xpack.infra.header.infrastructureTitle": "指标", + "xpack.infra.header.logsTitle": "鏃ュ織", + "xpack.infra.homePage.documentTitle": "指标", + "xpack.infra.homePage.inventoryTabTitle": "库存", + "xpack.infra.homePage.metricsExplorerTabTitle": "指标浏览器", + "xpack.infra.homePage.noMetricsIndicesDescription": "让我们添加一些!", + "xpack.infra.homePage.noMetricsIndicesInstructionsActionLabel": "查看设置说明", + "xpack.infra.homePage.noMetricsIndicesTitle": "似乎您没有任何指标索引。", + "xpack.infra.homePage.settingsTabTitle": "设置", + "xpack.infra.homePage.toolbar.kqlSearchFieldPlaceholder": "搜索基础设施数据……(例如 host.name:host-1)", + "xpack.infra.infrastructureDescription": "浏览您的基础设施", + "xpack.infra.infrastructureMetricsExplorerPage.documentTitle": "{previousTitle} | 指标浏览器", + "xpack.infra.infrastructureSnapshotPage.documentTitle": "{previousTitle} | 库存", + "xpack.infra.infrastructureTitle": "指标", + "xpack.infra.kibanaMetrics.cloudIdMissingErrorMessage": "{metricId} 的模型需要云 ID,但没有为 {nodeId} 提供。", + "xpack.infra.kibanaMetrics.invalidInfraMetricErrorMessage": "{id} 不是有效的 InfraMetric", + "xpack.infra.kibanaMetrics.nodeDoesNotExistErrorMessage": "{nodeId} 不存在。", + "xpack.infra.legendControls.applyButton": "应用", + "xpack.infra.legendControls.buttonLabel": "配置图例", + "xpack.infra.legendControls.errorMessage": "最小值应小于最大值", + "xpack.infra.legendControls.maxLabel": "最大值", + "xpack.infra.legendControls.minLabel": "最小值", + "xpack.infra.legendControls.switchLabel": "自动计算范围", + "xpack.infra.linkInfrastructureDescription": "浏览您的基础设施", + "xpack.infra.linkInfrastructureTitle": "指标", + "xpack.infra.linkLogsDescription": "浏览您的日志", + "xpack.infra.linkLogsTitle": "鏃ュ織", + "xpack.infra.linkTo.hostWithIp.error": "未找到 IP 地址为“{hostIp}”的主机。", + "xpack.infra.linkTo.hostWithIp.loading": "正在加载 IP 地址为“{hostIp}”的主机。", + "xpack.infra.logEntryActionsMenu.apmActionLabel": "在 APM 中查看", + "xpack.infra.logEntryActionsMenu.buttonLabel": "操作", + "xpack.infra.logEntryActionsMenu.uptimeActionLabel": "查看监测状态", + "xpack.infra.logEntryItemView.viewDetailsToolTip": "查看详情", + "xpack.infra.logFlyout.fieldColumnLabel": "字段", + "xpack.infra.logFlyout.filterAriaLabel": "筛选", + "xpack.infra.logFlyout.flyoutTitle": "日志事件文档详情", + "xpack.infra.logFlyout.loadingMessage": "正在加载事件", + "xpack.infra.logFlyout.setFilterTooltip": "使用筛选查看事件", + "xpack.infra.logFlyout.valueColumnLabel": "值", + "xpack.infra.logs.analysis.analyzeInMlButtonLabel": "在 ML 中分析", + "xpack.infra.logs.analysis.anomaliesExpandedRowNumberOfLogEntriesDescription": "日志条目数", + "xpack.infra.logs.analysis.anomaliesSectionLineSeriesName": "每 15 分钟日志条目数(平均值)", + "xpack.infra.logs.analysis.anomaliesSectionLoadingAriaLabel": "正在加载异常", + "xpack.infra.logs.analysis.anomaliesSectionTitle": "异常", + "xpack.infra.logs.analysis.anomaliesTableCollapseLabel": "折叠", + "xpack.infra.logs.analysis.anomaliesTableExpandLabel": "展开", + "xpack.infra.logs.analysis.anomaliesTableMaxAnomalyScoreColumnName": "最大异常分数", + "xpack.infra.logs.analysis.anomaliesTablePartitionColumnName": "分区", + "xpack.infra.logs.analysis.anomalySectionNoAnomaliesTitle": "未检测到任何异常。", + "xpack.infra.logs.analysis.anomalySectionNoDataBody": "您可能想调整时间范围。", + "xpack.infra.logs.analysis.anomalySectionNoDataTitle": "没有可显示的数据。", + "xpack.infra.logs.analysis.jobConfigurationOutdatedCalloutMessage": "创建 ML 作业时所使用的源配置不同。重新创建作业以应用当前配置。这将移除以前检测到的异常。", + "xpack.infra.logs.analysis.jobConfigurationOutdatedCalloutTitle": "ML 作业配置已过期", + "xpack.infra.logs.analysis.jobDefinitionOutdatedCalloutMessage": "ML 作业有更新的版本可用。重新创建作业以部署更新的版本。这将移除以前检测到的异常。", + "xpack.infra.logs.analysis.jobDefinitionOutdatedCalloutTitle": "ML 作业定义已过期", + "xpack.infra.logs.analysis.jobStoppedCalloutMessage": "ML 作业已手动停止或由于缺乏资源而停止。作业重新启动后,才会处理新的日志条目。", + "xpack.infra.logs.analysis.jobStoppedCalloutTitle": "ML 作业已停止", + "xpack.infra.logs.analysis.logRateResultsToolbarText": "从 {startTime} 到 {endTime} 已分析 {numberOfLogs} 个日志条目", + "xpack.infra.logs.analysis.logRateSectionBucketSpanLabel": "存储桶跨度:", + "xpack.infra.logs.analysis.logRateSectionBucketSpanValue": "15 分钟", + "xpack.infra.logs.analysis.logRateSectionLineSeriesName": "每 15 分钟日志条目数(平均值)", + "xpack.infra.logs.analysis.logRateSectionLoadingAriaLabel": "正在加载日志速率结果", + "xpack.infra.logs.analysis.logRateSectionNoDataBody": "您可能想调整时间范围。", + "xpack.infra.logs.analysis.logRateSectionNoDataTitle": "没有可显示的数据。", + "xpack.infra.logs.analysis.logRateSectionTitle": "日志速率", + "xpack.infra.logs.analysis.overallAnomaliesNumberOfLogEntriesDescription": "日志条目数", + "xpack.infra.logs.analysis.overallAnomaliesTopAnomalyScoreDescription": "最大异常分数", + "xpack.infra.logs.analysis.overallAnomalyChartMaxScoresLabel": "最大异常分数:", + "xpack.infra.logs.analysis.partitionMaxAnomalyScoreAnnotationLabel": "最大异常分数:{maxAnomalyScore}", + "xpack.infra.logs.analysis.recreateJobButtonLabel": "重新创建 ML 作业", + "xpack.infra.logs.analysisPage.loadingMessage": "正在检查分析作业的状态......", + "xpack.infra.logs.analysisPage.unavailable.mlAppLink": "Machine Learning 应用", + "xpack.infra.logs.customizeLogs.customizeButtonLabel": "定制", + "xpack.infra.logs.customizeLogs.lineWrappingFormRowLabel": "换行", + "xpack.infra.logs.customizeLogs.minimapScaleFormRowLabel": "迷你地图比例", + "xpack.infra.logs.customizeLogs.textSizeFormRowLabel": "文本大小", + "xpack.infra.logs.customizeLogs.textSizeRadioGroup": "{textScale, select, small {小} medium {Medium} large {Large} other {{textScale}} }", + "xpack.infra.logs.customizeLogs.wrapLongLinesSwitchLabel": "长行换行", + "xpack.infra.logs.emptyView.checkForNewDataButtonLabel": "检查新数据", + "xpack.infra.logs.emptyView.noLogMessageDescription": "尝试调整您的筛选。", + "xpack.infra.logs.emptyView.noLogMessageTitle": "没有可显示的日志消息。", + "xpack.infra.logs.highlights.clearHighlightTermsButtonLabel": "清除要突出显示的词", + "xpack.infra.logs.highlights.goToNextHighlightButtonLabel": "跳转到下一高亮条目", + "xpack.infra.logs.highlights.goToPreviousHighlightButtonLabel": "跳转到上一高亮条目", + "xpack.infra.logs.highlights.highlightsPopoverButtonLabel": "突出显示", + "xpack.infra.logs.highlights.highlightTermsFieldLabel": "要突出显示的词", + "xpack.infra.logs.index.settingsTabTitle": "设置", + "xpack.infra.logs.index.streamTabTitle": "流式传输", + "xpack.infra.logs.jumpToTailText": "跳到最近的条目", + "xpack.infra.logs.lastStreamingUpdateText": " 最后更新时间:{lastUpdateTime}", + "xpack.infra.logs.loadAgainButtonLabel": "重新加载", + "xpack.infra.logs.loadingAdditionalEntriesText": "正在加载其他条目", + "xpack.infra.logs.noAdditionalEntriesFoundText": "找不到其他条目", + "xpack.infra.logs.scrollableLogTextStreamView.loadingEntriesLabel": "正在加载条目", + "xpack.infra.logs.search.nextButtonLabel": "下一个", + "xpack.infra.logs.search.previousButtonLabel": "上一页", + "xpack.infra.logs.search.searchInLogsAriaLabel": "搜索", + "xpack.infra.logs.search.searchInLogsPlaceholder": "搜索", + "xpack.infra.logs.searchResultTooltip": "{bucketCount, plural, one {# 个高亮条目} other {# 个高亮条目}}", + "xpack.infra.logs.startStreamingButtonLabel": "实时流式传输", + "xpack.infra.logs.stopStreamingButtonLabel": "停止流式传输", + "xpack.infra.logs.streamingDescription": "正在流式传输新条目……", + "xpack.infra.logs.streamingNewEntriesText": "正在流式传输新条目", + "xpack.infra.logs.streamPage.documentTitle": "{previousTitle} | 流式传输", + "xpack.infra.logsPage.noLoggingIndicesDescription": "让我们添加一些!", + "xpack.infra.logsPage.noLoggingIndicesInstructionsActionLabel": "查看设置说明", + "xpack.infra.logsPage.noLoggingIndicesTitle": "似乎您没有任何日志索引。", + "xpack.infra.logsPage.toolbar.kqlSearchFieldAriaLabel": "搜索日志条目", + "xpack.infra.logsPage.toolbar.kqlSearchFieldPlaceholder": "搜索日志条目……(例如 host.name:host-1)", + "xpack.infra.mapLogs.oneDayLabel": "1 日", + "xpack.infra.mapLogs.oneHourLabel": "1 小时", + "xpack.infra.mapLogs.oneMinuteLabel": "1 分钟", + "xpack.infra.mapLogs.oneMonthLabel": "1 个月", + "xpack.infra.mapLogs.oneWeekLabel": "1 周", + "xpack.infra.mapLogs.oneYearLabel": "1 年", + "xpack.infra.metricDetailPage.awsMetricsLayout.cpuUtilSection.percentSeriesLabel": "百分比", + "xpack.infra.metricDetailPage.awsMetricsLayout.cpuUtilSection.sectionLabel": "CPU 使用率", + "xpack.infra.metricDetailPage.awsMetricsLayout.diskioBytesSection.readsSeriesLabel": "读取数", + "xpack.infra.metricDetailPage.awsMetricsLayout.diskioBytesSection.sectionLabel": "磁盘 I/O 字节数", + "xpack.infra.metricDetailPage.awsMetricsLayout.diskioBytesSection.writesSeriesLabel": "写入数", + "xpack.infra.metricDetailPage.awsMetricsLayout.diskioOperationsSection.readsSeriesLabel": "读取数", + "xpack.infra.metricDetailPage.awsMetricsLayout.diskioOperationsSection.sectionLabel": "磁盘 I/O 操作数", + "xpack.infra.metricDetailPage.awsMetricsLayout.diskioOperationsSection.writesSeriesLabel": "写入数", + "xpack.infra.metricDetailPage.awsMetricsLayout.networkBytesSection.rxSeriesLabel": "传入", + "xpack.infra.metricDetailPage.awsMetricsLayout.networkBytesSection.sectionLabel": "网络流量", + "xpack.infra.metricDetailPage.awsMetricsLayout.networkBytesSection.txSeriesLabel": "传出", + "xpack.infra.metricDetailPage.awsMetricsLayout.networkPacketsSection.packetsInSeriesLabel": "传入", + "xpack.infra.metricDetailPage.awsMetricsLayout.networkPacketsSection.packetsOutSeriesLabel": "传出", + "xpack.infra.metricDetailPage.awsMetricsLayout.networkPacketsSection.sectionLabel": "网络数据包(平均值)", + "xpack.infra.metricDetailPage.awsMetricsLayout.overviewSection.cpuUtilizationSeriesLabel": "CPU 使用率", + "xpack.infra.metricDetailPage.awsMetricsLayout.overviewSection.networkPacketsInLabel": "数据包(传入)", + "xpack.infra.metricDetailPage.awsMetricsLayout.overviewSection.networkPacketsOutLabel": "数据包(传出)", + "xpack.infra.metricDetailPage.awsMetricsLayout.overviewSection.sectionLabel": "概览", + "xpack.infra.metricDetailPage.awsMetricsLayout.overviewSection.statusCheckFailedLabel": "状态检查失败", + "xpack.infra.metricDetailPage.containerMetricsLayout.cpuUsageSection.sectionLabel": "CPU 使用", + "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoBytesSection.readRateSeriesLabel": "读取数", + "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoBytesSection.sectionLabel": "磁盘 IO(字节)", + "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoBytesSection.writeRateSeriesLabel": "写入数", + "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoOpsSection.readRateSeriesLabel": "读取数", + "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoOpsSection.sectionLabel": "磁盘 IO(操作数)", + "xpack.infra.metricDetailPage.containerMetricsLayout.diskIoOpsSection.writeRateSeriesLabel": "写入数", + "xpack.infra.metricDetailPage.containerMetricsLayout.layoutLabel": "容器", + "xpack.infra.metricDetailPage.containerMetricsLayout.memoryUsageSection.sectionLabel": "内存利用率", + "xpack.infra.metricDetailPage.containerMetricsLayout.networkTrafficSection.networkRxRateSeriesLabel": "传入", + "xpack.infra.metricDetailPage.containerMetricsLayout.networkTrafficSection.networkTxRateSeriesLabel": "传出", + "xpack.infra.metricDetailPage.containerMetricsLayout.networkTrafficSection.sectionLabel": "网络流量", + "xpack.infra.metricDetailPage.containerMetricsLayout.overviewSection.cpuUsageSeriesLabel": "CPU 使用", + "xpack.infra.metricDetailPage.containerMetricsLayout.overviewSection.inboundRXSeriesLabel": "入站 (RX)", + "xpack.infra.metricDetailPage.containerMetricsLayout.overviewSection.memoryUsageSeriesLabel": "内存利用率", + "xpack.infra.metricDetailPage.containerMetricsLayout.overviewSection.outboundTXSeriesLabel": "出站 (TX)", + "xpack.infra.metricDetailPage.containerMetricsLayout.overviewSection.sectionLabel": "概览", + "xpack.infra.metricDetailPage.documentTitle": "Infrastructure | 指标 | {name}", + "xpack.infra.metricDetailPage.documentTitleError": "{previousTitle} | 啊哦", + "xpack.infra.metricDetailPage.hostMetricsLayout.cpuUsageSection.sectionLabel": "CPU 使用", + "xpack.infra.metricDetailPage.hostMetricsLayout.layoutLabel": "主机", + "xpack.infra.metricDetailPage.hostMetricsLayout.loadSection.fifteenMinuteSeriesLabel": "15 分钟", + "xpack.infra.metricDetailPage.hostMetricsLayout.loadSection.fiveMinuteSeriesLabel": "5 分钟", + "xpack.infra.metricDetailPage.hostMetricsLayout.loadSection.oneMinuteSeriesLabel": "1 分钟", + "xpack.infra.metricDetailPage.hostMetricsLayout.loadSection.sectionLabel": "负载", + "xpack.infra.metricDetailPage.hostMetricsLayout.memoryUsageSection.sectionLabel": "内存利用率", + "xpack.infra.metricDetailPage.hostMetricsLayout.networkTrafficSection.networkRxRateSeriesLabel": "传入", + "xpack.infra.metricDetailPage.hostMetricsLayout.networkTrafficSection.networkTxRateSeriesLabel": "传出", + "xpack.infra.metricDetailPage.hostMetricsLayout.networkTrafficSection.sectionLabel": "网络流量", + "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.cpuUsageSeriesLabel": "CPU 使用", + "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.inboundRXSeriesLabel": "入站 (RX)", + "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.loadSeriesLabel": "负载(5 分钟)", + "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.memoryCapacitySeriesLabel": "内存利用率", + "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.outboundTXSeriesLabel": "出站 (TX)", + "xpack.infra.metricDetailPage.hostMetricsLayout.overviewSection.sectionLabel": "概览", + "xpack.infra.metricDetailPage.kubernetesMetricsLayout.nodeCpuCapacitySection.sectionLabel": "节点 CPU 容量", + "xpack.infra.metricDetailPage.kubernetesMetricsLayout.nodeDiskCapacitySection.sectionLabel": "节点磁盘容量", + "xpack.infra.metricDetailPage.kubernetesMetricsLayout.nodeMemoryCapacitySection.sectionLabel": "节点内存容量", + "xpack.infra.metricDetailPage.kubernetesMetricsLayout.nodePodCapacitySection.sectionLabel": "节点 Pod 容量", + "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.cpuUsageSeriesLabel": "CPU 容量", + "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.diskCapacitySeriesLabel": "磁盘容量", + "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.loadSeriesLabel": "负载(5 分钟)", + "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.memoryUsageSeriesLabel": "内存容量", + "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.podCapacitySeriesLabel": "Pod 容量", + "xpack.infra.metricDetailPage.kubernetesMetricsLayout.overviewSection.sectionLabel": "概览", + "xpack.infra.metricDetailPage.nginxMetricsLayout.activeConnectionsSection.sectionLabel": "活动连接", + "xpack.infra.metricDetailPage.nginxMetricsLayout.hitsSection.sectionLabel": "命中", + "xpack.infra.metricDetailPage.nginxMetricsLayout.requestRateSection.sectionLabel": "请求速率", + "xpack.infra.metricDetailPage.nginxMetricsLayout.requestsPerConnectionsSection.reqsPerConnSeriesLabel": "每连接请求数", + "xpack.infra.metricDetailPage.nginxMetricsLayout.requestsPerConnectionsSection.sectionLabel": "每连接请求数", + "xpack.infra.metricDetailPage.podMetricsLayout.cpuUsageSection.sectionLabel": "CPU 使用", + "xpack.infra.metricDetailPage.podMetricsLayout.layoutLabel": "Pod", + "xpack.infra.metricDetailPage.podMetricsLayout.memoryUsageSection.sectionLabel": "内存利用率", + "xpack.infra.metricDetailPage.podMetricsLayout.networkTrafficSection.networkRxRateSeriesLabel": "传入", + "xpack.infra.metricDetailPage.podMetricsLayout.networkTrafficSection.networkTxRateSeriesLabel": "传出", + "xpack.infra.metricDetailPage.podMetricsLayout.networkTrafficSection.sectionLabel": "网络流量", + "xpack.infra.metricDetailPage.podMetricsLayout.overviewSection.cpuUsageSeriesLabel": "CPU 使用", + "xpack.infra.metricDetailPage.podMetricsLayout.overviewSection.inboundRXSeriesLabel": "入站 (RX)", + "xpack.infra.metricDetailPage.podMetricsLayout.overviewSection.memoryUsageSeriesLabel": "内存利用率", + "xpack.infra.metricDetailPage.podMetricsLayout.overviewSection.outboundTXSeriesLabel": "出站 (TX)", + "xpack.infra.metricDetailPage.podMetricsLayout.overviewSection.sectionLabel": "概览", + "xpack.infra.metrics.emptyViewDescription": "尝试调整您的时间或筛选。", + "xpack.infra.metrics.emptyViewTitle": "没有可显示的数据。", + "xpack.infra.metrics.invalidNodeErrorDescription": "反复检查您的配置", + "xpack.infra.metrics.invalidNodeErrorTitle": "似乎 {nodeName} 未在收集任何指标数据", + "xpack.infra.metrics.loadingNodeDataText": "正在加载数据", + "xpack.infra.metrics.refetchButtonLabel": "检查新数据", + "xpack.infra.metricsExplorer.actionsLabel.aria": "适用于 {grouping} 的操作", + "xpack.infra.metricsExplorer.actionsLabel.button": "操作", + "xpack.infra.metricsExplorer.aggregationLabel": "的", + "xpack.infra.metricsExplorer.aggregationLables.avg": "平均值", + "xpack.infra.metricsExplorer.aggregationLables.cardinality": "基数", + "xpack.infra.metricsExplorer.aggregationLables.count": "文档计数", + "xpack.infra.metricsExplorer.aggregationLables.max": "最大值", + "xpack.infra.metricsExplorer.aggregationLables.min": "最小值", + "xpack.infra.metricsExplorer.aggregationLables.rate": "速率", + "xpack.infra.metricsExplorer.aggregationSelectLabel": "选择聚合", + "xpack.infra.metricsExplorer.chartOptions.areaLabel": "面积图", + "xpack.infra.metricsExplorer.chartOptions.autoLabel": "自动(最小值到最大值)", + "xpack.infra.metricsExplorer.chartOptions.barLabel": "条形图", + "xpack.infra.metricsExplorer.chartOptions.fromZeroLabel": "从零(0 到最大值)", + "xpack.infra.metricsExplorer.chartOptions.lineLabel": "折线图", + "xpack.infra.metricsExplorer.chartOptions.stackLabel": "堆叠序列", + "xpack.infra.metricsExplorer.chartOptions.stackSwitchLabel": "堆叠", + "xpack.infra.metricsExplorer.chartOptions.typeLabel": "图表样式", + "xpack.infra.metricsExplorer.chartOptions.yAxisDomainLabel": "Y 轴域", + "xpack.infra.metricsExplorer.customizeChartOptions": "定制", + "xpack.infra.metricsExplorer.emptyChart.body": "无法呈现图表。", + "xpack.infra.metricsExplorer.emptyChart.title": "图表数据缺失", + "xpack.infra.metricsExplorer.errorMessage": "似乎请求失败,并出现“{message}”", + "xpack.infra.metricsExplorer.filterByLabel": "添加筛选", + "xpack.infra.metricsExplorer.footerPaginationMessage": "显示 {length} 个图表,共 {total} 个,按“{groupBy}”分组", + "xpack.infra.metricsExplorer.groupByLabel": "所有内容", + "xpack.infra.metricsExplorer.groupByToolbarLabel": "图表/", + "xpack.infra.metricsExplorer.loadingCharts": "正在加载图表", + "xpack.infra.metricsExplorer.loadMoreChartsButton": "加载更多图表", + "xpack.infra.metricsExplorer.metricComboBoxPlaceholder": "选择指标以进行绘图", + "xpack.infra.metricsExplorer.noDataBodyText": "尝试调整您的时间、筛选或分组依据设置。", + "xpack.infra.metricsExplorer.noDataRefetchText": "检查新数据", + "xpack.infra.metricsExplorer.noDataTitle": "没有可显示的数据。", + "xpack.infra.metricsExplorer.noMetrics.body": "请在上面选择指标。", + "xpack.infra.metricsExplorer.noMetrics.title": "缺失指标", + "xpack.infra.metricsExplorer.openInTSVB": "在 Visualize 中打开", + "xpack.infra.metricsExplorer.viewNodeDetail": "查看 {name} 的指标", + "xpack.infra.node.ariaLabel": "{nodeName},单击打开菜单", + "xpack.infra.nodeContextMenu.viewLogsName": "查看日志", + "xpack.infra.nodeContextMenu.viewMetricsName": "查看指标", + "xpack.infra.nodeDetails.labels.availabilityZone": "可用区", + "xpack.infra.nodeDetails.labels.cloudProvider": "云服务提供商", + "xpack.infra.nodeDetails.labels.containerized": "容器化", + "xpack.infra.nodeDetails.labels.hostname": "主机名", + "xpack.infra.nodeDetails.labels.instanceId": "实例 ID", + "xpack.infra.nodeDetails.labels.instanceName": "实例名称", + "xpack.infra.nodeDetails.labels.kernelVersion": "内核版本", + "xpack.infra.nodeDetails.labels.machineType": "机器类型", + "xpack.infra.nodeDetails.labels.operatinSystem": "操作系统", + "xpack.infra.nodeDetails.labels.projectId": "项目 ID", + "xpack.infra.nodeDetails.labels.showMoreDetails": "显示更多详情", + "xpack.infra.nodeDetails.no": "否", + "xpack.infra.nodeDetails.yes": "是", + "xpack.infra.nodesToWaffleMap.groupsWithGroups.allName": "全部", + "xpack.infra.nodesToWaffleMap.groupsWithNodes.allName": "全部", + "xpack.infra.notFoundPage.noContentFoundErrorTitle": "未找到任何内容", + "xpack.infra.openView.actionNames.deleteConfirmation": "删除视图?", + "xpack.infra.openView.cancelButton": "取消", + "xpack.infra.openView.columnNames.actions": "操作", + "xpack.infra.openView.columnNames.name": "名称", + "xpack.infra.openView.flyoutHeader": "加载视图", + "xpack.infra.redirectToNodeLogs.loadingNodeLogsMessage": "正在加载 {nodeType} 日志", + "xpack.infra.registerFeatures.infraOpsDescription": "浏览常用服务器、容器和服务的基础设施指标和日志。", + "xpack.infra.registerFeatures.infraOpsTitle": "指标", + "xpack.infra.registerFeatures.logsDescription": "实时流式传输日志或在类似控制台的工具中滚动浏览历史视图。", + "xpack.infra.registerFeatures.logsTitle": "鏃ュ織", + "xpack.infra.sampleDataLinkLabel": "日志", + "xpack.infra.savedView.defaultViewName": "默认值", + "xpack.infra.savedView.errorOnCreate.title": "保存视图时出错。", + "xpack.infra.savedView.findError.title": "加载视图时出错。", + "xpack.infra.sourceConfiguration.addLogColumnButtonLabel": "添加列", + "xpack.infra.sourceConfiguration.applySettingsButtonLabel": "应用", + "xpack.infra.sourceConfiguration.containerFieldDescription": "用于标识 Docker 容器的字段", + "xpack.infra.sourceConfiguration.containerFieldLabel": "容器 ID", + "xpack.infra.sourceConfiguration.containerFieldRecommendedValue": "推荐值为 {defaultValue}", + "xpack.infra.sourceConfiguration.discardSettingsButtonLabel": "丢弃", + "xpack.infra.sourceConfiguration.fieldEmptyErrorMessage": "字段不得为空。", + "xpack.infra.sourceConfiguration.fieldLogColumnTitle": "字段", + "xpack.infra.sourceConfiguration.fieldsSectionTitle": "字段", + "xpack.infra.sourceConfiguration.hostFieldDescription": "推荐值为 {defaultValue}", + "xpack.infra.sourceConfiguration.hostFieldLabel": "主机名", + "xpack.infra.sourceConfiguration.hostNameFieldDescription": "用于标识主机的字段", + "xpack.infra.sourceConfiguration.hostNameFieldLabel": "主机名", + "xpack.infra.sourceConfiguration.indicesSectionTitle": "索引", + "xpack.infra.sourceConfiguration.logColumnListEmptyErrorMessage": "日志列列表不得为空。", + "xpack.infra.sourceConfiguration.logColumnsSectionTitle": "日志列", + "xpack.infra.sourceConfiguration.logIndicesDescription": "用于匹配包含日志数据的索引的索引模式", + "xpack.infra.sourceConfiguration.logIndicesLabel": "日志索引", + "xpack.infra.sourceConfiguration.logIndicesRecommendedValue": "推荐值为 {defaultValue}", + "xpack.infra.sourceConfiguration.logIndicesTitle": "日志索引", + "xpack.infra.sourceConfiguration.messageLogColumnDescription": "此系统字段显示派生自文档字段的日志条目消息。", + "xpack.infra.sourceConfiguration.metricIndicesDescription": "用于匹配包含 Metricbeat 数据的索引的索引模式", + "xpack.infra.sourceConfiguration.metricIndicesLabel": "指标索引", + "xpack.infra.sourceConfiguration.metricIndicesRecommendedValue": "推荐值为 {defaultValue}", + "xpack.infra.sourceConfiguration.metricIndicesTitle": "指标索引", + "xpack.infra.sourceConfiguration.nameDescription": "源配置的描述性名称", + "xpack.infra.sourceConfiguration.nameLabel": "名称", + "xpack.infra.sourceConfiguration.nameSectionTitle": "名称", + "xpack.infra.sourceConfiguration.noLogColumnsDescription": "使用上面的按钮将列添加到此列表。", + "xpack.infra.sourceConfiguration.noLogColumnsTitle": "无列", + "xpack.infra.sourceConfiguration.podFieldDescription": "用于标识 Kubernetes Pod 的字段", + "xpack.infra.sourceConfiguration.podFieldLabel": "Pod ID", + "xpack.infra.sourceConfiguration.podFieldRecommendedValue": "推荐值为 {defaultValue}", + "xpack.infra.sourceConfiguration.removeLogColumnButtonLabel": "删除“{columnDescription}”列", + "xpack.infra.sourceConfiguration.systemColumnBadgeLabel": "系统", + "xpack.infra.sourceConfiguration.tiebreakerFieldDescription": "用于时间戳相同的两个条目间决胜的字段", + "xpack.infra.sourceConfiguration.tiebreakerFieldLabel": "决胜属性", + "xpack.infra.sourceConfiguration.tiebreakerFieldRecommendedValue": "推荐值为 {defaultValue}", + "xpack.infra.sourceConfiguration.timestampFieldDescription": "用于排序日志条目的时间戳", + "xpack.infra.sourceConfiguration.timestampFieldLabel": "时间戳", + "xpack.infra.sourceConfiguration.timestampFieldRecommendedValue": "推荐值为 {defaultValue}", + "xpack.infra.sourceConfiguration.timestampLogColumnDescription": "此系统字段显示 {timestampSetting} 字段设置所确定的日志条目时间。", + "xpack.infra.sourceConfiguration.unsavedFormPrompt": "是否确定要离开?更改将丢失", + "xpack.infra.sourceErrorPage.failedToLoadDataSourcesMessage": "无法加载数据源。", + "xpack.infra.sourceLoadingPage.loadingDataSourcesMessage": "正在加载数据源", + "xpack.infra.tableView.columnName.avg": "平均值", + "xpack.infra.tableView.columnName.last1m": "过去 1 分钟", + "xpack.infra.tableView.columnName.max": "最大值", + "xpack.infra.tableView.columnName.name": "名称", + "xpack.infra.useHTTPRequest.error.status": "错误", + "xpack.infra.useHTTPRequest.error.title": "提取资源时出错", + "xpack.infra.useHTTPRequest.error.url": "URL", + "xpack.infra.viewSwitcher.lenged": "在表视图和地图视图间切换", + "xpack.infra.viewSwitcher.mapViewLabel": "地图视图", + "xpack.infra.viewSwitcher.tableViewLabel": "表视图", + "xpack.infra.waffle.checkNewDataButtonLabel": "检查新数据", + "xpack.infra.waffle.customGroupByDropdownPlacehoder": "选择一个", + "xpack.infra.waffle.customGroupByFieldLabel": "字段", + "xpack.infra.waffle.customGroupByHelpText": "这是用于词聚合的字段", + "xpack.infra.waffle.customGroupByOptionName": "定制字段", + "xpack.infra.waffle.customGroupByPanelTitle": "按定制字段分组", + "xpack.infra.waffle.groupByAllTitle": "全部", + "xpack.infra.waffle.groupByButtonLabel": "分组依据:", + "xpack.infra.waffle.inventoryButtonLabel": "视图:{selectedText}", + "xpack.infra.waffle.loadingDataText": "正在加载数据", + "xpack.infra.waffle.metricButtonLabel": "指标:{selectedMetric}", + "xpack.infra.waffle.metricOptions.countText": "计数", + "xpack.infra.waffle.metricOptions.cpuUsageText": "CPU 使用", + "xpack.infra.waffle.metricOptions.hostLogRateText": "日志速率", + "xpack.infra.waffle.metricOptions.inboundTrafficText": "入站流量", + "xpack.infra.waffle.metricOptions.loadText": "负载", + "xpack.infra.waffle.metricOptions.memoryUsageText": "内存利用率", + "xpack.infra.waffle.metricOptions.outboundTrafficText": "出站流量", + "xpack.infra.waffle.noDataDescription": "尝试调整您的时间或筛选。", + "xpack.infra.waffle.noDataTitle": "没有可显示的数据。", + "xpack.infra.waffle.savedView.createHeader": "保存视图", + "xpack.infra.waffle.savedViews.cancel": "取消", + "xpack.infra.waffle.savedViews.cancelButton": "取消", + "xpack.infra.waffle.savedViews.includeTimeFilterLabel": "将时间与视图一起存储", + "xpack.infra.waffle.savedViews.includeTimeHelpText": "每次加载此仪表板时,这都会将时间筛选更改为当前选定的时间", + "xpack.infra.waffle.savedViews.loadViewsLabel": "负载", + "xpack.infra.waffle.savedViews.saveButton": "保存", + "xpack.infra.waffle.savedViews.saveViewLabel": "保存", + "xpack.infra.waffle.savedViews.viewNamePlaceholder": "名称", + "xpack.infra.waffle.selectTwoGroupingsTitle": "选择最多两个分组", + "xpack.infra.waffle.unableToSelectGroupErrorMessage": "无法选择 {nodeType} 的分组依据选项", + "xpack.infra.waffle.unableToSelectMetricErrorTitle": "无法选择指标选项或指标值。", + "xpack.infra.waffleTime.autoRefreshButtonLabel": "自动刷新", + "xpack.infra.waffleTime.stopRefreshingButtonLabel": "停止刷新", + "xpack.kueryAutocomplete.andOperatorDescription": "需要{bothArguments}为真", + "xpack.kueryAutocomplete.andOperatorDescription.bothArgumentsText": "两个参数都", + "xpack.kueryAutocomplete.equalOperatorDescription": "{equals}某一值", + "xpack.kueryAutocomplete.equalOperatorDescription.equalsText": "等于", + "xpack.kueryAutocomplete.existOperatorDescription": "以任意形式{exists}", + "xpack.kueryAutocomplete.existOperatorDescription.existsText": "存在", + "xpack.kueryAutocomplete.filterResultsDescription": "筛选包含 {fieldName} 的结果", + "xpack.kueryAutocomplete.greaterThanOperatorDescription": "{greaterThan}某一值", + "xpack.kueryAutocomplete.greaterThanOperatorDescription.greaterThanText": "大于", + "xpack.kueryAutocomplete.greaterThanOrEqualOperatorDescription": "{greaterThanOrEqualTo}某一值", + "xpack.kueryAutocomplete.greaterThanOrEqualOperatorDescription.greaterThanOrEqualToText": "大于或等于", + "xpack.kueryAutocomplete.lessThanOperatorDescription": "{lessThan}某一值", + "xpack.kueryAutocomplete.lessThanOperatorDescription.lessThanText": "小于", + "xpack.kueryAutocomplete.lessThanOrEqualOperatorDescription": "{lessThanOrEqualTo}某一值", + "xpack.kueryAutocomplete.lessThanOrEqualOperatorDescription.lessThanOrEqualToText": "小于或等于", + "xpack.kueryAutocomplete.orOperatorDescription": "需要{oneOrMoreArguments}为真", + "xpack.kueryAutocomplete.orOperatorDescription.oneOrMoreArgumentsText": "一个或多个参数", "xpack.lens.app.docLoadingError": "加载已保存文档时出错", "xpack.lens.app.docSavingError": "保存文档时出错", "xpack.lens.app.indexPatternLoadingError": "加载索引模式时出错", @@ -12645,6 +6807,7 @@ "xpack.lens.breadcrumbsTitle": "可视化", "xpack.lens.chartSwitch.dataLossDescription": "切换到此图表将会丢失部分配置", "xpack.lens.chartSwitch.dataLossLabel": "数据丢失", + "xpack.lens.configPanel.selectVisualization": "选择可视化", "xpack.lens.configure.addConfig": "添加配置", "xpack.lens.configure.editConfig": "编辑配置", "xpack.lens.configure.emptyConfig": "将字段拖放到此处", @@ -12661,9 +6824,12 @@ "xpack.lens.datatypes.date": "日期", "xpack.lens.datatypes.ipAddress": "IP", "xpack.lens.datatypes.number": "数字", + "xpack.lens.datatypes.record": "记录", "xpack.lens.datatypes.string": "字符串", + "xpack.lens.editorFrame.dataFailure": "加载数据时出错。", "xpack.lens.editorFrame.emptyWorkspace": "将一些字段拖放到此处以开始", "xpack.lens.editorFrame.emptyWorkspaceHeading": "Lens 是用于创建可视化的新工具", + "xpack.lens.editorFrame.expandRenderingErrorButton": "显示错误的详情", "xpack.lens.editorFrame.expressionFailure": "无法成功执行表达式", "xpack.lens.editorFrame.goToForums": "提出请求并提供反馈", "xpack.lens.editorFrame.previewErrorLabel": "预览呈现失败", @@ -12678,16 +6844,29 @@ "xpack.lens.indexPattern.avgOf": "{name} 的平均值", "xpack.lens.indexPattern.cardinality": "唯一计数", "xpack.lens.indexPattern.cardinalityOf": "{name} 的唯一计数", + "xpack.lens.indexPattern.changeIndexPatternTitle": "更改索引模式", "xpack.lens.indexPattern.columnLabel": "标签", "xpack.lens.indexPattern.count": "计数", "xpack.lens.indexPattern.countOf": "文档计数", "xpack.lens.indexPattern.dateHistogram": "Date histogram", "xpack.lens.indexPattern.dateHistogram.autoInterval": "定制时间间隔", + "xpack.lens.indexPattern.dateHistogram.days": "天", + "xpack.lens.indexPattern.dateHistogram.hours": "灏忔椂", + "xpack.lens.indexPattern.dateHistogram.milliseconds": "毫秒", + "xpack.lens.indexPattern.dateHistogram.minimumInterval": "最小时间间隔", + "xpack.lens.indexPattern.dateHistogram.minutes": "鍒嗛挓", + "xpack.lens.indexPattern.dateHistogram.month": "月", "xpack.lens.indexPattern.dateHistogram.restrictedInterval": "由于聚合限制,时间间隔固定为 {intervalValue}。", + "xpack.lens.indexPattern.dateHistogram.seconds": "秒", + "xpack.lens.indexPattern.dateHistogram.week": "周", + "xpack.lens.indexPattern.dateHistogram.year": "年", + "xpack.lens.indexpattern.emptyTextColumnValue": "(空)", "xpack.lens.indexPattern.fieldDistributionLabel": "分布", + "xpack.lens.indexPattern.fieldItemTooltip": "拖放以可视化。", "xpack.lens.indexPattern.fieldlessOperationLabel": "要使用此函数,请选择字段。", "xpack.lens.indexPattern.fieldPanelEmptyStringValue": "空字符串", "xpack.lens.indexPattern.fieldPlaceholder": "字段", + "xpack.lens.indexPattern.fieldStatsButtonLabel": "单击以进行字段预览,或拖放以进行可视化。", "xpack.lens.indexPattern.fieldStatsCountLabel": "计数", "xpack.lens.indexPattern.fieldStatsDisplayToggle": "切换", "xpack.lens.indexPattern.fieldStatsNoData": "没有可显示的数据", @@ -12701,6 +6880,7 @@ "xpack.lens.indexPattern.groupingSecondTerms": "每个 {target} 的排名最前值", "xpack.lens.indexPattern.indexPatternLoadError": "加载索引模式时出错", "xpack.lens.indexPattern.individualFieldsLabel": "各个字段", + "xpack.lens.indexPattern.invalidInterval": "时间间隔值无效", "xpack.lens.indexPattern.invalidOperationLabel": "要使用此函数,请选择不同的字段。", "xpack.lens.indexPattern.max": "最大值", "xpack.lens.indexPattern.maxOf": "{name} 的最大值", @@ -12711,6 +6891,7 @@ "xpack.lens.indexPattern.ofDocumentsLabel": "文档", "xpack.lens.indexPattern.otherDocsLabel": "其他", "xpack.lens.indexPattern.percentageOfLabel": "{percentage}% 的", + "xpack.lens.indexPattern.records": "记录", "xpack.lens.indexPattern.removeColumnLabel": "移除配置", "xpack.lens.indexpattern.suggestions.nestingChangeLabel": "每个 {outerOperation} 的 {innerOperation}", "xpack.lens.indexpattern.suggestions.overallLabel": "{operation} - 总体", @@ -12727,14 +6908,22 @@ "xpack.lens.indexPattern.termsOf": "{name} 的排名最前值", "xpack.lens.indexPattern.uniqueLabel": "{label} [{num}]", "xpack.lens.indexPatterns.clearFiltersLabel": "清除名称和类型筛选", + "xpack.lens.indexPatterns.emptyFieldsWithDataLabel": "在当前筛选和时间范围下,没有任何字段有数据。请尝试更改筛选或时间范围。", "xpack.lens.indexPatterns.filterByNameAriaLabel": "搜索字段", "xpack.lens.indexPatterns.filterByNameLabel": "搜索字段", "xpack.lens.indexPatterns.filterByTypeLabel": "按类型筛选", + "xpack.lens.indexPatterns.noFieldsLabel": "在此索引模式中不存在任何字段。", + "xpack.lens.indexPatterns.noFilteredFieldsLabel": "没有任何字段匹配当前筛选。请尝试更改筛选或时间范围。", + "xpack.lens.indexPatterns.showAllFields.buttonText": "显示所有字段", "xpack.lens.indexPatterns.toggleEmptyFieldsSwitch": "仅显示具有数据的字段", "xpack.lens.indexPatterns.toggleFiltersPopover": "已筛选字段", + "xpack.lens.indexPatternSuggestion.removeLayerLabel": "仅显示 {indexPatternTitle}", + "xpack.lens.indexPatternSuggestion.removeLayerPositionLabel": "仅显示图层 {layerNumber}", "xpack.lens.lensSavedObjectLabel": "Lens 可视化", "xpack.lens.metric.label": "指标", "xpack.lens.metric.valueLabel": "值", + "xpack.lens.sugegstion.refreshSuggestionLabel": "刷新", + "xpack.lens.suggestion.refreshSuggestionTooltip": "基于选定可视化刷新建议。", "xpack.lens.suggestions.currentVisLabel": "当前", "xpack.lens.visTypeAlias.description": "Lens 简化了基本可视化的创建", "xpack.lens.visTypeAlias.promotion.buttonText": "前往 Lens", @@ -12742,6 +6931,7 @@ "xpack.lens.visTypeAlias.title": "Lens 可视化", "xpack.lens.visTypeAlias.type": "Lens", "xpack.lens.xyChart.addLayerButton": "添加图层", + "xpack.lens.xyChart.addLayerTooltip": "使用多个图层以组合图表类型或可视化不同的索引模式。", "xpack.lens.xyChart.chartTypeLabel": "图表类型", "xpack.lens.xyChart.chartTypeLegend": "图表类型", "xpack.lens.xyChart.deleteLayer": "删除图层", @@ -12776,11 +6966,6312 @@ "xpack.lens.xyVisualization.stackedBarHorizontalLabel": "堆叠水平条形图", "xpack.lens.xyVisualization.stackedBarLabel": "堆叠条形图", "xpack.lens.xyVisualization.xyLabel": "XY", + "xpack.licenseMgmt.app.checkingPermissionsErrorMessage": "检查权限时出错", + "xpack.licenseMgmt.app.deniedPermissionDescription": "要使用许可管理,必须具有{permissionType}权限。", + "xpack.licenseMgmt.app.deniedPermissionTitle": "您缺少集群权限", + "xpack.licenseMgmt.app.loadingPermissionsDescription": "正在检查权限......", + "xpack.licenseMgmt.dashboard.breadcrumb": "许可管理", + "xpack.licenseMgmt.licenseDashboard.addLicense.updateLicenseButtonLabel": "更新许可", + "xpack.licenseMgmt.licenseDashboard.addLicense.updateLicenseTitle": "更新您的许可", + "xpack.licenseMgmt.licenseDashboard.addLicense.useAvailableLicenseDescription": "如果已有新的许可,请立即上传。", + "xpack.licenseMgmt.licenseDashboard.licenseStatus.activeLicenseStatusDescription": "您的许可将于 {expiryDate}过期", + "xpack.licenseMgmt.licenseDashboard.licenseStatus.activeLicenseStatusText": "有效", + "xpack.licenseMgmt.licenseDashboard.licenseStatus.activeLicenseStatusTitle": "您的{typeTitleCase}许可{status}", + "xpack.licenseMgmt.licenseDashboard.licenseStatus.expiredLicenseStatusDescription": "您的许可已于 {expiryDate}过期", + "xpack.licenseMgmt.licenseDashboard.licenseStatus.expiredLicenseStatusTitle": "您的{typeTitleCase}许可已过期", + "xpack.licenseMgmt.licenseDashboard.licenseStatus.inactiveLicenseStatusText": "无效", + "xpack.licenseMgmt.licenseDashboard.licenseStatus.permanentActiveLicenseStatusDescription": "您的许可永不会过期。", + "xpack.licenseMgmt.licenseDashboard.requestTrialExtension.extendTrialButtonLabel": "延期试用", + "xpack.licenseMgmt.licenseDashboard.requestTrialExtension.extendYourTrialTitle": "延期您的试用", + "xpack.licenseMgmt.licenseDashboard.requestTrialExtension.howToContinueUsingPluginsDescription": "如果您想继续使用 Machine Learning、高级安全性以及我们其他超卓的{platinumLicenseFeaturesLinkText},请立即申请延期。", + "xpack.licenseMgmt.licenseDashboard.requestTrialExtension.platinumLicenseFeaturesLinkText": "白金级功能", + "xpack.licenseMgmt.licenseDashboard.revertToBasic.acknowledgeModal.revertToBasicButtonLabel": "恢复为基础级", + "xpack.licenseMgmt.licenseDashboard.revertToBasic.acknowledgeModalTitle": "恢复为基础级许可", + "xpack.licenseMgmt.licenseDashboard.revertToBasic.confirmModal.cancelButtonLabel": "取消", + "xpack.licenseMgmt.licenseDashboard.revertToBasic.confirmModal.confirmButtonLabel": "确认", + "xpack.licenseMgmt.licenseDashboard.revertToBasic.confirmModalTitle": "确认恢复为基础级许可", + "xpack.licenseMgmt.licenseDashboard.revertToBasic.platinumLicenseFeaturesLinkText": "白金级功能", + "xpack.licenseMgmt.licenseDashboard.revertToBasic.revertToFreeFeaturesDescription": "您将恢复到我们的免费功能,并失去对 Machine Learning、高级安全性和其他{platinumLicenseFeaturesLinkText}的访问权限。", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModal.cancelButtonLabel": "取消", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModal.startTrialButtonLabel": "开始我的试用", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription": "此试用具有 Elastic Stack 的全套{platinumLicenseFeaturesLinkText}您立即可以访问:", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.alertingFeatureTitle": "告警", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.dataBaseConnectivityFeatureTitle": "{sqlDataBase} 的 {jdbcStandard} 和 {odbcStandard} 连接性", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.graphCapabilitiesFeatureTitle": "图表功能", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.mashingLearningFeatureTitle": "Machine Learning", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.platinumLicenseFeaturesLinkText": "白金级功能", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.securityDocumentationLinkText": "文档", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.securityFeaturesConfigurationDescription": "诸如身份验证 ({authenticationTypeList})、字段级和文档级安全以及审计等高级安全功能需要配置。有关说明,请参阅 {securityDocumentationLinkText}。", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.termsAndConditionsDescription": "通过开始此试用,您同意其受这些{termsAndConditionsLinkText}约束。", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalDescription.termsAndConditionsLinkText": "条款和条件", + "xpack.licenseMgmt.licenseDashboard.startTrial.confirmModalTitle": "立即开始为期 30 天的免费试用", + "xpack.licenseMgmt.licenseDashboard.startTrial.platinumFeaturesExperienceDescription": "体验 Machine Learning、高级安全性以及我们所有其他{platinumLicenseFeaturesLinkText}能帮您做什么。", + "xpack.licenseMgmt.licenseDashboard.startTrial.platinumLicenseFeaturesLinkText": "白金级功能", + "xpack.licenseMgmt.licenseDashboard.startTrial.startTrialButtonLabel": "开始试用", + "xpack.licenseMgmt.licenseDashboard.startTrialTitle": "开始为期 30 天的试用", + "xpack.licenseMgmt.managementSectionDisplayName": "许可管理", + "xpack.licenseMgmt.replacingCurrentLicenseWithBasicLicenseWarningMessage": "如果将您的{currentLicenseType}许可替换成基础级许可,将会失去部分功能。查看下面的功能列表。", + "xpack.licenseMgmt.telemetryOptIn.customersHelpSupportDescription": "帮助 Elastic 支持提供更好的服务", + "xpack.licenseMgmt.telemetryOptIn.exampleLinkText": "示例", + "xpack.licenseMgmt.telemetryOptIn.featureUsageWarningMessage": "此功能定期发送基本的功能使用统计信息。此信息不会在 Elastic 以外进行共享。请参阅{exampleLink}或阅读我们的{telemetryPrivacyStatementLink}。您可以随时禁用此功能。", + "xpack.licenseMgmt.telemetryOptIn.readMoreLinkText": "阅读更多内容", + "xpack.licenseMgmt.telemetryOptIn.sendBasicFeatureStatisticsLabel": "定期向 Elastic 发送基本的功能使用统计信息。{popover}", + "xpack.licenseMgmt.telemetryOptIn.telemetryPrivacyStatementLinkText": "遥测隐私声明", + "xpack.licenseMgmt.upload.breadcrumb": "上传", + "xpack.licenseMgmt.uploadLicense.cancelButtonLabel": "取消", + "xpack.licenseMgmt.uploadLicense.checkLicenseFileErrorMessage": "{genericUploadError}检查您的许可文件。", + "xpack.licenseMgmt.uploadLicense.confirmModal.cancelButtonLabel": "取消", + "xpack.licenseMgmt.uploadLicense.confirmModal.confirmButtonLabel": "确认", + "xpack.licenseMgmt.uploadLicense.confirmModalTitle": "确认许可上传", + "xpack.licenseMgmt.uploadLicense.expiredLicenseErrorMessage": "提供的许可已过期。", + "xpack.licenseMgmt.uploadLicense.genericUploadErrorMessage": "上传许可时遇到错误:", + "xpack.licenseMgmt.uploadLicense.invalidLicenseErrorMessage": "提供的许可对于此产品无效。", + "xpack.licenseMgmt.uploadLicense.licenseFileNotSelectedErrorMessage": "必须选择许可文件。", + "xpack.licenseMgmt.uploadLicense.licenseKeyTypeDescription": "您的许可密钥是附有签名的 JSON 文件。", + "xpack.licenseMgmt.uploadLicense.problemWithUploadedLicenseDescription": "如果将您的{currentLicenseType}许可替换成{newLicenseType}许可,将会失去部分功能。查看下面的功能列表。", + "xpack.licenseMgmt.uploadLicense.replacingCurrentLicenseWarningMessage": "上传许可将会替换您当前的{currentLicenseType}许可。", + "xpack.licenseMgmt.uploadLicense.selectLicenseFileDescription": "选择或拖来您的许可文件", + "xpack.licenseMgmt.uploadLicense.unknownErrorErrorMessage": "未知错误。", + "xpack.licenseMgmt.uploadLicense.uploadButtonLabel": "上传", + "xpack.licenseMgmt.uploadLicense.uploadingButtonLabel": "正在上传……", + "xpack.licenseMgmt.uploadLicense.uploadLicenseTitle": "上传您的许可", "xpack.licensing.check.errorExpiredMessage": "您不能使用 {pluginName},因为您的{licenseType}许可证已过期。", "xpack.licensing.check.errorUnavailableMessage": "您不能使用 {pluginName},因为许可证信息当前不可用。", "xpack.licensing.check.errorUnsupportedMessage": "您的{licenseType}许可证不支持 {pluginName}。请升级您的许可证。", - "xpack.licensing.welcomeBanner.licenseIsExpiredDescription": "联系您的管理员或直接{updateYourLicenseLinkText}。", - "xpack.licensing.welcomeBanner.licenseIsExpiredDescription.updateYourLicenseLinkText": "更新您的许可", - "xpack.licensing.welcomeBanner.licenseIsExpiredTitle": "您的{licenseType}许可已过期" + "xpack.logstash.addRoleAlert.grantAdditionalPrivilegesDescription": "在 Kibana“管理”中,将 {role} 角色分配给您的 Kibana 用户。", + "xpack.logstash.addRoleAlert.grantAdditionalPrivilegesTitle": "授予其他权限。", + "xpack.logstash.alertCallOut.howToSeeAdditionalPipelinesDescription": "我如何可以看到其他管道?", + "xpack.logstash.confirmDeleteModal.cancelButtonLabel": "取消", + "xpack.logstash.confirmDeleteModal.deletedPipelineConfirmButtonLabel": "删除管道", + "xpack.logstash.confirmDeleteModal.deletedPipelinesConfirmButtonLabel": "删除 {numPipelinesSelected} 个管道", + "xpack.logstash.confirmDeleteModal.deletedPipelinesTitle": "删除 {numPipelinesSelected} 个管道", + "xpack.logstash.confirmDeleteModal.deletedPipelinesWarningMessage": "您无法恢复删除的管道。", + "xpack.logstash.confirmDeleteModal.deletedPipelineTitle": "删除管道“{id}”", + "xpack.logstash.confirmDeleteModal.deletedPipelineWarningMessage": "您无法恢复删除的管道", + "xpack.logstash.confirmDeletePipelineModal.cancelButtonText": "取消", + "xpack.logstash.confirmDeletePipelineModal.confirmButtonText": "删除管道", + "xpack.logstash.confirmDeletePipelineModal.deletePipelineTitle": "删除管道 {id}", + "xpack.logstash.couldNotLoadPipelineErrorNotification": "无法加载管道。错误:“{errStatusText}”。", + "xpack.logstash.deletePipelineModalMessage": "您无法恢复删除的管道。", + "xpack.logstash.enableMonitoringAlert.enableMonitoringDescription": "在 {configFileName} 文件中,将 {monitoringConfigParam} 和 {monitoringUiConfigParam} 设置为 {trueValue}。", + "xpack.logstash.enableMonitoringAlert.enableMonitoringTitle": "启用监测。", + "xpack.logstash.homeFeature.logstashPipelinesDescription": "创建、删除、更新和克隆数据采集管道。", + "xpack.logstash.homeFeature.logstashPipelinesTitle": "Logstash 管道", + "xpack.logstash.idFormatErrorMessage": "管道 ID 必须以字母或下划线开头,并只能包含字母、下划线、短划线和数字", + "xpack.logstash.insufficientUserPermissionsDescription": "管理 Logstash 管道的用户权限不足", + "xpack.logstash.kibanaManagementPipelinesTitle": "仅在 Kibana“管理”中创建的管道显示在此处", + "xpack.logstash.managementSection.createPipelineTitle": "创建管道", + "xpack.logstash.managementSection.editPipelineTitle": "编辑管道", + "xpack.logstash.managementSection.enableSecurityDescription": "必须启用 Security,才能使用 Logstash 管道管理功能。请在 elasticsearch.yml 中设置 xpack.security.enabled: true。", + "xpack.logstash.managementSection.licenseDoesNotSupportDescription": "您的{licenseType}许可不支持 Logstash 管道管理功能。请升级您的许可。", + "xpack.logstash.managementSection.notPossibleToManagePipelinesMessage": "您不能管理 Logstash 管道,因为许可信息当前不可用。", + "xpack.logstash.managementSection.pipelineCrudOperationsNotAllowedDescription": "您不能编辑、创建或删除您的 Logstash 管道,因为您的{licenseType}许可已过期。", + "xpack.logstash.managementSection.pipelinesTitle": "管道", + "xpack.logstash.manualUpgradeButtonLabel": "重试", + "xpack.logstash.newPipelineMessage": "在您可以添加管道之前,我们需要升级您的配置。", + "xpack.logstash.notManualUpgradeButtonLabel": "升级", + "xpack.logstash.notManualUpgradeTitle": "是时候升级了!", + "xpack.logstash.notNewPipelineMessage": "在您可以编辑此管道之前,我们需要升级您的配置。", + "xpack.logstash.pipelineBatchDelayTooltip": "创建管道事件批时,将过小的批分派给管道工作线程之前要等候每个事件的时长(毫秒)。\n\n默认值:50ms", + "xpack.logstash.pipelineBatchSizeTooltip": "单个工作线程在尝试执行其筛选和输出之前可以从输入收集的最大事件数目。较大的批大小通常更有效,但代价是内存开销也较大。您可能需要通过设置 LS_HEAP_SIZE 变量来增大 JVM 堆大小,从而有效利用该选项。\n\n默认值:125", + "xpack.logstash.pipelineEditor.cancelButtonLabel": "取消", + "xpack.logstash.pipelineEditor.clonePipelineTitle": "克隆管道“{id}”", + "xpack.logstash.pipelineEditor.createAndDeployButtonLabel": "创建并部署", + "xpack.logstash.pipelineEditor.createPipelineTitle": "创建管道", + "xpack.logstash.pipelineEditor.deletePipelineButtonLabel": "删除管道", + "xpack.logstash.pipelineEditor.descriptionFormRowLabel": "描述", + "xpack.logstash.pipelineEditor.editPipelineTitle": "编辑管道“{id}”", + "xpack.logstash.pipelineEditor.errorHandlerToastTitle": "管道错误", + "xpack.logstash.pipelineEditor.pipelineBatchDelayFormRowLabel": "管道批延迟", + "xpack.logstash.pipelineEditor.pipelineBatchSizeFormRowLabel": "管道批大小", + "xpack.logstash.pipelineEditor.pipelineFormRowLabel": "管道", + "xpack.logstash.pipelineEditor.pipelineIdFormRowLabel": "管道 ID", + "xpack.logstash.pipelineEditor.pipelineSuccessfullyDeletedMessage": "已删除“{id}”", + "xpack.logstash.pipelineEditor.pipelineSuccessfullySavedMessage": "已保存“{id}”", + "xpack.logstash.pipelineEditor.pipelineWorkersFormRowLabel": "管道工作线程", + "xpack.logstash.pipelineEditor.queueCheckpointWritesFormRowLabel": "队列检查点写入数", + "xpack.logstash.pipelineEditor.queueMaxBytesFormRowLabel": "队列最大字节数", + "xpack.logstash.pipelineEditor.queueTypeFormRowLabel": "队列类型", + "xpack.logstash.pipelineIdRequiredMessage": "管道 ID 必填", + "xpack.logstash.pipelineList.couldNotDeletePipelinesNotification": "无法删除 {numErrors, plural, one {# 个管道} other {# 个管道}}", + "xpack.logstash.pipelineList.head": "管道", + "xpack.logstash.pipelineList.noPermissionToManageDescription": "请联系您的管理员。", + "xpack.logstash.pipelineList.noPermissionToManageTitle": "您无权管理 Logstash 管道。", + "xpack.logstash.pipelineList.noPipelinesDescription": "未定义任何管道。", + "xpack.logstash.pipelineList.noPipelinesTitle": "没有管道", + "xpack.logstash.pipelineList.pipelineLoadingErrorNotification": "无法加载管道。错误:“{errStatusText}”。", + "xpack.logstash.pipelineList.pipelinesCouldNotBeDeletedDescription": "但 {numErrors, plural, one {# 个管道} other {# 个管道}}无法删除。", + "xpack.logstash.pipelineList.pipelinesLoadingErrorDescription": "加载管道时出错。", + "xpack.logstash.pipelineList.pipelinesLoadingErrorTitle": "错误", + "xpack.logstash.pipelineList.pipelinesLoadingMessage": "正在加载管道……", + "xpack.logstash.pipelineList.pipelinesSuccessfullyDeletedNotification": "已删除“{id}”", + "xpack.logstash.pipelineList.subhead": "管理 Logstash 事件处理并直观地查看结果", + "xpack.logstash.pipelineList.successfullyDeletedPipelinesNotification": "{numPipelinesSelected, plural, one {# 个管道} other {# 个管道}}有 {numSuccesses} 个已删除", + "xpack.logstash.pipelineNotCentrallyManagedTooltip": "此管道不是使用“集中配置管理”创建的。不能在此处管理或编辑它。", + "xpack.logstash.pipelines.createBreadcrumb": "创建", + "xpack.logstash.pipelines.listBreadcrumb": "管道", + "xpack.logstash.pipelinesTable.cloneButtonLabel": "克隆", + "xpack.logstash.pipelinesTable.createPipelineButtonLabel": "创建管道", + "xpack.logstash.pipelinesTable.deleteButtonLabel": "删除", + "xpack.logstash.pipelinesTable.descriptionColumnLabel": "描述", + "xpack.logstash.pipelinesTable.filterByIdLabel": "按 ID 筛选", + "xpack.logstash.pipelinesTable.idColumnLabel": "ID", + "xpack.logstash.pipelinesTable.lastModifiedColumnLabel": "最后修改时间", + "xpack.logstash.pipelinesTable.modifiedByColumnLabel": "修改者", + "xpack.logstash.pipelinesTable.selectablePipelineMessage": "选择管道“{id}”", + "xpack.logstash.queueCheckpointWritesTooltip": "启用持久性队列时,在强制执行检查点之前已写入事件的最大数目。指定 0 以将此值设置为无限制。\n\n默认值:1024", + "xpack.logstash.queueMaxBytesTooltip": "队列的总容量(字节数)。确保您的磁盘驱动器容量大于您在此处指定的值。\n\n默认值:1024mb (1g)", + "xpack.logstash.queueTypes.memoryLabel": "memory", + "xpack.logstash.queueTypes.persistedLabel": "persisted", + "xpack.logstash.queueTypeTooltip": "用于事件缓冲的内部排队模型。为旧式的内存内排队指定 memory 或为基于磁盘的已确认排队指定 persisted\n\n默认值:memory", + "xpack.logstash.units.bytesLabel": "字节", + "xpack.logstash.units.gigabytesLabel": "千兆字节", + "xpack.logstash.units.kilobytesLabel": "千字节", + "xpack.logstash.units.megabytesLabel": "兆字节", + "xpack.logstash.units.petabytesLabel": "万兆字节", + "xpack.logstash.units.terabytesLabel": "兆兆字节", + "xpack.logstash.upgradeFailedTitle": "升级失败", + "xpack.logstash.upgradeFailureActions.goBackButtonLabel": "返回", + "xpack.logstash.upstreamPipelineArgumentMustContainAnIdPropertyErrorMessage": "upstreamPipeline 参数必须包含 id 属性", + "xpack.logstash.workersTooltip": "并行执行管道的筛选和输出阶段的工作线程数目。如果您发现事件出现积压或 CPU 未饱和,请考虑增大此数值,以更好地利用机器处理能力。\n\n默认值:主机的 CPU 核心数", + "xpack.maps.addLayerPanel.addLayer": "添加图层", + "xpack.maps.addLayerPanel.changeDataSourceButtonLabel": "更改数据源", + "xpack.maps.addLayerPanel.chooseDataSourceTitle": "选择数据源", + "xpack.maps.addLayerPanel.footer.cancelButtonLabel": "鍙栨秷", + "xpack.maps.addLayerPanel.importFile": "导入文件", + "xpack.maps.addLayerPanel.selectSource": "选择源", + "xpack.maps.appDescription": "地图应用程序", + "xpack.maps.appTitle": "Maps", + "xpack.maps.badge.readOnly.text": "只读", + "xpack.maps.badge.readOnly.tooltip": "无法保存地图", + "xpack.maps.common.esSpatialRelation.containsLabel": "contains", + "xpack.maps.common.esSpatialRelation.disjointLabel": "disjoint", + "xpack.maps.common.esSpatialRelation.intersectsLabel": "intersects", + "xpack.maps.common.esSpatialRelation.withinLabel": "within", + "xpack.maps.drawTooltip.boundsInstructions": "单击可开始绘制矩形。再次单击以完成。", + "xpack.maps.drawTooltip.polygonInstructions": "单击以添加顶点。双击以完成。", + "xpack.maps.embeddableDisplayName": "地图", + "xpack.maps.es_geo_utils.convert.unsupportedGeometryTypeErrorMessage": "无法将 {geometryType} 几何图形转换成 geojson,不支持", + "xpack.maps.es_geo_utils.shapeFilter.geoPointRelationLabel": "传入", + "xpack.maps.es_geo_utils.unsupportedFieldTypeErrorMessage": "字段类型不受支持,应为 {expectedTypes},而提供的是 {fieldType}", + "xpack.maps.es_geo_utils.unsupportedGeometryTypeErrorMessage": "几何类型不受支持,应为 {expectedTypes},而提供的是 {geometryType}", + "xpack.maps.es_geo_utils.wkt.invalidWKTErrorMessage": "无法将 {wkt} 转换成 geojson。需要有效的 WKT。", + "xpack.maps.esSearch.featureCountMsg": "找到 {count} 个文档。", + "xpack.maps.esSearch.resultsTrimmedMsg": "结果仅限于前 {count} 个文档。", + "xpack.maps.esSearch.topHitsEntitiesCountMsg": "找到 {entityCount} 个实体。", + "xpack.maps.feature.appDescription": "从 Elasticsearch 和 Elastic 地图服务浏览地理空间数据", + "xpack.maps.featureRegistry.mapsFeatureName": "Maps", + "xpack.maps.geoGrid.resolutionLabel": "网格分辨率", + "xpack.maps.geometryFilterForm.geoFieldLabel": "已筛选字段", + "xpack.maps.geometryFilterForm.geometryLabelLabel": "几何标签", + "xpack.maps.geometryFilterForm.relationLabel": "空间关系", + "xpack.maps.heatmap.colorRampLabel": "颜色范围", + "xpack.maps.heatmapLegend.coldLabel": "冷", + "xpack.maps.heatmapLegend.hotLabel": "热", + "xpack.maps.inspector.centerLatLabel": "中心纬度", + "xpack.maps.inspector.centerLonLabel": "中心经度", + "xpack.maps.inspector.mapboxStyleTitle": "Mapbox 样式", + "xpack.maps.inspector.mapDetailsTitle": "地图详情", + "xpack.maps.inspector.mapDetailsViewHelpText": "查看地图状态", + "xpack.maps.inspector.mapDetailsViewTitle": "地图详情", + "xpack.maps.inspector.zoomLabel": "缩放", + "xpack.maps.layer.isUsingSearchMsg": "通过搜索栏缩减的结果", + "xpack.maps.layer.layerHiddenTooltip": "图层已隐藏。", + "xpack.maps.layer.loadWarningAriaLabel": "加载警告", + "xpack.maps.layer.zoomFeedbackTooltip": "图层在缩放级别 {minZoom} 和 {maxZoom} 之间可见。", + "xpack.maps.layerControl.addLayerButtonLabel": "添加图层", + "xpack.maps.layerControl.closeLayerTOCButtonAriaLabel": "折叠图层面板", + "xpack.maps.layerControl.layersTitle": "图层", + "xpack.maps.layerControl.openLayerTOCButtonAriaLabel": "展开图层面板", + "xpack.maps.layerControl.tocEntry.editButtonAriaLabel": "编辑图层", + "xpack.maps.layerControl.tocEntry.editButtonTitle": "编辑图层", + "xpack.maps.layerControl.tocEntry.grabButtonAriaLabel": "重新排序图层", + "xpack.maps.layerControl.tocEntry.grabButtonTitle": "重新排序图层", + "xpack.maps.layerControl.tocEntry.hideDetailsButtonAriaLabel": "隐藏图层详情", + "xpack.maps.layerControl.tocEntry.hideDetailsButtonTitle": "隐藏图层详情", + "xpack.maps.layerControl.tocEntry.showDetailsButtonAriaLabel": "显示图层详情", + "xpack.maps.layerControl.tocEntry.showDetailsButtonTitle": "显示图层详情", + "xpack.maps.layerPanel.filterEditor.addFilterButtonLabel": "添加筛选", + "xpack.maps.layerPanel.filterEditor.editFilterButtonLabel": "编辑筛选", + "xpack.maps.layerPanel.filterEditor.emptyState.description": "添加筛选以缩小图层数据范围。", + "xpack.maps.layerPanel.filterEditor.queryBarSubmitButtonLabel": "设置筛选", + "xpack.maps.layerPanel.filterEditor.title": "筛选", + "xpack.maps.layerPanel.fitToBoundsAriaLabel": "适应边界", + "xpack.maps.layerPanel.fitToBoundsButtonLabel": "适应", + "xpack.maps.layerPanel.footer.cancelButtonLabel": "取消", + "xpack.maps.layerPanel.footer.closeButtonLabel": "关闭", + "xpack.maps.layerPanel.footer.removeLayerButtonLabel": "移除图层", + "xpack.maps.layerPanel.footer.saveAndCloseButtonLabel": "保存并关闭", + "xpack.maps.layerPanel.join.deleteJoinAriaLabel": "删除联接", + "xpack.maps.layerPanel.join.deleteJoinTitle": "删除联接", + "xpack.maps.layerPanel.join.noIndexPatternErrorMessage": "找不到索引模式 {indexPatternId}", + "xpack.maps.layerPanel.joinEditor.addJoinAriaLabel": "添加联接", + "xpack.maps.layerPanel.joinEditor.addJoinButtonLabel": "添加联接", + "xpack.maps.layerPanel.joinEditor.termJoinsTitle": "词联接", + "xpack.maps.layerPanel.joinEditor.termJoinTooltip": "使用词联接及属性增强此图层,以实现数据驱动的样式。", + "xpack.maps.layerPanel.joinExpression.helpText": "配置共享密钥。", + "xpack.maps.layerPanel.joinExpression.joinPopoverTitle": "联接", + "xpack.maps.layerPanel.joinExpression.leftFieldLabel": "左字段", + "xpack.maps.layerPanel.joinExpression.leftSourceLabel": "左源", + "xpack.maps.layerPanel.joinExpression.leftSourceLabelHelpText": "包含共享密钥的左源字段。", + "xpack.maps.layerPanel.joinExpression.rightFieldLabel": "右字段", + "xpack.maps.layerPanel.joinExpression.rightSourceLabel": "右源", + "xpack.maps.layerPanel.joinExpression.rightSourceLabelHelpText": "包含共享密钥的右源字段。", + "xpack.maps.layerPanel.joinExpression.selectFieldPlaceholder": "选择字段", + "xpack.maps.layerPanel.joinExpression.selectIndexPatternPlaceholder": "选择索引模式", + "xpack.maps.layerPanel.joinExpression.selectPlaceholder": "-- 选择 --", + "xpack.maps.layerPanel.layerSettingsTitle": "图层设置", + "xpack.maps.layerPanel.metricsExpression.helpText": "配置右源的指标。这些值已添加到图层功能。", + "xpack.maps.layerPanel.metricsExpression.joinMustBeSetErrorMessage": "必须设置联接", + "xpack.maps.layerPanel.metricsExpression.metricsPopoverTitle": "指标", + "xpack.maps.layerPanel.metricsExpression.useMetricsDescription": "{metricsLength, plural, one {并使用指标} other {并使用指标}}", + "xpack.maps.layerPanel.settingsPanel.layerNameLabel": "名称", + "xpack.maps.layerPanel.settingsPanel.layerTransparencyLabel": "图层透明度", + "xpack.maps.layerPanel.settingsPanel.percentageLabel": "%", + "xpack.maps.layerPanel.settingsPanel.unableToLoadTitle": "无法加载图层", + "xpack.maps.layerPanel.settingsPanel.visibleZoom": "缩放级别", + "xpack.maps.layerPanel.settingsPanel.visibleZoomLabel": "图层可见性的缩放范围", + "xpack.maps.layerPanel.sourceDetailsLabel": "源详情", + "xpack.maps.layerPanel.styleSettingsTitle": "图层样式", + "xpack.maps.layerPanel.whereExpression.expressionDescription": "其中", + "xpack.maps.layerPanel.whereExpression.expressionValuePlaceholder": "-- 添加筛选 --", + "xpack.maps.layerPanel.whereExpression.helpText": "使用查询缩小右源范围。", + "xpack.maps.layerPanel.whereExpression.queryBarSubmitButtonLabel": "设置筛选", + "xpack.maps.layerTocActions.cloneLayerTitle": "克隆图层", + "xpack.maps.layerTocActions.editLayerTitle": "编辑图层", + "xpack.maps.layerTocActions.fitToDataTitle": "适应数据", + "xpack.maps.layerTocActions.hideLayerTitle": "隐藏图层", + "xpack.maps.layerTocActions.layerActionsTitle": "图层操作", + "xpack.maps.layerTocActions.noFitSupportTooltip": "图层不支持适应数据", + "xpack.maps.layerTocActions.showLayerTitle": "显示图层", + "xpack.maps.map.initializeErrorTitle": "无法初始化地图", + "xpack.maps.mapController.fullScreenButtonLabel": "全屏", + "xpack.maps.mapController.fullScreenDescription": "全屏", + "xpack.maps.mapController.mapsBreadcrumbLabel": "Maps", + "xpack.maps.mapController.openInspectorButtonLabel": "检查", + "xpack.maps.mapController.openInspectorDescription": "打开检查器", + "xpack.maps.mapController.saveErrorMessage": "保存 “{title}” 时出错", + "xpack.maps.mapController.saveMapButtonLabel": "保存", + "xpack.maps.mapController.saveMapDescription": "保存地图", + "xpack.maps.mapController.saveMapDisabledButtonTooltip": "保存或在保存之前取消您的图层更改", + "xpack.maps.mapController.saveSuccessMessage": "已保存“{title}”", + "xpack.maps.mapController.unsavedChangesWarning": "可能不会保存您未保存的更改", + "xpack.maps.mapEmbeddableFactory.invalidLayerList": "无法加载地图,图层列表格式不正确", + "xpack.maps.mapEmbeddableFactory.invalidSavedObject": "无法加载地图,已保存对象格式错误", + "xpack.maps.mapListing.advancedSettingsLinkText": "高级设置", + "xpack.maps.mapListing.cancelTitle": "取消", + "xpack.maps.mapListing.createMapButtonLabel": "创建地图", + "xpack.maps.mapListing.deleteSelectedButtonLabel": "删除选定", + "xpack.maps.mapListing.deleteSelectedItemsTitle": "删除选定项?", + "xpack.maps.mapListing.deleteTitle": "删除", + "xpack.maps.mapListing.deleteWarning": "您无法恢复已删除项。", + "xpack.maps.mapListing.descriptionFieldTitle": "描述", + "xpack.maps.mapListing.limitExceededTitle": "已超过列表限制", + "xpack.maps.mapListing.limitHelpDescription": "您有 {totalItems} 项,但您的 listingLimit 设置阻止下表显示 {listingLimit} 项以上。此设置可在以下选项下更改: ", + "xpack.maps.mapListing.listingTableTitle": "Maps", + "xpack.maps.mapListing.noItemsDescription": "似乎您没有任何地图。单击创建按钮来创建。", + "xpack.maps.mapListing.noMatchDescription": "没有任何项匹配您的搜索。", + "xpack.maps.mapListing.searchAriaLabel": "筛选项", + "xpack.maps.mapListing.searchPlaceholder": "搜索......", + "xpack.maps.mapListing.titleFieldTitle": "标题", + "xpack.maps.mapListing.unableToDeleteToastTitle": "无法删除地图", + "xpack.maps.mapSavedObjectLabel": "地图", + "xpack.maps.metricsEditor.addMetricButtonLabel": "添加指标", + "xpack.maps.metricsEditor.aggregationLabel": "聚合", + "xpack.maps.metricsEditor.customLabel": "定制标签", + "xpack.maps.metricsEditor.deleteMetricAriaLabel": "删除指标", + "xpack.maps.metricsEditor.deleteMetricButtonLabel": "删除指标", + "xpack.maps.metricsEditor.selectFieldLabel": "字段", + "xpack.maps.metricsEditor.selectFieldPlaceholder": "选择字段", + "xpack.maps.metricSelect.averageDropDownOptionLabel": "平均值", + "xpack.maps.metricSelect.countDropDownOptionLabel": "计数", + "xpack.maps.metricSelect.maxDropDownOptionLabel": "最大值", + "xpack.maps.metricSelect.minDropDownOptionLabel": "最小值", + "xpack.maps.metricSelect.selectAggregationPlaceholder": "选择聚合", + "xpack.maps.metricSelect.sumDropDownOptionLabel": "和", + "xpack.maps.noIndexPattern.doThisLinkTextDescription": "创建索引模式", + "xpack.maps.noIndexPattern.doThisPrefixDescription": "您将需要 ", + "xpack.maps.noIndexPattern.doThisSuffixDescription": " 使用地理空间字段。", + "xpack.maps.noIndexPattern.getStartedLinkText": "开始使用一些样例数据集。", + "xpack.maps.noIndexPattern.hintDescription": "没有任何地理空间数据集?", + "xpack.maps.noIndexPattern.messageTitle": "找不到任何具有地理空间字段的索引模式", + "xpack.maps.sampleData.ecommerceSpec.mapsTitle": "[电子商务] 订单(按国家/地区)", + "xpack.maps.sampleData.flightaSpec.logsTitle": "[日志] 请求和字节总数", + "xpack.maps.sampleData.flightaSpec.mapsTitle": "[航班] 始发地和到达地航班时间", + "xpack.maps.sampleDataLinkLabel": "地图", + "xpack.maps.setViewControl.goToButtonLabel": "前往", + "xpack.maps.setViewControl.latitudeLabel": "纬度", + "xpack.maps.setViewControl.longitudeLabel": "经度", + "xpack.maps.setViewControl.submitButtonLabel": "执行", + "xpack.maps.setViewControl.zoomLabel": "缩放", + "xpack.maps.source.dataSourceLabel": "数据源", + "xpack.maps.source.ems_xyzDescription": "来自包括 XYZ 坐标的 URL 的地图磁贴", + "xpack.maps.source.ems_xyzTitle": "来自 URL 的磁贴地图服务", + "xpack.maps.source.ems.disabledDescription": "已禁用对 Elastic 地图服务的访问。让您的系统管理员在 kibana.yml 中设置“map.includeElasticMapsService”。", + "xpack.maps.source.ems.noAccessDescription": "Kibana 无法访问 Elastic 地图服务。请联系您的系统管理员", + "xpack.maps.source.emsFile.layerLabel": "图层", + "xpack.maps.source.emsFile.selectPlaceholder": "选择 EMS 矢量形状", + "xpack.maps.source.emsFile.unableToFindIdErrorMessage": "找不到 ID {id} 的 EMS 矢量形状", + "xpack.maps.source.emsFileDescription": "来自 Elastic 地图服务的管理边界的矢量形状", + "xpack.maps.source.emsFileTitle": "矢量形状", + "xpack.maps.source.emsTile.autoLabel": "基于 Kibana 主题自动选择", + "xpack.maps.source.emsTile.errorMessage": "找不到 ID {id} 的 EMS 磁贴配置", + "xpack.maps.source.emsTile.isAutoSelectLabel": "基于 Kibana 主题自动选择", + "xpack.maps.source.emsTile.label": "Tile Service", + "xpack.maps.source.emsTile.serviceId": "Tile Service", + "xpack.maps.source.emsTileDescription": "Elastic 地图服务的地图磁贴", + "xpack.maps.source.emsTileTitle": "磁贴", + "xpack.maps.source.esGeoGrid.geofieldLabel": "地理空间字段", + "xpack.maps.source.esGeoGrid.geofieldPlaceholder": "选择地理字段", + "xpack.maps.source.esGeoGrid.gridRectangleDropdownOption": "网格矩形", + "xpack.maps.source.esGeoGrid.heatmapDropdownOption": "热图", + "xpack.maps.source.esGeoGrid.indexPatternLabel": "索引模式", + "xpack.maps.source.esGeoGrid.indexPatternPlaceholder": "选择索引模式", + "xpack.maps.source.esGeoGrid.pointsDropdownOption": "磅", + "xpack.maps.source.esGeoGrid.showAsLabel": "显示为", + "xpack.maps.source.esGeoGrid.showAsPlaceholder": "选择单个选项", + "xpack.maps.source.esGrid.coarseDropdownOption": "粗糙", + "xpack.maps.source.esGrid.fineDropdownOption": "精致", + "xpack.maps.source.esGrid.finestDropdownOption": "最精致化", + "xpack.maps.source.esGrid.geospatialFieldLabel": "地理空间字段", + "xpack.maps.source.esGrid.indexPatternLabel": "索引模式", + "xpack.maps.source.esGrid.inspectorDescription": "Elasticsearch 地理网格聚合请求", + "xpack.maps.source.esGrid.metricsLabel": "指标", + "xpack.maps.source.esGrid.noIndexPatternErrorMessage": "找不到索引模式 {id}", + "xpack.maps.source.esGrid.resolutionParamErrorMessage": "无法识别网格分辨率参数:{resolution}", + "xpack.maps.source.esGrid.showasFieldLabel": "显示为", + "xpack.maps.source.esGridDescription": "地理空间数据在网格中进行分组,每个网格单元格都具有指标", + "xpack.maps.source.esGridTitle": "网格聚合", + "xpack.maps.source.esJoin.joinDescription": "{description} 的 Elasticsearch 词聚合请求", + "xpack.maps.source.esJoin.joinLeftDescription": "将 {leftSourceName}:{leftFieldName} 联接到", + "xpack.maps.source.esJoin.joinMetricsDescription": "以获取指标 {metrics}", + "xpack.maps.source.esSearch.convertToGeoJsonErrorMsg": "无法将搜索响应转换成 geoJson 功能集合,错误:{errorMsg}", + "xpack.maps.source.esSearch.disableFilterByMapBoundsExplainMsg": "索引“{indexPatternTitle}”具有很少数量的文档,不需要动态筛选。", + "xpack.maps.source.esSearch.disableFilterByMapBoundsTitle": "动态数据筛选已禁用", + "xpack.maps.source.esSearch.disableFilterByMapBoundsTurnOnMsg": "如果预期文档数量会增加,请打开动态筛选。", + "xpack.maps.source.esSearch.extentFilterLabel": "在可见地图区域中动态筛留数据", + "xpack.maps.source.esSearch.geofieldLabel": "地理空间字段", + "xpack.maps.source.esSearch.geoFieldLabel": "地理空间字段", + "xpack.maps.source.esSearch.geoFieldTypeLabel": "地理空间字段类型", + "xpack.maps.source.esSearch.indexPatternLabel": "索引模式", + "xpack.maps.source.esSearch.loadErrorMessage": "找不到索引模式 {id}", + "xpack.maps.source.esSearch.loadTooltipPropertiesErrorMsg": "找不到文档,_id:{docId}", + "xpack.maps.source.esSearch.selectIndexPatternPlaceholder": "选择索引模式", + "xpack.maps.source.esSearch.selectLabel": "选择地理字段", + "xpack.maps.source.esSearch.sortFieldSelectPlaceholder": "选择排序字段", + "xpack.maps.source.esSearch.topHitsSizeLabel": "每个实体的文档", + "xpack.maps.source.esSearch.topHitsSplitFieldLabel": "实体", + "xpack.maps.source.esSearch.topHitsSplitFieldSelectPlaceholder": "选择实体字段", + "xpack.maps.source.esSearch.useTopHitsLabel": "按实体显示最近的文档", + "xpack.maps.source.esSearchDescription": "Kibana 索引模式的地理空间数据", + "xpack.maps.source.esSearchTitle": "文档", + "xpack.maps.source.esSource.noGeoFieldErrorMessage": "索引模式“{indexPatternTitle}”不再包含地理字段 {geoField}", + "xpack.maps.source.esSource.noIndexPatternErrorMessage": "找不到 ID {indexPatternId} 的索引模式", + "xpack.maps.source.esSource.requestFailedErrorMessage": "Elasticsearch 搜索请求失败,错误:{message}", + "xpack.maps.source.geojsonFileDescription": "在 Elasticsearch 上传 GeoJSON 文件和索引", + "xpack.maps.source.geojsonFileTitle": "上传 GeoJSON 矢量文件", + "xpack.maps.source.kbnRegionMap.noConfigErrorMessage": "找不到 {name} 的 map.regionmap 配置", + "xpack.maps.source.kbnRegionMap.noLayerAvailableHelptext": "没有可用的矢量图层。让您的系统管理员在 kibana.yml 中设置“map.regionmap”。", + "xpack.maps.source.kbnRegionMap.vectorLayerLabel": "矢量图层", + "xpack.maps.source.kbnRegionMapDescription": "来自 kibana.yml 配置的静态文件的矢量形状", + "xpack.maps.source.kbnRegionMapTitle": "定制矢量形状", + "xpack.maps.source.kbnTMS.kbnTMS.urlLabel": "磁贴地图 URL", + "xpack.maps.source.kbnTMS.noConfigErrorMessage": "在 kibana.yml 中找不到 map.tilemap.url 配置", + "xpack.maps.source.kbnTMS.noLayerAvailableHelptext": "没有可用的磁贴地图图层。让您的系统管理员在 kibana.yml 中设置“map.tilemap.url”。", + "xpack.maps.source.kbnTMS.urlLabel": "磁贴地图 URL", + "xpack.maps.source.kbnTMSDescription": "在 kibana.yml 中配置的地图磁贴", + "xpack.maps.source.kbnTMSTitle": "定制磁贴地图服务", + "xpack.maps.source.pewPew.destGeoFieldLabel": "目标", + "xpack.maps.source.pewPew.destGeoFieldPlaceholder": "选择目标地理位置字段", + "xpack.maps.source.pewPew.indexPatternLabel": "索引模式", + "xpack.maps.source.pewPew.indexPatternPlaceholder": "选择索引模式", + "xpack.maps.source.pewPew.inspectorDescription": "源-目标连接请求", + "xpack.maps.source.pewPew.metricsLabel": "指标", + "xpack.maps.source.pewPew.noIndexPatternErrorMessage": "找不到索引模式 {id}", + "xpack.maps.source.pewPew.noSourceAndDestDetails": "选定的索引模式不包含源和目标字段。", + "xpack.maps.source.pewPew.sourceGeoFieldLabel": "源", + "xpack.maps.source.pewPew.sourceGeoFieldPlaceholder": "选择源地理位置字段", + "xpack.maps.source.pewPewDescription": "源和目标之间的聚合数据路径", + "xpack.maps.source.pewPewTitle": "源-目标连接", + "xpack.maps.source.urlLabel": "URL", + "xpack.maps.source.vetorSource.formatErrorMessage": "无法从以下 URL 获取矢量形状:{format}", + "xpack.maps.source.vetorSource.requestFailedErrorMessage": "无法从以下 URL 获取矢量形状:{fetchUrl}", + "xpack.maps.source.wms.attributionLink": "属性文本必须附带链接", + "xpack.maps.source.wms.attributionText": "属性 url 必须附带文本", + "xpack.maps.source.wms.getCapabilitiesButtonText": "加载功能", + "xpack.maps.source.wms.getCapabilitiesErrorCalloutTitle": "无法加载服务元数据", + "xpack.maps.source.wms.layersHelpText": "使用图层名称逗号分隔列表", + "xpack.maps.source.wms.layersLabel": "图层", + "xpack.maps.source.wms.stylesHelpText": "使用样式名称逗号分隔列表", + "xpack.maps.source.wms.stylesLabel": "样式", + "xpack.maps.source.wms.urlLabel": "URL", + "xpack.maps.source.wmsDescription": "来自 OGC 标准 WMS 的地图", + "xpack.maps.source.wmsTitle": "Web 地图服务", + "xpack.maps.style.customColorRampLabel": "定制颜色渐变", + "xpack.maps.style.heatmap.displayNameLabel": "热图样式", + "xpack.maps.style.heatmap.resolutionStyleErrorMessage": "无法识别分辨率参数:{resolution}", + "xpack.maps.styles.vector.borderColorLabel": "边框颜色", + "xpack.maps.styles.vector.borderWidthLabel": "边框宽度", + "xpack.maps.styles.vector.fillColorLabel": "填充颜色", + "xpack.maps.styles.vector.orientationLabel": "符号方向", + "xpack.maps.styles.vector.selectFieldPlaceholder": "选择字段", + "xpack.maps.styles.vector.symbolSizeLabel": "符号大小", + "xpack.maps.toolbarOverlay.drawBounds.initialGeometryLabel": "边界", + "xpack.maps.toolbarOverlay.drawBoundsLabel": "绘制边界以筛选数据", + "xpack.maps.toolbarOverlay.drawBoundsLabelShort": "绘制边界", + "xpack.maps.toolbarOverlay.drawShape.initialGeometryLabel": "形状", + "xpack.maps.toolbarOverlay.drawShapeLabel": "绘制形状以筛选数据", + "xpack.maps.toolbarOverlay.drawShapeLabelShort": "绘制形状", + "xpack.maps.toolbarOverlay.tools.toolbarTitle": "工具", + "xpack.maps.toolbarOverlay.toolsControlTitle": "工具", + "xpack.maps.tooltip.allLayersLabel": "所有图层", + "xpack.maps.tooltip.closeAriaLabel": "关闭工具提示", + "xpack.maps.tooltip.filterOnPropertyAriaLabel": "基于属性筛选", + "xpack.maps.tooltip.filterOnPropertyTitle": "基于属性筛选", + "xpack.maps.tooltip.geometryFilterForm.createFilterButtonLabel": "创建筛选", + "xpack.maps.tooltip.geometryFilterForm.filterTooLargeMessage": "无法创建筛选。筛选已添加到 URL,此形状有过多的顶点,无法都容纳在 URL 中。", + "xpack.maps.tooltip.layerFilterLabel": "按图层筛选结果", + "xpack.maps.tooltip.loadingMsg": "正在加载", + "xpack.maps.tooltip.pageNumerText": "{total} 的 {pageNumber}", + "xpack.maps.tooltip.showGeometryFilterViewLinkLabel": "按几何筛选", + "xpack.maps.tooltip.toolsControl.cancelDrawButtonLabel": "取消", + "xpack.maps.tooltip.unableToLoadContentTitle": "无法加载工具提示内容", + "xpack.maps.tooltipSelector.addLabelWithCount": "添加 {count} 个", + "xpack.maps.tooltipSelector.addLabelWithoutCount": "添加", + "xpack.maps.tooltipSelector.grabButtonAriaLabel": "重新排序属性", + "xpack.maps.tooltipSelector.grabButtonTitle": "重新排序属性", + "xpack.maps.tooltipSelector.togglePopoverLabel": "添加", + "xpack.maps.tooltipSelector.trashButtonAriaLabel": "移除属性", + "xpack.maps.tooltipSelector.trashButtonTitle": "移除属性", + "xpack.maps.validatedRange.rangeErrorMessage": "必须介于 {min} 和 {max} 之间", + "xpack.maps.vector.dualSize.unitLabel": "px", + "xpack.maps.vector.size.unitLabel": "px", + "xpack.maps.vector.symbolAs.circleLabel": "圆", + "xpack.maps.vector.symbolAs.IconLabel": "图标", + "xpack.maps.vector.symbolLabel": "符号", + "xpack.maps.vectorLayer.noResultsFoundInJoinTooltip": "在词联接中未找到任何匹配结果", + "xpack.maps.vectorLayer.noResultsFoundTooltip": "找不到结果", + "xpack.maps.vectorStyleEditor.featureTypeButtonGroupLegend": "矢量功能按钮组", + "xpack.maps.vectorStyleEditor.lineLabel": "线", + "xpack.maps.vectorStyleEditor.pointLabel": "点", + "xpack.maps.vectorStyleEditor.polygonLabel": "多边形", + "xpack.maps.viewControl.latLabel": "纬度:", + "xpack.maps.viewControl.lonLabel": "经度:", + "xpack.maps.viewControl.zoomLabel": "缩放:", + "xpack.maps.visTypeAlias.description": "使用多个图层和索引创建地图并提供样式。\n使用 Maps 应用而非坐标地图和区域地图。\nMaps 应用提供更多的功能并更加易用。", + "xpack.maps.visTypeAlias.title": "Maps", + "xpack.maps.xyztmssource.attributionLink": "属性文本必须附带链接", + "xpack.maps.xyztmssource.attributionText": "属性 url 必须附带文本", + "xpack.ml.accessDenied.description": "您无权访问 ML 插件", + "xpack.ml.accessDenied.label": "权限不足", + "xpack.ml.annotationsTable.actionsColumnName": "操作", + "xpack.ml.annotationsTable.annotationColumnName": "注释", + "xpack.ml.annotationsTable.annotationsNotCreatedTitle": "没有为此作业创建注释", + "xpack.ml.annotationsTable.editAnnotationsTooltip": "编辑注释", + "xpack.ml.annotationsTable.editAnnotationsTooltipAriaLabel": "编辑注释", + "xpack.ml.annotationsTable.fromColumnName": "从", + "xpack.ml.annotationsTable.howToCreateAnnotationDescription": "要创建注释,请打开 {linkToSingleMetricView}", + "xpack.ml.annotationsTable.howToCreateAnnotationDescription.singleMetricViewerLinkText": "Single Metric Viewer", + "xpack.ml.annotationsTable.jobConfigurationNotSupportedInSingleMetricViewerAriaLabel": "Single Metric Viewer 中不支持作业配置", + "xpack.ml.annotationsTable.jobConfigurationNotSupportedInSingleMetricViewerTooltip": "Single Metric Viewer 中不支持作业配置", + "xpack.ml.annotationsTable.jobIdColumnName": "作业 ID", + "xpack.ml.annotationsTable.labelColumnName": "标签", + "xpack.ml.annotationsTable.lastModifiedByColumnName": "上次修改者", + "xpack.ml.annotationsTable.lastModifiedDateColumnName": "上次修改日期", + "xpack.ml.annotationsTable.openInSingleMetricViewerAriaLabel": "在 Single Metric Viewer 中打开", + "xpack.ml.annotationsTable.openInSingleMetricViewerTooltip": "在 Single Metric Viewer 中打开", + "xpack.ml.annotationsTable.toColumnName": "到", + "xpack.ml.anomaliesTable.actionsColumnName": "操作", + "xpack.ml.anomaliesTable.actualSortColumnName": "实际", + "xpack.ml.anomaliesTable.anomalyDetails.actualTitle": "实际", + "xpack.ml.anomaliesTable.anomalyDetails.anomalyDescriptionListMoreLinkText": "及另外 {othersCount} 个", + "xpack.ml.anomaliesTable.anomalyDetails.anomalyDescriptionShowLessLinkText": "显示更少", + "xpack.ml.anomaliesTable.anomalyDetails.anomalyDetailsTitle": "异常详情", + "xpack.ml.anomaliesTable.anomalyDetails.anomalyInLabel": "{anomalyDetector} 中的 {anomalySeverity} 异常", + "xpack.ml.anomaliesTable.anomalyDetails.anomalyTimeRangeLabel": "{anomalyTime} 至 {anomalyEndTime}", + "xpack.ml.anomaliesTable.anomalyDetails.categoryExamplesTitle": "类别示例", + "xpack.ml.anomaliesTable.anomalyDetails.causeValuesDescription": "{causeEntityValue}实际 {actualValue}典型 {typicalValue}可能性 {probabilityValue}", + "xpack.ml.anomaliesTable.anomalyDetails.causeValuesTitle": "{causeEntityName} 值", + "xpack.ml.anomaliesTable.anomalyDetails.descriptionTitle": "描述", + "xpack.ml.anomaliesTable.anomalyDetails.detailsOnHighestSeverityAnomalyTitle": "有关最高严重性异常的详情", + "xpack.ml.anomaliesTable.anomalyDetails.detailsTitle": "详情", + "xpack.ml.anomaliesTable.anomalyDetails.detectedInLabel": " 在 {sourcePartitionFieldName} {sourcePartitionFieldValue} 检测到", + "xpack.ml.anomaliesTable.anomalyDetails.examplesTitle": "示例", + "xpack.ml.anomaliesTable.anomalyDetails.fieldNameTitle": "fieldName", + "xpack.ml.anomaliesTable.anomalyDetails.foundForLabel": " 已为 {anomalyEntityName} {anomalyEntityValue} 找到", + "xpack.ml.anomaliesTable.anomalyDetails.functionTitle": "函数", + "xpack.ml.anomaliesTable.anomalyDetails.influencersTitle": "影响因素", + "xpack.ml.anomaliesTable.anomalyDetails.interimResultLabel": "中间结果", + "xpack.ml.anomaliesTable.anomalyDetails.jobIdTitle": "作业 ID", + "xpack.ml.anomaliesTable.anomalyDetails.multiBucketImpactTitle": "多存储桶影响", + "xpack.ml.anomaliesTable.anomalyDetails.multivariateDescription": "{sourceByFieldName} 中找到多变量关联;如果{sourceCorrelatedByFieldValue},{sourceByFieldValue} 将被视为有异常", + "xpack.ml.anomaliesTable.anomalyDetails.probabilityTitle": "可能性", + "xpack.ml.anomaliesTable.anomalyDetails.regexDescriptionAriaLabel": "描述", + "xpack.ml.anomaliesTable.anomalyDetails.regexDescriptionTooltip": "用于搜索匹配该类别的值(可能已截短至最大字符限制 {maxChars})的正则表达式", + "xpack.ml.anomaliesTable.anomalyDetails.regexTitle": "Regex", + "xpack.ml.anomaliesTable.anomalyDetails.termsDescriptionAriaLabel": "描述", + "xpack.ml.anomaliesTable.anomalyDetails.termsDescriptionTooltip": "该类别的值(可能已截短至最大字符限制({maxChars})中匹配的常见令牌的空格分隔列表", + "xpack.ml.anomaliesTable.anomalyDetails.termsTitle": "词", + "xpack.ml.anomaliesTable.anomalyDetails.timeTitle": "时间", + "xpack.ml.anomaliesTable.anomalyDetails.typicalTitle": "典型", + "xpack.ml.anomaliesTable.categoryExamplesColumnName": "类别示例", + "xpack.ml.anomaliesTable.detectorCell.rulesConfiguredTooltip": "个规则已为此检测工具配置", + "xpack.ml.anomaliesTable.detectorColumnName": "检测工具", + "xpack.ml.anomaliesTable.entityCell.addFilterAriaLabel": "添加筛选", + "xpack.ml.anomaliesTable.entityCell.addFilterTooltip": "添加筛选", + "xpack.ml.anomaliesTable.entityCell.removeFilterAriaLabel": "删除筛选", + "xpack.ml.anomaliesTable.entityCell.removeFilterTooltip": "删除筛选", + "xpack.ml.anomaliesTable.entityValueColumnName": "查找对象", + "xpack.ml.anomaliesTable.hideDetailsAriaLabel": "隐藏详情", + "xpack.ml.anomaliesTable.influencersCell.addFilterAriaLabel": "添加筛选", + "xpack.ml.anomaliesTable.influencersCell.addFilterTooltip": "添加筛选", + "xpack.ml.anomaliesTable.influencersCell.moreInfluencersLinkText": "及另外 {othersCount} 个", + "xpack.ml.anomaliesTable.influencersCell.removeFilterAriaLabel": "删除筛选", + "xpack.ml.anomaliesTable.influencersCell.removeFilterTooltip": "删除筛选", + "xpack.ml.anomaliesTable.influencersCell.showLessInfluencersLinkText": "显示更少", + "xpack.ml.anomaliesTable.influencersColumnName": "影响因素", + "xpack.ml.anomaliesTable.jobIdColumnName": "作业 ID", + "xpack.ml.anomaliesTable.linksMenu.configureRulesLabel": "配置规则", + "xpack.ml.anomaliesTable.linksMenu.loadingDetailsErrorMessage": "无法查看示例,因为加载有关类别 ID {categoryId} 的详细信息时出错", + "xpack.ml.anomaliesTable.linksMenu.noMappingCouldBeFoundErrorMessage": "无法查看 mlcategory 为 {categoryId} 的文档的示例,因为找不到分类字段 {categorizationFieldName} 的映射", + "xpack.ml.anomaliesTable.linksMenu.selectActionAriaLabel": "为 {time} 的异常选择操作", + "xpack.ml.anomaliesTable.linksMenu.unableToOpenLinkErrorMessage": "无法打开链接,因为加载有关类别 ID {categoryId} 的详细信息时出错", + "xpack.ml.anomaliesTable.linksMenu.unableToViewExamplesErrorMessage": "无法查看示例,因为未找到作业 ID {jobId} 的详细信息", + "xpack.ml.anomaliesTable.linksMenu.viewExamplesLabel": "查看示例", + "xpack.ml.anomaliesTable.linksMenu.viewSeriesLabel": "查看序列", + "xpack.ml.anomaliesTable.metricDescriptionSortColumnName": "描述", + "xpack.ml.anomaliesTable.noMatchingAnomaliesFoundTitle": "未找到任何匹配的异常", + "xpack.ml.anomaliesTable.severityColumnName": "严重性", + "xpack.ml.anomaliesTable.showDetailsAriaLabel": "显示详情", + "xpack.ml.anomaliesTable.timeColumnName": "时间", + "xpack.ml.anomaliesTable.typicalSortColumnName": "典型", + "xpack.ml.anomalyDetection.anomalyExplorerLabel": "Anomaly Explorer", + "xpack.ml.anomalyDetection.jobManagementLabel": "作业管理", + "xpack.ml.anomalyDetection.singleMetricViewerLabel": "Single Metric Viewer", + "xpack.ml.anomalyDetectionBreadcrumbLabel": "异常检测", + "xpack.ml.anomalyExplorerPageLabel": "Anomaly Explorer", + "xpack.ml.anomalyUtils.multiBucketImpact.highLabel": "高", + "xpack.ml.anomalyUtils.multiBucketImpact.lowLabel": "低", + "xpack.ml.anomalyUtils.multiBucketImpact.mediumLabel": "中", + "xpack.ml.anomalyUtils.multiBucketImpact.noneLabel": "无", + "xpack.ml.anomalyUtils.severity.criticalLabel": "紧急", + "xpack.ml.anomalyUtils.severity.majorLabel": "重大", + "xpack.ml.anomalyUtils.severity.minorLabel": "轻微", + "xpack.ml.anomalyUtils.severity.unknownLabel": "未知", + "xpack.ml.anomalyUtils.severity.warningLabel": "警告", + "xpack.ml.anomalyUtils.severityWithLow.lowLabel": "低", + "xpack.ml.calendarsEdit.calendarForm.allowedCharactersDescription": "使用小写字母数字(a-z 和 0-9)、连字符或下划线;必须以字母数字字符开头和结尾", + "xpack.ml.calendarsEdit.calendarForm.calendarIdLabel": "日历 ID", + "xpack.ml.calendarsEdit.calendarForm.calendarTitle": "日历 {calendarId}", + "xpack.ml.calendarsEdit.calendarForm.cancelButtonLabel": "取消", + "xpack.ml.calendarsEdit.calendarForm.createCalendarTitle": "创建新日历", + "xpack.ml.calendarsEdit.calendarForm.descriptionLabel": "描述", + "xpack.ml.calendarsEdit.calendarForm.eventsLabel": "事件", + "xpack.ml.calendarsEdit.calendarForm.groupsLabel": "组", + "xpack.ml.calendarsEdit.calendarForm.jobsLabel": "作业", + "xpack.ml.calendarsEdit.calendarForm.saveButtonLabel": "保存", + "xpack.ml.calendarsEdit.calendarForm.savingButtonLabel": "正在保存……", + "xpack.ml.calendarsEdit.canNotCreateCalendarWithExistingIdErrorMessag": "无法创建 ID 为 [{formCalendarId}] 的日历,因为它已经存在。", + "xpack.ml.calendarsEdit.errorWithCreatingCalendarErrorMessage": "创建日历 {calendarId} 时出错", + "xpack.ml.calendarsEdit.errorWithFetchingJobSummariesErrorMessage": "提取作业摘要时出错:{err}", + "xpack.ml.calendarsEdit.errorWithLoadingCalendarFromDataErrorMessage": "加载日历表单数据时出错。请尝试刷新页面。", + "xpack.ml.calendarsEdit.errorWithLoadingCalendarsErrorMessage": "加载日历时出错:{err}", + "xpack.ml.calendarsEdit.errorWithLoadingGroupsErrorMessage": "加载组时出错:{err}", + "xpack.ml.calendarsEdit.errorWithUpdatingCalendarErrorMessage": "保存日历 {calendarId} 时出错。请尝试刷新页面。", + "xpack.ml.calendarsEdit.eventsTable.cancelButtonLabel": "取消", + "xpack.ml.calendarsEdit.eventsTable.deleteButtonLabel": "删除", + "xpack.ml.calendarsEdit.eventsTable.descriptionColumnName": "描述", + "xpack.ml.calendarsEdit.eventsTable.endColumnName": "结束", + "xpack.ml.calendarsEdit.eventsTable.importButtonLabel": "导入", + "xpack.ml.calendarsEdit.eventsTable.importEventsButtonLabel": "导入事件", + "xpack.ml.calendarsEdit.eventsTable.importEventsDescription": "从 ICS 文件导入事件。", + "xpack.ml.calendarsEdit.eventsTable.importEventsTitle": "导入事件", + "xpack.ml.calendarsEdit.eventsTable.newEventButtonLabel": "新建事件", + "xpack.ml.calendarsEdit.eventsTable.startColumnName": "开始", + "xpack.ml.calendarsEdit.importedEvents.eventsToImportTitle": "要导入的事件:{eventsCount}", + "xpack.ml.calendarsEdit.importedEvents.includePastEventsLabel": "包含过去的事件", + "xpack.ml.calendarsEdit.importedEvents.recurringEventsNotSupportedDescription": "不支持重复事件。仅导入第一个事件。", + "xpack.ml.calendarsEdit.importModal.couldNotParseICSFileErrorMessage": "无法解析 ICS 文件。", + "xpack.ml.calendarsEdit.importModal.selectOrDragAndDropFilePromptText": "选择或拖放文件", + "xpack.ml.calendarsEdit.newEventModal.addButtonLabel": "添加", + "xpack.ml.calendarsEdit.newEventModal.cancelButtonLabel": "取消", + "xpack.ml.calendarsEdit.newEventModal.createNewEventTitle": "创建新事件", + "xpack.ml.calendarsEdit.newEventModal.descriptionLabel": "描述", + "xpack.ml.calendarsEdit.newEventModal.endDateAriaLabel": "结束日期", + "xpack.ml.calendarsEdit.newEventModal.fromLabel": "从:", + "xpack.ml.calendarsEdit.newEventModal.startDateAriaLabel": "开始日期", + "xpack.ml.calendarsEdit.newEventModal.toLabel": "到:", + "xpack.ml.calendarsList.deleteCalendars.calendarsLabel": "{calendarsToDeleteCount} 个日历", + "xpack.ml.calendarsList.deleteCalendars.deletingCalendarErrorMessage": "删除日历 {calendarId} 时出错。{errorMessage}", + "xpack.ml.calendarsList.deleteCalendars.deletingCalendarsNotificationMessage": "正在删除 {messageId}", + "xpack.ml.calendarsList.deleteCalendars.deletingCalendarSuccessNotificationMessage": "已删除 {messageId}", + "xpack.ml.calendarsList.deleteCalendarsModal.cancelButtonLabel": "取消", + "xpack.ml.calendarsList.deleteCalendarsModal.deleteButtonLabel": "删除", + "xpack.ml.calendarsList.deleteCalendarsModal.deleteCalendarsDescription": "是否删除{calendarsCount, plural, one {此日历} other {这些日历}}?{calendarsList}", + "xpack.ml.calendarsList.deleteCalendarsModal.deleteCalendarTitle": "删除日历", + "xpack.ml.calendarsList.errorWithLoadingListOfCalendarsErrorMessage": "加载日历列表时出错。", + "xpack.ml.calendarsList.table.deleteButtonLabel": "删除", + "xpack.ml.calendarsList.table.eventsColumnName": "事件", + "xpack.ml.calendarsList.table.eventsCountLabel": "{eventsLength, plural, one {# 个事件} other {# 个事件}}", + "xpack.ml.calendarsList.table.idColumnName": "ID", + "xpack.ml.calendarsList.table.jobsColumnName": "作业", + "xpack.ml.calendarsList.table.newButtonLabel": "新建", + "xpack.ml.checkLicense.licenseHasExpiredMessage": "您的 {licenseTypeName} Machine Learning 许可证已过期。", + "xpack.ml.checkLicense.licenseInformationNotAvailableThisTimeMessage": "您不能使用 Machine Learning,因为许可证信息当前不可用。", + "xpack.ml.checkLicense.mlIsUnavailableMessage": "Machine Learning 不可用", + "xpack.ml.controls.checkboxShowCharts.showChartsCheckboxLabel": "显示图表", + "xpack.ml.controls.selectInterval.autoLabel": "自动", + "xpack.ml.controls.selectInterval.dayLabel": "1 天", + "xpack.ml.controls.selectInterval.hourLabel": "1 小时", + "xpack.ml.controls.selectInterval.showAllLabel": "全部显示", + "xpack.ml.controls.selectSeverity.criticalLabel": "紧急", + "xpack.ml.controls.selectSeverity.majorLabel": "重大", + "xpack.ml.controls.selectSeverity.minorLabel": "轻微", + "xpack.ml.controls.selectSeverity.scoreDetailsDescription": "分数 {value} 及以上", + "xpack.ml.controls.selectSeverity.warningLabel": "警告", + "xpack.ml.customUrlEditor.discoverLabel": "Discover", + "xpack.ml.customUrlEditor.kibanaDashboardLabel": "Kibana 仪表板", + "xpack.ml.customUrlEditor.otherLabel": "其他", + "xpack.ml.customUrlEditorList.deleteCustomUrlAriaLabel": "删除定制 URL", + "xpack.ml.customUrlEditorList.deleteCustomUrlTooltip": "删除定制 URL", + "xpack.ml.customUrlEditorList.invalidTimeRangeFormatErrorMessage": "格式无效", + "xpack.ml.customUrlEditorList.labelIsNotUniqueErrorMessage": "必须提供唯一的标签", + "xpack.ml.customUrlEditorList.labelLabel": "标签", + "xpack.ml.customUrlEditorList.obtainingUrlToTestConfigurationErrorMessage": "获取 URL 用于测试配置时出错", + "xpack.ml.customUrlEditorList.testCustomUrlAriaLabel": "测试定制 URL", + "xpack.ml.customUrlEditorList.testCustomUrlTooltip": "测试定制 URL", + "xpack.ml.customUrlEditorList.timeRangeLabel": "时间范围", + "xpack.ml.customUrlEditorList.urlLabel": "URL", + "xpack.ml.customUrlsEditor.createNewCustomUrlTitle": "新建定制 URL", + "xpack.ml.customUrlsEditor.dashboardNameLabel": "仪表板名称", + "xpack.ml.customUrlsEditor.indexPatternLabel": "索引模式", + "xpack.ml.customUrlsEditor.intervalLabel": "时间间隔", + "xpack.ml.customUrlsEditor.invalidLabelErrorMessage": "必须提供唯一的标签", + "xpack.ml.customUrlsEditor.labelLabel": "标签", + "xpack.ml.customUrlsEditor.linkToLabel": "链接到", + "xpack.ml.customUrlsEditor.queryEntitiesLabel": "查询实体", + "xpack.ml.customUrlsEditor.selectEntitiesPlaceholder": "选择实体", + "xpack.ml.customUrlsEditor.timeRangeLabel": "时间范围", + "xpack.ml.customUrlsEditor.urlLabel": "URL", + "xpack.ml.customUrlsList.invalidIntervalFormatErrorMessage": "时间间隔格式无效", + "xpack.ml.dataframe.analytics.create.advancedEditor.codeEditorAriaLabel": "高级分析作业编辑器", + "xpack.ml.dataframe.analytics.create.advancedEditor.configRequestBody": "配置请求正文", + "xpack.ml.dataframe.analytics.create.advancedEditor.jobIdExistsError": "已存在具有此 ID 的分析作业。", + "xpack.ml.dataframe.analytics.create.advancedEditor.jobIdInputAriaLabel": "选择唯一的分析作业 ID。", + "xpack.ml.dataframe.analytics.create.advancedEditor.jobIdInvalidError": "只能包含小写字母数字字符(a-z 和 0-9)、连字符和下划线,并且必须以字母数字字符开头和结尾。", + "xpack.ml.dataframe.analytics.create.advancedEditor.jobIdLabel": "分析作业 ID", + "xpack.ml.dataframe.analytics.create.advancedEditorMessage.dependentVariableEmpty": "因变量字段不得为空。", + "xpack.ml.dataframe.analytics.create.advancedEditorMessage.destinationIndexNameEmpty": "目标索引名称不得为空。", + "xpack.ml.dataframe.analytics.create.advancedEditorMessage.destinationIndexNameValid": "目标索引名称无效。", + "xpack.ml.dataframe.analytics.create.advancedEditorMessage.sourceIndexNameEmpty": "源索引名称不得为空。", + "xpack.ml.dataframe.analytics.create.advancedEditorMessage.sourceIndexNameValid": "源索引名称无效。", + "xpack.ml.dataframe.analytics.create.createIndexPatternErrorMessage": "创建 Kibana 索引模式时发生错误:", + "xpack.ml.dataframe.analytics.create.createIndexPatternLabel": "创建索引模式", + "xpack.ml.dataframe.analytics.create.createIndexPatternSuccessMessage": "Kibana 索引模式 {indexPatternName} 已创建。", + "xpack.ml.dataframe.analytics.create.dependentVariableInputAriaLabel": "输入要用作因变量的字段。", + "xpack.ml.dataframe.analytics.create.dependentVariableLabel": "因变量", + "xpack.ml.dataframe.analytics.create.dependentVariableOptionsFetchError": "获取字段时出现问题。请刷新页面并重试。", + "xpack.ml.dataframe.analytics.create.dependentVariableOptionsNoNumericalFields": "没有为此索引模式找到任何数值类型字段。", + "xpack.ml.dataframe.analytics.create.dependentVariablePlaceholder": "因变量", + "xpack.ml.dataframe.analytics.create.destinationIndexHelpText": "已存在具有此名称的索引。请注意,运行此分析作业将会修改此目标索引。", + "xpack.ml.dataframe.analytics.create.destinationIndexInputAriaLabel": "选择唯一目标索引名称。", + "xpack.ml.dataframe.analytics.create.destinationIndexInvalidError": "目标索引名称无效。", + "xpack.ml.dataframe.analytics.create.destinationIndexLabel": "目标 IP", + "xpack.ml.dataframe.analytics.create.duplicateIndexPatternErrorMessage": "创建 Kibana 索引模式时发生错误:", + "xpack.ml.dataframe.analytics.create.duplicateIndexPatternErrorMessageError": "索引模式 {indexPatternName} 已存在。", + "xpack.ml.dataframe.analytics.create.enableAdvancedEditorHelpText": "您不能从高级编辑器切回到此表单。", + "xpack.ml.dataframe.analytics.create.enableAdvancedEditorSwitch": "启用高级编辑器", + "xpack.ml.dataframe.analytics.create.errorCreatingDataFrameAnalyticsJob": "创建数据帧分析作业时发生错误:", + "xpack.ml.dataframe.analytics.create.errorGettingDataFrameAnalyticsList": "获取现有数据帧分析作业 ID 时发生错误:", + "xpack.ml.dataframe.analytics.create.errorGettingDataFrameIndexNames": "获取现有索引名称时发生错误:", + "xpack.ml.dataframe.analytics.create.errorGettingIndexPatternTitles": "获取现有索引模式标题时发生错误:", + "xpack.ml.dataframe.analytics.create.errorStartingDataFrameAnalyticsJob": "启动数据帧分析作业时发生错误:", + "xpack.ml.dataframe.analytics.create.flyoutCancelButton": "取消", + "xpack.ml.dataframe.analytics.create.flyoutCloseButton": "关闭", + "xpack.ml.dataframe.analytics.create.flyoutCreateButton": "创建", + "xpack.ml.dataframe.analytics.create.flyoutHeaderTitle": "创建分析作业", + "xpack.ml.dataframe.analytics.create.flyoutStartButton": "开始", + "xpack.ml.dataframe.analytics.create.indexPatternAlreadyExistsError": "具有此名称的索引模式已存在。", + "xpack.ml.dataframe.analytics.create.indexPatternExistsError": "具有此名称的索引模式已存在。", + "xpack.ml.dataframe.analytics.create.jobIdExistsError": "已存在具有此 ID 的分析作业。", + "xpack.ml.dataframe.analytics.create.jobIdInputAriaLabel": "选择唯一的分析作业 ID。", + "xpack.ml.dataframe.analytics.create.jobIdInvalidError": "只能包含小写字母数字字符(a-z 和 0-9)、连字符和下划线,并且必须以字母数字字符开头和结尾。", + "xpack.ml.dataframe.analytics.create.jobIdInvalidMaxLengthErrorMessage": "作业 ID 的长度不得超过 {maxLength, plural, one {# 个字符} other {# 个字符}}。", + "xpack.ml.dataframe.analytics.create.jobIdLabel": "作业 ID", + "xpack.ml.dataframe.analytics.create.jobIdPlaceholder": "作业 ID", + "xpack.ml.dataframe.analytics.create.jobTypeLabel": "作业类型", + "xpack.ml.dataframe.analytics.create.outlierDetectionHelpText": "离群值检测作业需要映射为类表数据结构的源索引,将仅分析数值和布尔值字段。请使用高级编辑器应用定制选项,如模型内存限制和分析类型。", + "xpack.ml.dataframe.analytics.create.outlierRegressionHelpText": "回归作业将仅分析数值字段。请使用高级编辑器来应用定制选项,如模型内存限制和预测字段名称。", + "xpack.ml.dataframe.analytics.create.sourceIndexFieldCheckError": "检查数值字段时出现问题。请刷新页面并重试。", + "xpack.ml.dataframe.analytics.create.sourceIndexHelpText": "此索引模式不包含任何数值类型字段。分析作业可能无法提供任何离群值。", + "xpack.ml.dataframe.analytics.create.sourceIndexInputAriaLabel": "源索引模式或搜索。", + "xpack.ml.dataframe.analytics.create.sourceIndexInvalidError": "源索引名称无效,其不能包含空格或以下字符:{characterList}", + "xpack.ml.dataframe.analytics.create.sourceIndexLabel": "源索引", + "xpack.ml.dataframe.analytics.create.sourceIndexPlaceholder": "选择源索引模式或已保存搜索。", + "xpack.ml.dataframe.analytics.create.startDataFrameAnalyticsSuccessMessage": "数据帧分析 {jobId} 启动请求已确认。", + "xpack.ml.dataframe.analytics.create.trainingPercentLabel": "训练百分比", + "xpack.ml.dataframe.analytics.exploration.experimentalBadgeLabel": "实验性", + "xpack.ml.dataframe.analytics.exploration.experimentalBadgeTooltipContent": "数据帧分析为实验功能。我们很乐意听取您的反馈意见。", + "xpack.ml.dataframe.analytics.exploration.fieldSelection": "已选择 {selectedFieldsLength, number} 个{docFieldsCount, plural, one {字段} other {字段}},共 {docFieldsCount, number} 个", + "xpack.ml.dataframe.analytics.exploration.indexArrayBadgeContent": "数组", + "xpack.ml.dataframe.analytics.exploration.indexArrayToolTipContent": "无法显示此基于数组的列的完整内容。", + "xpack.ml.dataframe.analytics.exploration.indexError": "加载索引数据时出错。", + "xpack.ml.dataframe.analytics.exploration.indexObjectBadgeContent": "对象", + "xpack.ml.dataframe.analytics.exploration.indexObjectToolTipContent": "无法显示此基于对象的列的完整内容。", + "xpack.ml.dataframe.analytics.exploration.jobIdTitle": "作业 ID {jobId}", + "xpack.ml.dataframe.analytics.exploration.noDataCalloutBody": "该索引的查询未返回结果。请确保索引包含文档且您的查询限制不过于严格。", + "xpack.ml.dataframe.analytics.exploration.selectColumnsAriaLabel": "选择列", + "xpack.ml.dataframe.analytics.exploration.selectFieldsPopoverTitle": "选择字段", + "xpack.ml.dataframe.analytics.exploration.title": "分析浏览", + "xpack.ml.dataframe.analytics.regressionExploration.evaluateError": "加载数据时出错。", + "xpack.ml.dataframe.analytics.regressionExploration.generalError": "加载数据时出错。", + "xpack.ml.dataframe.analytics.regressionExploration.generalizationErrorTitle": "泛化误差", + "xpack.ml.dataframe.analytics.regressionExploration.meanSquaredErrorText": "均方误差", + "xpack.ml.dataframe.analytics.regressionExploration.noDataCalloutBody": "该索引的查询未返回结果。请确保作业已完成且索引包含文档。", + "xpack.ml.dataframe.analytics.regressionExploration.noDataCalloutTitle": "空的索引查询结果。", + "xpack.ml.dataframe.analytics.regressionExploration.noIndexCalloutBody": "该索引的查询未返回结果。请确保目标索引存在且包含文档。", + "xpack.ml.dataframe.analytics.regressionExploration.rSquaredText": "R 平方", + "xpack.ml.dataframe.analytics.regressionExploration.trainingErrorTitle": "训练误差", + "xpack.ml.dataframe.analyticsList.completeBatchAnalyticsToolTip": "{analyticsId} 为已完成的分析作业,无法重新启动。", + "xpack.ml.dataframe.analyticsList.createDataFrameAnalyticsButton": "创建分析作业", + "xpack.ml.dataframe.analyticsList.deleteActionDisabledToolTipContent": "停止数据帧分析,才能将其删除。", + "xpack.ml.dataframe.analyticsList.deleteActionName": "删除", + "xpack.ml.dataframe.analyticsList.deleteAnalyticsErrorMessage": "删除数据帧分析 {analyticsId} 时发生错误:{error}", + "xpack.ml.dataframe.analyticsList.deleteAnalyticsSuccessMessage": "数据帧分析 {analyticsId} 删除请求已确认。", + "xpack.ml.dataframe.analyticsList.deleteModalBody": "是否确定要删除此分析作业?分析作业的目标索引和可选 Kibana 索引模式将不会删除。", + "xpack.ml.dataframe.analyticsList.deleteModalCancelButton": "取消", + "xpack.ml.dataframe.analyticsList.deleteModalDeleteButton": "删除", + "xpack.ml.dataframe.analyticsList.deleteModalTitle": "删除 {analyticsId}", + "xpack.ml.dataframe.analyticsList.destinationIndex": "目标 IP", + "xpack.ml.dataFrame.analyticsList.emptyPromptButtonText": "创建您的首个数据帧分析作业", + "xpack.ml.dataFrame.analyticsList.emptyPromptTitle": "未找到任何数据帧分析作业", + "xpack.ml.dataFrame.analyticsList.errorPromptTitle": "获取数据帧分析列表时发生错误。", + "xpack.ml.dataframe.analyticsList.expandedRow.tabs.jobSettings.progress": "进度", + "xpack.ml.dataframe.analyticsList.expandedRow.tabs.jobSettings.state": "状态", + "xpack.ml.dataframe.analyticsList.expandedRow.tabs.jobSettings.stats": "统计", + "xpack.ml.dataframe.analyticsList.expandedRow.tabs.jobSettingsLabel": "作业详情", + "xpack.ml.dataframe.analyticsList.experimentalBadgeLabel": "实验性", + "xpack.ml.dataframe.analyticsList.experimentalBadgeTooltipContent": "数据帧分析为实验功能。我们很乐意听取您的反馈意见。", + "xpack.ml.dataframe.analyticsList.progress": "进度", + "xpack.ml.dataframe.analyticsList.refreshButtonLabel": "刷新", + "xpack.ml.dataframe.analyticsList.rowCollapse": "隐藏 {analyticsId} 的详情", + "xpack.ml.dataframe.analyticsList.rowExpand": "显示 {analyticsId} 的详情", + "xpack.ml.dataframe.analyticsList.sourceIndex": "源索引", + "xpack.ml.dataframe.analyticsList.startActionName": "开始", + "xpack.ml.dataframe.analyticsList.startAnalyticsErrorMessage": "启动数据帧分析 {analyticsId} 时发生错误:{error}", + "xpack.ml.dataframe.analyticsList.startAnalyticsSuccessMessage": "数据帧分析 {analyticsId} 启动请求已确认。", + "xpack.ml.dataframe.analyticsList.startModalBody": "数据帧分析作业将增加集群的搜索和索引负荷。如果负荷超载,请停止分析作业。是否确定要启动此分析作业?", + "xpack.ml.dataframe.analyticsList.startModalCancelButton": "取消", + "xpack.ml.dataframe.analyticsList.startModalStartButton": "开始", + "xpack.ml.dataframe.analyticsList.startModalTitle": "启动 {analyticsId}", + "xpack.ml.dataframe.analyticsList.status": "状态", + "xpack.ml.dataframe.analyticsList.statusFilter": "状态", + "xpack.ml.dataframe.analyticsList.stopActionName": "停止", + "xpack.ml.dataframe.analyticsList.stopAnalyticsErrorMessage": "停止数据帧分析 {analyticsId} 时发生错误:{error}", + "xpack.ml.dataframe.analyticsList.stopAnalyticsSuccessMessage": "数据帧分析 {analyticsId} 停止请求已确认。", + "xpack.ml.dataframe.analyticsList.tableActionLabel": "操作", + "xpack.ml.dataframe.analyticsList.title": "分析作业", + "xpack.ml.dataframe.analyticsList.type": "类型", + "xpack.ml.dataframe.analyticsList.viewActionName": "查看", + "xpack.ml.dataframe.analyticsList.viewAriaLabel": "查看", + "xpack.ml.dataframe.stepCreateForm.createDataFrameAnalyticsSuccessMessage": "数据帧分析 {jobId} 创建请求已确认。", + "xpack.ml.dataframe.stepDetailsForm.destinationIndexInvalidErrorLink": "详细了解索引名称限制。", + "xpack.ml.dataFrameAnalyticsBreadcrumbs.indexLabel": "索引", + "xpack.ml.datavisualizer.actionsPanel.advancedDescription": "使用全部选项为更高级的用例创建作业", + "xpack.ml.datavisualizer.actionsPanel.advancedTitle": "高级", + "xpack.ml.datavisualizer.actionsPanel.createJobDescription": "使用“高级作业”向导创建作业,以查找此数据中的异常:", + "xpack.ml.datavisualizer.actionsPanel.createJobTitle": "创建作业", + "xpack.ml.datavisualizer.actionsPanel.selectKnownConfigurationDescription": "选择已识别数据的已知配置:", + "xpack.ml.datavisualizer.dataLoader.internalServerErrorMessage": "加载索引 {index} 中的数据时出错。{message}。请求可能已超时。请尝试使用较小的样例大小或缩小时间范围。", + "xpack.ml.datavisualizer.fieldsPanel.fieldsCountDescription": "{wrappedCardsCount} {cardsCount, plural, one { 个字段存在} other { 个字段存在}}于文档中(共 {wrappedTotalFieldCount} 个)", + "xpack.ml.datavisualizer.fieldsPanel.filterFieldsPlaceholder": "筛选", + "xpack.ml.datavisualizer.fieldsPanel.searchBarError": "运行搜索时发生错误。{message}。", + "xpack.ml.datavisualizer.fieldsPanel.showAllCountDescription": "{wrappedCardsCount} {cardsCount, plural, one { 个字段} other { 个字段}}({wrappedPopulatedFieldCount} {populatedFieldCount, plural, one { 存在} other { 存在}}于文档中)", + "xpack.ml.datavisualizer.fieldsPanel.showEmptyFieldsLabel": "显示空字段", + "xpack.ml.datavisualizer.fieldTypesSelect.allFieldsTypeOptionLabel": "所有字段类型", + "xpack.ml.datavisualizer.fieldTypesSelect.selectAriaLabel": "选择要显示的字段类型", + "xpack.ml.datavisualizer.fieldTypesSelect.typeOptionLabel": "{fieldType} 类型", + "xpack.ml.dataVisualizer.fileBasedLabel": "文件", + "xpack.ml.datavisualizer.page.errorLoadingDataMessage": "加载索引 {index} 中的数据时出错。{message}", + "xpack.ml.datavisualizer.page.fieldsPanelTitle": "字段", + "xpack.ml.datavisualizer.page.metricsPanelTitle": "指标", + "xpack.ml.datavisualizer.searchPanel.allOptionLabel": "全部", + "xpack.ml.datavisualizer.searchPanel.documentsPerShardLabel": "每个分片的文档,共 {wrappedTotalCount} {totalCount, plural, one { 个文档 } other { 个文档}}", + "xpack.ml.datavisualizer.searchPanel.kqlEditOnlyLabel": "当前仅可以编辑 KQL 已保存搜索", + "xpack.ml.datavisualizer.searchPanel.queryBarPlaceholder": "选择较小的样例大小将减少查询运行时间和集群上的负载。", + "xpack.ml.datavisualizer.searchPanel.queryBarPlaceholderText": "搜索……(例如,status:200 AND extension:\"PHP\")", + "xpack.ml.datavisualizer.searchPanel.sampleLabel": "采样", + "xpack.ml.datavisualizer.searchPanel.sampleSizeAriaLabel": "选择要采样的文档数目", + "xpack.ml.datavisualizer.selector.dataVisualizerDescription": "Machine Learning Data Visualizer 工具通过分析日志文件或现有 Elasticsearch 索引中的指标和字段,帮助您理解数据。", + "xpack.ml.datavisualizer.selector.dataVisualizerTitle": "数据可视化工具", + "xpack.ml.datavisualizer.selector.experimentalBadgeLabel": "实验性", + "xpack.ml.datavisualizer.selector.experimentalBadgeTooltipLabel": "实验功能。我们很乐意听取您的反馈意见。", + "xpack.ml.datavisualizer.selector.importDataDescription": "从日志文件导入数据。您可以上传最大 100 MB 的文件。", + "xpack.ml.datavisualizer.selector.importDataTitle": "导入数据", + "xpack.ml.datavisualizer.selector.selectIndexButtonLabel": "选择索引", + "xpack.ml.datavisualizer.selector.selectIndexPatternDescription": "可视化现有 Elasticsearch 索引中的数据。", + "xpack.ml.datavisualizer.selector.selectIndexPatternTitle": "选择索引模式", + "xpack.ml.datavisualizer.selector.startTrialButtonLabel": "开始试用", + "xpack.ml.datavisualizer.selector.startTrialTitle": "开始试用", + "xpack.ml.datavisualizer.selector.uploadFileButtonLabel": "上传文件", + "xpack.ml.datavisualizerBreadcrumbLabel": "数据可视化工具", + "xpack.ml.dataVisualizerPageLabel": "数据可视化工具", + "xpack.ml.dfAnalyticsList.analyticsDetails.messagesPane.errorMessage": "无法加载消息", + "xpack.ml.explorer.annotationsTitle": "注释", + "xpack.ml.explorer.anomaliesTitle": "异常", + "xpack.ml.explorer.anomalyTimelineTitle": "异常时间线", + "xpack.ml.explorer.charts.detectorLabel": "{detectorLabel}{br}y 轴事件分布按 “{fieldName}” 分割", + "xpack.ml.explorer.charts.infoTooltip.aggregationIntervalTitle": "聚合时间间隔", + "xpack.ml.explorer.charts.infoTooltip.chartEventDistributionDescription": "灰点表示 {byFieldValuesParam} 的样例随时间发生的近似分布情况,其中顶部的事件类型较频繁,底部的事件类型较少。", + "xpack.ml.explorer.charts.infoTooltip.chartFunctionTitle": "图表功能", + "xpack.ml.explorer.charts.infoTooltip.chartPopulationDistributionDescription": "灰点表示 {overFieldValuesParam} 样例的值随时间的近似分布。", + "xpack.ml.explorer.charts.infoTooltip.jobIdTitle": "作业 ID", + "xpack.ml.explorer.charts.openInSingleMetricViewerButtonLabel": "在 Single Metric Viewer 中打开", + "xpack.ml.explorer.charts.tooManyBucketsDescription": "此选项包含太多要显示的时段。最好设置一个较短的时间范围来查看仪表板。", + "xpack.ml.explorer.charts.viewLabel": "查看", + "xpack.ml.explorer.createNewJobLinkText": "创建新作业", + "xpack.ml.explorer.distributionChart.anomalyScoreLabel": "异常分数", + "xpack.ml.explorer.distributionChart.entityLabel": "实体", + "xpack.ml.explorer.distributionChart.typicalLabel": "典型", + "xpack.ml.explorer.distributionChart.unusualByFieldValuesLabel": "{ numberOfCauses, plural, one {# 个异常 {byFieldName} 值} other {#{plusSign} 个异常 {byFieldName} 值}}", + "xpack.ml.explorer.distributionChart.valueLabel": "值", + "xpack.ml.explorer.distributionChart.valueWithoutAnomalyScoreLabel": "值", + "xpack.ml.explorer.fetchingSuggestionsErrorMessage": "获取建议时出错", + "xpack.ml.explorer.intervalLabel": "时间间隔", + "xpack.ml.explorer.invalidKuerySyntaxErrorMessage": "kuery 语法无效", + "xpack.ml.explorer.invalidKuerySyntaxErrorMessageFromTable": "查询栏中的语法无效。输入必须是有效的 Kibana 查询语言 (KQL)", + "xpack.ml.explorer.jobIdLabel": "作业 ID", + "xpack.ml.explorer.jobScoreAcrossAllInfluencersLabel": "(所有影响因素的作业分数)", + "xpack.ml.explorer.kueryBar.filterPlaceholder": "按影响因素字段筛选……({queryExample})", + "xpack.ml.explorer.limitLabel": "限制", + "xpack.ml.explorer.loadingLabel": "正在加载", + "xpack.ml.explorer.noConfiguredInfluencersTooltip": "“顶级影响因素”列表被隐藏,因为没有为所选作业配置影响因素。", + "xpack.ml.explorer.noJobsFoundLabel": "找不到作业", + "xpack.ml.explorer.noResultsFoundLabel": "找不到结果", + "xpack.ml.explorer.overallLabel": "总体", + "xpack.ml.explorer.overallSwimlaneUnfilteredLabel": "{label}(未筛选)", + "xpack.ml.explorer.severityThresholdLabel": "严重性阈值", + "xpack.ml.explorer.singleMetricChart.actualLabel": "实际", + "xpack.ml.explorer.singleMetricChart.anomalyScoreLabel": "异常分数", + "xpack.ml.explorer.singleMetricChart.multiBucketImpactLabel": "多存储桶影响", + "xpack.ml.explorer.singleMetricChart.scheduledEventsLabel": "已计划事件", + "xpack.ml.explorer.singleMetricChart.typicalLabel": "典型", + "xpack.ml.explorer.singleMetricChart.valueLabel": "值", + "xpack.ml.explorer.singleMetricChart.valueWithoutAnomalyScoreLabel": "值", + "xpack.ml.explorer.sortedByMaxAnomalyScoreForTimeFormattedLabel": "(按 {viewByLoadedForTimeFormatted} 的异常分数最大值排序)", + "xpack.ml.explorer.sortedByMaxAnomalyScoreLabel": "(按异常分数最大值排序)", + "xpack.ml.explorer.swimlane.maxAnomalyScoreLabel": "最大异常分数", + "xpack.ml.explorer.topInfuencersTitle": "顶级影响因素", + "xpack.ml.explorer.tryWideningTimeSelectionLabel": "请尝试扩大时间选择范围或进一步向前追溯", + "xpack.ml.explorer.viewByLabel": "查看者", + "xpack.ml.feature.reserved.description": "要向用户授予访问权限,还应分配 machine_learning_user 或 machine_learning_admin 角色。", + "xpack.ml.featureRegistry.mlFeatureName": "机器学习", + "xpack.ml.fieldDataCard.cardBoolean.documentsCountDescription": "{count, plural, zero {# 个文档} one {# 个文档} other {# 个文档}} ({docsPercent}%)", + "xpack.ml.fieldDataCard.cardBoolean.valuesLabel": "值", + "xpack.ml.fieldDataCard.cardDate.documentsCountDescription": "{count, plural, zero {# 个文档} one {# 个文档} other {# 个文档}} ({docsPercent}%)", + "xpack.ml.fieldDataCard.cardDate.earliestDescription": "最早的 {earliestFormatted}", + "xpack.ml.fieldDataCard.cardDate.latestDescription": "最新的 {latestFormatted}", + "xpack.ml.fieldDataCard.cardDocumentCount.calculatedOverAllDocumentsLabel": "计算所有文档", + "xpack.ml.fieldDataCard.cardGeoPoint.distinctCountDescription": "{cardinality} 不同的 {cardinality, plural, zero {值} one {value} 其他 {values}}", + "xpack.ml.fieldDataCard.cardGeoPoint.documentsCountDescription": "{count, plural, zero {# 个文档} one {# 个文档} other {# 个文档}} ({docsPercent}%)", + "xpack.ml.fieldDataCard.cardIp.distinctCountDescription": "{cardinality} 不同的 {cardinality, plural, zero {值} one {value} 其他 {values}}", + "xpack.ml.fieldDataCard.cardIp.documentsCountDescription": "{count, plural, zero {# 个文档} one {# 个文档} other {# 个文档}} ({docsPercent}%)", + "xpack.ml.fieldDataCard.cardIp.topValuesLabel": "排在前面的值", + "xpack.ml.fieldDataCard.cardKeyword.distinctCountDescription": "{cardinality} 不同的 {cardinality, plural, zero {值} one {value} 其他 {values}}", + "xpack.ml.fieldDataCard.cardKeyword.documentsCountDescription": "{count, plural, zero {# 个文档} one {# 个文档} other {# 个文档}} ({docsPercent}%)", + "xpack.ml.fieldDataCard.cardKeyword.topValuesLabel": "排在前面的值", + "xpack.ml.fieldDataCard.cardNumber.details.distributionOfValuesLabel": "值分布", + "xpack.ml.fieldDataCard.cardNumber.details.topValuesLabel": "排在前面的值", + "xpack.ml.fieldDataCard.cardNumber.displayingPercentilesLabel": "显示 {minPercent} - {maxPercent} 百分位数", + "xpack.ml.fieldDataCard.cardNumber.distinctCountDescription": "{cardinality} 不同的 {cardinality, plural, zero {值} one {value} 其他 {values}}", + "xpack.ml.fieldDataCard.cardNumber.documentsCountDescription": "{count, plural, zero {# 个文档} one {# 个文档} other {# 个文档}} ({docsPercent}%)", + "xpack.ml.fieldDataCard.cardNumber.maxLabel": "最大值", + "xpack.ml.fieldDataCard.cardNumber.medianLabel": "中值", + "xpack.ml.fieldDataCard.cardNumber.minLabel": "最小值", + "xpack.ml.fieldDataCard.cardNumber.selectMetricDetailsDisplayAriaLabel": "选择指标详情的显示选项", + "xpack.ml.fieldDataCard.cardOther.cardTypeLabel": "{cardType} 类型", + "xpack.ml.fieldDataCard.cardOther.distinctCountDescription": "{cardinality} 不同的 {cardinality, plural, zero {值} one {value} 其他 {values}}", + "xpack.ml.fieldDataCard.cardOther.documentsCountDescription": "{count, plural, zero {# 个文档} one {# 个文档} other {# 个文档}} ({docsPercent}%)", + "xpack.ml.fieldDataCard.cardText.examplesTitle": "{numExamples, plural, one { 个值} other { 个示例}}", + "xpack.ml.fieldDataCard.cardText.fieldMayBePopulatedDescription": "例如,可以使用文档映射中的 {copyToParam} 参数进行填充,也可以在索引后通过使用 {includesParam} 和 {excludesParam} 参数从 {sourceParam} 字段中进行剪裁。", + "xpack.ml.fieldDataCard.cardText.fieldNotPresentDescription": "查询的文档的 {sourceParam} 字段中不存在此字段。", + "xpack.ml.fieldDataCard.cardText.noExamplesForFieldsTitle": "没有获取此字段的示例", + "xpack.ml.fieldDataCard.documentCountChart.seriesLabel": "文档计数", + "xpack.ml.fieldDataCard.fieldNotInDocsLabel": "此字段不会出现在所选时间范围的任何文档中", + "xpack.ml.fieldDataCard.loadingLabel": "正在加载", + "xpack.ml.fieldDataCard.metricDistributionChart.seriesName": "分布", + "xpack.ml.fieldDataCard.metricDistributionChart.tooltipValueBetweenLabel": "{percent}% 的文档具有介于 {minValFormatted} 和 {maxValFormatted} 之间的值", + "xpack.ml.fieldDataCard.metricDistributionChart.tooltipValueEqualLabel": "{percent}% 的文档的值为 {valFormatted}", + "xpack.ml.fieldDataCard.topValues.calculatedFromSampleDescription": "基于每个分片的 {topValuesSamplerShardSize} 文档样例计算", + "xpack.ml.fieldTitleBar.documentCountLabel": "文档计数", + "xpack.ml.fieldTypeIcon.booleanTypeAriaLabel": "布尔类型", + "xpack.ml.fieldTypeIcon.dateTypeAriaLabel": "日期类型", + "xpack.ml.fieldTypeIcon.fieldTypeTooltip": "{type} 类型", + "xpack.ml.fieldTypeIcon.geoPointTypeAriaLabel": "{geoPointParam} 类型", + "xpack.ml.fieldTypeIcon.ipTypeAriaLabel": "IP 类型", + "xpack.ml.fieldTypeIcon.keywordTypeAriaLabel": "关键字类型", + "xpack.ml.fieldTypeIcon.numberTypeAriaLabel": "数字类型", + "xpack.ml.fieldTypeIcon.textTypeAriaLabel": "文本类型", + "xpack.ml.fieldTypeIcon.unknownTypeAriaLabel": "未知类型", + "xpack.ml.fileDatavisualizer.aboutPanel.analyzingDataTitle": "正在分析数据", + "xpack.ml.fileDatavisualizer.aboutPanel.selectOrDragAndDropFileDescription": "选择或拖放文件", + "xpack.ml.fileDatavisualizer.advancedImportSettings.createIndexPatternLabel": "创建索引模式", + "xpack.ml.fileDatavisualizer.advancedImportSettings.indexNameAriaLabel": "索引名称,必填字段", + "xpack.ml.fileDatavisualizer.advancedImportSettings.indexNameLabel": "索引名称", + "xpack.ml.fileDatavisualizer.advancedImportSettings.indexNamePlaceholder": "索引名称", + "xpack.ml.fileDatavisualizer.advancedImportSettings.indexPatternNameLabel": "索引模式名称", + "xpack.ml.fileDatavisualizer.advancedImportSettings.indexSettingsLabel": "索引设置", + "xpack.ml.fileDatavisualizer.advancedImportSettings.ingestPipelineLabel": "采集管道", + "xpack.ml.fileDatavisualizer.advancedImportSettings.mappingsLabel": "映射", + "xpack.ml.fileDatavisualizer.analysisSummary.analyzedLinesNumberTitle": "已分析的行数", + "xpack.ml.fileDatavisualizer.analysisSummary.delimiterTitle": "分隔符", + "xpack.ml.fileDatavisualizer.analysisSummary.formatTitle": "格式", + "xpack.ml.fileDatavisualizer.analysisSummary.grokPatternTitle": "Grok 模式", + "xpack.ml.fileDatavisualizer.analysisSummary.hasHeaderRowTitle": "包含标题行", + "xpack.ml.fileDatavisualizer.analysisSummary.summaryTitle": "结论", + "xpack.ml.fileDatavisualizer.analysisSummary.timeFieldTitle": "时间字段", + "xpack.ml.fileDatavisualizer.analysisSummary.timeFormatTitle": "时间 {timestampFormats, plural, zero {格式} one {format} 其他 {formats}}", + "xpack.ml.fileDatavisualizer.bottomBar.backButtonLabel": "上一步", + "xpack.ml.fileDatavisualizer.bottomBar.cancelButtonLabel": "取消", + "xpack.ml.fileDatavisualizer.bottomBar.readMode.cancelButtonLabel": "取消", + "xpack.ml.fileDatavisualizer.bottomBar.readMode.importButtonLabel": "导入", + "xpack.ml.fileDatavisualizer.editFlyout.applyOverrideSettingsButtonLabel": "应用", + "xpack.ml.fileDatavisualizer.editFlyout.closeOverrideSettingsButtonLabel": "关闭", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.customDelimiterFormRowLabel": "定制分隔符", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.customTimestampFormatErrorMessage": "时间戳格式必须为这些 Java 日期/时间格式的组合:\n yy、yyyy、M、MM、MMM、MMMM、d、dd、EEE、EEEE、H、HH、h、mm、ss、S 至 SSSSSSSSS、a、XX、XXX、zzz", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.customTimestampFormatFormRowLabel": "定制时间戳格式", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.dataFormatFormRowLabel": "数据格式", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.delimiterFormRowLabel": "分隔符", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.editFieldNamesTitle": "编辑字段名称", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.grokPatternFormRowLabel": "Grok 模式", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.hasHeaderRowLabel": "包含标题行", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.linesToSampleErrorMessage": "值必须大于 {min} 并小于或等于 {max}", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.linesToSampleFormRowLabel": "要采样的行数", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.quoteCharacterFormRowLabel": "引用字符", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.timeFieldFormRowLabel": "时间字段", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampEmptyValidationErrorMessage": "时间戳格式 {timestampFormat} 中没有时间格式字母组", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampFormatFormRowLabel": "时间戳格式", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampFormatHelpText": "请参阅有关接受格式的更多内容。", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampLetterSValidationErrorMessage": "{format}的字母 { length, plural, one { {lg} } other { 组 {lg} } } 不受支持,因为其未前置 ss 和 {sep} 中的分隔符", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampLetterValidationErrorMessage": "{format}的字母 { length, plural, one { {lg} } other { 组 {lg} } } 不受支持", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.timestampQuestionMarkValidationErrorMessage": "时间戳格式 {timestampFormat} 不受支持,因为其包含问号字符 ({fieldPlaceholder})", + "xpack.ml.fileDatavisualizer.editFlyout.overrides.trimFieldsLabel": "应剪裁字段", + "xpack.ml.fileDatavisualizer.editFlyout.overrideSettingsTitle": "替代设置", + "xpack.ml.fileDatavisualizer.experimentalBadge.experimentalLabel": "实验性", + "xpack.ml.fileDatavisualizer.fieldStatsCard.distinctCountDescription": "{fieldCardinality} 不同的 {fieldCardinality, plural, zero {值} one {value} 其他 {values}}", + "xpack.ml.fileDatavisualizer.fieldStatsCard.documentsCountDescription": "{fieldCount, plural, zero {# 个文档} one {# 个文档} other {# 个文档}} ({fieldPercent}%)", + "xpack.ml.fileDatavisualizer.fieldStatsCard.maxTitle": "最大值", + "xpack.ml.fileDatavisualizer.fieldStatsCard.medianTitle": "中值", + "xpack.ml.fileDatavisualizer.fieldStatsCard.minTitle": "最小值", + "xpack.ml.fileDatavisualizer.fieldStatsCard.noFieldInformationAvailableDescription": "没有可用的字段信息", + "xpack.ml.fileDatavisualizer.fieldStatsCard.topStatsValuesDescription": "排在前面的值", + "xpack.ml.fileDatavisualizer.fileContents.fileContentsTitle": "文件内容", + "xpack.ml.fileDatavisualizer.fileContents.firstLinesDescription": "前 {numberOfLines, plural, zero {# 行} one {# 行} other {# 行}}", + "xpack.ml.fileDatavisualizer.fileDatavisualizerView.xmlNotCurrentlySupportedErrorMessage": "当前不支持 XML", + "xpack.ml.fileDatavisualizer.fileErrorCallouts.fileCouldNotBeReadTitle": "无法读取文件", + "xpack.ml.fileDatavisualizer.fileErrorCallouts.fileSizeExceedsAllowedSizeByDiffFormatErrorMessage": "您选择用于上传的文件大小超过上限值 {maxFileSizeFormatted} 的 {diffFormatted}", + "xpack.ml.fileDatavisualizer.fileErrorCallouts.fileSizeExceedsAllowedSizeErrorMessage": "您选择用于上传的文件大小为 {fileSizeFormatted},超过上限值 {maxFileSizeFormatted}", + "xpack.ml.fileDatavisualizer.fileErrorCallouts.fileSizeTooLargeTitle": "文件太大", + "xpack.ml.fileDatavisualizer.fileErrorCallouts.revertingToPreviousSettingsDescription": "恢复到以前的设置", + "xpack.ml.fileDatavisualizer.importErrors.checkingPermissionErrorMessage": "导入权限错误", + "xpack.ml.fileDatavisualizer.importErrors.creatingIndexErrorMessage": "创建索引时出错", + "xpack.ml.fileDatavisualizer.importErrors.creatingIndexPatternErrorMessage": "创建索引模式时出错", + "xpack.ml.fileDatavisualizer.importErrors.creatingIngestPipelineErrorMessage": "创建采集管道时出错", + "xpack.ml.fileDatavisualizer.importErrors.defaultErrorMessage": "错误", + "xpack.ml.fileDatavisualizer.importErrors.moreButtonLabel": "更多", + "xpack.ml.fileDatavisualizer.importErrors.parsingJSONErrorMessage": "解析 JSON 出错", + "xpack.ml.fileDatavisualizer.importErrors.readingFileErrorMessage": "读取文件时出错", + "xpack.ml.fileDatavisualizer.importErrors.unknownErrorMessage": "未知错误", + "xpack.ml.fileDatavisualizer.importErrors.uploadingDataErrorMessage": "上传数据时出错", + "xpack.ml.fileDatavisualizer.importProgress.createIndexPatternTitle": "创建索引模式", + "xpack.ml.fileDatavisualizer.importProgress.createIndexTitle": "创建索引", + "xpack.ml.fileDatavisualizer.importProgress.createIngestPipelineTitle": "创建采集管道", + "xpack.ml.fileDatavisualizer.importProgress.creatingIndexPatternDescription": "正在创建索引模式", + "xpack.ml.fileDatavisualizer.importProgress.creatingIndexPatternTitle": "正在创建索引模式", + "xpack.ml.fileDatavisualizer.importProgress.creatingIndexTitle": "正在创建索引", + "xpack.ml.fileDatavisualizer.importProgress.creatingIngestPipelineTitle": "正在创建采集管道", + "xpack.ml.fileDatavisualizer.importProgress.dataUploadedTitle": "数据已上传", + "xpack.ml.fileDatavisualizer.importProgress.fileProcessedTitle": "文件已处理", + "xpack.ml.fileDatavisualizer.importProgress.indexCreatedTitle": "索引已创建", + "xpack.ml.fileDatavisualizer.importProgress.indexPatternCreatedTitle": "索引模式已创建", + "xpack.ml.fileDatavisualizer.importProgress.ingestPipelineCreatedTitle": "采集管道已创建", + "xpack.ml.fileDatavisualizer.importProgress.processFileTitle": "处理文件", + "xpack.ml.fileDatavisualizer.importProgress.processingFileTitle": "正在处理文件", + "xpack.ml.fileDatavisualizer.importProgress.processingImportedFileDescription": "正在处理要导入的文件", + "xpack.ml.fileDatavisualizer.importProgress.stepTwoCreatingIndexDescription": "正在创建索引", + "xpack.ml.fileDatavisualizer.importProgress.stepTwoCreatingIndexIngestPipelineDescription": "正在创建索引和采集管道", + "xpack.ml.fileDatavisualizer.importProgress.uploadDataTitle": "上传数据", + "xpack.ml.fileDatavisualizer.importProgress.uploadingDataDescription": "正在上传数据", + "xpack.ml.fileDatavisualizer.importProgress.uploadingDataTitle": "正在上传数据", + "xpack.ml.fileDatavisualizer.importSettings.advancedTabName": "高级", + "xpack.ml.fileDatavisualizer.importSettings.simpleTabName": "简单", + "xpack.ml.fileDatavisualizer.importSummary.documentsCouldNotBeImportedDescription": "无法导入 {importFailuresLength} 个文档(共 {docCount} 个)这可能是由于行与 Grok 模式不匹配。", + "xpack.ml.fileDatavisualizer.importSummary.documentsCouldNotBeImportedTitle": "部分文档无法导入", + "xpack.ml.fileDatavisualizer.importSummary.documentsIngestedTitle": "已采集的文档", + "xpack.ml.fileDatavisualizer.importSummary.failedDocumentsButtonLabel": "失败的文档", + "xpack.ml.fileDatavisualizer.importSummary.failedDocumentsTitle": "失败的文档", + "xpack.ml.fileDatavisualizer.importSummary.importCompleteTitle": "导入完成", + "xpack.ml.fileDatavisualizer.importSummary.indexPatternTitle": "索引模式", + "xpack.ml.fileDatavisualizer.importSummary.indexTitle": "索引", + "xpack.ml.fileDatavisualizer.importSummary.ingestPipelineTitle": "采集管道", + "xpack.ml.fileDatavisualizer.importView.experimentalFeatureTooltip": "实验功能。我们很乐意听取您的反馈意见。", + "xpack.ml.fileDatavisualizer.importView.importButtonLabel": "导入", + "xpack.ml.fileDatavisualizer.importView.importDataTitle": "导入数据", + "xpack.ml.fileDatavisualizer.importView.importPermissionError": "您无权创建或将数据导入索引 {index}", + "xpack.ml.fileDatavisualizer.importView.indexNameAlreadyExistsErrorMessage": "索引名称已存在", + "xpack.ml.fileDatavisualizer.importView.indexNameContainsIllegalCharactersErrorMessage": "索引名称包含非法字符", + "xpack.ml.fileDatavisualizer.importView.indexPatternDoesNotMatchIndexNameErrorMessage": "索引模式与索引名称不匹配", + "xpack.ml.fileDatavisualizer.importView.indexPatternNameAlreadyExistsErrorMessage": "索引模式名称已存在", + "xpack.ml.fileDatavisualizer.importView.noIdOrIndexSuppliedErrorMessage": "未提供任何 ID 或索引", + "xpack.ml.fileDatavisualizer.importView.parseMappingsError": "解析映射时出错:", + "xpack.ml.fileDatavisualizer.importView.parsePipelineError": "解析采集管道时出错:", + "xpack.ml.fileDatavisualizer.importView.parseSettingsError": "解析设置时出错:", + "xpack.ml.fileDatavisualizer.importView.resetButtonLabel": "重置", + "xpack.ml.fileDatavisualizer.resultsLinks.createNewMLJobTitle": "新建 ML 作业", + "xpack.ml.fileDatavisualizer.resultsLinks.indexManagementTitle": "索引管理", + "xpack.ml.fileDatavisualizer.resultsLinks.indexPatternManagementTitle": "索引模式管理", + "xpack.ml.fileDatavisualizer.resultsLinks.openInDataVisualizerTitle": "在数据可视化工具中打开", + "xpack.ml.fileDatavisualizer.resultsLinks.viewIndexInDiscoverTitle": "在 Discover 中查看索引", + "xpack.ml.fileDatavisualizer.resultsView.fileStatsTabName": "文件统计", + "xpack.ml.fileDatavisualizer.resultsView.overrideSettingsButtonLabel": "替代设置", + "xpack.ml.fileDatavisualizer.simpleImportSettings.createIndexPatternLabel": "创建索引模式", + "xpack.ml.fileDatavisualizer.simpleImportSettings.indexNameAriaLabel": "索引名称,必填字段", + "xpack.ml.fileDatavisualizer.simpleImportSettings.indexNameFormRowLabel": "索引名称", + "xpack.ml.fileDatavisualizer.simpleImportSettings.indexNamePlaceholder": "索引名称", + "xpack.ml.fileDatavisualizer.welcomeContent.delimitedTextFilesDescription": "分隔的文本文件,例如 CSV 和 TSV", + "xpack.ml.fileDatavisualizer.welcomeContent.experimentalFeatureDescription": "此功能处于试验状态。收到反馈?请在 {githubLink} 中创建问题。", + "xpack.ml.fileDatavisualizer.welcomeContent.experimentalFeatureTooltip": "实验功能。我们很乐意听取您的反馈意见。", + "xpack.ml.fileDatavisualizer.welcomeContent.logFilesWithCommonFormatDescription": "具有时间戳通用格式的日志文件", + "xpack.ml.fileDatavisualizer.welcomeContent.newlineDelimitedJsonDescription": "换行符分隔的 JSON", + "xpack.ml.fileDatavisualizer.welcomeContent.supportedFileFormatDescription": "File Data Visualizer 支持以下文件格式:", + "xpack.ml.fileDatavisualizer.welcomeContent.uploadedFilesAllowedSizeDescription": "您可以上传最大 100 MB 的文件。", + "xpack.ml.fileDatavisualizer.welcomeContent.visualizeDataFromLogFileDescription": "File Data Visualizer 可帮助您理解日志文件中的字段和指标。上传文件、分析文件数据,然后选择是否将数据导入 Elasticsearch 索引。", + "xpack.ml.fileDatavisualizer.welcomeContent.visualizeDataFromLogFileTitle": "可视化来自日志文件的数据 {experimentalBadge}", + "xpack.ml.formatters.metricChangeDescription.actualSameAsTypicalDescription": "实际上与典型模式相同", + "xpack.ml.formatters.metricChangeDescription.moreThan100xHigherDescription": "高 100 多倍", + "xpack.ml.formatters.metricChangeDescription.moreThan100xLowerDescription": "低 100 多倍", + "xpack.ml.formatters.metricChangeDescription.moreThanOneAndFiveHundredthsxHigherDescription": "高 {factor} 倍", + "xpack.ml.formatters.metricChangeDescription.moreThanOneAndFiveHundredthsxLowerDescription": "低 {factor} 倍", + "xpack.ml.formatters.metricChangeDescription.moreThanOneAndHalfxHigherDescription": "高 {factor} 倍", + "xpack.ml.formatters.metricChangeDescription.moreThanOneAndHalfxLowerDescription": "低 {factor} 倍", + "xpack.ml.formatters.metricChangeDescription.unexpectedNonZeroValueDescription": "异常非零值", + "xpack.ml.formatters.metricChangeDescription.unexpectedZeroValueDescription": "异常零值", + "xpack.ml.formatters.metricChangeDescription.unusuallyHighDescription": "异常高", + "xpack.ml.formatters.metricChangeDescription.unusuallyLowDescription": "异常低", + "xpack.ml.formatters.metricChangeDescription.unusualValuesDescription": "异常值", + "xpack.ml.fullTimeRangeSelector.errorSettingTimeRangeNotification": "设置时间范围时出错。", + "xpack.ml.fullTimeRangeSelector.useFullDataButtonLabel": "使用完整的 {indexPatternTitle} 数据", + "xpack.ml.indexPatternNotBasedOnTimeSeriesNotificationDescription": "仅针对基于时间的索引运行异常检测", + "xpack.ml.indexPatternNotBasedOnTimeSeriesNotificationTitle": "索引模式 {indexPatternTitle} 不基于时间序列", + "xpack.ml.influencersList.maxAnomalyScoreTooltipDescription": "最大异常分数:{maxScoreLabel}", + "xpack.ml.influencersList.noInfluencersFoundTitle": "找不到影响因素", + "xpack.ml.influencersList.totalAnomalyScoreTooltipDescription": "总异常分数:{totalScoreLabel}", + "xpack.ml.itemsGrid.itemsCountLabel": "{pageSize} 项", + "xpack.ml.itemsGrid.itemsPerPageButtonLabel": "每页中的项:{itemsPerPage}", + "xpack.ml.itemsGrid.noItemsAddedTitle": "没有添加任何项", + "xpack.ml.itemsGrid.noMatchingItemsTitle": "没有匹配的项", + "xpack.ml.jobsBreadcrumbs.advancedConfigurationLabel": "高级配置", + "xpack.ml.jobsBreadcrumbs.createJobLabel": "创建作业", + "xpack.ml.jobsBreadcrumbs.multiMetricLabel": "多指标", + "xpack.ml.jobsBreadcrumbs.populationLabel": "填充", + "xpack.ml.jobsBreadcrumbs.selectIndexOrSearchLabel": "选择索引或搜索", + "xpack.ml.jobsBreadcrumbs.singleMetricLabel": "单一指标", + "xpack.ml.jobSelect.noJobsSelectedWarningMessage": "未选择作业,将自动选择第一个作业", + "xpack.ml.jobSelect.requestedJobsDoesNotExistWarningMessage": "已请求\n{invalidIdsLength, plural, one { 个作业 {invalidIds} 不存在} other { 个作业 {invalidIds} 不存在}}", + "xpack.ml.jobSelectList.groupTimeRangeLabel": "{fromString} 到 {toString}", + "xpack.ml.jobSelector.applyFlyoutButton": "应用", + "xpack.ml.jobSelector.applyTimerangeSwitchLabel": "应用时间范围", + "xpack.ml.jobSelector.clearAllFlyoutButton": "全部清除", + "xpack.ml.jobSelector.closeFlyoutButton": "关闭", + "xpack.ml.jobSelector.customTable.searchBarPlaceholder": "搜索......", + "xpack.ml.jobSelector.customTable.selectAllCheckboxLabel": "全选", + "xpack.ml.jobSelector.filterBar.groupLabel": "组", + "xpack.ml.jobSelector.filterBar.invalidSearchErrorMessage": "无效搜索:{errorMessage}", + "xpack.ml.jobSelector.filterBar.jobGroupTitle": "({jobsCount, plural, one {# 个作业} other {# 个作业}})", + "xpack.ml.jobSelector.flyoutTitle": "作业选择", + "xpack.ml.jobSelector.groupsTab": "组", + "xpack.ml.jobSelector.hideBarBadges": "隐藏", + "xpack.ml.jobSelector.hideFlyoutBadges": "隐藏", + "xpack.ml.jobSelector.jobFetchErrorMessage": "获取作业时出错。刷新并重试。", + "xpack.ml.jobSelector.jobSelectionButton": "编辑作业选择", + "xpack.ml.jobSelector.jobsTab": "作业", + "xpack.ml.jobSelector.jobTimeRangeLabel": "{fromString} 到 {toString}", + "xpack.ml.jobSelector.noResultsForJobLabel": "无结果", + "xpack.ml.jobSelector.selectedGroupJobs": "({jobsCount, plural, one {# 个作业} other {# 个作业}})", + "xpack.ml.jobSelector.showBarBadges": "和另外 {overFlow} 个", + "xpack.ml.jobSelector.showFlyoutBadges": "和另外 {overFlow} 个", + "xpack.ml.jobService.activeDatafeedsLabel": "活动数据馈送", + "xpack.ml.jobService.activeMLNodesLabel": "活动 ML 节点", + "xpack.ml.jobService.closedJobsLabel": "已关闭的作业", + "xpack.ml.jobService.couldNotStartDatafeedErrorMessage": "无法开始 {jobId} 的数据馈送", + "xpack.ml.jobService.couldNotStopDatafeedErrorMessage": "无法停止 {jobId} 的数据馈送", + "xpack.ml.jobService.couldNotUpdateDatafeedErrorMessage": "无法更新数据馈送:{datafeedId}", + "xpack.ml.jobService.couldNotUpdateJobErrorMessage": "无法更新作业:{jobId}", + "xpack.ml.jobService.datafeedsListCouldNotBeRetrievedErrorMessage": "无法检索数据馈送列表", + "xpack.ml.jobService.failedJobsLabel": "失败的作业", + "xpack.ml.jobService.jobsListCouldNotBeRetrievedErrorMessage": "无法检索作业列表", + "xpack.ml.jobService.jobValidationErrorMessage": "作业验证错误:{errorMessage}", + "xpack.ml.jobService.openJobsLabel": "打开的作业", + "xpack.ml.jobService.requestMayHaveTimedOutErrorMessage": "请求可能已超时,并可能仍在后台运行。", + "xpack.ml.jobService.totalJobsLabel": "总计作业数", + "xpack.ml.jobsList.actionExecuteSuccessfullyNotificationMessage": "{successesJobsCount, plural, one{{successJob}} other{# 个作业}}{actionTextPT}已成功", + "xpack.ml.jobsList.actionFailedNotificationMessage": "{failureId} 未能{actionText}", + "xpack.ml.jobsList.actionsLabel": "操作", + "xpack.ml.jobsList.analyticsSpacesLabel": "工作区", + "xpack.ml.jobsList.breadcrumb": "作业", + "xpack.ml.jobsList.cannotSelectRowForJobMessage": "无法选择作业 ID {jobId}", + "xpack.ml.jobsList.cloneJobErrorMessage": "无法克隆 {jobId}。找不到作业", + "xpack.ml.jobsList.closeActionStatusText": "关闭", + "xpack.ml.jobsList.closedActionStatusText": "已关闭", + "xpack.ml.jobsList.closeJobErrorMessage": "作业无法关闭", + "xpack.ml.jobsList.collapseJobDetailsAriaLabel": "隐藏 {itemId} 的详情", + "xpack.ml.jobsList.createNewJobButtonLabel": "创建新作业", + "xpack.ml.jobsList.createWatchFlyout.closeButtonLabel": "关闭", + "xpack.ml.jobsList.createWatchFlyout.editWatchButtonLabel": "编辑监视", + "xpack.ml.jobsList.createWatchFlyout.pageTitle": "创建 {jobId} 的监视", + "xpack.ml.jobsList.createWatchFlyout.saveButtonLabel": "保存", + "xpack.ml.jobsList.createWatchFlyout.watchCreatedSuccessfullyNotificationMessage": "监视 {id} 已成功创建", + "xpack.ml.jobsList.createWatchFlyout.watchNotSavedErrorNotificationMessage": "无法保存监视", + "xpack.ml.jobsList.datafeedStateLabel": "数据馈送状态", + "xpack.ml.jobsList.deleteActionStatusText": "删除", + "xpack.ml.jobsList.deletedActionStatusText": "已删除", + "xpack.ml.jobsList.deleteJobErrorMessage": "作业无法删除", + "xpack.ml.jobsList.deleteJobModal.cancelButtonLabel": "取消", + "xpack.ml.jobsList.deleteJobModal.closeButtonLabel": "关闭", + "xpack.ml.jobsList.deleteJobModal.deleteButtonLabel": "删除", + "xpack.ml.jobsList.deleteJobModal.deleteJobsDescription": "是否确定要删除{jobsCount, plural, one {此作业} other {这些作业}}?", + "xpack.ml.jobsList.deleteJobModal.deleteJobsTitle": "删除 {jobsCount, plural, one {{jobId}} other {# 个作业}}", + "xpack.ml.jobsList.deleteJobModal.deleteMultipleJobsDescription": "删除{jobsCount, plural, one {一个作业} other {多个作业}}会非常耗时。将在后台删除{jobsCount, plural, one {该作业} other {这些作业}},但删除的作业可能不会立即从作业列表中消失", + "xpack.ml.jobsList.deleteJobModal.deletingJobsStatusLabel": "正在删除作业", + "xpack.ml.jobsList.descriptionLabel": "描述", + "xpack.ml.jobsList.editJobFlyout.changesNotSavedNotificationMessage": "无法保存对 {jobId} 所做的更改", + "xpack.ml.jobsList.editJobFlyout.changesSavedNotificationMessage": "已保存对 {jobId} 所做的更改", + "xpack.ml.jobsList.editJobFlyout.closeButtonLabel": "关闭", + "xpack.ml.jobsList.editJobFlyout.customUrls.addButtonLabel": "添加", + "xpack.ml.jobsList.editJobFlyout.customUrls.addCustomUrlButtonLabel": "添加定制 URL", + "xpack.ml.jobsList.editJobFlyout.customUrls.addNewUrlErrorNotificationMessage": "基于提供的设置构建新的定制 URL 时出错", + "xpack.ml.jobsList.editJobFlyout.customUrls.buildUrlErrorNotificationMessage": "基于提供的设置构建用于测试的定制 URL 时出错", + "xpack.ml.jobsList.editJobFlyout.customUrls.closeEditorAriaLabel": "关闭定制 URL 编辑器", + "xpack.ml.jobsList.editJobFlyout.customUrls.getTestUrlErrorNotificationMessage": "获取 URL 用于测试配置时出错", + "xpack.ml.jobsList.editJobFlyout.customUrls.loadIndexPatternsErrorNotificationMessage": "加载已保存的索引模式列表时出错", + "xpack.ml.jobsList.editJobFlyout.customUrls.loadSavedDashboardsErrorNotificationMessage": "加载已保存的 Kibana 仪表板列表时出错", + "xpack.ml.jobsList.editJobFlyout.customUrls.testButtonLabel": "测试", + "xpack.ml.jobsList.editJobFlyout.customUrlsTitle": "定制 URL", + "xpack.ml.jobsList.editJobFlyout.datafeed.frequencyLabel": "频率", + "xpack.ml.jobsList.editJobFlyout.datafeed.queryDelayLabel": "查询延迟", + "xpack.ml.jobsList.editJobFlyout.datafeed.queryLabel": "查询", + "xpack.ml.jobsList.editJobFlyout.datafeed.scrollSizeLabel": "滚动条大小", + "xpack.ml.jobsList.editJobFlyout.datafeedTitle": "数据馈送", + "xpack.ml.jobsList.editJobFlyout.detectorsTitle": "检测工具", + "xpack.ml.jobsList.editJobFlyout.groupsAndJobsHasSameIdErrorMessage": "已存在具有此 ID 的作业。组和作业不能使用相同的 ID。", + "xpack.ml.jobsList.editJobFlyout.jobDetails.jobDescriptionLabel": "作业描述", + "xpack.ml.jobsList.editJobFlyout.jobDetails.jobGroupsLabel": "作业组", + "xpack.ml.jobsList.editJobFlyout.jobDetails.jobGroupsPlaceholder": "选择或创建组", + "xpack.ml.jobsList.editJobFlyout.jobDetails.modelMemoryLimitLabel": "模型内存限制", + "xpack.ml.jobsList.editJobFlyout.jobDetailsTitle": "作业详情", + "xpack.ml.jobsList.editJobFlyout.leaveAnywayButtonLabel": "离开", + "xpack.ml.jobsList.editJobFlyout.pageTitle": "编辑 {jobId}", + "xpack.ml.jobsList.editJobFlyout.saveButtonLabel": "保存", + "xpack.ml.jobsList.editJobFlyout.saveChangesButtonLabel": "保存更改", + "xpack.ml.jobsList.editJobFlyout.unsavedChangesDialogMessage": "如果未保存,您的更改将会丢失。", + "xpack.ml.jobsList.editJobFlyout.unsavedChangesDialogTitle": "离开前保存更改?", + "xpack.ml.jobsList.expandJobDetailsAriaLabel": "显示 {itemId} 的详情", + "xpack.ml.jobsList.idLabel": "ID", + "xpack.ml.jobsList.jobDetails.analysisConfigTitle": "分析配置", + "xpack.ml.jobsList.jobDetails.analysisLimitsTitle": "分析限制", + "xpack.ml.jobsList.jobDetails.calendarsTitle": "日历", + "xpack.ml.jobsList.jobDetails.countsTitle": "计数", + "xpack.ml.jobsList.jobDetails.customUrlsTitle": "定制 URL", + "xpack.ml.jobsList.jobDetails.dataDescriptionTitle": "数据描述", + "xpack.ml.jobsList.jobDetails.datafeedTimingStatsTitle": "计时统计", + "xpack.ml.jobsList.jobDetails.datafeedTitle": "数据馈送", + "xpack.ml.jobsList.jobDetails.detectorsTitle": "检测工具", + "xpack.ml.jobsList.jobDetails.forecastsTable.createdLabel": "创建于", + "xpack.ml.jobsList.jobDetails.forecastsTable.expiresLabel": "过期时间", + "xpack.ml.jobsList.jobDetails.forecastsTable.fromLabel": "从", + "xpack.ml.jobsList.jobDetails.forecastsTable.loadingErrorMessage": "加载此作业上运行的预测列表时出错", + "xpack.ml.jobsList.jobDetails.forecastsTable.memorySizeLabel": "内存大小", + "xpack.ml.jobsList.jobDetails.forecastsTable.messagesLabel": "消息", + "xpack.ml.jobsList.jobDetails.forecastsTable.msTimeUnitLabel": "{ms} 毫秒", + "xpack.ml.jobsList.jobDetails.forecastsTable.noForecastsDescription": "要运行预测,请打开 {singleMetricViewerLink}", + "xpack.ml.jobsList.jobDetails.forecastsTable.noForecastsDescription.linkText": "Single Metric Viewer", + "xpack.ml.jobsList.jobDetails.forecastsTable.noForecastsTitle": "还没有针对此作业运行的预测", + "xpack.ml.jobsList.jobDetails.forecastsTable.processingTimeLabel": "处理时间", + "xpack.ml.jobsList.jobDetails.forecastsTable.statusLabel": "状态", + "xpack.ml.jobsList.jobDetails.forecastsTable.toLabel": "到", + "xpack.ml.jobsList.jobDetails.forecastsTable.viewAriaLabel": "查看在 {createdDate} 创建的预测", + "xpack.ml.jobsList.jobDetails.forecastsTable.viewLabel": "查看", + "xpack.ml.jobsList.jobDetails.generalTitle": "常规", + "xpack.ml.jobsList.jobDetails.influencersTitle": "影响因素", + "xpack.ml.jobsList.jobDetails.modelSizeStatsTitle": "模型大小统计", + "xpack.ml.jobsList.jobDetails.nodeTitle": "节点", + "xpack.ml.jobsList.jobDetails.noPermissionToViewDatafeedPreviewTitle": "您无权查看数据馈送预览", + "xpack.ml.jobsList.jobDetails.pleaseContactYourAdministratorLabel": "请联系您的管理员。", + "xpack.ml.jobsList.jobDetails.tabs.annotationsLabel": "注释", + "xpack.ml.jobsList.jobDetails.tabs.countsLabel": "计数", + "xpack.ml.jobsList.jobDetails.tabs.datafeedLabel": "数据馈送", + "xpack.ml.jobsList.jobDetails.tabs.datafeedPreviewLabel": "数据馈送预览", + "xpack.ml.jobsList.jobDetails.tabs.forecastsLabel": "预测", + "xpack.ml.jobsList.jobDetails.tabs.jobConfigLabel": "作业配置", + "xpack.ml.jobsList.jobDetails.tabs.jobMessagesLabel": "作业消息", + "xpack.ml.jobsList.jobDetails.tabs.jobSettingsLabel": "作业设置", + "xpack.ml.jobsList.jobDetails.tabs.jsonLabel": "JSON", + "xpack.ml.jobsList.jobFilterBar.closedLabel": "已关闭", + "xpack.ml.jobsList.jobFilterBar.failedLabel": "失败", + "xpack.ml.jobsList.jobFilterBar.groupLabel": "组", + "xpack.ml.jobsList.jobFilterBar.invalidSearchErrorMessage": "无效搜索:{errorMessage}", + "xpack.ml.jobsList.jobFilterBar.jobGroupTitle": "({jobsCount, plural, one {# 个作业} other {# 个作业}})", + "xpack.ml.jobsList.jobFilterBar.openedLabel": "已打开", + "xpack.ml.jobsList.jobFilterBar.startedLabel": "已开始", + "xpack.ml.jobsList.jobFilterBar.stoppedLabel": "已停止", + "xpack.ml.jobsList.jobStateLabel": "作业状态", + "xpack.ml.jobsList.latestTimestampLabel": "最新时间戳", + "xpack.ml.jobsList.loadingJobsLabel": "正在加载作业", + "xpack.ml.jobsList.managementActions.cloneJobDescription": "克隆作业", + "xpack.ml.jobsList.managementActions.cloneJobLabel": "克隆作业", + "xpack.ml.jobsList.managementActions.closeJobDescription": "关闭作业", + "xpack.ml.jobsList.managementActions.closeJobLabel": "关闭作业", + "xpack.ml.jobsList.managementActions.deleteJobDescription": "删除作业", + "xpack.ml.jobsList.managementActions.deleteJobLabel": "删除作业", + "xpack.ml.jobsList.managementActions.editJobDescription": "编辑作业", + "xpack.ml.jobsList.managementActions.editJobLabel": "编辑作业", + "xpack.ml.jobsList.managementActions.startDatafeedDescription": "开始数据馈送", + "xpack.ml.jobsList.managementActions.startDatafeedLabel": "开始数据馈送", + "xpack.ml.jobsList.managementActions.stopDatafeedDescription": "停止数据馈送", + "xpack.ml.jobsList.managementActions.stopDatafeedLabel": "停止数据馈送", + "xpack.ml.jobsList.memoryStatusLabel": "内存状态", + "xpack.ml.jobsList.multiJobActions.groupSelector.addButtonAriaLabel": "添加", + "xpack.ml.jobsList.multiJobActions.groupSelector.addNewGroupPlaceholder": "添加新组", + "xpack.ml.jobsList.multiJobActions.groupSelector.applyButtonLabel": "应用", + "xpack.ml.jobsList.multiJobActions.groupSelector.applyGroupsToJobTitle": "将组应用到{jobsCount, plural, one { 个作业} other { 个作业}}", + "xpack.ml.jobsList.multiJobActions.groupSelector.editJobGroupsButtonAriaLabel": "编辑作业组", + "xpack.ml.jobsList.multiJobActions.groupSelector.editJobGroupsButtonTooltip": "编辑作业组", + "xpack.ml.jobsList.multiJobActions.groupSelector.groupsAndJobsCanNotUseSameIdErrorMessage": "已存在具有此 ID 的作业。组和作业不能使用相同的 ID。", + "xpack.ml.jobsList.multiJobActionsMenu.managementActionsAriaLabel": "管理操作", + "xpack.ml.jobsList.multiJobsActions.closeJobsLabel": "关闭 {jobsCount, plural, one { 个作业} other { 个作业}}", + "xpack.ml.jobsList.multiJobsActions.deleteJobsLabel": "删除 {jobsCount, plural, one { 个作业} other { 个作业}}", + "xpack.ml.jobsList.multiJobsActions.jobsSelectedLabel": "已选择{selectedJobsCount, plural, one {# 个作业} other {# 个作业}}", + "xpack.ml.jobsList.multiJobsActions.startDatafeedsLabel": "开始 {jobsCount, plural, one { 个数据馈送} other { 个数据馈送}}", + "xpack.ml.jobsList.multiJobsActions.stopDatafeedsLabel": "停止 {jobsCount, plural, one { 个数据馈送} other { 个数据馈送}}", + "xpack.ml.jobsList.nodeAvailableWarning.linkToCloud.hereLinkText": "此处", + "xpack.ml.jobsList.nodeAvailableWarning.linkToCloudDescription": "请编辑您的{link}。可以启用免费的 1GB Machine Learning 节点或扩展现有的 ML 配置。", + "xpack.ml.jobsList.nodeAvailableWarning.noMLNodesAvailableDescription": "没有可用的 ML 节点。", + "xpack.ml.jobsList.nodeAvailableWarning.noMLNodesAvailableTitle": "没有可用的 ML 节点", + "xpack.ml.jobsList.nodeAvailableWarning.unavailableCreateOrRunJobsDescription": "您将无法创建或运行作业。", + "xpack.ml.jobsList.noJobsFoundLabel": "找不到作业", + "xpack.ml.jobsList.processedRecordsLabel": "已处理记录", + "xpack.ml.jobsList.refreshButtonLabel": "刷新", + "xpack.ml.jobsList.resultActions.openJobsInAnomalyExplorerText": "在 Anomaly Explorer 中打开 {jobsCount, plural, one {{jobId}} other {# 个作业}}", + "xpack.ml.jobsList.resultActions.openJobsInSingleMetricViewerText": "在 Single Metric Viewer 中打开 {jobsCount, plural, one {{jobId}} other {# 个作业}}", + "xpack.ml.jobsList.selectRowForJobMessage": "选择作业 ID {jobId} 的行", + "xpack.ml.jobsList.spacesLabel": "工作区", + "xpack.ml.jobsList.startActionStatusText": "开始", + "xpack.ml.jobsList.startDatafeedModal.cancelButtonLabel": "取消", + "xpack.ml.jobsList.startDatafeedModal.continueFromNowLabel": "从当前继续", + "xpack.ml.jobsList.startDatafeedModal.continueFromSpecifiedTimeLabel": "从指定时间继续", + "xpack.ml.jobsList.startDatafeedModal.continueFromStartTimeLabel": "从 {formattedStartTime} 继续", + "xpack.ml.jobsList.startDatafeedModal.createWatchDescription": "在数据馈送开始后创建监视", + "xpack.ml.jobsList.startDatafeedModal.noEndTimeLabel": "无结束时间(实时搜索)", + "xpack.ml.jobsList.startDatafeedModal.searchEndTimeTitle": "搜索结束时间", + "xpack.ml.jobsList.startDatafeedModal.searchStartTimeTitle": "搜索开始时间", + "xpack.ml.jobsList.startDatafeedModal.specifyEndTimeLabel": "指定结束时间", + "xpack.ml.jobsList.startDatafeedModal.specifyStartTimeLabel": "指定开始时间", + "xpack.ml.jobsList.startDatafeedModal.startAtBeginningOfDataLabel": "从数据开始处开始", + "xpack.ml.jobsList.startDatafeedModal.startButtonLabel": "开始", + "xpack.ml.jobsList.startDatafeedModal.startFromNowLabel": "从当前开始", + "xpack.ml.jobsList.startDatafeedModal.startJobsTitle": "启动 {jobsCount, plural, one {{jobId}} other {# 个作业}}", + "xpack.ml.jobsList.startedActionStatusText": "已启动", + "xpack.ml.jobsList.startJobErrorMessage": "作业无法启动", + "xpack.ml.jobsList.statsBar.activeDatafeedsLabel": "活动数据馈送", + "xpack.ml.jobsList.statsBar.activeMLNodesLabel": "活动 ML 节点", + "xpack.ml.jobsList.statsBar.closedJobsLabel": "已关闭的作业", + "xpack.ml.jobsList.statsBar.failedJobsLabel": "失败的作业", + "xpack.ml.jobsList.statsBar.openJobsLabel": "打开的作业", + "xpack.ml.jobsList.statsBar.totalJobsLabel": "总计作业数", + "xpack.ml.jobsList.stopActionStatusText": "停止", + "xpack.ml.jobsList.stopJobErrorMessage": "作业无法停止", + "xpack.ml.jobsList.stoppedActionStatusText": "已停止", + "xpack.ml.machineLearningBreadcrumbLabel": "机器学习", + "xpack.ml.machineLearningDescription": "对时序数据的正常行为自动建模以检测异常。", + "xpack.ml.machineLearningTitle": "机器学习", + "xpack.ml.management.jobsList.accessDeniedTitle": "访问被拒绝", + "xpack.ml.management.jobsList.analyticsDocsLabel": "分析作业文档", + "xpack.ml.management.jobsList.analyticsTab": "分析", + "xpack.ml.management.jobsList.anomalyDetectionDocsLabel": "异常检测作业文档", + "xpack.ml.management.jobsList.anomalyDetectionTab": "异常检测", + "xpack.ml.management.jobsList.jobsListTagline": "查看 Machine Learning 分析和异常检测作业。", + "xpack.ml.management.jobsList.jobsListTitle": "Machine Learning", + "xpack.ml.management.jobsList.noGrantedPrivilegesDescription": "您无权管理 ML 作业", + "xpack.ml.management.jobsList.noPermissionToAccessLabel": "您需要访问 ML 作业的权限", + "xpack.ml.management.jobsListTitle": "作业列表", + "xpack.ml.management.mlTitle": "Machine Learning", + "xpack.ml.messagebarService.errorTitle": "发生了错误", + "xpack.ml.mlNavDescription": "Elastic Stack 的 Machine Learning", + "xpack.ml.mlNavTitle": "机器学习", + "xpack.ml.models.jobService.allOtherRequestsCancelledDescription": " 所有其他请求已取消。", + "xpack.ml.models.jobService.deletingJob": "正在删除", + "xpack.ml.models.jobService.jobHasNoDatafeedErrorMessage": "作业没有数据馈送", + "xpack.ml.models.jobService.requestToActionTimedOutErrorMessage": "对 {action} “{id}” 的请求超时。{extra}", + "xpack.ml.models.jobValidation.analysisConfigIsNotObjectErrorMessage": "无效的 {invalidParamName}:需要是对象。", + "xpack.ml.models.jobValidation.detectorsAreNotArrayErrorMessage": "无效的 {invalidParamName}:需要是数组。", + "xpack.ml.models.jobValidation.jobIsNotObjectErrorMessage": "无效的 {invalidParamName}:需要是对象。", + "xpack.ml.models.jobValidation.messages.bucketSpanEmptyMessage": "必须指定存储桶跨度字段。", + "xpack.ml.models.jobValidation.messages.bucketSpanEstimationMismatchHeading": "存储桶跨度", + "xpack.ml.models.jobValidation.messages.bucketSpanEstimationMismatchMessage": "当前存储桶跨度为 {currentBucketSpan},但存储桶跨度估计返回 {estimateBucketSpan}。", + "xpack.ml.models.jobValidation.messages.bucketSpanHighHeading": "存储桶跨度", + "xpack.ml.models.jobValidation.messages.bucketSpanHighMessage": "存储桶跨度为 1 天或以上。请注意,天数被视为 UTC 天数,而非本地天数。", + "xpack.ml.models.jobValidation.messages.bucketSpanInvalidHeading": "存储桶跨度", + "xpack.ml.models.jobValidation.messages.bucketSpanInvalidMessage": "指定的存储桶跨度不是有效的时间间隔格式,例如 10m、1h。它还需要大于零。", + "xpack.ml.models.jobValidation.messages.bucketSpanValidHeading": "存储桶跨度", + "xpack.ml.models.jobValidation.messages.bucketSpanValidMessage": "{bucketSpan} 的格式有效。", + "xpack.ml.models.jobValidation.messages.cardinalityByFieldMessage": "{fieldName} 的基数大于 1000,可能会导致高内存用量。", + "xpack.ml.models.jobValidation.messages.cardinalityModelPlotHighMessage": "与创建模型绘图相关的字段的估计基数 {modelPlotCardinality} 可能导致资源密集型作业出现。", + "xpack.ml.models.jobValidation.messages.cardinalityOverFieldHighMessage": "{fieldName} 的基数大于 1000000,可能会导致高内存用量。", + "xpack.ml.models.jobValidation.messages.cardinalityOverFieldLowMessage": "{fieldName} 的基数低于 10,可能不适合人口分析。", + "xpack.ml.models.jobValidation.messages.cardinalityPartitionFieldMessage": "{fieldName} 的基数大于 1000,可能会导致高内存用量。", + "xpack.ml.models.jobValidation.messages.categorizationFiltersInvalidMessage": "分类筛选配置无效。确保筛选是有效的正则表达式,且已设置 {categorizationFieldName}。", + "xpack.ml.models.jobValidation.messages.categorizationFiltersValidMessage": "分类筛选检查已通过。", + "xpack.ml.models.jobValidation.messages.detectorsDuplicatesMessage": "找到重复的检测工具。在同一作业中,不允许存在具有 “{functionParam}”、“{fieldNameParam}”、“{byFieldNameParam}”、“{overFieldNameParam}” 和 “{partitionFieldNameParam}” 相同组合配置的检测工具。", + "xpack.ml.models.jobValidation.messages.detectorsEmptyMessage": "未找到任何检测工具。必须至少指定一个检测工具。", + "xpack.ml.models.jobValidation.messages.detectorsFunctionEmptyMessage": "检测工具函数之一为空。", + "xpack.ml.models.jobValidation.messages.detectorsFunctionNotEmptyHeading": "检测工具函数", + "xpack.ml.models.jobValidation.messages.detectorsFunctionNotEmptyMessage": "在所有检测工具中已验证检测工具函数的存在。", + "xpack.ml.models.jobValidation.messages.estimatedMmlGreaterThanMaxMmlMessage": "估计模型内存限制大于为此集群配置的最大模型内存限制。", + "xpack.ml.models.jobValidation.messages.estimatedMmlGreaterThanMmlMessage": "估计模型内存限制 大于已配置的模型内容限制。", + "xpack.ml.models.jobValidation.messages.fieldNotAggregatableMessage": "检测工具字段 {fieldName} 不是可聚合字段。", + "xpack.ml.models.jobValidation.messages.fieldsNotAggregatableMessage": "有一个检测工具字段不是可聚合字段。", + "xpack.ml.models.jobValidation.messages.halfEstimatedMmlGreaterThanMmlMessage": "指定的模型内存限制小于估计模型内存限制的一半,很可能会达到硬性限制。", + "xpack.ml.models.jobValidation.messages.indexFieldsInvalidMessage": "无法从索引加载字段。", + "xpack.ml.models.jobValidation.messages.indexFieldsValidMessage": "数据馈送中存在索引字段。", + "xpack.ml.models.jobValidation.messages.influencerHighMessage": "作业配置包括 3 个以上影响因素。考虑使用较少的影响因素或创建多个作业。", + "xpack.ml.models.jobValidation.messages.influencerLowMessage": "尚未配置任何影响因素。强烈建议选取影响因素。", + "xpack.ml.models.jobValidation.messages.influencerLowSuggestionMessage": "尚未配置任何影响因素。考虑使用 {influencerSuggestion} 作为影响因素。", + "xpack.ml.models.jobValidation.messages.influencerLowSuggestionsMessage": "尚未配置任何影响因素。考虑使用一个或多个 {influencerSuggestion}。", + "xpack.ml.models.jobValidation.messages.jobGroupIdInvalidMaxLengthErrorMessage": "作业组名称的长度不得超过 {maxLength, plural, one {# 个字符} other {# 个字符}}。", + "xpack.ml.models.jobValidation.messages.jobGroupIdInvalidMessage": "有一个作业组名称无效。它们可以包含小写字母数字(a-z 和 0-9)字符、连字符或下划线,必须以字母数字字符开头和结尾", + "xpack.ml.models.jobValidation.messages.jobGroupIdValidHeading": "作业 ID 格式有效。", + "xpack.ml.models.jobValidation.messages.jobGroupIdValidMessage": "小写字母数字(a-z 和 0-9)字符、连字符或下划线,以字母数字字符开头和结尾,且长度不超过 {maxLength, plural, one {# 个字符} other {# 个字符}}。", + "xpack.ml.models.jobValidation.messages.jobIdEmptyMessage": "作业名称字段不得为空。", + "xpack.ml.models.jobValidation.messages.jobIdInvalidMaxLengthErrorMessage": "作业 ID 的长度不得超过 {maxLength, plural, one {# 个字符} other {# 个字符}}。", + "xpack.ml.models.jobValidation.messages.jobIdInvalidMessage": "作业 ID 无效.其可以包含小写字母数字(a-z 和 0-9)字符、连字符或下划线,且必须以字母数字字符开头和结尾。", + "xpack.ml.models.jobValidation.messages.jobIdValidHeading": "作业 ID 格式有效", + "xpack.ml.models.jobValidation.messages.jobIdValidMessage": "小写字母数字(a-z 和 0-9)字符、连字符或下划线,以字母数字字符开头和结尾,且长度不超过 {maxLength, plural, one {# 个字符} other {# 个字符}}。", + "xpack.ml.models.jobValidation.messages.mmlGreaterThanMaxMmlMessage": "模型内存限制大于为此集群配置的最大模型内存限制。", + "xpack.ml.models.jobValidation.messages.mmlValueInvalidMessage": "{mml} 不是有效的模型内存限制值。该值需要至少 1MB,且应以字节为单位(例如 10MB)指定。", + "xpack.ml.models.jobValidation.messages.skippedExtendedTestsMessage": "已跳过其他检查,因为未满足作业配置的基本要求。", + "xpack.ml.models.jobValidation.messages.successBucketSpanHeading": "存储桶跨度", + "xpack.ml.models.jobValidation.messages.successBucketSpanMessage": "{bucketSpan} 的格式有效,已通过验证检查。", + "xpack.ml.models.jobValidation.messages.successCardinalityHeading": "基数", + "xpack.ml.models.jobValidation.messages.successCardinalityMessage": "检测工具字段的基数在建议边界内。", + "xpack.ml.models.jobValidation.messages.successInfluencersMessage": "影响因素配置已通过验证检查。", + "xpack.ml.models.jobValidation.messages.successMmlHeading": "模型内存限制", + "xpack.ml.models.jobValidation.messages.successMmlMessage": "有效且在估计模型内存限制内。", + "xpack.ml.models.jobValidation.messages.successTimeRangeHeading": "时间范围", + "xpack.ml.models.jobValidation.messages.successTimeRangeMessage": "有效且长度足以对数据中的模式进行建模。", + "xpack.ml.models.jobValidation.messages.timeFieldInvalidMessage": "{timeField} 不能用作时间字段,因为它不是类型“date”的有效字段。", + "xpack.ml.models.jobValidation.messages.timeRangeBeforeEpochHeading": "时间范围", + "xpack.ml.models.jobValidation.messages.timeRangeBeforeEpochMessage": "选定或可用时间范围包含时间戳在 UNIX epoch 开始之前的数据。Machine Learning 作业不支持在 01/01/1970 00:00:00 (UTC) 之前的时间戳。", + "xpack.ml.models.jobValidation.messages.timeRangeShortHeading": "时间范围", + "xpack.ml.models.jobValidation.messages.timeRangeShortMessage": "选定或可用时间范围可能过短。建议的最小时间范围应至少为 {minTimeSpanReadable} 且是存储桶跨度的 {bucketSpanCompareFactor} 倍。", + "xpack.ml.models.jobValidation.payloadIsNotObjectErrorMessage": "无效的 {invalidParamName}:需要是对象。", + "xpack.ml.models.jobValidation.unknownMessageIdErrorMessage": "{messageId}(未知消息 ID)", + "xpack.ml.models.jobValidation.validateJobObject.analysisConfigIsNotObjectErrorMessage": "无效的 {invalidParamName}:需要是对象。", + "xpack.ml.models.jobValidation.validateJobObject.dataDescriptionIsNotObjectErrorMessage": "无效的 {invalidParamName}:需要是对象。", + "xpack.ml.models.jobValidation.validateJobObject.datafeedConfigIsNotObjectErrorMessage": "无效的 {invalidParamName}:需要是对象。", + "xpack.ml.models.jobValidation.validateJobObject.detectorsAreNotArrayErrorMessage": "无效的 {invalidParamName}:需要是数组。", + "xpack.ml.models.jobValidation.validateJobObject.indicesAreNotArrayErrorMessage": "无效的 {invalidParamName}:需要是数组。", + "xpack.ml.models.jobValidation.validateJobObject.influencersAreNotArrayErrorMessage": "无效的 {invalidParamName}:需要是数组。", + "xpack.ml.models.jobValidation.validateJobObject.jobIsNotObjectErrorMessage": "无效的 {invalidParamName}:需要是对象。", + "xpack.ml.models.jobValidation.validateJobObject.timeFieldIsNotStringErrorMessage": "无效的 {invalidParamName}:需要是字符串。", + "xpack.ml.navMenu.anomalyDetectionTabLinkText": "异常检测", + "xpack.ml.navMenu.anomalyExplorerTabLinkText": "Anomaly Explorer", + "xpack.ml.navMenu.dataFrameAnalyticsTabLinkText": "分析", + "xpack.ml.navMenu.dataVisualizerTabLinkText": "数据可视化工具", + "xpack.ml.navMenu.jobManagementTabLinkText": "作业管理", + "xpack.ml.navMenu.overviewTabLinkText": "概览", + "xpack.ml.navMenu.settingsTabLinkText": "设置", + "xpack.ml.navMenu.singleMetricViewerTabLinkText": "Single Metric Viewer", + "xpack.ml.newJi18n(ob.recognize.jobsCreationFailed.resetButtonAriaLabel": "重置", + "xpack.ml.newJob.recognize.advancedLabel": "高级", + "xpack.ml.newJob.recognize.advancedSettingsAriaLabel": "高级设置", + "xpack.ml.newJob.recognize.alreadyExistsLabel": "(已存在)", + "xpack.ml.newJob.recognize.analysisRunningLabel": "分析正在运行", + "xpack.ml.newJob.recognize.createJobButtonAriaLabel": "创建作业", + "xpack.ml.newJob.recognize.createJobButtonLabel": "创建{numberOfJobs, plural, zero {作业} one {Job} other {Jobs}}", + "xpack.ml.newJob.recognize.dashboardsLabel": "仪表板", + "xpack.ml.newJob.recognize.datafeed.savedAriaLabel": "已保存", + "xpack.ml.newJob.recognize.datafeed.saveFailedAriaLabel": "保存失败", + "xpack.ml.newJob.recognize.datafeedLabel": "数据馈送", + "xpack.ml.newJob.recognize.indexPatternPageTitle": "索引模式 {indexPatternTitle}", + "xpack.ml.newJob.recognize.job.savedAriaLabel": "已保存", + "xpack.ml.newJob.recognize.job.saveFailedAriaLabel": "保存失败", + "xpack.ml.newJob.recognize.jobGroupAllowedCharactersDescription": "作业组名称可以包含小写字母数字(a-z 和 0-9)、连字符或下划线;必须以字母数字字符开头和结尾", + "xpack.ml.newJob.recognize.jobIdPrefixLabel": "作业 ID 前缀", + "xpack.ml.newJob.recognize.jobLabel": "作业名称", + "xpack.ml.newJob.recognize.jobLabelAllowedCharactersDescription": "作业标签可以包含小写字母数字(a-z 和 0-9)、连字符或下划线;必须以字母数字字符开头和结尾", + "xpack.ml.newJob.recognize.jobPrefixInvalidMaxLengthErrorMessage": "作业 ID 前缀的长度不得超过 {maxLength, plural, one {# 个字符} other {# 个字符}}。", + "xpack.ml.newJob.recognize.jobsCreatedTitle": "已创建作业", + "xpack.ml.newJob.recognize.jobSettingsTitle": "作业设置", + "xpack.ml.newJob.recognize.jobsTitle": "作业", + "xpack.ml.newJob.recognize.moduleCheckJobsExistWarningDescription": "尝试检查模块中的作业是否已创建时出错。", + "xpack.ml.newJob.recognize.moduleCheckJobsExistWarningTitle": "检查模块 {moduleId} 时出错", + "xpack.ml.newJob.recognize.moduleSetupFailedWarningDescription": "尝试创建模块中的{count, plural, one {作业} other {作业}}时出错。", + "xpack.ml.newJob.recognize.moduleSetupFailedWarningTitle": "设置模块 {moduleId} 时出错", + "xpack.ml.newJob.recognize.newJobFromTitle": "来自 {pageTitle} 的新作业", + "xpack.ml.newJob.recognize.results.savedAriaLabel": "已保存", + "xpack.ml.newJob.recognize.results.saveFailedAriaLabel": "保存失败", + "xpack.ml.newJob.recognize.running.startedAriaLabel": "已启动", + "xpack.ml.newJob.recognize.running.startFailedAriaLabel": "启动失败", + "xpack.ml.newJob.recognize.runningLabel": "正在运行", + "xpack.ml.newJob.recognize.savedSearchPageTitle": "已保存搜索 {savedSearchTitle}", + "xpack.ml.newJob.recognize.searchesLabel": "搜索", + "xpack.ml.newJob.recognize.searchWillBeOverwrittenLabel": "搜索将被覆盖", + "xpack.ml.newJob.recognize.someJobsCreationFailed.resetButtonLabel": "重置", + "xpack.ml.newJob.recognize.someJobsCreationFailedTitle": "部分作业未能创建", + "xpack.ml.newJob.recognize.startDatafeedAfterSaveLabel": "保存后启动数据馈送", + "xpack.ml.newJob.recognize.useDedicatedIndexLabel": "使用专用索引", + "xpack.ml.newJob.recognize.useFullDataLabel": "使用完整的 {indexPatternTitle} 数据", + "xpack.ml.newJob.recognize.usingSavedSearchDescription": "使用已保存搜索意味着在数据馈送中使用的查询会与我们在 {moduleId} 模块中提供的默认查询不同。", + "xpack.ml.newJob.recognize.viewResultsAriaLabel": "查看结果", + "xpack.ml.newJob.recognize.viewResultsLinkText": "查看结果", + "xpack.ml.newJob.recognize.visualizationsLabel": "可视化", + "xpack.ml.newJob.simple.createWatchView.emailAddressPlaceholder": "电子邮件地址", + "xpack.ml.newJob.simple.createWatchView.nowLabel": "立即 - {selectInterval}", + "xpack.ml.newJob.simple.createWatchView.sendEmailLabel": "发送电子邮件", + "xpack.ml.newJob.simple.createWatchView.severityThresholdLabel": "严重性阈值", + "xpack.ml.newJob.simple.createWatchView.successLabel": "成功", + "xpack.ml.newJob.simple.createWatchView.timeRangeLabel": "时间范围", + "xpack.ml.newJob.simple.createWatchView.watchAlreadyExistsWarningMessage": "警告,监视 ml-{jobId} 已存在,点击“应用”将覆盖原始监视。", + "xpack.ml.newJob.simple.createWatchView.watchEmailAddressAriaLabel": "监视电子邮件地址", + "xpack.ml.newJob.simple.recognize.jobsCreationFailedTitle": "作业创建失败", + "xpack.ml.newJob.simple.watcher.email.anomalyScoreLabel": "异常分数", + "xpack.ml.newJob.simple.watcher.email.elasticStackMachineLearningAlertLabel": "Elastic Stack Machine Learning 告警", + "xpack.ml.newJob.simple.watcher.email.jobLabel": "作业", + "xpack.ml.newJob.simple.watcher.email.mlWatcherAlertSubjectTitle": "ML Watcher 告警", + "xpack.ml.newJob.simple.watcher.email.openInAnomalyExplorerLinkText": "单击此处在 Anomaly Explorer 中打开。", + "xpack.ml.newJob.simple.watcher.email.timeLabel": "时间", + "xpack.ml.newJob.simple.watcher.email.topInfluencersLabel": "排在前面的影响因素:", + "xpack.ml.newJob.simple.watcher.email.topRecordsLabel": "排在前面的记录:", + "xpack.ml.newJob.wizard.autoSetJobCreatorTimeRange.error": "检索索引的开始和结束时间", + "xpack.ml.newJob.wizard.datafeedPreviewFlyout.closeButton": "关闭", + "xpack.ml.newJob.wizard.datafeedPreviewFlyout.datafeedDoesNotExistLabel": "数据馈送不存在", + "xpack.ml.newJob.wizard.datafeedPreviewFlyout.showButton": "数据馈送预览", + "xpack.ml.newJob.wizard.datafeedPreviewFlyout.title": "数据馈送预览", + "xpack.ml.newJob.wizard.datafeedStep.frequency.description": "搜索的时间间隔。", + "xpack.ml.newJob.wizard.datafeedStep.frequency.title": "频率", + "xpack.ml.newJob.wizard.datafeedStep.query.title": "Elasticsearch 查询", + "xpack.ml.newJob.wizard.datafeedStep.queryDelay.description": "当前时间和最新输入数据时间之间的时间延迟(秒)。", + "xpack.ml.newJob.wizard.datafeedStep.queryDelay.title": "查询延迟", + "xpack.ml.newJob.wizard.datafeedStep.scrollSize.description": "为搜索请求的最大文档数目。", + "xpack.ml.newJob.wizard.datafeedStep.scrollSize.title": "滚动条大小", + "xpack.ml.newJob.wizard.datafeedStep.timeField.description": "索引模式的默认时间字段将被自动选择,但可以覆盖。", + "xpack.ml.newJob.wizard.datafeedStep.timeField.title": "时间字段", + "xpack.ml.newJob.wizard.editJsonButton": "编辑 JSON", + "xpack.ml.newJob.wizard.jobDetailsStep.additionalSection.calendarsSelection.title": "日历", + "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.enableModelPlot.description": "选择以存储用于绘制模型边境的其他模型信息。这会增加系统的性能开销,不建议用于高基数数据。", + "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.enableModelPlot.title": "启用模型绘图", + "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.modelMemoryLimit.description": "设置分析模型可使用的内存量预计上限。", + "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.modelMemoryLimit.title": "模型内存限制", + "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.useDedicatedIndex.description": "选择可将结果存储在此作业的不同索引中。", + "xpack.ml.newJob.wizard.jobDetailsStep.advancedSection.useDedicatedIndex.title": "使用专用索引", + "xpack.ml.newJob.wizard.jobDetailsStep.advancedSectionButton": "高级", + "xpack.ml.newJob.wizard.jobDetailsStep.jobDescription.description": "可选描述性文本", + "xpack.ml.newJob.wizard.jobDetailsStep.jobDescription.title": "作业描述", + "xpack.ml.newJob.wizard.jobDetailsStep.jobGroupSelect.description": " (可选)作业的分组。可以创建新组或从现有组列表中选取。", + "xpack.ml.newJob.wizard.jobDetailsStep.jobGroupSelect.placeholder": "选择或创建组", + "xpack.ml.newJob.wizard.jobDetailsStep.jobGroupSelect.title": "组", + "xpack.ml.newJob.wizard.jobDetailsStep.jobId.description": "作业的唯一标识符。不允许使用空格和字符 / ? , \" < > | *", + "xpack.ml.newJob.wizard.jobDetailsStep.jobId.title": "作业 ID", + "xpack.ml.newJob.wizard.jobType.advancedAriaLabel": "高级作业", + "xpack.ml.newJob.wizard.jobType.advancedDescription": "使用全部选项为更高级的用例创建作业。", + "xpack.ml.newJob.wizard.jobType.advancedTitle": "高级", + "xpack.ml.newJob.wizard.jobType.createJobFromTitle": "从 {pageTitleLabel} 创建作业", + "xpack.ml.newJob.wizard.jobType.dataVisualizerAriaLabel": "数据可视化工具", + "xpack.ml.newJob.wizard.jobType.dataVisualizerDescription": "详细了解数据的特征,并通过 Machine Learning 识别分析字段。", + "xpack.ml.newJob.wizard.jobType.dataVisualizerTitle": "数据可视化工具", + "xpack.ml.newJob.wizard.jobType.howToRunAnomalyDetectionDescription": "异常检测只能在基于时间的索引上运行。", + "xpack.ml.newJob.wizard.jobType.indexPatternFromSavedSearchNotTimeBasedMessage": "{savedSearchTitle} 使用了不基于时间的索引模式 {indexPatternTitle}", + "xpack.ml.newJob.wizard.jobType.indexPatternNotTimeBasedMessage": "索引模式 {indexPatternTitle} 不基于时间", + "xpack.ml.newJob.wizard.jobType.indexPatternPageTitleLabel": "索引模式 {indexPatternTitle}", + "xpack.ml.newJob.wizard.jobType.learnMoreAboutDataDescription": "如果您不确定要创建的作业类型,请先浏览数据中的字段和指标。", + "xpack.ml.newJob.wizard.jobType.learnMoreAboutDataTitle": "深入了解数据", + "xpack.ml.newJob.wizard.jobType.multiMetricAriaLabel": "多指标作业", + "xpack.ml.newJob.wizard.jobType.multiMetricDescription": "通过按分类字段分割时序来检测多个指标中的异常。", + "xpack.ml.newJob.wizard.jobType.multiMetricTitle": "多指标", + "xpack.ml.newJob.wizard.jobType.populationAriaLabel": "填充作业", + "xpack.ml.newJob.wizard.jobType.populationDescription": "通过与人口行为比较检测异常活动。", + "xpack.ml.newJob.wizard.jobType.populationTitle": "填充", + "xpack.ml.newJob.wizard.jobType.savedSearchPageTitleLabel": "已保存搜索 {savedSearchTitle}", + "xpack.ml.newJob.wizard.jobType.selectDifferentIndexLinkText": "选择其他索引", + "xpack.ml.newJob.wizard.jobType.singleMetricAriaLabel": "单一指标作业", + "xpack.ml.newJob.wizard.jobType.singleMetricDescription": "检测单个时序中的异常。", + "xpack.ml.newJob.wizard.jobType.singleMetricTitle": "单一指标", + "xpack.ml.newJob.wizard.jobType.useSuppliedConfigurationDescription": "数据中的字段已被识别为匹配已知配置。选择并创建一组 Machine Learning 作业和关联的仪表板。", + "xpack.ml.newJob.wizard.jobType.useSuppliedConfigurationTitle": "使用提供的配置", + "xpack.ml.newJob.wizard.jobType.useWizardDescription": "使用其中一个向导创建 Machine Learning 作业,以查找数据中的异常。", + "xpack.ml.newJob.wizard.jobType.useWizardTitle": "使用向导", + "xpack.ml.newJob.wizard.jsonFlyout.closeButton": "关闭", + "xpack.ml.newJob.wizard.jsonFlyout.datafeed.title": "数据馈送配置 JSON", + "xpack.ml.newJob.wizard.jsonFlyout.job.title": "作业配置 JSON", + "xpack.ml.newJob.wizard.jsonFlyout.saveButton": "保存", + "xpack.ml.newJob.wizard.nextStepButton": "下一步", + "xpack.ml.newJob.wizard.pickFieldsStep.addDetectorButton": "添加检测工具", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorList.deleteButton": "删除", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorList.editButton": "编辑", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorList.title": "检测工具", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.aggSelect.description": "要执行的分析函数,例如 sum、count。", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.aggSelect.title": "函数", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.byFieldSelect.description": "通过与实体自身过去行为对比来检测异常的单个分析所必需。", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.byFieldSelect.title": "按字段", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.cancelButton": "取消", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.description.description": "使用检测工具分析内容的有意义描述覆盖默认检测工具描述。", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.description.title": "描述", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.excludeFrequent.description": "如果为 true,将自动识别并排除经常出现的实体,否则其可能影响结果。", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.excludeFrequent.title": "排除频繁", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.fieldSelect.description": "以下函数所必需:sum、mean、median、max、min、info_content、distinct_count。", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.fieldSelect.title": "字段", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.overFieldSelect.description": "通过与人口行为对比来检测异常的人口分析所必需。", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.overFieldSelect.title": "基于字段", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.partitionFieldSelect.description": "允许将建模分割成逻辑组。", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.partitionFieldSelect.title": "分区字段", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.saveButton": "保存", + "xpack.ml.newJob.wizard.pickFieldsStep.advancedDetectorModal.title": "创建检测工具", + "xpack.ml.newJob.wizard.pickFieldsStep.bucketSpan.description": "设置时序分析的时间间隔,通常 15m 至 1h。", + "xpack.ml.newJob.wizard.pickFieldsStep.bucketSpan.placeholder": "存储桶跨度", + "xpack.ml.newJob.wizard.pickFieldsStep.bucketSpan.title": "存储桶跨度", + "xpack.ml.newJob.wizard.pickFieldsStep.bucketSpanEstimatorButton": "估计桶跨度", + "xpack.ml.newJob.wizard.pickFieldsStep.categorizationField.description": "可选,用于分析非结构化日志数据。建议使用文本数据类型。", + "xpack.ml.newJob.wizard.pickFieldsStep.categorizationField.title": "归类字段", + "xpack.ml.newJob.wizard.pickFieldsStep.detectorTitle.placeholder": "{title} 由 {field} 分割", + "xpack.ml.newJob.wizard.pickFieldsStep.influencers.description": "选择对结果有影响的分类字段。您可能将异常“归咎”于谁/什么因素?建议 1-3 个影响因素。", + "xpack.ml.newJob.wizard.pickFieldsStep.influencers.title": "影响因素", + "xpack.ml.newJob.wizard.pickFieldsStep.multiMetricView.addMetric": "添加指标", + "xpack.ml.newJob.wizard.pickFieldsStep.noDetectorsCallout.message": "至少需要一个检测工具,才能创建作业。", + "xpack.ml.newJob.wizard.pickFieldsStep.noDetectorsCallout.title": "无检测工具", + "xpack.ml.newJob.wizard.pickFieldsStep.populationField.description": "选定字段中的所有值将作为一个群体一起进行建模。建议将此分析类型用于高基数数据。", + "xpack.ml.newJob.wizard.pickFieldsStep.populationField.placeholder": "分割数据", + "xpack.ml.newJob.wizard.pickFieldsStep.populationField.title": "群体字段", + "xpack.ml.newJob.wizard.pickFieldsStep.populationView.addMetric": "添加指标", + "xpack.ml.newJob.wizard.pickFieldsStep.populationView.splitFieldTitle": "群体由 {field} 分割", + "xpack.ml.newJob.wizard.pickFieldsStep.singleMetricView.convertToMultiMetricButton": "转换成多指标作业", + "xpack.ml.newJob.wizard.pickFieldsStep.sparseData.description": "选择是否希望将空存储桶不视为异常。可用于计数和求和分析。", + "xpack.ml.newJob.wizard.pickFieldsStep.sparseData.title": "稀疏数据", + "xpack.ml.newJob.wizard.pickFieldsStep.splitCards.dataSplitBy": "按 {field} 分割数据", + "xpack.ml.newJob.wizard.pickFieldsStep.splitField.description": "选择用于分析分区依据的字段。此字段的每个值将独立进行建模。", + "xpack.ml.newJob.wizard.pickFieldsStep.splitField.title": "分割字段", + "xpack.ml.newJob.wizard.pickFieldsStep.summaryCountField.description": "可选,用于输入数据已预汇总时,例如 \\{docCountParam\\}。", + "xpack.ml.newJob.wizard.pickFieldsStep.summaryCountField.title": "汇总计数字段", + "xpack.ml.newJob.wizard.previewJsonButton": "预览 JSON", + "xpack.ml.newJob.wizard.previousStepButton": "上一页", + "xpack.ml.newJob.wizard.searchSelection.notFoundLabel": "未找到匹配的索引或已保存搜索。", + "xpack.ml.newJob.wizard.searchSelection.savedObjectType.indexPattern": "索引模式", + "xpack.ml.newJob.wizard.searchSelection.savedObjectType.search": "已保存搜索", + "xpack.ml.newJob.wizard.selectIndexPatternOrSavedSearch": "选择索引模式或已保存搜索", + "xpack.ml.newJob.wizard.step.configureDatafeedTitle": "配置数据馈送", + "xpack.ml.newJob.wizard.step.jobDetailsTitle": "作业详情", + "xpack.ml.newJob.wizard.step.pickFieldsTitle": "选取字段", + "xpack.ml.newJob.wizard.step.summaryTitle": "总结", + "xpack.ml.newJob.wizard.step.timeRangeTitle": "时间范围", + "xpack.ml.newJob.wizard.step.validationTitle": "验证", + "xpack.ml.newJob.wizard.stepComponentWrapper.configureDatafeedTitle": "配置数据馈送", + "xpack.ml.newJob.wizard.stepComponentWrapper.jobDetailsTitle": "作业详情", + "xpack.ml.newJob.wizard.stepComponentWrapper.pickFieldsTitle": "选取字段", + "xpack.ml.newJob.wizard.stepComponentWrapper.summaryTitleIndexPattern": "从索引模式 {title} 新建作业", + "xpack.ml.newJob.wizard.stepComponentWrapper.summaryTitleSavedSearch": "从已保存搜索 {title} 新建作业", + "xpack.ml.newJob.wizard.stepComponentWrapper.timeRangeTitle": "时间范围", + "xpack.ml.newJob.wizard.stepComponentWrapper.validationTitle": "验证", + "xpack.ml.newJob.wizard.summaryStep.convertToAdvancedButton": "转换成高级作业", + "xpack.ml.newJob.wizard.summaryStep.createJobButton": "创建作业", + "xpack.ml.newJob.wizard.summaryStep.createJobError": "作业创建错误", + "xpack.ml.newJob.wizard.summaryStep.datafeedConfig.title": "数据馈送配置", + "xpack.ml.newJob.wizard.summaryStep.datafeedDetails.frequency.title": "频率", + "xpack.ml.newJob.wizard.summaryStep.datafeedDetails.query.title": "滚动条大小", + "xpack.ml.newJob.wizard.summaryStep.datafeedDetails.queryDelay.title": "查询延迟", + "xpack.ml.newJob.wizard.summaryStep.datafeedDetails.scrollSize.title": "滚动条大小", + "xpack.ml.newJob.wizard.summaryStep.datafeedDetails.timeField.title": "时间字段", + "xpack.ml.newJob.wizard.summaryStep.defaultString": "默认值", + "xpack.ml.newJob.wizard.summaryStep.falseLabel": "False", + "xpack.ml.newJob.wizard.summaryStep.jobConfig.title": "作业配置", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.bucketSpan.title": "存储桶跨度", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.categorizationField.title": "归类字段", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.enableModelPlot.title": "启用模型绘图", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.groups.placeholder": "未选择组", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.groups.title": "组", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.influencers.placeholder": "未选择影响因素", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.influencers.title": "影响因素", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.jobDescription.placeholder": "未提供描述", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.jobDescription.title": "作业描述", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.jobDetails.title": "作业 ID", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.modelMemoryLimit.title": "模型内存限制", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.populationField.placeholder": "未选择群体字段", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.populationField.title": "群体字段", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.splitField.placeholder": "未选择分割字段", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.splitField.title": "分割字段", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.summaryCountField.title": "汇总计数字段", + "xpack.ml.newJob.wizard.summaryStep.jobDetails.useDedicatedIndex.title": "使用专用索引", + "xpack.ml.newJob.wizard.summaryStep.postSaveOptions.createWatch": "创建监视", + "xpack.ml.newJob.wizard.summaryStep.postSaveOptions.startJobInRealTime": "启动实时运行的作业", + "xpack.ml.newJob.wizard.summaryStep.postSaveOptions.startJobInRealTimeError": "启动作业时出错", + "xpack.ml.newJob.wizard.summaryStep.postSaveOptions.startJobInRealTimeSuccess": "作业 {jobId} 已启动", + "xpack.ml.newJob.wizard.summaryStep.resetJobButton": "重置作业", + "xpack.ml.newJob.wizard.summaryStep.timeRange.end.title": "结束", + "xpack.ml.newJob.wizard.summaryStep.timeRange.start.title": "开始", + "xpack.ml.newJob.wizard.summaryStep.trueLabel": "True", + "xpack.ml.newJob.wizard.summaryStep.viewResultsButton": "查看结果", + "xpack.ml.newJob.wizard.timeRangeStep.timeRangePicker.endDateLabel": "结束日期", + "xpack.ml.newJob.wizard.timeRangeStep.timeRangePicker.startDateLabel": "开始日期", + "xpack.ml.newJob.wizard.validateJob.bucketSpanMustBeSetErrorMessage": "必须设置存储桶跨度", + "xpack.ml.newJob.wizard.validateJob.duplicatedDetectorsErrorMessage": "找到重复的检测工具。", + "xpack.ml.newJob.wizard.validateJob.frequencyInvalidTimeIntervalFormatErrorMessage": "{value} 不是有效的时间间隔格式,例如,{tenMinutes}、{oneHour}。还需要大于零。", + "xpack.ml.newJob.wizard.validateJob.groupNameAlreadyExists": "组 ID 已存在。组 ID 不能与现有作业或组相同。", + "xpack.ml.newJob.wizard.validateJob.jobGroupAllowedCharactersDescription": "作业组名称可以包含小写字母数字(a-z 和 0-9)、连字符或下划线;必须以字母数字字符开头和结尾", + "xpack.ml.newJob.wizard.validateJob.jobGroupMaxLengthDescription": "作业组名称的长度不得超过 {maxLength, plural, one {# 个字符} other {# 个字符}}。", + "xpack.ml.newJob.wizard.validateJob.jobIdInvalidMaxLengthErrorMessage": "作业 ID 的长度不得超过 {maxLength, plural, one {# 个字符} other {# 个字符}}。", + "xpack.ml.newJob.wizard.validateJob.jobNameAllowedCharactersDescription": "作业名称可以包含小写字母数字(a-z 和 0-9)、连字符或下划线;必须以字母数字字符开头和结尾", + "xpack.ml.newJob.wizard.validateJob.jobNameAlreadyExists": "作业 ID 已存在。作业 ID 不能与现有作业或组相同。", + "xpack.ml.newJob.wizard.validateJob.modelMemoryLimitRangeInvalidErrorMessage": "模型内存限制不能高于最大值 {maxModelMemoryLimit}", + "xpack.ml.newJob.wizard.validateJob.modelMemoryLimitUnitsInvalidErrorMessage": "无法识别模型内存限制数据单元。必须为 {str}", + "xpack.ml.newJob.wizard.validateJob.queryCannotBeEmpty": "数据馈送查询不能为空。", + "xpack.ml.newJob.wizard.validateJob.queryIsInvalidEsQuery": "数据馈送查询必须是有效的 Elasticsearch 查询。", + "xpack.ml.overview.analyticsList.createFirstJobMessage": "创建您的首个分析作业。", + "xpack.ml.overview.analyticsList.createJobButtonText": "创建作业", + "xpack.ml.overview.analyticsList.emptyPromptText": "数据帧分析允许您对数据执行不同的分析,并使用结果标注数据。分析作业将标注的数据以及源数据的副本存储在新的索引中。", + "xpack.ml.overview.analyticsList.errorPromptTitle": "获取数据帧分析列表时发生错误。", + "xpack.ml.overview.analyticsList.id": "ID", + "xpack.ml.overview.analyticsList.manageJobsButtonText": "管理作业", + "xpack.ml.overview.analyticsList.PanelTitle": "分析", + "xpack.ml.overview.analyticsList.reatedTimeColumnName": "创建时间", + "xpack.ml.overview.analyticsList.refreshJobsButtonText": "刷新", + "xpack.ml.overview.analyticsList.status": "状态", + "xpack.ml.overview.analyticsList.tableActionLabel": "操作", + "xpack.ml.overview.analyticsList.type": "类型", + "xpack.ml.overview.anomalyDetection.createFirstJobMessage": "创建您的首个异常检测作业。", + "xpack.ml.overview.anomalyDetection.createJobButtonText": "创建作业", + "xpack.ml.overview.anomalyDetection.emptyPromptText": "通过 Machine Learning,可以轻松检测 Elasticsearch 中存储的时序数据中的异常。跟踪单个机器的一个指标或数千个机器的数百个指标。开始自动发现数据中隐藏的异常并更快捷地解决问题。", + "xpack.ml.overview.anomalyDetection.errorPromptTitle": "获取异常检测作业列表时出错。", + "xpack.ml.overview.anomalyDetection.errorWithFetchingAnomalyScoreNotificationErrorMessage": "获取异常分数时出错:{error}", + "xpack.ml.overview.anomalyDetection.exploreActionName": "浏览", + "xpack.ml.overview.anomalyDetection.manageJobsButtonText": "管理作业", + "xpack.ml.overview.anomalyDetection.panelTitle": "异常检测", + "xpack.ml.overview.anomalyDetection.refreshJobsButtonText": "刷新", + "xpack.ml.overview.anomalyDetection.resultActions.openJobsInAnomalyExplorerText": "在 Anomaly Explorer 中打开 {jobsCount, plural, one {{jobId}} other {# 个作业}}", + "xpack.ml.overview.anomalyDetection.tableActionLabel": "操作", + "xpack.ml.overview.anomalyDetection.tableDocsProcessed": "已处理文档", + "xpack.ml.overview.anomalyDetection.tableId": "组 ID", + "xpack.ml.overview.anomalyDetection.tableLatestTimestamp": "最新时间戳", + "xpack.ml.overview.anomalyDetection.tableMaxScore": "最大异常分数", + "xpack.ml.overview.anomalyDetection.tableMaxScoreErrorTooltip": "加载最大异常分数时出现问题", + "xpack.ml.overview.anomalyDetection.tableMaxScoreTooltip": "最近 24 小时期间组中所有作业的最大分数", + "xpack.ml.overview.anomalyDetection.tableNumJobs": "组中的作业", + "xpack.ml.overview.feedbackSectionLink": "在线反馈", + "xpack.ml.overview.feedbackSectionText": "如果您对 Machine Learning 体验有任何建议,请随时{feedbackLink}。", + "xpack.ml.overview.feedbackSectionTitle": "反馈", + "xpack.ml.overview.gettingStartedSectionCreateJob": "创建新作业", + "xpack.ml.overview.gettingStartedSectionDocs": "文档", + "xpack.ml.overview.gettingStartedSectionText": "欢迎使用 Machine Learning。首先阅读我们的{docs}或{createJob}。有关 Elastic Stack 中的机器学习的详情,请参阅{whatIsMachineLearning}。建议使用 {transforms}为分析作业创建功能索引。", + "xpack.ml.overview.gettingStartedSectionTitle": "入门", + "xpack.ml.overview.gettingStartedSectionTransforms": "Elasticsearch 的转换", + "xpack.ml.overview.gettingStartedSectionWhatIsMachineLearning": "此处", + "xpack.ml.overview.statsBar.failedAnalyticsLabel": "失败", + "xpack.ml.overview.statsBar.runningAnalyticsLabel": "正在运行", + "xpack.ml.overview.statsBar.stoppedAnalyticsLabel": "已停止", + "xpack.ml.overview.statsBar.totalAnalyticsLabel": "分析作业总数", + "xpack.ml.overviewJobsList.statsBar.activeMLNodesLabel": "活动 ML 节点", + "xpack.ml.overviewJobsList.statsBar.closedJobsLabel": "已关闭的作业", + "xpack.ml.overviewJobsList.statsBar.failedJobsLabel": "失败的作业", + "xpack.ml.overviewJobsList.statsBar.openJobsLabel": "打开的作业", + "xpack.ml.overviewJobsList.statsBar.totalJobsLabel": "总计作业数", + "xpack.ml.privilege.licenseHasExpiredTooltip": "您的许可证已过期。", + "xpack.ml.privilege.noPermission.createCalendarsTooltip": "您没有权限创建日历。", + "xpack.ml.privilege.noPermission.createMLJobsTooltip": "您没有权限创建 Machine Learning 作业。", + "xpack.ml.privilege.noPermission.deleteCalendarsTooltip": "您没有权限删除日历。", + "xpack.ml.privilege.noPermission.deleteJobsTooltip": "您没有权限删除作业。", + "xpack.ml.privilege.noPermission.editJobsTooltip": "您没有权限编辑作业。", + "xpack.ml.privilege.noPermission.runForecastsTooltip": "您没有权限运行预测。", + "xpack.ml.privilege.noPermission.startOrStopDatafeedsTooltip": "您没有权限开始或停止数据馈送。", + "xpack.ml.privilege.pleaseContactAdministratorTooltip": "{message}请联系您的管理员。", + "xpack.ml.routes.annotations.annotationsFeatureUnavailableErrorMessage": "尚未创建或当前用户无法访问注释功能所需的索引和别名。", + "xpack.ml.ruleEditor.actionsSection.chooseActionsDescription": "选择在规则匹配异常时要采取的操作。", + "xpack.ml.ruleEditor.actionsSection.resultWillNotBeCreatedTooltip": "将不会创建结果。", + "xpack.ml.ruleEditor.actionsSection.skipModelUpdateLabel": "跳过模型更新", + "xpack.ml.ruleEditor.actionsSection.skipResultLabel": "跳过结果(建议)", + "xpack.ml.ruleEditor.actionsSection.valueWillNotBeUsedToUpdateModelTooltip": "该序列的值将不用于更新模型。", + "xpack.ml.ruleEditor.actualAppliesTypeText": "实际", + "xpack.ml.ruleEditor.addValueToFilterListLinkText": "将 {fieldValue} 添加到 {filterId}", + "xpack.ml.ruleEditor.conditionExpression.appliesToButtonLabel": "当", + "xpack.ml.ruleEditor.conditionExpression.appliesToPopoverTitle": "当", + "xpack.ml.ruleEditor.conditionExpression.deleteConditionButtonAriaLabel": "删除条件", + "xpack.ml.ruleEditor.conditionExpression.operatorValueButtonLabel": "是 {operator}", + "xpack.ml.ruleEditor.conditionExpression.operatorValuePopoverTitle": "是", + "xpack.ml.ruleEditor.conditionsSection.addNewConditionButtonLabel": "添加新条件", + "xpack.ml.ruleEditor.deleteJobRule.ruleNoLongerExistsErrorMessage": "作业 {jobId} 中不再存在检测工具索引 {detectorIndex} 的规则", + "xpack.ml.ruleEditor.deleteRuleModal.cancelButtonLabel": "取消", + "xpack.ml.ruleEditor.deleteRuleModal.deleteButtonLabel": "删除", + "xpack.ml.ruleEditor.deleteRuleModal.deleteRuleDescription": "是否确定要删除此规则?", + "xpack.ml.ruleEditor.deleteRuleModal.deleteRuleLinkText": "删除规则", + "xpack.ml.ruleEditor.deleteRuleModal.deleteRuleTitle": "删除规则", + "xpack.ml.ruleEditor.detectorDescriptionList.detectorTitle": "检测工具", + "xpack.ml.ruleEditor.detectorDescriptionList.jobIdTitle": "作业 ID", + "xpack.ml.ruleEditor.detectorDescriptionList.selectedAnomalyDescription": "实际 {actual}典型 {typical}", + "xpack.ml.ruleEditor.detectorDescriptionList.selectedAnomalyTitle": "已选异常", + "xpack.ml.ruleEditor.diffFromTypicalAppliesTypeText": "与典型的差异", + "xpack.ml.ruleEditor.editConditionLink.enterNumericValueForConditionAriaLabel": "输入条件的数值", + "xpack.ml.ruleEditor.editConditionLink.enterValuePlaceholder": "输入值", + "xpack.ml.ruleEditor.editConditionLink.updateLinkText": "更新", + "xpack.ml.ruleEditor.editConditionLink.updateRuleConditionFromText": "将规则条件从 {conditionValue} 更新为", + "xpack.ml.ruleEditor.excludeFilterTypeText": "不含于", + "xpack.ml.ruleEditor.greaterThanOperatorTypeText": "大于", + "xpack.ml.ruleEditor.greaterThanOrEqualToOperatorTypeText": "大于或等于", + "xpack.ml.ruleEditor.includeFilterTypeText": "传入", + "xpack.ml.ruleEditor.lessThanOperatorTypeText": "小于", + "xpack.ml.ruleEditor.lessThanOrEqualToOperatorTypeText": "小于或等于", + "xpack.ml.ruleEditor.ruleActionPanel.editRuleLinkText": "编辑规则", + "xpack.ml.ruleEditor.ruleActionPanel.ruleTitle": "规则", + "xpack.ml.ruleEditor.ruleDescription": "当{conditions}{filters} 时,跳过{actions}", + "xpack.ml.ruleEditor.ruleDescription.conditionsText": "{appliesTo} {operator} {value}", + "xpack.ml.ruleEditor.ruleDescription.filtersText": "{fieldName} 为 {filterType} {filterId}", + "xpack.ml.ruleEditor.ruleDescription.modelUpdateActionTypeText": "模型更新", + "xpack.ml.ruleEditor.ruleDescription.resultActionTypeText": "结果", + "xpack.ml.ruleEditor.ruleEditorFlyout.actionTitle": "操作", + "xpack.ml.ruleEditor.ruleEditorFlyout.addedItemToFilterListNotificationMessageDescription": "注意,更改将仅对新结果有效。", + "xpack.ml.ruleEditor.ruleEditorFlyout.addedItemToFilterListNotificationMessageTitle": "已将 {item} 添加到 {filterId}", + "xpack.ml.ruleEditor.ruleEditorFlyout.changesToJobDetectorRulesSavedNotificationMessageDescription": "注意,更改将仅对新结果有效。", + "xpack.ml.ruleEditor.ruleEditorFlyout.changesToJobDetectorRulesSavedNotificationMessageTitle": "对 {jobId} 检测工具规则的更改已保存", + "xpack.ml.ruleEditor.ruleEditorFlyout.closeButtonLabel": "关闭", + "xpack.ml.ruleEditor.ruleEditorFlyout.conditionsDescription": "添加应用规则的数值条件。多个条件可使用 AND 进行组合。", + "xpack.ml.ruleEditor.ruleEditorFlyout.conditionsNotSupportedTitle": "使用 {functionName} 函数的检测工具不支持条件", + "xpack.ml.ruleEditor.ruleEditorFlyout.conditionsTitle": "条件", + "xpack.ml.ruleEditor.ruleEditorFlyout.createRuleTitle": "创建规则", + "xpack.ml.ruleEditor.ruleEditorFlyout.editRulesTitle": "编辑规则", + "xpack.ml.ruleEditor.ruleEditorFlyout.editRuleTitle": "编辑规则", + "xpack.ml.ruleEditor.ruleEditorFlyout.errorWithAddingItemToFilterListNotificationMessage": "将 {item} 添加到筛选 {filterId} 时出错", + "xpack.ml.ruleEditor.ruleEditorFlyout.errorWithDeletingRuleFromJobDetectorNotificationMessage": "从 {jobId} 检测工具删除规则时出错", + "xpack.ml.ruleEditor.ruleEditorFlyout.errorWithLoadingFilterListsNotificationMesssage": "加载规则范围中使用的筛选列表时出错", + "xpack.ml.ruleEditor.ruleEditorFlyout.errorWithSavingChangesToJobDetectorRulesNotificationMessage": "保存对 {jobId} 检测工具规则的更改时出错", + "xpack.ml.ruleEditor.ruleEditorFlyout.howToApplyChangesToExistingResultsDescription": "要将这些更改应用到现有结果,必须克隆并重新运行作业。注意,重新运行作业可能会花费些时间,应在完成对此作业的规则的所有更改后再重新运行作业。", + "xpack.ml.ruleEditor.ruleEditorFlyout.rerunJobTitle": "重新运行作业", + "xpack.ml.ruleEditor.ruleEditorFlyout.ruleDeletedFromJobDetectorNotificationMessage": "规则已从 {jobId} 检测工具删除", + "xpack.ml.ruleEditor.ruleEditorFlyout.rulesDescription": "规则指示异常检测工具基于您提供的域特定知识更改其行为。创建规则时,您可以指定条件、范围和操作。满足规则的条件时,将会触发其操作。{learnMoreLink}", + "xpack.ml.ruleEditor.ruleEditorFlyout.rulesDescription.learnMoreLinkText": "了解详情", + "xpack.ml.ruleEditor.ruleEditorFlyout.saveButtonLabel": "保存", + "xpack.ml.ruleEditor.ruleEditorFlyout.unableToConfigureRulesNotificationMesssage": "无法配置规则,因为获取作业 ID {jobId} 的详细信息时出错", + "xpack.ml.ruleEditor.ruleEditorFlyout.whenChangesTakeEffectDescription": "对规则的更改仅对新结果有效。", + "xpack.ml.ruleEditor.scopeExpression.scopeFieldWhenLabel": "当", + "xpack.ml.ruleEditor.scopeExpression.scopeFilterTypeButtonLabel": "是 {filterType}", + "xpack.ml.ruleEditor.scopeExpression.scopeFilterTypePopoverTitle": "是", + "xpack.ml.ruleEditor.scopeSection.addFilterListLabel": "添加筛选列表可限制规则的应用位置。", + "xpack.ml.ruleEditor.scopeSection.createFilterListsDescription": "要配置范围,必须首先使用 “{filterListsLink}” 设置页面创建要在规则中包括或排除的值。", + "xpack.ml.ruleEditor.scopeSection.createFilterListsDescription.filterListsLinkText": "筛选列表", + "xpack.ml.ruleEditor.scopeSection.noFilterListsConfiguredTitle": "未配置任何筛选列表", + "xpack.ml.ruleEditor.scopeSection.noPermissionToViewFilterListsTitle": "您无权查看筛选列表", + "xpack.ml.ruleEditor.scopeSection.scopeTitle": "范围", + "xpack.ml.ruleEditor.selectRuleAction.createRuleLinkText": "创建规则", + "xpack.ml.ruleEditor.selectRuleAction.orText": "或 ", + "xpack.ml.ruleEditor.typicalAppliesTypeText": "典型", + "xpack.ml.sampleDataLinkLabel": "ML 作业", + "xpack.ml.settings.breadcrumbs.calendarManagement.createLabel": "创建", + "xpack.ml.settings.breadcrumbs.calendarManagement.editLabel": "编辑", + "xpack.ml.settings.breadcrumbs.calendarManagementLabel": "日历管理", + "xpack.ml.settings.breadcrumbs.filterLists.createLabel": "创建", + "xpack.ml.settings.breadcrumbs.filterLists.editLabel": "编辑", + "xpack.ml.settings.breadcrumbs.filterListsLabel": "筛选列表", + "xpack.ml.settings.calendarManagementButtonLabel": "日历管理", + "xpack.ml.settings.calendars.listHeader.calendarsDescription": "日志包含不想生成异常的已计划事件列表,例如已计划系统中断或公共假期。同一日历可分配给多个作业。{br}{learnMoreLink}", + "xpack.ml.settings.calendars.listHeader.calendarsDescription.learnMoreLinkText": "了解详情", + "xpack.ml.settings.calendars.listHeader.calendarsListTotalCount": "合计 {totalCount}", + "xpack.ml.settings.calendars.listHeader.calendarsTitle": "日历", + "xpack.ml.settings.calendars.listHeader.refreshButtonLabel": "刷新", + "xpack.ml.settings.filterLists.addItemPopover.addButtonLabel": "添加", + "xpack.ml.settings.filterLists.addItemPopover.addItemButtonLabel": "添加项", + "xpack.ml.settings.filterLists.addItemPopover.enterItemPerLineDescription": "每行输入一个项", + "xpack.ml.settings.filterLists.addItemPopover.itemsLabel": "项", + "xpack.ml.settings.filterLists.deleteFilterListModal.cancelButtonLabel": "取消", + "xpack.ml.settings.filterLists.deleteFilterListModal.confirmButtonLabel": "删除", + "xpack.ml.settings.filterLists.deleteFilterListModal.deleteButtonLabel": "删除", + "xpack.ml.settings.filterLists.deleteFilterListModal.deleteWarningMessage": "是否确定要删除{selectedFilterListsLength, plural, one {此筛选列表} other {这些筛选列表}}", + "xpack.ml.settings.filterLists.deleteFilterListModal.modalTitle": "删除 {selectedFilterListsLength, plural, one {{selectedFilterId}} other {# 个筛选列表}}", + "xpack.ml.settings.filterLists.deleteFilterLists.deletingErrorMessage": "删除筛选列表 {filterListId} 时出错。{respMessage}", + "xpack.ml.settings.filterLists.deleteFilterLists.deletingNotificationMessage": "正在删除 {filterListsToDeleteLength, plural, one {{filterListToDeleteId}} other {# 个筛选列表}}", + "xpack.ml.settings.filterLists.deleteFilterLists.filtersSuccessfullyDeletedNotificationMessage": "已删除 {filterListsToDeleteLength, plural, one {{filterListToDeleteId}} other {# 个筛选列表}}", + "xpack.ml.settings.filterLists.editDescriptionPopover.editDescriptionAriaLabel": "编辑描述", + "xpack.ml.settings.filterLists.editDescriptionPopover.filterListDescriptionAriaLabel": "筛选列表描述", + "xpack.ml.settings.filterLists.editFilterHeader.allowedCharactersDescription": "使用小写字母数字(a-z 和 0-9)、连字符或下划线;必须以字母数字字符开头和结尾", + "xpack.ml.settings.filterLists.editFilterHeader.createFilterListTitle": "新建筛选列表", + "xpack.ml.settings.filterLists.editFilterHeader.filterListIdAriaLabel": "筛选列表 ID", + "xpack.ml.settings.filterLists.editFilterHeader.filterListTitle": "筛选列表 {filterId}", + "xpack.ml.settings.filterLists.editFilterList.acrossText": "到", + "xpack.ml.settings.filterLists.editFilterList.addDescriptionText": "添加描述", + "xpack.ml.settings.filterLists.editFilterList.cancelButtonLabel": "取消", + "xpack.ml.settings.filterLists.editFilterList.duplicatedItemsInFilterListWarningMessage": "以下项已存在于筛选列表中:{alreadyInFilter}", + "xpack.ml.settings.filterLists.editFilterList.filterIsNotUsedInJobsDescription": "没有作业使用此筛选列表。", + "xpack.ml.settings.filterLists.editFilterList.filterIsUsedInJobsDescription": "此筛选列表用于", + "xpack.ml.settings.filterLists.editFilterList.loadingDetailsOfFilterErrorMessage": "加载筛选 {filterId} 详情时出错", + "xpack.ml.settings.filterLists.editFilterList.saveButtonLabel": "保存", + "xpack.ml.settings.filterLists.editFilterList.savingFilterErrorMessage": "保存筛选 {filterId} 时出错", + "xpack.ml.settings.filterLists.editFilterList.totalItemsDescription": "共 {totalItemCount, plural, one {# 个项} other {# 个项}}", + "xpack.ml.settings.filterLists.filterLists.loadingFilterListsErrorMessage": "加载筛选列表时出错", + "xpack.ml.settings.filterLists.filterWithIdExistsErrorMessage": "ID 为 {filterId} 的筛选已存在", + "xpack.ml.settings.filterLists.listHeader.filterListsContainsNotAllowedValuesDescription": "筛选列表包含可用于在 Machine Learning 分析中包含或排除事件的值。您可以在多个作业中使用相同的筛选列表。{br}{learnMoreLink}", + "xpack.ml.settings.filterLists.listHeader.filterListsContainsNotAllowedValuesDescription.learnMoreLinkText": "了解详情", + "xpack.ml.settings.filterLists.listHeader.filterListsDescription": "合计 {totalCount}", + "xpack.ml.settings.filterLists.listHeader.filterListsTitle": "筛选列表", + "xpack.ml.settings.filterLists.listHeader.refreshButtonLabel": "刷新", + "xpack.ml.settings.filterLists.table.descriptionColumnName": "描述", + "xpack.ml.settings.filterLists.table.idColumnName": "ID", + "xpack.ml.settings.filterLists.table.inUseAriaLabel": "使用中", + "xpack.ml.settings.filterLists.table.inUseColumnName": "使用中", + "xpack.ml.settings.filterLists.table.itemCountColumnName": "项计数", + "xpack.ml.settings.filterLists.table.newButtonLabel": "新建", + "xpack.ml.settings.filterLists.table.noFiltersCreatedTitle": "未创建任何筛选", + "xpack.ml.settings.filterLists.table.notInUseAriaLabel": "未在使用", + "xpack.ml.settings.filterLists.toolbar.deleteItemButtonLabel": "删除项", + "xpack.ml.settings.filterListsButtonLabel": "筛选列表", + "xpack.ml.settings.jobManagementTitle": "作业管理", + "xpack.ml.settingsBreadcrumbLabel": "设置", + "xpack.ml.singleMetricViewerPageLabel": "Single Metric Viewer", + "xpack.ml.timeSeriesExplorer.allPartitionValuesLabel": "全部", + "xpack.ml.timeSeriesExplorer.annotationDescriptionList.createdByTitle": "创建者", + "xpack.ml.timeSeriesExplorer.annotationDescriptionList.createdTitle": "创建于", + "xpack.ml.timeSeriesExplorer.annotationDescriptionList.endTitle": "结束", + "xpack.ml.timeSeriesExplorer.annotationDescriptionList.jobIdTitle": "作业 ID", + "xpack.ml.timeSeriesExplorer.annotationDescriptionList.lastModifiedTitle": "最后修改时间", + "xpack.ml.timeSeriesExplorer.annotationDescriptionList.modifiedByTitle": "修改者", + "xpack.ml.timeSeriesExplorer.annotationDescriptionList.startTitle": "开始", + "xpack.ml.timeSeriesExplorer.annotationFlyout.addAnnotationTitle": "添加注释", + "xpack.ml.timeSeriesExplorer.annotationFlyout.annotationTextLabel": "注释文本", + "xpack.ml.timeSeriesExplorer.annotationFlyout.approachingMaxLengthWarning": "还剩 {charsRemaining, number} {charsRemaining, plural, one {个字符} other {个字符}}", + "xpack.ml.timeSeriesExplorer.annotationFlyout.cancelButtonLabel": "取消", + "xpack.ml.timeSeriesExplorer.annotationFlyout.createButtonLabel": "创建", + "xpack.ml.timeSeriesExplorer.annotationFlyout.deleteButtonLabel": "删除", + "xpack.ml.timeSeriesExplorer.annotationFlyout.editAnnotationTitle": "编辑注释", + "xpack.ml.timeSeriesExplorer.annotationFlyout.maxLengthError": "超过最大长度 ({maxChars} 个字符) {charsOver, number} {charsOver, plural, one {个字符} other {}}", + "xpack.ml.timeSeriesExplorer.annotationFlyout.noAnnotationTextError": "输入注释文本", + "xpack.ml.timeSeriesExplorer.annotationFlyout.updateButtonLabel": "更新", + "xpack.ml.timeSeriesExplorer.annotationsLabel": "注释", + "xpack.ml.timeSeriesExplorer.annotationsTitle": "注释", + "xpack.ml.timeSeriesExplorer.anomaliesTitle": "异常", + "xpack.ml.timeSeriesExplorer.autoSelectingFirstJobText": ",自动选择第一个作业", + "xpack.ml.timeSeriesExplorer.canNotViewRequestedJobsWarningMessage": "您无法在此仪表板中查看请求的 {invalidIdsCount, plural, one {作业} other {作业}} {invalidIds}", + "xpack.ml.timeSeriesExplorer.countDataInChartDetailsDescription": "{openBrace}{cardinalityValue} 个不同 {fieldName} {cardinality, plural, one {} other {值}}{closeBrace}", + "xpack.ml.timeSeriesExplorer.createNewSingleMetricJobLinkText": "创建新的单指标作业", + "xpack.ml.timeSeriesExplorer.dataNotChartableDescription": "没有为选定{entityCount, plural, one {实体} other {实体}}收集模型绘图\n,无法为此检测工具绘制源数据。", + "xpack.ml.timeSeriesExplorer.deleteAnnotationModal.cancelButtonLabel": "取消", + "xpack.ml.timeSeriesExplorer.deleteAnnotationModal.deleteAnnotationTitle": "删除此注释?", + "xpack.ml.timeSeriesExplorer.deleteAnnotationModal.deleteButtonLabel": "删除", + "xpack.ml.timeSeriesExplorer.detectorLabel": "检测工具", + "xpack.ml.timeSeriesExplorer.enterValuePlaceholder": "输入值", + "xpack.ml.timeSeriesExplorer.forecastingModal.closeButtonLabel": "关闭", + "xpack.ml.timeSeriesExplorer.forecastingModal.closingJobTitle": "正在关闭作业……", + "xpack.ml.timeSeriesExplorer.forecastingModal.dataContainsMorePartitionsMessage": "注意,此数据包含 {warnNumPartitions} 个以上分区,因此运行预测可能会花费很长时间,并消耗大量的资源", + "xpack.ml.timeSeriesExplorer.forecastingModal.errorWithClosingJobAfterRunningForecastErrorMessage": "运行预测后关闭作业时出错", + "xpack.ml.timeSeriesExplorer.forecastingModal.errorWithClosingJobErrorMessage": "关闭作业时出错", + "xpack.ml.timeSeriesExplorer.forecastingModal.errorWithLoadingStatsOfRunningForecastErrorMessage": "加载正在运行的预测的统计信息时出错。", + "xpack.ml.timeSeriesExplorer.forecastingModal.errorWithObtainingListOfPreviousForecastsErrorMessage": "获取之前的预测时出错", + "xpack.ml.timeSeriesExplorer.forecastingModal.errorWithOpeningJobBeforeRunningForecastErrorMessage": "在运行预测之前打开作业时出错", + "xpack.ml.timeSeriesExplorer.forecastingModal.forecastButtonLabel": "预测", + "xpack.ml.timeSeriesExplorer.forecastingModal.forecastDurationMustNotBeGreaterThanMaximumErrorMessage": "预测持续时间不得大于 {maximumForecastDurationDays} 天", + "xpack.ml.timeSeriesExplorer.forecastingModal.forecastDurationMustNotBeZeroErrorMessage": "预测持续时间不得为零", + "xpack.ml.timeSeriesExplorer.forecastingModal.forecastingNotAvailableForPopulationDetectorsMessage": "预测不可用于具有 over 字段的人口检测工具", + "xpack.ml.timeSeriesExplorer.forecastingModal.forecastingOnlyAvailableForJobsCreatedInSpecifiedVersionMessage": "预测仅可用于在版本 {minVersion} 或更高版本中创建的作业", + "xpack.ml.timeSeriesExplorer.forecastingModal.forecastingTitle": "预测", + "xpack.ml.timeSeriesExplorer.forecastingModal.invalidDurationFormatErrorMessage": "持续时间格式无效", + "xpack.ml.timeSeriesExplorer.forecastingModal.noProgressReportedForNewForecastErrorMessage": "有 {WarnNoProgressMs}ms 未报告新预测的进度。运行预测时可能发生了错误。", + "xpack.ml.timeSeriesExplorer.forecastingModal.openingJobTitle": "正在打开作业……", + "xpack.ml.timeSeriesExplorer.forecastingModal.runningForecastTitle": "正在运行预测……", + "xpack.ml.timeSeriesExplorer.forecastingModal.unexpectedResponseFromRunningForecastErrorMessage": "正在运行的预测有意外响应。请求可能已失败。", + "xpack.ml.timeSeriesExplorer.forecastsList.createdColumnName": "创建于", + "xpack.ml.timeSeriesExplorer.forecastsList.fromColumnName": "从", + "xpack.ml.timeSeriesExplorer.forecastsList.listsOfFiveRecentlyRunForecastsTooltip": "最多列出五个最近运行的预测。", + "xpack.ml.timeSeriesExplorer.forecastsList.previousForecastsTitle": "以前的预测", + "xpack.ml.timeSeriesExplorer.forecastsList.toColumnName": "到", + "xpack.ml.timeSeriesExplorer.forecastsList.viewColumnName": "查看", + "xpack.ml.timeSeriesExplorer.forecastsList.viewForecastAriaLabel": "查看在 {createdDate} 创建的预测", + "xpack.ml.timeSeriesExplorer.intervalLabel": "时间间隔", + "xpack.ml.timeSeriesExplorer.loadingLabel": "正在加载", + "xpack.ml.timeSeriesExplorer.noResultsFoundLabel": "找不到结果", + "xpack.ml.timeSeriesExplorer.noSingleMetricJobsFoundLabel": "未找到单指标作业", + "xpack.ml.timeSeriesExplorer.requestedDetectorIndexNotValidWarningMessage": "请求的检测工具索引 {detectorIndex} 对于作业 {jobId} 无效", + "xpack.ml.timeSeriesExplorer.runControls.durationLabel": "持续时间", + "xpack.ml.timeSeriesExplorer.runControls.forecastMaximumLengthHelpText": "预测时长,最多 {maximumForecastDurationDays} 天。使用 s 表示秒,m 表示分钟,h 表示小时,d 表示天,w 表示周。", + "xpack.ml.timeSeriesExplorer.runControls.forecastsCanNotBeRunOnJobsTooltip": "{jobState} 作业上不能运行预测", + "xpack.ml.timeSeriesExplorer.runControls.noMLNodesAvailableTooltip": "没有可用的 ML 节点。", + "xpack.ml.timeSeriesExplorer.runControls.runButtonLabel": "运行", + "xpack.ml.timeSeriesExplorer.runControls.runNewForecastTitle": "运行新的预测", + "xpack.ml.timeSeriesExplorer.severityThresholdLabel": "严重性阈值", + "xpack.ml.timeSeriesExplorer.showForecastLabel": "显示预测", + "xpack.ml.timeSeriesExplorer.showModelBoundsLabel": "显示模型边界", + "xpack.ml.timeSeriesExplorer.singleTimeSeriesAnalysisTitle": "{functionLabel} 的单时间序列分析", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.actualLabel": "实际", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.addedAnnotationNotificationMessage": "已为 ID {jobId} 的作业添加注释。", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.anomalyScoreLabel": "异常分数", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.deletedAnnotationNotificationMessage": "已为 ID {jobId} 的作业删除注释。", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.errorWithCreatingAnnotationNotificationErrorMessage": "为 ID {jobId} 的作业创建注释时发生错误:{error}", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.errorWithDeletingAnnotationNotificationErrorMessage": "为 ID {jobId} 的作业删除注释时发生错误:{error}", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.errorWithUpdatingAnnotationNotificationErrorMessage": "为 ID {jobId} 的作业更新注释时发生错误:{error}", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.modelBoundsNotAvailableLabel": "模型边界不可用", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.modelPlotEnabled.lowerBoundsLabel": "下边界", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.modelPlotEnabled.upperBoundsLabel": "上边界", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.moreThanOneUnusualByFieldValuesLabel": "{numberOfCauses}{plusSign} 异常 {byFieldName} 值", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.multiBucketImpactLabel": "多存储桶影响", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.scheduledEventsLabel": "已计划事件{counter}", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.typicalLabel": "典型", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.updatedAnnotationNotificationMessage": "已为 ID {jobId} 的作业更新注释。", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.valueLabel": "值", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.withoutAnomalyScore.predictionLabel": "预测", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.withoutAnomalyScore.valueLabel": "值", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.withoutAnomalyScoreAndModelPlotEnabled.lowerBoundsLabel": "下边界", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.withoutAnomalyScoreAndModelPlotEnabled.upperBoundsLabel": "上边界", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.zoomAggregationIntervalLabel": "(聚合时间间隔:{focusAggInt},存储桶跨度:{bucketSpan})", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.zoomGroupAggregationIntervalLabel": "(聚合时间间隔:,存储桶跨度:)", + "xpack.ml.timeSeriesExplorer.timeSeriesChart.zoomLabel": "缩放:", + "xpack.ml.timeSeriesExplorer.tryWideningTheTimeSelectionDescription": "请尝试扩大时间选择范围或进一步向后追溯。", + "xpack.ml.timeSeriesExplorer.youCanViewOneJobAtTimeWarningMessage": "在此仪表板中,一次仅可以查看一个作业", + "xpack.ml.tooltips.newJobDedicatedIndexTooltip": "选择可将结果存储在此作业的不同索引中。", + "xpack.ml.tooltips.newJobRecognizerJobPrefixTooltip": "将添加到每个作业 ID 开头的前缀。", + "xpack.ml.upgrade.upgradeWarning.upgradeInProgressWarningDescription": "当前正在升级与 Machine Learning 相关的索引。", + "xpack.ml.upgrade.upgradeWarning.upgradeInProgressWarningDescriptionExtra": "此次某些操作不可用。", + "xpack.ml.upgrade.upgradeWarning.upgradeInProgressWarningTitle": "正在进行索引迁移。", + "xpack.ml.validateJob.allPassed": "所有验证检查都成功通过", + "xpack.ml.validateJob.learnMoreLinkText": "了解详情", + "xpack.ml.validateJob.modal.closeButtonLabel": "关闭", + "xpack.ml.validateJob.modal.jobValidationDescriptionText": "作业验证对作业配置和基础源数据执行特定检查,并提供特定建议,让您了解如何调整设置,才更有可能产生有深刻洞察力的结果。", + "xpack.ml.validateJob.modal.linkToJobTipsText": "有关更多信息,请参阅 {mlJobTipsLink}。", + "xpack.ml.validateJob.modal.linkToJobTipsText.mlJobTipsLinkText": "Machine Learning 作业提示", + "xpack.ml.validateJob.modal.validateJobTitle": "验证作业 {title}", + "xpack.ml.validateJob.validateJobButtonLabel": "验证作业", + "xpack.monitoring.accessDenied.backToKibanaButtonLabel": "返回 Kibana", + "xpack.monitoring.accessDenied.clusterNotConfiguredDescription": "如果您尝试访问专用监测集群,则这可能是因为该监测集群上未配置您登录时所用的用户帐户。", + "xpack.monitoring.accessDenied.notAuthorizedDescription": "您无权访问 Monitoring。要使用 Monitoring,您同时需要 `{kibanaUser}` 和 `{monitoringUser}` 角色授予的权限。", + "xpack.monitoring.accessDeniedTitle": "访问被拒绝", + "xpack.monitoring.ajaxErrorHandler.httpErrorMessage": "HTTP {errStatus}", + "xpack.monitoring.ajaxErrorHandler.requestErrorNotificationTitle": "Monitoring 请求错误", + "xpack.monitoring.ajaxErrorHandler.requestFailedNotification.retryButtonLabel": "重试", + "xpack.monitoring.ajaxErrorHandler.requestFailedNotificationTitle": "Monitoring 请求失败", + "xpack.monitoring.alerts.categoryColumn.generalLabel": "常规", + "xpack.monitoring.alerts.categoryColumnTitle": "类别", + "xpack.monitoring.alerts.clusterAlertsTitle": "集群告警", + "xpack.monitoring.alerts.clusterOverviewLinkLabel": "« 集群概览", + "xpack.monitoring.alerts.filterAlertsPlaceholder": "筛选告警……", + "xpack.monitoring.alerts.highSeverityName": "高", + "xpack.monitoring.alerts.lastCheckedColumnTitle": "上次检查时间", + "xpack.monitoring.alerts.lowSeverityName": "低", + "xpack.monitoring.alerts.mediumSeverityName": "中", + "xpack.monitoring.alerts.messageColumnTitle": "消息", + "xpack.monitoring.alerts.notResolvedDescription": "未解决", + "xpack.monitoring.alerts.resolvedAgoDescription": "{duration}前", + "xpack.monitoring.alerts.resolvedColumnTitle": "已解决", + "xpack.monitoring.alerts.severityTitle": "{severity}紧急告警", + "xpack.monitoring.alerts.statusColumnTitle": "状态", + "xpack.monitoring.alerts.triggeredColumnTitle": "已触发", + "xpack.monitoring.alerts.triggeredColumnValue": "{timestamp}前", + "xpack.monitoring.apm.healthStatusLabel": "运行状况:{status}", + "xpack.monitoring.apm.instance.routeTitle": "{apm} - 实例", + "xpack.monitoring.apm.instance.status.lastEventDescription": "{timeOfLastEvent}前", + "xpack.monitoring.apm.instance.status.lastEventLabel": "最后事件", + "xpack.monitoring.apm.instance.status.nameLabel": "名称", + "xpack.monitoring.apm.instance.status.outputLabel": "输出", + "xpack.monitoring.apm.instance.status.uptimeLabel": "运行时间", + "xpack.monitoring.apm.instance.status.versionLabel": "版本", + "xpack.monitoring.apm.instance.statusDescription": "状态:{apmStatusIcon}", + "xpack.monitoring.apm.instances.allocatedMemoryTitle": "已分配内存", + "xpack.monitoring.apm.instances.bytesSentRateTitle": "已发送字节速率", + "xpack.monitoring.apm.instances.filterInstancesPlaceholder": "筛选实例……", + "xpack.monitoring.apm.instances.lastEventTitle": "最后事件", + "xpack.monitoring.apm.instances.lastEventValue": "{timeOfLastEvent}前", + "xpack.monitoring.apm.instances.nameTitle": "名称", + "xpack.monitoring.apm.instances.outputEnabledTitle": "已启用输出", + "xpack.monitoring.apm.instances.outputErrorsTitle": "输出错误", + "xpack.monitoring.apm.instances.routeTitle": "{apm} - 实例", + "xpack.monitoring.apm.instances.status.lastEventDescription": "{timeOfLastEvent}前", + "xpack.monitoring.apm.instances.status.lastEventLabel": "最后事件", + "xpack.monitoring.apm.instances.status.serversLabel": "服务器", + "xpack.monitoring.apm.instances.status.totalEventsLabel": "事件合计", + "xpack.monitoring.apm.instances.statusDescription": "状态:{apmStatusIcon}", + "xpack.monitoring.apm.instances.totalEventsRateTitle": "事件合计速率", + "xpack.monitoring.apm.instances.versionFilter": "版本", + "xpack.monitoring.apm.instances.versionTitle": "版本", + "xpack.monitoring.apmNavigation.instancesLinkText": "实例", + "xpack.monitoring.apmNavigation.overviewLinkText": "概览", + "xpack.monitoring.beats.filterBeatsPlaceholder": "筛选 Beats……", + "xpack.monitoring.beats.instance.bytesSentLabel": "已发送字节", + "xpack.monitoring.beats.instance.configReloadsLabel": "配置重载", + "xpack.monitoring.beats.instance.eventsDroppedLabel": "已丢弃事件", + "xpack.monitoring.beats.instance.eventsEmittedLabel": "已发出事件", + "xpack.monitoring.beats.instance.eventsTotalLabel": "事件合计", + "xpack.monitoring.beats.instance.handlesLimitHardLabel": "句柄限制(硬性)", + "xpack.monitoring.beats.instance.handlesLimitSoftLabel": "句柄限制(弹性)", + "xpack.monitoring.beats.instance.hostLabel": "主机", + "xpack.monitoring.beats.instance.nameLabel": "名称", + "xpack.monitoring.beats.instance.outputLabel": "输出", + "xpack.monitoring.beats.instance.routeTitle": "Beats - {instanceName} - 概览", + "xpack.monitoring.beats.instance.typeLabel": "类型", + "xpack.monitoring.beats.instance.uptimeLabel": "运行时间", + "xpack.monitoring.beats.instance.versionLabel": "版本", + "xpack.monitoring.beats.instances.allocatedMemoryTitle": "已分配内存", + "xpack.monitoring.beats.instances.bytesSentRateTitle": "已发送字节速率", + "xpack.monitoring.beats.instances.nameTitle": "名称", + "xpack.monitoring.beats.instances.outputEnabledTitle": "已启用输出", + "xpack.monitoring.beats.instances.outputErrorsTitle": "输出错误", + "xpack.monitoring.beats.instances.totalEventsRateTitle": "事件合计速率", + "xpack.monitoring.beats.instances.typeFilter": "类型", + "xpack.monitoring.beats.instances.typeTitle": "类型", + "xpack.monitoring.beats.instances.versionFilter": "版本", + "xpack.monitoring.beats.instances.versionTitle": "版本", + "xpack.monitoring.beats.overview.activeBeatsInLastDayTitle": "过去一天里的活动 Beats", + "xpack.monitoring.beats.overview.bytesSentLabel": "已发送字节", + "xpack.monitoring.beats.overview.latestActive.last1DayLabel": "过去 1 天", + "xpack.monitoring.beats.overview.latestActive.last1HourLabel": "过去 1 小时", + "xpack.monitoring.beats.overview.latestActive.last1MinuteLabel": "过去 1 分钟", + "xpack.monitoring.beats.overview.latestActive.last20MinutesLabel": "过去 20 分钟", + "xpack.monitoring.beats.overview.latestActive.last5MinutesLabel": "过去 5 分钟", + "xpack.monitoring.beats.overview.noActivityDescription": "您好!此区域将显示您最新的 Beats 活动,但似乎在过去一天内您没有任何活动。", + "xpack.monitoring.beats.overview.routeTitle": "Beats - 概览", + "xpack.monitoring.beats.overview.top5BeatTypesInLastDayTitle": "过去一天内排名前 5 的 Beat 类型", + "xpack.monitoring.beats.overview.top5VersionsInLastDayTitle": "过去一天里排名前 5 的版本", + "xpack.monitoring.beats.overview.totalBeatsLabel": "Beats 合计", + "xpack.monitoring.beats.overview.totalEventsLabel": "事件合计", + "xpack.monitoring.beats.routeTitle": "Beats", + "xpack.monitoring.beatsNavigation.instance.overviewLinkText": "概览", + "xpack.monitoring.beatsNavigation.instancesLinkText": "实例", + "xpack.monitoring.beatsNavigation.overviewLinkText": "概览", + "xpack.monitoring.breadcrumbs.apm.instancesLabel": "实例", + "xpack.monitoring.breadcrumbs.apmLabel": "APM", + "xpack.monitoring.breadcrumbs.beats.instancesLabel": "实例", + "xpack.monitoring.breadcrumbs.beatsLabel": "Beats", + "xpack.monitoring.breadcrumbs.clustersLabel": "集群", + "xpack.monitoring.breadcrumbs.es.ccrLabel": "CCR", + "xpack.monitoring.breadcrumbs.es.indicesLabel": "索引", + "xpack.monitoring.breadcrumbs.es.jobsLabel": "作业", + "xpack.monitoring.breadcrumbs.es.nodesLabel": "节点", + "xpack.monitoring.breadcrumbs.kibana.instancesLabel": "实例", + "xpack.monitoring.breadcrumbs.logstash.nodesLabel": "节点", + "xpack.monitoring.breadcrumbs.logstash.pipelinesLabel": "管道", + "xpack.monitoring.breadcrumbs.logstashLabel": "Logstash", + "xpack.monitoring.chart.horizontalLegend.notAvailableLabel": "不适用", + "xpack.monitoring.chart.horizontalLegend.toggleButtonAriaLabel": "切换按钮", + "xpack.monitoring.chart.infoTooltip.intervalLabel": "时间间隔", + "xpack.monitoring.chart.screenReaderUnaccessibleTitle": "此图表不支持屏幕阅读器读取", + "xpack.monitoring.chart.seriesScreenReaderListDescription": "时间间隔:{bucketSize}", + "xpack.monitoring.chart.timeSeries.zoomOut": "缩小", + "xpack.monitoring.cluster.listing.alertsInticator.alertsTooltip": "告警", + "xpack.monitoring.cluster.listing.alertsInticator.clearStatusTooltip": "集群状态正常!", + "xpack.monitoring.cluster.listing.alertsInticator.clearTooltip": "清除", + "xpack.monitoring.cluster.listing.alertsInticator.highSeverityTooltip": "有一些紧急集群问题需要您立即关注!", + "xpack.monitoring.cluster.listing.alertsInticator.lowSeverityTooltip": "存在一些低紧急集群问题", + "xpack.monitoring.cluster.listing.alertsInticator.mediumSeverityTooltip": "有一些问题可能影响您的集群。", + "xpack.monitoring.cluster.listing.dataColumnTitle": "数据", + "xpack.monitoring.cluster.listing.incompatibleLicense.getLicenseLinkLabel": "获取具有完整功能的许可证", + "xpack.monitoring.cluster.listing.incompatibleLicense.infoMessage": "需要监测多个集群?{getLicenseInfoLink}以实现多集群监测。", + "xpack.monitoring.cluster.listing.incompatibleLicense.noMultiClusterSupportMessage": "基本许可不支持多集群监测。", + "xpack.monitoring.cluster.listing.incompatibleLicense.warningMessageTitle": "您无法查看 {clusterName} 集群", + "xpack.monitoring.cluster.listing.indicesColumnTitle": "索引", + "xpack.monitoring.cluster.listing.invalidLicense.getBasicLicenseLinkLabel": "获取免费的基本许可", + "xpack.monitoring.cluster.listing.invalidLicense.getLicenseLinkLabel": "获取具有完整功能的许可证", + "xpack.monitoring.cluster.listing.invalidLicense.infoMessage": "需要许可?{getBasicLicenseLink}或{getLicenseInfoLink}以实现多集群监测。", + "xpack.monitoring.cluster.listing.invalidLicense.invalidInfoMessage": "许可信息无效。", + "xpack.monitoring.cluster.listing.invalidLicense.warningMessageTitle": "您无法查看 {clusterName} 集群", + "xpack.monitoring.cluster.listing.kibanaColumnTitle": "Kibana", + "xpack.monitoring.cluster.listing.licenseColumnTitle": "许可证", + "xpack.monitoring.cluster.listing.logstashColumnTitle": "Logstash", + "xpack.monitoring.cluster.listing.nameColumnTitle": "名称", + "xpack.monitoring.cluster.listing.nodesColumnTitle": "节点", + "xpack.monitoring.cluster.listing.standaloneClusterCallOutDismiss": "消除", + "xpack.monitoring.cluster.listing.standaloneClusterCallOutLink": "查看这些实例。", + "xpack.monitoring.cluster.listing.standaloneClusterCallOutText": "或者,单击下表中的独立集群", + "xpack.monitoring.cluster.listing.standaloneClusterCallOutTitle": "似乎您具有未连接到 Elasticsearch 集群的实例。", + "xpack.monitoring.cluster.listing.statusColumnTitle": "状态", + "xpack.monitoring.cluster.overview.alertsPanel.lastCheckedTimeText": "上次检查时间是 {updateDateTime}(触发于 {duration}前)", + "xpack.monitoring.cluster.overview.alertsPanel.severityIconTitle": "{severityIconTitle}(已在 {time}前解决)", + "xpack.monitoring.cluster.overview.alertsPanel.topClusterTitle": "最亟需处理的集群告警", + "xpack.monitoring.cluster.overview.alertsPanel.viewAllButtonLabel": "查看所有告警", + "xpack.monitoring.cluster.overview.apmPanel.apmTitle": "APM", + "xpack.monitoring.cluster.overview.apmPanel.instancesTotalLinkAriaLabel": "APM 实例:{apmsTotal}", + "xpack.monitoring.cluster.overview.apmPanel.lastEventDescription": "{timeOfLastEvent}前", + "xpack.monitoring.cluster.overview.apmPanel.lastEventLabel": "最后事件", + "xpack.monitoring.cluster.overview.apmPanel.memoryUsageLabel": "内存利用率", + "xpack.monitoring.cluster.overview.apmPanel.overviewLinkAriaLabel": "APM 概览", + "xpack.monitoring.cluster.overview.apmPanel.overviewLinkLabel": "概览", + "xpack.monitoring.cluster.overview.apmPanel.processedEventsLabel": "已处理事件", + "xpack.monitoring.cluster.overview.apmPanel.serversTotalLinkLabel": "APM 服务器:{apmsTotal}", + "xpack.monitoring.cluster.overview.beatsPanel.beatsTitle": "Beats", + "xpack.monitoring.cluster.overview.beatsPanel.beatsTotalLinkLabel": "Beats:{beatsTotal}", + "xpack.monitoring.cluster.overview.beatsPanel.bytesSentLabel": "已发送字节", + "xpack.monitoring.cluster.overview.beatsPanel.instancesTotalLinkAriaLabel": "Beats 实例:{beatsTotal}", + "xpack.monitoring.cluster.overview.beatsPanel.overviewLinkAriaLabel": "Beats 概览", + "xpack.monitoring.cluster.overview.beatsPanel.overviewLinkLabel": "概览", + "xpack.monitoring.cluster.overview.beatsPanel.totalEventsLabel": "事件合计", + "xpack.monitoring.cluster.overview.esPanel.debugLogsTooltipText": "调试日志数", + "xpack.monitoring.cluster.overview.esPanel.diskAvailableLabel": "磁盘可用", + "xpack.monitoring.cluster.overview.esPanel.diskUsageLabel": "磁盘使用", + "xpack.monitoring.cluster.overview.esPanel.documentsLabel": "文档", + "xpack.monitoring.cluster.overview.esPanel.errorLogsTooltipText": "错误日志数", + "xpack.monitoring.cluster.overview.esPanel.fatalLogsTooltipText": "严重日志数", + "xpack.monitoring.cluster.overview.esPanel.indicesCountLinkAriaLabel": "Elasticsearch 索引:{indicesCount}", + "xpack.monitoring.cluster.overview.esPanel.indicesCountLinkLabel": "索引:{indicesCount}", + "xpack.monitoring.cluster.overview.esPanel.infoLogsTooltipText": "信息日志数", + "xpack.monitoring.cluster.overview.esPanel.jobsLabel": "作业", + "xpack.monitoring.cluster.overview.esPanel.jvmHeapLabel": "{javaVirtualMachine} 堆", + "xpack.monitoring.cluster.overview.esPanel.logsLinkAriaLabel": "Elasticsearch 日志", + "xpack.monitoring.cluster.overview.esPanel.logsLinkLabel": "鏃ュ織", + "xpack.monitoring.cluster.overview.esPanel.nodesTotalLinkLabel": "节点:{nodesTotal}", + "xpack.monitoring.cluster.overview.esPanel.overviewLinkAriaLabel": "Elasticsearch 概览", + "xpack.monitoring.cluster.overview.esPanel.overviewLinkLabel": "概览", + "xpack.monitoring.cluster.overview.esPanel.primaryShardsLabel": "主分片", + "xpack.monitoring.cluster.overview.esPanel.replicaShardsLabel": "副本分片", + "xpack.monitoring.cluster.overview.esPanel.uptimeLabel": "运行时间", + "xpack.monitoring.cluster.overview.esPanel.versionLabel": "版本", + "xpack.monitoring.cluster.overview.esPanel.versionNotAvailableDescription": "不适用", + "xpack.monitoring.cluster.overview.esPanel.warnLogsTooltipText": "警告日志数", + "xpack.monitoring.cluster.overview.healthStatusDescription": "运行状况为{status}", + "xpack.monitoring.cluster.overview.kibanaPanel.connectionsLabel": "连接", + "xpack.monitoring.cluster.overview.kibanaPanel.instancesCountLinkAriaLabel": "Kibana 实例:{instancesCount}", + "xpack.monitoring.cluster.overview.kibanaPanel.instancesCountLinkLabel": "实例:{instancesCount}", + "xpack.monitoring.cluster.overview.kibanaPanel.kibanaTitle": "Kibana", + "xpack.monitoring.cluster.overview.kibanaPanel.maxResponseTimeDescription": "{maxTime} 毫秒", + "xpack.monitoring.cluster.overview.kibanaPanel.maxResponseTimeLabel": "最大响应时间", + "xpack.monitoring.cluster.overview.kibanaPanel.memoryUsageLabel": "内存利用率", + "xpack.monitoring.cluster.overview.kibanaPanel.overviewLinkAriaLabel": "Kibana 概览", + "xpack.monitoring.cluster.overview.kibanaPanel.overviewLinkLabel": "概览", + "xpack.monitoring.cluster.overview.kibanaPanel.requestsLabel": "请求", + "xpack.monitoring.cluster.overview.licenseText.expireDateText": "将于 {expiryDate}过期", + "xpack.monitoring.cluster.overview.licenseText.toLicensePageLinkLabel": "{licenseType}许可{willExpireOn}", + "xpack.monitoring.cluster.overview.logsPanel.logTypeTitle": "{type}", + "xpack.monitoring.cluster.overview.logsPanel.noLogsFound": "未找到任何日志。", + "xpack.monitoring.cluster.overview.logstashPanel.betaFeatureTooltip": "公测版功能", + "xpack.monitoring.cluster.overview.logstashPanel.eventsEmittedLabel": "已发出事件", + "xpack.monitoring.cluster.overview.logstashPanel.eventsReceivedLabel": "已接收事件", + "xpack.monitoring.cluster.overview.logstashPanel.jvmHeapLabel": "{javaVirtualMachine} 堆", + "xpack.monitoring.cluster.overview.logstashPanel.logstashTitle": "Logstash", + "xpack.monitoring.cluster.overview.logstashPanel.nodesCountLinkAriaLabel": "Logstash 节点:{nodesCount}", + "xpack.monitoring.cluster.overview.logstashPanel.nodesCountLinkLabel": "节点:{nodesCount}", + "xpack.monitoring.cluster.overview.logstashPanel.overviewLinkAriaLabel": "Logstash 概览", + "xpack.monitoring.cluster.overview.logstashPanel.overviewLinkLabel": "概览", + "xpack.monitoring.cluster.overview.logstashPanel.pipelineCountLinkAriaLabel": "Logstash 管道(公测版功能):{pipelineCount}", + "xpack.monitoring.cluster.overview.logstashPanel.pipelinesCountLinkLabel": "管道:{pipelineCount}", + "xpack.monitoring.cluster.overview.logstashPanel.uptimeLabel": "运行时间", + "xpack.monitoring.cluster.overview.logstashPanel.withMemoryQueuesLabel": "内存队列", + "xpack.monitoring.cluster.overview.logstashPanel.withPersistentQueuesLabel": "持久性队列", + "xpack.monitoring.cluster.overviewTitle": "概览", + "xpack.monitoring.clusterAlerts.checkLicense.licenseIsBasicDescription": "如果禁用了 Watcher 或 [{clusterSource}] 集群的当前许可为基本许可,则“集群告警”将不会显示。", + "xpack.monitoring.clusterAlerts.checkLicense.licenseNotActiveDescription": "因为 [{clusterSource}] 集群的当前许可 [{type}] 未处于活动状态,所以“集群告警”将不会显示。", + "xpack.monitoring.clusterAlerts.checkLicense.licenseNotDeterminedDescription": "因为无法确定 [{clusterSource}] 集群的许可,所以“集群告警”将不会显示。", + "xpack.monitoring.clusterAlerts.checkLicense.watcherIsDisabledDescription": "因为禁用了 Watcher,所以“集群告警”未启用。", + "xpack.monitoring.clusterAlerts.clusterNeedsTSLEnabledDescription": "启用安全性时,需要配置 TLS,才能应用黄金或白金许可。", + "xpack.monitoring.clusterAlerts.disabledLicenseDescription": "“集群告警”功能已禁用。", + "xpack.monitoring.clusterAlerts.notDeterminedLicenseDescription": "无法确定“集群告警”功能的状态。", + "xpack.monitoring.clusterAlerts.seeDocumentationDescription": "有关详情,请参阅文档。", + "xpack.monitoring.clusterAlerts.unsupportedClusterAlertsDescription": "集群 [{clusterName}] 许可类型 [{licenseType}] 不支持“集群告警”", + "xpack.monitoring.clusterAlertsNavigation.clusterAlertsLinkText": "集群告警", + "xpack.monitoring.clustersNavigation.clustersLinkText": "集群", + "xpack.monitoring.clusterStats.uuidNotFoundErrorMessage": "在选定时间范围内找不到该集群。UUID:{clusterUuid}", + "xpack.monitoring.clusterStats.uuidNotSpecifiedErrorMessage": "{clusterUuid} 未指定", + "xpack.monitoring.elasticsearch.ccr.ccrListingTable.errorColumnTitle": "错误", + "xpack.monitoring.elasticsearch.ccr.ccrListingTable.followsColumnTitle": "跟随", + "xpack.monitoring.elasticsearch.ccr.ccrListingTable.indexColumnTitle": "索引", + "xpack.monitoring.elasticsearch.ccr.ccrListingTable.lastFetchTimeColumnTitle": "上次提取时间", + "xpack.monitoring.elasticsearch.ccr.ccrListingTable.opsSyncedColumnTitle": "已同步操作", + "xpack.monitoring.elasticsearch.ccr.ccrListingTable.syncLagOpsColumnTitle": "同步延迟(操作)", + "xpack.monitoring.elasticsearch.ccr.routeTitle": "Elasticsearch - CCR", + "xpack.monitoring.elasticsearch.ccr.shard.instanceTitle": "索引:{followerIndex} 分片:{shardId}", + "xpack.monitoring.elasticsearch.ccr.shard.routeTitle": "Elasticsearch - CCR - 分片", + "xpack.monitoring.elasticsearch.ccr.shardsTable.errorColumnTitle": "错误", + "xpack.monitoring.elasticsearch.ccr.shardsTable.lastFetchTimeColumnTitle": "上次提取时间", + "xpack.monitoring.elasticsearch.ccr.shardsTable.opsSyncedColumnTitle": "已同步操作", + "xpack.monitoring.elasticsearch.ccr.shardsTable.shardColumnTitle": "分片", + "xpack.monitoring.elasticsearch.ccr.shardsTable.syncLagOpsColumn.followerLagTooltip": "Follower 延迟:{syncLagOpsFollower}", + "xpack.monitoring.elasticsearch.ccr.shardsTable.syncLagOpsColumn.leaderLagTooltip": "Leader 延迟:{syncLagOpsLeader}", + "xpack.monitoring.elasticsearch.ccr.shardsTable.syncLagOpsColumnTitle": "同步延迟(操作)", + "xpack.monitoring.elasticsearch.ccrShard.errorsTable.reasonColumnTitle": "原因", + "xpack.monitoring.elasticsearch.ccrShard.errorsTable.typeColumnTitle": "类型", + "xpack.monitoring.elasticsearch.ccrShard.errorsTableTitle": "错误", + "xpack.monitoring.elasticsearch.ccrShard.latestStateAdvancedButtonLabel": "高级", + "xpack.monitoring.elasticsearch.ccrShard.status.failedFetchesLabel": "失败提取", + "xpack.monitoring.elasticsearch.ccrShard.status.followerIndexLabel": "Follower 索引", + "xpack.monitoring.elasticsearch.ccrShard.status.leaderIndexLabel": "Leader 索引", + "xpack.monitoring.elasticsearch.ccrShard.status.opsSyncedLabel": "已同步操作", + "xpack.monitoring.elasticsearch.ccrShard.status.shardIdLabel": "分片 ID", + "xpack.monitoring.elasticsearch.clusterStatus.dataLabel": "数据", + "xpack.monitoring.elasticsearch.clusterStatus.documentsLabel": "文档", + "xpack.monitoring.elasticsearch.clusterStatus.indicesLabel": "索引", + "xpack.monitoring.elasticsearch.clusterStatus.memoryLabel": "内存", + "xpack.monitoring.elasticsearch.clusterStatus.nodesLabel": "节点", + "xpack.monitoring.elasticsearch.clusterStatus.totalShardsLabel": "分片合计", + "xpack.monitoring.elasticsearch.clusterStatus.unassignedShardsLabel": "未分配分片", + "xpack.monitoring.elasticsearch.healthStatusLabel": "运行状况:{status}", + "xpack.monitoring.elasticsearch.indexDetailStatus.documentsTitle": "文档", + "xpack.monitoring.elasticsearch.indexDetailStatus.iconStatusLabel": "运行状况:{elasticsearchStatusIcon}", + "xpack.monitoring.elasticsearch.indexDetailStatus.primariesTitle": "主分片", + "xpack.monitoring.elasticsearch.indexDetailStatus.totalShardsTitle": "分片合计", + "xpack.monitoring.elasticsearch.indexDetailStatus.totalTitle": "合计", + "xpack.monitoring.elasticsearch.indexDetailStatus.unassignedShardsTitle": "未分配分片", + "xpack.monitoring.elasticsearch.indices.advanced.routeTitle": "Elasticsearch - 索引 - {indexName} - 高级", + "xpack.monitoring.elasticsearch.indices.dataTitle": "数据", + "xpack.monitoring.elasticsearch.indices.documentCountTitle": "文档计数", + "xpack.monitoring.elasticsearch.indices.howToShowSystemIndicesDescription": "如果您正在寻找系统索引(例如 .kibana),请尝试选中“显示系统索引”。", + "xpack.monitoring.elasticsearch.indices.indexRateTitle": "索引速率", + "xpack.monitoring.elasticsearch.indices.monitoringTablePlaceholder": "筛选索引……", + "xpack.monitoring.elasticsearch.indices.nameTitle": "名称", + "xpack.monitoring.elasticsearch.indices.noIndicesMatchYourSelectionDescription": "没有索引匹配您的选择。请尝试更改时间范围选择。", + "xpack.monitoring.elasticsearch.indices.overview.routeTitle": "Elasticsearch - 索引 - {indexName} - 概览", + "xpack.monitoring.elasticsearch.indices.routeTitle": "Elasticsearch - 索引", + "xpack.monitoring.elasticsearch.indices.searchRateTitle": "搜索速率", + "xpack.monitoring.elasticsearch.indices.statusTitle": "状态", + "xpack.monitoring.elasticsearch.indices.systemIndicesLabel": "系统索引", + "xpack.monitoring.elasticsearch.indices.unassignedShardsTitle": "未分配分片", + "xpack.monitoring.elasticsearch.mlJobListing.filterJobsPlaceholder": "筛选作业……", + "xpack.monitoring.elasticsearch.mlJobListing.forecastsTitle": "预测", + "xpack.monitoring.elasticsearch.mlJobListing.jobIdTitle": "作业 ID", + "xpack.monitoring.elasticsearch.mlJobListing.modelSizeTitle": "模型大小", + "xpack.monitoring.elasticsearch.mlJobListing.noDataLabel": "不适用", + "xpack.monitoring.elasticsearch.mlJobListing.nodeTitle": "节点", + "xpack.monitoring.elasticsearch.mlJobListing.noJobsDescription": "没有 Machine Learning 作业匹配您的查询。请尝试更改时间范围选择。", + "xpack.monitoring.elasticsearch.mlJobListing.processedRecordsTitle": "已处理记录", + "xpack.monitoring.elasticsearch.mlJobListing.stateTitle": "状态", + "xpack.monitoring.elasticsearch.mlJobListing.statusIconLabel": "作业状态:{status}", + "xpack.monitoring.elasticsearch.mlJobs.routeTitle": "Elasticsearch - Machine Learning 作业", + "xpack.monitoring.elasticsearch.node.advanced.routeTitle": "Elasticsearch - 节点 - {nodeSummaryName} - 高级", + "xpack.monitoring.elasticsearch.node.overview.routeTitle": "Elasticsearch - 节点 - {nodeName} - 概览", + "xpack.monitoring.elasticsearch.node.statusIconLabel": "状态:{status}", + "xpack.monitoring.elasticsearch.nodeDetailStatus.dataLabel": "数据", + "xpack.monitoring.elasticsearch.nodeDetailStatus.documentsLabel": "文档", + "xpack.monitoring.elasticsearch.nodeDetailStatus.freeDiskSpaceLabel": "可用磁盘空间", + "xpack.monitoring.elasticsearch.nodeDetailStatus.indicesLabel": "索引", + "xpack.monitoring.elasticsearch.nodeDetailStatus.jvmHeapLabel": "{javaVirtualMachine} 堆", + "xpack.monitoring.elasticsearch.nodeDetailStatus.shardsLabel": "分片", + "xpack.monitoring.elasticsearch.nodeDetailStatus.transportAddress": "传输地址", + "xpack.monitoring.elasticsearch.nodeDetailStatus.typeLabel": "类型", + "xpack.monitoring.elasticsearch.nodes.cells.maxText": "{metric} 最大值", + "xpack.monitoring.elasticsearch.nodes.cells.minText": "{metric} 最小值", + "xpack.monitoring.elasticsearch.nodes.cpuThrottlingColumnTitle": "CPU 限制", + "xpack.monitoring.elasticsearch.nodes.cpuUsageColumnTitle": "CPU 使用", + "xpack.monitoring.elasticsearch.nodes.diskFreeSpaceColumnTitle": "磁盘可用空间", + "xpack.monitoring.elasticsearch.nodes.jvmMemoryColumnTitle": "{javaVirtualMachine} 内存", + "xpack.monitoring.elasticsearch.nodes.loadAverageColumnTitle": "负载平均值", + "xpack.monitoring.elasticsearch.nodes.metricbeatMigration.detectedNodeDescription": "以下节点未受监测。单击下面的“使用 Metricbeat 监测”以开始监测。", + "xpack.monitoring.elasticsearch.nodes.metricbeatMigration.detectedNodeTitle": "检测到 Elasticsearch 节点", + "xpack.monitoring.elasticsearch.nodes.metricbeatMigration.disableInternalCollectionDescription": "禁用内部收集以完成迁移。", + "xpack.monitoring.elasticsearch.nodes.metricbeatMigration.disableInternalCollectionMigrationButtonLabel": "禁用内部收集", + "xpack.monitoring.elasticsearch.nodes.metricbeatMigration.disableInternalCollectionTitle": "Metricbeat 现在正监测您的 Elasticsearch 节点", + "xpack.monitoring.elasticsearch.nodes.monitoringTablePlaceholder": "筛选节点……", + "xpack.monitoring.elasticsearch.nodes.nameColumnTitle": "名称", + "xpack.monitoring.elasticsearch.nodes.routeTitle": "Elasticsearch - 节点", + "xpack.monitoring.elasticsearch.nodes.shardsColumnTitle": "分片", + "xpack.monitoring.elasticsearch.nodes.statusColumn.offlineLabel": "脱机", + "xpack.monitoring.elasticsearch.nodes.statusColumn.onlineLabel": "联机", + "xpack.monitoring.elasticsearch.nodes.statusColumnTitle": "状态", + "xpack.monitoring.elasticsearch.shardActivity.completedRecoveriesLabel": "已完成恢复", + "xpack.monitoring.elasticsearch.shardActivity.noActiveShardRecoveriesMessage.completedRecoveriesLinkText": "已完成恢复", + "xpack.monitoring.elasticsearch.shardActivity.noActiveShardRecoveriesMessage.completedRecoveriesLinkTextProblem": "此集群没有活动的分片恢复。", + "xpack.monitoring.elasticsearch.shardActivity.noActiveShardRecoveriesMessage.completedRecoveriesLinkTextSolution": "尝试查看{shardActivityHistoryLink}。", + "xpack.monitoring.elasticsearch.shardActivity.noDataMessage": "选定时间范围没有历史分片活动记录。", + "xpack.monitoring.elasticsearch.shardActivity.progress.noTranslogProgressLabel": "不适用", + "xpack.monitoring.elasticsearch.shardActivity.recoveryIndex.recoveryTypeDescription": "恢复类型:{relocationType}", + "xpack.monitoring.elasticsearch.shardActivity.recoveryIndex.shardDescription": "分片:{shard}", + "xpack.monitoring.elasticsearch.shardActivity.snapshotTitle": "存储库:{repo} / 快照:{snapshot}", + "xpack.monitoring.elasticsearch.shardActivity.sourceTooltip": "复制自 {copiedFrom} 分片", + "xpack.monitoring.elasticsearch.shardActivity.sourceTooltip.primarySourceText": "主分片", + "xpack.monitoring.elasticsearch.shardActivity.sourceTooltip.replicaSourceText": "副本分片", + "xpack.monitoring.elasticsearch.shardActivity.totalTimeTooltip": "已启动:{startTime}", + "xpack.monitoring.elasticsearch.shardActivityTitle": "分片活动", + "xpack.monitoring.elasticsearch.shardAllocation.clusterViewDisplayName": "ClusterView", + "xpack.monitoring.elasticsearch.shardAllocation.decorateShards.relocatingFromTextMessage": "正在从 {nodeName} 迁移", + "xpack.monitoring.elasticsearch.shardAllocation.decorateShards.relocatingToTextMessage": "正在迁移至 {nodeName}", + "xpack.monitoring.elasticsearch.shardAllocation.initializingLabel": "正在初始化", + "xpack.monitoring.elasticsearch.shardAllocation.labels.indicesLabel": "索引", + "xpack.monitoring.elasticsearch.shardAllocation.labels.nodesLabel": "节点", + "xpack.monitoring.elasticsearch.shardAllocation.labels.unassignedLabel": "未分配", + "xpack.monitoring.elasticsearch.shardAllocation.labels.unassignedNodesLabel": "节点", + "xpack.monitoring.elasticsearch.shardAllocation.primaryLabel": "主分片", + "xpack.monitoring.elasticsearch.shardAllocation.relocatingLabel": "正在迁移", + "xpack.monitoring.elasticsearch.shardAllocation.replicaLabel": "副本分片", + "xpack.monitoring.elasticsearch.shardAllocation.shardDisplayName": "分片", + "xpack.monitoring.elasticsearch.shardAllocation.shardLegendTitle": "分片图例", + "xpack.monitoring.elasticsearch.shardAllocation.tableBody.noShardsAllocatedDescription": "未分配任何分片。", + "xpack.monitoring.elasticsearch.shardAllocation.tableBodyDisplayName": "TableBody", + "xpack.monitoring.elasticsearch.shardAllocation.tableHead.indicesLabel": "索引", + "xpack.monitoring.elasticsearch.shardAllocation.unassignedDisplayName": "未分配", + "xpack.monitoring.elasticsearch.shardAllocation.unassignedPrimaryLabel": "未分配主分片", + "xpack.monitoring.elasticsearch.shardAllocation.unassignedReplicaLabel": "未分配副本分片", + "xpack.monitoring.errors.connectionFaultErrorMessage": "检查 Elasticsearch Monitoring 集群网络连接,并参考 Kibana 日志以了解详情。", + "xpack.monitoring.errors.insufficientUserErrorMessage": "对监测数据没有足够的用户权限", + "xpack.monitoring.errors.invalidAuthErrorMessage": "监测集群的身份验证无效", + "xpack.monitoring.errors.monitoringLicenseErrorDescription": "无法找到集群“{clusterId}”的许可信息。请在集群的主节点服务器日志中查看相关错误或警告。", + "xpack.monitoring.errors.monitoringLicenseErrorTitle": "监测许可错误", + "xpack.monitoring.errors.noConnectionsErrorMessage": "检查 Elasticsearch Monitoring 集群网络连接,并参考 Kibana 日志以了解详情。", + "xpack.monitoring.errors.statusCodeErrorMessage": "检查 Elasticsearch Monitoring 集群网络连接或节点的负载水平。", + "xpack.monitoring.es.indices.deletedClosedStatusLabel": "已删除 / 已关闭", + "xpack.monitoring.es.indices.notAvailableStatusLabel": "不可用", + "xpack.monitoring.es.indices.unknownStatusLabel": "未知", + "xpack.monitoring.es.nodes.offlineNodeStatusLabel": "脱机节点", + "xpack.monitoring.es.nodes.offlineStatusLabel": "脱机", + "xpack.monitoring.es.nodes.onlineStatusLabel": "联机", + "xpack.monitoring.es.nodeType.clientNodeLabel": "客户端节点", + "xpack.monitoring.es.nodeType.dataOnlyNodeLabel": "纯数据节点", + "xpack.monitoring.es.nodeType.invalidNodeLabel": "无效节点", + "xpack.monitoring.es.nodeType.masterNodeLabel": "主节点", + "xpack.monitoring.es.nodeType.masterOnlyNodeLabel": "只作主节点的节点", + "xpack.monitoring.es.nodeType.nodeLabel": "节点", + "xpack.monitoring.esNavigation.ccrLinkText": "CCR", + "xpack.monitoring.esNavigation.indicesLinkText": "索引", + "xpack.monitoring.esNavigation.instance.advancedLinkText": "高级", + "xpack.monitoring.esNavigation.instance.overviewLinkText": "概览", + "xpack.monitoring.esNavigation.jobsLinkText": "作业", + "xpack.monitoring.esNavigation.nodesLinkText": "节点", + "xpack.monitoring.esNavigation.overviewLinkText": "概览", + "xpack.monitoring.euiSSPTable.setupNewButtonLabel": "为新的 {identifier} 设置监测", + "xpack.monitoring.euiTable.isFullyMigratedLabel": "Metricbeat 收集", + "xpack.monitoring.euiTable.isInternalCollectorLabel": "内部收集", + "xpack.monitoring.euiTable.isPartiallyMigratedLabel": "内部收集开启", + "xpack.monitoring.euiTable.setupNewButtonLabel": "使用 Metricbeat 监测其他 {identifier}", + "xpack.monitoring.feature.reserved.description": "要向用户授予访问权限,还应分配 monitoring_user 角色。", + "xpack.monitoring.featureRegistry.monitoringFeatureName": "堆栈监测", + "xpack.monitoring.formatNumbers.notAvailableLabel": "不适用", + "xpack.monitoring.kibana.clusterStatus.connectionsLabel": "连接", + "xpack.monitoring.kibana.clusterStatus.instancesLabel": "实例", + "xpack.monitoring.kibana.clusterStatus.maxResponseTimeLabel": "最大响应时间", + "xpack.monitoring.kibana.clusterStatus.memoryLabel": "内存", + "xpack.monitoring.kibana.clusterStatus.requestsLabel": "请求", + "xpack.monitoring.kibana.detailStatus.osFreeMemoryLabel": "OS 可用内存", + "xpack.monitoring.kibana.detailStatus.transportAddressLabel": "传输地址", + "xpack.monitoring.kibana.detailStatus.uptimeLabel": "运行时间", + "xpack.monitoring.kibana.detailStatus.versionLabel": "版本", + "xpack.monitoring.kibana.instances.metricbeatMigration.detectedNodeDescription": "以下实例未受监测。\n 单击下面的“使用 Metricbeat 监测”以开始监测。", + "xpack.monitoring.kibana.instances.metricbeatMigration.detectedNodeTitle": "检测到 Kibana 实例", + "xpack.monitoring.kibana.listing.filterInstancesPlaceholder": "筛选实例……", + "xpack.monitoring.kibana.listing.instanceStatus.offlineLabel": "脱机", + "xpack.monitoring.kibana.listing.instanceStatusTitle": "实例状态:{kibanaStatus}", + "xpack.monitoring.kibana.listing.loadAverageColumnTitle": "负载平均值", + "xpack.monitoring.kibana.listing.memorySizeColumnTitle": "内存大小", + "xpack.monitoring.kibana.listing.nameColumnTitle": "名称", + "xpack.monitoring.kibana.listing.requestsColumnTitle": "请求", + "xpack.monitoring.kibana.listing.responseTimeColumnTitle": "响应时间", + "xpack.monitoring.kibana.listing.statusColumnTitle": "状态", + "xpack.monitoring.kibana.shardActivity.bytesTitle": "字节", + "xpack.monitoring.kibana.shardActivity.filesTitle": "文件", + "xpack.monitoring.kibana.shardActivity.indexTitle": "索引", + "xpack.monitoring.kibana.shardActivity.sourceDestinationTitle": "源 / 目标", + "xpack.monitoring.kibana.shardActivity.stageTitle": "阶段", + "xpack.monitoring.kibana.shardActivity.totalTimeTitle": "总时间", + "xpack.monitoring.kibana.shardActivity.translogTitle": "事务日志", + "xpack.monitoring.kibana.statusIconLabel": "运行状况:{status}", + "xpack.monitoring.kibanaNavigation.instancesLinkText": "实例", + "xpack.monitoring.kibanaNavigation.overviewLinkText": "概览", + "xpack.monitoring.license.howToUpdateLicenseDescription": "要更新此集群的许可,请通过 Elasticsearch {apiText} 提供许可文件:", + "xpack.monitoring.license.licenseRouteTitle": "许可证", + "xpack.monitoring.logs.listing.calloutLinkText": "鏃ュ織", + "xpack.monitoring.logs.listing.calloutTitle": "想要查看更多日志?", + "xpack.monitoring.logs.listing.clusterPageDescription": "显示此集群最新的日志,总共最多 {limit} 个日志。", + "xpack.monitoring.logs.listing.componentTitle": "组件", + "xpack.monitoring.logs.listing.indexPageDescription": "显示此索引最新的日志,总共最多 {limit} 个日志。", + "xpack.monitoring.logs.listing.levelTitle": "级别", + "xpack.monitoring.logs.listing.linkText": "访问 {link} 以更深入了解。", + "xpack.monitoring.logs.listing.messageTitle": "消息", + "xpack.monitoring.logs.listing.nodePageDescription": "显示此节点最新的日志,总共最多 {limit} 个日志。", + "xpack.monitoring.logs.listing.nodeTitle": "节点", + "xpack.monitoring.logs.listing.pageTitle": "最近日志", + "xpack.monitoring.logs.listing.timestampTitle": "时间戳", + "xpack.monitoring.logs.listing.typeTitle": "类型", + "xpack.monitoring.logs.reason.correctIndexNameLink": "单击此处以获取更多信息", + "xpack.monitoring.logs.reason.correctIndexNameMessage": "从您的 filebeat 索引读取数据时出现问题。{link}。", + "xpack.monitoring.logs.reason.correctIndexNameTitle": "Filebeat 索引损坏", + "xpack.monitoring.logs.reason.defaultMessage": "我们未找到任何日志数据,我们无法诊断原因。{link}", + "xpack.monitoring.logs.reason.defaultMessageLink": "请确认您的设置正确。", + "xpack.monitoring.logs.reason.defaultTitle": "未找到任何日志数据", + "xpack.monitoring.logs.reason.noClusterLink": "设置", + "xpack.monitoring.logs.reason.noClusterMessage": "确认您的 {link} 是否正确。", + "xpack.monitoring.logs.reason.noClusterTitle": "此集群没有日志", + "xpack.monitoring.logs.reason.noIndexLink": "设置", + "xpack.monitoring.logs.reason.noIndexMessage": "找到了日志,但没有此索引的日志。如果此问题持续存在,请确认您的 {link} 是否正确。", + "xpack.monitoring.logs.reason.noIndexPatternInTimePeriodMessage": "使用时间筛选调整时间范围。", + "xpack.monitoring.logs.reason.noIndexPatternInTimePeriodTitle": "没有选定时间的日志", + "xpack.monitoring.logs.reason.noIndexPatternLink": "Filebeat", + "xpack.monitoring.logs.reason.noIndexPatternMessage": "设置 {link},然后将 Elasticsearch 输出配置到您的监测集群。", + "xpack.monitoring.logs.reason.noIndexPatternTitle": "未找到任何日志数据", + "xpack.monitoring.logs.reason.noIndexTitle": "此索引没有任何日志", + "xpack.monitoring.logs.reason.noNodeLink": "设置", + "xpack.monitoring.logs.reason.noNodeMessage": "确认您的 {link} 是否正确。", + "xpack.monitoring.logs.reason.noNodeTitle": "此 Elasticsearch 节点没有任何日志", + "xpack.monitoring.logs.reason.notUsingStructuredLogsLink": "指向 JSON 日志", + "xpack.monitoring.logs.reason.notUsingStructuredLogsMessage": "检查 {varPaths} 设置是否{link}。", + "xpack.monitoring.logs.reason.notUsingStructuredLogsTitle": "未找到结构化日志", + "xpack.monitoring.logs.reason.noTypeLink": "这些方向", + "xpack.monitoring.logs.reason.noTypeMessage": "按照 {link} 设置 Elasticsearch。", + "xpack.monitoring.logs.reason.noTypeTitle": "Elasticsearch 没有任何日志", + "xpack.monitoring.logstash.clusterStatus.eventsEmittedLabel": "已发出事件", + "xpack.monitoring.logstash.clusterStatus.eventsReceivedLabel": "已接收事件", + "xpack.monitoring.logstash.clusterStatus.memoryLabel": "内存", + "xpack.monitoring.logstash.clusterStatus.nodesLabel": "节点", + "xpack.monitoring.logstash.detailStatus.batchSizeLabel": "批处理大小", + "xpack.monitoring.logstash.detailStatus.configReloadsLabel": "配置重载", + "xpack.monitoring.logstash.detailStatus.eventsEmittedLabel": "已发出事件", + "xpack.monitoring.logstash.detailStatus.eventsReceivedLabel": "已接收事件", + "xpack.monitoring.logstash.detailStatus.pipelineWorkersLabel": "管道工作线程", + "xpack.monitoring.logstash.detailStatus.queueTypeLabel": "队列类型", + "xpack.monitoring.logstash.detailStatus.transportAddressLabel": "传输地址", + "xpack.monitoring.logstash.detailStatus.uptimeLabel": "运行时间", + "xpack.monitoring.logstash.detailStatus.versionLabel": "版本", + "xpack.monitoring.logstash.filterNodesPlaceholder": "筛选节点……", + "xpack.monitoring.logstash.filterPipelinesPlaceholder": "筛选管道……", + "xpack.monitoring.logstash.node.advanced.routeTitle": "Logstash - {nodeName} - 高级", + "xpack.monitoring.logstash.node.pipelines.notAvailableDescription": "仅 Logstash 版本 6.0.0 或更高版本提供管道监测功能。此节点正在运行版本 {logstashVersion}。", + "xpack.monitoring.logstash.node.pipelines.routeTitle": "Logstash - {nodeName} - 管道", + "xpack.monitoring.logstash.node.routeTitle": "Logstash - {nodeName}", + "xpack.monitoring.logstash.nodes.configReloadsFailuresCountLabel": "{reloadsFailures} 失败", + "xpack.monitoring.logstash.nodes.configReloadsSuccessCountLabel": "{reloadsSuccesses} 成功", + "xpack.monitoring.logstash.nodes.configReloadsTitle": "配置重载", + "xpack.monitoring.logstash.nodes.cpuUsageTitle": "CPU 使用", + "xpack.monitoring.logstash.nodes.eventsIngestedTitle": "已采集事件", + "xpack.monitoring.logstash.nodes.jvmHeapUsedTitle": "已使用 {javaVirtualMachine} 堆", + "xpack.monitoring.logstash.nodes.loadAverageTitle": "负载平均值", + "xpack.monitoring.logstash.nodes.nameTitle": "名称", + "xpack.monitoring.logstash.nodes.versionTitle": "版本", + "xpack.monitoring.logstash.pipeline.detailDrawer.conditionalStatementDescription": "这是您的管道中的条件语句。", + "xpack.monitoring.logstash.pipeline.detailDrawer.eventsEmittedLabel": "已发出事件", + "xpack.monitoring.logstash.pipeline.detailDrawer.eventsEmittedRateLabel": "已发出事件速率", + "xpack.monitoring.logstash.pipeline.detailDrawer.eventsLatencyLabel": "事件延迟", + "xpack.monitoring.logstash.pipeline.detailDrawer.eventsReceivedLabel": "已接收事件", + "xpack.monitoring.logstash.pipeline.detailDrawer.noMetricsForIfDescription": "对于此 if 条件,当前没有可显示的指标。", + "xpack.monitoring.logstash.pipeline.detailDrawer.noMetricsForQueueDescription": "对于该队列,当前没有可显示的指标。", + "xpack.monitoring.logstash.pipeline.detailDrawer.specifyVertexIdDescription": "没有为此 {vertexType} 显式指定 ID。指定 ID 允许您跟踪管道更改间的差异。您可以为此插件显式指定 ID,如:", + "xpack.monitoring.logstash.pipeline.detailDrawer.structureDescription": "这是 Logstash 用来缓冲输入和管道其余部分之间的事件的内部结构。", + "xpack.monitoring.logstash.pipeline.detailDrawer.vertexIdDescription": "此 {vertexType} 的 ID 为 {vertexId}。", + "xpack.monitoring.logstash.pipeline.queue.noMetricsDescription": "队列指标不可用", + "xpack.monitoring.logstash.pipeline.relativeFirstSeenAgoLabel": "{relativeFirstSeen}前", + "xpack.monitoring.logstash.pipeline.relativeLastSeenAgoLabel": "直到 {relativeLastSeen}前", + "xpack.monitoring.logstash.pipeline.relativeLastSeenNowLabel": "现在", + "xpack.monitoring.logstash.pipeline.routeTitle": "Logstash - 管道", + "xpack.monitoring.logstash.pipelines.eventsEmittedRateTitle": "已发出事件速率", + "xpack.monitoring.logstash.pipelines.idTitle": "ID", + "xpack.monitoring.logstash.pipelines.numberOfNodesTitle": "节点数目", + "xpack.monitoring.logstash.pipelineStatement.viewDetailsAriaLabel": "查看详情", + "xpack.monitoring.logstash.pipelineViewer.filtersTitle": "筛选", + "xpack.monitoring.logstash.pipelineViewer.inputsTitle": "输入", + "xpack.monitoring.logstash.pipelineViewer.outputsTitle": "输出", + "xpack.monitoring.logstashNavigation.instance.advancedLinkText": "高级", + "xpack.monitoring.logstashNavigation.instance.overviewLinkText": "概览", + "xpack.monitoring.logstashNavigation.instance.pipelinesLinkText": "管道", + "xpack.monitoring.logstashNavigation.nodesLinkText": "节点", + "xpack.monitoring.logstashNavigation.overviewLinkText": "概览", + "xpack.monitoring.logstashNavigation.pipelinesLinkText": "管道", + "xpack.monitoring.logstashNavigation.pipelineVersionDescription": "活动版本 {relativeLastSeen} 和首次看到 {relativeFirstSeen}", + "xpack.monitoring.metricbeatMigration.apmInstructions.configureMetricbeatDescription": "在 {file} 文件中进行这些更改。", + "xpack.monitoring.metricbeatMigration.apmInstructions.configureMetricbeatTitle": "配置 Metricbeat 以发送至监测集群", + "xpack.monitoring.metricbeatMigration.apmInstructions.disableInternalCollection.description": "在 APM Server 的配置文件 ({file}) 中添加以下设置:", + "xpack.monitoring.metricbeatMigration.apmInstructions.disableInternalCollection.note": "进行此更改后,需要重新启动 APM Server。", + "xpack.monitoring.metricbeatMigration.apmInstructions.disableInternalCollection.title": "禁用 APM Server 监测指标的内部收集", + "xpack.monitoring.metricbeatMigration.apmInstructions.enableMetricbeatModuleDescription": "该模块将默认从 http://localhost:5066 收集 APM Server 监测指标。如果本地 APM Server 有不同的地址,则必须通过 {file} 文件中的 {hosts} 设置进行指定。", + "xpack.monitoring.metricbeatMigration.apmInstructions.enableMetricbeatModuleTitle": "在 Metricbeat 中启用并配置 Beat x-pack 模块", + "xpack.monitoring.metricbeatMigration.apmInstructions.installMetricbeatLinkText": "按照此处的说明执行操作。", + "xpack.monitoring.metricbeatMigration.apmInstructions.installMetricbeatTitle": "在安装 APM Server 的同一台服务器上安装 Metricbeat", + "xpack.monitoring.metricbeatMigration.apmInstructions.startMetricbeatLinkText": "按照此处的说明执行操作。", + "xpack.monitoring.metricbeatMigration.apmInstructions.startMetricbeatTitle": "启动 Metricbeat", + "xpack.monitoring.metricbeatMigration.beatsInstructions.configureMetricbeatDescription": "在 {file} 文件中进行这些更改。", + "xpack.monitoring.metricbeatMigration.beatsInstructions.configureMetricbeatTitle": "配置 Metricbeat 以发送至监测集群", + "xpack.monitoring.metricbeatMigration.beatsInstructions.disableInternalCollection.description": "在 {beatType} 的配置文件 ({file}) 中添加以下设置:", + "xpack.monitoring.metricbeatMigration.beatsInstructions.disableInternalCollection.note": "进行此更改后,您需要重新启动 {beatType}。", + "xpack.monitoring.metricbeatMigration.beatsInstructions.disableInternalCollection.title": "禁用 {beatType} 监测指标的内部收集", + "xpack.monitoring.metricbeatMigration.beatsInstructions.enableMetricbeatModuleDescription": "该模块将默认从 http://localhost:5066 收集 {beatType} 监测指标。如果正在监测的 {beatType} 实例有不同的地址,则必须通过 {file} 文件中的 {hosts} 设置进行指定。", + "xpack.monitoring.metricbeatMigration.beatsInstructions.enableMetricbeatModuleHttpEnabledDirections": "要使 Metricbeat 从正在运行的 {beatType} 收集指标,需要{link}。", + "xpack.monitoring.metricbeatMigration.beatsInstructions.enableMetricbeatModuleHttpEnabledDirectionsLinkText": "为正在监测的 {beatType} 实例启用 HTTP 终端节点", + "xpack.monitoring.metricbeatMigration.beatsInstructions.enableMetricbeatModuleTitle": "在 Metricbeat 中启用并配置 Beat x-pack 模块", + "xpack.monitoring.metricbeatMigration.beatsInstructions.installMetricbeatLinkText": "按照此处的说明执行操作。", + "xpack.monitoring.metricbeatMigration.beatsInstructions.installMetricbeatTitle": "在安装此 {beatType} 的同一台服务器上安装 Metricbeat", + "xpack.monitoring.metricbeatMigration.beatsInstructions.startMetricbeatLinkText": "按照此处的说明执行操作。", + "xpack.monitoring.metricbeatMigration.beatsInstructions.startMetricbeatTitle": "启动 Metricbeat", + "xpack.monitoring.metricbeatMigration.disableInternalCollection.fullyMigratedStatusDescription": "我们未看到来自内部收集的任何文档。迁移完成!", + "xpack.monitoring.metricbeatMigration.disableInternalCollection.fullyMigratedStatusTitle": "恭喜您!", + "xpack.monitoring.metricbeatMigration.disableInternalCollection.partiallyMigratedStatusDescription": "上次内部收集是在 {secondsSinceLastInternalCollectionLabel}前。", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.configureMetricbeatDescription": "修改 {file} 以设置连接信息。", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.configureMetricbeatTitle": "配置 Metricbeat 以发送至监测集群", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.disableInternalCollectionDescription": "禁用 Elasticsearch 监测指标的内部收集。在生产集群中的每个服务器上将 {monospace} 设置为 false。", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.disableInternalCollectionTitle": "禁用 Elasticsearch 监测指标的内部收集", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.enableMetricbeatModuleDescription": "默认情况下,模块从 {url} 收集 Elasticsearch 指标。如果本地服务器有不同的地址,请在 {module} 中将其添加到主机设置。", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.enableMetricbeatModuleInstallDirectory": "从安装目录中,运行:", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.enableMetricbeatModuleTitle": "在 Metricbeat 中启用并配置 Elasticsearch x-pack 模块", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.installMetricbeatLinkText": "按照此处的说明执行操作。", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.installMetricbeatTitle": "在安装 Elasticsearch 的同一台服务器上安装 Metricbeat", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.startMetricbeatLinkText": "按照此处的说明执行操作。", + "xpack.monitoring.metricbeatMigration.elasticsearchInstructions.startMetricbeatTitle": "启动 Metricbeat", + "xpack.monitoring.metricbeatMigration.flyout.closeButtonLabel": "关闭", + "xpack.monitoring.metricbeatMigration.flyout.doneButtonLabel": "完成", + "xpack.monitoring.metricbeatMigration.flyout.flyoutTitle": "使用 Metricbeat 监测 `{instanceName}` {instanceIdentifier}", + "xpack.monitoring.metricbeatMigration.flyout.flyoutTitleNewUser": "使用 Metricbeat 监测 {instanceName} {instanceIdentifier}", + "xpack.monitoring.metricbeatMigration.flyout.learnMore": "了解原因。", + "xpack.monitoring.metricbeatMigration.flyout.nextButtonLabel": "下一个", + "xpack.monitoring.metricbeatMigration.flyout.noClusterUuidCheckboxLabel": "是的,我明白我将需要在独立集群中寻找\n 此 {productName} {instanceIdentifier}。", + "xpack.monitoring.metricbeatMigration.flyout.noClusterUuidDescription": "此 {productName} {instanceIdentifier} 未连接到 Elasticsearch 集群,因此完全迁移后,此 {productName} {instanceIdentifier} 将显示在独立集群中,而非此集群中。{link}", + "xpack.monitoring.metricbeatMigration.flyout.noClusterUuidTitle": "未检测到集群", + "xpack.monitoring.metricbeatMigration.flyout.step1.monitoringUrlHelpText": "通常为单个 URL。如果有多个 URL,请使用逗号分隔。\n 正在运行的 Metricbeat 实例必须能够与这些 Elasticsearch 服务器通信。", + "xpack.monitoring.metricbeatMigration.flyout.step1.monitoringUrlLabel": "监测集群 URL", + "xpack.monitoring.metricbeatMigration.fullyMigratedStatusDescription": "Metricbeat 正在发送监测数据。", + "xpack.monitoring.metricbeatMigration.fullyMigratedStatusTitle": "恭喜您!", + "xpack.monitoring.metricbeatMigration.isInternalCollectorStatusTitle": "未检测到任何监测数据,但我们将继续检查。", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.configureMetricbeatDescription": "在 {file} 文件中进行这些更改。", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.configureMetricbeatTitle": "配置 Metricbeat 以发送至监测集群", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.disableInternalCollection.description": "将此设置添加到 {file}。", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.disableInternalCollection.note": "对于 {config},请保留默认值 ({defaultValue})。", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.disableInternalCollection.restartNote": "此步骤需要您重新启动 Kibana 服务器。在服务器再次运行之前应会看到错误。", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.disableInternalCollection.restartWarningTitle": "警告", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.disableInternalCollection.title": "禁用 Kibana 监测指标的内部收集", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.enableMetricbeatModuleDescription": "该模块将默认从 http://localhost:5601 收集 Kibana 监测指标。如果本地 Kibana 实例有不同的地址,则必须通过 {file} 文件中的 {hosts} 设置进行指定。", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.enableMetricbeatModuleTitle": "在 Metricbeat 中启用并配置 Kibana x-pack 模块", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.installMetricbeatLinkText": "按照此处的说明执行操作。", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.installMetricbeatTitle": "在安装 Kibana 的同一台服务器上安装 Metricbeat", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.startMetricbeatLinkText": "按照此处的说明执行操作。", + "xpack.monitoring.metricbeatMigration.kibanaInstructions.startMetricbeatTitle": "启动 Metricbeat", + "xpack.monitoring.metricbeatMigration.logstashInstructions.configureMetricbeatDescription": "在 {file} 文件中进行这些更改。", + "xpack.monitoring.metricbeatMigration.logstashInstructions.configureMetricbeatTitle": "配置 Metricbeat 以发送至监测集群", + "xpack.monitoring.metricbeatMigration.logstashInstructions.disableInternalCollection.description": "在 Logstash 配置文件 ({file}) 中添加以下设置:", + "xpack.monitoring.metricbeatMigration.logstashInstructions.disableInternalCollection.note": "进行此更改后,您需要重新启动 Logstash。", + "xpack.monitoring.metricbeatMigration.logstashInstructions.disableInternalCollection.title": "禁用 Logstash 监测指标的内部收集", + "xpack.monitoring.metricbeatMigration.logstashInstructions.enableMetricbeatModuleDescription": "该模块将默认从 http://localhost:9600 收集 Logstash 监测指标。如果本地 Logstash 实例有不同的地址,则必须通过 {file} 文件中的 {hosts} 设置进行指定。", + "xpack.monitoring.metricbeatMigration.logstashInstructions.enableMetricbeatModuleTitle": "在 Metricbeat 中启用并配置 Logstash x-pack 模块", + "xpack.monitoring.metricbeatMigration.logstashInstructions.installMetricbeatLinkText": "按照此处的说明执行操作。", + "xpack.monitoring.metricbeatMigration.logstashInstructions.installMetricbeatTitle": "在安装 Logstash 的同一台服务器上安装 Metricbeat", + "xpack.monitoring.metricbeatMigration.logstashInstructions.startMetricbeatLinkText": "按照此处的说明执行操作。", + "xpack.monitoring.metricbeatMigration.logstashInstructions.startMetricbeatTitle": "启动 Metricbeat", + "xpack.monitoring.metricbeatMigration.migrationStatus": "迁移状态", + "xpack.monitoring.metricbeatMigration.monitoringStatus": "监测状态", + "xpack.monitoring.metricbeatMigration.partiallyMigratedStatusDescription": "最多需要 {secondsAgo} 秒钟检测到数据。", + "xpack.monitoring.metricbeatMigration.partiallyMigratedStatusTitle": "数据仍来自于内部收集", + "xpack.monitoring.metricbeatMigration.securitySetup": "如果启用了安全,可能需要{link}。", + "xpack.monitoring.metricbeatMigration.securitySetupLinkText": "其他设置", + "xpack.monitoring.metrics.apm.outputAckedEventsRate.ackedDescription": "输出处理的事件(包括重试)", + "xpack.monitoring.metrics.apm.outputAckedEventsRate.ackedLabel": "已确认", + "xpack.monitoring.metrics.apm.outputAckedEventsRateTitle": "输出已确认事件速率", + "xpack.monitoring.metrics.apm.outputActiveEventsRate.activeDescription": "输出处理的事件(包括重试)", + "xpack.monitoring.metrics.apm.outputActiveEventsRate.activeLabel": "有效", + "xpack.monitoring.metrics.apm.outputActiveEventsRateTitle": "输出活动事件速率", + "xpack.monitoring.metrics.apm.outputDroppedEventsRate.droppedDescription": "输出处理的事件(包括重试)", + "xpack.monitoring.metrics.apm.outputDroppedEventsRate.droppedLabel": "已丢弃", + "xpack.monitoring.metrics.apm.outputDroppedEventsRateTitle": "输出已丢弃事件速率", + "xpack.monitoring.metrics.apm.outputEventsRate.totalDescription": "输出处理的事件(包括重试)", + "xpack.monitoring.metrics.apm.outputEventsRate.totalLabel": "合计", + "xpack.monitoring.metrics.apm.outputEventsRateTitle": "输出事件速率", + "xpack.monitoring.metrics.apm.outputFailedEventsRate.failedDescription": "输出处理的事件(包括重试)", + "xpack.monitoring.metrics.apm.outputFailedEventsRate.failedLabel": "失败", + "xpack.monitoring.metrics.apm.outputFailedEventsRateTitle": "输出失败事件速率", + "xpack.monitoring.metrics.apm.perMinuteUnitLabel": "/分钟", + "xpack.monitoring.metrics.apm.processedEvents.transactionDescription": "已处理事务事件", + "xpack.monitoring.metrics.apm.processedEvents.transactionLabel": "事务", + "xpack.monitoring.metrics.apm.processedEventsTitle": "已处理事件", + "xpack.monitoring.metrics.apm.requests.requestedDescription": "服务器接收的 HTTP 请求", + "xpack.monitoring.metrics.apm.requests.requestedLabel": "已请求", + "xpack.monitoring.metrics.apm.requestsTitle": "请求计数摄入 API", + "xpack.monitoring.metrics.apm.response.acceptedDescription": "成功报告新事件的 HTTP 请求", + "xpack.monitoring.metrics.apm.response.acceptedLabel": "已接受", + "xpack.monitoring.metrics.apm.response.acceptedTitle": "已接受", + "xpack.monitoring.metrics.apm.response.okDescription": "200 OK 响应计数", + "xpack.monitoring.metrics.apm.response.okLabel": "确定", + "xpack.monitoring.metrics.apm.response.okTitle": "确定", + "xpack.monitoring.metrics.apm.responseCount.totalDescription": "服务器响应的 HTTP 请求", + "xpack.monitoring.metrics.apm.responseCount.totalLabel": "合计", + "xpack.monitoring.metrics.apm.responseCountTitle": "响应计数摄入 API", + "xpack.monitoring.metrics.apm.responseErrors.closedDescription": "服务器关闭期间拒绝的 HTTP 请求", + "xpack.monitoring.metrics.apm.responseErrors.closedLabel": "已关闭", + "xpack.monitoring.metrics.apm.responseErrors.closedTitle": "已关闭", + "xpack.monitoring.metrics.apm.responseErrors.concurrencyDescription": "由于违反总体并发限制而拒绝的 HTTP 请求", + "xpack.monitoring.metrics.apm.responseErrors.concurrencyLabel": "并发", + "xpack.monitoring.metrics.apm.responseErrors.concurrencyTitle": "并发", + "xpack.monitoring.metrics.apm.responseErrors.decodeDescription": "由于解码错误而拒绝的 HTTP 请求 - json 无效、实体的数据类型不正确", + "xpack.monitoring.metrics.apm.responseErrors.decodeLabel": "解码", + "xpack.monitoring.metrics.apm.responseErrors.decodeTitle": "解码", + "xpack.monitoring.metrics.apm.responseErrors.forbiddenDescription": "拒绝的已禁止 HTTP 请求 - CORS 违规、已禁用终端节点", + "xpack.monitoring.metrics.apm.responseErrors.forbiddenLabel": "已禁止", + "xpack.monitoring.metrics.apm.responseErrors.forbiddenTitle": "已禁止", + "xpack.monitoring.metrics.apm.responseErrors.internalDescription": "由于其他内部错误而拒绝的 HTTP 请求", + "xpack.monitoring.metrics.apm.responseErrors.internalLabel": "内部", + "xpack.monitoring.metrics.apm.responseErrors.internalTitle": "内部", + "xpack.monitoring.metrics.apm.responseErrors.methodDescription": "由于 HTTP 方法错误而拒绝的 HTTP 请求", + "xpack.monitoring.metrics.apm.responseErrors.methodLabel": "方法", + "xpack.monitoring.metrics.apm.responseErrors.methodTitle": "方法", + "xpack.monitoring.metrics.apm.responseErrors.queueDescription": "由于内部队列已填满而拒绝的 HTTP 请求", + "xpack.monitoring.metrics.apm.responseErrors.queueLabel": "队列", + "xpack.monitoring.metrics.apm.responseErrors.queueTitle": "队列", + "xpack.monitoring.metrics.apm.responseErrors.rateLimitDescription": "由于速率限制超出而拒绝的 HTTP 请求", + "xpack.monitoring.metrics.apm.responseErrors.rateLimitLabel": "速率限制", + "xpack.monitoring.metrics.apm.responseErrors.rateLimitTitle": "速率限制", + "xpack.monitoring.metrics.apm.responseErrors.tooLargeLabelDescription": "由于负载大小过大而拒绝的 HTTP 请求", + "xpack.monitoring.metrics.apm.responseErrors.tooLargeLabelTitle": "过大", + "xpack.monitoring.metrics.apm.responseErrors.unauthorizedDescription": "由于密钥令牌无效而拒绝的 HTTP 请求", + "xpack.monitoring.metrics.apm.responseErrors.unauthorizedLabel": "未授权", + "xpack.monitoring.metrics.apm.responseErrors.unauthorizedTitle": "未授权", + "xpack.monitoring.metrics.apm.responseErrors.validateDescription": "由于负载验证错误而拒绝的 HTTP 请求", + "xpack.monitoring.metrics.apm.responseErrors.validateLabel": "验证", + "xpack.monitoring.metrics.apm.responseErrors.validateTitle": "验证", + "xpack.monitoring.metrics.apm.responseErrorsTitle": "响应错误摄入 API", + "xpack.monitoring.metrics.apm.transformations.errorDescription": "已处理错误事件", + "xpack.monitoring.metrics.apm.transformations.errorLabel": "错误", + "xpack.monitoring.metrics.apm.transformations.metricDescription": "已处理指标事件", + "xpack.monitoring.metrics.apm.transformations.metricLabel": "指标", + "xpack.monitoring.metrics.apm.transformations.spanDescription": "已处理范围错误", + "xpack.monitoring.metrics.apm.transformations.spanLabel": "范围", + "xpack.monitoring.metrics.apm.transformationsTitle": "转换", + "xpack.monitoring.metrics.apmInstance.cpuUtilization.totalDescription": "为 APM 进程执行(用户+内核模式)所花费的 CPU 时间百分比", + "xpack.monitoring.metrics.apmInstance.cpuUtilization.totalLabel": "合计", + "xpack.monitoring.metrics.apmInstance.cpuUtilizationTitle": "CPU 使用率", + "xpack.monitoring.metrics.apmInstance.memory.allocatedMemoryDescription": "已分配内存", + "xpack.monitoring.metrics.apmInstance.memory.allocatedMemoryLabel": "已分配内存", + "xpack.monitoring.metrics.apmInstance.memory.gcNextDescription": "执行垃圾回收的已分配内存限制", + "xpack.monitoring.metrics.apmInstance.memory.gcNextLabel": "下一 GC", + "xpack.monitoring.metrics.apmInstance.memory.processTotalDescription": "APM 服务从 OS 保留的内存常驻集大小", + "xpack.monitoring.metrics.apmInstance.memory.processTotalLabel": "进程合计", + "xpack.monitoring.metrics.apmInstance.memoryTitle": "内存", + "xpack.monitoring.metrics.apmInstance.systemLoad.last15MinutesDescription": "过去 15 分钟的负载平均值", + "xpack.monitoring.metrics.apmInstance.systemLoad.last15MinutesLabel": "15 分钟", + "xpack.monitoring.metrics.apmInstance.systemLoad.last1MinuteDescription": "过去 1 分钟的负载平均值", + "xpack.monitoring.metrics.apmInstance.systemLoad.last1MinuteLabel": "1 分钟", + "xpack.monitoring.metrics.apmInstance.systemLoad.last5MinutesDescription": "过去 5 分钟的负载平均值", + "xpack.monitoring.metrics.apmInstance.systemLoad.last5MinutesLabel": "5 分钟", + "xpack.monitoring.metrics.apmInstance.systemLoadTitle": "系统负载", + "xpack.monitoring.metrics.beats.eventsRate.acknowledgedDescription": "输出确认的事件(包括输出丢弃的事件)", + "xpack.monitoring.metrics.beats.eventsRate.acknowledgedLabel": "已确认", + "xpack.monitoring.metrics.beats.eventsRate.emittedDescription": "输出处理的事件(包括重试)", + "xpack.monitoring.metrics.beats.eventsRate.emittedLabel": "已发出", + "xpack.monitoring.metrics.beats.eventsRate.queuedDescription": "添加到事件管道队列的事件", + "xpack.monitoring.metrics.beats.eventsRate.queuedLabel": "已排队", + "xpack.monitoring.metrics.beats.eventsRate.totalDescription": "发布管道中新创建的所有事件", + "xpack.monitoring.metrics.beats.eventsRate.totalLabel": "合计", + "xpack.monitoring.metrics.beats.eventsRateTitle": "事件速率", + "xpack.monitoring.metrics.beats.failRates.droppedInOutputDescription": "(致命丢弃)因“无效”而被输出丢弃的事件。 输出仍确认事件,以便 Beat 将其从队列中删除。", + "xpack.monitoring.metrics.beats.failRates.droppedInOutputLabel": "在输出中已丢弃", + "xpack.monitoring.metrics.beats.failRates.droppedInPipelineDescription": "N 次重试后丢弃的事件(N = max_retries 设置)", + "xpack.monitoring.metrics.beats.failRates.droppedInPipelineLabel": "在管道中已丢弃", + "xpack.monitoring.metrics.beats.failRates.failedInPipelineDescription": "将事件添加到发布管道前发生的失败(输出已禁用或发布器客户端已关闭)", + "xpack.monitoring.metrics.beats.failRates.failedInPipelineLabel": "在管道中失败", + "xpack.monitoring.metrics.beats.failRates.retryInPipelineDescription": "在管道中重新尝试发送到输出的事件", + "xpack.monitoring.metrics.beats.failRates.retryInPipelineLabel": "在管道中重试", + "xpack.monitoring.metrics.beats.failRatesTitle": "失败速率", + "xpack.monitoring.metrics.beats.outputErrors.receivingDescription": "从输出读取响应时的错误", + "xpack.monitoring.metrics.beats.outputErrors.receivingLabel": "接收", + "xpack.monitoring.metrics.beats.outputErrors.sendingDescription": "从输出写入响应时的错误", + "xpack.monitoring.metrics.beats.outputErrors.sendingLabel": "发送", + "xpack.monitoring.metrics.beats.outputErrorsTitle": "输出错误", + "xpack.monitoring.metrics.beats.perSecondUnitLabel": "/秒", + "xpack.monitoring.metrics.beats.throughput.bytesReceivedDescription": "作为响应从输出读取的字节", + "xpack.monitoring.metrics.beats.throughput.bytesReceivedLabel": "已接收字节", + "xpack.monitoring.metrics.beats.throughput.bytesSentDescription": "写入到输出的字节(包括网络标头和已压缩负载的大小)", + "xpack.monitoring.metrics.beats.throughput.bytesSentLabel": "已发送字节", + "xpack.monitoring.metrics.beats.throughputTitle": "吞吐量", + "xpack.monitoring.metrics.beatsInstance.cpuUtilization.totalDescription": "为 Beat 进程执行(用户+内核模式)所花费的 CPU 时间百分比", + "xpack.monitoring.metrics.beatsInstance.cpuUtilization.totalLabel": "合计", + "xpack.monitoring.metrics.beatsInstance.cpuUtilizationTitle": "CPU 使用率", + "xpack.monitoring.metrics.beatsInstance.eventsRate.acknowledgedDescription": "输出确认的事件(包括输出丢弃的事件)", + "xpack.monitoring.metrics.beatsInstance.eventsRate.acknowledgedLabel": "已确认", + "xpack.monitoring.metrics.beatsInstance.eventsRate.emittedDescription": "输出处理的事件(包括重试)", + "xpack.monitoring.metrics.beatsInstance.eventsRate.emittedLabel": "已发出", + "xpack.monitoring.metrics.beatsInstance.eventsRate.newDescription": "发送到发布管道的新事件", + "xpack.monitoring.metrics.beatsInstance.eventsRate.newLabel": "新建", + "xpack.monitoring.metrics.beatsInstance.eventsRate.queuedDescription": "添加到事件管道队列的事件", + "xpack.monitoring.metrics.beatsInstance.eventsRate.queuedLabel": "已排队", + "xpack.monitoring.metrics.beatsInstance.eventsRateTitle": "事件速率", + "xpack.monitoring.metrics.beatsInstance.failRates.droppedInOutputDescription": "(致命丢弃)因“无效”而被输出丢弃的事件。 输出仍确认事件,以便 Beat 将其从队列中删除。", + "xpack.monitoring.metrics.beatsInstance.failRates.droppedInOutputLabel": "在输出中已丢弃", + "xpack.monitoring.metrics.beatsInstance.failRates.droppedInPipelineDescription": "N 次重试后丢弃的事件(N = max_retries 设置)", + "xpack.monitoring.metrics.beatsInstance.failRates.droppedInPipelineLabel": "在管道中已丢弃", + "xpack.monitoring.metrics.beatsInstance.failRates.failedInPipelineDescription": "将事件添加到发布管道前发生的失败(输出已禁用或发布器客户端已关闭)", + "xpack.monitoring.metrics.beatsInstance.failRates.failedInPipelineLabel": "在管道中失败", + "xpack.monitoring.metrics.beatsInstance.failRates.retryInPipelineDescription": "在管道中重新尝试发送到输出的事件", + "xpack.monitoring.metrics.beatsInstance.failRates.retryInPipelineLabel": "在管道中重试", + "xpack.monitoring.metrics.beatsInstance.failRatesTitle": "失败速率", + "xpack.monitoring.metrics.beatsInstance.memory.activeDescription": "正被 Beat 频繁使用的专用内存", + "xpack.monitoring.metrics.beatsInstance.memory.activeLabel": "有效", + "xpack.monitoring.metrics.beatsInstance.memory.gcNextDescription": "执行垃圾回收的已分配内存限制", + "xpack.monitoring.metrics.beatsInstance.memory.gcNextLabel": "下一 GC", + "xpack.monitoring.metrics.beatsInstance.memory.processTotalDescription": "Beat 从 OS 保留的内存常驻集大小", + "xpack.monitoring.metrics.beatsInstance.memory.processTotalLabel": "进程合计", + "xpack.monitoring.metrics.beatsInstance.memoryTitle": "内存", + "xpack.monitoring.metrics.beatsInstance.openHandlesDescription": "打开的文件句柄计数", + "xpack.monitoring.metrics.beatsInstance.openHandlesLabel": "打开的句柄", + "xpack.monitoring.metrics.beatsInstance.openHandlesTitle": "打开的句柄", + "xpack.monitoring.metrics.beatsInstance.outputErrors.receivingDescription": "从输出读取响应时的错误", + "xpack.monitoring.metrics.beatsInstance.outputErrors.receivingLabel": "接收", + "xpack.monitoring.metrics.beatsInstance.outputErrors.sendingDescription": "从输出写入响应时的错误", + "xpack.monitoring.metrics.beatsInstance.outputErrors.sendingLabel": "发送", + "xpack.monitoring.metrics.beatsInstance.outputErrorsTitle": "输出错误", + "xpack.monitoring.metrics.beatsInstance.systemLoad.last15MinutesDescription": "过去 15 分钟的负载平均值", + "xpack.monitoring.metrics.beatsInstance.systemLoad.last15MinutesLabel": "15 分钟", + "xpack.monitoring.metrics.beatsInstance.systemLoad.last1MinuteDescription": "过去 1 分钟的负载平均值", + "xpack.monitoring.metrics.beatsInstance.systemLoad.last1MinuteLabel": "1 分钟", + "xpack.monitoring.metrics.beatsInstance.systemLoad.last5MinutesDescription": "过去 5 分钟的负载平均值", + "xpack.monitoring.metrics.beatsInstance.systemLoad.last5MinutesLabel": "5 分钟", + "xpack.monitoring.metrics.beatsInstance.systemLoadTitle": "系统负载", + "xpack.monitoring.metrics.beatsInstance.throughput.bytesReceivedDescription": "作为响应从输出读取的字节", + "xpack.monitoring.metrics.beatsInstance.throughput.bytesReceivedLabel": "已接收字节", + "xpack.monitoring.metrics.beatsInstance.throughput.bytesSentDescription": "写入到输出的字节(包括网络标头和已压缩负载的大小)", + "xpack.monitoring.metrics.beatsInstance.throughput.bytesSentLabel": "已发送字节", + "xpack.monitoring.metrics.beatsInstance.throughputTitle": "吞吐量", + "xpack.monitoring.metrics.es.indexingLatencyDescription": "索引文档的平均延迟,即索引文档所用时间除以索引文档的数目。这仅考虑主分片。", + "xpack.monitoring.metrics.es.indexingLatencyLabel": "索引延迟", + "xpack.monitoring.metrics.es.indexingRate.primaryShardsDescription": "为主分片索引的文档数目。", + "xpack.monitoring.metrics.es.indexingRate.primaryShardsLabel": "主分片", + "xpack.monitoring.metrics.es.indexingRate.totalShardsDescription": "为主分片和副本分片索引的文档数目。", + "xpack.monitoring.metrics.es.indexingRate.totalShardsLabel": "分片合计", + "xpack.monitoring.metrics.es.indexingRateTitle": "索引速率", + "xpack.monitoring.metrics.es.latencyMetricParamErrorMessage": "延迟指标参数必须是等于“index”或“query”的字符串", + "xpack.monitoring.metrics.es.msTimeUnitLabel": "ms", + "xpack.monitoring.metrics.es.nsTimeUnitLabel": "纳秒", + "xpack.monitoring.metrics.es.perSecondsUnitLabel": "/秒", + "xpack.monitoring.metrics.es.perSecondTimeUnitLabel": "/秒", + "xpack.monitoring.metrics.es.searchLatencyDescription": "搜索的平均延迟,即执行搜索所用的时间除以提交的搜索数目。这考虑主分片和副本分片。", + "xpack.monitoring.metrics.es.searchLatencyLabel": "搜索延迟", + "xpack.monitoring.metrics.es.searchRate.totalShardsDescription": "跨主分片和副本分片执行的搜索请求数目。可以对多个分片运行单个搜索!", + "xpack.monitoring.metrics.es.searchRate.totalShardsLabel": "分片合计", + "xpack.monitoring.metrics.es.searchRateTitle": "搜索速率", + "xpack.monitoring.metrics.es.secondsUnitLabel": "s", + "xpack.monitoring.metrics.esCcr.fetchDelayDescription": "Follower 索引落后 Leader 的时间量。", + "xpack.monitoring.metrics.esCcr.fetchDelayLabel": "提取延迟", + "xpack.monitoring.metrics.esCcr.fetchDelayTitle": "提取延迟", + "xpack.monitoring.metrics.esCcr.opsDelayDescription": "Follower 索引落后 Leader 的操作数目。", + "xpack.monitoring.metrics.esCcr.opsDelayLabel": "操作延迟", + "xpack.monitoring.metrics.esCcr.opsDelayTitle": "操作延迟", + "xpack.monitoring.metrics.esIndex.disk.mergesDescription": "主分片和副本分片上的合并大小。", + "xpack.monitoring.metrics.esIndex.disk.mergesLabel": "合并", + "xpack.monitoring.metrics.esIndex.disk.mergesPrimariesDescription": "主分片上的合并大小。", + "xpack.monitoring.metrics.esIndex.disk.mergesPrimariesLabel": "合并(主分片)", + "xpack.monitoring.metrics.esIndex.disk.storeDescription": "磁盘上主分片和副本分片的大小。", + "xpack.monitoring.metrics.esIndex.disk.storeLabel": "存储", + "xpack.monitoring.metrics.esIndex.disk.storePrimariesDescription": "磁盘上主分片的大小。", + "xpack.monitoring.metrics.esIndex.disk.storePrimariesLabel": "存储(主分片)", + "xpack.monitoring.metrics.esIndex.diskTitle": "磁盘", + "xpack.monitoring.metrics.esIndex.docValuesDescription": "文档值使用的堆大小。这是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esIndex.docValuesLabel": "文档值", + "xpack.monitoring.metrics.esIndex.fielddataDescription": "Fielddata(例如全局序号或文本字段上显式启用的 Fielddata)使用的堆内存。这用于相同的分片,但不是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esIndex.fielddataLabel": "Fielddata", + "xpack.monitoring.metrics.esIndex.fixedBitsetsDescription": "固定位组(例如深嵌套文档)使用的堆内存。这是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esIndex.fixedBitsetsLabel": "固定位组", + "xpack.monitoring.metrics.esIndex.indexingRate.primaryShardsDescription": "为主分片索引的文档数目。", + "xpack.monitoring.metrics.esIndex.indexingRate.primaryShardsLabel": "主分片", + "xpack.monitoring.metrics.esIndex.indexingRate.totalShardsDescription": "为主分片和副本分片索引的文档数目。", + "xpack.monitoring.metrics.esIndex.indexingRate.totalShardsLabel": "分片合计", + "xpack.monitoring.metrics.esIndex.indexingRateTitle": "索引速率", + "xpack.monitoring.metrics.esIndex.indexMemoryEs.queryCacheDescription": "查询缓存(例如缓存的筛选)使用的堆内存。这用于相同的分片,但不是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esIndex.indexMemoryEs.queryCacheLabel": "查询缓存", + "xpack.monitoring.metrics.esIndex.indexMemoryEsTitle": "索引内存 - {elasticsearch}", + "xpack.monitoring.metrics.esIndex.indexMemoryLucene1.luceneTotalDescription": "Lucene 用于当前索引的堆内存合计。这是主分片和副本分片的其他字段合计。", + "xpack.monitoring.metrics.esIndex.indexMemoryLucene1.luceneTotalLabel": "Lucene 合计", + "xpack.monitoring.metrics.esIndex.indexMemoryLucene1Title": "索引内存 - Lucene 1", + "xpack.monitoring.metrics.esIndex.indexMemoryLucene2.luceneTotalDescription": "Lucene 用于当前索引的堆内存合计。这是主分片和副本分片的其他字段合计。", + "xpack.monitoring.metrics.esIndex.indexMemoryLucene2.luceneTotalLabel": "Lucene 合计", + "xpack.monitoring.metrics.esIndex.indexMemoryLucene2Title": "索引内存 - Lucene 2", + "xpack.monitoring.metrics.esIndex.indexMemoryLucene3.luceneTotalDescription": "Lucene 用于当前索引的堆内存合计。这是主分片和副本分片的其他字段合计。", + "xpack.monitoring.metrics.esIndex.indexMemoryLucene3.luceneTotalLabel": "Lucene 合计", + "xpack.monitoring.metrics.esIndex.indexMemoryLucene3Title": "索引内存 - Lucene 3", + "xpack.monitoring.metrics.esIndex.indexWriterDescription": "索引编写器使用的堆内存。这不是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esIndex.indexWriterLabel": "索引编写器", + "xpack.monitoring.metrics.esIndex.latency.indexingLatencyDescription": "索引文档的平均延迟,即索引文档所用时间除以索引文档的数目。这仅考虑主分片。", + "xpack.monitoring.metrics.esIndex.latency.indexingLatencyLabel": "索引延迟", + "xpack.monitoring.metrics.esIndex.latency.searchLatencyDescription": "搜索的平均延迟,即执行搜索所用的时间除以提交的搜索数目。这考虑主分片和副本分片。", + "xpack.monitoring.metrics.esIndex.latency.searchLatencyLabel": "搜索延迟", + "xpack.monitoring.metrics.esIndex.latencyTitle": "延迟", + "xpack.monitoring.metrics.esIndex.luceneTotalDescription": "Lucene 用于当前索引的堆内存合计。这是主分片和副本分片的其他字段合计。", + "xpack.monitoring.metrics.esIndex.luceneTotalLabel": "Lucene 合计", + "xpack.monitoring.metrics.esIndex.normsDescription": "Norms(查询时间、文本评分的标准化因子)使用的堆内存。这是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esIndex.normsLabel": "Norms", + "xpack.monitoring.metrics.esIndex.pointsDescription": "Points(数字、IP 和地理数据)使用的堆内存。这是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esIndex.pointsLabel": "Points", + "xpack.monitoring.metrics.esIndex.refreshTime.primariesDescription": "对主分片执行刷新操作所花费的时间量。", + "xpack.monitoring.metrics.esIndex.refreshTime.primariesLabel": "主分片", + "xpack.monitoring.metrics.esIndex.refreshTime.totalDescription": "对主分片和副本分片执行刷新操作所花费的时间量。", + "xpack.monitoring.metrics.esIndex.refreshTime.totalLabel": "合计", + "xpack.monitoring.metrics.esIndex.refreshTimeTitle": "刷新时间", + "xpack.monitoring.metrics.esIndex.requestCacheDescription": "请求缓存(例如即时聚合)使用的堆内存。这用于相同的分片,但不是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esIndex.requestCacheLabel": "请求缓存", + "xpack.monitoring.metrics.esIndex.requestRate.indexTotalDescription": "索引操作数量。", + "xpack.monitoring.metrics.esIndex.requestRate.indexTotalLabel": "索引合计", + "xpack.monitoring.metrics.esIndex.requestRate.searchTotalDescription": "搜索操作数量(每分片)。", + "xpack.monitoring.metrics.esIndex.requestRate.searchTotalLabel": "搜索合计", + "xpack.monitoring.metrics.esIndex.requestRateTitle": "请求速率", + "xpack.monitoring.metrics.esIndex.requestTime.indexingDescription": "对主分片和副本分片执行索引操作所花费的时间量。", + "xpack.monitoring.metrics.esIndex.requestTime.indexingLabel": "索引", + "xpack.monitoring.metrics.esIndex.requestTime.indexingPrimariesDescription": "仅对主分片执行索引操作所花费的时间量。", + "xpack.monitoring.metrics.esIndex.requestTime.indexingPrimariesLabel": "索引(主分片)", + "xpack.monitoring.metrics.esIndex.requestTime.searchDescription": "执行搜索操作所花费的时间量(每分片)。", + "xpack.monitoring.metrics.esIndex.requestTime.searchLabel": "搜索", + "xpack.monitoring.metrics.esIndex.requestTimeTitle": "请求时间", + "xpack.monitoring.metrics.esIndex.searchRate.totalShardsDescription": "跨主分片和副本分片执行的搜索请求数目。可以对多个分片运行单个搜索!", + "xpack.monitoring.metrics.esIndex.searchRate.totalShardsLabel": "分片合计", + "xpack.monitoring.metrics.esIndex.searchRateTitle": "搜索速率", + "xpack.monitoring.metrics.esIndex.segmentCount.primariesDescription": "主分片的段数。", + "xpack.monitoring.metrics.esIndex.segmentCount.primariesLabel": "主分片", + "xpack.monitoring.metrics.esIndex.segmentCount.totalDescription": "主分片和副本分片的段数。", + "xpack.monitoring.metrics.esIndex.segmentCount.totalLabel": "合计", + "xpack.monitoring.metrics.esIndex.segmentCountTitle": "段计数", + "xpack.monitoring.metrics.esIndex.storedFieldsDescription": "存储字段(例如 _source)使用的堆内存。这是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esIndex.storedFieldsLabel": "存储字段", + "xpack.monitoring.metrics.esIndex.termsDescription": "词使用的堆内存(例如文本)。这是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esIndex.termsLabel": "词", + "xpack.monitoring.metrics.esIndex.termVectorsDescription": "字词向量使用的堆内存。这是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esIndex.termVectorsLabel": "字词向量", + "xpack.monitoring.metrics.esIndex.throttleTime.indexingDescription": "对主分片和副本分片限制索引操作所花费的时间量。", + "xpack.monitoring.metrics.esIndex.throttleTime.indexingLabel": "索引", + "xpack.monitoring.metrics.esIndex.throttleTime.indexingPrimariesDescription": "对主分片限制索引操作所花费的时间量。", + "xpack.monitoring.metrics.esIndex.throttleTime.indexingPrimariesLabel": "索引(主分片)", + "xpack.monitoring.metrics.esIndex.throttleTimeTitle": "限制时间", + "xpack.monitoring.metrics.esIndex.versionMapDescription": "版本控制(例如更新和删除)使用的堆内存。这不是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esIndex.versionMapLabel": "版本映射", + "xpack.monitoring.metrics.esNode.cgroupCfsStats.cgroupElapsedPeriodsDescription": "完全公平调度器 (CFS) 的采样期间数目。与限制的次数比较。", + "xpack.monitoring.metrics.esNode.cgroupCfsStats.cgroupElapsedPeriodsLabel": "Cgroup 已用期间", + "xpack.monitoring.metrics.esNode.cgroupCfsStats.cgroupThrottledCountDescription": "Cgroup 限制 CPU 的次数。", + "xpack.monitoring.metrics.esNode.cgroupCfsStats.cgroupThrottledCountLabel": "Cgroup 限制计数", + "xpack.monitoring.metrics.esNode.cgroupCfsStatsTitle": "Cgroup CFS 统计", + "xpack.monitoring.metrics.esNode.cgroupCpuPerformance.cgroupThrottlingDescription": "Cgroup 的限制时间量,以纳秒为单位。", + "xpack.monitoring.metrics.esNode.cgroupCpuPerformance.cgroupThrottlingLabel": "Cgroup 限制", + "xpack.monitoring.metrics.esNode.cgroupCpuPerformance.cgroupUsageDescription": "Cgroup 的使用,以纳秒为单位。将其与限制比较以发现问题。", + "xpack.monitoring.metrics.esNode.cgroupCpuPerformance.cgroupUsageLabel": "Cgroup 使用", + "xpack.monitoring.metrics.esNode.cgroupCpuPerformanceTitle": "Cgroup CPU 性能", + "xpack.monitoring.metrics.esNode.cpuUtilization.cgroupCpuUtilizationDescription": "与 CPU 配额相比较的 CPU 使用时间(显示为百分比)。如果未设置 CPU 配额,将不会显示任何数据。", + "xpack.monitoring.metrics.esNode.cpuUtilization.cgroupCpuUtilizationLabel": "Cgroup CPU 使用率", + "xpack.monitoring.metrics.esNode.cpuUtilizationDescription": "Elasticsearch 进程的 CPU 使用百分比。", + "xpack.monitoring.metrics.esNode.cpuUtilizationLabel": "CPU 使用率", + "xpack.monitoring.metrics.esNode.cpuUtilizationTitle": "CPU 使用率", + "xpack.monitoring.metrics.esNode.diskFreeSpaceDescription": "节点上的可用磁盘空间。", + "xpack.monitoring.metrics.esNode.diskFreeSpaceLabel": "磁盘可用空间", + "xpack.monitoring.metrics.esNode.documentCountDescription": "总文档数目,仅包括主分片。", + "xpack.monitoring.metrics.esNode.documentCountLabel": "文档计数", + "xpack.monitoring.metrics.esNode.docValuesDescription": "文档值使用的堆大小。这是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esNode.docValuesLabel": "文档值", + "xpack.monitoring.metrics.esNode.fielddataDescription": "Fielddata(例如全局序号或文本字段上显式启用的 Fielddata)使用的堆内存。这用于相同的分片,但不是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esNode.fielddataLabel": "Fielddata", + "xpack.monitoring.metrics.esNode.fixedBitsetsDescription": "固定位组(例如深嵌套文档)使用的堆内存。这是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esNode.fixedBitsetsLabel": "固定位组", + "xpack.monitoring.metrics.esNode.gcCount.oldDescription": "旧代垃圾回收的数目。", + "xpack.monitoring.metrics.esNode.gcCount.oldLabel": "旧代", + "xpack.monitoring.metrics.esNode.gcCount.youngDescription": "新代垃圾回收的数目。", + "xpack.monitoring.metrics.esNode.gcCount.youngLabel": "新代", + "xpack.monitoring.metrics.esNode.gcDuration.oldDescription": "执行旧代垃圾回收所花费的时间。", + "xpack.monitoring.metrics.esNode.gcDuration.oldLabel": "旧代", + "xpack.monitoring.metrics.esNode.gcDuration.youngDescription": "执行新代垃圾回收所花费的时间。", + "xpack.monitoring.metrics.esNode.gcDuration.youngLabel": "新代", + "xpack.monitoring.metrics.esNode.gsCountTitle": "GC 计数", + "xpack.monitoring.metrics.esNode.gsDurationTitle": "GC 持续时间", + "xpack.monitoring.metrics.esNode.indexingThreads.searchRejectionsDescription": "被拒绝(发生在队列已满时)的搜索操作数目。", + "xpack.monitoring.metrics.esNode.indexingThreads.searchRejectionsLabel": "搜索拒绝", + "xpack.monitoring.metrics.esNode.indexingThreads.writeQueueDescription": "队列中索引、批处理和写入操作的数目。批处理线程池已重命名以在 6.3 中写入,索引线程池已弃用。", + "xpack.monitoring.metrics.esNode.indexingThreads.writeQueueLabel": "写入队列", + "xpack.monitoring.metrics.esNode.indexingThreads.writeRejectionsDescription": "被拒绝(发生在队列已满时)的索引、批处理和写入操作数目。批处理线程池已重命名以在 6.3 中写入,索引线程池已弃用。", + "xpack.monitoring.metrics.esNode.indexingThreads.writeRejectionsLabel": "写入拒绝", + "xpack.monitoring.metrics.esNode.indexingThreadsTitle": "索引线程", + "xpack.monitoring.metrics.esNode.indexingTime.indexThrottlingTimeDescription": "因索引限制所花费的时间量,其表示节点上的磁盘运行缓慢。", + "xpack.monitoring.metrics.esNode.indexingTime.indexThrottlingTimeLabel": "索引限制时间", + "xpack.monitoring.metrics.esNode.indexingTime.indexTimeDescription": "索引操作所花费的时间量。", + "xpack.monitoring.metrics.esNode.indexingTime.indexTimeLabel": "索引时间", + "xpack.monitoring.metrics.esNode.indexingTimeTitle": "索引时间", + "xpack.monitoring.metrics.esNode.indexMemoryEs.queryCacheDescription": "查询缓存(例如缓存的筛选)使用的堆内存。这用于相同的分片,但不是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esNode.indexMemoryEs.queryCacheLabel": "查询缓存", + "xpack.monitoring.metrics.esNode.indexMemoryEsTitle": "索引内存 - {elasticsearch}", + "xpack.monitoring.metrics.esNode.indexMemoryLucene1.lucenceTotalDescription": "Lucene 用于当前索引的堆内存合计。这是此节点上主分片和副本分片的其他字段合计。", + "xpack.monitoring.metrics.esNode.indexMemoryLucene1.lucenceTotalLabel": "Lucene 合计", + "xpack.monitoring.metrics.esNode.indexMemoryLucene1Title": "索引内存 - Lucene 1", + "xpack.monitoring.metrics.esNode.indexMemoryLucene2.lucenceTotalDescription": "Lucene 用于当前索引的堆内存合计。这是此节点上主分片和副本分片的其他字段合计。", + "xpack.monitoring.metrics.esNode.indexMemoryLucene2.lucenceTotalLabel": "Lucene 合计", + "xpack.monitoring.metrics.esNode.indexMemoryLucene2Title": "索引内存 - Lucene 2", + "xpack.monitoring.metrics.esNode.indexMemoryLucene3.lucenceTotalDescription": "Lucene 用于当前索引的堆内存合计。这是此节点上主分片和副本分片的其他字段合计。", + "xpack.monitoring.metrics.esNode.indexMemoryLucene3.lucenceTotalLabel": "Lucene 合计", + "xpack.monitoring.metrics.esNode.indexMemoryLucene3Title": "索引内存 - Lucene 3", + "xpack.monitoring.metrics.esNode.indexThrottlingTimeDescription": "因索引限制所花费的时间量,其表示合并缓慢。", + "xpack.monitoring.metrics.esNode.indexThrottlingTimeLabel": "索引限制时间", + "xpack.monitoring.metrics.esNode.indexWriterDescription": "索引编写器使用的堆内存。这不是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esNode.indexWriterLabel": "索引编写器", + "xpack.monitoring.metrics.esNode.ioRateTitle": "I/O 操作速率", + "xpack.monitoring.metrics.esNode.jvmHeap.maxHeapDescription": "可用于 JVM 中运行的 Elasticsearch 的堆合计。", + "xpack.monitoring.metrics.esNode.jvmHeap.maxHeapLabel": "最大堆", + "xpack.monitoring.metrics.esNode.jvmHeap.usedHeapDescription": "在 JVM 中运行的 Elasticsearch 使用的堆合计。", + "xpack.monitoring.metrics.esNode.jvmHeap.usedHeapLabel": "已用堆", + "xpack.monitoring.metrics.esNode.jvmHeapTitle": "{javaVirtualMachine} 堆", + "xpack.monitoring.metrics.esNode.latency.indexingDescription": "索引文档的平均延迟,即索引文档所用时间除以索引文档的数目。这考虑位于此节点上的任何分片,包括副本分片。", + "xpack.monitoring.metrics.esNode.latency.indexingLabel": "索引", + "xpack.monitoring.metrics.esNode.latency.searchDescription": "搜索的平均延迟,即执行搜索所用的时间除以提交的搜索数目。这考虑主分片和副本分片。", + "xpack.monitoring.metrics.esNode.latency.searchLabel": "搜索", + "xpack.monitoring.metrics.esNode.latencyTitle": "延迟", + "xpack.monitoring.metrics.esNode.luceneTotalDescription": "Lucene 用于当前索引的堆内存合计。这是此节点上主分片和副本分片的其他字段合计。", + "xpack.monitoring.metrics.esNode.luceneTotalLabel": "Lucene 合计", + "xpack.monitoring.metrics.esNode.mergeRateDescription": "已合并段的字节数。较大数值表示磁盘活动较密集。", + "xpack.monitoring.metrics.esNode.mergeRateLabel": "合并速率", + "xpack.monitoring.metrics.esNode.normsDescription": "Norms(查询时间、文本评分的标准化因子)使用的堆内存。这是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esNode.normsLabel": "Norms", + "xpack.monitoring.metrics.esNode.pointsDescription": "Points(数字、IP 和地理数据)使用的堆内存。这是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esNode.pointsLabel": "Points", + "xpack.monitoring.metrics.esNode.readThreads.getQueueDescription": "队列中的 GET 操作数目。", + "xpack.monitoring.metrics.esNode.readThreads.getQueueLabel": "GET 队列", + "xpack.monitoring.metrics.esNode.readThreads.getRejectionsDescription": "被拒绝(发生在队列已满时)的 GET 操作数目。", + "xpack.monitoring.metrics.esNode.readThreads.getRejectionsLabel": "GET 拒绝", + "xpack.monitoring.metrics.esNode.readThreads.searchQueueDescription": "队列中搜索操作的数目(例如分片级别搜索)。", + "xpack.monitoring.metrics.esNode.readThreads.searchQueueLabel": "搜索队列", + "xpack.monitoring.metrics.esNode.readThreadsTitle": "读取线程", + "xpack.monitoring.metrics.esNode.requestCacheDescription": "请求缓存(例如即时聚合)使用的堆内存。这用于相同的分片,但不是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esNode.requestCacheLabel": "请求缓存", + "xpack.monitoring.metrics.esNode.requestRate.indexingTotalDescription": "索引操作数量。", + "xpack.monitoring.metrics.esNode.requestRate.indexingTotalLabel": "索引合计", + "xpack.monitoring.metrics.esNode.requestRate.searchTotalDescription": "搜索操作数量(每分片)。", + "xpack.monitoring.metrics.esNode.requestRate.searchTotalLabel": "搜索合计", + "xpack.monitoring.metrics.esNode.requestRateTitle": "请求速率", + "xpack.monitoring.metrics.esNode.searchRate.totalShardsDescription": "跨主分片和副本分片执行的搜索请求数目。可以对多个分片运行单个搜索!", + "xpack.monitoring.metrics.esNode.searchRate.totalShardsLabel": "分片合计", + "xpack.monitoring.metrics.esNode.searchRateTitle": "搜索速率", + "xpack.monitoring.metrics.esNode.segmentCountDescription": "此节点上主分片和副本分片的最大段计数。", + "xpack.monitoring.metrics.esNode.segmentCountLabel": "段计数", + "xpack.monitoring.metrics.esNode.storedFieldsDescription": "存储字段(例如 _source)使用的堆内存。这是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esNode.storedFieldsLabel": "存储字段", + "xpack.monitoring.metrics.esNode.systemLoad.last1MinuteDescription": "过去 1 分钟的负载平均值。", + "xpack.monitoring.metrics.esNode.systemLoad.last1MinuteLabel": "1 分钟", + "xpack.monitoring.metrics.esNode.systemLoadTitle": "系统负载", + "xpack.monitoring.metrics.esNode.termsDescription": "词使用的堆内存(例如文本)。这是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esNode.termsLabel": "词", + "xpack.monitoring.metrics.esNode.termVectorsDescription": "字词向量使用的堆内存。这是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esNode.termVectorsLabel": "字词向量", + "xpack.monitoring.metrics.esNode.threadQueue.getDescription": "此节点上等候处理的 Get 操作数目。", + "xpack.monitoring.metrics.esNode.threadQueue.getLabel": "获取", + "xpack.monitoring.metrics.esNode.threadQueueTitle": "线程队列", + "xpack.monitoring.metrics.esNode.threadsQueued.bulkDescription": "此节点上等候处理的批处理索引操作数目。单个批处理请求可以创建多个批处理操作。", + "xpack.monitoring.metrics.esNode.threadsQueued.bulkLabel": "批处理", + "xpack.monitoring.metrics.esNode.threadsQueued.genericDescription": "此节点上等候处理的常规(内部)操作数目。", + "xpack.monitoring.metrics.esNode.threadsQueued.genericLabel": "常规", + "xpack.monitoring.metrics.esNode.threadsQueued.indexDescription": "此节点上等候处理的非批处理索引操作数目。", + "xpack.monitoring.metrics.esNode.threadsQueued.indexLabel": "索引", + "xpack.monitoring.metrics.esNode.threadsQueued.managementDescription": "此节点上等候处理的管理(内部)操作数目。", + "xpack.monitoring.metrics.esNode.threadsQueued.managementLabel": "管理", + "xpack.monitoring.metrics.esNode.threadsQueued.searchDescription": "此节点上等候处理的搜索操作数目。单个搜索请求可以创建多个搜索操作。", + "xpack.monitoring.metrics.esNode.threadsQueued.searchLabel": "搜索", + "xpack.monitoring.metrics.esNode.threadsQueued.watcherDescription": "此节点上等候处理的 Watcher 操作数目。", + "xpack.monitoring.metrics.esNode.threadsQueued.watcherLabel": "Watcher", + "xpack.monitoring.metrics.esNode.threadsRejected.bulkDescription": "批处理拒绝。队列已满时发生这些拒绝。", + "xpack.monitoring.metrics.esNode.threadsRejected.bulkLabel": "批处理", + "xpack.monitoring.metrics.esNode.threadsRejected.genericDescription": "常规(内部)拒绝。队列已满时发生这些拒绝。", + "xpack.monitoring.metrics.esNode.threadsRejected.genericLabel": "常规", + "xpack.monitoring.metrics.esNode.threadsRejected.getDescription": "Get 拒绝。队列已满时发生这些拒绝。", + "xpack.monitoring.metrics.esNode.threadsRejected.getLabel": "获取", + "xpack.monitoring.metrics.esNode.threadsRejected.indexDescription": "索引拒绝。队列已满时发生这些拒绝。应查看批处理索引。", + "xpack.monitoring.metrics.esNode.threadsRejected.indexLabel": "索引", + "xpack.monitoring.metrics.esNode.threadsRejected.managementDescription": "Get(内部)拒绝。队列已满时发生这些拒绝。", + "xpack.monitoring.metrics.esNode.threadsRejected.managementLabel": "管理", + "xpack.monitoring.metrics.esNode.threadsRejected.searchDescription": "搜索拒绝。队列已满时发生这些拒绝。这可能表明分片过量。", + "xpack.monitoring.metrics.esNode.threadsRejected.searchLabel": "搜索", + "xpack.monitoring.metrics.esNode.threadsRejected.watcherDescription": "监视拒绝。队列已满时发生这些拒绝。这可能表明监视堆积。", + "xpack.monitoring.metrics.esNode.threadsRejected.watcherLabel": "Watcher", + "xpack.monitoring.metrics.esNode.totalIoDescription": "I/O 总计。(此指标不支持所有平台,如果 I/O 数据不可用,可能显示“不可用”)", + "xpack.monitoring.metrics.esNode.totalIoLabel": "I/O 总计", + "xpack.monitoring.metrics.esNode.totalIoReadDescription": "读取 I/O 总计。(此指标不支持所有平台,如果 I/O 数据不可用,可能显示“不可用”)", + "xpack.monitoring.metrics.esNode.totalIoReadLabel": "读取 I/O 总计", + "xpack.monitoring.metrics.esNode.totalIoWriteDescription": "写入 I/O 总计。(此指标不支持所有平台,如果 I/O 数据不可用,可能显示“不可用”)", + "xpack.monitoring.metrics.esNode.totalIoWriteLabel": "写入 I/O 总计", + "xpack.monitoring.metrics.esNode.totalRefreshTimeDescription": "Elasticsearch 刷新主分片和副本分片所用的时间。", + "xpack.monitoring.metrics.esNode.totalRefreshTimeLabel": "总刷新时间", + "xpack.monitoring.metrics.esNode.versionMapDescription": "版本控制(例如更新和删除)使用的堆内存。这不是 Lucene 合计的组成部分。", + "xpack.monitoring.metrics.esNode.versionMapLabel": "版本映射", + "xpack.monitoring.metrics.kibana.clientRequestsDescription": "Kibana 实例接收的客户端请求总数。", + "xpack.monitoring.metrics.kibana.clientRequestsLabel": "客户端请求", + "xpack.monitoring.metrics.kibana.clientResponseTime.averageDescription": "Kibana 实例对客户端请求的平均响应时间。", + "xpack.monitoring.metrics.kibana.clientResponseTime.averageLabel": "平均值", + "xpack.monitoring.metrics.kibana.clientResponseTime.maxDescription": "Kibana 实例对客户端请求的最大响应时间。", + "xpack.monitoring.metrics.kibana.clientResponseTime.maxLabel": "最大值", + "xpack.monitoring.metrics.kibana.clientResponseTimeTitle": "客户端响应时间", + "xpack.monitoring.metrics.kibana.httpConnectionsDescription": "Kibana 实例打开的套接字连接总数。", + "xpack.monitoring.metrics.kibana.httpConnectionsLabel": "HTTP 连接", + "xpack.monitoring.metrics.kibana.msTimeUnitLabel": "ms", + "xpack.monitoring.metrics.kibanaInstance.clientRequestsDescription": "Kibana 实例接收的客户端请求总数。", + "xpack.monitoring.metrics.kibanaInstance.clientRequestsLabel": "客户端请求", + "xpack.monitoring.metrics.kibanaInstance.clientResponseTime.averageDescription": "Kibana 实例对客户端请求的平均响应时间。", + "xpack.monitoring.metrics.kibanaInstance.clientResponseTime.averageLabel": "平均值", + "xpack.monitoring.metrics.kibanaInstance.clientResponseTime.maxDescription": "Kibana 实例对客户端请求的最大响应时间。", + "xpack.monitoring.metrics.kibanaInstance.clientResponseTime.maxLabel": "最大值", + "xpack.monitoring.metrics.kibanaInstance.clientResponseTimeTitle": "客户端响应时间", + "xpack.monitoring.metrics.kibanaInstance.eventLoopDelayDescription": "Kibana 服务器事件循环中的延迟。较长的延迟可能表示在服务器线程中有阻止事件,例如同步函数占用大量的 CPU 时间。", + "xpack.monitoring.metrics.kibanaInstance.eventLoopDelayLabel": "事件循环延迟", + "xpack.monitoring.metrics.kibanaInstance.memorySize.heapSizeLimitDescription": "垃圾回收前的内存利用率限制。", + "xpack.monitoring.metrics.kibanaInstance.memorySize.heapSizeLimitLabel": "堆大小限制", + "xpack.monitoring.metrics.kibanaInstance.memorySizeDescription": "在 Node.js 中运行的 Kibana 使用的堆合计。", + "xpack.monitoring.metrics.kibanaInstance.memorySizeLabel": "内存大小", + "xpack.monitoring.metrics.kibanaInstance.memorySizeTitle": "内存大小", + "xpack.monitoring.metrics.kibanaInstance.systemLoad.last15MinutesDescription": "过去 15 分钟的负载平均值。", + "xpack.monitoring.metrics.kibanaInstance.systemLoad.last15MinutesLabel": "15 分钟", + "xpack.monitoring.metrics.kibanaInstance.systemLoad.last1MinuteDescription": "过去 1 分钟的负载平均值。", + "xpack.monitoring.metrics.kibanaInstance.systemLoad.last1MinuteLabel": "1 分钟", + "xpack.monitoring.metrics.kibanaInstance.systemLoad.last5MinutesDescription": "过去 5 分钟的负载平均值。", + "xpack.monitoring.metrics.kibanaInstance.systemLoad.last5MinutesLabel": "5 分钟", + "xpack.monitoring.metrics.kibanaInstance.systemLoadTitle": "系统负载", + "xpack.monitoring.metrics.logstash.eventLatencyDescription": "事件在筛选和输出阶段所花费的平均时间,即处理事件所用的总时间除以已发出事件数目。", + "xpack.monitoring.metrics.logstash.eventLatencyLabel": "事件延迟", + "xpack.monitoring.metrics.logstash.eventsEmittedRateDescription": "所有 Logstash 节点在输出阶段每秒发出的事件数目。", + "xpack.monitoring.metrics.logstash.eventsEmittedRateLabel": "已发出事件速率", + "xpack.monitoring.metrics.logstash.eventsPerSecondUnitLabel": "事件/秒", + "xpack.monitoring.metrics.logstash.eventsReceivedRateDescription": "所有 Logstash 节点在输入阶段每秒接收的事件数目。", + "xpack.monitoring.metrics.logstash.eventsReceivedRateLabel": "已接收事件速率", + "xpack.monitoring.metrics.logstash.msTimeUnitLabel": "ms", + "xpack.monitoring.metrics.logstash.nsTimeUnitLabel": "纳秒", + "xpack.monitoring.metrics.logstash.perSecondUnitLabel": "/秒", + "xpack.monitoring.metrics.logstash.systemLoadTitle": "系统负载", + "xpack.monitoring.metrics.logstashInstance.cgroupCfsStats.cgroupElapsedPeriodsDescription": "完全公平调度器 (CFS) 的采样期间数目。与限制的次数比较。", + "xpack.monitoring.metrics.logstashInstance.cgroupCfsStats.cgroupElapsedPeriodsLabel": "Cgroup 已用期间", + "xpack.monitoring.metrics.logstashInstance.cgroupCfsStats.cgroupThrottledCountDescription": "Cgroup 限制 CPU 的次数。", + "xpack.monitoring.metrics.logstashInstance.cgroupCfsStats.cgroupThrottledCountLabel": "Cgroup 限制计数", + "xpack.monitoring.metrics.logstashInstance.cgroupCfsStatsTitle": "Cgroup CFS 统计", + "xpack.monitoring.metrics.logstashInstance.cgroupCpuPerformance.cgroupThrottlingDescription": "Cgroup 的限制时间量,以纳秒为单位。", + "xpack.monitoring.metrics.logstashInstance.cgroupCpuPerformance.cgroupThrottlingLabel": "Cgroup 限制", + "xpack.monitoring.metrics.logstashInstance.cgroupCpuPerformance.cgroupUsageDescription": "Cgroup 的使用,以纳秒为单位。将其与限制比较以发现问题。", + "xpack.monitoring.metrics.logstashInstance.cgroupCpuPerformance.cgroupUsageLabel": "Cgroup 使用", + "xpack.monitoring.metrics.logstashInstance.cgroupCpuPerformanceTitle": "Cgroup CPU 性能", + "xpack.monitoring.metrics.logstashInstance.cgroupCpuUtilizationDescription": "与 CPU 配额相比较的 CPU 使用时间(显示为百分比)。如果未设置 CPU 配额,将不会显示任何数据。", + "xpack.monitoring.metrics.logstashInstance.cpuUtilization.cgroupCpuUtilizationLabel": "Cgroup CPU 使用率", + "xpack.monitoring.metrics.logstashInstance.cpuUtilizationDescription": "OS 报告的 CPU 使用百分比(100% 为最大值)。", + "xpack.monitoring.metrics.logstashInstance.cpuUtilizationLabel": "CPU 使用率", + "xpack.monitoring.metrics.logstashInstance.cpuUtilizationTitle": "CPU 使用率", + "xpack.monitoring.metrics.logstashInstance.eventLatencyDescription": "事件在筛选和输出阶段所花费的平均时间,即处理事件所用的总时间除以已发出事件数目。", + "xpack.monitoring.metrics.logstashInstance.eventLatencyLabel": "事件延迟", + "xpack.monitoring.metrics.logstashInstance.eventsEmittedRateDescription": "Logstash 节点在输出阶段每秒发出的事件数目。", + "xpack.monitoring.metrics.logstashInstance.eventsEmittedRateLabel": "已发出事件速率", + "xpack.monitoring.metrics.logstashInstance.eventsQueuedDescription": "在永久队列中等候筛选和输出阶段处理的平均事件数目。", + "xpack.monitoring.metrics.logstashInstance.eventsQueuedLabel": "已排队事件", + "xpack.monitoring.metrics.logstashInstance.eventsReceivedRateDescription": "Logstash 节点在输入阶段每秒接收的事件数目。", + "xpack.monitoring.metrics.logstashInstance.eventsReceivedRateLabel": "已接收事件速率", + "xpack.monitoring.metrics.logstashInstance.jvmHeap.maxHeapDescription": "可用于 JVM 中运行的 Logstash 的堆合计。", + "xpack.monitoring.metrics.logstashInstance.jvmHeap.maxHeapLabel": "最大堆", + "xpack.monitoring.metrics.logstashInstance.jvmHeap.usedHeapDescription": "JVM 中运行的 Logstash 使用的堆合计。", + "xpack.monitoring.metrics.logstashInstance.jvmHeap.usedHeapLabel": "已用堆", + "xpack.monitoring.metrics.logstashInstance.jvmHeapTitle": "{javaVirtualMachine} 堆", + "xpack.monitoring.metrics.logstashInstance.maxQueueSizeDescription": "为此节点上的持久队列设置的最大大小。", + "xpack.monitoring.metrics.logstashInstance.maxQueueSizeLabel": "最大队列大小", + "xpack.monitoring.metrics.logstashInstance.persistentQueueEventsTitle": "持久队列事件", + "xpack.monitoring.metrics.logstashInstance.persistentQueueSizeTitle": "持久队列大小", + "xpack.monitoring.metrics.logstashInstance.pipelineNodeCountDescription": "正在运行 Logstash 管道的节点数目。", + "xpack.monitoring.metrics.logstashInstance.pipelineNodeCountLabel": "管道节点计数", + "xpack.monitoring.metrics.logstashInstance.pipelineThroughputDescription": "Logstash 管道在输出阶段每秒发出的事件数目。", + "xpack.monitoring.metrics.logstashInstance.pipelineThroughputLabel": "管道吞吐量", + "xpack.monitoring.metrics.logstashInstance.queueSizeDescription": "此节点上 Logstash 管道中的所有持久队列的当前大小。", + "xpack.monitoring.metrics.logstashInstance.queueSizeLabel": "队列大小", + "xpack.monitoring.metrics.logstashInstance.systemLoad.last15MinutesDescription": "过去 15 分钟的负载平均值。", + "xpack.monitoring.metrics.logstashInstance.systemLoad.last15MinutesLabel": "15 分钟", + "xpack.monitoring.metrics.logstashInstance.systemLoad.last1MinuteDescription": "过去 1 分钟的负载平均值。", + "xpack.monitoring.metrics.logstashInstance.systemLoad.last1MinuteLabel": "1 分钟", + "xpack.monitoring.metrics.logstashInstance.systemLoad.last5MinutesDescription": "过去 5 分钟的负载平均值。", + "xpack.monitoring.metrics.logstashInstance.systemLoad.last5MinutesLabel": "5 分钟", + "xpack.monitoring.monitoringDescription": "跟踪 Elastic Stack 的实时运行状况和性能。", + "xpack.monitoring.monitoringTitle": "Monitoring", + "xpack.monitoring.noData.blurbs.changesNeededDescription": "要运行 Monitoring,请执行以下步骤", + "xpack.monitoring.noData.blurbs.changesNeededTitle": "您需要做些调整", + "xpack.monitoring.noData.blurbs.cloudDeploymentDescription": "请返回到您的 ", + "xpack.monitoring.noData.blurbs.cloudDeploymentDescriptionMore": "有关在 Elastic Cloud 中监测的详情,请参阅 ", + "xpack.monitoring.noData.blurbs.cloudDeploymentTitle": "此处没有您的监测数据。", + "xpack.monitoring.noData.blurbs.lookingForMonitoringDataDescription": "通过 Monitoring,可深入了解您的硬件性能和负载。", + "xpack.monitoring.noData.blurbs.lookingForMonitoringDataTitle": "我们正在寻找您的监测数据", + "xpack.monitoring.noData.blurbs.monitoringIsOffDescription": "通过 Monitoring,可深入了解您的硬件性能和负载。", + "xpack.monitoring.noData.blurbs.monitoringIsOffTitle": "Monitoring 当前已关闭", + "xpack.monitoring.noData.checkerErrors.checkEsSettingsErrorMessage": "尝试检查 Elasticsearch 设置时遇到一些错误。您需要管理员权限,才能检查设置以及根据需要启用监测收集设置。", + "xpack.monitoring.noData.collectionInterval.turnOnMonitoringButtonLabel": "使用 Metricbeat 设置监测", + "xpack.monitoring.noData.defaultLoadingMessage": "正在加载,请稍候", + "xpack.monitoring.noData.explanations.collectionEnabled.monitoringTurnedOnDescription": "数据在您的集群中时,您的监测仪表板将显示在此处。这可能需要几秒钟的时间。", + "xpack.monitoring.noData.explanations.collectionEnabled.monitoringTurnedOnTitle": "成功!获取您的监测数据。", + "xpack.monitoring.noData.explanations.collectionEnabled.stillWaitingLinkText": "仍在等候?", + "xpack.monitoring.noData.explanations.collectionEnabled.turnItOnDescription": "是否要打开它?", + "xpack.monitoring.noData.explanations.collectionEnabled.turnOnMonitoringButtonLabel": "打开 Monitoring", + "xpack.monitoring.noData.explanations.collectionEnabledDescription": "我们已检查 {context} 设置,发现 {property} 已设置为 {data}。", + "xpack.monitoring.noData.explanations.collectionInterval.changeIntervalDescription": "是否希望我们更改该设置并启用 Monitoring?", + "xpack.monitoring.noData.explanations.collectionInterval.monitoringTurnedOnDescription": "监测数据一显示在集群中,该页面便会自动刷新您的监测仪表板。这只需要几秒的时间。", + "xpack.monitoring.noData.explanations.collectionInterval.monitoringTurnedOnTitle": "成功!请稍候。", + "xpack.monitoring.noData.explanations.collectionInterval.turnOnMonitoringButtonLabel": "打开 Monitoring", + "xpack.monitoring.noData.explanations.collectionInterval.wrongIntervalValueDescription": "收集时间间隔设置需要为正整数(推荐 10s),以便收集代理能够处于活动状态。", + "xpack.monitoring.noData.explanations.collectionIntervalDescription": "我们已检查 {context} 设置,发现 {property} 已设置为 {data}。", + "xpack.monitoring.noData.explanations.exporters.checkConfigDescription": "确认用于将统计信息发送到监测集群的导出器已启用,且监测集群主机匹配 {kibanaConfig} 中的 {monitoringEs} 设置,以查看此 Kibana 实例中的监测数据。", + "xpack.monitoring.noData.explanations.exporters.problemWithConfigDescription": "强烈推荐使用监测导出器将监测数据传输到远程监测集群,因为无论生产集群出现什么状况,该监测集群都可以确保监测数据的完整性。不过,因为此 Kibana 实例无法查找到任何监测数据,所以似乎 {property} 配置或 {kibanaConfig} 中的 {monitoringEs} 设置有问题。", + "xpack.monitoring.noData.explanations.exportersCloudDescription": "在 Elastic Cloud 中,您的监测数据将存储在专用监测集群中。", + "xpack.monitoring.noData.explanations.exportersDescription": "我们已检查 {property} 的 {context} 设置并发现了原因:{data}。", + "xpack.monitoring.noData.explanations.pluginEnabledDescription": "我们已检查 {context} 设置,发现 {property} 已设置为 {data},这禁用了 Monitoring。将 {monitoringEnableFalse} 设置从您的配置中删除将会使默认值生效,并会启用 Monitoring。", + "xpack.monitoring.noData.noMonitoringDataFound": "是否已设置监测?如果已设置,确保右上角所选的时间段包含监测数据。", + "xpack.monitoring.noData.noMonitoringDetected": "找不到任何监测数据", + "xpack.monitoring.noData.reasons.couldNotActivateMonitoringTitle": "我们无法激活 Monitoring", + "xpack.monitoring.noData.reasons.explainWhyNoDataDescription": "存在将 {property} 设置为 {data} 的 {context} 设置。", + "xpack.monitoring.noData.reasons.ifDataInClusterDescription": "如果数据在您的集群中,您的监测仪表板将显示在此处。", + "xpack.monitoring.noData.reasons.noMonitoringDataFoundDescription": "找不到任何监测数据。尝试将时间筛选设置为“过去 1 小时”或检查是否有其他时段的数据。", + "xpack.monitoring.noData.routeTitle": "设置监测", + "xpack.monitoring.noData.setupInternalInstead": "或,使用内部收集设置", + "xpack.monitoring.noData.setupMetricbeatInstead": "或,使用 Metricbeat 设置(推荐)", + "xpack.monitoring.pageLoadingTitle": "正在加载……", + "xpack.monitoring.requestedClusters.uuidNotFoundErrorMessage": "在选定时间范围内找不到该集群。UUID:{clusterUuid}", + "xpack.monitoring.setupMode.clickToDisableInternalCollection": "禁用内部收集(self monitoring)", + "xpack.monitoring.setupMode.clickToMonitorWithMetricbeat": "使用 Metricbeat 监测", + "xpack.monitoring.setupMode.description": "您处于设置模式。图标 ({flagIcon}) 表示配置选项。", + "xpack.monitoring.setupMode.detectedNodeDescription": "单击下面的“设置监测”以开始监测此 {identifier}。", + "xpack.monitoring.setupMode.detectedNodeTitle": "检测到 {product} {identifier}", + "xpack.monitoring.setupMode.disableInternalCollectionDescription": "Metricbeat 现在正监测您的 {product} {identifier}。禁用内部收集以完成迁移。", + "xpack.monitoring.setupMode.disableInternalCollectionTitle": "禁用内部收集(self monitoring)", + "xpack.monitoring.setupMode.enter": "进入设置模式", + "xpack.monitoring.setupMode.exit": "退出设置模式", + "xpack.monitoring.setupMode.instance": "实例", + "xpack.monitoring.setupMode.instances": "实例", + "xpack.monitoring.setupMode.metricbeatAllNodes": "Metricbeat 正在监测所有 {identifier}。", + "xpack.monitoring.setupMode.migrateSomeToMetricbeatDescription": "某些 {product} {identifier} 通过内部收集进行监测。迁移到使用 Metricbeat 监测。", + "xpack.monitoring.setupMode.migrateToMetricbeat": "使用 Metricbeat 监测", + "xpack.monitoring.setupMode.migrateToMetricbeatDescription": "这些 {product} {identifier} 自我监测。\n 单击“使用 Metricbeat 监测”以迁移。", + "xpack.monitoring.setupMode.monitorAllNodes": "一些节点仅使用内部收集", + "xpack.monitoring.setupMode.netNewUserDescription": "单击“设置监测”以开始使用 Metricbeat 监测。", + "xpack.monitoring.setupMode.node": "节点", + "xpack.monitoring.setupMode.nodes": "节点", + "xpack.monitoring.setupMode.noMonitoringDataFound": "未检测到 {product} {identifier}", + "xpack.monitoring.setupMode.notAvailableCloud": "此功能在云上不可用。", + "xpack.monitoring.setupMode.notAvailablePermissions": "您没有所需的权限来执行此功能。", + "xpack.monitoring.setupMode.notAvailableTitle": "设置模式不可用", + "xpack.monitoring.setupMode.server": "服务器", + "xpack.monitoring.setupMode.servers": "服务器", + "xpack.monitoring.setupMode.tooltip.allSet": "Metricbeat 正在监测所有 {identifierPlural}。", + "xpack.monitoring.setupMode.tooltip.detected": "无监测", + "xpack.monitoring.setupMode.tooltip.disableInternal": "Metricbeat 正在监测所有 {identifierPlural}。单击以查看 {identifierPlural} 并禁用内部收集。", + "xpack.monitoring.setupMode.tooltip.mightExist": "我们检测到此产品的使用。单击以开始监测。", + "xpack.monitoring.setupMode.tooltip.noUsage": "无使用", + "xpack.monitoring.setupMode.tooltip.noUsageDetected": "我们未检测到任何使用。单击以查看 {identifier}。", + "xpack.monitoring.setupMode.tooltip.oneInternal": "至少一个 {identifier} 未使用 Metricbeat 进行监测。单击以查看状态。", + "xpack.monitoring.setupMode.unknown": "不可用", + "xpack.monitoring.setupMode.usingMetricbeatCollection": "已使用 Metricbeat 监测", + "xpack.monitoring.stackMonitoringDocTitle": "堆栈监测 {clusterName} {suffix}", + "xpack.monitoring.stackMonitoringTitle": "堆栈监测", + "xpack.monitoring.summaryStatus.statusDescription": "状态", + "xpack.monitoring.summaryStatus.statusIconLabel": "状态:{status}", + "xpack.monitoring.summaryStatus.statusIconTitle": "状态:{statusIcon}", + "xpack.monitoring.uiExportsDescription": "Elastic Stack 的 Monitoring 组件", + "xpack.remoteClusters.addAction.clusterNameAlreadyExistsErrorMessage": "名为 “{clusterName}” 的集群已存在。", + "xpack.remoteClusters.addAction.errorTitle": "添加集群时出错", + "xpack.remoteClusters.addAction.failedDefaultErrorMessage": "请求失败,显示 {statusCode} 错误。{message}", + "xpack.remoteClusters.addAction.successTitle": "添加了远程集群“{name}”", + "xpack.remoteClusters.addBreadcrumbTitle": "添加", + "xpack.remoteClusters.addTitle": "添加远程集群", + "xpack.remoteClusters.appName": "远程集群", + "xpack.remoteClusters.appTitle": "远程集群", + "xpack.remoteClusters.configuredByNodeWarningTitle": "您无法编辑或删除此远程集群,因为它是在节点的 elasticsearch.yml 配置文件中定义的。", + "xpack.remoteClusters.connectedStatus.connectedAriaLabel": "已连接", + "xpack.remoteClusters.connectedStatus.notConnectedAriaLabel": "未连接", + "xpack.remoteClusters.connectedStatus.notConnectedToolTip": "确保已为种子节点配置远程集群的传输端口,而非 http 端口。", + "xpack.remoteClusters.detailPanel.closeButtonLabel": "关闭", + "xpack.remoteClusters.detailPanel.connectedLabel": "连接", + "xpack.remoteClusters.detailPanel.connectedNodesLabel": "已连接节点", + "xpack.remoteClusters.detailPanel.editButtonLabel": "编辑", + "xpack.remoteClusters.detailPanel.initialConnectTimeoutLabel": "初始连接超时", + "xpack.remoteClusters.detailPanel.maxConnectionsPerClusterLabel": "最大连接数", + "xpack.remoteClusters.detailPanel.notFoundLabel": "找不到远程集群", + "xpack.remoteClusters.detailPanel.removeButtonLabel": "删除", + "xpack.remoteClusters.detailPanel.seedsLabel": "种子", + "xpack.remoteClusters.detailPanel.skipUnavailableFalseValue": "否", + "xpack.remoteClusters.detailPanel.skipUnavailableLabel": "无法跳过", + "xpack.remoteClusters.detailPanel.skipUnavailableNullValue": "默认值", + "xpack.remoteClusters.detailPanel.skipUnavailableTrueValue": "是", + "xpack.remoteClusters.detailPanel.statusTitle": "状态", + "xpack.remoteClusters.edit.backToRemoteClustersButtonLabel": "返回远程集群", + "xpack.remoteClusters.edit.loadingErrorMessage": "远程集群“{name}”不存在。", + "xpack.remoteClusters.edit.loadingErrorTitle": "加载远程集群时出错", + "xpack.remoteClusters.edit.loadingLabel": "正在加载远程集群……", + "xpack.remoteClusters.edit.viewRemoteClustersButtonLabel": "查看远程集群", + "xpack.remoteClusters.editAction.errorTitle": "编辑集群时出错", + "xpack.remoteClusters.editAction.failedDefaultErrorMessage": "请求失败,显示 {statusCode} 错误。{message}", + "xpack.remoteClusters.editAction.successTitle": "已编辑远程集群“{name}”", + "xpack.remoteClusters.editBreadcrumbTitle": "编辑", + "xpack.remoteClusters.editTitle": "编辑远程集群", + "xpack.remoteClusters.form.errors.illegalCharacters": "从名称中删除{characterListLength, plural, one {字符} other {字符}} {characterList}。", + "xpack.remoteClusters.form.errors.illegalSpace": "名称中不允许使用空格。", + "xpack.remoteClusters.form.errors.nameMissing": "“名称”必填", + "xpack.remoteClusters.form.errors.seedMissing": "至少需要一个种子节点。", + "xpack.remoteClusters.listBreadcrumbTitle": "远程集群", + "xpack.remoteClusters.loadAction.errorTitle": "加载远程集群时出错", + "xpack.remoteClusters.readDocsButtonLabel": "远程集群文档", + "xpack.remoteClusters.refreshAction.errorTitle": "刷新远程集群时出错", + "xpack.remoteClusters.remoteClusterForm.actions.savingText": "正在保存", + "xpack.remoteClusters.remoteClusterForm.cancelButtonLabel": "取消", + "xpack.remoteClusters.remoteClusterForm.errorTitle": "继续前请解决错误。", + "xpack.remoteClusters.remoteClusterForm.fieldNameLabel": "名称", + "xpack.remoteClusters.remoteClusterForm.fieldNameLabelHelpText": "名称只能包含字母、数字、下划线和短划线。", + "xpack.remoteClusters.remoteClusterForm.fieldSeedsLabel": "种子节点", + "xpack.remoteClusters.remoteClusterForm.fieldSeedsPlaceholder": "host:port", + "xpack.remoteClusters.remoteClusterForm.hideRequestButtonLabel": "隐藏请求", + "xpack.remoteClusters.remoteClusterForm.inputLocalSeedErrorMessage": "“种子节点”字段无效。", + "xpack.remoteClusters.remoteClusterForm.inputNameErrorMessage": "“名称”字段无效。", + "xpack.remoteClusters.remoteClusterForm.inputSeedsErrorMessage": "“种子节点”字段无效。", + "xpack.remoteClusters.remoteClusterForm.localSeedError.duplicateMessage": "不允许存在重复的种子节点。", + "xpack.remoteClusters.remoteClusterForm.localSeedError.invalidCharactersMessage": "种子节点必须使用 host:port 格式。示例:127.0.0.1:9400,localhost:9400。主机只能由字母、数字和短划线构成。", + "xpack.remoteClusters.remoteClusterForm.localSeedError.invalidPortMessage": "“端口”必填。", + "xpack.remoteClusters.remoteClusterForm.saveButtonLabel": "保存", + "xpack.remoteClusters.remoteClusterForm.sectionNameDescription": "远程集群的唯一名称。", + "xpack.remoteClusters.remoteClusterForm.sectionNameTitle": "名称", + "xpack.remoteClusters.remoteClusterForm.sectionSeedsDescription1": "要查询集群状态的远程集群节点的列表。指定多个种子节点,以便在节点不可用时发现不会失败。", + "xpack.remoteClusters.remoteClusterForm.sectionSeedsHelpText": "IP 地址或主机名,后跟远程集群的 {transportPort}。", + "xpack.remoteClusters.remoteClusterForm.sectionSeedsHelpText.transportPortLinkText": "传输端口", + "xpack.remoteClusters.remoteClusterForm.sectionSeedsTitle": "用于集群发现的种子节点", + "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableDescription": "默认情况下,如果任何查询的远程集群不可用,请求将失败。要在此集群不可用时继续向其他远程集群发送请求,请启用 {optionName}。{learnMoreLink}", + "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableDescription.learnMoreLinkLabel": "了解详情。", + "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableDescription.optionNameLabel": "如果不可用,则跳过", + "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableLabel": "如果不可用,则跳过", + "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableResetLabel": "重置为默认值", + "xpack.remoteClusters.remoteClusterForm.sectionSkipUnavailableTitle": "使远程集群可选", + "xpack.remoteClusters.remoteClusterForm.showRequestButtonLabel": "显示请求", + "xpack.remoteClusters.remoteClusterList.connectButtonLabel": "添加远程集群", + "xpack.remoteClusters.remoteClusterList.emptyPrompt.connectButtonLabel": "添加远程集群", + "xpack.remoteClusters.remoteClusterList.emptyPromptDescription": "远程集群创建从本地集群到其他集群的单向连接。", + "xpack.remoteClusters.remoteClusterList.emptyPromptTitle": "添加您的第一个远程集群", + "xpack.remoteClusters.remoteClusterList.loadingErrorTitle": "加载远程集群时出错", + "xpack.remoteClusters.remoteClusterList.loadingTitle": "正在加载远程集群……", + "xpack.remoteClusters.remoteClusterList.noPermissionText": "您没有权限查看或添加远程集群。", + "xpack.remoteClusters.remoteClusterList.noPermissionTitle": "权限错误", + "xpack.remoteClusters.remoteClusterList.table.actionBlockedDeleteDescription": "无法删除在 elasticsearch.yml 中定义的远程集群", + "xpack.remoteClusters.remoteClusterList.table.actionBlockedEditDescription": "无法编辑在 elasticsearch.yml 中定义的远程集群", + "xpack.remoteClusters.remoteClusterList.table.actionDeleteDescription": "删除远程集群", + "xpack.remoteClusters.remoteClusterList.table.actionEditDescription": "编辑远程集群", + "xpack.remoteClusters.remoteClusterList.table.actionsColumnTitle": "操作", + "xpack.remoteClusters.remoteClusterList.table.connectedColumnTitle": "连接", + "xpack.remoteClusters.remoteClusterList.table.connectedNodesColumnTitle": "已连接节点", + "xpack.remoteClusters.remoteClusterList.table.isConfiguredByNodeMessage": "在 elasticsearch.yml 中定义", + "xpack.remoteClusters.remoteClusterList.table.nameColumnTitle": "名称", + "xpack.remoteClusters.remoteClusterList.table.removeButtonLabel": "删除 {count, plural, one { 个远程集群} other {{count} 个远程集群}}", + "xpack.remoteClusters.remoteClusterList.table.seedsColumnTitle": "种子", + "xpack.remoteClusters.remoteClusterListTitle": "远程集群", + "xpack.remoteClusters.removeAction.errorMultipleNotificationTitle": "删除 “{count}” 个远程集群时出错", + "xpack.remoteClusters.removeAction.errorSingleNotificationTitle": "删除远程集群 “{name}” 时出错", + "xpack.remoteClusters.removeAction.successMultipleNotificationTitle": "已删除 {count} 个远程集群", + "xpack.remoteClusters.removeAction.successSingleNotificationTitle": "已删除远程集群“{name}”", + "xpack.remoteClusters.removeButton.confirmModal.cancelButtonText": "取消", + "xpack.remoteClusters.removeButton.confirmModal.confirmButtonText": "删除", + "xpack.remoteClusters.removeButton.confirmModal.deleteSingleClusterTitle": "是否删除远程集群 “{name}”?", + "xpack.remoteClusters.removeButton.confirmModal.multipleDeletionDescription": "您即将删除以下远程集群:", + "xpack.remoteClusters.removeButton.confirmModal.multipleDeletionTitle": "是否删除 {count} 个远程集群?", + "xpack.remoteClusters.requestFlyout.closeButtonLabel": "关闭", + "xpack.remoteClusters.requestFlyout.descriptionText": "此 Elasticsearch 请求将创建或更新此远程集群。", + "xpack.remoteClusters.requestFlyout.namedTitle": "对“{name}”的请求", + "xpack.remoteClusters.requestFlyout.unnamedTitle": "请求", + "xpack.reporting.breadcrumb": "报告", + "xpack.reporting.dashboard.csvDownloadStartedMessage": "您的 CSV 将很快下载。", + "xpack.reporting.dashboard.csvDownloadStartedTitle": "CSV 下载已开始", + "xpack.reporting.dashboard.downloadCsvPanelTitle": "下载 CSV", + "xpack.reporting.dashboard.failedCsvDownloadMessage": "我们此次无法生成 CSV。", + "xpack.reporting.dashboard.failedCsvDownloadTitle": "CSV 下载失败。", + "xpack.reporting.errorButton.showReportErrorAriaLabel": "显示报告错误", + "xpack.reporting.errorButton.unableToFetchReportContentTitle": "无法提取报告内容", + "xpack.reporting.errorButton.unableToGenerateReportTitle": "无法生成报告", + "xpack.reporting.exportTypes.csv_from_savedobject.executeJob.failedToDecryptReportJobDataErrorMessage": "无法解密报告作业数据。请确保已设置 {encryptionKey},然后重新生成此报告。{err}", + "xpack.reporting.exportTypes.csv.executeJob.failedToDecryptReportJobDataErrorMessage": "无法解密报告作业数据。请确保已设置 {encryptionKey},然后重新生成此报告。{err}", + "xpack.reporting.exportTypes.csv.hitIterator.expectedHitsErrorMessage": "在以下 Elasticsearch 响应中预期 {hits}:{response}", + "xpack.reporting.exportTypes.csv.hitIterator.expectedScrollIdErrorMessage": "在以下 Elasticsearch 响应中预期 {scrollId}:{response}", + "xpack.reporting.exportTypes.printablePdf.documentStreamIsNotgeneratedErrorMessage": "尚未生成文档流", + "xpack.reporting.exportTypes.printablePdf.logoDescription": "由 Elastic 提供支持", + "xpack.reporting.exportTypes.printablePdf.pagingDescription": "第 {currentPage} 页,共 {pageCount} 页", + "xpack.reporting.exportTypes.printablePdf.screenshots.unexpectedErrorMessage": "在页面上出现意外消息:{toastHeaderText}", + "xpack.reporting.jobStatuses.cancelledText": "已取消", + "xpack.reporting.jobStatuses.completedText": "已完成", + "xpack.reporting.jobStatuses.failedText": "失败", + "xpack.reporting.jobStatuses.pendingText": "待处理", + "xpack.reporting.jobStatuses.processingText": "正在处理", + "xpack.reporting.listing.reports.subtitle": "在此处查找 Kibana 应用程序中生成的报告", + "xpack.reporting.listing.reportstitle": "报告", + "xpack.reporting.listing.table.csvContainsFormulas": "您的 CSV 包含电子表格应用程序可解释为公式的字符。", + "xpack.reporting.listing.table.downloadReportAriaLabel": "下载报告", + "xpack.reporting.listing.table.loadingReportsDescription": "正在载入报告", + "xpack.reporting.listing.table.maxSizeReachedTooltip": "已达到最大大小,包含部分数据。", + "xpack.reporting.listing.table.noCreatedReportsDescription": "未创建任何报告", + "xpack.reporting.listing.table.requestFailedErrorMessage": "请求失败", + "xpack.reporting.listing.tableColumns.actionsTitle": "操作", + "xpack.reporting.listing.tableColumns.createdAtTitle": "创建于", + "xpack.reporting.listing.tableColumns.reportTitle": "报告", + "xpack.reporting.listing.tableColumns.statusTitle": "状态", + "xpack.reporting.listing.tableValue.createdAtDetail.maxSizeReachedText": " - 最大大小已达到", + "xpack.reporting.listing.tableValue.createdAtDetail.pendingStatusReachedText": "待处理 - 正在等候处理作业", + "xpack.reporting.listing.tableValue.createdAtDetail.statusTimestampText": "{statusTimestamp} 时为 {statusLabel}", + "xpack.reporting.management.reportingTitle": "报告", + "xpack.reporting.panelContent.copyUrlButtonLabel": "复制 POST URL", + "xpack.reporting.panelContent.generateButtonLabel": "生成 {reportingType}", + "xpack.reporting.panelContent.generationTimeDescription": "{reportingType} 可能会花费 1 或 2 分钟生成,取决于 {objectType} 的大小。", + "xpack.reporting.panelContent.howToCallGenerationDescription": "或者,复制此 POST URL 以从 Kibana 外部或从 Watcher 调用生成。", + "xpack.reporting.panelContent.noPermissionToGenerateReportDescription": "您无权生成此报告。", + "xpack.reporting.panelContent.notification.cantReachServerDescription": "无法访问服务器。请重试。", + "xpack.reporting.panelContent.notification.reportingErrorTitle": "报告错误", + "xpack.reporting.panelContent.saveWorkDescription": "请在生成报告之前保存您的工作。", + "xpack.reporting.panelContent.successfullyQueuedReportNotificationDescription": "在“管理”中跟踪其进度", + "xpack.reporting.panelContent.successfullyQueuedReportNotificationTitle": "已为 {objectType} 排队报告", + "xpack.reporting.panelContent.whatCanBeExportedWarningDescription": "请先保存您的工作", + "xpack.reporting.panelContent.whatCanBeExportedWarningTitle": "只会导出保存的 {objectType}", + "xpack.reporting.pdfFooterImageDescription": "PDF 的页脚中要使用的定制图片", + "xpack.reporting.pdfFooterImageLabel": "PDF 页脚图片", + "xpack.reporting.registerFeature.reportingDescription": "管理您从 Discover、Visualize 和 Dashboard 生成的报告。", + "xpack.reporting.registerFeature.reportingTitle": "报告", + "xpack.reporting.screenCapturePanelContent.optimizeForPrintingLabel": "打印优化", + "xpack.reporting.shareContextMenu.csvReportsButtonLabel": "CSV 报告", + "xpack.reporting.shareContextMenu.pdfReportsButtonLabel": "PDF 报告", + "xpack.rollupJobs.appTitle": "汇总/打包作业", + "xpack.rollupJobs.checkLicense.errorExpiredMessage": "您不能使用 {pluginName},因为您的 {licenseType} 许可证已过期", + "xpack.rollupJobs.checkLicense.errorUnavailableMessage": "您不能使用 {pluginName},因为许可证信息当前不可用。", + "xpack.rollupJobs.checkLicense.errorUnsupportedMessage": "您的 {licenseType} 许可证不支持 {pluginName}。请升级您的许可。", + "xpack.rollupJobs.create.backButton.label": "上一步", + "xpack.rollupJobs.create.dateTypeField": "日期", + "xpack.rollupJobs.create.errors.dateHistogramFieldMissing": "“日期”字段必填。", + "xpack.rollupJobs.create.errors.dateHistogramIntervalInvalidCalendarInterval": "“{unit}” 单位仅允许值为 1。请尝试 {suggestion}。", + "xpack.rollupJobs.create.errors.dateHistogramIntervalInvalidCalendarIntervalSuggestion": "1{unit}", + "xpack.rollupJobs.create.errors.dateHistogramIntervalInvalidFormat": "时间间隔格式无效。", + "xpack.rollupJobs.create.errors.dateHistogramIntervalMissing": "“时间间隔”必填。", + "xpack.rollupJobs.create.errors.histogramIntervalMissing": "汇总这些直方图字段需要一个时间间隔。", + "xpack.rollupJobs.create.errors.histogramIntervalWholeNumber": "时间间隔必须是整数。", + "xpack.rollupJobs.create.errors.histogramIntervalZero": "时间间隔值必须大于零。", + "xpack.rollupJobs.create.errors.idMissing": "“名称”必填", + "xpack.rollupJobs.create.errors.idSameAsCloned": "名称不能与克隆名称相同:“{clonedId}。", + "xpack.rollupJobs.create.errors.indexPatternIllegalCharacters": "从索引模式中删除 {characterList} 字符。", + "xpack.rollupJobs.create.errors.indexPatternMatchesRollupIndices": "索引模式不能与汇总/打包索引匹配。", + "xpack.rollupJobs.create.errors.indexPatternMissing": "索引模式必填。", + "xpack.rollupJobs.create.errors.indexPatternNoMatchingIndices": "索引模式不匹配任何索引。", + "xpack.rollupJobs.create.errors.indexPatternNoTimeFields": "索引模式必须匹配包含时间字段的索引。", + "xpack.rollupJobs.create.errors.indexPatternSameAsRollupIndex": "索引模式不能与汇总/打包索引相同。", + "xpack.rollupJobs.create.errors.indexPatternSpaces": "从索引模式中删除空格。", + "xpack.rollupJobs.create.errors.indexPatternValidationError": "验证此索引模式时出现问题:{statusCode} {error}", + "xpack.rollupJobs.create.errors.indexPatternValidationFatalErrorTitle": "汇总/打包作业向导索引模式验证", + "xpack.rollupJobs.create.errors.metricsTypesMissing": "选择这些字段的指标类型或将其删除:{allMissingTypes}。", + "xpack.rollupJobs.create.errors.rollupCronMissing": "Cron 模式或基本间隔必填。", + "xpack.rollupJobs.create.errors.rollupDelayInvalidCalendarInterval": "“{unit}” 单位仅允许值为 1。请尝试 {suggestion}。", + "xpack.rollupJobs.create.errors.rollupDelayInvalidCalendarIntervalSuggestion": "1{unit}", + "xpack.rollupJobs.create.errors.rollupDelayInvalidFormat": "延迟格式无效。", + "xpack.rollupJobs.create.errors.rollupIndexBeginningPeriod": "索引名称不能以句点开头。", + "xpack.rollupJobs.create.errors.rollupIndexCommas": "从汇总/打包索引名称中删除逗号。", + "xpack.rollupJobs.create.errors.rollupIndexIllegalCharacters": "从汇总/打包索引名称中删除字符 {characterList}。", + "xpack.rollupJobs.create.errors.rollupIndexMissing": "汇总/打包索引必填。", + "xpack.rollupJobs.create.errors.rollupIndexSameAsIndexPattern": "汇总/打包索引不能与索引模式相同。", + "xpack.rollupJobs.create.errors.rollupIndexSpaces": "从汇总/打包索引名称中删除空格。", + "xpack.rollupJobs.create.errors.rollupPageSizeGreaterThanZero": "页面大小必须大于零。", + "xpack.rollupJobs.create.errors.rollupPageSizeMissing": "“页面大小”必填。", + "xpack.rollupJobs.create.jobDetails.tabHistogramLabel": "Histogram", + "xpack.rollupJobs.create.jobDetails.tabJsonLabel": "JSON", + "xpack.rollupJobs.create.jobDetails.tabMetricsLabel": "指标", + "xpack.rollupJobs.create.jobDetails.tabRequestLabel": "请求", + "xpack.rollupJobs.create.jobDetails.tabSummaryLabel": "结论", + "xpack.rollupJobs.create.jobDetails.tabTermsLabel": "词", + "xpack.rollupJobs.create.keywordTypeField": "关键字", + "xpack.rollupJobs.create.navigation.savingText": "正在保存", + "xpack.rollupJobs.create.nextButton.label": "下一个", + "xpack.rollupJobs.create.numericTypeField": "数值", + "xpack.rollupJobs.create.saveButton.label": "保存", + "xpack.rollupJobs.create.startJobLabel": "立即启动作业", + "xpack.rollupJobs.create.stepDateHistogram.fieldDateFieldLabel": "日期字段", + "xpack.rollupJobs.create.stepDateHistogram.fieldDelay.helpExampleLabel": "示例值:30s、20m、24h、2d、1w、1M", + "xpack.rollupJobs.create.stepDateHistogram.fieldDelayLabel": "延迟缓冲(可选)", + "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.helpExampleLabel": "示例大小:1000ms、30s、20m、24h、2d、1w、1M、1y", + "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.preferFixedWarningDayLabel": "考虑使用 24h 代替 1d。这样会使查询更灵活。", + "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.preferFixedWarningHourLabel": "考虑使用 60m 代替 1h。这样会使查询更灵活。", + "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.preferFixedWarningMonthLabel": "考虑使用单位 d 代替 M。这样会使查询更灵活。", + "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.preferFixedWarningWeekLabel": "考虑使用单位 d 代替 w。这样会使查询更灵活。", + "xpack.rollupJobs.create.stepDateHistogram.fieldInterval.preferFixedWarningYearLabel": "考虑使用单位 d 代替 y。这样会使查询更灵活。", + "xpack.rollupJobs.create.stepDateHistogram.fieldIntervalLabel": "时间桶大小", + "xpack.rollupJobs.create.stepDateHistogram.fieldTimeZoneLabel": "时区", + "xpack.rollupJobs.create.stepDateHistogram.readDocsButtonLabel": "日期直方图文档", + "xpack.rollupJobs.create.stepDateHistogram.sectionDataSourceDescription": "请注意,时间桶越小在比例上占用的空间越多。", + "xpack.rollupJobs.create.stepDateHistogramDescription": "定义 {link} 对汇总/打包数据的操作方式。", + "xpack.rollupJobs.create.stepDateHistogramDescription.aggregationsLinkLabel": "日期直方图聚合", + "xpack.rollupJobs.create.stepDateHistogramTitle": "Date histogram", + "xpack.rollupJobs.create.stepErrorTitle": "继续前请解决错误。", + "xpack.rollupJobs.create.stepHistogram.fieldHistogramIntervalLabel": "时间间隔", + "xpack.rollupJobs.create.stepHistogram.fieldsChooserLabel": "添加直方图字段", + "xpack.rollupJobs.create.stepHistogram.histogramDescription": "使用数字间隔选择要存储的字段。", + "xpack.rollupJobs.create.stepHistogram.readDocsButtonLabel": "直方图文档", + "xpack.rollupJobs.create.stepHistogram.sectionHistogramIntervalDescription": "这是在汇总/打包时生成的直方图桶的间隔,例如,5 表示将创建五个单位宽(0-5、5-10等)的桶。请注意,直方图组中只能指定一个间隔,这意味着通过直方图分组的所有字段必须共享相同的间隔。", + "xpack.rollupJobs.create.stepHistogram.sectionHistogramIntervalTitle": "直方图间隔", + "xpack.rollupJobs.create.stepHistogramTitle": "Histogram(可选)", + "xpack.rollupJobs.create.stepLogistics.fieldCron.helpReferenceLinkLabel": "详细了解 Cron 表达式", + "xpack.rollupJobs.create.stepLogistics.fieldCronLabel": "Cron 表达式", + "xpack.rollupJobs.create.stepLogistics.fieldIdLabel": "名称", + "xpack.rollupJobs.create.stepLogistics.fieldIndexPattern.helpAllowLabel": "使用通配符 ({asterisk}) 匹配多个索引。", + "xpack.rollupJobs.create.stepLogistics.fieldIndexPattern.helpDisallowLabel": "不允许使用空格和字符 {characterList}。", + "xpack.rollupJobs.create.stepLogistics.fieldIndexPattern.helpHasMatchesLabel": "成功!索引模式具有匹配的索引。", + "xpack.rollupJobs.create.stepLogistics.fieldIndexPattern.helpMustMatchLabel": "索引模式必须至少匹配一个不是汇总/打包的索引。", + "xpack.rollupJobs.create.stepLogistics.fieldIndexPattern.helpSearchingLabel": "正在寻找匹配的索引......", + "xpack.rollupJobs.create.stepLogistics.fieldIndexPatternLabel": "索引模式", + "xpack.rollupJobs.create.stepLogistics.fieldPageSizeLabel": "页面大小", + "xpack.rollupJobs.create.stepLogistics.fieldRollupIndex.helpDisallowLabel": "不允许出现空格、逗号和字符 {characterList}。", + "xpack.rollupJobs.create.stepLogistics.fieldRollupIndexLabel": "汇总/打包索引名称", + "xpack.rollupJobs.create.stepLogistics.logisticsDescription": "定义如何运行汇总/打包作业以及何时索引文档。", + "xpack.rollupJobs.create.stepLogistics.readDocsButtonLabel": "运筹文档", + "xpack.rollupJobs.create.stepLogistics.sectionDataFlowDescription": "您想要汇总/打包哪些索引以及您希望在何处存储数据?", + "xpack.rollupJobs.create.stepLogistics.sectionDataFlowTitle": "数据流", + "xpack.rollupJobs.create.stepLogistics.sectionDelayDescription": "延迟缓冲将延迟汇总/打包数据。通过允许可变的采集延迟,这将实现准确度更高的汇总/打包。默认情况下,汇总/打包作业会尝试汇总/打包所有可用的数据。", + "xpack.rollupJobs.create.stepLogistics.sectionDelayTitle": "汇总/打包作业在汇总/打包新数据之前需要等待多长时间?", + "xpack.rollupJobs.create.stepLogistics.sectionIdDescription": "此名称将用作此汇总/打包作业的唯一标识符。", + "xpack.rollupJobs.create.stepLogistics.sectionIdTitle": "名称", + "xpack.rollupJobs.create.stepLogistics.sectionPageSizeDescription": "较大的页面大小会更快地汇总/打包数据,但需要更多内存。", + "xpack.rollupJobs.create.stepLogistics.sectionPageSizeTitle": "您想一次汇总/打包多少文档?", + "xpack.rollupJobs.create.stepLogistics.sectionSchedule.buttonAdvancedLabel": "创建 Cron 表达式", + "xpack.rollupJobs.create.stepLogistics.sectionSchedule.buttonBasicLabel": "创建基本间隔", + "xpack.rollupJobs.create.stepLogistics.sectionScheduleDescription": "您要多久汇总/打包一次数据?", + "xpack.rollupJobs.create.stepLogistics.sectionScheduleTitle": "计划", + "xpack.rollupJobs.create.stepLogisticsTitle": "运筹", + "xpack.rollupJobs.create.stepMetrics.allCheckbox": "全部", + "xpack.rollupJobs.create.stepMetrics.checkboxAverageLabel": "平均值", + "xpack.rollupJobs.create.stepMetrics.checkboxMaxLabel": "最大值", + "xpack.rollupJobs.create.stepMetrics.checkboxMinLabel": "最小值", + "xpack.rollupJobs.create.stepMetrics.checkboxSumLabel": "和", + "xpack.rollupJobs.create.stepMetrics.checkboxValueCountLabel": "值计数", + "xpack.rollupJobs.create.stepMetrics.emptyListLabel": "未添加任何指标字段", + "xpack.rollupJobs.create.stepMetrics.fieldColumnLabel": "字段", + "xpack.rollupJobs.create.stepMetrics.fieldsChooserLabel": "添加指标字段", + "xpack.rollupJobs.create.stepMetrics.metricsColumnHeader": "指标", + "xpack.rollupJobs.create.stepMetrics.readDocsButtonLabel": "指标文档", + "xpack.rollupJobs.create.stepMetrics.selectAllPopoverButtonLabel": "选择指标", + "xpack.rollupJobs.create.stepMetrics.selectAllRowLabel": "全部", + "xpack.rollupJobs.create.stepMetrics.typeColumnLabel": "类型", + "xpack.rollupJobs.create.stepMetricsDescription": "选择在汇总数据时要收集的指标。默认情况下,每个组仅收集 doc_counts。", + "xpack.rollupJobs.create.stepMetricsTitle": "指标(可选)", + "xpack.rollupJobs.create.stepReviewTitle": "查看 “{jobId}” 的详情", + "xpack.rollupJobs.create.steps.stepDateHistogramTitle": "Date histogram", + "xpack.rollupJobs.create.steps.stepHistogramTitle": "Histogram", + "xpack.rollupJobs.create.steps.stepLogisticsTitle": "运筹", + "xpack.rollupJobs.create.steps.stepMetricsTitle": "指标", + "xpack.rollupJobs.create.steps.stepReviewTitle": "查看并保存", + "xpack.rollupJobs.create.steps.stepTermsTitle": "词", + "xpack.rollupJobs.create.stepTerms.fieldsChooserLabel": "添加字词字段", + "xpack.rollupJobs.create.stepTerms.readDocsButtonLabel": "字词文档", + "xpack.rollupJobs.create.stepTermsDescription": "使用字词聚合选择要存储的字段。如果时间桶稀疏,这对于诸如 IP 地址等的高基数字段可能会成本高昂。", + "xpack.rollupJobs.create.stepTermsTitle": "字词(可选)", + "xpack.rollupJobs.createAction.errorTitle": "创建汇总/打包作业时出错", + "xpack.rollupJobs.createAction.failedDefaultErrorMessage": "请求失败,显示 {statusCode} 错误。{message}", + "xpack.rollupJobs.createAction.jobIdAlreadyExistsErrorMessage": "ID 为 “{jobConfigId}” 的作业已存在。", + "xpack.rollupJobs.createBreadcrumbTitle": "创建", + "xpack.rollupJobs.createTitle": "创建汇总/打包作业", + "xpack.rollupJobs.deleteAction.errorTitle": "删除汇总/打包作业时出错", + "xpack.rollupJobs.deleteAction.successMultipleNotificationTitle": "已删除 {count} 个汇总/打包作业", + "xpack.rollupJobs.deleteAction.successSingleNotificationTitle": "已删除汇总/打包作业“{jobId}”", + "xpack.rollupJobs.detailPanel.jobActionMenu.buttonLabel": "管理", + "xpack.rollupJobs.detailPanel.loadingLabel": "正在加载汇总/打包作业……", + "xpack.rollupJobs.detailPanel.notFoundLabel": "未找到汇总/打包作业", + "xpack.rollupJobs.editorConfig.dateHistogram.customInterval.helpText": "必须是汇总/打包配置时间间隔的倍数:{interval}", + "xpack.rollupJobs.editorConfig.histogram.interval.helpText": "必须是汇总/打包配置时间间隔的倍数:{interval}", + "xpack.rollupJobs.editRollupIndexPattern.createIndex.defaultButtonDescription": "针对汇总数据执行有限聚合", + "xpack.rollupJobs.editRollupIndexPattern.createIndex.defaultButtonText": "汇总/打包索引模式", + "xpack.rollupJobs.editRollupIndexPattern.createIndex.defaultTypeName": "汇总/打包索引模式", + "xpack.rollupJobs.editRollupIndexPattern.createIndex.indexLabel": "汇总/打包", + "xpack.rollupJobs.editRollupIndexPattern.createIndex.noMatchError": "汇总/打包索引模式错误:必须匹配一个汇总/打包索引", + "xpack.rollupJobs.editRollupIndexPattern.createIndex.tooManyMatchesError": "汇总/打包索引模式错误:只能匹配一个汇总/打包索引", + "xpack.rollupJobs.editRollupIndexPattern.createIndex.uncaughtError": "汇总索引模式错误:{error}", + "xpack.rollupJobs.featureCatalogueDescription": "汇总历史数据并将其存储在较小的索引中以供将来分析。", + "xpack.rollupJobs.indexMgmtBadge.rollupLabel": "汇总/打包", + "xpack.rollupJobs.indexMgmtToggle.toggleLabel": "包括汇总索引", + "xpack.rollupJobs.jobActionMenu.buttonLabel": "管理 {jobCount, plural, one { 个作业} other { 个作业}}", + "xpack.rollupJobs.jobActionMenu.cloneJobLabel": "克隆作业", + "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.cancelButtonText": "取消", + "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.confirmButtonText": "删除", + "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.deleteSingleJobDescription": "已启动此作业。", + "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.deleteSingleJobTitle": "是否删除汇总/打包作业 “{id}”?", + "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.multipleDeletionDescription": "您即将删除{isSingleSelection, plural, one {此作业} other {这些作业}}", + "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.multipleDeletionTitle": "是否删除 {count} 个汇总/打包作业?", + "xpack.rollupJobs.jobActionMenu.deleteJob.confirmModal.startedMessage": "已启动", + "xpack.rollupJobs.jobActionMenu.deleteJobLabel": "删除 {isSingleSelection, plural, one { 个作业} other { 个作业}}", + "xpack.rollupJobs.jobActionMenu.jobActionMenuButtonAriaLabel": "作业选项", + "xpack.rollupJobs.jobActionMenu.panelTitle": "作业选项", + "xpack.rollupJobs.jobActionMenu.startJobLabel": "启动 {isSingleSelection, plural, one { 个作业} other { 个作业}}", + "xpack.rollupJobs.jobActionMenu.stopJobLabel": "停止 {isSingleSelection, plural, one { 个作业} other { 个作业}}", + "xpack.rollupJobs.jobActionMenu.updatingText": "正在更新", + "xpack.rollupJobs.jobDetails.tabHistogram.intervalLabel": "直方图间隔", + "xpack.rollupJobs.jobDetails.tabHistogram.nameColumnLabel": "字段", + "xpack.rollupJobs.jobDetails.tabMetrics.nameColumnLabel": "字段", + "xpack.rollupJobs.jobDetails.tabMetrics.typesColumnLabel": "类型", + "xpack.rollupJobs.jobDetails.tabRequest.descriptionText": "此 Elasticsearch 请求将创建此汇总/打包作业。", + "xpack.rollupJobs.jobDetails.tabSummary.itemCronLabel": "Cron", + "xpack.rollupJobs.jobDetails.tabSummary.itemCronTip": "汇总/打包数据的频率", + "xpack.rollupJobs.jobDetails.tabSummary.itemDelay.none": "无", + "xpack.rollupJobs.jobDetails.tabSummary.itemDelayLabel": "延迟", + "xpack.rollupJobs.jobDetails.tabSummary.itemDocumentsProcessedLabel": "已处理的文档", + "xpack.rollupJobs.jobDetails.tabSummary.itemIndexPatternLabel": "索引模式", + "xpack.rollupJobs.jobDetails.tabSummary.itemIntervalLabel": "时间间隔", + "xpack.rollupJobs.jobDetails.tabSummary.itemIntervalTip": "汇总/打包数据的时段间隔", + "xpack.rollupJobs.jobDetails.tabSummary.itemPagesProcessedLabel": "已处理的页面", + "xpack.rollupJobs.jobDetails.tabSummary.itemRollupIndexLabel": "汇总/打包索引", + "xpack.rollupJobs.jobDetails.tabSummary.itemRollupsIndexedLabel": "已编制索引的汇总/打包", + "xpack.rollupJobs.jobDetails.tabSummary.itemTimeFieldLabel": "时间字段", + "xpack.rollupJobs.jobDetails.tabSummary.itemTimezoneLabel": "时区", + "xpack.rollupJobs.jobDetails.tabSummary.itemTriggerCountLabel": "触发计数", + "xpack.rollupJobs.jobDetails.tabSummary.sectionDateHistogramLabel": "Date histogram", + "xpack.rollupJobs.jobDetails.tabSummary.sectionLogisticsLabel": "运筹", + "xpack.rollupJobs.jobDetails.tabSummary.sectionStatsTitle": "统计", + "xpack.rollupJobs.jobList.createButtonLabel": "创建汇总/打包作业", + "xpack.rollupJobs.jobList.emptyPrompt.createButtonLabel": "创建汇总/打包作业", + "xpack.rollupJobs.jobList.emptyPromptDescription": "汇总/打包作业可汇总历史数据并将其存储在较小的索引中以供将来分析。", + "xpack.rollupJobs.jobList.emptyPromptTitle": "创建您的首个汇总/打包作业", + "xpack.rollupJobs.jobList.loadingErrorTitle": "加载汇总/打包作业时出错", + "xpack.rollupJobs.jobList.loadingTitle": "正在加载汇总/打包作业……", + "xpack.rollupJobs.jobList.noPermissionText": "您没有权限查看或添加汇总/打包作业。", + "xpack.rollupJobs.jobList.noPermissionTitle": "权限错误", + "xpack.rollupJobs.jobListTitle": "汇总/打包作业", + "xpack.rollupJobs.jobStatus.abortingLabel": "正在中止", + "xpack.rollupJobs.jobStatus.indexingLabel": "索引", + "xpack.rollupJobs.jobStatus.startedLabel": "已开始", + "xpack.rollupJobs.jobStatus.stoppedLabel": "已停止", + "xpack.rollupJobs.jobStatus.stoppingLabel": "正在停止", + "xpack.rollupJobs.jobStatus.unknownLabel": "未知", + "xpack.rollupJobs.jobTable.headers.delayHeader": "延迟", + "xpack.rollupJobs.jobTable.headers.groupsHeader": "组", + "xpack.rollupJobs.jobTable.headers.indexPatternHeader": "索引模式", + "xpack.rollupJobs.jobTable.headers.intervalHeader": "时间间隔", + "xpack.rollupJobs.jobTable.headers.metricsHeader": "指标", + "xpack.rollupJobs.jobTable.headers.nameHeader": "ID", + "xpack.rollupJobs.jobTable.headers.rollupIndexHeader": "汇总/打包索引", + "xpack.rollupJobs.jobTable.headers.statusHeader": "状态", + "xpack.rollupJobs.jobTable.noJobsMatchSearchMessage": "没有汇总作业匹配您的搜索", + "xpack.rollupJobs.jobTable.searchInputPlaceholder": "搜索", + "xpack.rollupJobs.listBreadcrumbTitle": "汇总/打包作业", + "xpack.rollupJobs.loadAction.errorTitle": "加载汇总/打包作业时出错", + "xpack.rollupJobs.refreshAction.errorTitle": "刷新汇总/打包作业时出错", + "xpack.rollupJobs.rollupIndexPatternsDescription": "启用用于捕获汇总/打包索引的索引模式的创建,\n 汇总/打包索引反过来基于汇总/打包数据启用可视化。刷新\n 页面以应用更改。", + "xpack.rollupJobs.rollupIndexPatternsTitle": "启用汇总索引模式", + "xpack.rollupJobs.startJobsAction.errorTitle": "启动汇总/打包作业时出错", + "xpack.rollupJobs.stopJobsAction.errorTitle": "停止汇总/打包作业时出错", + "xpack.searchProfiler.aggregationProfileTabTitle": "聚合配置文件", + "xpack.searchProfiler.basicLicenseTitle": "基础级", + "xpack.searchProfiler.errorToastTitle": "JSON 解析错误", + "xpack.searchProfiler.formIndexLabel": "索引", + "xpack.searchProfiler.formProfileButtonLabel": "配置文件", + "xpack.searchProfiler.goldLicenseTitle": "黄金级", + "xpack.searchProfiler.highlightDetails.descriptionTitle": "描述", + "xpack.searchProfiler.highlightDetails.selfTimeTitle": "独自时间", + "xpack.searchProfiler.highlightDetails.selfTimeTooltip": "此查询组件单独花费的时间(不包括子项)", + "xpack.searchProfiler.highlightDetails.timingBreakdownTitle": "计时分解", + "xpack.searchProfiler.highlightDetails.totalTimeTitle": "总时间", + "xpack.searchProfiler.highlightDetails.totalTimeTooltip": "此查询组件花费的总时间(包括子项)", + "xpack.searchProfiler.highlightDetails.typeTitle": "类型", + "xpack.searchProfiler.licenseErrorMessageDescription": "分析器可视化需要有效的许可({licenseTypeList}或{platinumLicenseType},但在您的集群中未找到任何许可。", + "xpack.searchProfiler.licenseHasExpiredMessage": "Search Profiler 不可用 - 许可已过期。", + "xpack.searchProfiler.pageDisplayName": "Search Profiler", + "xpack.searchProfiler.platinumLicenseTitle": "白金级", + "xpack.searchProfiler.profileTree.cumulativeTimeTitle": "累计时间:", + "xpack.searchProfiler.profileTree.cumulativeTimeTooltip": "索引中所有分片的累计时间。注意:这不是时钟时间,因为分片可以并行执行。", + "xpack.searchProfiler.profileTree.header.selfTimeTitle": "独自时间", + "xpack.searchProfiler.profileTree.header.totalTimeTitle": "总时间", + "xpack.searchProfiler.profileTree.header.typeTitle": "类型和描述", + "xpack.searchProfiler.profileTree.indexTitle": "索引:", + "xpack.searchProfiler.queryProfileTabTitle": "查询配置文件", + "xpack.searchProfiler.registerLicenseDescription": "请{registerLicenseLink}以继续使用 Search Profiler", + "xpack.searchProfiler.registerLicenseLinkLabel": "注册许可", + "xpack.searchProfiler.registryProviderDescription": "快速检查任何 Elasticsearch 查询的性能。", + "xpack.searchProfiler.registryProviderTitle": "Search Profiler", + "xpack.searchProfiler.trialLicenseTitle": "试用", + "xpack.searchProfiler.unavailableLicenseInformationMessage": "Search Profiler 不可用 - 许可信息当前不可用。", + "xpack.searchProfiler.upgradeLicenseMessage": "Search Profiler 不可用于当前的{licenseInfo}许可。请升级您的许可。", + "xpack.security.account.breadcrumb": "帐户管理", + "xpack.security.account.changePasswordDescription": "为您的帐户更改密码。", + "xpack.security.account.changePasswordForm.cancelButtonLabel": "重置", + "xpack.security.account.changePasswordForm.confirmPasswordLabel": "确认新密码", + "xpack.security.account.changePasswordForm.currentPasswordLabel": "当前密码", + "xpack.security.account.changePasswordForm.invalidPassword": "当前密码不正确。", + "xpack.security.account.changePasswordForm.newPasswordLabel": "新密码", + "xpack.security.account.changePasswordForm.passwordRequirements": "至少使用 6 个字符。", + "xpack.security.account.changePasswordForm.saveChangesButtonLabel": "更改密码", + "xpack.security.account.changePasswordNotSupportedText": "不能更改此帐户的密码。", + "xpack.security.account.changePasswordSuccess": "您的密码已更改。", + "xpack.security.account.changePasswordTitle": "密码", + "xpack.security.account.currentPasswordRequired": "当前密码必填。", + "xpack.security.account.noEmailMessage": "没有电子邮件地址", + "xpack.security.account.passwordLengthDescription": "密码过短。", + "xpack.security.account.passwordsDoNotMatch": "密码不匹配。", + "xpack.security.account.usernameGroupDescription": "不能更改此信息。", + "xpack.security.account.usernameGroupTitle": "用户名和电子邮件", + "xpack.security.apiKeys.breadcrumb": "API 密钥", + "xpack.security.loggedOut.login": "登录", + "xpack.security.loggedOut.title": "已成功退出", + "xpack.security.login.basicLoginForm.invalidUsernameOrPasswordErrorMessage": "用户名或密码无效。请重试。", + "xpack.security.login.basicLoginForm.logInButtonLabel": "登录", + "xpack.security.login.basicLoginForm.passwordFormRowLabel": "密码", + "xpack.security.login.basicLoginForm.unknownErrorMessage": "糟糕!错误。重试。", + "xpack.security.login.basicLoginForm.usernameFormRowLabel": "用户名", + "xpack.security.login.loggedOutDescription": "您已注销 Kibana。", + "xpack.security.login.sessionExpiredDescription": "您的会话已超时。请重新登录。", + "xpack.security.loginPage.esUnavailableMessage": "请参阅 Kibana 日志了解详情,然后尝试重新加载页面。", + "xpack.security.loginPage.esUnavailableTitle": "无法连接到 Elasticsearch 集群", + "xpack.security.loginPage.requiresSecureConnectionMessage": "请联系您的管理员。", + "xpack.security.loginPage.requiresSecureConnectionTitle": "登录需要安全连接", + "xpack.security.loginPage.unknownLayoutMessage": "请参阅 Kibana 日志了解详情,然后刷新以重试。", + "xpack.security.loginPage.unknownLayoutTitle": "登录窗体布局不支持。", + "xpack.security.loginPage.welcomeDescription": "您了解 Elastic Stack 的窗口", + "xpack.security.loginPage.welcomeTitle": "欢迎使用 Kibana", + "xpack.security.loginPage.xpackUnavailableMessage": "要使用此 Kibana 发行版中全部免费功能,请将 Elasticsearch 更新为默认发行版。", + "xpack.security.loginPage.xpackUnavailableTitle": "当前无法连接到为 Kibana 配置的 Elasticsearch 集群。", + "xpack.security.management.apiKeys.deniedPermissionTitle": "您需要管理 API 密钥的权限", + "xpack.security.management.apiKeys.invalidateApiKey.confirmModal.cancelButtonLabel": "取消", + "xpack.security.management.apiKeys.invalidateApiKey.confirmModal.confirmButtonLabel": "作废 {count, plural, one {API 密钥} other {API 密钥}}", + "xpack.security.management.apiKeys.invalidateApiKey.confirmModal.invalidateMultipleListDescription": "您即将作废以下 API 密钥:", + "xpack.security.management.apiKeys.invalidateApiKey.confirmModal.invalidateMultipleTitle": "作废 {count} API 密钥?", + "xpack.security.management.apiKeys.invalidateApiKey.confirmModal.invalidateSingleTitle": "作废 API 密钥“{name}”?", + "xpack.security.management.apiKeys.invalidateApiKey.errorMultipleNotificationTitle": "删除 {count} 个 api 密钥时出错", + "xpack.security.management.apiKeys.invalidateApiKey.errorSingleNotificationTitle": "删除 API 密钥“{name}”时出错", + "xpack.security.management.apiKeys.invalidateApiKey.successMultipleNotificationTitle": "已作废 {count} 个 API 密钥", + "xpack.security.management.apiKeys.invalidateApiKey.successSingleNotificationTitle": "已作废 API 密钥“{name}”", + "xpack.security.management.apiKeys.noPermissionToManageRolesDescription": "请联系您的管理员。", + "xpack.security.management.apiKeys.table.actionDeleteAriaLabel": "作废“{name}”", + "xpack.security.management.apiKeys.table.actionDeleteTooltip": "作废", + "xpack.security.management.apiKeys.table.actionsColumnName": "操作", + "xpack.security.management.apiKeys.table.adminText": "您是 API 密钥管理员。", + "xpack.security.management.apiKeys.table.apiKeysAllDescription": "查看并作废 API 密钥。API 密钥代表用户发送请求。", + "xpack.security.management.apiKeys.table.apiKeysDisabledErrorDescription": "请联系您的系统管理员并参阅{link}以启用 API 密钥。", + "xpack.security.management.apiKeys.table.apiKeysDisabledErrorLinkText": "文档", + "xpack.security.management.apiKeys.table.apiKeysDisabledErrorTitle": "Elasticsearch 中未启用 API 密钥", + "xpack.security.management.apiKeys.table.apiKeysOwnDescription": "查看并作废您的 API 密钥。API 密钥代表您发送请求。", + "xpack.security.management.apiKeys.table.apiKeysTableLoadingMessage": "正在加载 API 密钥……", + "xpack.security.management.apiKeys.table.apiKeysTitle": "API 密钥", + "xpack.security.management.apiKeys.table.creationDateColumnName": "创建时间", + "xpack.security.management.apiKeys.table.emptyPromptAdminTitle": "无 API 密钥", + "xpack.security.management.apiKeys.table.emptyPromptConsoleButtonMessage": "前往 Console", + "xpack.security.management.apiKeys.table.emptyPromptDescription": "您可以从 Console 创建 {link}。", + "xpack.security.management.apiKeys.table.emptyPromptDocsLinkMessage": "API 密钥", + "xpack.security.management.apiKeys.table.emptyPromptNonAdminTitle": "您未有任何 API 密钥", + "xpack.security.management.apiKeys.table.expirationDateColumnName": "过期", + "xpack.security.management.apiKeys.table.expirationDateNeverMessage": "永远不", + "xpack.security.management.apiKeys.table.invalidateApiKeyButton": "作废 {count, plural, one {API 密钥} other {API 密钥}}", + "xpack.security.management.apiKeys.table.loadingApiKeysDescription": "正在加载 API 密钥……", + "xpack.security.management.apiKeys.table.loadingApiKeysErrorTitle": "加载 API 密钥时出错", + "xpack.security.management.apiKeys.table.nameColumnName": "名称", + "xpack.security.management.apiKeys.table.realmColumnName": "Realm", + "xpack.security.management.apiKeys.table.realmFilterLabel": "Realm", + "xpack.security.management.apiKeys.table.reloadApiKeysButton": "重新加载", + "xpack.security.management.apiKeys.table.statusColumnName": "状态", + "xpack.security.management.apiKeys.table.userFilterLabel": "用户", + "xpack.security.management.apiKeys.table.userNameColumnName": "用户", + "xpack.security.management.apiKeysTitle": "API 密钥", + "xpack.security.management.changePasswordForm.cancelButtonLabel": "取消", + "xpack.security.management.changePasswordForm.changePasswordLinkLabel": "更改密码", + "xpack.security.management.changePasswordForm.confirmPasswordLabel": "确认密码", + "xpack.security.management.changePasswordForm.currentPasswordLabel": "当前密码", + "xpack.security.management.changePasswordForm.incorrectPasswordDescription": "您输入的当前密码不正确。", + "xpack.security.management.changePasswordForm.newPasswordLabel": "新密码", + "xpack.security.management.changePasswordForm.passwordDontMatchDescription": "密码不匹配", + "xpack.security.management.changePasswordForm.passwordLabel": "密码", + "xpack.security.management.changePasswordForm.passwordLengthDescription": "密码长度必须至少为 6 个字符", + "xpack.security.management.changePasswordForm.saveChangesButtonLabel": "保存更改", + "xpack.security.management.changePasswordForm.updateAndRestartKibanaDescription": "更改 Kibana 用户的密码后,必须更新 kibana.yml 文件并重新启动 Kibana", + "xpack.security.management.editRole.cancelButtonLabel": "取消", + "xpack.security.management.editRole.changeAllPrivilegesLink": "(全部更改)", + "xpack.security.management.editRole.collapsiblePanel.hideLinkText": "隐藏", + "xpack.security.management.editRole.collapsiblePanel.showLinkText": "显示", + "xpack.security.management.editRole.createRoleText": "创建角色", + "xpack.security.management.editRole.createRoleTitle": "创建角色", + "xpack.security.management.editRole.deleteRoleButton.cancelButtonLabel": "不,不删除", + "xpack.security.management.editRole.deleteRoleButton.confirmButtonLabel": "是的,删除角色", + "xpack.security.management.editRole.deleteRoleButton.deleteRoleButtonLabel": "删除角色", + "xpack.security.management.editRole.deleteRoleButton.deleteRoleTitle": "删除角色", + "xpack.security.management.editRole.deleteRoleButton.deletingRoleConfirmationText": "是否确定要删除此角色?", + "xpack.security.management.editRole.deleteRoleButton.deletingRoleWarningText": "此操作无法撤消!", + "xpack.security.management.editRole.editRoleTitle": "编辑角色", + "xpack.security.management.editRole.elasticSearchPrivileges.addIndexPrivilegesButtonLabel": "添加索引权限", + "xpack.security.management.editRole.elasticSearchPrivileges.addUserTitle": "添加用户……", + "xpack.security.management.editRole.elasticSearchPrivileges.clusterPrivilegesTitle": "集群权限", + "xpack.security.management.editRole.elasticSearchPrivileges.controlAccessToClusterDataDescription": "控制对集群中数据的访问权限。", + "xpack.security.management.editRole.elasticSearchPrivileges.howToBeSubmittedOnBehalfOfOtherUsersDescription": "允许代表其他用户提交请求。", + "xpack.security.management.editRole.elasticSearchPrivileges.indexPrivilegesTitle": "索引权限", + "xpack.security.management.editRole.elasticSearchPrivileges.learnMoreLinkText": "了解详情", + "xpack.security.management.editRole.elasticSearchPrivileges.manageRoleActionsDescription": "管理此角色可以对您的集群执行的操作。", + "xpack.security.management.editRole.elasticSearchPrivileges.runAsPrivilegesTitle": "运行身份权限", + "xpack.security.management.editRole.featureTable.enabledRoleFeaturesEnabledColumnTitle": "权限", + "xpack.security.management.editRole.featureTable.enabledRoleFeaturesFeatureColumnTitle": "功能", + "xpack.security.management.editRole.featureTable.excludedFromBasePrivilegsTooltip": "使用“定制”权限来授予权限。{featureName} 不属于基础权限。", + "xpack.security.management.editRole.indexPrivilegeForm.deleteSpacePrivilegeAriaLabel": "删除索引权限", + "xpack.security.management.editRole.indexPrivilegeForm.grantedDocumentsQueryFormRowLabel": "已授权文档查询", + "xpack.security.management.editRole.indexPrivilegeForm.grantReadPrivilegesLabel": "授予特定文档的读取权限", + "xpack.security.management.editRole.indexPrivilegeForm.indicesFormRowLabel": "索引", + "xpack.security.management.editRole.indexPrivilegeForm.privilegesFormRowLabel": "权限", + "xpack.security.management.editRole.modifyingReversedRolesDescription": "保留角色为内置角色,不能删除或修改。", + "xpack.security.management.editRole.returnToRoleListButtonLabel": "返回角色列表", + "xpack.security.management.editRole.reversedRoleBadge.reservedRolesCanNotBeModifiedTooltip": "保留角色为内置角色,不能删除或修改。", + "xpack.security.management.editRole.roleNameFormRowHelpText": "创建角色名称后无法更改。", + "xpack.security.management.editRole.roleNameFormRowTitle": "角色名称", + "xpack.security.management.editRole.roleSuccessfullyDeletedNotificationMessage": "删除角色", + "xpack.security.management.editRole.roleSuccessfullySavedNotificationMessage": "保存的角色", + "xpack.security.management.editRole.setPrivilegesToKibanaDescription": "设置 Elasticsearch 数据的权限并控制对 Kibana 的访问权限。", + "xpack.security.management.editRole.setPrivilegesToKibanaSpacesDescription": "设置 Elasticsearch 数据的权限并控制对 Kibana 空间的访问权限。", + "xpack.security.management.editRole.simplePrivilegeForm.allPrivilegeDropdown": "全部", + "xpack.security.management.editRole.simplePrivilegeForm.allPrivilegeDropdownDescription": "授予对 Kibana 全部功能的完全权限", + "xpack.security.management.editRole.simplePrivilegeForm.allPrivilegeInput": "全部", + "xpack.security.management.editRole.simplePrivilegeForm.customPrivilegeDropdown": "定制", + "xpack.security.management.editRole.simplePrivilegeForm.customPrivilegeDropdownDescription": "定制对 Kibana 的访问权限", + "xpack.security.management.editRole.simplePrivilegeForm.customPrivilegeInput": "定制", + "xpack.security.management.editRole.simplePrivilegeForm.kibanaPrivilegesTitle": "Kibana 权限", + "xpack.security.management.editRole.simplePrivilegeForm.noPrivilegeDropdown": "无", + "xpack.security.management.editRole.simplePrivilegeForm.noPrivilegeDropdownDescription": "没有对 Kibana 的访问权限", + "xpack.security.management.editRole.simplePrivilegeForm.noPrivilegeInput": "无", + "xpack.security.management.editRole.simplePrivilegeForm.readPrivilegeDropdown": "读取", + "xpack.security.management.editRole.simplePrivilegeForm.readPrivilegeDropdownDescription": "授予对 Kibana 全部功能的只读权限。", + "xpack.security.management.editRole.simplePrivilegeForm.readPrivilegeInput": "读取", + "xpack.security.management.editRole.simplePrivilegeForm.specifyPrivilegeForRoleDescription": "为此角色指定 Kibana 权限。", + "xpack.security.management.editRole.simplePrivilegeForm.unsupportedSpacePrivilegesWarning": "此角色包含工作区的权限定义,但在 Kibana 中未启用工作区。保存此角色将会移除这些权限。", + "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.effectivePrivilegeMessage": "已通过 {source} 授予。", + "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.globalBasePrivilegeSource": "全局基本权限", + "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.globalFeaturePrivilegeSource": "全局功能权限", + "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.privilegeSupercededMessage": "{supersededPrivilege} 的原始权限已为 {actualPrivilegeSource} 所覆盖", + "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.spaceBasePrivilegeSource": "工作区基本权限", + "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.spaceFeaturePrivilegeSource": "全局功能权限", + "xpack.security.management.editRole.spaceAwarePrivilegeDisplay.unknownPrivilegeSource": "**未知**", + "xpack.security.management.editRole.spaceAwarePrivilegeForm.ensureAccountHasAllPrivilegesGrantedDescription": "请确保您的帐户具有 {kibanaUser} 角色授予的所有权限,然后重试。", + "xpack.security.management.editRole.spaceAwarePrivilegeForm.globalSpacesName": "* 全局(所有工作区)", + "xpack.security.management.editRole.spaceAwarePrivilegeForm.howToViewAllAvailableSpacesDescription": "您无权查看所有可用工作区。", + "xpack.security.management.editRole.spaceAwarePrivilegeForm.insufficientPrivilegesDescription": "权限不足", + "xpack.security.management.editRole.spaceAwarePrivilegeForm.kibanaUserTitle": "kibana_user", + "xpack.security.management.editRole.spacePrivilegeForm.allPrivilegeDetails": "授予对选定工作区所有功能的完全访问权限。", + "xpack.security.management.editRole.spacePrivilegeForm.allPrivilegeDisplay": "全部", + "xpack.security.management.editRole.spacePrivilegeForm.allPrivilegeDropdownDisplay": "全部", + "xpack.security.management.editRole.spacePrivilegeForm.customizeFeaturePrivilegeDescription": "按功能提高权限级别。某些功能可能被工作区隐藏或受全局工作区权限影响。", + "xpack.security.management.editRole.spacePrivilegeForm.customizeFeaturePrivileges": "按功能定制", + "xpack.security.management.editRole.spacePrivilegeForm.customPrivilegeDetails": "在选定工作区中按功能定制访问权限。", + "xpack.security.management.editRole.spacePrivilegeForm.customPrivilegeDisplay": "定制", + "xpack.security.management.editRole.spacePrivilegeForm.customPrivilegeDropdownDisplay": "定制", + "xpack.security.management.editRole.spacePrivilegeForm.featurePrivilegeSummaryDescription": "某些功能可能被工作区隐藏或受全局工作区权限影响。", + "xpack.security.management.editRole.spacePrivilegeForm.globalPrivilegeNotice": "这些权限将应用到所有当前和未来工作区。", + "xpack.security.management.editRole.spacePrivilegeForm.globalPrivilegeWarning": "创建全局权限可能会影响您的其他工作区权限。", + "xpack.security.management.editRole.spacePrivilegeForm.modalTitle": "工作区权限", + "xpack.security.management.editRole.spacePrivilegeForm.privilegeSelectorFormLabel": "权限", + "xpack.security.management.editRole.spacePrivilegeForm.readPrivilegeDetails": "授予对选定工作区所有功能的只读访问权限。", + "xpack.security.management.editRole.spacePrivilegeForm.readPrivilegeDisplay": "读取", + "xpack.security.management.editRole.spacePrivilegeForm.readPrivilegeDropdownDisplay": "读取", + "xpack.security.management.editRole.spacePrivilegeForm.spaceSelectorFormLabel": "工作区", + "xpack.security.management.editRole.spacePrivilegeForm.summaryOfFeaturePrivileges": "功能权限的摘要", + "xpack.security.management.editRole.spacePrivilegeMatrix.basePrivilegeText": "基本权限", + "xpack.security.management.editRole.spacePrivilegeMatrix.basePrivilegeTooltip": "所有功能的基本权限将自动授予。", + "xpack.security.management.editRole.spacePrivilegeMatrix.closeButton": "关闭", + "xpack.security.management.editRole.spacePrivilegeMatrix.featureColumnTitle": "功能", + "xpack.security.management.editRole.spacePrivilegeMatrix.globalSpaceName": "全局", + "xpack.security.management.editRole.spacePrivilegeMatrix.modalTitle": "权限摘要", + "xpack.security.management.editRole.spacePrivilegeMatrix.showAllSpacesLink": "(所有工作区)", + "xpack.security.management.editRole.spacePrivilegeMatrix.showNMoreSpacesLink": "另外 {count} 个", + "xpack.security.management.editRole.spacePrivilegeMatrix.showSummaryText": "查看权限摘要", + "xpack.security.management.editRole.spacePrivilegeSection.addSpacePrivilegeButton": "添加工作区权限", + "xpack.security.management.editRole.spacePrivilegeSection.noAccessToKibanaTitle": "此角色未授予对 Kibana 的访问权限", + "xpack.security.management.editRole.spacePrivilegeTable.deletePrivilegesLabel": "删除以下工作区的权限:{spaceNames}。", + "xpack.security.management.editRole.spacePrivilegeTable.editPrivilegesLabel": "编辑以下工作区的权限:{spaceNames}。", + "xpack.security.management.editRole.spacePrivilegeTable.showAllSpacesLink": "显示工作区", + "xpack.security.management.editRole.spacePrivilegeTable.showLessSpacesLink": "显示更少", + "xpack.security.management.editRole.spacePrivilegeTable.showNMoreSpacesLink": "另外 {count} 个", + "xpack.security.management.editRole.spaceSelectorLabel": "工作区", + "xpack.security.management.editRole.spacesPopoverList.findSpacePlaceholder": "查找工作区", + "xpack.security.management.editRole.spacesPopoverList.noSpacesFoundTitle": " 未找到工作区 ", + "xpack.security.management.editRole.spacesPopoverList.popoverTitle": "工作区", + "xpack.security.management.editRole.transformErrorSectionDescription": "此角色定义无效,无法通过此屏幕进行编辑。", + "xpack.security.management.editRole.transformErrorSectionTitle": "角色格式不正确", + "xpack.security.management.editRole.updateRoleText": "更新角色", + "xpack.security.management.editRole.validateRole.indicesTypeErrorMessage": "{elasticIndices} 应为数组", + "xpack.security.management.editRole.validateRole.nameAllowedCharactersWarningMessage": "名称必须以字母或下划线开头,且只能包含字母、下划线和数字。", + "xpack.security.management.editRole.validateRole.nameLengthWarningMessage": "名称不能超过 1024 个字符", + "xpack.security.management.editRole.validateRole.onePrivilegeRequiredWarningMessage": "至少需要一个权限", + "xpack.security.management.editRole.validateRole.oneSpaceRequiredWarningMessage": "至少需要一个工作区", + "xpack.security.management.editRole.validateRole.privilegeRequiredWarningMessage": "“权限”必填", + "xpack.security.management.editRole.validateRole.provideRoleNameWarningMessage": "请提供角色名称", + "xpack.security.management.editRole.viewingRoleTitle": "查看角色", + "xpack.security.management.editRoles.indexPrivilegeForm.deniedFieldsFormRowLabel": "已拒绝字段", + "xpack.security.management.editRoles.indexPrivilegeForm.grantedFieldsFormRowHelpText": "如果未授权任何字段,则分配到此角色的用户将无法查看此索引的任何数据。", + "xpack.security.management.editRoles.indexPrivilegeForm.grantedFieldsFormRowLabel": "已授权字段", + "xpack.security.management.editRoles.indexPrivilegeForm.grantFieldPrivilegesLabel": "授予对特定字段的访问权限", + "xpack.security.management.editRolespacePrivilegeForm.cancelButton": "取消", + "xpack.security.management.editRolespacePrivilegeForm.createGlobalPrivilegeButton": "创建全局权限", + "xpack.security.management.editRolespacePrivilegeForm.createPrivilegeButton": "创建工作区权限", + "xpack.security.management.editRolespacePrivilegeForm.updateGlobalPrivilegeButton": "更新全局权限", + "xpack.security.management.editRolespacePrivilegeForm.updatePrivilegeButton": "更新工作区权限", + "xpack.security.management.passwordForm.confirmPasswordLabel": "确认密码", + "xpack.security.management.passwordForm.passwordDontMatchDescription": "密码不匹配", + "xpack.security.management.passwordForm.passwordLabel": "密码", + "xpack.security.management.passwordForm.passwordLengthDescription": "密码长度必须至少为 6 个字符", + "xpack.security.management.roles.actionsColumnName": "鎿嶄綔", + "xpack.security.management.roles.cloneRoleActionName": "克隆 {roleName}", + "xpack.security.management.roles.confirmDelete.cancelButtonLabel": "取消", + "xpack.security.management.roles.confirmDelete.deleteButtonLabel": "删除", + "xpack.security.management.roles.confirmDelete.removingRolesDescription": "您即将删除以下角色:", + "xpack.security.management.roles.confirmDelete.roleDeletingErrorNotificationMessage": "删除角色 {roleName} 时出错", + "xpack.security.management.roles.confirmDelete.roleSuccessfullyDeletedNotificationMessage": "删除角色 {roleName}", + "xpack.security.management.roles.createRoleButtonLabel": "创建角色", + "xpack.security.management.roles.deleteRoleTitle": "删除角色{value, plural, one {{roleName}} other {}}", + "xpack.security.management.roles.deleteSelectedRolesButtonLabel": "删除 {numSelected} 个角色{numSelected, plural, one {} other {}}", + "xpack.security.management.roles.deletingRolesWarningMessage": "此操作无法撤消。", + "xpack.security.management.roles.deniedPermissionTitle": "您需要用于管理角色的权限", + "xpack.security.management.roles.disabledTooltip": " (已禁用)", + "xpack.security.management.roles.editRoleActionName": "编辑 {roleName}", + "xpack.security.management.roles.fetchingRolesErrorMessage": "获取用户时出错:{message}", + "xpack.security.management.roles.nameColumnName": "角色", + "xpack.security.management.roles.noPermissionToManageRolesDescription": "请联系您的管理员。", + "xpack.security.management.roles.reservedColumnDescription": "保留角色为内置角色,不能编辑或移除。", + "xpack.security.management.roles.reservedColumnName": "保留", + "xpack.security.management.roles.reservedRoleIconLabel": "保留角色", + "xpack.security.management.roles.roleNotFound": "未找到任何“{roleName}”。", + "xpack.security.management.roles.roleTitle": "角色", + "xpack.security.management.roles.subtitle": "将角色应用到用户组并管理整个堆栈的权限。", + "xpack.security.management.rolesTitle": "角色", + "xpack.security.management.securityTitle": "安全性", + "xpack.security.management.users.confirmDelete.cancelButtonLabel": "取消", + "xpack.security.management.users.confirmDelete.confirmButtonLabel": "删除", + "xpack.security.management.users.confirmDelete.deleteMultipleUsersTitle": "删除 {userLength} 用户", + "xpack.security.management.users.confirmDelete.deleteOneUserTitle": "删除用户 {userLength}", + "xpack.security.management.users.confirmDelete.removingUsersDescription": "您即将删除以下用户:", + "xpack.security.management.users.confirmDelete.removingUsersWarningMessage": "此操作无法撤消。", + "xpack.security.management.users.confirmDelete.userDeletingErrorNotificationMessage": "删除用户 {username} 时出错", + "xpack.security.management.users.confirmDelete.userSuccessfullyDeletedNotificationMessage": "已删除用户 {username}", + "xpack.security.management.users.createNewUserButtonLabel": "创建用户", + "xpack.security.management.users.deleteUsersButtonLabel": "删除 {numSelected} 个用户{numSelected, plural, one { } other { 个用户}}", + "xpack.security.management.users.deniedPermissionTitle": "您需要用于管理用户的权限", + "xpack.security.management.users.editUser.addRolesPlaceholder": "添加角色", + "xpack.security.management.users.editUser.cancelButtonLabel": "取消", + "xpack.security.management.users.editUser.changePasswordButtonLabel": "更改密码", + "xpack.security.management.users.editUser.changePasswordExtraStepTitle": "需要额外的步骤", + "xpack.security.management.users.editUser.changePasswordUpdateKibanaTitle": "更改 Kibana 用户的密码后,必须更新 {kibana} 文件并重新启动 Kibana。", + "xpack.security.management.users.editUser.changingUserNameAfterCreationDescription": "用户名一经创建,将无法更改。", + "xpack.security.management.users.editUser.confirmPasswordFormRowLabel": "确认密码", + "xpack.security.management.users.editUser.createUserButtonLabel": "创建用户", + "xpack.security.management.users.editUser.deleteUserButtonLabel": "删除用户", + "xpack.security.management.users.editUser.editUserTitle": "编辑 {userName} 用户", + "xpack.security.management.users.editUser.emailAddressFormRowLabel": "电子邮件地址", + "xpack.security.management.users.editUser.errorLoadingRolesTitle": "加载角色时出错", + "xpack.security.management.users.editUser.errorLoadingUserTitle": "加载用户时出错", + "xpack.security.management.users.editUser.fullNameFormRowLabel": "全名", + "xpack.security.management.users.editUser.modifyingReservedUsersDescription": "保留的用户是内置的,无法删除或修改。只能更改密码。", + "xpack.security.management.users.editUser.newUserTitle": "新建用户", + "xpack.security.management.users.editUser.passwordDoNotMatchErrorMessage": "密码不匹配", + "xpack.security.management.users.editUser.passwordFormRowLabel": "密码", + "xpack.security.management.users.editUser.passwordLengthErrorMessage": "密码长度必须至少为 6 个字符", + "xpack.security.management.users.editUser.requiredUsernameErrorMessage": "“用户名”必填", + "xpack.security.management.users.editUser.returnToUserListButtonLabel": "返回到用户列表", + "xpack.security.management.users.editUser.rolesFormRowLabel": "角色", + "xpack.security.management.users.editUser.savingUserErrorMessage": "保存用户时出错:{message}", + "xpack.security.management.users.editUser.settingPasswordErrorMessage": "设置密码时出错:{message}", + "xpack.security.management.users.editUser.updateUserButtonLabel": "更新用户", + "xpack.security.management.users.editUser.usernameAllowedCharactersErrorMessage": "用户名必须以字母或下划线开头,并只能包含字母、下划线和数字", + "xpack.security.management.users.editUser.usernameFormRowLabel": "用户名", + "xpack.security.management.users.editUser.userSuccessfullySavedNotificationMessage": "已保存用户{message}", + "xpack.security.management.users.editUser.validEmailRequiredErrorMessage": "电子邮件地址无效", + "xpack.security.management.users.emailAddressColumnName": "电子邮件地址", + "xpack.security.management.users.fetchingUsersErrorMessage": "提取用户时出错:{message}", + "xpack.security.management.users.fullNameColumnName": "全名", + "xpack.security.management.users.permissionDeniedToManageUsersDescription": "请联系您的管理员。", + "xpack.security.management.users.reservedColumnDescription": "保留的用户是内置的,无法删除。只能更改密码。", + "xpack.security.management.users.reservedColumnName": "保留", + "xpack.security.management.users.rolesColumnName": "角色", + "xpack.security.management.users.userNameColumnName": "用户名", + "xpack.security.management.users.usersTitle": "用户", + "xpack.security.management.usersTitle": "用户", + "xpack.security.navControlComponent.accountMenuAriaLabel": "帐户菜单", + "xpack.security.navControlComponent.editProfileLinkText": "编辑配置文件", + "xpack.security.navControlComponent.logoutLinkText": "注销", + "xpack.security.overwrittenSession.continueAsUserText": "作为 {username} 继续", + "xpack.security.overwrittenSession.title": "您以前以其他用户身份登录。", + "xpack.security.registerFeature.securitySettingsDescription": "保护您的数据,并轻松管理谁有权限以用户和角色身份访问什么内容。", + "xpack.security.registerFeature.securitySettingsTitle": "安全性设置", + "xpack.security.roles.breadcrumb": "角色", + "xpack.security.roles.createBreadcrumb": "创建", + "xpack.security.users.breadcrumb": "用户", + "xpack.security.users.createBreadcrumb": "创建", + "xpack.server.checkLicense.errorExpiredMessage": "您不能使用 {pluginName},因为您的{licenseType}许可证已过期", + "xpack.server.checkLicense.errorUnavailableMessage": "您不能使用 {pluginName},因为许可证信息当前不可用。", + "xpack.server.checkLicense.errorUnsupportedMessage": "您的{licenseType}许可证不支持 {pluginName}。请升级您的许可证。", + "xpack.siem.add_filter_to_global_search_bar.filterForValueHoverAction": "筛留值", + "xpack.siem.andOrBadge.and": "AND", + "xpack.siem.andOrBadge.or": "OR", + "xpack.siem.anomaliesTable.table.anomaliesDescription": "异常", + "xpack.siem.anomaliesTable.table.anomaliesTooltip": "异常表无法通过 SIEM 全局 KQL 搜索进行筛选。", + "xpack.siem.anomaliesTable.table.showingDescription": "显示", + "xpack.siem.anomaliesTable.table.unit": "{totalCount, plural, =1 {个异常} other {个异常}}", + "xpack.siem.auditd.abortedAuditStartupDescription": "已中止审计启动", + "xpack.siem.auditd.accessErrorDescription": "访问错误", + "xpack.siem.auditd.accessPermissionDescription": "访问权限", + "xpack.siem.auditd.accessResultDescription": "访问结果", + "xpack.siem.auditd.acquiredCredentialsDescription": "已获得凭据 - 至", + "xpack.siem.auditd.adddedGroupAccountUsingDescription": "已添加组帐户 - 使用", + "xpack.siem.auditd.addedUserAccountDescription": "已添加用户帐户", + "xpack.siem.auditd.allocatedMemoryForDescription": "已分配内存 - 为", + "xpack.siem.auditd.asDescription": "作为", + "xpack.siem.auditd.assignedUserRoleToDescription": "已将用户角色分配给", + "xpack.siem.auditd.assignedVmIdDescription": "已分配 vm id", + "xpack.siem.auditd.assignedVMResourceDescription": "已分配 vm 资源", + "xpack.siem.auditd.attemptedLoginDescription": "已尝试登录 - 通过", + "xpack.siem.auditd.attemptedLoginFromUnusalPlaceDescription": "尝试异常位置的登录", + "xpack.siem.auditd.attemptedLoginFromUnusualHourDescription": "尝试异常时段的登录", + "xpack.siem.auditd.auditErrorDescription": "审计错误", + "xpack.siem.auditd.authenticatedToGroupDescription": "已验证到组", + "xpack.siem.auditd.authenticatedUsingDescription": "已验证 - 使用", + "xpack.siem.auditd.bootedSystemDescription": "已启动系统", + "xpack.siem.auditd.boundSocketFromDescription": "绑定套接字 - 来自", + "xpack.siem.auditd.causedMacPolicyErrorDescription": "已导致 mac 策略错误", + "xpack.siem.auditd.changedAuditConfigurationDescription": "已更改审计配置", + "xpack.siem.auditd.changedAuditFeatureDescription": "已更改审计功能", + "xpack.siem.auditd.changedConfigurationWIthDescription": "已更改配置", + "xpack.siem.auditd.ChangedFileAttributesOfDescription": "已更改文件属性 -", + "xpack.siem.auditd.changedFilePermissionOfDescription": "已更改文件权限 -", + "xpack.siem.auditd.changedGroupDescription": "已更改组", + "xpack.siem.auditd.changedGroupPasswordDescription": "已更改组密码", + "xpack.siem.auditd.changedIdentityUsingDescription": "已更改身份 - 使用", + "xpack.siem.auditd.changedLoginIdToDescription": "已将登录 id 更改为", + "xpack.siem.auditd.changedMacConfigurationDescription": "已更改 mac 配置", + "xpack.siem.auditd.changedPasswordWithDescription": "已更改密码 -", + "xpack.siem.auditd.changedRoleUsingDescription": "已更改角色 - 使用", + "xpack.siem.auditd.changedSeLinuxBooleanDescription": "已更改 selinux 布尔值", + "xpack.siem.auditd.changedSelinuxEnforcementDescription": "已 更改 selinux 强制", + "xpack.siem.auditd.changedSystemNameDescription": "已更改系统名称", + "xpack.siem.auditd.changedSystemTimeWithDescription": "已更改系统时间 -", + "xpack.siem.auditd.changedTimeStampOfDescription": "已更改时间戳 -", + "xpack.siem.auditd.changedToRunLevelWithDescription": "已更改到运行级别 -", + "xpack.siem.auditd.changedUserIdDescription": "已更改用户 id", + "xpack.siem.auditd.changeidleOwernshipOfDescription": "已更改文件所有权 -", + "xpack.siem.auditd.checkedFileSystemMetadataOfDescription": "已检查文件系统元数据 -", + "xpack.siem.auditd.checkedIntegrityOfDescription": "已更改完整性 -", + "xpack.siem.auditd.chedckedMetaDataOfDescription": "已更改元数据 -", + "xpack.siem.auditd.connectedUsingDescription": "已连接 - 使用", + "xpack.siem.auditd.crashedProgramDescription": "已崩溃程序", + "xpack.siem.auditd.createdDirectoryDescription": "已创建目录", + "xpack.siem.auditd.createdVmImageDescription": "已创建 vm 映像", + "xpack.siem.auditd.cryptoOfficerLoggedInDescription": "加密员已登录", + "xpack.siem.auditd.cryptoOfficerLoggedOutDescription": "加密员已注销", + "xpack.siem.auditd.deletedDescription": "已删除", + "xpack.siem.auditd.deletedGroupAccountUsingDescription": "已删除组帐户 - 使用", + "xpack.siem.auditd.deletedUserAccountUsingDescription": "已删除用户帐户 - 使用", + "xpack.siem.auditd.deletedVmImageDescription": "已删除 vm 映像", + "xpack.siem.auditd.disposedCredentialsDescription": "已将凭据处置到", + "xpack.siem.auditd.endedFromDescription": "结束自", + "xpack.siem.auditd.errorFromDescription": "错误来自", + "xpack.siem.auditd.executedDescription": "已执行", + "xpack.siem.auditd.executionOfForbiddenProgramDescription": "已禁止程序的执行", + "xpack.siem.auditd.failedLoginTooManyTimesDescription": "由于登录次数过多,登录失败", + "xpack.siem.auditd.inDescription": "传入", + "xpack.siem.auditd.initializedAuditSubsystemDescription": "已初始化审计子系统", + "xpack.siem.auditd.issuedVmControlDescription": "已签发 vm 控制", + "xpack.siem.auditd.killedProcessIdDescription": "已终止进程 id -", + "xpack.siem.auditd.ListeningForConnectionsUsingDescription": "正在侦听连接 - 使用", + "xpack.siem.auditd.loadedFirewallRuleDescription": "已加载防火墙规则", + "xpack.siem.auditd.loadedMacPolicyDescription": "已加载 mac 策略", + "xpack.siem.auditd.loadedSeLinuxPolicyDescription": "已加载 selinux 策略", + "xpack.siem.auditd.loaedKernelModuleOfDescription": "已加载内核模块 -", + "xpack.siem.auditd.lockedAccountDescription": "已锁定帐户", + "xpack.siem.auditd.loggedOutDescription": "已注销", + "xpack.siem.auditd.macPermissionDescription": "mac 权限", + "xpack.siem.auditd.madeDeviceWithDescription": "已制作设备 -", + "xpack.siem.auditd.migratedVmFromDescription": "已迁移 vm - 从", + "xpack.siem.auditd.migratedVmToDescription": "已将 vm 迁移至", + "xpack.siem.auditd.modifiedGroupAccountDescription": "已修改组帐户", + "xpack.siem.auditd.modifiedLevelOfDescription": "已修改级别 -", + "xpack.siem.auditd.modifiedRoleDescription": "已修改角色", + "xpack.siem.auditd.modifiedUserAccountDescription": "已修改用户帐户", + "xpack.siem.auditd.mountedDescription": "已安装", + "xpack.siem.auditd.negotiatedCryptoKeyDescription": "已协商加密密钥", + "xpack.siem.auditd.nonExistentDescription": "至未知进程", + "xpack.siem.auditd.OpenedFileDescription": "已打开文件", + "xpack.siem.auditd.openedTooManySessionsDescription": "已打开过多会话", + "xpack.siem.auditd.overrodeLabelOfDescription": "已覆盖标签 -", + "xpack.siem.auditd.promiscuousModeDescription": "已更改设备上的混杂模式 - 使用", + "xpack.siem.auditd.ranCommandDescription": "已运行命令", + "xpack.siem.auditd.receivedFromDescription": "已接收 - 从", + "xpack.siem.auditd.reconfiguredAuditDescription": "已重新配置审计", + "xpack.siem.auditd.refreshedCredentialsForDescription": "已刷新凭据 -", + "xpack.siem.auditd.relabeledFileSystemDescription": "已重新标记文件系统", + "xpack.siem.auditd.remoteAuditConnectedDescription": "远程审计已连接", + "xpack.siem.auditd.remoteAuditDisconnectedDescription": "远程审计已断开连接", + "xpack.siem.auditd.removedUserRoleFromDescription": "已移除用户角色 - 从", + "xpack.siem.auditd.renamedDescription": "已重命名", + "xpack.siem.auditd.resumedAuditLoggingDescription": "已恢复审计日志记录", + "xpack.siem.auditd.rotatedAuditLogsDescription": "rotated-audit-logs", + "xpack.siem.auditd.scheduledPolicyOFDescription": "已排定策略 -", + "xpack.siem.auditd.sentMessageDescription": "已发送消息", + "xpack.siem.auditd.sentTestDescription": "已发送测试", + "xpack.siem.auditd.sentToDescription": "已发送至", + "xpack.siem.auditd.sessionDescription": "会话", + "xpack.siem.auditd.shutDownAuditDescription": "关闭审计", + "xpack.siem.auditd.shutdownSystemDescription": "关闭系统", + "xpack.siem.auditd.startedAtDescription": "已启动", + "xpack.siem.auditd.startedAuditDescription": "已启动审计", + "xpack.siem.auditd.startedCryptoSessionDescription": "已启动加密会话", + "xpack.siem.auditd.startedServiceDescription": "已启动服务", + "xpack.siem.auditd.stoppedServiceDescription": "已停止服务", + "xpack.siem.auditd.suspiciousProgramDescription": "已使用可疑程序", + "xpack.siem.auditd.symLinkedDescription": "已象征性链接", + "xpack.siem.auditd.testedFileSystemIntegrityDescription": "已测试文件系统完整性", + "xpack.siem.auditd.unknownDescription": "未知", + "xpack.siem.auditd.unloadedKernelModuleOfDescription": "已加载内核模块", + "xpack.siem.auditd.unlockedAccountDescription": "已解锁帐户", + "xpack.siem.auditd.unmountedDescription": "已卸载", + "xpack.siem.auditd.usingDescription": "使用", + "xpack.siem.auditd.violatedAppArmorPolicyFromDescription": "已违反应用防护策略 - 来自", + "xpack.siem.auditd.violatedSeccompPolicyWithDescription": "已违反 seccomp 策略 -", + "xpack.siem.auditd.violatedSeLinuxPolicyDescription": "已违反 selinux 策略", + "xpack.siem.auditd.wasAuthorizedToUseDescription": "有权使用", + "xpack.siem.auditd.withResultDescription": ",结果为", + "xpack.siem.authenticationsOverTime.authenticationCountTitle": "身份验证计数", + "xpack.siem.authenticationsOverTime.unit": "{totalCount, plural, =1 {个身份验证} other {个身份验证}}", + "xpack.siem.authenticationsTable.authenticationFailures": "身份验证", + "xpack.siem.authenticationsTable.failures": "失败", + "xpack.siem.authenticationsTable.lastFailedDestination": "上一失败目标", + "xpack.siem.authenticationsTable.lastFailedSource": "上一失败源", + "xpack.siem.authenticationsTable.lastFailedTime": "上次失败", + "xpack.siem.authenticationsTable.lastSuccessfulDestination": "上一成功目标", + "xpack.siem.authenticationsTable.lastSuccessfulSource": "上一成功源", + "xpack.siem.authenticationsTable.lastSuccessfulTime": "上次成功", + "xpack.siem.authenticationsTable.rows": "{numRows} {numRows, plural, =0 {行} =1 {行} other {行}}", + "xpack.siem.authenticationsTable.successes": "成功", + "xpack.siem.authenticationsTable.uncommonProcessTable": "不常见进程", + "xpack.siem.authenticationsTable.unit": "{totalCount, plural, =1 {个用户} other {个用户}}", + "xpack.siem.authenticationsTable.user": "用户", + "xpack.siem.certificate.fingerprint.clientCertLabel": "客户端证书", + "xpack.siem.certificate.fingerprint.serverCertLabel": "服务器证书", + "xpack.siem.chart.dataAllValuesZerosTitle": "所有值返回零", + "xpack.siem.chart.dataNotAvailableTitle": "图表数据不可用", + "xpack.siem.clipboard.copied": "已复制", + "xpack.siem.clipboard.copy": "复制", + "xpack.siem.clipboard.copy.to.the.clipboard": "复制到剪贴板", + "xpack.siem.clipboard.to.the.clipboard": "至剪贴板", + "xpack.siem.components.embeddables.embeddedMap.destinationLayerLabel": "目标点", + "xpack.siem.components.embeddables.embeddedMap.embeddableHeaderHelp": "地图配置帮助", + "xpack.siem.components.embeddables.embeddedMap.embeddableHeaderTitle": "网络地图", + "xpack.siem.components.embeddables.embeddedMap.embeddablePanelTitle": "源 -> 目标点对点地图", + "xpack.siem.components.embeddables.embeddedMap.errorConfiguringEmbeddableApiTitle": "配置可嵌入 API 时出错", + "xpack.siem.components.embeddables.embeddedMap.errorCreatingMapEmbeddableTitle": "创建地图可嵌入对象时出错", + "xpack.siem.components.embeddables.embeddedMap.lineLayerLabel": "折线图", + "xpack.siem.components.embeddables.embeddedMap.sourceLayerLabel": "源点", + "xpack.siem.components.embeddables.indexPatternsMissingPrompt.errorButtonLabel": "配置索引模式", + "xpack.siem.components.embeddables.indexPatternsMissingPrompt.errorDescription2": "还可以在 Kibana 中手动配置它们。", + "xpack.siem.components.embeddables.indexPatternsMissingPrompt.errorTitle": "未配置所需的索引模式", + "xpack.siem.components.embeddables.mapToolTip.errorTitle": "加载地图特征时出错", + "xpack.siem.components.embeddables.mapToolTip.filterForValueHoverAction": "筛留值", + "xpack.siem.components.embeddables.mapToolTip.footerLabel": "{currentFeature} / {totalFeatures} {totalFeatures, plural, =1 {feature} other {features}}", + "xpack.siem.components.embeddables.mapToolTip.lineContent.destinationLabel": "目标", + "xpack.siem.components.embeddables.mapToolTip.lineContent.sourceLabel": "源", + "xpack.siem.components.embeddables.mapToolTip.pointContent.asnTitle": "ASN", + "xpack.siem.components.embeddables.mapToolTip.pointContent.destinationDomainTitle": "目标域", + "xpack.siem.components.embeddables.mapToolTip.pointContent.destinationIPTitle": "目标 IP", + "xpack.siem.components.embeddables.mapToolTip.pointContent.hostTitle": "主机", + "xpack.siem.components.embeddables.mapToolTip.pointContent.locationTitle": "位置", + "xpack.siem.components.embeddables.mapToolTip.pointContent.sourceDomainTitle": "源域", + "xpack.siem.components.embeddables.mapToolTip.pointContent.sourceIPTitle": "源 IP", + "xpack.siem.components.flowControls.selectFlowDirection.bidirectionalButtonLabel": "双向", + "xpack.siem.components.flowControls.selectFlowDirection.unidirectionalButtonLabel": "单向", + "xpack.siem.components.flowControls.selectFlowTarget.clientDropDownOptionLabel": "客户端", + "xpack.siem.components.flowControls.selectFlowTarget.destinationDropDownOptionLabel": "目标", + "xpack.siem.components.flowControls.selectFlowTarget.serverDropDownOptionLabel": "服务器", + "xpack.siem.components.flowControls.selectFlowTarget.sourceDropDownOptionLabel": "源", + "xpack.siem.components.ml.anomaly.errors.anomaliesTableFetchFailureTitle": "异常表提取失败", + "xpack.siem.components.ml.api.errors.networkErrorFailureTitle": "网络错误:", + "xpack.siem.components.ml.api.errors.statusCodeFailureTitle": "状态代码:", + "xpack.siem.components.ml.permissions.errors.machineLearningPermissionsFailureTitle": "Machine Learning 权限错误", + "xpack.siem.components.mlPopover.jobsTable.filters.groupsLabel": "组", + "xpack.siem.components.mlPopover.jobsTable.filters.noGroupsAvailableDescription": "没有可用的组", + "xpack.siem.components.mlPopover.jobsTable.filters.searchFilterPlaceholder": "例如 rare_process_linux", + "xpack.siem.components.mlPopover.jobsTable.filters.showAllJobsLabel": "Elastic 作业", + "xpack.siem.components.mlPopover.jobsTable.filters.showSiemJobsLabel": "定制作业", + "xpack.siem.components.mlPopup.anomalyDetectionButtonLabel": "异常检测", + "xpack.siem.components.mlPopup.anomalyDetectionDescription": "运行以下任何 Machine Learning 作业以查看该 SIEM 应用程序的所有异常事件。我们提供若干可让您入门的常规检测作业。如果您希望添加自己的定制作业,只需从用于纳入定制作业的 {machineLearning} 应用程序中创建定制作业并使用“SIEM”标记它们。", + "xpack.siem.components.mlPopup.anomalyDetectionTitle": "异常检测设置", + "xpack.siem.components.mlPopup.cloudLink": "云部署", + "xpack.siem.components.mlPopup.errors.createJobFailureTitle": "创建作业失败", + "xpack.siem.components.mlPopup.errors.startJobFailureTitle": "启动作业失败", + "xpack.siem.components.mlPopup.hooks.errors.indexPatternFetchFailureTitle": "索引模式提取失败", + "xpack.siem.components.mlPopup.hooks.errors.siemJobFetchFailureTitle": "SIEM 作业提取失败", + "xpack.siem.components.mlPopup.jobsTable.createCustomJobButtonLabel": "创建定制作业", + "xpack.siem.components.mlPopup.jobsTable.jobNameColumn": "作业名称", + "xpack.siem.components.mlPopup.jobsTable.noItemsDescription": "未找到任何 SIEM Machine Learning 作业", + "xpack.siem.components.mlPopup.jobsTable.runJobColumn": "运行作业", + "xpack.siem.components.mlPopup.jobsTable.tagsColumn": "组", + "xpack.siem.components.mlPopup.licenseButtonLabel": "管理许可", + "xpack.siem.components.mlPopup.machineLearningLink": "Machine Learning", + "xpack.siem.components.mlPopup.moduleNotCompatibleDescription": "我们找不到任何数据,有关 Machine Learning 作业要求的详细信息,请参阅 {mlDocs}。", + "xpack.siem.components.mlPopup.moduleNotCompatibleTitle": "{incompatibleJobCount} {incompatibleJobCount, plural, =1 {job} other {jobs}}当前不可用。", + "xpack.siem.components.mlPopup.showingLabel": "显示:{filterResultsLength} 个 {filterResultsLength, plural, one {作业} other {作业}}", + "xpack.siem.components.mlPopup.upgradeButtonLabel": "订阅选项", + "xpack.siem.components.mlPopup.upgradeDescription": "要访问 SIEM 的异常检测功能,必须将您的许可更新到白金级、开始 30 天免费试用或在 AWS、GCP 或 Azurein 实施{cloudLink}。然后便可以运行 Machine Learning 作业并查看异常。", + "xpack.siem.components.mlPopup.upgradeTitle": "升级 Elastic 白金级", + "xpack.siem.containers.errors.dataFetchFailureTitle": "数据提取失败", + "xpack.siem.containers.errors.networkFailureTitle": "网络故障", + "xpack.siem.containers.errors.stopJobFailureTitle": "停止作业失败", + "xpack.siem.dataProviders.and": "AND", + "xpack.siem.dataProviders.deleteDataProvider": "删除", + "xpack.siem.dataProviders.dropAnything": "放置任何内容", + "xpack.siem.dataProviders.dropHere": "放在此处", + "xpack.siem.dataProviders.dropHereToAddAnLabel": "放在此处以添加", + "xpack.siem.dataProviders.editMenuItem": "编辑筛选", + "xpack.siem.dataProviders.editTitle": "编辑筛选", + "xpack.siem.dataProviders.excludeDataProvider": "排除结果", + "xpack.siem.dataProviders.existsLabel": "存在", + "xpack.siem.dataProviders.filterForFieldPresentLabel": "筛留存在的字段", + "xpack.siem.dataProviders.hereToBuildAn": "在此处以构建", + "xpack.siem.dataProviders.highlighted": "已突出显示", + "xpack.siem.dataProviders.includeDataProvider": "包括结果", + "xpack.siem.dataProviders.not": "非", + "xpack.siem.dataProviders.or": "或", + "xpack.siem.dataProviders.query": "查询", + "xpack.siem.dataProviders.reEnableDataProvider": "重新启用", + "xpack.siem.dataProviders.removeDataProvider": "移除数据提供程序", + "xpack.siem.dataProviders.showOptionsDataProvider": "显示选项 - 适用于", + "xpack.siem.dataProviders.temporaryDisableDataProvider": "暂时禁用", + "xpack.siem.dataProviders.toBuildAn": "以构建", + "xpack.siem.dataProviders.toggle": "切换", + "xpack.siem.dataProviders.valueAriaLabel": "值", + "xpack.siem.dataProviders.valuePlaceholder": "值", + "xpack.siem.draggables.field.categoryLabel": "类别", + "xpack.siem.draggables.field.fieldLabel": "字段", + "xpack.siem.draggables.field.typeLabel": "类型", + "xpack.siem.draggables.field.viewCategoryTooltip": "查看类别", + "xpack.siem.editDataProvider.doesNotExistLabel": "不存在", + "xpack.siem.editDataProvider.existsLabel": "存在", + "xpack.siem.editDataProvider.fieldLabel": "字段", + "xpack.siem.editDataProvider.fieldPlaceholder": "选择字段", + "xpack.siem.editDataProvider.isLabel": "是", + "xpack.siem.editDataProvider.isNotLabel": "不是", + "xpack.siem.editDataProvider.operatorLabel": "运算符", + "xpack.siem.editDataProvider.saveButton": "保存", + "xpack.siem.editDataProvider.selectAnOperatorPlaceholder": "选择运算符", + "xpack.siem.editDataProvider.valueLabel": "值", + "xpack.siem.editDataProvider.valuePlaceholder": "值", + "xpack.siem.emptyString.emptyStringDescription": "空字符串", + "xpack.siem.eventDetails.blank": " ", + "xpack.siem.eventDetails.copyToClipboard": "复制到剪贴板", + "xpack.siem.eventDetails.copyToClipboardTooltip": "复制到剪贴板", + "xpack.siem.eventDetails.description": "描述", + "xpack.siem.eventDetails.field": "字段", + "xpack.siem.eventDetails.filter.placeholder": "按字段、值或描述筛选......", + "xpack.siem.eventDetails.jsonView": "JSON 视图", + "xpack.siem.eventDetails.table": "表", + "xpack.siem.eventDetails.toggleColumnTooltip": "切换列", + "xpack.siem.eventDetails.value": "值", + "xpack.siem.eventsOverTime.eventCountFrequencyByActionTitle": "事件计数 - 按操作", + "xpack.siem.eventsOverTime.showing": "显示", + "xpack.siem.eventsOverTime.unit": "{totalCount, plural, =1 {个事件} other {个事件}}", + "xpack.siem.eventsViewer.eventsLabel": "事件", + "xpack.siem.eventsViewer.showingLabel": "显示", + "xpack.siem.eventsViewer.unit": "{totalCount, plural, =1 {个事件} other {个事件}}", + "xpack.siem.featureRegistry.linkSiemTitle": "SIEM", + "xpack.siem.fieldBrowser.categoriesCountTitle": "{totalCount} {totalCount, plural, =1 {个类别} other {个类别}}", + "xpack.siem.fieldBrowser.categoriesTitle": "类别", + "xpack.siem.fieldBrowser.categoryLabel": "类别", + "xpack.siem.fieldBrowser.copyToClipboard": "复制到剪贴板", + "xpack.siem.fieldBrowser.customizeColumnsTitle": "定制列", + "xpack.siem.fieldBrowser.descriptionLabel": "描述", + "xpack.siem.fieldBrowser.fieldLabel": "字段", + "xpack.siem.fieldBrowser.fieldsCountTitle": "{totalCount} {totalCount, plural, =1 {个字段} other {个字段}}", + "xpack.siem.fieldBrowser.fieldsTitle": "字段", + "xpack.siem.fieldBrowser.filterPlaceholder": "字段名称", + "xpack.siem.fieldBrowser.noFieldsMatchInputLabel": "没有字段匹配 {searchInput}", + "xpack.siem.fieldBrowser.noFieldsMatchLabel": "没有字段匹配", + "xpack.siem.fieldBrowser.resetFieldsLink": "重置字段", + "xpack.siem.fieldBrowser.toggleColumnTooltip": "切换列", + "xpack.siem.fieldBrowser.viewCategoryTooltip": "查看所有 {categoryId} 字段", + "xpack.siem.fieldRenderers.moreLabel": "更多", + "xpack.siem.flyout.button.text": "时间线", + "xpack.siem.flyout.button.timeline": "时间线", + "xpack.siem.footer.autoRefreshActiveDescription": "自动刷新已启用", + "xpack.siem.footer.autoRefreshActiveTooltip": "自动刷新已启用时,时间线将显示匹配查询的最近 {numberOfItems} 个事件。", + "xpack.siem.footer.data": "数据", + "xpack.siem.footer.events": "事件", + "xpack.siem.footer.live": "实时", + "xpack.siem.footer.loadingLabel": "正在加载", + "xpack.siem.footer.loadingTimelineData": "正在加载 Timeline 数据", + "xpack.siem.footer.loadMoreLabel": "加载更多", + "xpack.siem.footer.of": "的", + "xpack.siem.footer.rows": "行", + "xpack.siem.footer.totalCountOfEvents": "匹配搜索条件的事件", + "xpack.siem.footer.updated": "已更新", + "xpack.siem.formatted.duration.aFewMillisecondsTooltip": "几毫秒", + "xpack.siem.formatted.duration.aFewNanosecondsTooltip": "几纳秒", + "xpack.siem.formatted.duration.aMillisecondTooltip": "一毫秒", + "xpack.siem.formatted.duration.aNanosecondTooltip": "一纳秒", + "xpack.siem.formatted.duration.aSecondTooltip": "一秒", + "xpack.siem.formatted.duration.invalidDurationTooltip": "持续时间无效", + "xpack.siem.formatted.duration.noDurationTooltip": "无持续时间", + "xpack.siem.formatted.duration.zeroNanosecondsTooltip": "零纳秒", + "xpack.siem.formattedDuration.tooltipLabel": "原始", + "xpack.siem.headerPage.pageSubtitle": "最后事件:{beat}", + "xpack.siem.host.details.architectureLabel": "架构", + "xpack.siem.host.details.firstSeenTitle": "首次看到时间", + "xpack.siem.host.details.lastSeenTitle": "最后看到时间", + "xpack.siem.host.details.overview.cloudProviderTitle": "云服务提供商", + "xpack.siem.host.details.overview.familyTitle": "系列", + "xpack.siem.host.details.overview.hostIdTitle": "主机 ID", + "xpack.siem.host.details.overview.inspectTitle": "主机概览", + "xpack.siem.host.details.overview.instanceIdTitle": "实例 ID", + "xpack.siem.host.details.overview.ipAddressesTitle": "IP 地址", + "xpack.siem.host.details.overview.macAddressesTitle": "MAC 地址", + "xpack.siem.host.details.overview.machineTypeTitle": "机器类型", + "xpack.siem.host.details.overview.maxAnomalyScoreByJobTitle": "最大异常分数(按作业)", + "xpack.siem.host.details.overview.osTitle": "操作系统", + "xpack.siem.host.details.overview.platformTitle": "平台", + "xpack.siem.host.details.overview.regionTitle": "地区", + "xpack.siem.host.details.versionLabel": "版本", + "xpack.siem.hosts.emptyActionPrimary": "查看设置说明", + "xpack.siem.hosts.emptyActionSecondary": "前往文档", + "xpack.siem.hosts.emptyTitle": "似乎您在 SIEM 应用程序中没有与主机相关的索引", + "xpack.siem.hosts.kqlPlaceholder": "例如 host.name:“foo”", + "xpack.siem.hosts.navigation.allHostsTitle": "所有主机", + "xpack.siem.hosts.navigation.anomaliesTitle": "异常", + "xpack.siem.hosts.navigation.authenticationsTitle": "身份验证", + "xpack.siem.hosts.navigation.eventsTitle": "事件", + "xpack.siem.hosts.navigation.uncommonProcessesTitle": "不常见进程", + "xpack.siem.hosts.pageTitle": "主机", + "xpack.siem.hostsTable.firstLastSeenToolTip": "相对于选定日期范围", + "xpack.siem.hostsTable.hostsTitle": "所有主机", + "xpack.siem.hostsTable.lastSeenTitle": "最后看到时间", + "xpack.siem.hostsTable.nameTitle": "名称", + "xpack.siem.hostsTable.osTitle": "操作系统", + "xpack.siem.hostsTable.rows": "{numRows} {numRows, plural, =0 {行} =1 {行} other {行}}", + "xpack.siem.hostsTable.unit": "{totalCount, plural, =1 {个主机} other {个主机}}", + "xpack.siem.hostsTable.versionTitle": "版本", + "xpack.siem.inspect.modal.closeTitle": "鍏抽棴", + "xpack.siem.inspect.modal.indexPatternDescription": "连接到 Elasticsearch 索引的索引模式。可以在“Kibana”>“高级设置”中配置这些索引。", + "xpack.siem.inspect.modal.indexPatternLabel": "索引模式", + "xpack.siem.inspect.modal.queryTimeDescription": "处理查询所花费的时间。不包括发送请求或在浏览器中解析它的时间。", + "xpack.siem.inspect.modal.queryTimeLabel": "查询时间", + "xpack.siem.inspect.modal.reqTimestampDescription": "记录请求启动的时间", + "xpack.siem.inspect.modal.reqTimestampLabel": "请求时间戳", + "xpack.siem.inspect.modal.somethingWentWrongDescription": "抱歉,出现问题。", + "xpack.siem.inspectDescription": "检查", + "xpack.siem.ja3.fingerprint.ja3.fingerprintLabel": "ja3", + "xpack.siem.kpiHosts.hosts.title": "主机", + "xpack.siem.kpiHosts.uniqueIps.destinationChartLabel": "目标", + "xpack.siem.kpiHosts.uniqueIps.destinationUnitLabel": "目标", + "xpack.siem.kpiHosts.uniqueIps.sourceChartLabel": "源", + "xpack.siem.kpiHosts.uniqueIps.sourceUnitLabel": "源", + "xpack.siem.kpiHosts.uniqueIps.title": "唯一 IP", + "xpack.siem.kpiHosts.userAuthentications.failChartLabel": "失败", + "xpack.siem.kpiHosts.userAuthentications.failUnitLabel": "失败", + "xpack.siem.kpiHosts.userAuthentications.successChartLabel": "成功", + "xpack.siem.kpiHosts.userAuthentications.successUnitLabel": "成功", + "xpack.siem.kpiHosts.userAuthentications.title": "用户身份验证", + "xpack.siem.kpiNetwork.dnsQueries.title": "DNS 查询", + "xpack.siem.kpiNetwork.networkEvents.title": "网络事件", + "xpack.siem.kpiNetwork.tlsHandshakes.title": "TLS 握手", + "xpack.siem.kpiNetwork.uniqueFlowIds.title": "唯一流 ID", + "xpack.siem.kpiNetwork.uniquePrivateIps.destinationChartLabel": "目标", + "xpack.siem.kpiNetwork.uniquePrivateIps.destinationUnitLabel": "目标", + "xpack.siem.kpiNetwork.uniquePrivateIps.sourceChartLabel": "源", + "xpack.siem.kpiNetwork.uniquePrivateIps.sourceUnitLabel": "源", + "xpack.siem.kpiNetwork.uniquePrivateIps.title": "唯一专用 IP", + "xpack.siem.linkSecurityDescription": "浏览您的 SIEM 应用", + "xpack.siem.markdown.hint.boldLabel": "**粗体**", + "xpack.siem.markdown.hint.bulletLabel": "* 项目符号", + "xpack.siem.markdown.hint.codeLabel": "`code`", + "xpack.siem.markdown.hint.headingLabel": "# 标题", + "xpack.siem.markdown.hint.imageUrlLabel": "![image](url)", + "xpack.siem.markdown.hint.italicsLabel": "_italics_", + "xpack.siem.markdown.hint.preformattedLabel": "```preformatted```", + "xpack.siem.markdown.hint.quoteLabel": ">引用", + "xpack.siem.markdown.hint.strikethroughLabel": "删除线", + "xpack.siem.markdown.hint.urlLabel": "[链接](url)", + "xpack.siem.ml.score.anomalousEntityTitle": "异常实体", + "xpack.siem.ml.score.anomalyJobTitle": "作业", + "xpack.siem.ml.score.detectedTitle": "已检测到", + "xpack.siem.ml.score.influencedByTitle": "影响因素", + "xpack.siem.ml.score.maxAnomalyScoreTitle": "最大异常分数", + "xpack.siem.ml.score.narrowToThisDateRangeLink": "缩小至此日期范围", + "xpack.siem.ml.score.viewInMachineLearningLink": "在 Machine Learning 中查看", + "xpack.siem.ml.table.detectorTitle": "作业名称", + "xpack.siem.ml.table.entityTitle": "实体", + "xpack.siem.ml.table.hostNameTitle": "主机名", + "xpack.siem.ml.table.influencedByTitle": "影响因素", + "xpack.siem.ml.table.networkNameTitle": "网络 IP", + "xpack.siem.ml.table.scoreTitle": "异常分数", + "xpack.siem.ml.table.timestampTitle": "时间戳", + "xpack.siem.modalAllErrors.close.button": "关闭", + "xpack.siem.modalAllErrors.seeAllErrors.button": "请参阅完整的错误信息", + "xpack.siem.modalAllErrors.title": "您的可视化有错误", + "xpack.siem.navigation.hosts": "主机", + "xpack.siem.navigation.network": "网络", + "xpack.siem.navigation.overview": "概览", + "xpack.siem.navigation.timelines": "时间线", + "xpack.siem.network.emptyActionPrimary": "查看设置说明", + "xpack.siem.network.emptyActionSecondary": "前往文档", + "xpack.siem.network.emptyTitle": "似乎您在 SIEM 应用程序中没有与网络相关的索引", + "xpack.siem.network.ipDetails.ipOverview.asDestinationDropDownOptionLabel": "作为目标", + "xpack.siem.network.ipDetails.ipOverview.asSourceDropDownOptionLabel": "作为源", + "xpack.siem.network.ipDetails.ipOverview.autonomousSystemTitle": "自治系统", + "xpack.siem.network.ipDetails.ipOverview.firstSeenTitle": "首次看到时间", + "xpack.siem.network.ipDetails.ipOverview.hostIdTitle": "主机 ID", + "xpack.siem.network.ipDetails.ipOverview.hostNameTitle": "主机名", + "xpack.siem.network.ipDetails.ipOverview.inspectTitle": "IP 概览", + "xpack.siem.network.ipDetails.ipOverview.ipReputationTitle": "信誉", + "xpack.siem.network.ipDetails.ipOverview.lastSeenTitle": "最后看到时间", + "xpack.siem.network.ipDetails.ipOverview.locationTitle": "位置", + "xpack.siem.network.ipDetails.ipOverview.maxAnomalyScoreByJobTitle": "最大异常分数(按作业)", + "xpack.siem.network.ipDetails.ipOverview.viewTalosIntelligenceTitle": "talosIntelligence.com", + "xpack.siem.network.ipDetails.ipOverview.viewVirusTotalTitle.": "virustotal.com", + "xpack.siem.network.ipDetails.ipOverview.viewWhoisTitle": "iana.org", + "xpack.siem.network.ipDetails.ipOverview.whoIsTitle": "WhoIs", + "xpack.siem.network.ipDetails.tlsTable.columns.issuerTitle": "颁发者", + "xpack.siem.network.ipDetails.tlsTable.columns.ja3FingerPrintTitle": "JA3 指纹", + "xpack.siem.network.ipDetails.tlsTable.columns.sha1FingerPrintTitle": "SHA1 指纹", + "xpack.siem.network.ipDetails.tlsTable.columns.subjectTitle": "主题", + "xpack.siem.network.ipDetails.tlsTable.columns.validUntilTitle": "失效日期", + "xpack.siem.network.ipDetails.tlsTable.rows": "{numRows} {numRows, plural, =0 {行} =1 {行} other {行}}", + "xpack.siem.network.ipDetails.tlsTable.transportLayerSecurityTitle": "传输层安全", + "xpack.siem.network.ipDetails.tlsTable.unit": "{totalCount, plural, =1 {个颁发者} other {个颁发者}}", + "xpack.siem.network.ipDetails.usersTable.columns.documentCountTitle": "文档计数", + "xpack.siem.network.ipDetails.usersTable.columns.groupIdTitle": "组 ID", + "xpack.siem.network.ipDetails.usersTable.columns.groupNameTitle": "组名称", + "xpack.siem.network.ipDetails.usersTable.columns.userIdTitle": "ID", + "xpack.siem.network.ipDetails.usersTable.columns.userNameTitle": "用户", + "xpack.siem.network.ipDetails.usersTable.rows": "{numRows} {numRows, plural, =0 {行} =1 {行} other {行}}", + "xpack.siem.network.ipDetails.usersTable.unit": "{totalCount, plural, =1 {个用户} other {个用户}}", + "xpack.siem.network.ipDetails.usersTable.usersTitle": "用户", + "xpack.siem.network.kqlPlaceholder": "例如 source.ip:“foo”", + "xpack.siem.network.navigation.anomaliesTitle": "异常", + "xpack.siem.network.navigation.dnsTitle": "DNS", + "xpack.siem.network.navigation.flowsTitle": "Flows", + "xpack.siem.network.navigation.tlsTitle": "TLS", + "xpack.siem.network.pageTitle": "网络", + "xpack.siem.networkDnsTable.column.bytesInTitle": "DNS 传入字节", + "xpack.siem.networkDnsTable.column.bytesOutTitle": "DNS 传出字节", + "xpack.siem.networkDnsTable.column.registeredDomain": "已注册域", + "xpack.siem.networkDnsTable.column.TotalQueriesTitle": "查询总数", + "xpack.siem.networkDnsTable.column.uniqueDomainsTitle": "唯一域", + "xpack.siem.networkDnsTable.helperTooltip": "其仅显示 DNS 协议流量,可用于捕获 DNS 数据外泄中使用的域。", + "xpack.siem.networkDnsTable.rows": "{numRows} {numRows, plural, =0 {行} =1 {行} other {行}}", + "xpack.siem.networkDnsTable.select.includePtrRecords": "包括 PTR 记录", + "xpack.siem.networkDnsTable.title": "排名靠前的 DNS 域", + "xpack.siem.networkDnsTable.unit": "{totalCount, plural, =1 {个域} other {个域}}", + "xpack.siem.networkTopCountriesTable.column.bytesInTitle": "传入字节", + "xpack.siem.networkTopCountriesTable.column.bytesOutTitle": "传出字节", + "xpack.siem.networkTopCountriesTable.column.countryTitle": "国家/地区", + "xpack.siem.networkTopCountriesTable.column.destinationIps": "目标 IP", + "xpack.siem.networkTopCountriesTable.column.flows": "Flows", + "xpack.siem.networkTopCountriesTable.column.sourceIps": "源 IP", + "xpack.siem.networkTopCountriesTable.heading.destinationCountries": "目标国家/地区", + "xpack.siem.networkTopCountriesTable.heading.sourceCountries": "源国家/地区", + "xpack.siem.networkTopCountriesTable.heading.unit": "{totalCount, plural, =1 {个国家或地区} other {个国家或地区}}", + "xpack.siem.networkTopCountriesTable.rows": "{numRows} {numRows, plural, =0 {行} =1 {行} other {行}}", + "xpack.siem.networkTopNFlowTable.column.asTitle": "自治系统", + "xpack.siem.networkTopNFlowTable.column.bytesInTitle": "传入字节", + "xpack.siem.networkTopNFlowTable.column.bytesOutTitle": "传出字节", + "xpack.siem.networkTopNFlowTable.column.destinationIpTitle": "目标 IP", + "xpack.siem.networkTopNFlowTable.column.domainTitle": "域", + "xpack.siem.networkTopNFlowTable.column.IpTitle": "IP", + "xpack.siem.networkTopNFlowTable.column.sourceIpTitle": "源 IP", + "xpack.siem.networkTopNFlowTable.destinationIps": "目标 IP", + "xpack.siem.networkTopNFlowTable.flows": "Flows", + "xpack.siem.networkTopNFlowTable.rows": "{numRows} {numRows, plural, =0 {行} =1 {行} other {行}}", + "xpack.siem.networkTopNFlowTable.sourceIps": "源 IP", + "xpack.siem.networkTopNFlowTable.unit": "{totalCount, plural, =1 {个 IP} other {个 IP}}", + "xpack.siem.notes.addANotePlaceholder": "添加备注", + "xpack.siem.notes.addedANoteLabel": "已添加备注", + "xpack.siem.notes.addNoteButtonLabel": "添加备注", + "xpack.siem.notes.cancelButtonLabel": "取消", + "xpack.siem.notes.copyToClipboardButtonLabel": "复制到剪贴板", + "xpack.siem.notes.noteLabel": "注释", + "xpack.siem.notes.notesTitle": "备注", + "xpack.siem.notes.previewMarkdownTitle": "预览 (Markdown)", + "xpack.siem.notes.search.FilterByUserOrNotePlaceholder": "按用户或备注筛选", + "xpack.siem.open.timeline.cancelButton": "取消", + "xpack.siem.open.timeline.collapseButton": "折叠", + "xpack.siem.open.timeline.deleteButton": "删除", + "xpack.siem.open.timeline.deleteSelectedButton": "删除选定", + "xpack.siem.open.timeline.deleteTimelineModalTitle": "删除“{title}”?", + "xpack.siem.open.timeline.deleteWarningLabel": "一旦删除,将无法恢复此时间线或其备注。", + "xpack.siem.open.timeline.descriptionTableHeader": "描述", + "xpack.siem.open.timeline.expandButton": "展开", + "xpack.siem.open.timeline.favoriteSelectedButton": "收藏所选", + "xpack.siem.open.timeline.favoritesTooltip": "收藏夹", + "xpack.siem.open.timeline.lastModifiedTableHeader": "最后修改时间", + "xpack.siem.open.timeline.missingSavedObjectIdTooltip": "缺失 savedObjectId", + "xpack.siem.open.timeline.modifiedByTableHeader": "修改者", + "xpack.siem.open.timeline.notesTooltip": "备注", + "xpack.siem.open.timeline.onlyFavoritesButtonLabel": "仅收藏夹", + "xpack.siem.open.timeline.openAsDuplicateTooltip": "作为时间线副本打开", + "xpack.siem.open.timeline.openTimelineButton": "打开时间线......", + "xpack.siem.open.timeline.openTimelineTitle": "打开时间线", + "xpack.siem.open.timeline.pinnedEventsTooltip": "置顶事件", + "xpack.siem.open.timeline.postedLabel": "已发表:", + "xpack.siem.open.timeline.searchPlaceholder": "例如时间线名称或描述", + "xpack.siem.open.timeline.showingNTimelinesLabel": "显示 {totalSearchResultsCount} {totalSearchResultsCount, plural, one {个时间线} other {个时间线}} {with}", + "xpack.siem.open.timeline.timelineNameTableHeader": "时间线名称", + "xpack.siem.open.timeline.untitledTimelineLabel": "未命名时间线", + "xpack.siem.open.timeline.withLabel": "具有", + "xpack.siem.open.timeline.zeroTimelinesMatchLabel": "0 个时间线匹配搜索条件", + "xpack.siem.overview.auditBeatAuditTitle": "Auditbeat 审计", + "xpack.siem.overview.auditBeatFimTitle": "Auditbeat 文件完整性模块", + "xpack.siem.overview.auditBeatLoginTitle": "Auditbeat 登录", + "xpack.siem.overview.auditBeatPackageTitle": "Auditbeat 软件包", + "xpack.siem.overview.auditBeatProcessTitle": "Auditbeat 进程", + "xpack.siem.overview.auditBeatSocketTitle": "Auditbeat 套接字", + "xpack.siem.overview.auditBeatUserTitle": "Auditbeat 用户", + "xpack.siem.overview.emptyActionPrimary": "查看设置说明", + "xpack.siem.overview.emptyActionSecondary": "前往文档", + "xpack.siem.overview.emptyTitle": "似乎您没有与 SIEM 应用程序相关的索引", + "xpack.siem.overview.endgameDnsTitle": "Endgame DNS", + "xpack.siem.overview.endgameFileTitle": "Endgame 文件", + "xpack.siem.overview.endgameImageLoadTitle": "Endgame 图像加载", + "xpack.siem.overview.endgameNetworkTitle": "Endgame 网络", + "xpack.siem.overview.endgameProcessTitle": "Endgame 进程", + "xpack.siem.overview.endgameRegistryTitle": "Endgame 注册表", + "xpack.siem.overview.endgameSecurityTitle": "Endgame 安全", + "xpack.siem.overview.feedbackText": "如果您对 Elastic SIEM 体验有任何建议,请随时{feedback}。", + "xpack.siem.overview.feedbackText.feedbackLinkText": "在线提交反馈", + "xpack.siem.overview.feedbackTitle": "反馈", + "xpack.siem.overview.filebeatCiscoTitle": "Filebeat Cisco", + "xpack.siem.overview.filebeatNetflowTitle": "Filebeat NetFlow", + "xpack.siem.overview.filebeatPanwTitle": "Filebeat Palo Alto Networks", + "xpack.siem.overview.fileBeatSuricataTitle": "Filebeat Suricata", + "xpack.siem.overview.filebeatSystemModuleTitle": "Filebeat 系统模块", + "xpack.siem.overview.fileBeatZeekTitle": "Filebeat Zeek", + "xpack.siem.overview.hostsAction": "查看主机", + "xpack.siem.overview.hostsSubtitle": "显示:过去 24 小时", + "xpack.siem.overview.hostsTitle": "主机事件", + "xpack.siem.overview.networkAction": "查看网络", + "xpack.siem.overview.networkSubtitle": "显示:过去 24 小时", + "xpack.siem.overview.networkTitle": "网络事件", + "xpack.siem.overview.packetBeatDnsTitle": "Packetbeat DNS", + "xpack.siem.overview.packetBeatFlowTitle": "Packetbeat 流", + "xpack.siem.overview.packetbeatTLSTitle": "Packetbeat TLS", + "xpack.siem.overview.pageBadgeLabel": "公测版", + "xpack.siem.overview.pageBadgeTooltip": "SIEM 仍为公测版。请通过在 Kibana 报告中报告问题或错误,帮助我们改进产品。", + "xpack.siem.overview.pageSubtitle": "Elastic Stack 的安全信息和事件管理功能", + "xpack.siem.overview.pageTitle": "SIEM", + "xpack.siem.overview.startedText": "欢迎使用安全信息和事件管理 (SIEM)。首先,查看我们的 {docs} 或 {data}。有关即将推出的功能和教程,确保查看我们的{siemSolution}页。", + "xpack.siem.overview.startedText.dataLinkText": "正在采集数据", + "xpack.siem.overview.startedText.docsLinkText": "文档", + "xpack.siem.overview.startedText.siemSolutionLinkText": "SIEM 解决方案", + "xpack.siem.overview.startedTitle": "入门", + "xpack.siem.overview.winlogbeatTitle": "Winlogbeat", + "xpack.siem.pages.fourohfour.noContentFoundDescription": "未找到任何内容", + "xpack.siem.paginatedTable.rowsButtonLabel": "每页行数", + "xpack.siem.paginatedTable.showingSubtitle": "显示", + "xpack.siem.paginatedTable.tooManyResultsToastText": "缩减您的查询范围,以更好地筛选结果", + "xpack.siem.paginatedTable.tooManyResultsToastTitle": " - 结果过多", + "xpack.siem.securityDescription": "浏览您的 SIEM 应用", + "xpack.siem.source.destination.packetsLabel": "pkts", + "xpack.siem.system.acceptedAConnectionViaDescription": "已接受连接,通过", + "xpack.siem.system.acceptedDescription": "已接受该用户 - 通过", + "xpack.siem.system.attemptedLoginDescription": "已尝试登录 - 通过", + "xpack.siem.system.createdFileDescription": "已创建文件", + "xpack.siem.system.deletedFileDescription": "已删除文件", + "xpack.siem.system.disconnectedViaDescription": "已断开连接,通过", + "xpack.siem.system.errorDescription": "遇到错误 - ", + "xpack.siem.system.existingPackageDescription": "正在使用现有软件包", + "xpack.siem.system.existingProcessDescription": "正在运行进程", + "xpack.siem.system.existingSocketDescription": "正在使用现有套接字 - 来自", + "xpack.siem.system.existingUserDescription": "是现有用户", + "xpack.siem.system.hostDescription": "主机信息", + "xpack.siem.system.invalidDescription": "已尝试无效使用", + "xpack.siem.system.loggedOutDescription": "已注销 - 通过", + "xpack.siem.system.packageInstalledDescription": "已安装软件包", + "xpack.siem.system.packageRemovedDescription": "已移除软件包", + "xpack.siem.system.packageSystemStartedDescription": "系统已启动", + "xpack.siem.system.packageUpdatedDescription": "已更新软件包", + "xpack.siem.system.processErrorDescription": "遇到进程错误 -", + "xpack.siem.system.processStartedDescription": "已启动进程", + "xpack.siem.system.processStoppedDescription": "已停止进程", + "xpack.siem.system.socketClosedDescription": "已关闭套接字 -", + "xpack.siem.system.socketOpenedDescription": "已打开套接字 -", + "xpack.siem.system.systemDescription": "系统", + "xpack.siem.system.terminatedProcessDescription": "已终止进程", + "xpack.siem.system.userAddedDescription": "用户已添加", + "xpack.siem.system.userChangedDescription": "用户已更改", + "xpack.siem.system.userRemovedDescription": "已移除", + "xpack.siem.system.usingDescription": "使用", + "xpack.siem.system.viaDescription": "通过", + "xpack.siem.system.viaParentProcessDescription": "通过父进程", + "xpack.siem.system.wasAuthorizedToUseDescription": "有权使用", + "xpack.siem.system.withExitCodeDescription": "退出代码为", + "xpack.siem.system.withResultDescription": ",结果为", + "xpack.siem.tables.rowItemHelper.moreDescription": "未显示", + "xpack.siem.timeline.autosave.warning.description": "其他用户已更改此时间线。您所做的任何更改不会自动保存,直至您刷新了此时间线以吸收这些更改。", + "xpack.siem.timeline.autosave.warning.refresh.title": "刷新时间线", + "xpack.siem.timeline.autosave.warning.title": "刷新后才会启用自动保存", + "xpack.siem.timeline.body.actions.collapseAriaLabel": "折叠", + "xpack.siem.timeline.body.actions.expandAriaLabel": "展开", + "xpack.siem.timeline.body.copyToClipboardButtonLabel": "复制到剪贴板", + "xpack.siem.timeline.body.notes.addOrViewNotesForThisEventTooltip": "添加或查看此事件的备注", + "xpack.siem.timeline.body.pinning.pinnedTooltip": "该时间线持续出现此事件", + "xpack.siem.timeline.body.pinning.pinnnedWithNotesTooltip": "此事件无法固定,因为其有备注", + "xpack.siem.timeline.body.pinning.unpinnedTooltip": "该时间线未持续存在此事件", + "xpack.siem.timeline.body.renderers.dns.askedForDescription": "请求过", + "xpack.siem.timeline.body.renderers.dns.responseCodeDescription": "响应代码:", + "xpack.siem.timeline.body.renderers.dns.viaDescription": "通过", + "xpack.siem.timeline.body.renderers.dns.whichResolvedToDescription": ",其已解析为", + "xpack.siem.timeline.body.renderers.dns.withQuestionTypeDescription": ",问题类型为", + "xpack.siem.timeline.body.renderers.endgame.aLoginWasAttemptedUsingExplicitCredentialsDescription": "已使用显式凭据尝试登录", + "xpack.siem.timeline.body.renderers.endgame.asRequestedBySubjectDescription": ",如主语所请求", + "xpack.siem.timeline.body.renderers.endgame.loggedOffDescription": "已注销", + "xpack.siem.timeline.body.renderers.endgame.logonTypeBatchDescription": "批量", + "xpack.siem.timeline.body.renderers.endgame.logonTypeCachedInteractiveDescription": "缓存交互", + "xpack.siem.timeline.body.renderers.endgame.logonTypeInteractiveDescription": "交互", + "xpack.siem.timeline.body.renderers.endgame.logonTypeNetworkCleartextDescription": "网络明文", + "xpack.siem.timeline.body.renderers.endgame.logonTypeNetworkDescription": "网络", + "xpack.siem.timeline.body.renderers.endgame.logonTypeNewCredentialsDescription": "新凭据", + "xpack.siem.timeline.body.renderers.endgame.logonTypeRemoteInteractiveDescription": "远程交互", + "xpack.siem.timeline.body.renderers.endgame.logonTypeServiceDescription": "服务", + "xpack.siem.timeline.body.renderers.endgame.logonTypeUnlockDescription": "解锁", + "xpack.siem.timeline.body.renderers.endgame.subjectLogonIdDescription": "主语登录 ID", + "xpack.siem.timeline.body.renderers.endgame.successfullyLoggedInDescription": "已成功登录", + "xpack.siem.timeline.body.renderers.endgame.targetLogonIdDescription": "目标登录 ID", + "xpack.siem.timeline.body.renderers.endgame.toDescription": "到", + "xpack.siem.timeline.body.renderers.endgame.usingLogonTypeDescription": "使用登录类型", + "xpack.siem.timeline.body.renderers.endgame.viaDescription": "通过", + "xpack.siem.timeline.body.renderers.endgame.withSpecialPrivilegesDescription": "使用特殊权限,", + "xpack.siem.timeline.callOut.unauthorized.message.description": "您需要在 SIEM 内自动保存时间线的权限,但您可以继续使用该时间线搜索和筛选安全事件", + "xpack.siem.timeline.categoryTooltip": "类别", + "xpack.siem.timeline.descriptionTooltip": "描述", + "xpack.siem.timeline.destination": "目标", + "xpack.siem.timeline.eventsSelect.actions.pinSelected": "固定所选", + "xpack.siem.timeline.eventsSelect.actions.selectAll": "全部", + "xpack.siem.timeline.eventsSelect.actions.selectNone": "无", + "xpack.siem.timeline.eventsSelect.actions.selectPinned": "已固定", + "xpack.siem.timeline.eventsSelect.actions.selectUnpinned": "取消固定", + "xpack.siem.timeline.eventsSelect.actions.unpinSelected": "取消固定所选", + "xpack.siem.timeline.expandableEvent.copyToClipboardToolTip": "复制到剪贴板", + "xpack.siem.timeline.expandableEvent.eventToolTipTitle": "时间", + "xpack.siem.timeline.fieldTooltip": "字段", + "xpack.siem.timeline.flyout.pane.closeTimelineButtonLabel": "关闭时间线", + "xpack.siem.timeline.flyout.pane.removeColumnButtonLabel": "删除列", + "xpack.siem.timeline.flyout.pane.timelinePropertiesAriaLabel": "时间线属性", + "xpack.siem.timeline.properties.descriptionPlaceholder": "描述", + "xpack.siem.timeline.properties.descriptionTooltip": "此时间线中事件和备注的摘要", + "xpack.siem.timeline.properties.favoriteTooltip": "收藏", + "xpack.siem.timeline.properties.historyLabel": "历史记录", + "xpack.siem.timeline.properties.historyToolTip": "与此时间线相关的操作历史记录(按时间顺序排列)", + "xpack.siem.timeline.properties.inspectTimelineTitle": "鏃堕棿绾", + "xpack.siem.timeline.properties.isViewingTooltip": "正在查看此时间线", + "xpack.siem.timeline.properties.lockDatePickerDescription": "将日期选取器锁定到全局日期选取器", + "xpack.siem.timeline.properties.lockDatePickerTooltip": "禁用当前查看的页面和您的时间线之间的日期/时间范围同步", + "xpack.siem.timeline.properties.newTimelineButtonLabel": "创建新的时间线", + "xpack.siem.timeline.properties.notAFavoriteTooltip": "取消收藏", + "xpack.siem.timeline.properties.notesButtonLabel": "备注", + "xpack.siem.timeline.properties.notesToolTip": "添加并复查此时间线的备注。也可以向事件添加备注。", + "xpack.siem.timeline.properties.streamLiveButtonLabel": "实时流式传输", + "xpack.siem.timeline.properties.streamLiveToolTip": "新数据到达时更新时间线", + "xpack.siem.timeline.properties.timelineDescription": "时间线描述", + "xpack.siem.timeline.properties.timelineTitleAriaLabel": "时间线标题", + "xpack.siem.timeline.properties.titleTitle": "标题", + "xpack.siem.timeline.properties.unlockDatePickerDescription": "从全局日期选取器解除锁定日期选取器", + "xpack.siem.timeline.properties.unlockDatePickerTooltip": "启用当前查看的页面和您的时间线之间的日期/时间范围同步", + "xpack.siem.timeline.properties.untitledTimelinePlaceholder": "未命名时间线", + "xpack.siem.timeline.protocol": "协议", + "xpack.siem.timeline.rangePicker.oneDay": "1 日", + "xpack.siem.timeline.rangePicker.oneMonth": "1 个月", + "xpack.siem.timeline.rangePicker.oneWeek": "1 周", + "xpack.siem.timeline.rangePicker.oneYear": "1 年", + "xpack.siem.timeline.searchOrFilter.filterDescription": "来自上述数据提供程序的事件按相邻 KQL 进行筛选", + "xpack.siem.timeline.searchOrFilter.filterKqlPlaceholder": "筛选事件", + "xpack.siem.timeline.searchOrFilter.filterKqlSelectedText": "筛选", + "xpack.siem.timeline.searchOrFilter.filterKqlTooltip": "来自上述数据提供程序的事件按此 KQL 进行筛选", + "xpack.siem.timeline.searchOrFilter.filterOrSearchWithKql": "使用 KQL 筛选或搜索", + "xpack.siem.timeline.searchOrFilter.searchDescription": "来自上述数据提供程序的事件与来自相邻 KQL 的结果合并", + "xpack.siem.timeline.searchOrFilter.searchKqlPlaceholder": "搜索事件", + "xpack.siem.timeline.searchOrFilter.searchKqlSelectedText": "搜索", + "xpack.siem.timeline.searchOrFilter.searchKqlTooltip": "来自上述数据提供程序的事件与来自此 KQL 的结果合并", + "xpack.siem.timeline.source": "源", + "xpack.siem.timeline.tcp": "TCP", + "xpack.siem.timeline.typeTooltip": "类型", + "xpack.siem.timelines.allTimelines.panelTitle": "所有时间线", + "xpack.siem.timelines.pageTitle": "时间线", + "xpack.siem.uiSettings.defaultAnomalyScoreDescription": "

在显示异常之前要超过的默认异常分数阈值。

有效值:0 到 100。

", + "xpack.siem.uiSettings.defaultAnomalyScoreLabel": "默认异常阈值", + "xpack.siem.uiSettings.defaultIndexDescription": "

SIEM 应用要从其中搜索事件的 Elasticsearch 索引逗号分隔列表。

", + "xpack.siem.uiSettings.defaultIndexLabel": "默认索引", + "xpack.siem.uiSettings.defaultRefreshIntervalDescription": "

SIEM 时间筛选的默认刷新时间间隔(毫秒)。

", + "xpack.siem.uiSettings.defaultRefreshIntervalLabel": "时间筛选刷新时间间隔", + "xpack.siem.uiSettings.defaultTimeRangeDescription": "

SIEM 时间筛选中的默认时间期间。

", + "xpack.siem.uiSettings.defaultTimeRangeLabel": "时间筛选默认值", + "xpack.siem.uncommonProcessTable.hostsTitle": "主机", + "xpack.siem.uncommonProcessTable.lastCommandTitle": "上一命令", + "xpack.siem.uncommonProcessTable.lastUserTitle": "上一用户", + "xpack.siem.uncommonProcessTable.nameTitle": "名称", + "xpack.siem.uncommonProcessTable.numberOfHostsTitle": "主机数目", + "xpack.siem.uncommonProcessTable.numberOfInstances": "实例", + "xpack.siem.uncommonProcessTable.rows": "{numRows} {numRows, plural, =0 {行} =1 {行} other {行}}", + "xpack.siem.uncommonProcessTable.unit": "{totalCount, plural, =1 {个进程} other {个进程}}", + "xpack.siem.zeek.othDescription": "未看到 SYN,仅中游流量", + "xpack.siem.zeek.rejDescription": "已拒绝连接尝试", + "xpack.siem.zeek.rstoODescription": "连接已建立,发起方已中止(已发送 RST)", + "xpack.siem.zeek.rstosoDescription": "发起方已发送 SYN,后跟 RST,响应方未发送 SYN-ACK", + "xpack.siem.zeek.rstrDescription": "已建立,响应方已中止", + "xpack.siem.zeek.rstrhDescription": "响应方已发送 SYN ACK,后跟 RST,(假设)发起方未发送 SYN", + "xpack.siem.zeek.s0Description": "已看到连接尝试,无答复", + "xpack.siem.zeek.s1Description": "连接已建立,未终止", + "xpack.siem.zeek.s2Description": "连接已建立,已看到发起方的关闭尝试(但没有响应方的答复)", + "xpack.siem.zeek.s3Description": "连接已建立,已看到响应方的关闭尝试(但没有发起方的答复)", + "xpack.siem.zeek.sfDescription": "正常 SYN/FIN 完成", + "xpack.siem.zeek.shDescription": "发起方已发送 SYN,后跟 FIN,响应方未发送 SYN ACK", + "xpack.siem.zeek.shrDescription": "响应方已发送 SYN ACK,后跟 FIN,发起方未发送 SYN", + "xpack.snapshotRestore.addPolicy.breadcrumbTitle": "添加策略", + "xpack.snapshotRestore.addPolicy.loadingIndicesDescription": "正在加载可用索引……", + "xpack.snapshotRestore.addPolicy.LoadingIndicesErrorMessage": "加载可用索引时出错", + "xpack.snapshotRestore.addPolicy.savingPolicyErrorTitle": "无法创建新策略", + "xpack.snapshotRestore.addPolicyTitle": "创建策略", + "xpack.snapshotRestore.addRepository.breadcrumbTitle": "添加存储库", + "xpack.snapshotRestore.addRepository.savingRepositoryErrorTitle": "无法注册新存储库", + "xpack.snapshotRestore.addRepositoryButtonLabel": "注册存储库", + "xpack.snapshotRestore.addRepositoryTitle": "注册存储库", + "xpack.snapshotRestore.app.checkingPrivilegesDescription": "正在检查权限……", + "xpack.snapshotRestore.app.checkingPrivilegesErrorMessage": "从服务器获取用户权限时出错。", + "xpack.snapshotRestore.app.deniedPrivilegeDescription": "要使用“快照和还原”,必须具有{privilegesCount, plural, one {以下集群权限} other {以下集群权限}}:{missingPrivileges}。", + "xpack.snapshotRestore.app.deniedPrivilegeTitle": "您缺少集群权限", + "xpack.snapshotRestore.appName": "快照存储库", + "xpack.snapshotRestore.createPolicyButton": "创建策略", + "xpack.snapshotRestore.dataPlaceholderLabel": "-", + "xpack.snapshotRestore.deletePolicy.confirmModal.cancelButtonLabel": "取消", + "xpack.snapshotRestore.deletePolicy.confirmModal.confirmButtonLabel": "删除{count, plural, one {策略} other {策略}}", + "xpack.snapshotRestore.deletePolicy.confirmModal.deleteMultipleListDescription": "您即将删除以下策略:", + "xpack.snapshotRestore.deletePolicy.confirmModal.deleteMultipleTitle": "删除 {count} 个策略?", + "xpack.snapshotRestore.deletePolicy.confirmModal.deleteSingleTitle": "删除策略“{name}”?", + "xpack.snapshotRestore.deletePolicy.errorMultipleNotificationTitle": "删除 {count} 个策略时出错", + "xpack.snapshotRestore.deletePolicy.errorSingleNotificationTitle": "删除策略“{name}”时出错", + "xpack.snapshotRestore.deletePolicy.successMultipleNotificationTitle": "已删除 {count} 个策略", + "xpack.snapshotRestore.deletePolicy.successSingleNotificationTitle": "已删除策略“{name}”", + "xpack.snapshotRestore.deleteRepository.confirmModal.cancelButtonLabel": "取消", + "xpack.snapshotRestore.deleteRepository.confirmModal.confirmMultipleButtonLabel": "移除存储库", + "xpack.snapshotRestore.deleteRepository.confirmModal.confirmSingleButtonLabel": "移除存储库", + "xpack.snapshotRestore.deleteRepository.confirmModal.deleteMultipleDescription": "这些存储库中的快照仍将存在,但 Elasticsearch 将无法访问它们。调整使用这些存储库的策略,以防止排定的快照失败。", + "xpack.snapshotRestore.deleteRepository.confirmModal.deleteMultipleListDescription": "您即将移除以下存储库:", + "xpack.snapshotRestore.deleteRepository.confirmModal.deleteMultipleTitle": "移除 {count} 个存储库", + "xpack.snapshotRestore.deleteRepository.confirmModal.deleteSingleDescription": "此存储库中的快照仍将存在,但 Elasticsearch 将无法访问它们。调整使用此存储库的策略,以防止排定的快照失败。", + "xpack.snapshotRestore.deleteRepository.confirmModal.deleteSingleTitle": "移除存储库“{name}”?", + "xpack.snapshotRestore.deleteRepository.errorMultipleNotificationTitle": "移除 {count} 个存储库时出错", + "xpack.snapshotRestore.deleteRepository.errorSingleNotificationTitle": "移除存储库“{name}”时出错", + "xpack.snapshotRestore.deleteRepository.successMultipleNotificationTitle": "已移除 {count} 个存储库", + "xpack.snapshotRestore.deleteRepository.successSingleNotificationTitle": "已移除存储库“{name}”", + "xpack.snapshotRestore.deleteSnapshot.confirmModal.cancelButtonLabel": "鍙栨秷", + "xpack.snapshotRestore.deleteSnapshot.confirmModal.confirmButtonLabel": "删除{count, plural, one {快照} other {快照}}", + "xpack.snapshotRestore.deleteSnapshot.confirmModal.deleteMultipleDescription": "与{count, plural, one {此快照} other {这些快照}}关联的还原操作将停止。", + "xpack.snapshotRestore.deleteSnapshot.confirmModal.deleteMultipleListDescription": "您即将删除以下快照:", + "xpack.snapshotRestore.deleteSnapshot.confirmModal.deleteMultipleTitle": "删除 {count} 个快照?", + "xpack.snapshotRestore.deleteSnapshot.confirmModal.deleteSingleTitle": "删除快照“{name}”?", + "xpack.snapshotRestore.deleteSnapshot.confirmModal.deletingCalloutDescription": "这可能需要若干分钟。", + "xpack.snapshotRestore.deleteSnapshot.confirmModal.deletingCalloutTitle": "正在删除快照", + "xpack.snapshotRestore.deleteSnapshot.errorMultipleNotificationTitle": "删除 {count} 个快照时出错", + "xpack.snapshotRestore.deleteSnapshot.errorSingleNotificationTitle": "删除快照“{name}”时出错", + "xpack.snapshotRestore.deleteSnapshot.successMultipleNotificationTitle": "已删除 {count} 个快照", + "xpack.snapshotRestore.deleteSnapshot.successSingleNotificationTitle": "已删除快照“{name}”", + "xpack.snapshotRestore.editPolicy.breadcrumbTitle": "编辑策略", + "xpack.snapshotRestore.editPolicy.loadingIndicesDescription": "正在加载可用索引……", + "xpack.snapshotRestore.editPolicy.LoadingIndicesErrorMessage": "加载可用索引时出错", + "xpack.snapshotRestore.editPolicy.loadingPolicyDescription": "正在加载策略详细信息……", + "xpack.snapshotRestore.editPolicy.loadingPolicyErrorTitle": "加载策略详细信息时出错", + "xpack.snapshotRestore.editPolicy.policyNotFoundErrorMessage": "策略“{name}”不存在。", + "xpack.snapshotRestore.editPolicy.savingPolicyErrorTitle": "无法保存策略", + "xpack.snapshotRestore.editPolicyTitle": "编辑策略", + "xpack.snapshotRestore.editRepository.breadcrumbTitle": "编辑存储库", + "xpack.snapshotRestore.editRepository.loadingRepositoryDescription": "正在加载存储库详情……", + "xpack.snapshotRestore.editRepository.loadingRepositoryErrorTitle": "加载存储库详情时出错", + "xpack.snapshotRestore.editRepository.managedRepositoryWarningTitle": "这是托管存储库。更改此存储库可能会影响使用它的其他系统。请谨慎操作。", + "xpack.snapshotRestore.editRepository.repositoryNotFoundErrorMessage": "存储库“{name}”不存在。", + "xpack.snapshotRestore.editRepository.savingRepositoryErrorTitle": "无法保存存储库", + "xpack.snapshotRestore.editRepositoryTitle": "编辑存储库", + "xpack.snapshotRestore.emptyPrompt.noSnapshotsDocLinkText": "了解如何创建快照", + "xpack.snapshotRestore.emptyPrompt.usePolicyDocLinkText": "Elasticsearch API", + "xpack.snapshotRestore.executePolicy.confirmModal.cancelButtonLabel": "取消", + "xpack.snapshotRestore.executePolicy.confirmModal.confirmButtonLabel": "运行策略", + "xpack.snapshotRestore.executePolicy.confirmModal.executePolicyTitle": "立即运行“{name}”?", + "xpack.snapshotRestore.executePolicy.errorNotificationTitle": "运行策略“{name}”时出错", + "xpack.snapshotRestore.executePolicy.successNotificationTitle": "策略“{name}”正在运行", + "xpack.snapshotRestore.executeRetention.confirmModal.cancelButtonLabel": "取消", + "xpack.snapshotRestore.executeRetention.confirmModal.confirmButtonLabel": "运行保留", + "xpack.snapshotRestore.executeRetention.confirmModal.executeRetentionTitle": "立即运行快照保留?", + "xpack.snapshotRestore.executeRetention.errorMessage": "运行保留时出错", + "xpack.snapshotRestore.executeRetention.successMessage": "保留正在运行", + "xpack.snapshotRestore.home.breadcrumbTitle": "快照存储库", + "xpack.snapshotRestore.home.policiesTabTitle": "策略", + "xpack.snapshotRestore.home.repositoriesTabTitle": "存储库", + "xpack.snapshotRestore.home.restoreTabTitle": "还原状态", + "xpack.snapshotRestore.home.snapshotRestoreDescription": "使用存储库存储 Elasticsearch 索引和集群的备份。", + "xpack.snapshotRestore.home.snapshotRestoreDocsLinkText": "快照文档", + "xpack.snapshotRestore.home.snapshotRestoreTitle": "快照存储库", + "xpack.snapshotRestore.home.snapshotsTabTitle": "快照", + "xpack.snapshotRestore.policies.breadcrumbTitle": "策略", + "xpack.snapshotRestore.policyDetails.allIndicesLabel": "所有索引", + "xpack.snapshotRestore.policyDetails.closeButtonLabel": "关闭", + "xpack.snapshotRestore.policyDetails.deleteButtonLabel": "删除", + "xpack.snapshotRestore.policyDetails.editButtonLabel": "编辑", + "xpack.snapshotRestore.policyDetails.executeButtonLabel": "立即运行", + "xpack.snapshotRestore.policyDetails.expireAfterLabel": "在指定时间后删除:", + "xpack.snapshotRestore.policyDetails.generalTitle": "常规", + "xpack.snapshotRestore.policyDetails.historyTabTitle": "历史记录", + "xpack.snapshotRestore.policyDetails.ignoreUnavailableFalseLabel": "否", + "xpack.snapshotRestore.policyDetails.ignoreUnavailableLabel": "忽略不可用索引", + "xpack.snapshotRestore.policyDetails.ignoreUnavailableTrueLabel": "是", + "xpack.snapshotRestore.policyDetails.includeGlobalStateFalseLabel": "否", + "xpack.snapshotRestore.policyDetails.includeGlobalStateLabel": "包括全局状态", + "xpack.snapshotRestore.policyDetails.includeGlobalStateTrueLabel": "是", + "xpack.snapshotRestore.policyDetails.indicesCollapseAllLink": "隐藏 {count, plural, one {# 个索引} other {# 个索引}}", + "xpack.snapshotRestore.policyDetails.indicesLabel": "索引", + "xpack.snapshotRestore.policyDetails.indicesShowAllLink": "再显示 {count} 个 {count, plural, one {索引} other {索引}}", + "xpack.snapshotRestore.policyDetails.inProgressSnapshotLinkText": "“{snapshotName}”正在进行中", + "xpack.snapshotRestore.policyDetails.lastFailure.dateLabel": "日期", + "xpack.snapshotRestore.policyDetails.lastFailure.detailsAriaLabel": "策略“{name}”的上次失败详情", + "xpack.snapshotRestore.policyDetails.lastFailure.detailsLabel": "详情", + "xpack.snapshotRestore.policyDetails.lastFailure.snapshotNameLabel": "快照名称", + "xpack.snapshotRestore.policyDetails.lastFailureTitle": "上次快照失败", + "xpack.snapshotRestore.policyDetails.lastSuccess.dateLabel": "日期", + "xpack.snapshotRestore.policyDetails.lastSuccess.snapshotNameLabel": "快照名称", + "xpack.snapshotRestore.policyDetails.lastSuccessTitle": "上次成功快照", + "xpack.snapshotRestore.policyDetails.loadingPolicyDescription": "正在加载策略……", + "xpack.snapshotRestore.policyDetails.loadingPolicyErrorTitle": "加载策略时出错", + "xpack.snapshotRestore.policyDetails.manageButtonLabel": "管理策略", + "xpack.snapshotRestore.policyDetails.managePanelTitle": "策略选项", + "xpack.snapshotRestore.policyDetails.maxCountLabel": "最大计数", + "xpack.snapshotRestore.policyDetails.minCountLabel": "最小计数", + "xpack.snapshotRestore.policyDetails.modifiedDateLabel": "最后修改时间", + "xpack.snapshotRestore.policyDetails.nextExecutionLabel": "下一快照", + "xpack.snapshotRestore.policyDetails.noHistoryMessage": "此策略将在 {date} {time}运行。", + "xpack.snapshotRestore.policyDetails.partialFalseLabel": "否", + "xpack.snapshotRestore.policyDetails.partialLabel": "允许部分分片", + "xpack.snapshotRestore.policyDetails.partialTrueLabel": "是", + "xpack.snapshotRestore.policyDetails.policyNotFoundErrorMessage": "策略“{name}”不存在。", + "xpack.snapshotRestore.policyDetails.reloadButtonAriaLabel": "重新加载", + "xpack.snapshotRestore.policyDetails.repositoryLabel": "存储库", + "xpack.snapshotRestore.policyDetails.retentionTitle": "保留", + "xpack.snapshotRestore.policyDetails.scheduleLabel": "计划", + "xpack.snapshotRestore.policyDetails.snapshotDeletionFailuresStat": "删除失败", + "xpack.snapshotRestore.policyDetails.snapshotNameLabel": "快照名称", + "xpack.snapshotRestore.policyDetails.snapshotsDeletedStat": "已删除", + "xpack.snapshotRestore.policyDetails.snapshotsFailedStat": "失败", + "xpack.snapshotRestore.policyDetails.snapshotsTakenStat": "快照", + "xpack.snapshotRestore.policyDetails.summaryTabTitle": "总结", + "xpack.snapshotRestore.policyDetails.versionLabel": "版本", + "xpack.snapshotRestore.policyForm.addRepositoryButtonLabel": "注册存储库", + "xpack.snapshotRestore.policyForm.backButtonLabel": "上一步", + "xpack.snapshotRestore.policyForm.cancelButtonLabel": "取消", + "xpack.snapshotRestore.policyForm.createButtonLabel": "创建策略", + "xpack.snapshotRestore.policyForm.loadingRepositoriesDescription": "正在加载存储库……", + "xpack.snapshotRestore.policyForm.loadingRepositoriesErrorMessage": "加载存储库时出错", + "xpack.snapshotRestore.policyForm.navigation.stepLogisticsName": "运筹", + "xpack.snapshotRestore.policyForm.navigation.stepRetentionName": "快照保留", + "xpack.snapshotRestore.policyForm.navigation.stepReviewName": "复查", + "xpack.snapshotRestore.policyForm.navigation.stepSettingsName": "快照设置", + "xpack.snapshotRestore.policyForm.nextButtonLabel": "下一步", + "xpack.snapshotRestore.policyForm.noRepositoriesErrorMessage": "必须注册存储库,才能存储快照。", + "xpack.snapshotRestore.policyForm.noRepositoriesErrorTitle": "您未有任何存储库", + "xpack.snapshotRestore.policyForm.reloadRepositoriesButtonLabel": "重新加载存储库", + "xpack.snapshotRestore.policyForm.saveButtonLabel": "保存策略", + "xpack.snapshotRestore.policyForm.savingButtonLabel": "正在保存……", + "xpack.snapshotRestore.policyForm.stepLogistics.docsButtonLabel": "运筹文档", + "xpack.snapshotRestore.policyForm.stepLogistics.nameDescription": "此策略的唯一标识符。", + "xpack.snapshotRestore.policyForm.stepLogistics.nameDescriptionTitle": "策略名称", + "xpack.snapshotRestore.policyForm.stepLogistics.nameLabel": "名称", + "xpack.snapshotRestore.policyForm.stepLogistics.namePlaceholder": "每日快照", + "xpack.snapshotRestore.policyForm.stepLogistics.policyRepositoryLabel": "存储库", + "xpack.snapshotRestore.policyForm.stepLogistics.policyScheduleButtonAdvancedLabel": "创建 Cron 表达式", + "xpack.snapshotRestore.policyForm.stepLogistics.policyScheduleButtonBasicLabel": "创建基本间隔", + "xpack.snapshotRestore.policyForm.stepLogistics.policyScheduleHelpText": "使用 Cron 表达式。{docLink}", + "xpack.snapshotRestore.policyForm.stepLogistics.policyScheduleHelpTextDocLink": "了解详情。", + "xpack.snapshotRestore.policyForm.stepLogistics.policyScheduleLabel": "计划", + "xpack.snapshotRestore.policyForm.stepLogistics.policySnapshotNameHelpText": "支持日期匹配表达式。{docLink}", + "xpack.snapshotRestore.policyForm.stepLogistics.policySnapshotNameHelpTextDocLink": "了解详情。", + "xpack.snapshotRestore.policyForm.stepLogistics.policySnapshotNameLabel": "快照名称", + "xpack.snapshotRestore.policyForm.stepLogistics.policySnapshotNamePlaceholder": "<daily-snap-\\{now \\}>", + "xpack.snapshotRestore.policyForm.stepLogistics.repositoryDescription": "要用于存储快照的存储库。", + "xpack.snapshotRestore.policyForm.stepLogistics.repositoryDescriptionTitle": "存储库", + "xpack.snapshotRestore.policyForm.stepLogistics.scheduleDescription": "拍取快照的频率。", + "xpack.snapshotRestore.policyForm.stepLogistics.scheduleDescriptionTitle": "计划", + "xpack.snapshotRestore.policyForm.stepLogistics.snapshotNameDescription": "快照的名称。唯一标识符将自动添加到每个名称中。", + "xpack.snapshotRestore.policyForm.stepLogistics.snapshotNameDescriptionTitle": "快照名称", + "xpack.snapshotRestore.policyForm.stepLogisticsTitle": "运筹", + "xpack.snapshotRestore.policyForm.stepRetention.countDescription": "在您的集群中要存储的最小和最大快照数目。", + "xpack.snapshotRestore.policyForm.stepRetention.countTitle": "要保留的快照", + "xpack.snapshotRestore.policyForm.stepRetention.docsButtonLabel": "快照保留文档", + "xpack.snapshotRestore.policyForm.stepRetention.expirationDescription": "删除快照前要等候的时间。", + "xpack.snapshotRestore.policyForm.stepRetention.expirationTitle": "到期", + "xpack.snapshotRestore.policyForm.stepRetention.expireAfterLabel": "在指定时间后删除:", + "xpack.snapshotRestore.policyForm.stepRetention.maxCountLabel": "最大计数", + "xpack.snapshotRestore.policyForm.stepRetention.minCountLabel": "最小计数", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionAddTitle": "添加保留计划", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionAdvancedLabel": "创建 Cron 表达式", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionBasicLabel": "创建基本间隔", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionCancelButtonLabel": "取消", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionEditButtonLabel": "保存更改", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionEditTitle": "编辑保留计划", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionErrorTitle": "保存保留计划时出错", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionHelpText": "使用 Cron 表达式。{docLink}", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionHelpTextDocLinkText": "了解详情。", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionSaveButtonLabel": "计划", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionScheduleFieldErrorMessage": "保留计划必填。", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionScheduleLabel": "保留计划", + "xpack.snapshotRestore.policyForm.stepRetention.policyUpdateRetentionSuccessMessage": "保留计划已更新", + "xpack.snapshotRestore.policyForm.stepRetentionTitle": "快照保留(可选)", + "xpack.snapshotRestore.policyForm.stepReview.editIconAriaLabel": "编辑步长", + "xpack.snapshotRestore.policyForm.stepReview.requestTabTitle": "请求", + "xpack.snapshotRestore.policyForm.stepReview.retentionTab.expireAfterLabel": "在指定时间后删除:", + "xpack.snapshotRestore.policyForm.stepReview.retentionTab.maxCountLabel": "最大计数", + "xpack.snapshotRestore.policyForm.stepReview.retentionTab.minCountLabel": "最小计数", + "xpack.snapshotRestore.policyForm.stepReview.retentionTab.sectionRetentionTitle": "快照保留", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.allIndicesValue": "所有索引", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.editStepTooltip": "编辑", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.ignoreUnavailableFalseLabel": "否", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.ignoreUnavailableLabel": "忽略不可用索引", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.ignoreUnavailableTrueLabel": "是", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.includeGlobalStateFalseLabel": "否", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.includeGlobalStateLabel": "包括全局状态", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.includeGlobalStateTrueLabel": "是", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.indicesCollapseAllLink": "隐藏 {count, plural, one {# 个索引} other {# 个索引}}", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.indicesLabel": "索引", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.indicesShowAllLink": "再显示 {count} 个 {count, plural, one {索引} other {索引}}", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.nameLabel": "策略名称", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.partialFalseLabel": "否", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.partialLabel": "允许部分分片", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.partialTrueLabel": "是", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.repositoryLabel": "存储库", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.scheduleLabel": "计划", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.sectionLogisticsTitle": "运筹", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.sectionSettingsTitle": "快照设置", + "xpack.snapshotRestore.policyForm.stepReview.summaryTab.snapshotNameLabel": "快照名称", + "xpack.snapshotRestore.policyForm.stepReview.summaryTabTitle": "总结", + "xpack.snapshotRestore.policyForm.stepReviewTitle": "复查策略", + "xpack.snapshotRestore.policyForm.stepSettings.allIndicesLabel": "所有索引,包括系统索引", + "xpack.snapshotRestore.policyForm.stepSettings.deselectAllIndicesLink": "取消全选", + "xpack.snapshotRestore.policyForm.stepSettings.docsButtonLabel": "快照设置文档", + "xpack.snapshotRestore.policyForm.stepSettings.ignoreUnavailableDescription": "拍取快照时忽略不可用的索引。否则,整个快照将失败。", + "xpack.snapshotRestore.policyForm.stepSettings.ignoreUnavailableDescriptionTitle": "忽略不可用索引", + "xpack.snapshotRestore.policyForm.stepSettings.ignoreUnavailableLabel": "忽略不可用索引", + "xpack.snapshotRestore.policyForm.stepSettings.includeGlobalStateDescription": "将集群的全局状态存储为快照的一部分。", + "xpack.snapshotRestore.policyForm.stepSettings.includeGlobalStateDescriptionTitle": "包括全局状态", + "xpack.snapshotRestore.policyForm.stepSettings.indicesDescription": "要备份的索引。", + "xpack.snapshotRestore.policyForm.stepSettings.indicesPatternLabel": "索引模式", + "xpack.snapshotRestore.policyForm.stepSettings.indicesPatternPlaceholder": "输入索引模式,例如 logstash-*", + "xpack.snapshotRestore.policyForm.stepSettings.indicesTitle": "索引", + "xpack.snapshotRestore.policyForm.stepSettings.indicesToggleCustomLink": "使用索引模式", + "xpack.snapshotRestore.policyForm.stepSettings.indicesToggleListLink": "选择索引", + "xpack.snapshotRestore.policyForm.stepSettings.partialDescription": "允许具有不可用主分片的索引的快照。否则,整个快照将失败。", + "xpack.snapshotRestore.policyForm.stepSettings.partialDescriptionTitle": "允许部分索引", + "xpack.snapshotRestore.policyForm.stepSettings.partialIndicesToggleSwitch": "允许部分索引", + "xpack.snapshotRestore.policyForm.stepSettings.policyIncludeGlobalStateLabel": "包括全局状态", + "xpack.snapshotRestore.policyForm.stepSettings.selectAllIndicesLink": "全选", + "xpack.snapshotRestore.policyForm.stepSettings.selectIndicesHelpText": "将备份 {count} 个 {count, plural, one {索引} other {索引}}。{selectOrDeselectAllLink}", + "xpack.snapshotRestore.policyForm.stepSettings.selectIndicesLabel": "选择索引", + "xpack.snapshotRestore.policyForm.stepSettingsTitle": "快照设置", + "xpack.snapshotRestore.policyList.deniedPrivilegeDescription": "要管理快照生命周期策略,必须具有{privilegesCount, plural, one {以下集群权限} other {以下集群权限}}:{missingPrivileges}。", + "xpack.snapshotRestore.policyList.deniedPrivilegeTitle": "您缺少集群权限", + "xpack.snapshotRestore.policyList.emptyPromptDescription": "创建自动备份集群的策略。", + "xpack.snapshotRestore.policyList.emptyPromptTitle": "您尚未有任何快照策略", + "xpack.snapshotRestore.policyList.loadingPoliciesDescription": "正在加载策略……", + "xpack.snapshotRestore.policyList.LoadingPoliciesErrorMessage": "加载策略时出错", + "xpack.snapshotRestore.policyList.table.actionDeleteAriaLabel": "删除策略“{name}”", + "xpack.snapshotRestore.policyList.table.actionDeleteTooltip": "删除", + "xpack.snapshotRestore.policyList.table.actionEditAriaLabel": "编辑策略“{name}”", + "xpack.snapshotRestore.policyList.table.actionEditTooltip": "编辑", + "xpack.snapshotRestore.policyList.table.actionExecuteAriaLabel": "立即运行“{name}”", + "xpack.snapshotRestore.policyList.table.actionExecuteDisabledTooltip": "策略正在运行", + "xpack.snapshotRestore.policyList.table.actionExecuteTooltip": "立即运行", + "xpack.snapshotRestore.policyList.table.actionsColumnTitle": "操作", + "xpack.snapshotRestore.policyList.table.addPolicyButton": "创建策略", + "xpack.snapshotRestore.policyList.table.deletePolicyButton": "删除{count, plural, one {策略} other {策略}}", + "xpack.snapshotRestore.policyList.table.inProgressTooltip": "快照进行中", + "xpack.snapshotRestore.policyList.table.lastSnapshotFailedTooltip": "上次快照失败", + "xpack.snapshotRestore.policyList.table.nextExecutionColumnTitle": "下一快照", + "xpack.snapshotRestore.policyList.table.policyNameColumnTitle": "政策", + "xpack.snapshotRestore.policyList.table.reloadPoliciesButton": "重新加载", + "xpack.snapshotRestore.policyList.table.repositoryColumnTitle": "存储库", + "xpack.snapshotRestore.policyList.table.repositoryFilterLabel": "存储库", + "xpack.snapshotRestore.policyList.table.retentionColumnAriaLabel": "已配置保留", + "xpack.snapshotRestore.policyList.table.retentionColumnTitle": "保留", + "xpack.snapshotRestore.policyList.table.scheduleColumnTitle": "计划", + "xpack.snapshotRestore.policyList.table.snapshotNameColumnTitle": "快照名称", + "xpack.snapshotRestore.policyRetentionSchedulePanel.addButtonLabel": "计划", + "xpack.snapshotRestore.policyRetentionSchedulePanel.errorFetchingRetentionScheduleReloadButtonLabel": "重新加载", + "xpack.snapshotRestore.policyRetentionSchedulePanel.errorFetchingRetentionScheduleTitle": "获取保留计划时出错", + "xpack.snapshotRestore.policyRetentionSchedulePanel.executeButtonLabel": "立即运行", + "xpack.snapshotRestore.policyRetentionSchedulePanel.managePanelTitle": "保留选项", + "xpack.snapshotRestore.policyRetentionSchedulePanel.manageRetentionButtonLabel": "管理保留", + "xpack.snapshotRestore.policyRetentionSchedulePanel.noScheduleConfiguredWarningDescription": "一个或多个策略具有保留期间,但未计划保留。", + "xpack.snapshotRestore.policyRetentionSchedulePanel.noScheduleConfiguredWarningTitle": "保留未计划", + "xpack.snapshotRestore.policyRetentionSchedulePanel.retentionScheduleDescription": "保留快照的 cron 计划是:{cronSchedule}。", + "xpack.snapshotRestore.policyRetentionSchedulePanel.retentionScheduleEditLinkAriaLabel": "编辑保留计划", + "xpack.snapshotRestore.policyRetentionSchedulePanel.retentionScheduleEditLinkTooltip": "编辑保留计划", + "xpack.snapshotRestore.policyRetentionSchedulePanel.retentionScheduleExecuteLinkAriaLabel": "立即运行保留", + "xpack.snapshotRestore.policyRetentionSchedulePanel.retentionScheduleExecuteLinkTooltip": "立即运行保留", + "xpack.snapshotRestore.policyScheduleWarningDescription": "一次仅可以拍取一个快照。要避免快照失败,请编辑或删除策略。", + "xpack.snapshotRestore.policyScheduleWarningTitle": "两个或更多策略有相同的计划", + "xpack.snapshotRestore.policyValidation.indexPatternRequiredErrorMessage": "至少需要一个索引模式。", + "xpack.snapshotRestore.policyValidation.indicesRequiredErrorMessage": "必须至少选择一个索引。", + "xpack.snapshotRestore.policyValidation.invalidMinCountErrorMessage": "最小计数不能大于最大计数。", + "xpack.snapshotRestore.policyValidation.nameRequiredErroMessage": "策略名称必填。", + "xpack.snapshotRestore.policyValidation.repositoryRequiredErrorMessage": "存储库必填。", + "xpack.snapshotRestore.policyValidation.scheduleRequiredErrorMessage": "计划必填。", + "xpack.snapshotRestore.policyValidation.snapshotNameRequiredErrorMessage": "快照名称必填。", + "xpack.snapshotRestore.repositories.breadcrumbTitle": "存储库", + "xpack.snapshotRestore.repositoryDetails.closeButtonLabel": "关闭", + "xpack.snapshotRestore.repositoryDetails.editButtonLabel": "编辑", + "xpack.snapshotRestore.repositoryDetails.genericSettingsDescription": "存储库“{name}”的只读设置", + "xpack.snapshotRestore.repositoryDetails.loadingRepositoryDescription": "正在加载存储库……", + "xpack.snapshotRestore.repositoryDetails.loadingRepositoryErrorTitle": "加载存储库时出错", + "xpack.snapshotRestore.repositoryDetails.managedRepositoryWarningTitle": "这是其他系统使用的托管存储库。您所做的任何更改可能会影响这些系统的运行方式。", + "xpack.snapshotRestore.repositoryDetails.noSnapshotInformationDescription": "无快照信息", + "xpack.snapshotRestore.repositoryDetails.removeButtonLabel": "删除", + "xpack.snapshotRestore.repositoryDetails.removeManagedRepositoryButtonTitle": "您无法删除托管存储库。", + "xpack.snapshotRestore.repositoryDetails.repositoryNotFoundErrorMessage": "存储库“{name}”不存在。", + "xpack.snapshotRestore.repositoryDetails.repositoryTypeDocLink": "存储库文档", + "xpack.snapshotRestore.repositoryDetails.settingsTitle": "设置", + "xpack.snapshotRestore.repositoryDetails.snapshotsDescription": "找到 {count} 个 {count, plural, one {快照} other {快照}}", + "xpack.snapshotRestore.repositoryDetails.snapshotsTitle": "快照", + "xpack.snapshotRestore.repositoryDetails.typeAzure.basePathLabel": "基路径", + "xpack.snapshotRestore.repositoryDetails.typeAzure.chunkSizeLabel": "块大小", + "xpack.snapshotRestore.repositoryDetails.typeAzure.clientLabel": "客户端", + "xpack.snapshotRestore.repositoryDetails.typeAzure.compressLabel": "快照压缩", + "xpack.snapshotRestore.repositoryDetails.typeAzure.containerLabel": "容器", + "xpack.snapshotRestore.repositoryDetails.typeAzure.locationModeLabel": "位置模式", + "xpack.snapshotRestore.repositoryDetails.typeAzure.maxRestoreBytesLabel": "每秒最大还原字节数", + "xpack.snapshotRestore.repositoryDetails.typeAzure.maxSnapshotBytesLabel": "每秒最大快照字节数", + "xpack.snapshotRestore.repositoryDetails.typeAzure.readonlyLabel": "只读", + "xpack.snapshotRestore.repositoryDetails.typeFS.chunkSizeLabel": "块大小", + "xpack.snapshotRestore.repositoryDetails.typeFS.compressLabel": "快照压缩", + "xpack.snapshotRestore.repositoryDetails.typeFS.locationLabel": "位置", + "xpack.snapshotRestore.repositoryDetails.typeFS.maxRestoreBytesLabel": "每秒最大还原字节数", + "xpack.snapshotRestore.repositoryDetails.typeFS.maxSnapshotBytesLabel": "每秒最大快照字节数", + "xpack.snapshotRestore.repositoryDetails.typeFS.readonlyLabel": "只读", + "xpack.snapshotRestore.repositoryDetails.typeGCS.basePathLabel": "基路径", + "xpack.snapshotRestore.repositoryDetails.typeGCS.bucketLabel": "存储桶", + "xpack.snapshotRestore.repositoryDetails.typeGCS.chunkSizeLabel": "块大小", + "xpack.snapshotRestore.repositoryDetails.typeGCS.clientLabel": "客户端", + "xpack.snapshotRestore.repositoryDetails.typeGCS.compressLabel": "快照压缩", + "xpack.snapshotRestore.repositoryDetails.typeGCS.maxRestoreBytesLabel": "每秒最大还原字节数", + "xpack.snapshotRestore.repositoryDetails.typeGCS.maxSnapshotBytesLabel": "每秒最大快照字节数", + "xpack.snapshotRestore.repositoryDetails.typeGCS.readonlyLabel": "只读", + "xpack.snapshotRestore.repositoryDetails.typeHDFS.chunkSizeLabel": "块大小", + "xpack.snapshotRestore.repositoryDetails.typeHDFS.compressLabel": "快照压缩", + "xpack.snapshotRestore.repositoryDetails.typeHDFS.loadDefaultsLabel": "加载默认值", + "xpack.snapshotRestore.repositoryDetails.typeHDFS.maxRestoreBytesLabel": "每秒最大还原字节数", + "xpack.snapshotRestore.repositoryDetails.typeHDFS.maxSnapshotBytesLabel": "每秒最大快照字节数", + "xpack.snapshotRestore.repositoryDetails.typeHDFS.pathLabel": "路径", + "xpack.snapshotRestore.repositoryDetails.typeHDFS.readonlyLabel": "只读", + "xpack.snapshotRestore.repositoryDetails.typeHDFS.securityPrincipalLabel": "安全主体", + "xpack.snapshotRestore.repositoryDetails.typeHDFS.uriLabel": "URI", + "xpack.snapshotRestore.repositoryDetails.typeReadonly.urlLabel": "URL", + "xpack.snapshotRestore.repositoryDetails.typeS3.basePathLabel": "基路径", + "xpack.snapshotRestore.repositoryDetails.typeS3.bucketLabel": "存储桶", + "xpack.snapshotRestore.repositoryDetails.typeS3.bufferSizeLabel": "缓冲区大小", + "xpack.snapshotRestore.repositoryDetails.typeS3.cannedAclLabel": "标准 ACL", + "xpack.snapshotRestore.repositoryDetails.typeS3.chunkSizeLabel": "块大小", + "xpack.snapshotRestore.repositoryDetails.typeS3.clientLabel": "客户端", + "xpack.snapshotRestore.repositoryDetails.typeS3.compressLabel": "快照压缩", + "xpack.snapshotRestore.repositoryDetails.typeS3.maxRestoreBytesLabel": "每秒最大还原字节数", + "xpack.snapshotRestore.repositoryDetails.typeS3.maxSnapshotBytesLabel": "每秒最大快照字节数", + "xpack.snapshotRestore.repositoryDetails.typeS3.readonlyLabel": "只读", + "xpack.snapshotRestore.repositoryDetails.typeS3.serverSideEncryptionLabel": "服务器端加密", + "xpack.snapshotRestore.repositoryDetails.typeS3.storageClassLabel": "存储类", + "xpack.snapshotRestore.repositoryDetails.typeTitle": "存储库类型", + "xpack.snapshotRestore.repositoryDetails.verificationDetailsTitle": "详情", + "xpack.snapshotRestore.repositoryDetails.verificationTitle": "验证状态", + "xpack.snapshotRestore.repositoryDetails.verifyButtonLabel": "验证存储库", + "xpack.snapshotRestore.repositoryDetails.zeroSnapshotsDescription": "存储库没有快照", + "xpack.snapshotRestore.repositoryFor.typeFS.locationDescription": "必须在所有主节点和数据节点上的 {settingKey} 设置中注册该位置。", + "xpack.snapshotRestore.repositoryForm.backButtonLabel": "上一步", + "xpack.snapshotRestore.repositoryForm.errorUnknownRepositoryTypesMessage": "存储库类型“{type}”不受支持。", + "xpack.snapshotRestore.repositoryForm.errorUnknownRepositoryTypesTitle": "未知的存储库类型", + "xpack.snapshotRestore.repositoryForm.fields.cloudTypeDescription": "Elasticsearch 为定制存储库提供核心插件。{docLink}", + "xpack.snapshotRestore.repositoryForm.fields.defaultTypeDescription": "Elasticsearch 支持文件系统和只读 URL 存储库。其他类型需要插件。{docLink}", + "xpack.snapshotRestore.repositoryForm.fields.nameDescription": "存储库的唯一名称。", + "xpack.snapshotRestore.repositoryForm.fields.nameDescriptionTitle": "存储库名称", + "xpack.snapshotRestore.repositoryForm.fields.nameLabel": "名称", + "xpack.snapshotRestore.repositoryForm.fields.settingsTitle": "{repositoryName} 设置", + "xpack.snapshotRestore.repositoryForm.fields.sourceOnlyDescription": "创建仅限于源的快照,其最多占用 50% 空间。{docLink}", + "xpack.snapshotRestore.repositoryForm.fields.sourceOnlyDescriptionTitle": "仅限于源的快照", + "xpack.snapshotRestore.repositoryForm.fields.sourceOnlyDocLinkText": "详细了解仅限于源的存储库。", + "xpack.snapshotRestore.repositoryForm.fields.sourceOnlyLabel": "仅限于源的快照", + "xpack.snapshotRestore.repositoryForm.fields.typeDescriptionTitle": "存储库类型", + "xpack.snapshotRestore.repositoryForm.fields.typeDocsLinkText": "了解详情", + "xpack.snapshotRestore.repositoryForm.fields.typePluginsDocLinkText": "详细了解插件。", + "xpack.snapshotRestore.repositoryForm.loadingRepositoryTypesDescription": "正在加载存储库类型……", + "xpack.snapshotRestore.repositoryForm.loadingRepositoryTypesErrorMessage": "加载存储库类型时出错", + "xpack.snapshotRestore.repositoryForm.nextButtonLabel": "下一个", + "xpack.snapshotRestore.repositoryForm.noRepositoryTypesErrorMessage": "您可以安装插件以启用不同的存储库类型。{docLink}", + "xpack.snapshotRestore.repositoryForm.noRepositoryTypesErrorTitle": "没有可用的存储库类型", + "xpack.snapshotRestore.repositoryForm.registerButtonLabel": "注册", + "xpack.snapshotRestore.repositoryForm.repositoryTypeDocLink": "{repositoryType} 存储库文档", + "xpack.snapshotRestore.repositoryForm.saveButtonLabel": "保存", + "xpack.snapshotRestore.repositoryForm.savingButtonLabel": "正在保存……", + "xpack.snapshotRestore.repositoryForm.typeAzure.basePathDescription": "存储库数据的容器路径。", + "xpack.snapshotRestore.repositoryForm.typeAzure.basePathLabel": "基路径", + "xpack.snapshotRestore.repositoryForm.typeAzure.basePathTitle": "基路径", + "xpack.snapshotRestore.repositoryForm.typeAzure.chunkSizeDescription": "拍取快照时,将文件拆分成更小的单位。", + "xpack.snapshotRestore.repositoryForm.typeAzure.chunkSizeLabel": "块大小", + "xpack.snapshotRestore.repositoryForm.typeAzure.chunkSizeTitle": "块大小", + "xpack.snapshotRestore.repositoryForm.typeAzure.clientDescription": "Azure 客户端的名称。", + "xpack.snapshotRestore.repositoryForm.typeAzure.clientLabel": "客户端", + "xpack.snapshotRestore.repositoryForm.typeAzure.clientTitle": "客户端", + "xpack.snapshotRestore.repositoryForm.typeAzure.compressDescription": "压缩快照的索引映射和设置文件。数据文件未压缩。", + "xpack.snapshotRestore.repositoryForm.typeAzure.compressLabel": "压缩快照", + "xpack.snapshotRestore.repositoryForm.typeAzure.compressTitle": "快照压缩", + "xpack.snapshotRestore.repositoryForm.typeAzure.containerDescription": "要用于快照的 Azure 容器的名称。", + "xpack.snapshotRestore.repositoryForm.typeAzure.containerLabel": "容器", + "xpack.snapshotRestore.repositoryForm.typeAzure.containerTitle": "容器", + "xpack.snapshotRestore.repositoryForm.typeAzure.locationModeDescription": "主要位置或辅助位置。如果为辅助位置,则只读为 true。", + "xpack.snapshotRestore.repositoryForm.typeAzure.locationModeLabel": "位置模式", + "xpack.snapshotRestore.repositoryForm.typeAzure.locationModeTitle": "位置模式", + "xpack.snapshotRestore.repositoryForm.typeAzure.maxRestoreBytesDescription": "每个节点的快照还原速率。", + "xpack.snapshotRestore.repositoryForm.typeAzure.maxRestoreBytesLabel": "每秒最大还原字节数", + "xpack.snapshotRestore.repositoryForm.typeAzure.maxRestoreBytesTitle": "每秒最大还原字节数", + "xpack.snapshotRestore.repositoryForm.typeAzure.maxSnapshotBytesDescription": "为每个节点创建快照的速率。", + "xpack.snapshotRestore.repositoryForm.typeAzure.maxSnapshotBytesLabel": "每秒最大快照字节数", + "xpack.snapshotRestore.repositoryForm.typeAzure.maxSnapshotBytesTitle": "每秒最大快照字节数", + "xpack.snapshotRestore.repositoryForm.typeAzure.readonlyDescription": "仅一个集群应对此存储库有写权限。所有其他集群应为只读。", + "xpack.snapshotRestore.repositoryForm.typeAzure.readonlyLabel": "只读存储库", + "xpack.snapshotRestore.repositoryForm.typeAzure.readonlyTitle": "只读", + "xpack.snapshotRestore.repositoryForm.typeFS.chunkSizeDescription": "拍取快照时,将文件拆分成更小的单位。", + "xpack.snapshotRestore.repositoryForm.typeFS.chunkSizeLabel": "块大小", + "xpack.snapshotRestore.repositoryForm.typeFS.chunkSizeTitle": "块大小", + "xpack.snapshotRestore.repositoryForm.typeFS.compressDescription": "压缩快照的索引映射和设置文件。数据文件未压缩。", + "xpack.snapshotRestore.repositoryForm.typeFS.compressLabel": "压缩快照", + "xpack.snapshotRestore.repositoryForm.typeFS.compressTitle": "快照压缩", + "xpack.snapshotRestore.repositoryForm.typeFS.locationLabel": "位置(必填)", + "xpack.snapshotRestore.repositoryForm.typeFS.locationTitle": "文件系统位置", + "xpack.snapshotRestore.repositoryForm.typeFS.maxRestoreBytesDescription": "每个节点的快照还原速率。", + "xpack.snapshotRestore.repositoryForm.typeFS.maxRestoreBytesLabel": "每秒最大还原字节数", + "xpack.snapshotRestore.repositoryForm.typeFS.maxRestoreBytesTitle": "每秒最大还原字节数", + "xpack.snapshotRestore.repositoryForm.typeFS.maxSnapshotBytesDescription": "为每个节点创建快照的速率。", + "xpack.snapshotRestore.repositoryForm.typeFS.maxSnapshotBytesLabel": "每秒最大快照字节数", + "xpack.snapshotRestore.repositoryForm.typeFS.maxSnapshotBytesTitle": "每秒最大快照字节数", + "xpack.snapshotRestore.repositoryForm.typeFS.readonlyDescription": "仅一个集群应对此存储库有写权限。所有其他集群应为只读。", + "xpack.snapshotRestore.repositoryForm.typeFS.readonlyLabel": "只读存储库", + "xpack.snapshotRestore.repositoryForm.typeFS.readonlyTitle": "只读", + "xpack.snapshotRestore.repositoryForm.typeGCS.basePathDescription": "存储库数据的存储桶路径。", + "xpack.snapshotRestore.repositoryForm.typeGCS.basePathLabel": "基路径", + "xpack.snapshotRestore.repositoryForm.typeGCS.basePathTitle": "基路径", + "xpack.snapshotRestore.repositoryForm.typeGCS.bucketDescription": "要用于快照的 Google Cloud Storage 存储桶的名称。", + "xpack.snapshotRestore.repositoryForm.typeGCS.bucketLabel": "存储桶(必填)", + "xpack.snapshotRestore.repositoryForm.typeGCS.bucketTitle": "存储桶", + "xpack.snapshotRestore.repositoryForm.typeGCS.chunkSizeDescription": "拍取快照时,将文件拆分成更小的单位。", + "xpack.snapshotRestore.repositoryForm.typeGCS.chunkSizeLabel": "块大小", + "xpack.snapshotRestore.repositoryForm.typeGCS.chunkSizeTitle": "块大小", + "xpack.snapshotRestore.repositoryForm.typeGCS.clientDescription": "Google Cloud Storage 客户端的名称。", + "xpack.snapshotRestore.repositoryForm.typeGCS.clientLabel": "客户端", + "xpack.snapshotRestore.repositoryForm.typeGCS.clientTitle": "客户端", + "xpack.snapshotRestore.repositoryForm.typeGCS.compressDescription": "压缩快照的索引映射和设置文件。数据文件未压缩。", + "xpack.snapshotRestore.repositoryForm.typeGCS.compressLabel": "压缩快照", + "xpack.snapshotRestore.repositoryForm.typeGCS.compressTitle": "压缩快照", + "xpack.snapshotRestore.repositoryForm.typeGCS.maxRestoreBytesDescription": "每个节点的快照还原速率。", + "xpack.snapshotRestore.repositoryForm.typeGCS.maxRestoreBytesLabel": "每秒最大还原字节数", + "xpack.snapshotRestore.repositoryForm.typeGCS.maxRestoreBytesTitle": "每秒最大还原字节数", + "xpack.snapshotRestore.repositoryForm.typeGCS.maxSnapshotBytesDescription": "为每个节点创建快照的速率。", + "xpack.snapshotRestore.repositoryForm.typeGCS.maxSnapshotBytesLabel": "每秒最大快照字节数", + "xpack.snapshotRestore.repositoryForm.typeGCS.maxSnapshotBytesTitle": "每秒最大快照字节数", + "xpack.snapshotRestore.repositoryForm.typeGCS.readonlyDescription": "仅一个集群应对此存储库有写权限。所有其他集群应为只读。", + "xpack.snapshotRestore.repositoryForm.typeGCS.readonlyLabel": "只读存储库", + "xpack.snapshotRestore.repositoryForm.typeGCS.readonlyTitle": "只读", + "xpack.snapshotRestore.repositoryForm.typeHDFS.chunkSizeDescription": "拍取快照时,将文件拆分成更小的单位。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.chunkSizeLabel": "块大小", + "xpack.snapshotRestore.repositoryForm.typeHDFS.chunkSizeTitle": "块大小", + "xpack.snapshotRestore.repositoryForm.typeHDFS.compressDescription": "压缩快照的索引映射和设置文件。数据文件未压缩。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.compressLabel": "压缩快照", + "xpack.snapshotRestore.repositoryForm.typeHDFS.compressTitle": "快照压缩", + "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationAriaLabel": "HDFS 存储桶“{name}”的其他配置", + "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationDescription": "要添加到 Hadoop 配置的其他 JSON 格式配置参数。仅会识别 Hadoop core 和 HDFS 文件的面向客户端的属性。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationFormatError": "JSON 格式无效", + "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationKeyDescription": "键的格式应为 {confKeyFormat}。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationLabel": "配置", + "xpack.snapshotRestore.repositoryForm.typeHDFS.configurationTitle": "配置", + "xpack.snapshotRestore.repositoryForm.typeHDFS.loadDefaultsDescription": "加载默认的 Hadoop 配置。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.loadDefaultsLabel": "加载默认值", + "xpack.snapshotRestore.repositoryForm.typeHDFS.loadDefaultsTitle": "加载默认值", + "xpack.snapshotRestore.repositoryForm.typeHDFS.maxRestoreBytesDescription": "每个节点的快照还原速率。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.maxRestoreBytesLabel": "每秒最大还原字节数", + "xpack.snapshotRestore.repositoryForm.typeHDFS.maxRestoreBytesTitle": "每秒最大还原字节数", + "xpack.snapshotRestore.repositoryForm.typeHDFS.maxSnapshotBytesDescription": "为每个节点创建快照的速率。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.maxSnapshotBytesLabel": "每秒最大快照字节数", + "xpack.snapshotRestore.repositoryForm.typeHDFS.maxSnapshotBytesTitle": "每秒最大快照字节数", + "xpack.snapshotRestore.repositoryForm.typeHDFS.pathDescription": "存储数据的文件路径。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.pathLabel": "路径(必填)", + "xpack.snapshotRestore.repositoryForm.typeHDFS.pathTitle": "路径", + "xpack.snapshotRestore.repositoryForm.typeHDFS.readonlyDescription": "仅一个集群应对此存储库有写权限。所有其他集群应为只读。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.readonlyLabel": "只读存储库", + "xpack.snapshotRestore.repositoryForm.typeHDFS.readonlyTitle": "只读", + "xpack.snapshotRestore.repositoryForm.typeHDFS.securityPrincipalDescription": "连接到安全 HDFS 集群时要使用的 Kerberos 主体。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.securityPrincipalLabel": "安全主体", + "xpack.snapshotRestore.repositoryForm.typeHDFS.securityPrincipalTitle": "安全主体", + "xpack.snapshotRestore.repositoryForm.typeHDFS.uriDescription": "HDFS 的 URI 地址。", + "xpack.snapshotRestore.repositoryForm.typeHDFS.uriLabel": "URI(必填)", + "xpack.snapshotRestore.repositoryForm.typeHDFS.uriTitle": "URI", + "xpack.snapshotRestore.repositoryForm.typeReadonly.urlDescription": "快照的位置。", + "xpack.snapshotRestore.repositoryForm.typeReadonly.urlFilePathDescription": "必须在 {settingKey} 设置中注册此文件位置。", + "xpack.snapshotRestore.repositoryForm.typeReadonly.urlLabel": "路径(必填)", + "xpack.snapshotRestore.repositoryForm.typeReadonly.urlSchemeLabel": "方案", + "xpack.snapshotRestore.repositoryForm.typeReadonly.urlTitle": "URL", + "xpack.snapshotRestore.repositoryForm.typeReadonly.urlWhitelistDescription": "必须在 {settingKey} 设置中注册此 URL。", + "xpack.snapshotRestore.repositoryForm.typeS3.basePathDescription": "存储库数据的存储桶路径。", + "xpack.snapshotRestore.repositoryForm.typeS3.basePathLabel": "基路径", + "xpack.snapshotRestore.repositoryForm.typeS3.basePathTitle": "基路径", + "xpack.snapshotRestore.repositoryForm.typeS3.bucketDescription": "要用于快照的 AWS S3 存储桶的名称。", + "xpack.snapshotRestore.repositoryForm.typeS3.bucketLabel": "存储桶(必填)", + "xpack.snapshotRestore.repositoryForm.typeS3.bucketTitle": "存储桶", + "xpack.snapshotRestore.repositoryForm.typeS3.bufferSizeDescription": "超过此最小阈值后,S3 存储库将使用 AWS 分段上传 API 将块拆分成多个部分,并分别使用请求上传各个部分。", + "xpack.snapshotRestore.repositoryForm.typeS3.bufferSizeLabel": "缓冲区大小", + "xpack.snapshotRestore.repositoryForm.typeS3.bufferSizeTitle": "缓冲区大小", + "xpack.snapshotRestore.repositoryForm.typeS3.cannedAclDescription": "要添加到新 S3 存储库和对象的标准 ACL。", + "xpack.snapshotRestore.repositoryForm.typeS3.cannedAclLabel": "标准 ACL", + "xpack.snapshotRestore.repositoryForm.typeS3.cannedAclTitle": "标准 ACL", + "xpack.snapshotRestore.repositoryForm.typeS3.chunkSizeDescription": "拍取快照时,将文件拆分成更小的单位。", + "xpack.snapshotRestore.repositoryForm.typeS3.chunkSizeLabel": "块大小", + "xpack.snapshotRestore.repositoryForm.typeS3.chunkSizeTitle": "块大小", + "xpack.snapshotRestore.repositoryForm.typeS3.clientDescription": "AWS S3 客户端的名称。", + "xpack.snapshotRestore.repositoryForm.typeS3.clientLabel": "客户端", + "xpack.snapshotRestore.repositoryForm.typeS3.clientTitle": "客户端", + "xpack.snapshotRestore.repositoryForm.typeS3.compressDescription": "压缩快照的索引映射和设置文件。数据文件未压缩。", + "xpack.snapshotRestore.repositoryForm.typeS3.compressLabel": "压缩快照", + "xpack.snapshotRestore.repositoryForm.typeS3.compressTitle": "快照压缩", + "xpack.snapshotRestore.repositoryForm.typeS3.maxRestoreBytesDescription": "每个节点的快照还原速率。", + "xpack.snapshotRestore.repositoryForm.typeS3.maxRestoreBytesLabel": "每秒最大还原字节数", + "xpack.snapshotRestore.repositoryForm.typeS3.maxRestoreBytesTitle": "每秒最大还原字节数", + "xpack.snapshotRestore.repositoryForm.typeS3.maxSnapshotBytesDescription": "为每个节点创建快照的速率。", + "xpack.snapshotRestore.repositoryForm.typeS3.maxSnapshotBytesLabel": "每秒最大快照字节数", + "xpack.snapshotRestore.repositoryForm.typeS3.maxSnapshotBytesTitle": "每秒最大快照字节数", + "xpack.snapshotRestore.repositoryForm.typeS3.readonlyDescription": "仅一个集群应对此存储库有写权限。所有其他集群应为只读。", + "xpack.snapshotRestore.repositoryForm.typeS3.readonlyLabel": "只读存储库", + "xpack.snapshotRestore.repositoryForm.typeS3.readonlyTitle": "只读", + "xpack.snapshotRestore.repositoryForm.typeS3.serverSideEncryptionDescription": "使用 AES256 算法加密服务器上的文件。", + "xpack.snapshotRestore.repositoryForm.typeS3.serverSideEncryptionLabel": "服务器端加密", + "xpack.snapshotRestore.repositoryForm.typeS3.serverSideEncryptionTitle": "服务器端加密", + "xpack.snapshotRestore.repositoryForm.typeS3.storageClassDescription": "S3 存储库中新对象的存储类。", + "xpack.snapshotRestore.repositoryForm.typeS3.storageClassLabel": "存储类", + "xpack.snapshotRestore.repositoryForm.typeS3.storageClassTitle": "存储类", + "xpack.snapshotRestore.repositoryForm.validationErrorTitle": "继续前请解决错误。", + "xpack.snapshotRestore.repositoryList.addRepositoryButtonLabel": "注册存储库", + "xpack.snapshotRestore.repositoryList.emptyPromptDescription": "您需要用来存储快照的存储库。", + "xpack.snapshotRestore.repositoryList.emptyPromptTitle": "您未有任何存储库", + "xpack.snapshotRestore.repositoryList.loadingRepositoriesDescription": "正在加载存储库……", + "xpack.snapshotRestore.repositoryList.LoadingRepositoriesErrorMessage": "加载存储库时出错", + "xpack.snapshotRestore.repositoryList.table.actionEditAriaLabel": "编辑存储库 `{name}`", + "xpack.snapshotRestore.repositoryList.table.actionEditTooltip": "编辑", + "xpack.snapshotRestore.repositoryList.table.actionRemoveAriaLabel": "移除存储库 `{name}`", + "xpack.snapshotRestore.repositoryList.table.actionRemoveTooltip": "删除", + "xpack.snapshotRestore.repositoryList.table.actionsColumnTitle": "操作", + "xpack.snapshotRestore.repositoryList.table.deleteManagedRepositoryTooltip": "您无法删除托管存储库。", + "xpack.snapshotRestore.repositoryList.table.deleteMultipleRepositoriesButton": "移除存储库", + "xpack.snapshotRestore.repositoryList.table.deleteSingleRepositoryButton": "移除存储库", + "xpack.snapshotRestore.repositoryList.table.managedRepositoryBadgeLabel": "受管", + "xpack.snapshotRestore.repositoryList.table.nameColumnTitle": "名称", + "xpack.snapshotRestore.repositoryList.table.reloadRepositoriesButton": "重新加载", + "xpack.snapshotRestore.repositoryList.table.typeColumnTitle": "类型", + "xpack.snapshotRestore.repositoryList.table.typeFilterLabel": "类型", + "xpack.snapshotRestore.repositoryType.azureTypeName": "Azure", + "xpack.snapshotRestore.repositoryType.fileSystemTypeName": "共享文件系统", + "xpack.snapshotRestore.repositoryType.gcsTypeName": "Google Cloud Storage", + "xpack.snapshotRestore.repositoryType.hdfsTypeName": "Hadoop HDFS", + "xpack.snapshotRestore.repositoryType.readonlyTypeName": "只读 URL", + "xpack.snapshotRestore.repositoryType.s3TypeName": "AWS S3", + "xpack.snapshotRestore.repositoryType.sourceTypeName": "仅源", + "xpack.snapshotRestore.repositoryValidation.bucketRequired": "“存储桶”必填", + "xpack.snapshotRestore.repositoryValidation.delegateTypeRequired": "“类型”必填", + "xpack.snapshotRestore.repositoryValidation.locationRequired": "“位置”必填。", + "xpack.snapshotRestore.repositoryValidation.nameRequired": "“存储库名称”必填。", + "xpack.snapshotRestore.repositoryValidation.nameValidation.errorSpace": "名称中不允许使用空格。", + "xpack.snapshotRestore.repositoryValidation.nameValidation.invalidCharacter": "名称中不允许使用字符“{char}”。", + "xpack.snapshotRestore.repositoryValidation.pathRequired": "“路径”必填", + "xpack.snapshotRestore.repositoryValidation.uriRequired": "“URI”必填。", + "xpack.snapshotRestore.repositoryValidation.urlRequired": "“URL”必填", + "xpack.snapshotRestore.repositoryVerification.verificationErrorValue": "未连接", + "xpack.snapshotRestore.repositoryVerification.verificationSuccessfulValue": "已连接", + "xpack.snapshotRestore.repositoryVerification.verificationUnknownValue": "未知", + "xpack.snapshotRestore.repositoryWarningDescription": "快照可能加载缓慢。前往 {repositoryLink} 以修复错误。", + "xpack.snapshotRestore.repositoryWarningLinkText": "存储库", + "xpack.snapshotRestore.repositoryWarningTitle": "一些存储库包含错误", + "xpack.snapshotRestore.restoreForm.backButtonLabel": "上一步", + "xpack.snapshotRestore.restoreForm.navigation.stepLogisticsName": "运筹", + "xpack.snapshotRestore.restoreForm.navigation.stepReviewName": "复查", + "xpack.snapshotRestore.restoreForm.navigation.stepSettingsName": "索引设置", + "xpack.snapshotRestore.restoreForm.nextButtonLabel": "下一步", + "xpack.snapshotRestore.restoreForm.savingButtonLabel": "正在还原……", + "xpack.snapshotRestore.restoreForm.stepLogistics.allIndicesLabel": "所有索引,包括系统索引", + "xpack.snapshotRestore.restoreForm.stepLogistics.deselectAllIndicesLink": "取消全选", + "xpack.snapshotRestore.restoreForm.stepLogistics.docsButtonLabel": "快照和还原文档", + "xpack.snapshotRestore.restoreForm.stepLogistics.includeGlobalStateDescription": "还原当前在集群中不存在的模板并覆盖同名模板。同时还原永久性设置。", + "xpack.snapshotRestore.restoreForm.stepLogistics.includeGlobalStateDisabledDescription": "不适用于此快照。", + "xpack.snapshotRestore.restoreForm.stepLogistics.includeGlobalStateLabel": "还原全局状态", + "xpack.snapshotRestore.restoreForm.stepLogistics.includeGlobalStateTitle": "还原全局状态", + "xpack.snapshotRestore.restoreForm.stepLogistics.indicesDescription": "如果不存在,则创建新索引。如果现有索引已关闭且与快照索引有相同数目的分片,则还原现有索引。", + "xpack.snapshotRestore.restoreForm.stepLogistics.indicesPatternLabel": "索引模式", + "xpack.snapshotRestore.restoreForm.stepLogistics.indicesPatternPlaceholder": "输入索引模式,例如 logstash-*", + "xpack.snapshotRestore.restoreForm.stepLogistics.indicesTitle": "索引", + "xpack.snapshotRestore.restoreForm.stepLogistics.indicesToggleCustomLink": "使用索引模式", + "xpack.snapshotRestore.restoreForm.stepLogistics.indicesToggleListLink": "选择索引", + "xpack.snapshotRestore.restoreForm.stepLogistics.partialDescription": "允许还原不具有所有分片的快照的索引。", + "xpack.snapshotRestore.restoreForm.stepLogistics.partialLabel": "部分还原", + "xpack.snapshotRestore.restoreForm.stepLogistics.partialTitle": "部分还原", + "xpack.snapshotRestore.restoreForm.stepLogistics.renameIndicesDescription": "还原时重命名索引。", + "xpack.snapshotRestore.restoreForm.stepLogistics.renameIndicesLabel": "重命名索引", + "xpack.snapshotRestore.restoreForm.stepLogistics.renameIndicesTitle": "重命名索引", + "xpack.snapshotRestore.restoreForm.stepLogistics.renamePatternHelpText": "使用正则表达式", + "xpack.snapshotRestore.restoreForm.stepLogistics.renamePatternLabel": "捕获模式", + "xpack.snapshotRestore.restoreForm.stepLogistics.renameReplacementLabel": "替换模式", + "xpack.snapshotRestore.restoreForm.stepLogistics.selectAllIndicesLink": "全选", + "xpack.snapshotRestore.restoreForm.stepLogistics.selectIndicesHelpText": "将还原 {count} 个 {count, plural, one {索引} other {索引}}。{selectOrDeselectAllLink}", + "xpack.snapshotRestore.restoreForm.stepLogistics.selectIndicesLabel": "选择索引", + "xpack.snapshotRestore.restoreForm.stepLogisticsTitle": "还原详情", + "xpack.snapshotRestore.restoreForm.stepReview.jsonTab.jsonAriaLabel": "还原要执行的设置", + "xpack.snapshotRestore.restoreForm.stepReview.jsonTabTitle": "JSON", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.allIndicesValue": "所有索引", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.editStepTooltip": "缂栬緫", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.ignoreIndexSettingsLabel": "重置", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.includeGlobalStateFalseValue": "否", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.includeGlobalStateLabel": "还原全局状态", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.includeGlobalStateTrueValue": "鏄", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.indexSettingsLabel": "修改", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.indicesCollapseAllLink": "隐藏 {count, plural, one {# 个索引} other {# 个索引}}", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.indicesLabel": "索引", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.indicesShowAllLink": "再显示 {count} 个 {count, plural, one {索引} other {索引}}", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.noSettingsValue": "无索引设置修改", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.partialFalseValue": "否", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.partialLabel": "部分还原", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.partialTrueValue": "鏄", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.renamePatternLabel": "捕获模式", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.renameReplacementLabel": "替换模式", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.sectionLogisticsTitle": "运筹", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.sectionRenameTitle": "重命名索引", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTab.sectionSettingsTitle": "索引设置", + "xpack.snapshotRestore.restoreForm.stepReview.summaryTabTitle": "摘要", + "xpack.snapshotRestore.restoreForm.stepReviewTitle": "复查还原详情", + "xpack.snapshotRestore.restoreForm.stepSettings.docsButtonLabel": "索引设置文档", + "xpack.snapshotRestore.restoreForm.stepSettings.ignoreIndexSettingsDescription": "在还原期间将选定设置重置为默认值。{docLink}", + "xpack.snapshotRestore.restoreForm.stepSettings.ignoreIndexSettingsLabel": "重置索引设置", + "xpack.snapshotRestore.restoreForm.stepSettings.ignoreIndexSettingsPlaceholder": "选择或键入索引设置", + "xpack.snapshotRestore.restoreForm.stepSettings.ignoreIndexSettingsTitle": "重置索引设置", + "xpack.snapshotRestore.restoreForm.stepSettings.indexSettingsAriaLabel": "要修改的索引设置", + "xpack.snapshotRestore.restoreForm.stepSettings.indexSettingsDescription": "在还原期间覆盖索引设置。{docLink}", + "xpack.snapshotRestore.restoreForm.stepSettings.indexSettingsDocLinkText": "浜嗚В璇︽儏銆.", + "xpack.snapshotRestore.restoreForm.stepSettings.indexSettingsEditorDescription": "使用 JSON 格式:{format}", + "xpack.snapshotRestore.restoreForm.stepSettings.indexSettingsEditorLabel": "索引设置", + "xpack.snapshotRestore.restoreForm.stepSettings.indexSettingsLabel": "修改索引设置", + "xpack.snapshotRestore.restoreForm.stepSettings.indexSettingsTitle": "修改索引设置", + "xpack.snapshotRestore.restoreForm.stepSettings.selectIgnoreIndexSettingsLabel": "选择设置", + "xpack.snapshotRestore.restoreForm.stepSettingsTitle": "索引设置", + "xpack.snapshotRestore.restoreForm.submitButtonLabel": "还原快照", + "xpack.snapshotRestore.restoreList.deniedPrivilegeDescription": "要查看快照还原状态,必须对一个或多个索引具有{privilegesCount, plural, one {以下索引权限} other {以下索引权限}}:{missingPrivileges}.", + "xpack.snapshotRestore.restoreList.deniedPrivilegeTitle": "您缺少索引权限", + "xpack.snapshotRestore.restoreList.emptyPromptDescription": "前往{snapshotsLink}以启动还原。", + "xpack.snapshotRestore.restoreList.emptyPromptDescriptionLink": "快照", + "xpack.snapshotRestore.restoreList.emptyPromptTitle": "您尚未有任何还原的快照", + "xpack.snapshotRestore.restoreList.intervalMenu.minutesIntervalValue": "{minutes} {minutes, plural, one {分钟} other {分钟}}", + "xpack.snapshotRestore.restoreList.intervalMenu.secondsIntervalValue": "{seconds} {seconds, plural, one {秒} other {秒}}", + "xpack.snapshotRestore.restoreList.intervalMenuButtonText": "每 {interval}刷新一次数据", + "xpack.snapshotRestore.restoreList.loadingRestoresDescription": "正在加载还原……", + "xpack.snapshotRestore.restoreList.loadingRestoresErrorMessage": "加载还原时出错", + "xpack.snapshotRestore.restoreList.shardTable.bytesColumnTitle": "字节", + "xpack.snapshotRestore.restoreList.shardTable.durationColumnTitle": "持续时间", + "xpack.snapshotRestore.restoreList.shardTable.durationValue": "{seconds} {seconds, plural, one {秒} other {秒}}", + "xpack.snapshotRestore.restoreList.shardTable.endTimeColumnTitle": "结束时间", + "xpack.snapshotRestore.restoreList.shardTable.filesColumnTitle": "文件", + "xpack.snapshotRestore.restoreList.shardTable.indexColumnTitle": "ID", + "xpack.snapshotRestore.restoreList.shardTable.primaryAbbreviationText": "P", + "xpack.snapshotRestore.restoreList.shardTable.primaryTooltipLabel": "主分片", + "xpack.snapshotRestore.restoreList.shardTable.progressTooltipLabel": "{restored} / {total} 个已还原", + "xpack.snapshotRestore.restoreList.shardTable.repositoryColumnTitle": "存储库", + "xpack.snapshotRestore.restoreList.shardTable.snapshotColumnTitle": "快照", + "xpack.snapshotRestore.restoreList.shardTable.stageColumnTitle": "阶段", + "xpack.snapshotRestore.restoreList.shardTable.startTimeColumnTitle": "开始时间", + "xpack.snapshotRestore.restoreList.shardTable.targetHostColumnTitle": "目标主机", + "xpack.snapshotRestore.restoreList.shardTable.targetNodeColumnTitle": "目标节点", + "xpack.snapshotRestore.restoreList.shardTable.versionColumnTitle": "版本", + "xpack.snapshotRestore.restoreList.table.indexColumnTitle": "绱㈠紩", + "xpack.snapshotRestore.restoreList.table.lastActivityColumn.nowLabel": "现在", + "xpack.snapshotRestore.restoreList.table.lastActivityTitle": "上次活动", + "xpack.snapshotRestore.restoreList.table.shardsCompletedTitle": "已完成分片", + "xpack.snapshotRestore.restoreList.table.shardsInProgressTitle": "进行中的分片", + "xpack.snapshotRestore.restoreList.table.statusColumn.completeLabel": "已完成", + "xpack.snapshotRestore.restoreList.table.statusColumn.inProgressLabel": "正在进行中", + "xpack.snapshotRestore.restoreList.table.statusColumnTitle": "状态", + "xpack.snapshotRestore.restoreSnapshot.breadcrumbTitle": "还原快照", + "xpack.snapshotRestore.restoreSnapshot.executeRestoreErrorTitle": "无法还原快照", + "xpack.snapshotRestore.restoreSnapshot.loadingSnapshotDescription": "正在加载快照详情……", + "xpack.snapshotRestore.restoreSnapshot.loadingSnapshotErrorTitle": "加载快照详情时出错", + "xpack.snapshotRestore.restoreSnapshot.snapshotNotFoundErrorMessage": "快照“{snapshot}”在存储库“{repository}”中不存在。", + "xpack.snapshotRestore.restoreSnapshotTitle": "还原“{snapshot}”", + "xpack.snapshotRestore.restoreStatus.breadcrumbTitle": "还原状态", + "xpack.snapshotRestore.restoreValidation.ignoreIndexSettingsRequiredError": "至少需要一个设置。", + "xpack.snapshotRestore.restoreValidation.indexPatternRequiredError": "至少需要一个索引模式。", + "xpack.snapshotRestore.restoreValidation.indexSettingsInvalidError": "JSON 格式无效", + "xpack.snapshotRestore.restoreValidation.indexSettingsNotModifiableError": "无法修改:{settings}", + "xpack.snapshotRestore.restoreValidation.indexSettingsNotRemovableError": "无法重置:{settings}", + "xpack.snapshotRestore.restoreValidation.indexSettingsRequiredError": "至少需要一个设置。", + "xpack.snapshotRestore.restoreValidation.indicesRequiredError": "必须至少选择一个索引。", + "xpack.snapshotRestore.restoreValidation.renamePatternRequiredError": "捕获模式必填。", + "xpack.snapshotRestore.restoreValidation.renameReplacementRequiredError": "替换模式必填。", + "xpack.snapshotRestore.snapshotDetails.closeButtonLabel": "关闭", + "xpack.snapshotRestore.snapshotDetails.createdByLabel": "创建者", + "xpack.snapshotRestore.snapshotDetails.deleteButtonLabel": "鍒犻櫎", + "xpack.snapshotRestore.snapshotDetails.deleteManagedRepositorySnapshotButtonTitle": "您无法删除托管存储库中存储的快照。", + "xpack.snapshotRestore.snapshotDetails.errorLoadingRepositoryTitle": "加载存储库时出错", + "xpack.snapshotRestore.snapshotDetails.errorSnapshotNotFound": "快照“{snapshotId}”在存储库“{repositoryName}”中不存在或该存储库不存在。", + "xpack.snapshotRestore.snapshotDetails.failureShardTitle": "分片 {shardId}", + "xpack.snapshotRestore.snapshotDetails.failuresTabTitle": "失败的索引 ({failuresCount})", + "xpack.snapshotRestore.snapshotDetails.itemDurationLabel": "持续时间", + "xpack.snapshotRestore.snapshotDetails.itemDurationValueLabel": "{seconds} {seconds, plural, one {秒} other {秒}}", + "xpack.snapshotRestore.snapshotDetails.itemEndTimeLabel": "结束时间", + "xpack.snapshotRestore.snapshotDetails.itemIncludeGlobalStateLabel": "包括全局状态", + "xpack.snapshotRestore.snapshotDetails.itemIncludeGlobalStateNoLabel": "否", + "xpack.snapshotRestore.snapshotDetails.itemIncludeGlobalStateYesLabel": "是", + "xpack.snapshotRestore.snapshotDetails.itemIndicesCollapseAllLink": "隐藏 {count, plural, one {# 个索引} other {# 个索引}}", + "xpack.snapshotRestore.snapshotDetails.itemIndicesLabel": "索引 ({indicesCount})", + "xpack.snapshotRestore.snapshotDetails.itemIndicesNoneLabel": "-", + "xpack.snapshotRestore.snapshotDetails.itemIndicesShowAllLink": "再显示 {count} 个 {count, plural, one {索引} other {索引}}", + "xpack.snapshotRestore.snapshotDetails.itemStartTimeLabel": "开始时间", + "xpack.snapshotRestore.snapshotDetails.itemStateLabel": "状态", + "xpack.snapshotRestore.snapshotDetails.itemUuidLabel": "UUID", + "xpack.snapshotRestore.snapshotDetails.itemVersionLabel": "版本 / 版本 ID", + "xpack.snapshotRestore.snapshotDetails.loadingSnapshotDescription": "正在加载快照……", + "xpack.snapshotRestore.snapshotDetails.noIndexFailuresMessage": "所有索引成功存储。", + "xpack.snapshotRestore.snapshotDetails.repositoryTitle": "“{repositoryName}”存储库", + "xpack.snapshotRestore.snapshotDetails.restoreButtonLabel": "还原", + "xpack.snapshotRestore.snapshotDetails.snapshotIsBeingCreatedMessage": "正在创建快照。", + "xpack.snapshotRestore.snapshotDetails.summaryTabTitle": "结论", + "xpack.snapshotRestore.snapshotList.emptyPrompt.addPolicyText": "创建策略", + "xpack.snapshotRestore.snapshotList.emptyPrompt.errorRepositoriesTitle": "一些存储库包含错误", + "xpack.snapshotRestore.snapshotList.emptyPrompt.goToPoliciesText": "查看策略", + "xpack.snapshotRestore.snapshotList.emptyPrompt.noRepositoriesAddButtonLabel": "注册存储库", + "xpack.snapshotRestore.snapshotList.emptyPrompt.noRepositoriesDescription": "首先为您的快照注册存储库。", + "xpack.snapshotRestore.snapshotList.emptyPrompt.noRepositoriesTitle": "您尚未有任何快照或存储库", + "xpack.snapshotRestore.snapshotList.emptyPrompt.noSnapshotsDescription": "使用 Elasticsearch API 创建快照", + "xpack.snapshotRestore.snapshotList.emptyPrompt.noSnapshotsTitle": "您尚未有任何快照", + "xpack.snapshotRestore.snapshotList.emptyPrompt.repositoryWarningDescription": "前往 {repositoryLink} 以修复错误。", + "xpack.snapshotRestore.snapshotList.emptyPrompt.usePolicyDescription": "运行快照生命周期策略以创建快照。还可以使用 {docLink} 创建快照。", + "xpack.snapshotRestore.snapshotList.loadingSnapshotsDescription": "正在加载快照……", + "xpack.snapshotRestore.snapshotList.loadingSnapshotsErrorMessage": "加载快照时出错", + "xpack.snapshotRestore.snapshotList.table.actionDeleteAriaLabel": "删除快照 `{name}`", + "xpack.snapshotRestore.snapshotList.table.actionDeleteTooltip": "鍒犻櫎", + "xpack.snapshotRestore.snapshotList.table.actionRestoreAriaLabel": "存储快照 `{name}`", + "xpack.snapshotRestore.snapshotList.table.actionRestoreDisabledInProgressTooltip": "无法还原进行中的快照", + "xpack.snapshotRestore.snapshotList.table.actionRestoreDisabledInvalidTooltip": "无法还原无效快照", + "xpack.snapshotRestore.snapshotList.table.actionRestoreTooltip": "还原", + "xpack.snapshotRestore.snapshotList.table.actionsColumnTitle": "鎿嶄綔", + "xpack.snapshotRestore.snapshotList.table.deleteManagedRepositorySnapshotTooltip": "您无法删除托管存储库中存储的快照。", + "xpack.snapshotRestore.snapshotList.table.deleteSnapshotButton": "删除{count, plural, one {快照} other {快照}}", + "xpack.snapshotRestore.snapshotList.table.durationColumnTitle": "持续时间", + "xpack.snapshotRestore.snapshotList.table.durationColumnValueLabel": "{seconds} 秒", + "xpack.snapshotRestore.snapshotList.table.failedShardsColumnTitle": "失败的分片", + "xpack.snapshotRestore.snapshotList.table.indicesColumnTitle": "索引", + "xpack.snapshotRestore.snapshotList.table.reloadSnapshotsButton": "重新加载", + "xpack.snapshotRestore.snapshotList.table.repositoryColumnTitle": "存储库", + "xpack.snapshotRestore.snapshotList.table.repositoryFilterLabel": "存储库", + "xpack.snapshotRestore.snapshotList.table.shardsColumnTitle": "分片", + "xpack.snapshotRestore.snapshotList.table.snapshotColumnTitle": "快照", + "xpack.snapshotRestore.snapshotList.table.startTimeColumnTitle": "创建日期", + "xpack.snapshotRestore.snapshots.breadcrumbTitle": "快照", + "xpack.snapshotRestore.snapshotState.completeLabel": "快照完成", + "xpack.snapshotRestore.snapshotState.failedLabel": "快照失败", + "xpack.snapshotRestore.snapshotState.incompatibleLabel": "不兼容版本", + "xpack.snapshotRestore.snapshotState.incompatibleTipDescription": "创建快照所用的 Elasticsearch 版本与集群的版本不兼容。", + "xpack.snapshotRestore.snapshotState.inProgressLabel": "正在拍取快照……", + "xpack.snapshotRestore.snapshotState.partialLabel": "部分失败", + "xpack.snapshotRestore.snapshotState.partialTipDescription": "全局集群状态已存储,但至少一个分片未成功存储。请参阅“失败的索引”选项卡。", + "xpack.spaces.defaultSpaceDescription": "这是您的默认工作区!", + "xpack.spaces.defaultSpaceTitle": "默认值", + "xpack.spaces.displayName": "工作区", + "xpack.spaces.featureDescription": "将仪表板和其他已保存的对象管理为有意义的类别。", + "xpack.spaces.management.advancedSettingsSubtitle.applyingSettingsOnPageToSpaceDescription": "除非已指定,否则此页面上的设置适用于 {spaceName} 空间。", + "xpack.spaces.management.advancedSettingsTitle.settingsTitle": "设置", + "xpack.spaces.management.collapsiblePanel.hideLinkDescription": "隐藏 {title}", + "xpack.spaces.management.collapsiblePanel.hideLinkText": "隐藏", + "xpack.spaces.management.collapsiblePanel.showLinkDescription": "显示 {title}", + "xpack.spaces.management.collapsiblePanel.showLinkText": "显示", + "xpack.spaces.management.confirmAlterActiveSpaceModal.cancelButton": "取消", + "xpack.spaces.management.confirmAlterActiveSpaceModal.reloadWarningMessage": "您已更新此工作区中的可见功能。保存后,您的页面将重新加载。", + "xpack.spaces.management.confirmAlterActiveSpaceModal.title": "确认更新工作区", + "xpack.spaces.management.confirmAlterActiveSpaceModal.updateSpaceButton": "更新工作区", + "xpack.spaces.management.confirmDeleteModal.allContentsText": "所有内容", + "xpack.spaces.management.confirmDeleteModal.cancelButtonLabel": "取消", + "xpack.spaces.management.confirmDeleteModal.confirmDeleteSpaceButtonLabel": "删除空间 {spaceName}", + "xpack.spaces.management.confirmDeleteModal.confirmSpaceNameFormRowLabel": "确认要删除的工作区名称", + "xpack.spaces.management.confirmDeleteModal.deleteSpaceAndAllContentsButtonLabel": " 删除空间及其所有内容", + "xpack.spaces.management.confirmDeleteModal.deletingSpaceWarningMessage": "删除空间会永久删除空间及其 {allContents}。此操作无法撤消。", + "xpack.spaces.management.confirmDeleteModal.redirectAfterDeletingCurrentSpaceWarningMessage": "您即将删除当前空间 {name}。如果继续,系统会将您重定向到选择其他空间的位置。", + "xpack.spaces.management.confirmDeleteModal.spaceNamesDoNoMatchErrorMessage": "空间名称不匹配。", + "xpack.spaces.management.copyToSpace.actionDescription": "将此已保存对象复制到一个或多个工作区", + "xpack.spaces.management.copyToSpace.actionTitle": "复制到工作区", + "xpack.spaces.management.copyToSpace.automaticallyOverwrite": "自动覆盖所有已保存对象", + "xpack.spaces.management.copyToSpace.copyDetail.overwriteButton": "覆盖", + "xpack.spaces.management.copyToSpace.copyDetail.skipOverwriteButton": "跳过", + "xpack.spaces.management.copyToSpace.copyErrorTitle": "复制已保存对象时出错", + "xpack.spaces.management.copyToSpace.copyResultsLabel": "复制结果", + "xpack.spaces.management.copyToSpace.copyStatus.conflictsMessage": "具有匹配 ID ({id}) 的已保存对象在此工作区中已存在。", + "xpack.spaces.management.copyToSpace.copyStatus.conflictsOverwriteMessage": "单击“覆盖”可将此版本替换为复制的版本。", + "xpack.spaces.management.copyToSpace.copyStatus.pendingOverwriteMessage": "已保存对象将被覆盖。单击“跳过”可取消此操作。", + "xpack.spaces.management.copyToSpace.copyStatus.successMessage": "已保存对象成功复制。", + "xpack.spaces.management.copyToSpace.copyStatus.unresolvableErrorMessage": "复制此已保存对象时出错。", + "xpack.spaces.management.copyToSpace.copyStatusSummary.conflictsMessage": "在 {space} 工作区中检测到一个或多个冲突。展开此部分以进行解决。", + "xpack.spaces.management.copyToSpace.copyStatusSummary.failedMessage": "复制到 {space} 工作区失败。展开此部分以获取详情。", + "xpack.spaces.management.copyToSpace.copyStatusSummary.successMessage": "已成功复制到 {space} 工作区。", + "xpack.spaces.management.copyToSpace.copyToSpacesButton": "复制到 {spaceCount} {spaceCount, plural, one {个工作区} other {个工作区}}", + "xpack.spaces.management.copyToSpace.disabledCopyToSpacesButton": "复制", + "xpack.spaces.management.copyToSpace.dontIncludeRelatedLabel": "不包括相关已保存对象", + "xpack.spaces.management.copyToSpace.dontOverwriteLabel": "未覆盖已保存对象", + "xpack.spaces.management.copyToSpace.finishCopyToSpacesButton": "完成", + "xpack.spaces.management.copyToSpace.finishedButtonLabel": "复制已完成。", + "xpack.spaces.management.copyToSpace.finishPendingOverwritesCopyToSpacesButton": "覆盖 {overwriteCount} 个对象", + "xpack.spaces.management.copyToSpace.includeRelatedFormLabel": "包括相关已保存对象", + "xpack.spaces.management.copyToSpace.includeRelatedLabel": "包括相关已保存对象", + "xpack.spaces.management.copyToSpace.inProgressButtonLabel": "复制正在进行中。请稍候。", + "xpack.spaces.management.copyToSpace.noSpacesBody": "没有可向其中进行复制的合格工作区。", + "xpack.spaces.management.copyToSpace.noSpacesTitle": "没有可用的工作区", + "xpack.spaces.management.copyToSpace.overwriteLabel": "正在自动覆盖已保存对象", + "xpack.spaces.management.copyToSpace.resolveCopyErrorTitle": "解决已保存对象冲突时出错", + "xpack.spaces.management.copyToSpace.resolveCopySuccessTitle": "覆盖成功", + "xpack.spaces.management.copyToSpace.selectSpacesLabel": "选择要向其中进行复制的工作区", + "xpack.spaces.management.copyToSpace.spacesLoadErrorTitle": "加载可用工作区时出错", + "xpack.spaces.management.copyToSpaceFlyoutFooter.conflictCount": "已跳过", + "xpack.spaces.management.copyToSpaceFlyoutFooter.errorCount": "错误", + "xpack.spaces.management.copyToSpaceFlyoutFooter.pendingCount": "待处理", + "xpack.spaces.management.copyToSpaceFlyoutFooter.successCount": "已复制", + "xpack.spaces.management.copyToSpaceFlyoutHeader": "将已保存对象复制到工作区", + "xpack.spaces.management.customizeSpaceAvatar.colorFormRowLabel": "颜色", + "xpack.spaces.management.customizeSpaceAvatar.imageUrl": "定制图像", + "xpack.spaces.management.customizeSpaceAvatar.initialItemsFormRowLabel": "名字缩写(最多两个字符)", + "xpack.spaces.management.customizeSpaceAvatar.removeImage": "删除定制图像", + "xpack.spaces.management.customizeSpaceAvatar.selectImageUrl": "选择图像文件", + "xpack.spaces.management.deleteSpacesButton.deleteSpaceAriaLabel": "删除此空间", + "xpack.spaces.management.deleteSpacesButton.deleteSpaceButtonLabel": "删除空间", + "xpack.spaces.management.deleteSpacesButton.deleteSpaceErrorTitle": "删除空间时出错:{errorMessage}", + "xpack.spaces.management.deleteSpacesButton.spaceSuccessfullyDeletedNotificationMessage": "已删除 {spaceName} 空间。", + "xpack.spaces.management.enabledSpaceFeatures.allFeaturesEnabledMessage": "(所有可见功能)", + "xpack.spaces.management.enabledSpaceFeatures.enabledFeaturesSectionMessage": "定制功能显示", + "xpack.spaces.management.enabledSpaceFeatures.enableFeaturesInSpaceMessage": "控制哪些功能在此工作区中可见。", + "xpack.spaces.management.enabledSpaceFeatures.goToRolesLink": "想保护访问?前往 {rolesLink}。", + "xpack.spaces.management.enabledSpaceFeatures.noFeaturesEnabledMessage": "(没有可见功能)", + "xpack.spaces.management.enabledSpaceFeatures.notASecurityMechanismMessage": "该功能在 UI 中已隐藏,但未禁用。", + "xpack.spaces.management.enabledSpaceFeatures.rolesLinkText": "角色", + "xpack.spaces.management.enabledSpaceFeatures.someFeaturesEnabledMessage": "({enabledCount} / {featureCount} 个功能可见)", + "xpack.spaces.management.enabledSpaceFeaturesEnabledColumnTitle": "显示?", + "xpack.spaces.management.enabledSpaceFeaturesFeatureColumnTitle": "功能", + "xpack.spaces.management.hideAllFeaturesText": "全部隐藏", + "xpack.spaces.management.manageSpacePage.avatarFormRowLabel": "头像", + "xpack.spaces.management.manageSpacePage.awesomeSpacePlaceholder": "超卓的空间", + "xpack.spaces.management.manageSpacePage.cancelSpaceButton": "取消", + "xpack.spaces.management.manageSpacePage.clickToCustomizeTooltip": "单击可定制此工作区头像", + "xpack.spaces.management.manageSpacePage.createSpaceButton": "创建工作区", + "xpack.spaces.management.manageSpacePage.createSpaceTitle": "创建一个空间", + "xpack.spaces.management.manageSpacePage.customizeSpacePanelDescription": "命名您的工作区并定制其头像。", + "xpack.spaces.management.manageSpacePage.customizeSpacePanelUrlIdentifierEditable": "记下 URL 标识符。创建工作区后,将不能更改它。", + "xpack.spaces.management.manageSpacePage.customizeSpacePanelUrlIdentifierNotEditable": "URL 标识符无法更改。", + "xpack.spaces.management.manageSpacePage.customizeSpaceTitle": "定制您的工作区", + "xpack.spaces.management.manageSpacePage.customizeVisibleFeatures": "定制可见功能", + "xpack.spaces.management.manageSpacePage.errorLoadingSpaceTitle": "加载空间时出错:{message}", + "xpack.spaces.management.manageSpacePage.errorSavingSpaceTitle": "保存空间时出错:{message}", + "xpack.spaces.management.manageSpacePage.manageDescription": "将已保存对象组织到有意义的类别中。", + "xpack.spaces.management.manageSpacePage.nameFormRowLabel": "名称", + "xpack.spaces.management.manageSpacePage.spaceDescriptionFormRowLabel": "描述(可选)", + "xpack.spaces.management.manageSpacePage.spaceDescriptionHelpText": "描述显示在”工作区选择“屏幕上。", + "xpack.spaces.management.manageSpacePage.spaceSuccessfullySavedNotificationMessage": "空间 “{name}” 已保存。", + "xpack.spaces.management.manageSpacePage.updateSpaceButton": "更新工作区", + "xpack.spaces.management.reversedSpaceBadge.reversedSpacesCanBePartiallyModifiedTooltip": "保留的空间是内置的,只能进行部分修改。", + "xpack.spaces.management.secureSpaceMessage.howToAssignRoleToSpaceDescription": "想要为工作区分配角色?前往 {rolesLink}。", + "xpack.spaces.management.secureSpaceMessage.rolesLinkText": "角色", + "xpack.spaces.management.secureSpaceMessage.rolesLinkTextAriaLabel": "角色管理页面", + "xpack.spaces.management.showAllFeaturesText": "全部显示", + "xpack.spaces.management.spaceIdentifier.customizeSpaceLinkText": "[定制]", + "xpack.spaces.management.spaceIdentifier.customizeSpaceNameLinkLabel": "定制 URL 标识符", + "xpack.spaces.management.spaceIdentifier.emptySpaceIdentifierText": "awesome-space", + "xpack.spaces.management.spaceIdentifier.kibanaURLForSpaceIdentifierDescription": "示例:https://my-kibana.example{spaceIdentifier}/app/kibana。", + "xpack.spaces.management.spaceIdentifier.resetSpaceNameLinkLabel": "重置 URL 标识符", + "xpack.spaces.management.spaceIdentifier.resetSpaceNameLinkText": "[重置]", + "xpack.spaces.management.spaceIdentifier.urlIdentifierGeneratedFromSpaceNameTooltip": "awesome-space", + "xpack.spaces.management.spaceIdentifier.urlIdentifierLabel": "URL 标识符 ", + "xpack.spaces.management.spaceIdentifier.urlIdentifierTitle": "URL 标识符", + "xpack.spaces.management.spacesGridPage.actionsColumnName": "操作", + "xpack.spaces.management.spacesGridPage.allFeaturesEnabled": "所有可见功能", + "xpack.spaces.management.spacesGridPage.createSpaceButtonLabel": "创建一个空间", + "xpack.spaces.management.spacesGridPage.deleteActionName": "删除 {spaceName}。", + "xpack.spaces.management.spacesGridPage.descriptionColumnName": "描述", + "xpack.spaces.management.spacesGridPage.editSpaceActionName": "编辑 {spaceName}。", + "xpack.spaces.management.spacesGridPage.errorDeletingSpaceErrorMessage": "删除空间时出错:{errorMessage}", + "xpack.spaces.management.spacesGridPage.featuresColumnName": "功能", + "xpack.spaces.management.spacesGridPage.identifierColumnName": "标识符", + "xpack.spaces.management.spacesGridPage.loadingTitle": "正在加载……", + "xpack.spaces.management.spacesGridPage.noFeaturesEnabled": "没有可见功能", + "xpack.spaces.management.spacesGridPage.searchPlaceholder": "搜索", + "xpack.spaces.management.spacesGridPage.someFeaturesEnabled": "{enabledFeatureCount} / {totalFeatureCount} 个功能可见", + "xpack.spaces.management.spacesGridPage.spaceColumnName": "工作区", + "xpack.spaces.management.spacesGridPage.spacesTitle": "工作区", + "xpack.spaces.management.spacesGridPage.spaceSuccessfullyDeletedNotificationMessage": "已删除 “{spaceName}” 空间。", + "xpack.spaces.management.toggleAllFeaturesLink": "(全部更改)", + "xpack.spaces.management.unauthorizedPrompt.permissionDeniedDescription": "您没有权限管理空间。", + "xpack.spaces.management.unauthorizedPrompt.permissionDeniedTitle": "权限被拒绝", + "xpack.spaces.management.validateSpace.describeMaxLengthErrorMessage": "描述不能超过 2000 个字符。", + "xpack.spaces.management.validateSpace.nameMaxLengthErrorMessage": "名称不能超过 1024 个字符。", + "xpack.spaces.management.validateSpace.requiredNameErrorMessage": "“名称”必填", + "xpack.spaces.management.validateSpace.urlIdentifierAllowedCharactersErrorMessage": "URL 标识符只能包含 a-z、0-9 和字符“_”及“-”。", + "xpack.spaces.management.validateSpace.urlIdentifierRequiredErrorMessage": "“URL 标识符”必填。", + "xpack.spaces.manageSpacesButton.manageSpacesButtonLabel": "管理空间", + "xpack.spaces.navControl.spacesMenu.changeCurrentSpaceTitle": "更改当前空间", + "xpack.spaces.navControl.spacesMenu.findSpacePlaceholder": "查找工作区", + "xpack.spaces.navControl.spacesMenu.noSpacesFoundTitle": " 未找到工作区 ", + "xpack.spaces.spaceSelector.changeSpaceAnytimeAvailabilityText": "您可以随时更改您的空间", + "xpack.spaces.spaceSelector.findSpacePlaceholder": "查找工作区", + "xpack.spaces.spaceSelector.noSpacesMatchSearchCriteriaDescription": "没有匹配搜索条件的空间", + "xpack.spaces.spaceSelector.selectSpacesTitle": "选择您的空间", + "xpack.spaces.spacesTitle": "工作区", + "xpack.transform.agg.popoverForm.aggLabel": "聚合", + "xpack.transform.agg.popoverForm.aggNameAlreadyUsedError": "其他聚合已使用该名称。", + "xpack.transform.agg.popoverForm.aggNameInvalidCharError": "名称无效。不允许使用字符“[”、“]”和“>”,且名称不得以空格字符开头或结束。", + "xpack.transform.agg.popoverForm.fieldLabel": "字段", + "xpack.transform.agg.popoverForm.nameLabel": "聚合名称", + "xpack.transform.agg.popoverForm.submitButtonLabel": "应用", + "xpack.transform.agg.popoverForm.unsupportedAggregationHelpText": "在此表单中仅可以编辑聚合名称。请使用高级编辑器编辑聚合的其他部分。", + "xpack.transform.aggLabelForm.deleteItemAriaLabel": "删除项", + "xpack.transform.aggLabelForm.editAggAriaLabel": "编辑聚合", + "xpack.transform.app.checkingPrivilegesDescription": "正在检查权限……", + "xpack.transform.app.checkingPrivilegesErrorMessage": "从服务器获取用户权限时出错。", + "xpack.transform.app.deniedPrivilegeDescription": "要使用“转换”的此部分,必须具有{privilegesCount, plural, one {以下集群权限} other {以下集群权限}}:{missingPrivileges}。", + "xpack.transform.app.deniedPrivilegeTitle": "您缺少集群权限", + "xpack.transform.appName": "数据帧作业", + "xpack.transform.capability.noPermission.createTransformTooltip": "您无权创建数据帧转换。", + "xpack.transform.capability.noPermission.deleteTransformTooltip": "您无权删除数据帧转换。", + "xpack.transform.capability.noPermission.startOrStopTransformTooltip": "您无权启动或停止转换。", + "xpack.transform.capability.pleaseContactAdministratorTooltip": "{message}请联系您的管理员。", + "xpack.transform.createTransform.breadcrumbTitle": "创建转换", + "xpack.transform.description": "描述", + "xpack.transform.destinationIndex": "目标 IP", + "xpack.transform.groupby.popoverForm.aggLabel": "聚合", + "xpack.transform.groupBy.popoverForm.aggNameAlreadyUsedError": "其他分组依据配置已使用该名称。", + "xpack.transform.groupBy.popoverForm.aggNameInvalidCharError": "名称无效。不允许使用字符“[”、“]”和“>”,且名称不得以空格字符开头或结束。", + "xpack.transform.groupBy.popoverForm.fieldLabel": "字段", + "xpack.transform.groupBy.popoverForm.intervalError": "时间间隔无效。", + "xpack.transform.groupBy.popoverForm.intervalLabel": "时间间隔", + "xpack.transform.groupBy.popoverForm.nameLabel": "分组依据名称", + "xpack.transform.groupBy.popoverForm.submitButtonLabel": "应用", + "xpack.transform.groupBy.popoverForm.unsupportedGroupByHelpText": "在此表单中仅可以编辑 group_by 名称。请使用高级编辑器编辑 group_by 配置的其他部分。", + "xpack.transform.groupByLabelForm.deleteItemAriaLabel": "删除项", + "xpack.transform.groupByLabelForm.editIntervalAriaLabel": "编辑时间间隔", + "xpack.transform.home.breadcrumbTitle": "数据帧作业", + "xpack.transform.list.emptyPromptButtonText": "创建您的首个转换", + "xpack.transform.list.emptyPromptTitle": "找不到转换", + "xpack.transform.list.errorPromptTitle": "获取数据帧转换列表时发生错误。", + "xpack.transform.mode": "模式", + "xpack.transform.modeFilter": "模式", + "xpack.transform.models.transformService.allOtherRequestsCancelledDescription": "所有其他请求已取消。", + "xpack.transform.models.transformService.requestToActionTimedOutErrorMessage": "对 {action}“{id}”的请求超时。{extra}", + "xpack.transform.multiTransformActionsMenu.managementActionsAriaLabel": "管理操作", + "xpack.transform.multiTransformActionsMenu.transformsCount": "已选择 {count} 个{count, plural, one {转换} other {转换}}", + "xpack.transform.newTransform.chooseSourceTitle": "选择源", + "xpack.transform.newTransform.newTransformTitle": "新转换", + "xpack.transform.newTransform.searchSelection.notFoundLabel": "未找到匹配的索引或已保存搜索。", + "xpack.transform.newTransform.searchSelection.savedObjectType.indexPattern": "索引模式", + "xpack.transform.newTransform.searchSelection.savedObjectType.search": "已保存搜索", + "xpack.transform.pivotPreview.copyClipboardTooltip": "将透视预览的开发控制台语句复制到剪贴板。", + "xpack.transform.pivotPreview.PivotPreviewError": "加载数据透视表预览时出错。", + "xpack.transform.pivotPreview.PivotPreviewIncompleteConfigCalloutBody": "请至少选择一个分组依据字段和聚合。", + "xpack.transform.pivotPreview.PivotPreviewNoDataCalloutBody": "预览请求未返回任何数据。请确保可选查询返回数据且存在分组依据和聚合字段使用的字段的值。", + "xpack.transform.pivotPreview.PivotPreviewNoDataCalloutTitle": "数据透视表预览不可用", + "xpack.transform.pivotPreview.PivotPreviewTitle": "转换数据透视表预览", + "xpack.transform.progress": "进度", + "xpack.transform.sourceIndex": "源索引", + "xpack.transform.sourceIndexPreview.copyClipboardTooltip": "将源索引预览的开发控制台语句复制到剪贴板。", + "xpack.transform.sourceIndexPreview.fieldSelection": "已选择 {selectedFieldsLength, number} 个{docFieldsCount, plural, one {字段} other {字段}},共 {docFieldsCount, number} 个", + "xpack.transform.sourceIndexPreview.rowCollapse": "折叠", + "xpack.transform.sourceIndexPreview.rowExpand": "展开", + "xpack.transform.sourceIndexPreview.selectColumnsAriaLabel": "选择列", + "xpack.transform.sourceIndexPreview.selectFieldsPopoverTitle": "选择字段", + "xpack.transform.sourceIndexPreview.SourceIndexArrayBadgeContent": "数组", + "xpack.transform.sourceIndexPreview.SourceIndexArrayToolTipContent": "此基于数组的列的完整内容在展开的行中。", + "xpack.transform.sourceIndexPreview.SourceIndexNoDataCalloutBody": "源索引的查询未返回结果。请确保索引包含文档且您的查询限制不过于严格。", + "xpack.transform.sourceIndexPreview.SourceIndexNoDataCalloutTitle": "源索引查询结果为空。", + "xpack.transform.sourceIndexPreview.SourceIndexObjectBadgeContent": "对象", + "xpack.transform.sourceIndexPreview.SourceIndexObjectToolTipContent": "此基于对象的列的完整内容在展开的行中。", + "xpack.transform.sourceIndexPreview.sourceIndexPatternError": "加载源索引数据时出错。", + "xpack.transform.sourceIndexPreview.sourceIndexPatternTitle": "源索引 {indexPatternTitle}", + "xpack.transform.statsBar.batchTransformsLabel": "批量", + "xpack.transform.statsBar.continuousTransformsLabel": "连续", + "xpack.transform.statsBar.failedTransformsLabel": "失败", + "xpack.transform.statsBar.startedTransformsLabel": "已启动", + "xpack.transform.statsBar.totalTransformsLabel": "转换总数", + "xpack.transform.status": "状态", + "xpack.transform.statusFilter": "状态", + "xpack.transform.stepCreateForm.continuousModeLabel": "连续模式", + "xpack.transform.stepCreateForm.copyTransformConfigToClipboardButton": "复制到剪贴板", + "xpack.transform.stepCreateForm.copyTransformConfigToClipboardDescription": "将用于创建作业的 Kibana 开发控制台命令复制到剪贴板。", + "xpack.transform.stepCreateForm.createAndStartTransformButton": "创建并启动", + "xpack.transform.stepCreateForm.createAndStartTransformDescription": "创建并启动转换。转换将增加集群的搜索和索引负荷。如果负荷超载,请停止转换。转换启动后,系统将为您提供继续浏览转换的选项。", + "xpack.transform.stepCreateForm.createIndexPatternErrorMessage": "创建 Kibana 索引模式时发生错误 {indexPatternName}:", + "xpack.transform.stepCreateForm.createIndexPatternLabel": "创建索引模式", + "xpack.transform.stepCreateForm.createIndexPatternSuccessMessage": "Kibana 索引模式 {indexPatternName} 成功创建。", + "xpack.transform.stepCreateForm.createTransformButton": "创建", + "xpack.transform.stepCreateForm.createTransformDescription": "在不启动转换的情况下创建转换。您之后能够通过返回到转换列表,来启动转换。", + "xpack.transform.stepCreateForm.createTransformErrorMessage": "创建转换 {transformId} 时出错:", + "xpack.transform.stepCreateForm.createTransformSuccessMessage": "创建转换 {transformId} 的请求已确认。", + "xpack.transform.stepCreateForm.creatingIndexPatternMessage": "正在创建 Kibana 索引模式......", + "xpack.transform.stepCreateForm.discoverCardDescription": "使用 Discover 浏览数据帧透视表。", + "xpack.transform.stepCreateForm.discoverCardTitle": "Discover", + "xpack.transform.stepCreateForm.duplicateIndexPatternErrorMessage": "创建 Kibana 索引模式时发生错误 {indexPatternName}:该索引模式已存在。", + "xpack.transform.stepCreateForm.progressErrorMessage": "获取进度百分比时出错:", + "xpack.transform.stepCreateForm.progressTitle": "进度", + "xpack.transform.stepCreateForm.startTransformButton": "开始", + "xpack.transform.stepCreateForm.startTransformDescription": "启动转换。转换将增加集群的搜索和索引负荷。如果负荷超载,请停止转换。转换启动后,系统将为您提供继续浏览转换的选项。", + "xpack.transform.stepCreateForm.startTransformErrorMessage": "启动转换 {transformId} 时发生错误:", + "xpack.transform.stepCreateForm.startTransformSuccessMessage": "启动转换 {transformId} 的请求已确认。", + "xpack.transform.stepCreateForm.transformListCardDescription": "返回数据帧作业管理页面。", + "xpack.transform.stepCreateForm.transformListCardTitle": "数据帧作业", + "xpack.transform.stepDefineForm.advancedEditorApplyButtonText": "应用更改", + "xpack.transform.stepDefineForm.advancedEditorAriaLabel": "高级数据透视表编辑器", + "xpack.transform.stepDefineForm.advancedEditorHelpText": "高级编辑器允许您编辑数据帧转换的数据透视表配置。", + "xpack.transform.stepDefineForm.advancedEditorHelpTextLink": "详细了解可用选项。", + "xpack.transform.stepDefineForm.advancedEditorLabel": "数据透视表配置对象", + "xpack.transform.stepDefineForm.advancedEditorSourceConfigSwitchLabel": "高级查询编辑器", + "xpack.transform.stepDefineForm.advancedEditorSwitchLabel": "高级数据透视表编辑器", + "xpack.transform.stepDefineForm.advancedEditorSwitchModalBodyText": "高级编辑器中的更改尚未应用。禁用高级编辑器将会使您的编辑丢失。", + "xpack.transform.stepDefineForm.advancedEditorSwitchModalCancelButtonText": "取消", + "xpack.transform.stepDefineForm.advancedEditorSwitchModalConfirmButtonText": "禁用高级编辑器", + "xpack.transform.stepDefineForm.advancedEditorSwitchModalTitle": "未应用的更改", + "xpack.transform.stepDefineForm.advancedSourceEditorApplyButtonText": "应用更改", + "xpack.transform.stepDefineForm.advancedSourceEditorAriaLabel": "高级查询编辑器", + "xpack.transform.stepDefineForm.advancedSourceEditorHelpText": "高级编辑器允许您编辑数据帧转换的源查询子句。", + "xpack.transform.stepDefineForm.advancedSourceEditorLabel": "源查询子句", + "xpack.transform.stepDefineForm.advancedSourceEditorSwitchModalBodyText": "切换回到 KQL 查询栏,您将会丢失编辑。", + "xpack.transform.stepDefineForm.advancedSourceEditorSwitchModalConfirmButtonText": "切换到 KQL", + "xpack.transform.stepDefineForm.advancedSourceEditorSwitchModalTitle": "编辑将会丢失", + "xpack.transform.stepDefineForm.aggExistsErrorMessage": "名称为“{aggName}”的聚合配置已存在。", + "xpack.transform.stepDefineForm.aggregationsLabel": "聚合", + "xpack.transform.stepDefineForm.aggregationsPlaceholder": "添加聚合……", + "xpack.transform.stepDefineForm.formHelp": "转换是用于数据透视的可伸缩和自动化流程。至少选择一个分组依据和聚合,才能开始。", + "xpack.transform.stepDefineForm.groupByExistsErrorMessage": "名称为“{aggName}”的分组依据配置已存在。", + "xpack.transform.stepDefineForm.groupByLabel": "分组依据", + "xpack.transform.stepDefineForm.groupByPlaceholder": "添加分组依据字段……", + "xpack.transform.stepDefineForm.indexPatternHelpText": "不支持此索引模式的可选查询。受支持索引字段数目为 {maxIndexFields},而此索引有 {numIndexFields} 个字段。", + "xpack.transform.stepDefineForm.indexPatternLabel": "索引模式", + "xpack.transform.stepDefineForm.nestedAggListConflictErrorMessage": "无法添加配置“{aggName}”,因为与“{aggListName}”有嵌套冲突。", + "xpack.transform.stepDefineForm.nestedConflictErrorMessage": "无法添加配置“{aggName}”,因为与“{aggNameCheck}”有嵌套冲突。", + "xpack.transform.stepDefineForm.nestedGroupByListConflictErrorMessage": "无法添加配置“{aggName}”,因为与“{groupByListName}”有嵌套冲突。", + "xpack.transform.stepDefineForm.queryHelpText": "使用查询字符串筛选源数据(可选)。", + "xpack.transform.stepDefineForm.queryLabel": "查询", + "xpack.transform.stepDefineForm.queryPlaceholder": "例如,{example}", + "xpack.transform.stepDefineForm.savedSearchLabel": "已保存搜索", + "xpack.transform.stepDefineSummary.aggregationsLabel": "聚合", + "xpack.transform.stepDefineSummary.groupByLabel": "分组依据", + "xpack.transform.stepDefineSummary.indexPatternLabel": "索引模式", + "xpack.transform.stepDefineSummary.queryCodeBlockLabel": "查询", + "xpack.transform.stepDefineSummary.queryLabel": "查询", + "xpack.transform.stepDefineSummary.savedSearchLabel": "已保存搜索", + "xpack.transform.stepDetailsForm.continuousModeAriaLabel": "选择延迟。", + "xpack.transform.stepDetailsForm.continuousModeDateFieldHelpText": "选择可用于标识新文档的日期字段。", + "xpack.transform.stepDetailsForm.continuousModeDateFieldLabel": "日期字段", + "xpack.transform.stepDetailsForm.continuousModeDelayError": "延迟格式无效", + "xpack.transform.stepDetailsForm.continuousModeDelayHelpText": "当前时间和最新输入数据时间之间的时间延迟。", + "xpack.transform.stepDetailsForm.continuousModeDelayLabel": "延迟", + "xpack.transform.stepDetailsForm.continuousModeError": "连续模式不可用于没有日期字段的索引。", + "xpack.transform.stepDetailsForm.destinationIndexHelpText": "已存在具有此名称的索引。请注意,运行此转换将会修改此目标索引。", + "xpack.transform.stepDetailsForm.destinationIndexInputAriaLabel": "选择唯一目标索引名称。", + "xpack.transform.stepDetailsForm.destinationIndexInvalidError": "目标索引名称无效。", + "xpack.transform.stepDetailsForm.destinationIndexInvalidErrorLink": "详细了解索引名称限制。", + "xpack.transform.stepDetailsForm.destinationIndexLabel": "目标 IP", + "xpack.transform.stepDetailsForm.errorGettingIndexNames": "获取现有索引名称时发生错误:", + "xpack.transform.stepDetailsForm.errorGettingIndexPatternTitles": "获取现有索引模式标题时发生错误:", + "xpack.transform.stepDetailsForm.errorGettingTransformList": "获取现有转换 ID 时发生错误:", + "xpack.transform.stepDetailsForm.indexPatternTitleError": "具有此名称的索引模式已存在。", + "xpack.transform.stepDetailsForm.transformDescriptionHelpText": "(可选)描述性文本。", + "xpack.transform.stepDetailsForm.transformDescriptionInputAriaLabel": "选择可选的转换描述。", + "xpack.transform.stepDetailsForm.transformDescriptionLabel": "转换描述", + "xpack.transform.stepDetailsForm.transformIdExistsError": "已存在具有此 ID 的转换。", + "xpack.transform.stepDetailsForm.transformIdInputAriaLabel": "选择唯一的作业 ID。", + "xpack.transform.stepDetailsForm.transformIdInvalidError": "只能包含小写字母数字字符(a-z 和 0-9)、连字符和下划线,并且必须以字母数字字符开头和结尾。", + "xpack.transform.stepDetailsForm.transformIdLabel": "作业 ID", + "xpack.transform.stepDetailsSummary.continuousModeDateFieldLabel": "连续模式日期字段", + "xpack.transform.stepDetailsSummary.createIndexPatternMessage": "将为此作业创建 Kibana 索引模式。", + "xpack.transform.stepDetailsSummary.destinationIndexLabel": "目标 IP", + "xpack.transform.stepDetailsSummary.transformDescriptionLabel": "转换描述", + "xpack.transform.stepDetailsSummary.transformIdLabel": "作业 ID", + "xpack.transform.tableActionLabel": "操作", + "xpack.transform.toastText.closeModalButtonText": "关闭", + "xpack.transform.toastText.modalTitle": "错误详细信息", + "xpack.transform.toastText.openModalButtonText": "查看详情", + "xpack.transform.transformForm.sizeNotationPlaceholder": "示例:{example1}、{example2}、{example3}、{example4}", + "xpack.transform.transformList.betaBadgeLabel": "公测版", + "xpack.transform.transformList.betaBadgeTooltipContent": "转换为公测版功能。我们很乐意听取您的反馈意见。", + "xpack.transform.transformList.bulkDeleteModalBody": "是否确定要删除{count, plural, one {这} other {这}} {count} 个 {count, plural, one {转换} other {转换}}?转换的目标索引和可选 Kibana 索引模式将不会删除。", + "xpack.transform.transformList.bulkDeleteModalTitle": "删除 {count} 个 {count, plural, one {转换} other {转换}}?", + "xpack.transform.transformList.bulkStartModalTitle": "启动 {count} 个 {count, plural, one {转换} other {转换}}?", + "xpack.transform.transformList.completeBatchTransformBulkActionToolTip": "一个或多个转换为已完成批量转换,无法重新启动。", + "xpack.transform.transformList.completeBatchTransformToolTip": "{transformId} 为已完成批量转换,无法重新启动。", + "xpack.transform.transformList.createTransformButton": "创建转换", + "xpack.transform.transformList.deleteActionDisabledToolTipContent": "停止数据帧作业,以便将其删除。", + "xpack.transform.transformList.deleteActionName": "删除", + "xpack.transform.transformList.deleteBulkActionDisabledToolTipContent": "一个或多个选定数据帧转换必须停止,才能删除。", + "xpack.transform.transformList.deleteModalBody": "是否确定要删除此转换?转换的目标索引和可选 Kibana 索引模式将不会删除。", + "xpack.transform.transformList.deleteModalCancelButton": "取消", + "xpack.transform.transformList.deleteModalDeleteButton": "删除", + "xpack.transform.transformList.deleteModalTitle": "删除 {transformId}", + "xpack.transform.transformList.deleteTransformErrorMessage": "删除转换 {transformId} 时发生错误", + "xpack.transform.transformList.deleteTransformGenericErrorMessage": "调用用于删除转换的 API 终端节点时发生错误。", + "xpack.transform.transformList.deleteTransformSuccessMessage": "删除转换 {transformId} 的请求已确认。", + "xpack.transform.transformList.refreshButtonLabel": "刷新", + "xpack.transform.transformList.rowCollapse": "隐藏 {transformId} 的详情", + "xpack.transform.transformList.rowExpand": "显示 {transformId} 的详情", + "xpack.transform.transformList.startActionName": "开始", + "xpack.transform.transformList.startedTransformBulkToolTip": "一个或多个选定数据帧转换已启动。", + "xpack.transform.transformList.startedTransformToolTip": "{transformId} 已启动。", + "xpack.transform.transformList.startModalBody": "转换将增加集群的搜索和索引负荷。如果负荷超载,请停止转换。是否确定要启动{count, plural, one {这} other {这}} {count} 个 {count, plural, one {转换} other {转换}}?", + "xpack.transform.transformList.startModalCancelButton": "取消", + "xpack.transform.transformList.startModalStartButton": "启动", + "xpack.transform.transformList.startModalTitle": "启动 {transformId}", + "xpack.transform.transformList.startTransformErrorMessage": "启动转换 {transformId} 时发生错误", + "xpack.transform.transformList.startTransformSuccessMessage": "启动转换 {transformId} 的请求已确认。", + "xpack.transform.transformList.stepDetails.previewPane.errorMessage": "无法加载预览", + "xpack.transform.transformList.stopActionName": "停止", + "xpack.transform.transformList.stoppedTransformBulkToolTip": "一个或多个选定数据帧转换已停止。", + "xpack.transform.transformList.stoppedTransformToolTip": "{transformId} 已停止。", + "xpack.transform.transformList.stopTransformErrorMessage": "停止数据帧转换 {transformId} 时发生错误", + "xpack.transform.transformList.stopTransformSuccessMessage": "停止数据帧转换 {transformId} 的请求已确认。", + "xpack.transform.transformList.transformDescription": "使用转换将现有 Elasticsearch 索引切换到摘要式或以实体为中心的索引。", + "xpack.transform.transformList.transformDetails.messagesPane.errorMessage": "无法加载消息", + "xpack.transform.transformList.transformDetails.messagesPane.messageLabel": "消息", + "xpack.transform.transformList.transformDetails.messagesPane.nodeLabel": "节点", + "xpack.transform.transformList.transformDetails.messagesPane.timeLabel": "时间", + "xpack.transform.transformList.transformDetails.tabs.transformMessagesLabel": "消息", + "xpack.transform.transformList.transformDetails.tabs.transformPreviewLabel": "预览", + "xpack.transform.transformList.transformDetails.tabs.transformSettingsLabel": "作业详情", + "xpack.transform.transformList.transformDocsLinkText": "转换文档", + "xpack.transform.transformList.transformTitle": "数据帧作业", + "xpack.transform.transformsWizard.betaBadgeLabel": "公测版", + "xpack.transform.transformsWizard.betaBadgeTooltipContent": "转换为公测版功能。我们很乐意听取您的反馈意见。", + "xpack.transform.transformsWizard.createTransformTitle": "创建转换", + "xpack.transform.transformsWizard.stepCreateTitle": "创建", + "xpack.transform.transformsWizard.stepDefineTitle": "定义透视", + "xpack.transform.transformsWizard.stepDetailsTitle": "作业详情", + "xpack.transform.transformsWizard.transformDocsLinkText": "转换文档", + "xpack.transform.wizard.nextStepButton": "下一个", + "xpack.transform.wizard.previousStepButton": "上一页", + "xpack.upgradeAssistant.appTitle": "{version} 升级助手", + "xpack.upgradeAssistant.checkupTab.backUpCallout.calloutBody.calloutDetail": "使用 {snapshotRestoreDocsButton} 备份您的数据。", + "xpack.upgradeAssistant.checkupTab.backUpCallout.calloutBody.snapshotRestoreDocsButtonLabel": "快照和还原 API", + "xpack.upgradeAssistant.checkupTab.backUpCallout.calloutTitle": "立即备份索引", + "xpack.upgradeAssistant.checkupTab.changeFiltersShowMoreLabel": "更改筛选以显示更多内容。", + "xpack.upgradeAssistant.checkupTab.clusterTabLabel": "集群", + "xpack.upgradeAssistant.checkupTab.controls.collapseAllButtonLabel": "折叠全部", + "xpack.upgradeAssistant.checkupTab.controls.expandAllButtonLabel": "展开全部", + "xpack.upgradeAssistant.checkupTab.controls.filterBar.allButtonLabel": "全部", + "xpack.upgradeAssistant.checkupTab.controls.filterBar.criticalButtonLabel": "紧急", + "xpack.upgradeAssistant.checkupTab.controls.groupByBar.byIndexLabel": "按索引", + "xpack.upgradeAssistant.checkupTab.controls.groupByBar.byIssueLabel": "按问题", + "xpack.upgradeAssistant.checkupTab.controls.refreshButtonLabel": "刷新", + "xpack.upgradeAssistant.checkupTab.controls.searchBarPlaceholder": "筛选", + "xpack.upgradeAssistant.checkupTab.deprecations.criticalActionTooltip": "请解决此问题后再升级。", + "xpack.upgradeAssistant.checkupTab.deprecations.criticalLabel": "紧急", + "xpack.upgradeAssistant.checkupTab.deprecations.documentationButtonLabel": "文档", + "xpack.upgradeAssistant.checkupTab.deprecations.indexTable.detailsColumnLabel": "详情", + "xpack.upgradeAssistant.checkupTab.deprecations.indexTable.indexColumnLabel": "索引", + "xpack.upgradeAssistant.checkupTab.deprecations.warningActionTooltip": "建议在升级之前先解决此问题,但这不是必需的。", + "xpack.upgradeAssistant.checkupTab.deprecations.warningLabel": "警告", + "xpack.upgradeAssistant.checkupTab.indexLabel": "索引", + "xpack.upgradeAssistant.checkupTab.indicesBadgeLabel": "{numIndices, plural, one { 个索引} other { 个索引}}", + "xpack.upgradeAssistant.checkupTab.indicesTabLabel": "索引", + "xpack.upgradeAssistant.checkupTab.noDeprecationsLabel": "无弃用内容", + "xpack.upgradeAssistant.checkupTab.noIssues.nextStepsDetail": "选中 {overviewTabButton} 以执行后续步骤。", + "xpack.upgradeAssistant.checkupTab.noIssues.nextStepsDetail.overviewTabButtonLabel": "“概述”选项卡", + "xpack.upgradeAssistant.checkupTab.noIssues.noIssuesLabel": "您没有 {strongCheckupLabel} 问题。", + "xpack.upgradeAssistant.checkupTab.noIssues.noIssuesTitle": "全部清除!", + "xpack.upgradeAssistant.checkupTab.numDeprecationsShownLabel": "显示 {numShown} 个,共 {total} 个", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.cancelButtonLabel": "取消", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.closeButtonLabel": "关闭", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.continueButtonLabel": "继续重新索引", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.insufficientPrivilegeCallout.calloutTitle": "您没有足够的权限来重新索引此索引", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.readonlyCallout.backgroundResumeDetail": "重新索引将在后台继续,但如果 Kibana 关闭或重新启动,您将需要返回此页,才能恢复重新索引。", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.readonlyCallout.calloutTitle": "在重新索引时,索引无法采集、更新或删除文档", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.readonlyCallout.cantStopDetail": "如果您无法停止文档更新或需要重新索引到新的集群中,请考虑使用不同的升级策略。", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexButton.doneLabel": "已完成!", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexButton.reindexingLabel": "正在重新索引……", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexButton.resumeLabel": "恢复", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexButton.runReindexLabel": "运行重新索引", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexButton.tryAgainLabel": "重试", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.aliasSwapStepTitle": "正在交换具有别名的原始索引", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.cancelButton.cancelLabel": "取消", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.cancelButton.cancelledLabel": "已取消", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.cancelButton.cancellingLabel": "正在取消……", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.cancelButton.errorLabel": "无法取消", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.createIndexStepTitle": "正在创建新索引", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.pauseMlStepTitle": "正在暂停 Machine Learning 作业", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.readonlyStepTitle": "正在将旧索引设置为只读", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.reindexingDocumentsStepTitle": "正在重新索引文档", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.resumeMlStepTitle": "正在恢复 Machine Learning 作业", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.resumeWatcherStepTitle": "正在恢复 Watcher", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklist.stopWatcherStepTitle": "正在停止 Watcher", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.checklistStep.reindexingChecklistTitle": "重新索引过程", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.flyoutHeader": "重新索引 {indexName}", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.warningsStep.apmReindexWarningDetail": "从版本 7.0.0 开始,将以 Elastic Common Schema 格式表示 APM 数据。只有重新索引历史 APM 数据后,其才可见。", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.warningsStep.apmReindexWarningTitle": "此索引将转换成 ECS 格式", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.warningsStep.destructiveCallout.calloutDetail": "备份您的索引,然后通过接受每个重大更改来继续重新索引。", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.warningsStep.destructiveCallout.calloutTitle": "此索引需要无法撤消的破坏性更改", + "xpack.upgradeAssistant.checkupTab.reindexing.flyout.warningsStep.documentationLinkLabel": "文档", + "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.cancelledLabel": "已取消", + "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.doneLabel": "完成", + "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.failedLabel": "失败", + "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.loadingLabel": "正在加载……", + "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.pausedLabel": "已暂停", + "xpack.upgradeAssistant.checkupTab.reindexing.reindexButton.reindexLabel": "重新索引", + "xpack.upgradeAssistant.checkupTab.tabDetail": "需要注意这些 {strongCheckupLabel} 问题。在升级到 Elasticsearch {nextEsVersion} 之前先解决这些问题。", + "xpack.upgradeAssistant.forbiddenErrorCallout.calloutTitle": "您没有足够的权限来查看此页。", + "xpack.upgradeAssistant.genericErrorCallout.calloutTitle": "检索检查结果时出错。", + "xpack.upgradeAssistant.overviewTab.overviewTabTitle": "概览", + "xpack.upgradeAssistant.overviewTab.steps.clusterStep.issuesRemainingStepTitle": "检查集群是否存在问题", + "xpack.upgradeAssistant.overviewTab.steps.clusterStep.noIssuesRemainingStepTitle": "您的集群设置已就绪", + "xpack.upgradeAssistant.overviewTab.steps.clusterStep.noRemainingIssuesLabel": "没有其余已弃用设置。", + "xpack.upgradeAssistant.overviewTab.steps.clusterStep.remainingIssuesDetail": "必须解决 {numIssues} 个问题。", + "xpack.upgradeAssistant.overviewTab.steps.clusterStep.todo.clusterTabButtonLabel": "“集群”选项卡", + "xpack.upgradeAssistant.overviewTab.steps.clusterStep.todo.todoDetail": "转到 {clusterTabButton} 并更新已弃用的设置。", + "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.deprecationLogs.deprecationLogsDocButtonLabel": "弃用日志", + "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.deprecationLogs.logsDetail": "请参阅 {deprecationLogsDocButton},了解您的应用程序使用的功能是否未在 {nextEsVersion} 中提供。您可能需要启用弃用日志。", + "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.enableDeprecationLoggingLabel": "是否启用弃用日志?", + "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.enableDeprecationLoggingToggleSwitch.disabledLabel": "关闭", + "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.enableDeprecationLoggingToggleSwitch.enabledLabel": "开启", + "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.enableDeprecationLoggingToggleSwitch.errorLabel": "无法加载日志状态", + "xpack.upgradeAssistant.overviewTab.steps.deprecationLogsStep.stepTitle": "查看 Elasticsearch 弃用日志", + "xpack.upgradeAssistant.overviewTab.steps.indicesStep.issuesRemainingStepTitle": "检查索引是否存在问题", + "xpack.upgradeAssistant.overviewTab.steps.indicesStep.noIssuesRemainingStepTitle": "您的索引设置已就绪", + "xpack.upgradeAssistant.overviewTab.steps.indicesStep.noRemainingIssuesLabel": "没有其余已弃用设置。", + "xpack.upgradeAssistant.overviewTab.steps.indicesStep.remainingIssuesDetail": "必须解决 {numIssues} 个问题。", + "xpack.upgradeAssistant.overviewTab.steps.indicesStep.todo.indicesTabButtonLabel": "“索引”选项卡", + "xpack.upgradeAssistant.overviewTab.steps.indicesStep.todo.todoDetail": "转到 {indicesTabButton} 并更新已弃用的设置。", + "xpack.upgradeAssistant.overviewTab.steps.startUpgradeStep.stepTitle": "开始升级", + "xpack.upgradeAssistant.overviewTab.steps.startUpgradeStepCloud.stepDetail.goToCloudDashboardDetail": "转到 Elastic Cloud 仪表板上的“部署”部分开始升级。", + "xpack.upgradeAssistant.overviewTab.steps.startUpgradeStepOnPrem.stepDetail.followInstructionsDetail": "按照 {instructionButton} 开始升级。", + "xpack.upgradeAssistant.overviewTab.steps.startUpgradeStepOnPrem.stepDetail.instructionButtonLabel": "以下说明", + "xpack.upgradeAssistant.overviewTab.steps.waitForReleaseStep.stepDetail": "版本发布后,请升级到最新的 {currentEsMajorVersion} 版本,然后返回此处,继续升级到 {nextEsMajorVersion}。", + "xpack.upgradeAssistant.overviewTab.steps.waitForReleaseStep.stepTitle": "等待 Elasticsearch {nextEsVersion} 发布版", + "xpack.upgradeAssistant.overviewTab.tabDetail": "此助理将帮助您为 Elasticsearch {nextEsVersion} 准备集群和索引。有关需要注意的其他问题,请参阅 Elasticsearch 日志。", + "xpack.upgradeAssistant.tabs.checkupTab.clusterLabel": "集群", + "xpack.upgradeAssistant.tabs.incompleteCallout.calloutBody.breackingChangesDocButtonLabel": "弃用内容和重大更改", + "xpack.upgradeAssistant.tabs.incompleteCallout.calloutBody.calloutDetail": "Elasticsearch {nextEsVersion} 中的 {breakingChangesDocButton} 完整列表将在最终的 {currentEsVersion} 次要版本中提供。完成列表后,此警告将消失。", + "xpack.upgradeAssistant.tabs.incompleteCallout.calloutTitle": "问题列表可能不完整", + "xpack.upgradeAssistant.tabs.upgradingInterstitial.upgradeCompleteDescription": "所有 Elasticsearch 节点已升级。可以现在升级 Kibana。", + "xpack.upgradeAssistant.tabs.upgradingInterstitial.upgradeCompleteTitle": "您的集群已升级", + "xpack.upgradeAssistant.tabs.upgradingInterstitial.upgradingDescription": "一个或多个 Elasticsearch 节点的 Elasticsearch 版本比 Kibana 版本新。所有节点升级后,请升级 Kibana。", + "xpack.upgradeAssistant.tabs.upgradingInterstitial.upgradingTitle": "您的集群正在升级", + "xpack.uptime.apmIntegrationAction.description": "在 APM 中搜索此监测", + "xpack.uptime.apmIntegrationAction.text": "在 APM 中查找域", + "xpack.uptime.badge.readOnly.text": "只读", + "xpack.uptime.badge.readOnly.tooltip": "无法保存", + "xpack.uptime.breadcrumbs.overviewBreadcrumbText": "运行时间", + "xpack.uptime.durationChart.emptyPrompt.description": "在选定时间范围内此监测从未{emphasizedText}。", + "xpack.uptime.durationChart.emptyPrompt.title": "没有持续时间数据", + "xpack.uptime.emptyState.configureHeartbeatLinkText": "配置 Heartbeat", + "xpack.uptime.emptyState.configureHeartbeatToGetStartedMessage": "{configureHeartbeatLink}以开始收集运行时间数据。", + "xpack.uptime.emptyState.loadingMessage": "正在加载……", + "xpack.uptime.emptyState.noDataMessage": "未找到任何运行时间数据", + "xpack.uptime.emptyState.noDataTitle": "没有可用的运行时间数据", + "xpack.uptime.emptyState.noIndexTitle": "找不到运行时间索引", + "xpack.uptime.emptyStateError.notAuthorized": "您无权查看 Uptime 数据,请联系系统管理员。", + "xpack.uptime.emptyStateError.notFoundPage": "未找到页面", + "xpack.uptime.emptyStateError.title": "错误", + "xpack.uptime.errorMessage": "错误:{message}", + "xpack.uptime.featureCatalogueDescription": "执行终端节点运行状况检查和运行时间监测。", + "xpack.uptime.featureRegistry.uptimeFeatureName": "运行时间", + "xpack.uptime.filterBar.filterDownLabel": "关闭", + "xpack.uptime.filterBar.filterUpLabel": "运行", + "xpack.uptime.filterBar.options.location.name": "位置", + "xpack.uptime.filterBar.options.portLabel": "端口", + "xpack.uptime.filterBar.options.schemeLabel": "方案", + "xpack.uptime.filterPopout.loadingMessage": "正在加载……", + "xpack.uptime.filterPopout.searchMessage": "搜索 {title}", + "xpack.uptime.integrationLink.missingDataMessage": "未找到此集成的所需数据。", + "xpack.uptime.kueryBar.indexPatternMissingWarningMessage": "检索索引模式时出错。", + "xpack.uptime.kueryBar.searchPlaceholder": "搜索监测 ID、名称和协议类型......", + "xpack.uptime.locationName.helpLinkAnnotation": "添加位置", + "xpack.uptime.monitorChart.checksChart.bottomAxis.title": "鏃堕棿鎴", + "xpack.uptime.monitorChart.checksChart.leftAxis.title": "检查数目", + "xpack.uptime.monitorCharts.checkStatus.series.downCountLabel": "关闭计数", + "xpack.uptime.monitorCharts.checkStatus.series.upCountLabel": "运行计数", + "xpack.uptime.monitorCharts.checkStatus.title": "检查状态", + "xpack.uptime.monitorCharts.durationChart.bottomAxis.title": "鏃堕棿鎴", + "xpack.uptime.monitorCharts.durationChart.leftAxis.title": "持续时间 (ms)", + "xpack.uptime.monitorCharts.loadingMessage": "正在加载……", + "xpack.uptime.monitorCharts.monitorDuration.titleLabel": "监测持续时间(毫秒)", + "xpack.uptime.monitorList.downLineSeries.downLabel": "关闭", + "xpack.uptime.monitorList.expandDrawerButton.ariaLabel": "展开 ID {id} 的监测行", + "xpack.uptime.monitorList.geoName.helpLinkAnnotation": "添加位置", + "xpack.uptime.monitorList.infraIntegrationAction.container.message": "显示容器指标", + "xpack.uptime.monitorList.infraIntegrationAction.docker.description": "在 Infrastructure UI 上查找此监测的容器 ID", + "xpack.uptime.monitorList.infraIntegrationAction.docker.tooltip": "在 Infrastructure UI 上查找容器 ID“{containerId}”", + "xpack.uptime.monitorList.infraIntegrationAction.ip.ariaLabel": "在 Infrastructure UI 上查找此监测的 IP 地址", + "xpack.uptime.monitorList.infraIntegrationAction.ip.message": "显示主机指标", + "xpack.uptime.monitorList.infraIntegrationAction.ip.tooltip": "在 Infrastructure UI 上查找 IP“{ip}”", + "xpack.uptime.monitorList.infraIntegrationAction.kubernetes.description": "在 Infrastructure UI 上查找此监测的 Pod UID", + "xpack.uptime.monitorList.infraIntegrationAction.kubernetes.message": "显示 Pod 指标", + "xpack.uptime.monitorList.infraIntegrationAction.kubernetes.tooltip": "在 Infrastructure UI 上查找 Pod UID“{podUid}”", + "xpack.uptime.monitorList.integrationGroup.emptyMessage": "没有可用的集成应用程序", + "xpack.uptime.monitorList.loggingIntegrationAction.container.id": "显示容器日志", + "xpack.uptime.monitorList.loggingIntegrationAction.container.message": "显示容器日志", + "xpack.uptime.monitorList.loggingIntegrationAction.container.tooltip": "在 Logging UI 上查找容器 ID“{containerId}”", + "xpack.uptime.monitorList.loggingIntegrationAction.ip.description": "在 Logging UI 中查找此监测的 IP 地址", + "xpack.uptime.monitorList.loggingIntegrationAction.ip.message": "显示主机日志", + "xpack.uptime.monitorList.loggingIntegrationAction.ip.tooltip": "在 Logging UI 上查找 IP“{ip}”", + "xpack.uptime.monitorList.loggingIntegrationAction.kubernetes.ariaLabel": "显示 Pod 日志", + "xpack.uptime.monitorList.loggingIntegrationAction.kubernetes.message": "显示 Pod 日志", + "xpack.uptime.monitorList.loggingIntegrationAction.kubernetes.tooltip": "查找 Pod UID“{podUid}”的日志", + "xpack.uptime.monitorList.monitorHistoryColumnLabel": "中断历史记录", + "xpack.uptime.monitorList.monitoringStatusTitle": "检测状态", + "xpack.uptime.monitorList.nameColumnLabel": "鍥惧眰鍚嶇О", + "xpack.uptime.monitorList.noItemForSelectedFiltersMessage": "未找到匹配选定筛选条件的监测", + "xpack.uptime.monitorList.noItemMessage": "未找到任何运行时间监测", + "xpack.uptime.monitorList.observabilityIntegrationsColumn.apmIntegrationLink.tooltip": "点击此处以在 APM 中查找“{domain}”。", + "xpack.uptime.monitorList.observabilityIntegrationsColumn.popoverIconButton.ariaLabel": "打开 url {monitorUrl} 的监测的集成弹出式窗口", + "xpack.uptime.monitorList.statusColumn.downLabel": "关闭", + "xpack.uptime.monitorList.statusColumn.upLabel": "运行", + "xpack.uptime.monitorList.statusColumnLabel": "状态", + "xpack.uptime.monitorList.table.description": "具有“状态”、“名称”、“URL”、“IP”、“中断历史记录”和“集成”列的“监测状态”表。该表当前显示 {length} 个项目。", + "xpack.uptime.monitorStatusBar.durationTextAriaLabel": "监测持续时间(毫秒)", + "xpack.uptime.monitorStatusBar.healthStatusMessage.downLabel": "关闭", + "xpack.uptime.monitorStatusBar.healthStatusMessage.upLabel": "运行", + "xpack.uptime.monitorStatusBar.healthStatusMessageAriaLabel": "检测状态", + "xpack.uptime.monitorStatusBar.loadingMessage": "正在加载……", + "xpack.uptime.monitorStatusBar.monitorUrlLinkAriaLabel": "监测 URL 链接", + "xpack.uptime.monitorStatusBar.timestampFromNowTextAriaLabel": "自上次检查以来经过的时间", + "xpack.uptime.notFountPage.homeLinkText": "返回主页", + "xpack.uptime.overviewPage.headerText": "概览", + "xpack.uptime.overviewPageLink.disabled.ariaLabel": "禁用的分页按钮表示在监测列表中无法进行进一步导航。", + "xpack.uptime.overviewPageLink.next.ariaLabel": "下页结果", + "xpack.uptime.overviewPageLink.prev.ariaLabel": "上页结果", + "xpack.uptime.overviewPageParsingErrorCallout.content": "解析筛选查询时出错。{content}", + "xpack.uptime.overviewPageParsingErrorCallout.noMessage": "没有错误消息", + "xpack.uptime.overviewPageParsingErrorCallout.title": "解析错误", + "xpack.uptime.pingList.checkHistoryTitle": "历史记录", + "xpack.uptime.pingList.collapseRow": "折叠", + "xpack.uptime.pingList.durationMsColumnFormatting": "{millis} 毫秒", + "xpack.uptime.pingList.durationMsColumnLabel": "持续时间", + "xpack.uptime.pingList.errorTypeColumnLabel": "错误类型", + "xpack.uptime.pingList.expandedRow.bodySize": "正文大小为 {bodyBytes}。", + "xpack.uptime.pingList.expandedRow.error": "错误", + "xpack.uptime.pingList.expandedRow.response_body": "响应正文", + "xpack.uptime.pingList.expandedRow.truncated": "显示前 {contentBytes} 字节。", + "xpack.uptime.pingList.expandRow": "展开", + "xpack.uptime.pingList.ipAddressColumnLabel": "IP", + "xpack.uptime.pingList.locationLabel": "位置", + "xpack.uptime.pingList.locationNameColumnLabel": "位置", + "xpack.uptime.pingList.recencyMessage": "{fromNow}已检查", + "xpack.uptime.pingList.responseCodeColumnLabel": "响应代码", + "xpack.uptime.pingList.statusColumnHealthDownLabel": "关闭", + "xpack.uptime.pingList.statusColumnHealthUpLabel": "运行", + "xpack.uptime.pingList.statusColumnLabel": "状态", + "xpack.uptime.pingList.statusLabel": "状态", + "xpack.uptime.pingList.statusOptions.allStatusOptionLabel": "全部", + "xpack.uptime.pingList.statusOptions.downStatusOptionLabel": "关闭", + "xpack.uptime.pingList.statusOptions.upStatusOptionLabel": "运行", + "xpack.uptime.pluginDescription": "运行时间监测", + "xpack.uptime.snapshot.downCountsMessage": "{down}/{total} 个监测已关闭", + "xpack.uptime.snapshot.noDataDescription": "抱歉,没有可用于该直方图的数据", + "xpack.uptime.snapshot.noDataTitle": "没有可用的直方图数据", + "xpack.uptime.snapshot.noMonitorMessage": "未找到任何监测", + "xpack.uptime.snapshot.pingsOverTimeTitle": "时移 Ping 数", + "xpack.uptime.snapshot.zeroDownMessage": "所有监测已启动", + "xpack.uptime.snapshotHistogram.description": "显示从 {startTime} 到 {endTime} 的运行时间时移状态的条形图。", + "xpack.uptime.snapshotHistogram.downMonitorsId": "已关闭监测", + "xpack.uptime.snapshotHistogram.series.downLabel": "关闭", + "xpack.uptime.snapshotHistogram.series.upLabel": "运行", + "xpack.uptime.snapshotHistogram.xAxisId": "快照 X 轴", + "xpack.uptime.snapshotHistogram.yAxis.title": "Ping", + "xpack.uptime.snapshotHistogram.yAxisId": "快照 Y 轴", + "xpack.uptime.uptimeFeatureCatalogueTitle": "运行时间", + "xpack.watcher.app.licenseErrorLinkText": "管理您的许可。", + "xpack.watcher.app.licenseErrorTitle": "许可错误", + "xpack.watcher.appName": "Watcher", + "xpack.watcher.breadcrumb.createLabel": "创建", + "xpack.watcher.breadcrumb.editLabel": "缂栬緫", + "xpack.watcher.breadcrumb.listLabel": "Watcher", + "xpack.watcher.breadcrumb.statusLabel": "状态", + "xpack.watcher.constants.actionStates.acknowledgedStateText": "已确认", + "xpack.watcher.constants.actionStates.configErrorStateText": "配置错误", + "xpack.watcher.constants.actionStates.errorStateText": "错误", + "xpack.watcher.constants.actionStates.firingStateText": "正在发送", + "xpack.watcher.constants.actionStates.okStateText": "确定", + "xpack.watcher.constants.actionStates.throttledStateText": "已限制", + "xpack.watcher.constants.watchStateComments.acknowledgedStateCommentText": "已确认", + "xpack.watcher.constants.watchStateComments.executionFailingStateCommentText": "执行失败", + "xpack.watcher.constants.watchStateComments.partiallyAcknowledgedStateCommentText": "已部分确认", + "xpack.watcher.constants.watchStateComments.partiallyThrottledStateCommentText": "已部分限制", + "xpack.watcher.constants.watchStateComments.throttledStateCommentText": "已限制", + "xpack.watcher.constants.watchStates.configErrorStateText": "配置错误", + "xpack.watcher.constants.watchStates.disabledStateText": "已禁用", + "xpack.watcher.constants.watchStates.errorStateText": "错误!", + "xpack.watcher.constants.watchStates.firingStateText": "正在发送", + "xpack.watcher.constants.watchStates.okStateText": "确定", + "xpack.watcher.deleteSelectedWatchesConfirmModal.cancelButtonLabel": "鍙栨秷", + "xpack.watcher.deleteSelectedWatchesConfirmModal.deleteButtonLabel": "删除 {numWatchesToDelete, plural, one {个监视} other {# 个监视}} ", + "xpack.watcher.deleteSelectedWatchesConfirmModal.descriptionText": "无法恢复{numWatchesToDelete, plural, one {已删除监视} other {已删除监视}}。", + "xpack.watcher.models.actionStatus.actionStatusJsonPropertyMissingBadRequestMessage": "JSON 参数必须包含“{missingProperty}”属性", + "xpack.watcher.models.actionStatus.notDetermineActionStatusBadImplementationMessage": "无法确定操作状态;操作 = {actionStatusJson}", + "xpack.watcher.models.baseAction.selectMessageText": "执行操作。", + "xpack.watcher.models.baseAction.simulateButtonLabel": "立即模拟此操作", + "xpack.watcher.models.baseAction.simulateMessage": "已成功模拟操作 {id}", + "xpack.watcher.models.baseAction.typeName": "操作", + "xpack.watcher.models.baseWatch.createUnknownActionTypeErrorMessage": "尝试创建的操作类型 {type} 未知。", + "xpack.watcher.models.baseWatch.displayName": "新建监视", + "xpack.watcher.models.baseWatch.idPropertyMissingBadRequestMessage": "json 参数必须包含 {id} 属性", + "xpack.watcher.models.baseWatch.selectMessageText": "设置新监视。", + "xpack.watcher.models.baseWatch.typeName": "监视", + "xpack.watcher.models.baseWatch.watchJsonPropertyMissingBadRequestMessage": "json 参数必须包含 {watchJson} 属性", + "xpack.watcher.models.baseWatch.watchStatusJsonPropertyMissingBadRequestMessage": "json 参数必须包含 {watchStatusJson} 属性", + "xpack.watcher.models.emailAction.actionJsonEmailPropertyMissingBadRequestMessage": "json 参数必须包含 {actionJsonEmail} 属性", + "xpack.watcher.models.emailAction.actionJsonEmailToPropertyMissingBadRequestMessage": "json 参数必须包含 {actionJsonEmailTo} 属性", + "xpack.watcher.models.emailAction.defaultSubjectText": "监视 [{context}] 已超过阈值", + "xpack.watcher.models.emailAction.selectMessageText": "从您的服务器发送电子邮件。", + "xpack.watcher.models.emailAction.simulateButtonLabel": "立即试发电子邮件", + "xpack.watcher.models.emailAction.simulateFailMessage": "无法将电子邮件发至 {toList}。", + "xpack.watcher.models.emailAction.simulateMessage": "已发至 {toList} 的电子邮件示例", + "xpack.watcher.models.emailAction.typeName": "电子邮件", + "xpack.watcher.models.fields.fieldsPropertyMissingBadRequestMessage": "json 参数必须包含 {fields} 属性", + "xpack.watcher.models.indexAction.actionJsonIndexPropertyMissingBadRequestMessage": "JSON 参数必须包含 {actionJsonIndex} 属性", + "xpack.watcher.models.indexAction.selectMessageText": "将数据索引到 Elasticsearch 中。", + "xpack.watcher.models.indexAction.simulateButtonLabel": "索引数据", + "xpack.watcher.models.indexAction.simulateFailMessage": "无法索引 {index}", + "xpack.watcher.models.indexAction.simulateMessage": "已对索引 {index} 进行索引。", + "xpack.watcher.models.indexAction.typeName": "绱㈠紩", + "xpack.watcher.models.jiraAction.actionJsonJiraIssueTypePropertyMissingBadRequestMessage": "JSON 参数必须包含 {actionJsonJiraIssueType} 属性", + "xpack.watcher.models.jiraAction.actionJsonJiraProjectKeyPropertyMissingBadRequestMessage": "JSON 参数必须包含 {actionJsonJiraProjectKey} 属性", + "xpack.watcher.models.jiraAction.actionJsonJiraPropertyMissingBadRequestMessage": "JSON 参数必须包含 {actionJsonJira} 属性", + "xpack.watcher.models.jiraAction.actionJsonJiraSummaryPropertyMissingBadRequestMessage": "JSON 参数必须包含 {actionJsonJiraSummary} 属性", + "xpack.watcher.models.jiraAction.defaultSummaryText": "监视 [{context}] 已超过阈值", + "xpack.watcher.models.jiraAction.selectMessageText": "在 Atlassian 的 Jira Software 中创建问题。", + "xpack.watcher.models.jiraAction.simulateButtonLabel": "创建示例 Jira 问题", + "xpack.watcher.models.jiraAction.simulateFailMessage": "无法创建 Jira 问题。", + "xpack.watcher.models.jiraAction.simulateMessage": "Jira 问题已创建。", + "xpack.watcher.models.jiraAction.typeName": "Jira", + "xpack.watcher.models.jsonWatch.selectMessageText": "以原始 JSON 格式设置定制监视。", + "xpack.watcher.models.jsonWatch.typeName": "高级监视", + "xpack.watcher.models.loggingAction.actionJsonIndexNamePropertyMissingBadRequestMessage": "JSON 参数必须包含 {actionJsonIndexName} 属性", + "xpack.watcher.models.loggingAction.actionJsonLoggingPropertyMissingBadRequestMessage": "json 参数必须包含 {actionJsonLogging} 属性", + "xpack.watcher.models.loggingAction.actionJsonLoggingTextPropertyMissingBadRequestMessage": "json 参数必须包含 {actionJsonLoggingText} 属性", + "xpack.watcher.models.loggingAction.actionJsonWebhookHostPropertyMissingBadRequestMessage": "JSON 参数必须包含 {actionJsonWebhookHost} 属性", + "xpack.watcher.models.loggingAction.actionJsonWebhookPortPropertyMissingBadRequestMessage": "JSON 参数必须包含 {actionJsonWebhookPort} 属性", + "xpack.watcher.models.loggingAction.defaultText": "监视 [{context}] 已超过阈值", + "xpack.watcher.models.loggingAction.selectMessageText": "向日志添加新项。", + "xpack.watcher.models.loggingAction.simulateButtonLabel": "立即记录示例消息", + "xpack.watcher.models.loggingAction.simulateFailMessage": "无法记录示例消息。", + "xpack.watcher.models.loggingAction.simulateMessage": "示例消息已记录", + "xpack.watcher.models.loggingAction.typeName": "日志", + "xpack.watcher.models.monitoringWatch.formatVisualizeDataCalledBadRequestMessage": "为监测监视而调用的 {formatVisualizeData}", + "xpack.watcher.models.monitoringWatch.fromDownstreamJsonCalledBadRequestMessage": "为监测监视而调用的 {fromDownstreamJson}", + "xpack.watcher.models.monitoringWatch.getVisualizeQueryCalledBadRequestMessage": "为监测监视而调用的 {getVisualizeQuery}", + "xpack.watcher.models.monitoringWatch.upstreamJsonCalledBadRequestMessage": "为监测监视而调用的 {upstreamJson}", + "xpack.watcher.models.pagerDutyAction.actionJsonPagerDutyDescriptionPropertyMissingBadRequestMessage": "JSON 参数必须包含 {actionJsonPagerDutyText} 属性", + "xpack.watcher.models.pagerDutyAction.actionJsonPagerDutyPropertyMissingBadRequestMessage": "JSON 参数必须包含 {actionJsonPagerDuty} 属性", + "xpack.watcher.models.pagerdutyAction.defaultDescriptionText": "监视 [{context}] 已超过阈值", + "xpack.watcher.models.pagerDutyAction.selectMessageText": "在 PagerDuty 中创建事件。", + "xpack.watcher.models.pagerDutyAction.simulateButtonLabel": "发送 PagerDuty 事件", + "xpack.watcher.models.pagerDutyAction.simulateFailMessage": "无法发送 Hipchat 事件。", + "xpack.watcher.models.pagerDutyAction.simulateMessage": "PagerDuty 事件已发送。", + "xpack.watcher.models.pagerDutyAction.typeName": "PagerDuty", + "xpack.watcher.models.slackAction.actionJsonSlackMessagePropertyMissingBadRequestMessage": "json 参数必须包含 {actionJsonSlackMessage} 属性", + "xpack.watcher.models.slackAction.actionJsonSlackPropertyMissingBadRequestMessage": "json 参数必须包含 {actionJsonSlack} 属性", + "xpack.watcher.models.slackAction.defaultText": "监视 [{context}] 已超过阈值", + "xpack.watcher.models.slackAction.selectMessageText": "向 slack 用户或渠道发送消息。", + "xpack.watcher.models.slackAction.simulateButtonLabel": "立即发送示例消息", + "xpack.watcher.models.slackAction.simulateFailMessage": "无法将示例 Slack 消息发至 {toList}。", + "xpack.watcher.models.slackAction.simulateMessage": "已发送至 {toList} 的示例 Slack 消息。", + "xpack.watcher.models.slackAction.TypeName": "Slack", + "xpack.watcher.models.thresholdWatch.selectMessageText": "在特定条件下发送告警", + "xpack.watcher.models.thresholdWatch.sendAlertOnSpecificConditionTitleDescription": "满足特定条件时发送告警。", + "xpack.watcher.models.thresholdWatch.thresholdWatchIntervalTitleDescription": "这将每 {triggerIntervalSize} {timeUnitLabel}运行一次。", + "xpack.watcher.models.thresholdWatch.typeName": "阈值告警", + "xpack.watcher.models.unknownAction.actionJsonPropertyMissingBadRequestMessage": "json 参数必须包含 {actionJson} 属性", + "xpack.watcher.models.watch.typePropertyMissingBadRequestMessage": "json 参数必须包含 {type} 属性", + "xpack.watcher.models.watch.unknownWatchTypeLoadingAttemptBadRequestMessage": "尝试加载的类型 {jsonType} 未知", + "xpack.watcher.models.watch.watchJsonPropertyMissingBadRequestMessage": "json 参数必须包含 {watchJson} 属性", + "xpack.watcher.models.watchHistoryItem.idPropertyMissingBadRequestMessage": "json 参数必须包含 {id} 属性", + "xpack.watcher.models.watchHistoryItem.watchHistoryItemJsonPropertyMissingBadRequestMessage": "json 参数必须包含 {watchHistoryItemJson} 属性", + "xpack.watcher.models.watchHistoryItem.watchIdPropertyMissingBadRequestMessage": "json 参数必须包含 {watchId} 属性", + "xpack.watcher.models.watchStatus.idPropertyMissingBadRequestMessage": "json 参数必须包含 {id} 属性", + "xpack.watcher.models.watchStatus.watchStatusJsonPropertyMissingBadRequestMessage": "json 参数必须包含 {watchStatusJson} 属性", + "xpack.watcher.models.webhookAction.selectMessageText": "将请求发送到 Web 服务。", + "xpack.watcher.models.webhookAction.simulateButtonLabel": "发送请求", + "xpack.watcher.models.webhookAction.simulateFailMessage": "无法将请求发送至 {fullPath}", + "xpack.watcher.models.webhookAction.simulateMessage": "样例请求已发送到 {fullPath}", + "xpack.watcher.models.webhookAction.typeName": "Webhook", + "xpack.watcher.pageErrorForbidden.title": "您没有使用 Watcher 的权限", + "xpack.watcher.pageErrorNotExist.description": "找不到 ID 为“{id}”的监视。", + "xpack.watcher.pageErrorNotExist.title": "找不到监视", + "xpack.watcher.requestFlyout.closeButtonLabel": "关闭", + "xpack.watcher.requestFlyout.descriptionText": "此 Elasticsearch 请求将创建或更新此监视。", + "xpack.watcher.requestFlyout.namedTitle": "对“{id}”的请求", + "xpack.watcher.requestFlyout.unnamedTitle": "请求", + "xpack.watcher.saveRoute.duplicateWatchIdErrorMessage": "已有 ID 为“{watchId}”的监视。", + "xpack.watcher.sections.watchDetail.actionErrorsCalloutTitle": "此操作包含错误", + "xpack.watcher.sections.watchDetail.header": "“{watch}”的当前状态", + "xpack.watcher.sections.watchDetail.headerBadgeText": "系统监视", + "xpack.watcher.sections.watchDetail.headerBadgeToolipText": "您无法停用或删除系统监视。", + "xpack.watcher.sections.watchDetail.watchTable.ackActionCellTitle": "确认", + "xpack.watcher.sections.watchDetail.watchTable.ackActionCellTooltipTitle": "确认监视操作。", + "xpack.watcher.sections.watchDetail.watchTable.ackActionErrorMessage": "确认操作 {actionId} 时出错", + "xpack.watcher.sections.watchDetail.watchTable.actionHeader": "鍥惧眰鍚嶇О", + "xpack.watcher.sections.watchDetail.watchTable.errorsCellText": "{total, number} {total, plural, one {个错误} other {个错误}}", + "xpack.watcher.sections.watchDetail.watchTable.errorsHeader": "错误", + "xpack.watcher.sections.watchDetail.watchTable.noWatchesMessage": "没有可显示的操作", + "xpack.watcher.sections.watchDetail.watchTable.stateHeader": "状态", + "xpack.watcher.sections.watchEdit.actions.addActionButtonLabel": "添加操作", + "xpack.watcher.sections.watchEdit.actions.disabledOptionLabel": "已禁用。配置您的 elasticsearch.yml。", + "xpack.watcher.sections.watchEdit.actions.title": "满足条件时执行 {watchActionsCount, plural, one{# 个操作} other {# 个操作}}", + "xpack.watcher.sections.watchEdit.errorLoadingWatchVisualizationTitle": "无法加载监视可视化", + "xpack.watcher.sections.watchEdit.errorTitle": "加载监视时出错", + "xpack.watcher.sections.watchEdit.json.cancelButtonLabel": "鍙栨秷", + "xpack.watcher.sections.watchEdit.json.createButtonLabel": "创建监视", + "xpack.watcher.sections.watchEdit.json.editTabLabel": "编辑", + "xpack.watcher.sections.watchEdit.json.error.invalidActionType": "为操作“{action}”提供的操作类型未知。", + "xpack.watcher.sections.watchEdit.json.error.invalidIdText": "ID 只能包含字母、下划线、短划线和数字。", + "xpack.watcher.sections.watchEdit.json.error.invalidJsonText": "JSON 无效", + "xpack.watcher.sections.watchEdit.json.error.requiredIdText": "ID 必填", + "xpack.watcher.sections.watchEdit.json.error.requiredJsonText": "JSON 必填", + "xpack.watcher.sections.watchEdit.json.form.actionValidationErrorMessage": "监视操作无效", + "xpack.watcher.sections.watchEdit.json.form.watchIDLabel": "ID", + "xpack.watcher.sections.watchEdit.json.form.watchJsonAriaLabel": "代码编辑器", + "xpack.watcher.sections.watchEdit.json.form.watchJsonDocLink": "API 语法", + "xpack.watcher.sections.watchEdit.json.form.watchJsonLabel": "监视 JSON", + "xpack.watcher.sections.watchEdit.json.form.watchNameLabel": "名称(可选)", + "xpack.watcher.sections.watchEdit.json.hideRequestButtonLabel": "隐藏请求", + "xpack.watcher.sections.watchEdit.json.saveButtonLabel": "保存监视", + "xpack.watcher.sections.watchEdit.json.saveConfirmModal.cancelButtonLabel": "鍙栨秷", + "xpack.watcher.sections.watchEdit.json.saveConfirmModal.saveButtonLabel": "保存监视", + "xpack.watcher.sections.watchEdit.json.saveSuccessNotificationText": "已保存“{watchDisplayName}”", + "xpack.watcher.sections.watchEdit.json.saveWatchErrorTitle": "保存监视时出错", + "xpack.watcher.sections.watchEdit.json.showRequestButtonLabel": "显示请求", + "xpack.watcher.sections.watchEdit.json.simulateTabLabel": "模拟", + "xpack.watcher.sections.watchEdit.json.titlePanel.createNewTypeOfWatchTitle": "创建 {typeName}", + "xpack.watcher.sections.watchEdit.json.titlePanel.editWatchTitle": "编辑 {watchName}", + "xpack.watcher.sections.watchEdit.loadingWatchDescription": "正在加载监视……", + "xpack.watcher.sections.watchEdit.loadingWatchVisualizationDescription": "正在加载监视可视化……", + "xpack.watcher.sections.watchEdit.monitoring.edit.calloutDescriptionText": "监视“{watchName}”为系统监视,无法编辑。{watchStatusLink}", + "xpack.watcher.sections.watchEdit.monitoring.edit.calloutTitleText": "此监视无法编辑。", + "xpack.watcher.sections.watchEdit.monitoring.header.watchLinkTitle": "查看监视状态。", + "xpack.watcher.sections.watchEdit.simulate.form.actionModesFieldLabel": "操作模式", + "xpack.watcher.sections.watchEdit.simulate.form.actionOverridesDescription": "允许监视执行或跳过操作。{actionsLink}", + "xpack.watcher.sections.watchEdit.simulate.form.actionOverridesDescription.linkLabel": "了解操作。", + "xpack.watcher.sections.watchEdit.simulate.form.actionOverridesTitle": "鎿嶄綔", + "xpack.watcher.sections.watchEdit.simulate.form.alternativeInputAriaLabel": "代码编辑器", + "xpack.watcher.sections.watchEdit.simulate.form.alternativeInputFieldLabel": "备用输入", + "xpack.watcher.sections.watchEdit.simulate.form.conditionOverridesDescription": "满足条件时执行监视。否则,请忽略该条件并以固定排定运行监视。", + "xpack.watcher.sections.watchEdit.simulate.form.conditionOverridesTitle": "条件", + "xpack.watcher.sections.watchEdit.simulate.form.ignoreConditionFieldLabel": "忽略条件", + "xpack.watcher.sections.watchEdit.simulate.form.inputOverridesDescription": "输入 JSON 数据以覆盖来自运行输入的监视负载。", + "xpack.watcher.sections.watchEdit.simulate.form.inputOverridesTitle": "输入", + "xpack.watcher.sections.watchEdit.simulate.form.invalidJsonFieldError": "JSON 无效", + "xpack.watcher.sections.watchEdit.simulate.form.saveButtonLabel": "模拟监视", + "xpack.watcher.sections.watchEdit.simulate.form.scheduledTimeFieldLabel": "排定频率 - 每", + "xpack.watcher.sections.watchEdit.simulate.form.triggeredTimeFieldLabel": "指定时间后触发:", + "xpack.watcher.sections.watchEdit.simulate.form.triggerOverridesDescription": "设置启动监视的时间和日期。", + "xpack.watcher.sections.watchEdit.simulate.form.triggerOverridesTitle": "触发", + "xpack.watcher.sections.watchEdit.simulate.pageDescription": "使用模拟器覆盖监视排定、条件、操作和输入结果。", + "xpack.watcher.sections.watchEdit.simulate.table.idColumnLabel": "ID", + "xpack.watcher.sections.watchEdit.simulate.table.modeColumnLabel": "模式", + "xpack.watcher.sections.watchEdit.simulate.table.modeSelectLabel": "操作模式", + "xpack.watcher.sections.watchEdit.simulate.table.typeColumnLabel": "类型", + "xpack.watcher.sections.watchEdit.simulateResults.actionsSectionTitle": "鎿嶄綔", + "xpack.watcher.sections.watchEdit.simulateResults.errorTitle": "无法模拟监视", + "xpack.watcher.sections.watchEdit.simulateResults.simulationOutputSectionTitle": "模拟输出", + "xpack.watcher.sections.watchEdit.simulateResults.table.actionColumnLabel": "ID", + "xpack.watcher.sections.watchEdit.simulateResults.table.modeColumnLabel": "模式", + "xpack.watcher.sections.watchEdit.simulateResults.table.reasonColumnLabel": "原因", + "xpack.watcher.sections.watchEdit.simulateResults.table.stateColumnLabel": "状态", + "xpack.watcher.sections.watchEdit.simulateResults.table.typeColumnLabel": "类型", + "xpack.watcher.sections.watchEdit.simulateResults.title": "模拟结果", + "xpack.watcher.sections.watchEdit.threshold.accordion.deleteIconAriaLabel": "鍒犻櫎", + "xpack.watcher.sections.watchEdit.threshold.accordion.simulateResultsErrorTitle": "测试操作时出错", + "xpack.watcher.sections.watchEdit.threshold.actions.actionConfigurationWarningDescriptionText": "要创建此操作,必须至少配置一个 {accountType} 帐户。{docLink}", + "xpack.watcher.sections.watchEdit.threshold.actions.actionConfigurationWarningHelpLinkText": "浜嗚В璇︽儏銆.", + "xpack.watcher.sections.watchEdit.threshold.actions.actionConfigurationWarningTitleText": "无法配置帐户", + "xpack.watcher.sections.watchEdit.threshold.andLabel": "且", + "xpack.watcher.sections.watchEdit.threshold.cancelButtonLabel": "鍙栨秷", + "xpack.watcher.sections.watchEdit.threshold.createButtonLabel": "创建告警", + "xpack.watcher.sections.watchEdit.threshold.emailAction.bodyTextAreaFieldLabel": "正文", + "xpack.watcher.sections.watchEdit.threshold.emailAction.recipientTextFieldLabel": "收件人电子邮件地址", + "xpack.watcher.sections.watchEdit.threshold.emailAction.subjectTextFieldLabel": "主题(可选)", + "xpack.watcher.sections.watchEdit.threshold.enterOneOrMoreIndicesValidationMessage": "输入一个或多个索引。", + "xpack.watcher.sections.watchEdit.threshold.error.requiredNameText": "“名称”必填。", + "xpack.watcher.sections.watchEdit.threshold.forTheLastButtonLabel": "过去", + "xpack.watcher.sections.watchEdit.threshold.forTheLastLabel": "过去", + "xpack.watcher.sections.watchEdit.threshold.groupedOverLabel": "分组范围", + "xpack.watcher.sections.watchEdit.threshold.indexAction.indexFieldLabel": "绱㈠紩", + "xpack.watcher.sections.watchEdit.threshold.intervalSizeIsRequiredValidationMessage": "时间间隔大小必填。", + "xpack.watcher.sections.watchEdit.threshold.intervalSizeNegativeNumberValidationMessage": "时间间隔大小不能为负数。", + "xpack.watcher.sections.watchEdit.threshold.invalidIndexValidationMessage": "索引没有时间字段。", + "xpack.watcher.sections.watchEdit.threshold.jiraAction.issueTypeFieldLabel": "问题类型", + "xpack.watcher.sections.watchEdit.threshold.jiraAction.projectKeyFieldLabel": "项目键", + "xpack.watcher.sections.watchEdit.threshold.jiraAction.summaryFieldLabel": "摘要", + "xpack.watcher.sections.watchEdit.threshold.loggingAction.logTextFieldLabel": "日志文本", + "xpack.watcher.sections.watchEdit.threshold.ofButtonLabel": "的", + "xpack.watcher.sections.watchEdit.threshold.ofLabel": "的", + "xpack.watcher.sections.watchEdit.threshold.overButtonLabel": "范围", + "xpack.watcher.sections.watchEdit.threshold.overLabel": "范围", + "xpack.watcher.sections.watchEdit.threshold.pagerDutyAction.descriptionFieldLabel": "描述", + "xpack.watcher.sections.watchEdit.threshold.saveButtonLabel": "保存", + "xpack.watcher.sections.watchEdit.threshold.slackAction.messageTextAreaFieldLabel": "消息(可选)", + "xpack.watcher.sections.watchEdit.threshold.slackAction.recipientTextFieldLabel": "收件人(可选)", + "xpack.watcher.sections.watchEdit.threshold.timeFieldIsRequiredValidationText": "需要时间字段。", + "xpack.watcher.sections.watchEdit.threshold.webhookAction.basicAuthPassword": "密码(可选)", + "xpack.watcher.sections.watchEdit.threshold.webhookAction.basicAuthUsername": "用户名(可选)", + "xpack.watcher.sections.watchEdit.threshold.webhookAction.bodyCodeEditorAriaLabel": "代码编辑器", + "xpack.watcher.sections.watchEdit.threshold.webhookAction.bodyFieldLabel": "正文", + "xpack.watcher.sections.watchEdit.threshold.webhookAction.hostFieldLabel": "主机", + "xpack.watcher.sections.watchEdit.threshold.webhookAction.methodFieldLabel": "方法", + "xpack.watcher.sections.watchEdit.threshold.webhookAction.methodPortLabel": "端口", + "xpack.watcher.sections.watchEdit.threshold.webhookAction.pathFieldLabel": "路径(可选)", + "xpack.watcher.sections.watchEdit.threshold.whenButtonLabel": "当", + "xpack.watcher.sections.watchEdit.threshold.whenLabel": "当", + "xpack.watcher.sections.watchEdit.titlePanel.chooseLabel": "选择……", + "xpack.watcher.sections.watchEdit.titlePanel.durationAriaLabel": "持续时间单位", + "xpack.watcher.sections.watchEdit.titlePanel.howToBroadenSearchQueryDescription": "使用 * 拓宽您的搜索查询", + "xpack.watcher.sections.watchEdit.titlePanel.indicesAndIndexPatternsLabel": "基于您的索引和索引模式", + "xpack.watcher.sections.watchEdit.titlePanel.indicesToQueryLabel": "要查询的索引", + "xpack.watcher.sections.watchEdit.titlePanel.timeFieldLabel": "时间字段", + "xpack.watcher.sections.watchEdit.titlePanel.timeFieldOptionLabel": "选择字段", + "xpack.watcher.sections.watchEdit.titlePanel.watchIntervalLabel": "运行监视的频率", + "xpack.watcher.sections.watchEdit.titlePanel.watchNameLabel": "名称", + "xpack.watcher.sections.watchEdit.watchConditionSectionTitle": "匹配以下条件", + "xpack.watcher.sections.watchHistory.changeTimespanSelectAriaLabel": "更改监视历史记录的时间跨度", + "xpack.watcher.sections.watchHistory.deleteWatchButtonLabel": "鍒犻櫎", + "xpack.watcher.sections.watchHistory.timeSpan.1h": "过去 1 小时", + "xpack.watcher.sections.watchHistory.timeSpan.1y": "杩囧幓 1 骞", + "xpack.watcher.sections.watchHistory.timeSpan.24h": "杩囧幓 24 灏忔椂", + "xpack.watcher.sections.watchHistory.timeSpan.30d": "杩囧幓 30 澶", + "xpack.watcher.sections.watchHistory.timeSpan.6M": "杩囧幓 6 涓湀", + "xpack.watcher.sections.watchHistory.timeSpan.7d": "杩囧幓 7 澶", + "xpack.watcher.sections.watchHistory.watchActionStatusTable.id": "鍥惧眰鍚嶇О", + "xpack.watcher.sections.watchHistory.watchActionStatusTable.state": "状态", + "xpack.watcher.sections.watchHistory.watchExecutionErrorTitle": "加载执行历史记录时出错", + "xpack.watcher.sections.watchHistory.watchHistoryDetail.actionsTitle": "鎿嶄綔", + "xpack.watcher.sections.watchHistory.watchHistoryDetail.errorTitle": "执行详情", + "xpack.watcher.sections.watchHistory.watchHistoryDetail.jsonTitle": "JSON", + "xpack.watcher.sections.watchHistory.watchHistoryDetail.title": "已于 {date} 执行", + "xpack.watcher.sections.watchHistory.watchHistoryDetailsErrorTitle": "加载执行详情时出错", + "xpack.watcher.sections.watchHistory.watchTable.activateWatchLabel": "激活", + "xpack.watcher.sections.watchHistory.watchTable.commentHeader": "注释", + "xpack.watcher.sections.watchHistory.watchTable.deactivateWatchLabel": "停用", + "xpack.watcher.sections.watchHistory.watchTable.noCurrentStatus": "没有可显示的执行历史记录", + "xpack.watcher.sections.watchHistory.watchTable.noWatchesMessage": "当前没有可显示的状态", + "xpack.watcher.sections.watchHistory.watchTable.startTimeHeader": "触发时间", + "xpack.watcher.sections.watchHistory.watchTable.stateHeader": "状态", + "xpack.watcher.sections.watchList.createAdvancedWatchButtonLabel": "创建高级监视", + "xpack.watcher.sections.watchList.createAdvancedWatchTooltip": "以原始 JSON 格式设置定制监视", + "xpack.watcher.sections.watchList.createThresholdAlertButtonLabel": "创建阈值告警", + "xpack.watcher.sections.watchList.createThresholdAlertButtonTooltip": "在特定条件下发送告警", + "xpack.watcher.sections.watchList.createWatchButtonLabel": "创建", + "xpack.watcher.sections.watchList.deleteMultipleWatchesButtonLabel": "删除监视", + "xpack.watcher.sections.watchList.deleteSelectedWatchesErrorNotification.descriptionText": "无法删除 {numErrors, number} {numErrors, plural, one {个监视} other {个监视}}", + "xpack.watcher.sections.watchList.deleteSelectedWatchesSuccessNotification.descriptionText": "已删除 {numSuccesses, number} {numSuccesses, plural, one {个监视} other {个监视}}", + "xpack.watcher.sections.watchList.deleteSingleWatchButtonLabel": "删除监视", + "xpack.watcher.sections.watchList.emptyPromptTitle": "鎮ㄥ皻鏈湁浠讳綍蹇収", + "xpack.watcher.sections.watchList.errorTitle": "加载监视时出错", + "xpack.watcher.sections.watchList.header": "创建阈值告警", + "xpack.watcher.sections.watchList.loadingWatchesDescription": "正在加载监视……", + "xpack.watcher.sections.watchList.managementSection.editDisplayName": "编辑", + "xpack.watcher.sections.watchList.managementSection.newWatchDisplayName": "新建监视", + "xpack.watcher.sections.watchList.managementSection.statusDisplayName": "状态", + "xpack.watcher.sections.watchList.managementSection.watcherDisplayName": "Watcher", + "xpack.watcher.sections.watchList.managementSection.watchesDisplayName": "监视", + "xpack.watcher.sections.watchList.subhead": "特定参数命中时,发出电子邮件、Slack 消息和日志事件", + "xpack.watcher.sections.watchList.toggleActivatationErrorNotification.activateDescriptionText": "无法激活监视", + "xpack.watcher.sections.watchList.toggleActivatationErrorNotification.deactivateDescriptionText": "无法停用监视", + "xpack.watcher.sections.watchList.watcherGettingStartedDocsLinkText": "Watcher 文档", + "xpack.watcher.sections.watchList.watcherLearnMoreLinkText": "浜嗚В璇︽儏銆.", + "xpack.watcher.sections.watchList.watchTable.actionDeleteAriaLabel": "删除监视“{name}”", + "xpack.watcher.sections.watchList.watchTable.actionDeleteTooltipLabel": "鍒犻櫎", + "xpack.watcher.sections.watchList.watchTable.actionEditAriaLabel": "编辑监视“{name}”", + "xpack.watcher.sections.watchList.watchTable.actionEditTooltipLabel": "缂栬緫", + "xpack.watcher.sections.watchList.watchTable.actionHeader": "鎿嶄綔", + "xpack.watcher.sections.watchList.watchTable.commentHeader": "注释", + "xpack.watcher.sections.watchList.watchTable.disabledWatchTooltipText": "此监视为只读", + "xpack.watcher.sections.watchList.watchTable.idHeader": "ID", + "xpack.watcher.sections.watchList.watchTable.lastFiredHeader": "最后发送时间", + "xpack.watcher.sections.watchList.watchTable.lastTriggeredHeader": "最后触发时间", + "xpack.watcher.sections.watchList.watchTable.nameHeader": "鍥惧眰鍚嶇О", + "xpack.watcher.sections.watchList.watchTable.noWatchesMessage": "没有可显示的监视", + "xpack.watcher.sections.watchList.watchTable.stateHeader": "状态", + "xpack.watcher.sections.watchStatus.actionsTabLabel": "操作状态", + "xpack.watcher.sections.watchStatus.executionHistoryTabLabel": "执行历史记录", + "xpack.watcher.sections.watchStatus.loadingWatchDetailsDescription": "正在加载监视详情……", + "xpack.watcher.thresholdPreviewChart.dataDoesNotExistTextMessage": "您的索引和条件未返回任何数据", + "xpack.watcher.thresholdPreviewChart.noDataTitle": "无数据", + "xpack.watcher.thresholdWatchExpression.aggType.xpack.watcher.thresholdWatchExpression.groupBy.requiredValueValidationMessage": "需要值。", + "xpack.watcher.thresholdWatchExpression.comparators.isAboveLabel": "高于", + "xpack.watcher.thresholdWatchExpression.comparators.isAboveOrEqualsLabel": "大于或等于", + "xpack.watcher.thresholdWatchExpression.comparators.isBelowLabel": "低于", + "xpack.watcher.thresholdWatchExpression.comparators.isBelowOrEqualsLabel": "小于或等于", + "xpack.watcher.thresholdWatchExpression.comparators.isBetweenLabel": "介于", + "xpack.watcher.thresholdWatchExpression.fixErrorInExpressionBelowValidationMessage": "请解决如下表达式中的错误。", + "xpack.watcher.thresholdWatchExpression.groupBy.requiredFieldValidationMessage": "请选择字段。", + "xpack.watcher.thresholdWatchExpression.groupByLabel.allDocumentsLabel": "所有文档", + "xpack.watcher.thresholdWatchExpression.groupByLabel.topLabel": "顶部", + "xpack.watcher.thresholdWatchExpression.thresholdLevel.secondValueMustBeGreaterMessage": "值必须大于 {lowerBound}。", + "xpack.watcher.thresholdWatchExpression.thresholdLevel.valueIsRequiredValidationMessage": "需要值。", + "xpack.watcher.thresholdWatchExpression.timeWindow.durationSizeIsRequiredValidationMessage": "“窗口持续时间大小”必填。", + "xpack.watcher.timeUnits.dayLabel": "{timeValue, plural, one {天} other {天}}", + "xpack.watcher.timeUnits.hourLabel": "{timeValue, plural, one {小时} other {小时}}", + "xpack.watcher.timeUnits.minuteLabel": "{timeValue, plural, one {分钟} other {分钟}}", + "xpack.watcher.timeUnits.secondLabel": "{timeValue, plural, one {秒} other {秒}}", + "xpack.watcher.watchActions.email.emailRecipientIsRequiredValidationMessage": "“收件人”电子邮件地址必填。", + "xpack.watcher.watchActions.index.indexIsRequiredValidationMessage": "索引名称必填。", + "xpack.watcher.watchActions.jira.issueTypeNameIsRequiredValidationMessage": "Jira 问题类型必填。", + "xpack.watcher.watchActions.jira.projectKeyIsRequiredValidationMessage": "Jira 项目键必填。", + "xpack.watcher.watchActions.jira.summaryIsRequiredValidationMessage": "Jira 摘要必填。", + "xpack.watcher.watchActions.logging.logTextIsRequiredValidationMessage": "“日志文本”必填。", + "xpack.watcher.watchActions.pagerduty.descriptionIsRequiredValidationMessage": "PagerDuty 说明必填。", + "xpack.watcher.watchActions.webhook.hostIsRequiredValidationMessage": "Webhook 主机必填。", + "xpack.watcher.watchActions.webhook.invalidJsonValidationMessage": "JSON 无效", + "xpack.watcher.watchActions.webhook.passwordIsRequiredIfUsernameValidationMessage": "密码必填。", + "xpack.watcher.watchActions.webhook.portIsRequiredValidationMessage": "Webhook 端口必填。", + "xpack.watcher.watchActions.webhook.usernameIsRequiredIfPasswordValidationMessage": "用户名必填。", + "xpack.watcher.watchEdit.thresholdWatchExpression.aggType.fieldIsRequiredValidationMessage": "此字段必填。", + "xpack.watcher.watcherDescription": "通过创建、管理和监测警报来检测数据中的更改。" } } \ No newline at end of file From c1cf970fe1ab911ebb8d9068c1d9ec91db2ae165 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Felix=20St=C3=BCrmer?= Date: Tue, 14 Jan 2020 16:28:27 +0100 Subject: [PATCH 094/139] [Logs UI] Move beta badges from tabs to headings (#54572) This moves the beta badges for the Ml integration tabs from the tabbed navigation bar into the primary headings of the respective setup and result pages. --- .../infra/public/components/beta_badge.tsx | 26 +++++++++++++++++++ .../components/navigation/routed_tabs.tsx | 21 +-------------- .../plugins/infra/public/pages/logs/index.tsx | 16 +++--------- .../page_setup_content.tsx | 4 ++- .../top_categories/top_categories_section.tsx | 5 +++- .../log_entry_rate/page_setup_content.tsx | 4 ++- .../sections/log_rate/index.tsx | 13 ++++++---- 7 files changed, 48 insertions(+), 41 deletions(-) create mode 100644 x-pack/legacy/plugins/infra/public/components/beta_badge.tsx diff --git a/x-pack/legacy/plugins/infra/public/components/beta_badge.tsx b/x-pack/legacy/plugins/infra/public/components/beta_badge.tsx new file mode 100644 index 0000000000000..5d5770af1a41e --- /dev/null +++ b/x-pack/legacy/plugins/infra/public/components/beta_badge.tsx @@ -0,0 +1,26 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { EuiBetaBadge } from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; +import React from 'react'; + +export const BetaBadge: React.FunctionComponent = () => ( + +); +const betaBadgeLabel = i18n.translate('xpack.infra.common.tabBetaBadgeLabel', { + defaultMessage: 'Beta', +}); + +const betaBadgeTooltipContent = i18n.translate('xpack.infra.common.tabBetaBadgeTooltipContent', { + defaultMessage: + 'This feature is under active development. Extra functionality is coming, and some functionality may change.', +}); diff --git a/x-pack/legacy/plugins/infra/public/components/navigation/routed_tabs.tsx b/x-pack/legacy/plugins/infra/public/components/navigation/routed_tabs.tsx index 0b1d34870a72d..c43ade12ded6d 100644 --- a/x-pack/legacy/plugins/infra/public/components/navigation/routed_tabs.tsx +++ b/x-pack/legacy/plugins/infra/public/components/navigation/routed_tabs.tsx @@ -4,8 +4,7 @@ * you may not use this file except in compliance with the Elastic License. */ -import { EuiBetaBadge, EuiLink, EuiTab, EuiTabs } from '@elastic/eui'; -import { i18n } from '@kbn/i18n'; +import { EuiLink, EuiTab, EuiTabs } from '@elastic/eui'; import React from 'react'; import { Route } from 'react-router-dom'; @@ -56,24 +55,6 @@ export class RoutedTabs extends React.Component { } } -const tabBetaBadgeLabel = i18n.translate('xpack.infra.common.tabBetaBadgeLabel', { - defaultMessage: 'Beta', -}); - -const tabBetaBadgeTooltipContent = i18n.translate('xpack.infra.common.tabBetaBadgeTooltipContent', { - defaultMessage: - 'This feature is under active development. Extra functionality is coming, and some functionality may change.', -}); - -export const TabBetaBadge = euiStyled(EuiBetaBadge).attrs({ - 'aria-label': tabBetaBadgeLabel, - label: tabBetaBadgeLabel, - tooltipContent: tabBetaBadgeTooltipContent, -})` - margin-left: 4px; - vertical-align: baseline; -`; - const TabContainer = euiStyled.div` .euiLink { color: inherit !important; diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/index.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/index.tsx index f38f066b5323f..505878f0239dc 100644 --- a/x-pack/legacy/plugins/infra/public/pages/logs/index.tsx +++ b/x-pack/legacy/plugins/infra/public/pages/logs/index.tsx @@ -11,7 +11,7 @@ import { Route, RouteComponentProps, Switch } from 'react-router-dom'; import { DocumentTitle } from '../../components/document_title'; import { HelpCenterContent } from '../../components/help_center_content'; import { Header } from '../../components/header'; -import { RoutedTabs, TabBetaBadge } from '../../components/navigation/routed_tabs'; +import { RoutedTabs } from '../../components/navigation/routed_tabs'; import { ColumnarPage } from '../../components/page'; import { SourceLoadingPage } from '../../components/source_loading_page'; import { SourceErrorPage } from '../../components/source_error_page'; @@ -41,22 +41,12 @@ export const LogsPage = ({ match }: RouteComponentProps) => { }; const logRateTab = { - title: ( - <> - {logRateTabTitle} - - - ), + title: logRateTabTitle, path: `${match.path}/log-rate`, }; const logCategoriesTab = { - title: ( - <> - {logCategoriesTabTitle} - - - ), + title: logCategoriesTabTitle, path: `${match.path}/log-categories`, }; diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/page_setup_content.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/page_setup_content.tsx index f0e90cb7ccc05..53e485e0ea8b3 100644 --- a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/page_setup_content.tsx +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/page_setup_content.tsx @@ -8,6 +8,7 @@ import { EuiSpacer, EuiSteps, EuiText } from '@elastic/eui'; import { FormattedMessage } from '@kbn/i18n/react'; import React, { useMemo } from 'react'; +import { BetaBadge } from '../../../components/beta_badge'; import { createInitialConfigurationStep, createProcessStep, @@ -82,7 +83,8 @@ export const LogEntryCategoriesSetupContent: React.FunctionComponent = () => { + />{' '} + diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/top_categories_section.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/top_categories_section.tsx index 0281615a59c78..962b506536253 100644 --- a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/top_categories_section.tsx +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_categories/sections/top_categories/top_categories_section.tsx @@ -10,6 +10,7 @@ import React from 'react'; import { LogEntryCategory } from '../../../../../../common/http_api/log_analysis'; import { TimeRange } from '../../../../../../common/http_api/shared'; +import { BetaBadge } from '../../../../../components/beta_badge'; import { LoadingOverlayWrapper } from '../../../../../components/loading_overlay_wrapper'; import { RecreateJobButton } from '../../../../../components/logging/log_analysis_job_status'; import { AnalyzeInMlButton } from '../../../../../components/logging/log_analysis_results'; @@ -42,7 +43,9 @@ export const TopCategoriesSection: React.FunctionComponent<{ -

{title}

+

+ {title} +

diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/page_setup_content.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/page_setup_content.tsx index 7e90cf29072e1..d6d8e241c996b 100644 --- a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/page_setup_content.tsx +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/page_setup_content.tsx @@ -8,6 +8,7 @@ import { EuiSpacer, EuiSteps, EuiText } from '@elastic/eui'; import { FormattedMessage } from '@kbn/i18n/react'; import React, { useMemo } from 'react'; +import { BetaBadge } from '../../../components/beta_badge'; import { createInitialConfigurationStep, createProcessStep, @@ -82,7 +83,8 @@ export const LogEntryRateSetupContent: React.FunctionComponent = () => { + />{' '} + diff --git a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/sections/log_rate/index.tsx b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/sections/log_rate/index.tsx index a11dc9d4d607a..3da025d90119f 100644 --- a/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/sections/log_rate/index.tsx +++ b/x-pack/legacy/plugins/infra/public/pages/logs/log_entry_rate/sections/log_rate/index.tsx @@ -4,15 +4,16 @@ * you may not use this file except in compliance with the Elastic License. */ -import { EuiEmptyPrompt, EuiLoadingSpinner, EuiSpacer, EuiTitle, EuiText } from '@elastic/eui'; +import { EuiEmptyPrompt, EuiLoadingSpinner, EuiSpacer, EuiText, EuiTitle } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; import React, { useMemo } from 'react'; -import { LogEntryRateResults as Results } from '../../use_log_entry_rate_results'; import { TimeRange } from '../../../../../../common/http_api/shared/time_range'; -import { LogEntryRateBarChart } from './bar_chart'; -import { getLogEntryRatePartitionedSeries } from '../helpers/data_formatters'; +import { BetaBadge } from '../../../../../components/beta_badge'; import { LoadingOverlayWrapper } from '../../../../../components/loading_overlay_wrapper'; +import { LogEntryRateResults as Results } from '../../use_log_entry_rate_results'; +import { getLogEntryRatePartitionedSeries } from '../helpers/data_formatters'; +import { LogEntryRateBarChart } from './bar_chart'; export const LogRateResults = ({ isLoading, @@ -33,7 +34,9 @@ export const LogRateResults = ({ return ( <> -

{title}

+

+ {title} +

}> {!results || (results && results.histogramBuckets && !results.histogramBuckets.length) ? ( From 6a45241b79a518c321fd46414cc1a00eef7b6e9a Mon Sep 17 00:00:00 2001 From: Robert Oskamp Date: Tue, 14 Jan 2020 16:29:43 +0100 Subject: [PATCH 095/139] [ML] Functional tests - basic tests for single metric viewer and anomaly explorer (#54699) This PR adds basic functional UI tests for the single metric viewer and the anomaly explorer. --- .../anomalies_table/anomalies_table.js | 1 + .../anomalies_table_columns.js | 12 +++ .../influencers_list/influencers_list.js | 4 +- .../job_selector_badge/job_selector_badge.js | 2 +- .../loading_indicator/loading_indicator.js | 6 +- .../timeseriesexplorer/timeseriesexplorer.js | 1 + .../anomaly_detection/anomaly_explorer.ts | 95 +++++++++++++++++++ .../anomaly_detection/index.ts | 2 + .../anomaly_detection/single_metric_viewer.ts | 91 ++++++++++++++++++ .../machine_learning/anomalies_table.ts | 26 +++++ .../machine_learning/anomaly_explorer.ts | 27 ++++++ .../services/machine_learning/api.ts | 86 +++++++++++++++++ .../services/machine_learning/common.ts | 6 ++ .../services/machine_learning/index.ts | 2 + .../machine_learning/job_selection.ts | 27 ++++++ .../services/machine_learning/job_table.ts | 10 ++ .../machine_learning/single_metric_viewer.ts | 36 +++++++ x-pack/test/functional/services/ml.ts | 7 ++ 18 files changed, 437 insertions(+), 4 deletions(-) create mode 100644 x-pack/test/functional/apps/machine_learning/anomaly_detection/anomaly_explorer.ts create mode 100644 x-pack/test/functional/apps/machine_learning/anomaly_detection/single_metric_viewer.ts create mode 100644 x-pack/test/functional/services/machine_learning/anomalies_table.ts create mode 100644 x-pack/test/functional/services/machine_learning/job_selection.ts diff --git a/x-pack/legacy/plugins/ml/public/application/components/anomalies_table/anomalies_table.js b/x-pack/legacy/plugins/ml/public/application/components/anomalies_table/anomalies_table.js index bc3ce88921110..6728f019a6bd5 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/anomalies_table/anomalies_table.js +++ b/x-pack/legacy/plugins/ml/public/application/components/anomalies_table/anomalies_table.js @@ -195,6 +195,7 @@ class AnomaliesTable extends Component { return { onMouseOver: () => this.onMouseOverRow(item), onMouseLeave: () => this.onMouseLeaveRow(), + 'data-test-subj': `mlAnomaliesListRow row-${item.rowId}`, }; }; diff --git a/x-pack/legacy/plugins/ml/public/application/components/anomalies_table/anomalies_table_columns.js b/x-pack/legacy/plugins/ml/public/application/components/anomalies_table/anomalies_table_columns.js index 36faac45164f4..5454911673fe2 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/anomalies_table/anomalies_table_columns.js +++ b/x-pack/legacy/plugins/ml/public/application/components/anomalies_table/anomalies_table_columns.js @@ -80,11 +80,13 @@ export function getColumns( }) } data-row-id={item.rowId} + data-test-subj="mlJobListRowDetailsToggle" /> ), }, { field: 'time', + 'data-test-subj': 'mlAnomaliesListColumnTime', name: i18n.translate('xpack.ml.anomaliesTable.timeColumnName', { defaultMessage: 'time', }), @@ -95,6 +97,7 @@ export function getColumns( }, { field: 'severity', + 'data-test-subj': 'mlAnomaliesListColumnSeverity', name: i18n.translate('xpack.ml.anomaliesTable.severityColumnName', { defaultMessage: 'severity', }), @@ -105,6 +108,7 @@ export function getColumns( }, { field: 'detector', + 'data-test-subj': 'mlAnomaliesListColumnDetector', name: i18n.translate('xpack.ml.anomaliesTable.detectorColumnName', { defaultMessage: 'detector', }), @@ -119,6 +123,7 @@ export function getColumns( if (items.some(item => item.entityValue !== undefined)) { columns.push({ field: 'entityValue', + 'data-test-subj': 'mlAnomaliesListColumnFoundFor', name: i18n.translate('xpack.ml.anomaliesTable.entityValueColumnName', { defaultMessage: 'found for', }), @@ -138,6 +143,7 @@ export function getColumns( if (items.some(item => item.influencers !== undefined)) { columns.push({ field: 'influencers', + 'data-test-subj': 'mlAnomaliesListColumnInfluencers', name: i18n.translate('xpack.ml.anomaliesTable.influencersColumnName', { defaultMessage: 'influenced by', }), @@ -159,6 +165,7 @@ export function getColumns( if (items.some(item => item.actual !== undefined)) { columns.push({ field: 'actualSort', + 'data-test-subj': 'mlAnomaliesListColumnActual', name: i18n.translate('xpack.ml.anomaliesTable.actualSortColumnName', { defaultMessage: 'actual', }), @@ -176,6 +183,7 @@ export function getColumns( if (items.some(item => item.typical !== undefined)) { columns.push({ field: 'typicalSort', + 'data-test-subj': 'mlAnomaliesListColumnTypical', name: i18n.translate('xpack.ml.anomaliesTable.typicalSortColumnName', { defaultMessage: 'typical', }), @@ -198,6 +206,7 @@ export function getColumns( if (nonTimeOfDayOrWeek === true) { columns.push({ field: 'metricDescriptionSort', + 'data-test-subj': 'mlAnomaliesListColumnDescription', name: i18n.translate('xpack.ml.anomaliesTable.metricDescriptionSortColumnName', { defaultMessage: 'description', }), @@ -213,6 +222,7 @@ export function getColumns( if (jobIds && jobIds.length > 1) { columns.push({ field: 'jobId', + 'data-test-subj': 'mlAnomaliesListColumnJobID', name: i18n.translate('xpack.ml.anomaliesTable.jobIdColumnName', { defaultMessage: 'job ID', }), @@ -223,6 +233,7 @@ export function getColumns( const showExamples = items.some(item => item.entityName === 'mlcategory'); if (showExamples === true) { columns.push({ + 'data-test-subj': 'mlAnomaliesListColumnCategoryExamples', name: i18n.translate('xpack.ml.anomaliesTable.categoryExamplesColumnName', { defaultMessage: 'category examples', }), @@ -254,6 +265,7 @@ export function getColumns( if (showLinks === true) { columns.push({ + 'data-test-subj': 'mlAnomaliesListColumnAction', name: i18n.translate('xpack.ml.anomaliesTable.actionsColumnName', { defaultMessage: 'actions', }), diff --git a/x-pack/legacy/plugins/ml/public/application/components/influencers_list/influencers_list.js b/x-pack/legacy/plugins/ml/public/application/components/influencers_list/influencers_list.js index 6a395c5cbc114..ae61e65f91799 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/influencers_list/influencers_list.js +++ b/x-pack/legacy/plugins/ml/public/application/components/influencers_list/influencers_list.js @@ -56,7 +56,7 @@ function Influencer({ influencerFieldName, influencerFilter, valueData }) { const tooltipContent = getTooltipContent(maxScoreLabel, totalScoreLabel); return ( -
+
{influencerFieldName !== 'mlcategory' ? ( - +

{influencerFieldName}

diff --git a/x-pack/legacy/plugins/ml/public/application/components/job_selector/job_selector_badge/job_selector_badge.js b/x-pack/legacy/plugins/ml/public/application/components/job_selector/job_selector_badge/job_selector_badge.js index ff5bb475e3a73..4d2ab01e2a054 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/job_selector/job_selector_badge/job_selector_badge.js +++ b/x-pack/legacy/plugins/ml/public/application/components/job_selector/job_selector_badge/job_selector_badge.js @@ -33,7 +33,7 @@ export function JobSelectorBadge({ icon, id, isGroup = false, numJobs, removeId } return ( - + {`${id}${jobCount ? jobCount : ''}`} ); diff --git a/x-pack/legacy/plugins/ml/public/application/components/loading_indicator/loading_indicator.js b/x-pack/legacy/plugins/ml/public/application/components/loading_indicator/loading_indicator.js index e84ef2f87c3ba..20f4fb86b5372 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/loading_indicator/loading_indicator.js +++ b/x-pack/legacy/plugins/ml/public/application/components/loading_indicator/loading_indicator.js @@ -12,7 +12,11 @@ import { EuiLoadingChart, EuiSpacer } from '@elastic/eui'; export function LoadingIndicator({ height, label }) { height = height ? +height : 100; return ( -
+
{label && ( <> diff --git a/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer.js b/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer.js index 807a368fc9b34..016f054430fa3 100644 --- a/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer.js +++ b/x-pack/legacy/plugins/ml/public/application/timeseriesexplorer/timeseriesexplorer.js @@ -1314,6 +1314,7 @@ export class TimeSeriesExplorer extends React.Component { onChange={this.detectorIndexChangeHandler} value={selectedDetectorIndex} options={detectorSelectOptions} + data-test-subj="mlSingleMetricViewerDetectorSelect" /> diff --git a/x-pack/test/functional/apps/machine_learning/anomaly_detection/anomaly_explorer.ts b/x-pack/test/functional/apps/machine_learning/anomaly_detection/anomaly_explorer.ts new file mode 100644 index 0000000000000..83c348e824fa8 --- /dev/null +++ b/x-pack/test/functional/apps/machine_learning/anomaly_detection/anomaly_explorer.ts @@ -0,0 +1,95 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import expect from '@kbn/expect'; + +import { FtrProviderContext } from '../../../ftr_provider_context'; +import { + Job, + Datafeed, +} from '../../../../..//legacy/plugins/ml/public/application/jobs/new_job/common/job_creator/configs'; + +const JOB_CONFIG: Job = { + job_id: `fq_multi_1_ae`, + description: + 'mean/min/max(responsetime) partition=airline on farequote dataset with 1h bucket span', + groups: ['farequote', 'automated', 'multi-metric'], + analysis_config: { + bucket_span: '1h', + influencers: ['airline'], + detectors: [ + { function: 'mean', field_name: 'responsetime', partition_field_name: 'airline' }, + { function: 'min', field_name: 'responsetime', partition_field_name: 'airline' }, + { function: 'max', field_name: 'responsetime', partition_field_name: 'airline' }, + ], + }, + data_description: { time_field: '@timestamp' }, + analysis_limits: { model_memory_limit: '20mb' }, + model_plot_config: { enabled: true }, +}; + +const DATAFEED_CONFIG: Datafeed = { + datafeed_id: 'datafeed-fq_multi_1_se', + indices: ['farequote'], + job_id: 'fq_multi_1_ae', + query: { bool: { must: [{ match_all: {} }] } }, +}; + +// eslint-disable-next-line import/no-default-export +export default function({ getService }: FtrProviderContext) { + const esArchiver = getService('esArchiver'); + const ml = getService('ml'); + + describe('anomaly explorer', function() { + this.tags(['smoke', 'mlqa']); + before(async () => { + await esArchiver.load('ml/farequote'); + await ml.api.createAndRunAnomalyDetectionLookbackJob(JOB_CONFIG, DATAFEED_CONFIG); + }); + + after(async () => { + await esArchiver.unload('ml/farequote'); + await ml.api.cleanMlIndices(); + }); + + it('loads from job list row link', async () => { + await ml.navigation.navigateToMl(); + await ml.navigation.navigateToJobManagement(); + + await ml.jobTable.waitForJobsToLoad(); + await ml.jobTable.filterWithSearchString(JOB_CONFIG.job_id); + const rows = await ml.jobTable.parseJobTable(); + expect(rows.filter(row => row.id === JOB_CONFIG.job_id)).to.have.length(1); + + await ml.jobTable.clickOpenJobInAnomalyExplorerButton(JOB_CONFIG.job_id); + await ml.common.waitForMlLoadingIndicatorToDisappear(); + }); + + it('pre-fills the job selection', async () => { + await ml.jobSelection.assertJobSelection([JOB_CONFIG.job_id]); + }); + + it('displays the influencers list', async () => { + await ml.anomalyExplorer.assertInfluencerListExists(); + for (const influencerField of JOB_CONFIG.analysis_config.influencers) { + await ml.anomalyExplorer.assertInfluencerFieldExists(influencerField); + await ml.anomalyExplorer.assertInfluencerFieldListNotEmpty(influencerField); + } + }); + + it('displays the swimlanes', async () => { + await ml.anomalyExplorer.assertOverallSwimlaneExists(); + await ml.anomalyExplorer.assertSwimlaneViewByExists(); + }); + + it('displays the anomalies table', async () => { + await ml.anomaliesTable.assertTableExists(); + }); + + it('anomalies table is not empty', async () => { + await ml.anomaliesTable.assertTableNotEmpty(); + }); + }); +} diff --git a/x-pack/test/functional/apps/machine_learning/anomaly_detection/index.ts b/x-pack/test/functional/apps/machine_learning/anomaly_detection/index.ts index d5d617587fc3b..a52e3d3aca2c0 100644 --- a/x-pack/test/functional/apps/machine_learning/anomaly_detection/index.ts +++ b/x-pack/test/functional/apps/machine_learning/anomaly_detection/index.ts @@ -14,5 +14,7 @@ export default function({ loadTestFile }: FtrProviderContext) { loadTestFile(require.resolve('./population_job')); loadTestFile(require.resolve('./saved_search_job')); loadTestFile(require.resolve('./advanced_job')); + loadTestFile(require.resolve('./single_metric_viewer')); + loadTestFile(require.resolve('./anomaly_explorer')); }); } diff --git a/x-pack/test/functional/apps/machine_learning/anomaly_detection/single_metric_viewer.ts b/x-pack/test/functional/apps/machine_learning/anomaly_detection/single_metric_viewer.ts new file mode 100644 index 0000000000000..a52ef6442cf21 --- /dev/null +++ b/x-pack/test/functional/apps/machine_learning/anomaly_detection/single_metric_viewer.ts @@ -0,0 +1,91 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import expect from '@kbn/expect'; + +import { FtrProviderContext } from '../../../ftr_provider_context'; +import { + Job, + Datafeed, +} from '../../../../..//legacy/plugins/ml/public/application/jobs/new_job/common/job_creator/configs'; + +const JOB_CONFIG: Job = { + job_id: `fq_single_1_smv`, + description: 'mean(responsetime) on farequote dataset with 15m bucket span', + groups: ['farequote', 'automated', 'single-metric'], + analysis_config: { + bucket_span: '15m', + influencers: [], + detectors: [ + { + function: 'mean', + field_name: 'responsetime', + }, + ], + }, + data_description: { time_field: '@timestamp' }, + analysis_limits: { model_memory_limit: '10mb' }, + model_plot_config: { enabled: true }, +}; + +const DATAFEED_CONFIG: Datafeed = { + datafeed_id: 'datafeed-fq_single_1_smv', + indices: ['farequote'], + job_id: 'fq_single_1_smv', + query: { bool: { must: [{ match_all: {} }] } }, +}; + +// eslint-disable-next-line import/no-default-export +export default function({ getService }: FtrProviderContext) { + const esArchiver = getService('esArchiver'); + const ml = getService('ml'); + + describe('single metric viewer', function() { + this.tags(['smoke', 'mlqa']); + before(async () => { + await esArchiver.load('ml/farequote'); + await ml.api.createAndRunAnomalyDetectionLookbackJob(JOB_CONFIG, DATAFEED_CONFIG); + }); + + after(async () => { + await esArchiver.unload('ml/farequote'); + await ml.api.cleanMlIndices(); + }); + + it('loads from job list row link', async () => { + await ml.navigation.navigateToMl(); + await ml.navigation.navigateToJobManagement(); + + await ml.jobTable.waitForJobsToLoad(); + await ml.jobTable.filterWithSearchString(JOB_CONFIG.job_id); + const rows = await ml.jobTable.parseJobTable(); + expect(rows.filter(row => row.id === JOB_CONFIG.job_id)).to.have.length(1); + + await ml.jobTable.clickOpenJobInSingleMetricViewerButton(JOB_CONFIG.job_id); + await ml.common.waitForMlLoadingIndicatorToDisappear(); + }); + + it('pre-fills the job selection', async () => { + await ml.jobSelection.assertJobSelection([JOB_CONFIG.job_id]); + }); + + it('pre-fills the detector input', async () => { + await ml.singleMetricViewer.assertDetectorInputExsist(); + await ml.singleMetricViewer.assertDetectorInputValue('0'); + }); + + it('displays the chart', async () => { + await ml.singleMetricViewer.assertChartExsist(); + }); + + it('displays the anomalies table', async () => { + await ml.anomaliesTable.assertTableExists(); + }); + + it('anomalies table is not empty', async () => { + await ml.anomaliesTable.assertTableNotEmpty(); + }); + }); +} diff --git a/x-pack/test/functional/services/machine_learning/anomalies_table.ts b/x-pack/test/functional/services/machine_learning/anomalies_table.ts new file mode 100644 index 0000000000000..c8701099dcd7a --- /dev/null +++ b/x-pack/test/functional/services/machine_learning/anomalies_table.ts @@ -0,0 +1,26 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import expect from '@kbn/expect'; + +import { FtrProviderContext } from '../../ftr_provider_context'; + +export function MachineLearningAnomaliesTableProvider({ getService }: FtrProviderContext) { + const testSubjects = getService('testSubjects'); + + return { + async assertTableExists() { + await testSubjects.existOrFail('mlAnomaliesTable'); + }, + + async assertTableNotEmpty() { + const tableRows = await testSubjects.findAll('mlAnomaliesTable > ~mlAnomaliesListRow'); + expect(tableRows.length).to.be.greaterThan( + 0, + 'Anomalies table should have at least one row (got 0)' + ); + }, + }; +} diff --git a/x-pack/test/functional/services/machine_learning/anomaly_explorer.ts b/x-pack/test/functional/services/machine_learning/anomaly_explorer.ts index 18a185cbf253b..e18441ba7c3fa 100644 --- a/x-pack/test/functional/services/machine_learning/anomaly_explorer.ts +++ b/x-pack/test/functional/services/machine_learning/anomaly_explorer.ts @@ -3,6 +3,7 @@ * or more contributor license agreements. Licensed under the Elastic License; * you may not use this file except in compliance with the Elastic License. */ +import expect from '@kbn/expect'; import { FtrProviderContext } from '../../ftr_provider_context'; @@ -13,5 +14,31 @@ export function MachineLearningAnomalyExplorerProvider({ getService }: FtrProvid async assertAnomalyExplorerEmptyListMessageExists() { await testSubjects.existOrFail('mlNoJobsFound'); }, + + async assertInfluencerListExists() { + await testSubjects.existOrFail('mlAnomalyExplorerInfluencerList'); + }, + + async assertInfluencerFieldExists(influencerField: string) { + await testSubjects.existOrFail(`mlInfluencerFieldName ${influencerField}`); + }, + + async assertInfluencerFieldListNotEmpty(influencerField: string) { + const influencerFieldEntries = await testSubjects.findAll( + `mlInfluencerEntry field-${influencerField}` + ); + expect(influencerFieldEntries.length).to.be.greaterThan( + 0, + `Influencer list for field '${influencerField}' should have at least one entry (got 0)` + ); + }, + + async assertOverallSwimlaneExists() { + await testSubjects.existOrFail('mlAnomalyExplorerSwimlaneOverall'); + }, + + async assertSwimlaneViewByExists() { + await testSubjects.existOrFail('mlAnomalyExplorerSwimlaneViewBy'); + }, }; } diff --git a/x-pack/test/functional/services/machine_learning/api.ts b/x-pack/test/functional/services/machine_learning/api.ts index 1f3711ff5e506..7330a7b9812d5 100644 --- a/x-pack/test/functional/services/machine_learning/api.ts +++ b/x-pack/test/functional/services/machine_learning/api.ts @@ -10,6 +10,8 @@ import { FtrProviderContext } from '../../ftr_provider_context'; import { JOB_STATE, DATAFEED_STATE } from '../../../../legacy/plugins/ml/common/constants/states'; import { DATA_FRAME_TASK_STATE } from '../../../../legacy/plugins/ml/public/application/data_frame_analytics/pages/analytics_management/components/analytics_list/common'; +import { Job } from '../../../..//legacy/plugins/ml/public/application/jobs/new_job/common/job_creator/configs/job'; +import { Datafeed } from '../../../..//legacy/plugins/ml/public/application/jobs/new_job/common/job_creator/configs/datafeed'; export type MlApi = ProvidedType; @@ -270,5 +272,89 @@ export function MachineLearningAPIProvider({ getService }: FtrProviderContext) { } }); }, + + async getAnomalyDetectionJob(jobId: string) { + return await esSupertest.get(`/_ml/anomaly_detectors/${jobId}`).expect(200); + }, + + async createAnomalyDetectionJob(jobConfig: Job) { + const jobId = jobConfig.job_id; + log.debug(`Creating anomaly detection job with id '${jobId}'...`); + await esSupertest + .put(`/_ml/anomaly_detectors/${jobId}`) + .send(jobConfig) + .expect(200); + + await retry.waitForWithTimeout(`'${jobId}' to be created`, 5 * 1000, async () => { + if (await this.getAnomalyDetectionJob(jobId)) { + return true; + } else { + throw new Error(`expected anomaly detection job '${jobId}' to be created`); + } + }); + }, + + async getDatafeed(datafeedId: string) { + return await esSupertest.get(`/_ml/datafeeds/${datafeedId}`).expect(200); + }, + + async createDatafeed(datafeedConfig: Datafeed) { + const datafeedId = datafeedConfig.datafeed_id; + log.debug(`Creating datafeed with id '${datafeedId}'...`); + await esSupertest + .put(`/_ml/datafeeds/${datafeedId}`) + .send(datafeedConfig) + .expect(200); + + await retry.waitForWithTimeout(`'${datafeedId}' to be created`, 5 * 1000, async () => { + if (await this.getDatafeed(datafeedId)) { + return true; + } else { + throw new Error(`expected datafeed '${datafeedId}' to be created`); + } + }); + }, + + async openAnomalyDetectionJob(jobId: string) { + log.debug(`Opening anomaly detection job '${jobId}'...`); + const openResponse = await esSupertest + .post(`/_ml/anomaly_detectors/${jobId}/_open`) + .send({ timeout: '10s' }) + .set({ 'Content-Type': 'application/json' }) + .expect(200) + .then((res: any) => res.body); + + expect(openResponse) + .to.have.property('opened') + .eql(true, 'Response for open job request should be acknowledged'); + }, + + async startDatafeed( + datafeedId: string, + startConfig: { start?: string; end?: string } = { start: '0' } + ) { + log.debug( + `Starting datafeed '${datafeedId}' with start: '${startConfig.start}', end: '${startConfig.end}'...` + ); + const startResponse = await esSupertest + .post(`/_ml/datafeeds/${datafeedId}/_start`) + .send(startConfig) + .set({ 'Content-Type': 'application/json' }) + .expect(200) + .then((res: any) => res.body); + + expect(startResponse) + .to.have.property('started') + .eql(true, 'Response for start datafeed request should be acknowledged'); + }, + + async createAndRunAnomalyDetectionLookbackJob(jobConfig: Job, datafeedConfig: Datafeed) { + await this.createAnomalyDetectionJob(jobConfig); + await this.createDatafeed(datafeedConfig); + await this.openAnomalyDetectionJob(jobConfig.job_id); + await this.startDatafeed(datafeedConfig.datafeed_id, { start: '0', end: `${Date.now()}` }); + await this.waitForDatafeedState(datafeedConfig.datafeed_id, DATAFEED_STATE.STOPPED); + await this.waitForJobState(jobConfig.job_id, JOB_STATE.CLOSED); + }, }; } diff --git a/x-pack/test/functional/services/machine_learning/common.ts b/x-pack/test/functional/services/machine_learning/common.ts index 35ee32fa5d94e..fc72ac1699272 100644 --- a/x-pack/test/functional/services/machine_learning/common.ts +++ b/x-pack/test/functional/services/machine_learning/common.ts @@ -72,5 +72,11 @@ export function MachineLearningCommonProvider({ getService }: FtrProviderContext } }); }, + + async waitForMlLoadingIndicatorToDisappear() { + await retry.tryForTime(10 * 1000, async () => { + await testSubjects.missingOrFail('mlLoadingIndicator'); + }); + }, }; } diff --git a/x-pack/test/functional/services/machine_learning/index.ts b/x-pack/test/functional/services/machine_learning/index.ts index 7c393689d166c..b01f127519670 100644 --- a/x-pack/test/functional/services/machine_learning/index.ts +++ b/x-pack/test/functional/services/machine_learning/index.ts @@ -4,6 +4,7 @@ * you may not use this file except in compliance with the Elastic License. */ +export { MachineLearningAnomaliesTableProvider } from './anomalies_table'; export { MachineLearningAnomalyExplorerProvider } from './anomaly_explorer'; export { MachineLearningAPIProvider } from './api'; export { MachineLearningCommonProvider } from './common'; @@ -14,6 +15,7 @@ export { MachineLearningDataFrameAnalyticsTableProvider } from './data_frame_ana export { MachineLearningDataVisualizerProvider } from './data_visualizer'; export { MachineLearningDataVisualizerIndexBasedProvider } from './data_visualizer_index_based'; export { MachineLearningJobManagementProvider } from './job_management'; +export { MachineLearningJobSelectionProvider } from './job_selection'; export { MachineLearningJobSourceSelectionProvider } from './job_source_selection'; export { MachineLearningJobTableProvider } from './job_table'; export { MachineLearningJobTypeSelectionProvider } from './job_type_selection'; diff --git a/x-pack/test/functional/services/machine_learning/job_selection.ts b/x-pack/test/functional/services/machine_learning/job_selection.ts new file mode 100644 index 0000000000000..db693a8f9bb99 --- /dev/null +++ b/x-pack/test/functional/services/machine_learning/job_selection.ts @@ -0,0 +1,27 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ +import expect from '@kbn/expect'; + +import { FtrProviderContext } from '../../ftr_provider_context'; + +export function MachineLearningJobSelectionProvider({ getService }: FtrProviderContext) { + const testSubjects = getService('testSubjects'); + + return { + async assertJobSelection(jobOrGroupIds: string[]) { + const selectedJobsOrGroups = await testSubjects.findAll( + 'mlJobSelectionBadges > ~mlJobSelectionBadge' + ); + const actualJobOrGroupLabels = await Promise.all( + selectedJobsOrGroups.map(async badge => await badge.getVisibleText()) + ); + expect(actualJobOrGroupLabels).to.eql( + jobOrGroupIds, + `Job selection should display jobs or groups '${jobOrGroupIds}' (got '${actualJobOrGroupLabels}')` + ); + }, + }; +} diff --git a/x-pack/test/functional/services/machine_learning/job_table.ts b/x-pack/test/functional/services/machine_learning/job_table.ts index 7eded43d1f058..eed6d180b4dca 100644 --- a/x-pack/test/functional/services/machine_learning/job_table.ts +++ b/x-pack/test/functional/services/machine_learning/job_table.ts @@ -235,5 +235,15 @@ export function MachineLearningJobTableProvider({ getService }: FtrProviderConte await testSubjects.click('mlDeleteJobConfirmModal > confirmModalConfirmButton'); await testSubjects.missingOrFail('mlDeleteJobConfirmModal', { timeout: 30 * 1000 }); } + + public async clickOpenJobInSingleMetricViewerButton(jobId: string) { + await testSubjects.click(`~openJobsInSingleMetricViewer-${jobId}`); + await testSubjects.existOrFail('~mlPageSingleMetricViewer'); + } + + public async clickOpenJobInAnomalyExplorerButton(jobId: string) { + await testSubjects.click(`~openJobsInSingleAnomalyExplorer-${jobId}`); + await testSubjects.existOrFail('~mlPageAnomalyExplorer'); + } })(); } diff --git a/x-pack/test/functional/services/machine_learning/single_metric_viewer.ts b/x-pack/test/functional/services/machine_learning/single_metric_viewer.ts index 36abeecbddcea..b2c3e19020e62 100644 --- a/x-pack/test/functional/services/machine_learning/single_metric_viewer.ts +++ b/x-pack/test/functional/services/machine_learning/single_metric_viewer.ts @@ -3,6 +3,7 @@ * or more contributor license agreements. Licensed under the Elastic License; * you may not use this file except in compliance with the Elastic License. */ +import expect from '@kbn/expect'; import { FtrProviderContext } from '../../ftr_provider_context'; @@ -13,5 +14,40 @@ export function MachineLearningSingleMetricViewerProvider({ getService }: FtrPro async assertSingleMetricViewerEmptyListMessageExsist() { await testSubjects.existOrFail('mlNoSingleMetricJobsFound'); }, + + async assertForecastButtonExistsExsist() { + await testSubjects.existOrFail( + 'mlSingleMetricViewerSeriesControls > mlSingleMetricViewerButtonForecast' + ); + }, + + async assertDetectorInputExsist() { + await testSubjects.existOrFail( + 'mlSingleMetricViewerSeriesControls > mlSingleMetricViewerDetectorSelect' + ); + }, + + async assertDetectorInputValue(expectedDetectorOptionValue: string) { + const actualDetectorValue = await testSubjects.getAttribute( + 'mlSingleMetricViewerSeriesControls > mlSingleMetricViewerDetectorSelect', + 'value' + ); + expect(actualDetectorValue).to.eql( + expectedDetectorOptionValue, + `Detector input option value should be '${expectedDetectorOptionValue}' (got '${actualDetectorValue}')` + ); + }, + + async setDetectorInputValue(detectorOptionValue: string) { + await testSubjects.selectValue( + 'mlSingleMetricViewerSeriesControls > mlSingleMetricViewerDetectorSelect', + detectorOptionValue + ); + await this.assertDetectorInputValue(detectorOptionValue); + }, + + async assertChartExsist() { + await testSubjects.existOrFail('mlSingleMetricViewerChart'); + }, }; } diff --git a/x-pack/test/functional/services/ml.ts b/x-pack/test/functional/services/ml.ts index 8e71c16921078..5957a8a2eeb0a 100644 --- a/x-pack/test/functional/services/ml.ts +++ b/x-pack/test/functional/services/ml.ts @@ -7,6 +7,7 @@ import { FtrProviderContext } from '../ftr_provider_context'; import { + MachineLearningAnomaliesTableProvider, MachineLearningAnomalyExplorerProvider, MachineLearningAPIProvider, MachineLearningCommonProvider, @@ -17,6 +18,7 @@ import { MachineLearningDataVisualizerProvider, MachineLearningDataVisualizerIndexBasedProvider, MachineLearningJobManagementProvider, + MachineLearningJobSelectionProvider, MachineLearningJobSourceSelectionProvider, MachineLearningJobTableProvider, MachineLearningJobTypeSelectionProvider, @@ -32,6 +34,7 @@ import { export function MachineLearningProvider(context: FtrProviderContext) { const common = MachineLearningCommonProvider(context); + const anomaliesTable = MachineLearningAnomaliesTableProvider(context); const anomalyExplorer = MachineLearningAnomalyExplorerProvider(context); const api = MachineLearningAPIProvider(context); const customUrls = MachineLearningCustomUrlsProvider(context); @@ -41,6 +44,7 @@ export function MachineLearningProvider(context: FtrProviderContext) { const dataVisualizer = MachineLearningDataVisualizerProvider(context); const dataVisualizerIndexBased = MachineLearningDataVisualizerIndexBasedProvider(context); const jobManagement = MachineLearningJobManagementProvider(context, api); + const jobSelection = MachineLearningJobSelectionProvider(context); const jobSourceSelection = MachineLearningJobSourceSelectionProvider(context); const jobTable = MachineLearningJobTableProvider(context); const jobTypeSelection = MachineLearningJobTypeSelectionProvider(context); @@ -53,8 +57,10 @@ export function MachineLearningProvider(context: FtrProviderContext) { const singleMetricViewer = MachineLearningSingleMetricViewerProvider(context); return { + anomaliesTable, anomalyExplorer, api, + common, customUrls, dataFrameAnalytics, dataFrameAnalyticsCreation, @@ -62,6 +68,7 @@ export function MachineLearningProvider(context: FtrProviderContext) { dataVisualizer, dataVisualizerIndexBased, jobManagement, + jobSelection, jobSourceSelection, jobTable, jobTypeSelection, From 13d771b267ca985a8eb4aa8301c38a3658e4e27c Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Tue, 14 Jan 2020 10:31:25 -0500 Subject: [PATCH 096/139] feedback --- .../components/color/dynamic_color_form.js | 136 +++++++++--------- 1 file changed, 66 insertions(+), 70 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js index d4dd891de98d3..5cfda225804ea 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js @@ -11,8 +11,8 @@ import { ColorMapSelect } from './color_map_select'; import { EuiFlexGroup, EuiFlexItem, EuiSpacer } from '@elastic/eui'; import { CATEGORICAL_DATA_TYPES, COLOR_MAP_TYPE } from '../../../../../../common/constants'; import { OrdinalFieldMetaOptionsPopover } from '../ordinal_field_meta_options_popover'; -import { FormattedMessage } from '@kbn/i18n/react'; import { COLOR_GRADIENTS, COLOR_PALETTES_INPUTS } from '../../../color_utils'; +import { i18n } from '@kbn/i18n'; export class DynamicColorForm extends React.Component { state = { @@ -63,82 +63,78 @@ export class DynamicColorForm extends React.Component { const { onDynamicStyleChange, styleProperty } = this.props; const styleOptions = styleProperty.getOptions(); + if (!styleOptions.field || !styleOptions.field.name) { + return; + } + let colorSelect; - if (styleOptions.field && styleOptions.field.name) { - const onColorChange = colorOptions => { - const newColorOptions = { - type: colorOptions.type, - color: colorOptions.color, - }; - if (colorOptions.type === COLOR_MAP_TYPE.ORDINAL) { - newColorOptions.useCustomColorRamp = colorOptions.useCustomColorMap; - newColorOptions.customColorRamp = colorOptions.customColorMap; - } else { - newColorOptions.useCustomColorPalette = colorOptions.useCustomColorMap; - newColorOptions.customColorPalette = colorOptions.customColorMap; - } + const onColorChange = colorOptions => { + const newColorOptions = { + type: colorOptions.type, + color: colorOptions.color, + }; + if (colorOptions.type === COLOR_MAP_TYPE.ORDINAL) { + newColorOptions.useCustomColorRamp = colorOptions.useCustomColorMap; + newColorOptions.customColorRamp = colorOptions.customColorMap; + } else { + newColorOptions.useCustomColorPalette = colorOptions.useCustomColorMap; + newColorOptions.customColorPalette = colorOptions.customColorMap; + } - const oldStyleOptions = { ...styleOptions }; - - if (oldStyleOptions.type === !newColorOptions.type) { - delete oldStyleOptions.type; - if (newColorOptions.type === COLOR_MAP_TYPE.ORDINAL) { - delete oldStyleOptions.useCustomColorPalette; - delete oldStyleOptions.customColorPalette; - } else { - delete oldStyleOptions.useCustomColorRamp; - delete oldStyleOptions.customColorRamp; - } + const oldStyleOptions = { ...styleOptions }; + + if (oldStyleOptions.type === !newColorOptions.type) { + delete oldStyleOptions.type; + if (newColorOptions.type === COLOR_MAP_TYPE.ORDINAL) { + delete oldStyleOptions.useCustomColorPalette; + delete oldStyleOptions.customColorPalette; + } else { + delete oldStyleOptions.useCustomColorRamp; + delete oldStyleOptions.customColorRamp; } + } - const newOptions = { - ...oldStyleOptions, - ...newColorOptions, - }; - onDynamicStyleChange(styleProperty.getStyleName(), newOptions); + const newOptions = { + ...oldStyleOptions, + ...newColorOptions, }; + onDynamicStyleChange(styleProperty.getStyleName(), newOptions); + }; - if (this.state.colorMapType === COLOR_MAP_TYPE.ORDINAL) { - const customOptionLabel = ( - - ); - colorSelect = ( - onColorChange(options)} - colorMapType={COLOR_MAP_TYPE.ORDINAL} - color={styleOptions.color} - customColorMap={styleOptions.customColorRamp} - useCustomColorMap={_.get(styleOptions, 'useCustomColorRamp', false)} - compressed - /> - ); - } else if (this.state.colorMapType === COLOR_MAP_TYPE.CATEGORICAL) { - const customOptionLabel = ( - - ); - colorSelect = ( - onColorChange(options)} - colorMapType={COLOR_MAP_TYPE.CATEGORICAL} - color={styleOptions.color} - customColorMap={styleOptions.customColorPalette} - useCustomColorMap={_.get(styleOptions, 'useCustomColorPalette', false)} - compressed - /> - ); - } - return colorSelect; + if (this.state.colorMapType === COLOR_MAP_TYPE.ORDINAL) { + const customOptionLabel = i18n.translate('xpack.maps.style.customColorRampLabel', { + defaultMessage: 'Custom color ramp', + }); + colorSelect = ( + onColorChange(options)} + colorMapType={COLOR_MAP_TYPE.ORDINAL} + color={styleOptions.color} + customColorMap={styleOptions.customColorRamp} + useCustomColorMap={_.get(styleOptions, 'useCustomColorRamp', false)} + compressed + /> + ); + } else if (this.state.colorMapType === COLOR_MAP_TYPE.CATEGORICAL) { + const customOptionLabel = i18n.translate('xpack.maps.style.customColorPaletteLabel', { + defaultMessage: 'Custom color palette', + }); + colorSelect = ( + onColorChange(options)} + colorMapType={COLOR_MAP_TYPE.CATEGORICAL} + color={styleOptions.color} + customColorMap={styleOptions.customColorPalette} + useCustomColorMap={_.get(styleOptions, 'useCustomColorPalette', false)} + compressed + /> + ); } + return colorSelect; } render() { From e20fbd8e8f4026b411a887bf669bc722016c4b37 Mon Sep 17 00:00:00 2001 From: patrykkopycinski Date: Tue, 14 Jan 2020 16:36:15 +0100 Subject: [PATCH 097/139] [SIEM] Detection Engine UI improvements (#54712) --- .../components/alerts_viewer/alerts_table.tsx | 18 ++++++++------- .../events_viewer/events_viewer.tsx | 2 +- .../siem/public/components/toasters/index.tsx | 22 +++++++++++++------ .../detection_engine/rules/all/index.tsx | 6 ++++- 4 files changed, 31 insertions(+), 17 deletions(-) diff --git a/x-pack/legacy/plugins/siem/public/components/alerts_viewer/alerts_table.tsx b/x-pack/legacy/plugins/siem/public/components/alerts_viewer/alerts_table.tsx index 179474ee6e9d4..1901101957307 100644 --- a/x-pack/legacy/plugins/siem/public/components/alerts_viewer/alerts_table.tsx +++ b/x-pack/legacy/plugins/siem/public/components/alerts_viewer/alerts_table.tsx @@ -59,6 +59,15 @@ interface Props { const AlertsTableComponent: React.FC = ({ endDate, startDate, pageFilters = [] }) => { const alertsFilter = useMemo(() => [...defaultAlertsFilters, ...pageFilters], [pageFilters]); + const timelineTypeContext = useMemo( + () => ({ + documentType: i18n.ALERTS_DOCUMENT_TYPE, + footerText: i18n.TOTAL_COUNT_OF_ALERTS, + title: i18n.ALERTS_TABLE_TITLE, + }), + [] + ); + return ( = ({ endDate, startDate, pageFilters end={endDate} id={ALERTS_TABLE_ID} start={startDate} - timelineTypeContext={useMemo( - () => ({ - documentType: i18n.ALERTS_DOCUMENT_TYPE, - footerText: i18n.TOTAL_COUNT_OF_ALERTS, - title: i18n.ALERTS_TABLE_TITLE, - }), - [] - )} + timelineTypeContext={timelineTypeContext} /> ); }; diff --git a/x-pack/legacy/plugins/siem/public/components/events_viewer/events_viewer.tsx b/x-pack/legacy/plugins/siem/public/components/events_viewer/events_viewer.tsx index 2c669c259d07e..77d51f68c18ca 100644 --- a/x-pack/legacy/plugins/siem/public/components/events_viewer/events_viewer.tsx +++ b/x-pack/legacy/plugins/siem/public/components/events_viewer/events_viewer.tsx @@ -113,7 +113,7 @@ const EventsViewerComponent: React.FC = ({ ); return ( - + {({ measureRef, content: { width = 0 } }) => ( <> diff --git a/x-pack/legacy/plugins/siem/public/components/toasters/index.tsx b/x-pack/legacy/plugins/siem/public/components/toasters/index.tsx index 7098e618aeb55..b046c91dcd912 100644 --- a/x-pack/legacy/plugins/siem/public/components/toasters/index.tsx +++ b/x-pack/legacy/plugins/siem/public/components/toasters/index.tsx @@ -60,6 +60,12 @@ export const ManageGlobalToaster = ({ children }: ManageGlobalToasterProps) => { ); }; +const GlobalToasterListContainer = styled.div` + position: absolute; + right: 0; + bottom: 0; +`; + interface GlobalToasterProps { toastLifeTimeMs?: number; } @@ -82,13 +88,15 @@ export const GlobalToaster = ({ toastLifeTimeMs = 5000 }: GlobalToasterProps) => return ( <> {toasts.length > 0 && !isShowing && ( - { - dispatch({ type: 'deleteToaster', id }); - }} - toastLifeTimeMs={toastLifeTimeMs} - /> + + { + dispatch({ type: 'deleteToaster', id }); + }} + toastLifeTimeMs={toastLifeTimeMs} + /> + )} {toastInModal != null && ( diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/index.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/index.tsx index 202be75f09e69..819b513ecc9bc 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/index.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/index.tsx @@ -186,6 +186,10 @@ export const AllRules = React.memo<{ filter: filterString, }, }); + dispatch({ + type: 'updatePagination', + pagination: { ...pagination, page: 1 }, + }); }} /> @@ -221,7 +225,7 @@ export const AllRules = React.memo<{ Date: Tue, 14 Jan 2020 15:56:08 +0000 Subject: [PATCH 098/139] [ML] Adding categorization job wizard icon (#54721) --- .../job_type/categorization_job_icon.tsx | 22 +++++++++++++++++++ .../jobs/new_job/pages/job_type/page.tsx | 3 ++- 2 files changed, 24 insertions(+), 1 deletion(-) create mode 100644 x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/job_type/categorization_job_icon.tsx diff --git a/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/job_type/categorization_job_icon.tsx b/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/job_type/categorization_job_icon.tsx new file mode 100644 index 0000000000000..d69814e3e1347 --- /dev/null +++ b/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/job_type/categorization_job_icon.tsx @@ -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; + * you may not use this file except in compliance with the Elastic License. + */ + +import React from 'react'; + +export const CategorizationIcon = ( + + + + +); diff --git a/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/job_type/page.tsx b/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/job_type/page.tsx index 9a44d561c2d94..1b57dd341a046 100644 --- a/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/job_type/page.tsx +++ b/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/job_type/page.tsx @@ -24,6 +24,7 @@ import { DataRecognizer } from '../../../../components/data_recognizer'; import { addItemToRecentlyAccessed } from '../../../../util/recently_accessed'; import { timeBasedIndexCheck } from '../../../../util/index_utils'; import { CreateJobLinkCard } from '../../../../components/create_job_link_card'; +import { CategorizationIcon } from './categorization_job_icon'; export const Page: FC = () => { const kibanaContext = useKibanaContext(); @@ -154,7 +155,7 @@ export const Page: FC = () => { { href: getUrl('#jobs/new_job/categorization'), icon: { - type: 'createAdvancedJob', + type: CategorizationIcon, ariaLabel: i18n.translate('xpack.ml.newJob.wizard.jobType.categorizationAriaLabel', { defaultMessage: 'Categorization job', }), From 040aee9fedc8ffe7a804d5525296e7768e64cb46 Mon Sep 17 00:00:00 2001 From: Dmitry Lemeshko Date: Tue, 14 Jan 2020 16:56:38 +0100 Subject: [PATCH 099/139] Functional tests: refactor dashboard_page (#54588) * [test/functional] cleanup & tsfy dashboard_page * fix & improvement Co-authored-by: Elastic Machine --- .../apps/dashboard/dashboard_clone.js | 15 +- .../apps/dashboard/dashboard_filter_bar.js | 6 +- .../apps/dashboard/dashboard_filtering.js | 6 +- .../apps/dashboard/dashboard_listing.js | 54 +-- .../apps/dashboard/dashboard_save.js | 17 +- .../apps/dashboard/dashboard_snapshots.js | 6 +- .../apps/dashboard/dashboard_state.js | 7 +- .../apps/dashboard/dashboard_time_picker.js | 4 +- .../apps/dashboard/panel_controls.js | 12 +- test/functional/apps/dashboard/view_edit.js | 4 +- .../{dashboard_page.js => dashboard_page.ts} | 337 ++++++------------ test/functional/page_objects/index.ts | 1 - test/functional/page_objects/time_picker.js | 16 + .../functional/page_objects/visualize_page.ts | 10 +- .../services/dashboard/visualizations.js | 11 +- test/functional/services/listing_table.ts | 116 +++++- .../dashboard_mode/dashboard_view_mode.js | 4 +- .../functional/apps/lens/lens_reporting.ts | 3 +- .../apps/spaces/spaces_selection.ts | 5 +- 19 files changed, 312 insertions(+), 322 deletions(-) rename test/functional/page_objects/{dashboard_page.js => dashboard_page.ts} (60%) diff --git a/test/functional/apps/dashboard/dashboard_clone.js b/test/functional/apps/dashboard/dashboard_clone.js index 2a955a2dc90b1..f5485c1db206e 100644 --- a/test/functional/apps/dashboard/dashboard_clone.js +++ b/test/functional/apps/dashboard/dashboard_clone.js @@ -21,6 +21,7 @@ import expect from '@kbn/expect'; export default function({ getService, getPageObjects }) { const retry = getService('retry'); + const listingTable = getService('listingTable'); const PageObjects = getPageObjects(['dashboard', 'header', 'common']); describe('dashboard clone', function describeIndexTests() { @@ -40,10 +41,12 @@ export default function({ getService, getPageObjects }) { await PageObjects.dashboard.clickClone(); await PageObjects.dashboard.confirmClone(); - - const countOfDashboards = await PageObjects.dashboard.getDashboardCountWithName( + await PageObjects.dashboard.gotoDashboardLandingPage(); + const countOfDashboards = await listingTable.searchAndGetItemsCount( + 'dashboard', clonedDashboardName ); + expect(countOfDashboards).to.equal(1); }); @@ -70,8 +73,10 @@ export default function({ getService, getPageObjects }) { it("and doesn't save", async () => { await PageObjects.dashboard.cancelClone(); + await PageObjects.dashboard.gotoDashboardLandingPage(); - const countOfDashboards = await PageObjects.dashboard.getDashboardCountWithName( + const countOfDashboards = await listingTable.searchAndGetItemsCount( + 'dashboard', dashboardName ); expect(countOfDashboards).to.equal(1); @@ -85,8 +90,10 @@ export default function({ getService, getPageObjects }) { await PageObjects.dashboard.expectDuplicateTitleWarningDisplayed({ displayed: true }); await PageObjects.dashboard.confirmClone(); await PageObjects.dashboard.waitForRenderComplete(); + await PageObjects.dashboard.gotoDashboardLandingPage(); - const countOfDashboards = await PageObjects.dashboard.getDashboardCountWithName( + const countOfDashboards = await listingTable.searchAndGetItemsCount( + 'dashboard', dashboardName + ' Copy' ); expect(countOfDashboards).to.equal(2); diff --git a/test/functional/apps/dashboard/dashboard_filter_bar.js b/test/functional/apps/dashboard/dashboard_filter_bar.js index 5dcb18374c51f..6d2a30fa85325 100644 --- a/test/functional/apps/dashboard/dashboard_filter_bar.js +++ b/test/functional/apps/dashboard/dashboard_filter_bar.js @@ -27,7 +27,7 @@ export default function({ getService, getPageObjects }) { const pieChart = getService('pieChart'); const esArchiver = getService('esArchiver'); const kibanaServer = getService('kibanaServer'); - const PageObjects = getPageObjects(['common', 'dashboard', 'header', 'visualize']); + const PageObjects = getPageObjects(['common', 'dashboard', 'header', 'visualize', 'timePicker']); describe('dashboard filter bar', () => { before(async () => { @@ -91,7 +91,7 @@ export default function({ getService, getPageObjects }) { await filterBar.ensureFieldEditorModalIsClosed(); await PageObjects.dashboard.gotoDashboardLandingPage(); await PageObjects.dashboard.clickNewDashboard(); - await PageObjects.dashboard.setTimepickerInDataRange(); + await PageObjects.timePicker.setDefaultDataRange(); }); it('are not selected by default', async function() { @@ -136,7 +136,7 @@ export default function({ getService, getPageObjects }) { await filterBar.ensureFieldEditorModalIsClosed(); await PageObjects.dashboard.gotoDashboardLandingPage(); await PageObjects.dashboard.clickNewDashboard(); - await PageObjects.dashboard.setTimepickerInDataRange(); + await PageObjects.timePicker.setDefaultDataRange(); }); it('are added when a cell magnifying glass is clicked', async function() { diff --git a/test/functional/apps/dashboard/dashboard_filtering.js b/test/functional/apps/dashboard/dashboard_filtering.js index bd31bb010f260..1cb9f1490d442 100644 --- a/test/functional/apps/dashboard/dashboard_filtering.js +++ b/test/functional/apps/dashboard/dashboard_filtering.js @@ -34,7 +34,7 @@ export default function({ getService, getPageObjects }) { const esArchiver = getService('esArchiver'); const kibanaServer = getService('kibanaServer'); const dashboardPanelActions = getService('dashboardPanelActions'); - const PageObjects = getPageObjects(['common', 'dashboard', 'header', 'visualize']); + const PageObjects = getPageObjects(['common', 'dashboard', 'header', 'visualize', 'timePicker']); describe('dashboard filtering', function() { this.tags('smoke'); @@ -52,7 +52,7 @@ export default function({ getService, getPageObjects }) { describe('adding a filter that excludes all data', () => { before(async () => { await PageObjects.dashboard.clickNewDashboard(); - await PageObjects.dashboard.setTimepickerInDataRange(); + await PageObjects.timePicker.setDefaultDataRange(); await dashboardAddPanel.addEveryVisualization('"Filter Bytes Test"'); await dashboardAddPanel.addEverySavedSearch('"Filter Bytes Test"'); @@ -234,7 +234,7 @@ export default function({ getService, getPageObjects }) { it('visualization saved with a query filters data', async () => { await PageObjects.dashboard.clickNewDashboard(); - await PageObjects.dashboard.setTimepickerInDataRange(); + await PageObjects.timePicker.setDefaultDataRange(); await dashboardAddPanel.addVisualization('Rendering-Test:-animal-sounds-pie'); await PageObjects.header.waitUntilLoadingHasFinished(); diff --git a/test/functional/apps/dashboard/dashboard_listing.js b/test/functional/apps/dashboard/dashboard_listing.js index 179f10223afb2..e3e835109da2c 100644 --- a/test/functional/apps/dashboard/dashboard_listing.js +++ b/test/functional/apps/dashboard/dashboard_listing.js @@ -22,6 +22,7 @@ import expect from '@kbn/expect'; export default function({ getService, getPageObjects }) { const PageObjects = getPageObjects(['dashboard', 'header', 'common']); const browser = getService('browser'); + const listingTable = getService('listingTable'); describe('dashboard listing page', function describeIndexTests() { const dashboardName = 'Dashboard Listing Test'; @@ -41,7 +42,8 @@ export default function({ getService, getPageObjects }) { await PageObjects.dashboard.saveDashboard(dashboardName); await PageObjects.dashboard.gotoDashboardLandingPage(); - const countOfDashboards = await PageObjects.dashboard.getDashboardCountWithName( + const countOfDashboards = await listingTable.searchAndGetItemsCount( + 'dashboard', dashboardName ); expect(countOfDashboards).to.equal(1); @@ -53,7 +55,8 @@ export default function({ getService, getPageObjects }) { }); it('is not shown when there are no dashboards shown during a search', async function() { - const countOfDashboards = await PageObjects.dashboard.getDashboardCountWithName( + const countOfDashboards = await listingTable.searchAndGetItemsCount( + 'dashboard', 'gobeldeguck' ); expect(countOfDashboards).to.equal(0); @@ -65,9 +68,9 @@ export default function({ getService, getPageObjects }) { describe('delete', function() { it('default confirm action is cancel', async function() { - await PageObjects.dashboard.searchForDashboardWithName(dashboardName); - await PageObjects.dashboard.checkDashboardListingSelectAllCheckbox(); - await PageObjects.dashboard.clickDeleteSelectedDashboards(); + await listingTable.searchForItemWithName(dashboardName); + await listingTable.checkListingSelectAllCheckbox(); + await listingTable.clickDeleteSelected(); await PageObjects.common.expectConfirmModalOpenState(true); @@ -75,19 +78,21 @@ export default function({ getService, getPageObjects }) { await PageObjects.common.expectConfirmModalOpenState(false); - const countOfDashboards = await PageObjects.dashboard.getDashboardCountWithName( + const countOfDashboards = await listingTable.searchAndGetItemsCount( + 'dashboard', dashboardName ); expect(countOfDashboards).to.equal(1); }); it('succeeds on confirmation press', async function() { - await PageObjects.dashboard.checkDashboardListingSelectAllCheckbox(); - await PageObjects.dashboard.clickDeleteSelectedDashboards(); + await listingTable.checkListingSelectAllCheckbox(); + await listingTable.clickDeleteSelected(); await PageObjects.common.clickConfirmOnModal(); - const countOfDashboards = await PageObjects.dashboard.getDashboardCountWithName( + const countOfDashboards = await listingTable.searchAndGetItemsCount( + 'dashboard', dashboardName ); expect(countOfDashboards).to.equal(0); @@ -96,44 +101,45 @@ export default function({ getService, getPageObjects }) { describe('search', function() { before(async () => { - await PageObjects.dashboard.clearSearchValue(); + await listingTable.clearSearchFilter(); await PageObjects.dashboard.clickNewDashboard(); await PageObjects.dashboard.saveDashboard('Two Words'); + await PageObjects.dashboard.gotoDashboardLandingPage(); }); it('matches on the first word', async function() { - await PageObjects.dashboard.searchForDashboardWithName('Two'); - const countOfDashboards = await PageObjects.dashboard.getCountOfDashboardsInListingTable(); + await listingTable.searchForItemWithName('Two'); + const countOfDashboards = await listingTable.getItemsCount('dashboard'); expect(countOfDashboards).to.equal(1); }); it('matches the second word', async function() { - await PageObjects.dashboard.searchForDashboardWithName('Words'); - const countOfDashboards = await PageObjects.dashboard.getCountOfDashboardsInListingTable(); + await listingTable.searchForItemWithName('Words'); + const countOfDashboards = await listingTable.getItemsCount('dashboard'); expect(countOfDashboards).to.equal(1); }); it('matches the second word prefix', async function() { - await PageObjects.dashboard.searchForDashboardWithName('Wor'); - const countOfDashboards = await PageObjects.dashboard.getCountOfDashboardsInListingTable(); + await listingTable.searchForItemWithName('Wor'); + const countOfDashboards = await listingTable.getItemsCount('dashboard'); expect(countOfDashboards).to.equal(1); }); it('does not match mid word', async function() { - await PageObjects.dashboard.searchForDashboardWithName('ords'); - const countOfDashboards = await PageObjects.dashboard.getCountOfDashboardsInListingTable(); + await listingTable.searchForItemWithName('ords'); + const countOfDashboards = await listingTable.getItemsCount('dashboard'); expect(countOfDashboards).to.equal(0); }); it('is case insensitive', async function() { - await PageObjects.dashboard.searchForDashboardWithName('two words'); - const countOfDashboards = await PageObjects.dashboard.getCountOfDashboardsInListingTable(); + await listingTable.searchForItemWithName('two words'); + const countOfDashboards = await listingTable.getItemsCount('dashboard'); expect(countOfDashboards).to.equal(1); }); it('is using AND operator', async function() { - await PageObjects.dashboard.searchForDashboardWithName('three words'); - const countOfDashboards = await PageObjects.dashboard.getCountOfDashboardsInListingTable(); + await listingTable.searchForItemWithName('three words'); + const countOfDashboards = await listingTable.getItemsCount('dashboard'); expect(countOfDashboards).to.equal(0); }); }); @@ -176,7 +182,7 @@ export default function({ getService, getPageObjects }) { }); it('preloads search filter bar when there is no match', async function() { - const searchFilter = await PageObjects.dashboard.getSearchFilterValue(); + const searchFilter = await listingTable.getSearchFilterValue(); expect(searchFilter).to.equal('"nodashboardsnamedme"'); }); @@ -196,7 +202,7 @@ export default function({ getService, getPageObjects }) { }); it('preloads search filter bar when there is more than one match', async function() { - const searchFilter = await PageObjects.dashboard.getSearchFilterValue(); + const searchFilter = await listingTable.getSearchFilterValue(); expect(searchFilter).to.equal('"two words"'); }); diff --git a/test/functional/apps/dashboard/dashboard_save.js b/test/functional/apps/dashboard/dashboard_save.js index 23bb784c79cd0..2ea1389b89ad4 100644 --- a/test/functional/apps/dashboard/dashboard_save.js +++ b/test/functional/apps/dashboard/dashboard_save.js @@ -19,8 +19,9 @@ import expect from '@kbn/expect'; -export default function({ getPageObjects }) { +export default function({ getPageObjects, getService }) { const PageObjects = getPageObjects(['dashboard', 'header']); + const listingTable = getService('listingTable'); describe('dashboard save', function describeIndexTests() { this.tags('smoke'); @@ -47,8 +48,10 @@ export default function({ getPageObjects }) { it('does not save on reject confirmation', async function() { await PageObjects.dashboard.cancelSave(); + await PageObjects.dashboard.gotoDashboardLandingPage(); - const countOfDashboards = await PageObjects.dashboard.getDashboardCountWithName( + const countOfDashboards = await listingTable.searchAndGetItemsCount( + 'dashboard', dashboardName ); expect(countOfDashboards).to.equal(1); @@ -68,15 +71,17 @@ export default function({ getPageObjects }) { // wait till it finishes reloading or it might reload the url after simulating the // dashboard landing page click. await PageObjects.header.waitUntilLoadingHasFinished(); + await PageObjects.dashboard.gotoDashboardLandingPage(); - const countOfDashboards = await PageObjects.dashboard.getDashboardCountWithName( + const countOfDashboards = await listingTable.searchAndGetItemsCount( + 'dashboard', dashboardName ); expect(countOfDashboards).to.equal(2); }); it('Does not warn when you save an existing dashboard with the title it already has, and that title is a duplicate', async function() { - await PageObjects.dashboard.selectDashboard(dashboardName); + await listingTable.clickItemLink('dashboard', dashboardName); await PageObjects.header.awaitGlobalLoadingIndicatorHidden(); await PageObjects.dashboard.switchToEditMode(); await PageObjects.dashboard.saveDashboard(dashboardName); @@ -121,8 +126,10 @@ export default function({ getPageObjects }) { // wait till it finishes reloading or it might reload the url after simulating the // dashboard landing page click. await PageObjects.header.waitUntilLoadingHasFinished(); + await PageObjects.dashboard.gotoDashboardLandingPage(); - const countOfDashboards = await PageObjects.dashboard.getDashboardCountWithName( + const countOfDashboards = await listingTable.searchAndGetItemsCount( + 'dashboard', dashboardNameEnterKey ); expect(countOfDashboards).to.equal(1); diff --git a/test/functional/apps/dashboard/dashboard_snapshots.js b/test/functional/apps/dashboard/dashboard_snapshots.js index 9900881e4690d..3a09b46a713cc 100644 --- a/test/functional/apps/dashboard/dashboard_snapshots.js +++ b/test/functional/apps/dashboard/dashboard_snapshots.js @@ -20,7 +20,7 @@ import expect from '@kbn/expect'; export default function({ getService, getPageObjects, updateBaselines }) { - const PageObjects = getPageObjects(['dashboard', 'header', 'visualize', 'common']); + const PageObjects = getPageObjects(['dashboard', 'header', 'visualize', 'common', 'timePicker']); const screenshot = getService('screenshots'); const browser = getService('browser'); const esArchiver = getService('esArchiver'); @@ -48,7 +48,7 @@ export default function({ getService, getPageObjects, updateBaselines }) { it('compare TSVB snapshot', async () => { await PageObjects.dashboard.gotoDashboardLandingPage(); await PageObjects.dashboard.clickNewDashboard(); - await PageObjects.dashboard.setTimepickerInLogstashDataRange(); + await PageObjects.timePicker.setLogstashDataRange(); await dashboardAddPanel.addVisualization('Rendering Test: tsvb-ts'); await PageObjects.common.closeToast(); @@ -71,7 +71,7 @@ export default function({ getService, getPageObjects, updateBaselines }) { it('compare area chart snapshot', async () => { await PageObjects.dashboard.gotoDashboardLandingPage(); await PageObjects.dashboard.clickNewDashboard(); - await PageObjects.dashboard.setTimepickerInLogstashDataRange(); + await PageObjects.timePicker.setLogstashDataRange(); await dashboardAddPanel.addVisualization('Rendering Test: area with not filter'); await PageObjects.common.closeToast(); diff --git a/test/functional/apps/dashboard/dashboard_state.js b/test/functional/apps/dashboard/dashboard_state.js index 3b9e404e9b94d..b9172990c501d 100644 --- a/test/functional/apps/dashboard/dashboard_state.js +++ b/test/functional/apps/dashboard/dashboard_state.js @@ -34,6 +34,7 @@ export default function({ getService, getPageObjects }) { 'discover', 'tileMap', 'visChart', + 'timePicker', ]); const testSubjects = getService('testSubjects'); const browser = getService('browser'); @@ -58,7 +59,7 @@ export default function({ getService, getPageObjects }) { await PageObjects.dashboard.gotoDashboardLandingPage(); await PageObjects.dashboard.clickNewDashboard(); - await PageObjects.dashboard.setTimepickerInHistoricalDataRange(); + await PageObjects.timePicker.setHistoricalDataRange(); await dashboardAddPanel.addVisualization(AREA_CHART_VIS_NAME); await PageObjects.dashboard.saveDashboard('Overridden colors'); @@ -83,7 +84,7 @@ export default function({ getService, getPageObjects }) { await PageObjects.dashboard.gotoDashboardLandingPage(); await PageObjects.header.clickDiscover(); - await PageObjects.dashboard.setTimepickerInHistoricalDataRange(); + await PageObjects.timePicker.setHistoricalDataRange(); await PageObjects.discover.clickFieldListItemAdd('bytes'); await PageObjects.discover.saveSearch('my search'); await PageObjects.header.waitUntilLoadingHasFinished(); @@ -147,7 +148,7 @@ export default function({ getService, getPageObjects }) { await PageObjects.dashboard.gotoDashboardLandingPage(); await PageObjects.dashboard.clickNewDashboard(); - await PageObjects.dashboard.setTimepickerInHistoricalDataRange(); + await PageObjects.timePicker.setHistoricalDataRange(); await dashboardAddPanel.addVisualization('Visualization TileMap'); await PageObjects.dashboard.saveDashboard('No local edits'); diff --git a/test/functional/apps/dashboard/dashboard_time_picker.js b/test/functional/apps/dashboard/dashboard_time_picker.js index 0b73bc224ab74..b99de9fee6db1 100644 --- a/test/functional/apps/dashboard/dashboard_time_picker.js +++ b/test/functional/apps/dashboard/dashboard_time_picker.js @@ -44,7 +44,7 @@ export default function({ getService, getPageObjects }) { await PageObjects.dashboard.addVisualizations([PIE_CHART_VIS_NAME]); await pieChart.expectPieSliceCount(0); - await PageObjects.dashboard.setTimepickerInHistoricalDataRange(); + await PageObjects.timePicker.setHistoricalDataRange(); await pieChart.expectPieSliceCount(10); }); @@ -95,7 +95,7 @@ export default function({ getService, getPageObjects }) { await PageObjects.dashboard.gotoDashboardLandingPage(); await PageObjects.dashboard.clickNewDashboard(); await PageObjects.dashboard.addVisualizations([PIE_CHART_VIS_NAME]); - // Same date range as `setTimepickerInHistoricalDataRange` + // Same date range as `timePicker.setHistoricalDataRange()` await PageObjects.timePicker.setAbsoluteRange( '2015-09-19 06:31:44.000', '2015-09-23 18:31:44.000' diff --git a/test/functional/apps/dashboard/panel_controls.js b/test/functional/apps/dashboard/panel_controls.js index 683f3683e65e5..f30f58913bd97 100644 --- a/test/functional/apps/dashboard/panel_controls.js +++ b/test/functional/apps/dashboard/panel_controls.js @@ -33,7 +33,13 @@ export default function({ getService, getPageObjects }) { const dashboardReplacePanel = getService('dashboardReplacePanel'); const dashboardVisualizations = getService('dashboardVisualizations'); const renderable = getService('renderable'); - const PageObjects = getPageObjects(['dashboard', 'header', 'visualize', 'discover']); + const PageObjects = getPageObjects([ + 'dashboard', + 'header', + 'visualize', + 'discover', + 'timePicker', + ]); const dashboardName = 'Dashboard Panel Controls Test'; describe('dashboard panel controls', function viewEditModeTests() { @@ -52,7 +58,7 @@ export default function({ getService, getPageObjects }) { let intialDimensions; before(async () => { await PageObjects.dashboard.clickNewDashboard(); - await PageObjects.dashboard.setTimepickerInHistoricalDataRange(); + await PageObjects.timePicker.setHistoricalDataRange(); await dashboardAddPanel.addVisualization(PIE_CHART_VIS_NAME); await dashboardAddPanel.addVisualization(LINE_CHART_VIS_NAME); intialDimensions = await PageObjects.dashboard.getPanelDimensions(); @@ -110,7 +116,7 @@ export default function({ getService, getPageObjects }) { describe('panel edit controls', function() { before(async () => { await PageObjects.dashboard.clickNewDashboard(); - await PageObjects.dashboard.setTimepickerInHistoricalDataRange(); + await PageObjects.timePicker.setHistoricalDataRange(); await dashboardAddPanel.addVisualization(PIE_CHART_VIS_NAME); }); diff --git a/test/functional/apps/dashboard/view_edit.js b/test/functional/apps/dashboard/view_edit.js index 212044d898251..a0b972f3ab63c 100644 --- a/test/functional/apps/dashboard/view_edit.js +++ b/test/functional/apps/dashboard/view_edit.js @@ -68,7 +68,7 @@ export default function({ getService, getPageObjects }) { }); it('when time changed is stored with dashboard', async function() { - await PageObjects.dashboard.setTimepickerInDataRange(); + await PageObjects.timePicker.setDefaultDataRange(); const originalTime = await PageObjects.timePicker.getTimeConfig(); @@ -196,7 +196,7 @@ export default function({ getService, getPageObjects }) { describe('and preserves edits on cancel', function() { it('when time changed is stored with dashboard', async function() { await PageObjects.dashboard.gotoDashboardEditMode(dashboardName); - await PageObjects.dashboard.setTimepickerInDataRange(); + await PageObjects.timePicker.setDefaultDataRange(); await PageObjects.dashboard.saveDashboard(dashboardName, true); await PageObjects.dashboard.switchToEditMode(); await PageObjects.timePicker.setAbsoluteRange( diff --git a/test/functional/page_objects/dashboard_page.js b/test/functional/page_objects/dashboard_page.ts similarity index 60% rename from test/functional/page_objects/dashboard_page.js rename to test/functional/page_objects/dashboard_page.ts index b0f1a3304a9b8..af0a0160a81d8 100644 --- a/test/functional/page_objects/dashboard_page.js +++ b/test/functional/page_objects/dashboard_page.ts @@ -17,89 +17,85 @@ * under the License. */ -import _ from 'lodash'; import { DashboardConstants } from '../../../src/legacy/core_plugins/kibana/public/dashboard/np_ready/dashboard_constants'; export const PIE_CHART_VIS_NAME = 'Visualization PieChart'; export const AREA_CHART_VIS_NAME = 'Visualization漢字 AreaChart'; export const LINE_CHART_VIS_NAME = 'Visualization漢字 LineChart'; +import { FtrProviderContext } from '../ftr_provider_context'; -export function DashboardPageProvider({ getService, getPageObjects }) { +export function DashboardPageProvider({ getService, getPageObjects }: FtrProviderContext) { const log = getService('log'); const find = getService('find'); const retry = getService('retry'); - const config = getService('config'); const browser = getService('browser'); const esArchiver = getService('esArchiver'); const kibanaServer = getService('kibanaServer'); const testSubjects = getService('testSubjects'); const dashboardAddPanel = getService('dashboardAddPanel'); const renderable = getService('renderable'); - const PageObjects = getPageObjects(['common', 'header', 'settings', 'visualize', 'timePicker']); - - const defaultFindTimeout = config.get('timeouts.find'); + const listingTable = getService('listingTable'); + const PageObjects = getPageObjects(['common', 'header', 'visualize']); + + interface SaveDashboardOptions { + waitDialogIsClosed: boolean; + needsConfirm?: boolean; + storeTimeWithDashboard?: boolean; + saveAsNew?: boolean; + } class DashboardPage { async initTests({ kibanaIndex = 'dashboard/legacy', defaultIndex = 'logstash-*' } = {}) { log.debug('load kibana index with visualizations and log data'); await esArchiver.load(kibanaIndex); - await kibanaServer.uiSettings.replace({ - defaultIndex: defaultIndex, - }); + await kibanaServer.uiSettings.replace({ defaultIndex }); await PageObjects.common.navigateToApp('dashboard'); } - async preserveCrossAppState() { + public async preserveCrossAppState() { const url = await browser.getCurrentUrl(); await browser.get(url, false); await PageObjects.header.waitUntilLoadingHasFinished(); } - async selectDefaultIndex(indexName) { - await PageObjects.settings.navigateTo(); - await PageObjects.settings.clickKibanaIndexPatterns(); - await find.clickByPartialLinkText(indexName); - await PageObjects.settings.clickDefaultIndexButton(); - } - - async clickFullScreenMode() { + public async clickFullScreenMode() { log.debug(`clickFullScreenMode`); await testSubjects.click('dashboardFullScreenMode'); await testSubjects.exists('exitFullScreenModeLogo'); await this.waitForRenderComplete(); } - async fullScreenModeMenuItemExists() { + public async fullScreenModeMenuItemExists() { return await testSubjects.exists('dashboardFullScreenMode'); } - async exitFullScreenTextButtonExists() { + public async exitFullScreenTextButtonExists() { return await testSubjects.exists('exitFullScreenModeText'); } - async getExitFullScreenTextButton() { + public async getExitFullScreenTextButton() { return await testSubjects.find('exitFullScreenModeText'); } - async exitFullScreenLogoButtonExists() { + public async exitFullScreenLogoButtonExists() { return await testSubjects.exists('exitFullScreenModeLogo'); } - async getExitFullScreenLogoButton() { + public async getExitFullScreenLogoButton() { return await testSubjects.find('exitFullScreenModeLogo'); } - async clickExitFullScreenLogoButton() { + public async clickExitFullScreenLogoButton() { await testSubjects.click('exitFullScreenModeLogo'); await this.waitForRenderComplete(); } - async clickExitFullScreenTextButton() { + public async clickExitFullScreenTextButton() { await testSubjects.click('exitFullScreenModeText'); await this.waitForRenderComplete(); } - async getDashboardIdFromCurrentUrl() { + public async getDashboardIdFromCurrentUrl() { const currentUrl = await browser.getCurrentUrl(); const urlSubstring = 'kibana#/dashboard/'; const startOfIdIndex = currentUrl.indexOf(urlSubstring) + urlSubstring.length; @@ -115,25 +111,25 @@ export function DashboardPageProvider({ getService, getPageObjects }) { * Returns true if already on the dashboard landing page (that page doesn't have a link to itself). * @returns {Promise} */ - async onDashboardLandingPage() { + public async onDashboardLandingPage() { log.debug(`onDashboardLandingPage`); return await testSubjects.exists('dashboardLandingPage', { timeout: 5000, }); } - async expectExistsDashboardLandingPage() { + public async expectExistsDashboardLandingPage() { log.debug(`expectExistsDashboardLandingPage`); await testSubjects.existOrFail('dashboardLandingPage'); } - async clickDashboardBreadcrumbLink() { + public async clickDashboardBreadcrumbLink() { log.debug('clickDashboardBreadcrumbLink'); await find.clickByCssSelector(`a[href="#${DashboardConstants.LANDING_PAGE_PATH}"]`); await this.expectExistsDashboardLandingPage(); } - async gotoDashboardLandingPage() { + public async gotoDashboardLandingPage() { log.debug('gotoDashboardLandingPage'); const onPage = await this.onDashboardLandingPage(); if (!onPage) { @@ -141,26 +137,26 @@ export function DashboardPageProvider({ getService, getPageObjects }) { } } - async clickClone() { + public async clickClone() { log.debug('Clicking clone'); await testSubjects.click('dashboardClone'); } - async getCloneTitle() { + public async getCloneTitle() { return await testSubjects.getAttribute('clonedDashboardTitle', 'value'); } - async confirmClone() { + public async confirmClone() { log.debug('Confirming clone'); await testSubjects.click('cloneConfirmButton'); } - async cancelClone() { + public async cancelClone() { log.debug('Canceling clone'); await testSubjects.click('cloneCancelButton'); } - async setClonedDashboardTitle(title) { + public async setClonedDashboardTitle(title: string) { await testSubjects.setValue('clonedDashboardTitle', title); } @@ -168,7 +164,7 @@ export function DashboardPageProvider({ getService, getPageObjects }) { * Asserts that the duplicate title warning is either displayed or not displayed. * @param { displayed: boolean } */ - async expectDuplicateTitleWarningDisplayed({ displayed }) { + public async expectDuplicateTitleWarningDisplayed({ displayed = true }) { if (displayed) { await testSubjects.existOrFail('titleDupicateWarnMsg'); } else { @@ -180,18 +176,16 @@ export function DashboardPageProvider({ getService, getPageObjects }) { * Asserts that the toolbar pagination (count and arrows) is either displayed or not displayed. * @param { displayed: boolean } */ - async expectToolbarPaginationDisplayed({ displayed }) { + public async expectToolbarPaginationDisplayed({ displayed = true }) { const subjects = ['btnPrevPage', 'btnNextPage', 'toolBarPagerText']; if (displayed) { - return await Promise.all(subjects.map(async subj => await testSubjects.existOrFail(subj))); + await Promise.all(subjects.map(async subj => await testSubjects.existOrFail(subj))); } else { - return await Promise.all( - subjects.map(async subj => await testSubjects.missingOrFail(subj)) - ); + await Promise.all(subjects.map(async subj => await testSubjects.missingOrFail(subj))); } } - async switchToEditMode() { + public async switchToEditMode() { log.debug('Switching to edit mode'); await testSubjects.click('dashboardEditMode'); // wait until the count of dashboard panels equals the count of toggle menu icons @@ -204,66 +198,34 @@ export function DashboardPageProvider({ getService, getPageObjects }) { }); } - async getIsInViewMode() { + public async getIsInViewMode() { log.debug('getIsInViewMode'); return await testSubjects.exists('dashboardEditMode'); } - async clickCancelOutOfEditMode() { + public async clickCancelOutOfEditMode() { log.debug('clickCancelOutOfEditMode'); - return await testSubjects.click('dashboardViewOnlyMode'); + await testSubjects.click('dashboardViewOnlyMode'); } - async clickNewDashboard() { - // One or the other will eventually show up on the landing page, depending on whether there are - // dashboards. - await retry.try(async () => { - const createNewItemButtonExists = await testSubjects.exists('newItemButton'); - if (createNewItemButtonExists) { - return await testSubjects.click('newItemButton'); - } - const createNewItemPromptExists = await this.getCreateDashboardPromptExists(); - if (createNewItemPromptExists) { - return await this.clickCreateDashboardPrompt(); - } - - throw new Error( - 'Page is still loading... waiting for create new prompt or button to appear' - ); - }); + public async clickNewDashboard() { + await listingTable.clickNewButton('createDashboardPromptButton'); } - async clickCreateDashboardPrompt() { + public async clickCreateDashboardPrompt() { await testSubjects.click('createDashboardPromptButton'); } - async getCreateDashboardPromptExists() { + public async getCreateDashboardPromptExists() { return await testSubjects.exists('createDashboardPromptButton'); } - async checkDashboardListingRow(id) { - await testSubjects.click(`checkboxSelectRow-${id}`); - } - - async checkDashboardListingSelectAllCheckbox() { - const element = await testSubjects.find('checkboxSelectAll'); - const isSelected = await element.isSelected(); - if (!isSelected) { - log.debug(`checking checkbox "checkboxSelectAll"`); - await testSubjects.click('checkboxSelectAll'); - } - } - - async clickDeleteSelectedDashboards() { - await testSubjects.click('deleteSelectedItems'); - } - - async isOptionsOpen() { + public async isOptionsOpen() { log.debug('isOptionsOpen'); return await testSubjects.exists('dashboardOptionsMenu'); } - async openOptions() { + public async openOptions() { log.debug('openOptions'); const isOpen = await this.isOptionsOpen(); if (!isOpen) { @@ -272,36 +234,36 @@ export function DashboardPageProvider({ getService, getPageObjects }) { } // avoids any 'Object with id x not found' errors when switching tests. - async clearSavedObjectsFromAppLinks() { + public async clearSavedObjectsFromAppLinks() { await PageObjects.header.clickVisualize(); await PageObjects.visualize.gotoLandingPage(); await PageObjects.header.clickDashboard(); await this.gotoDashboardLandingPage(); } - async isMarginsOn() { + public async isMarginsOn() { log.debug('isMarginsOn'); await this.openOptions(); return await testSubjects.getAttribute('dashboardMarginsCheckbox', 'checked'); } - async useMargins(on = true) { + public async useMargins(on = true) { await this.openOptions(); const isMarginsOn = await this.isMarginsOn(); - if (isMarginsOn !== on) { + if (isMarginsOn !== 'on') { return await testSubjects.click('dashboardMarginsCheckbox'); } } - async gotoDashboardEditMode(dashboardName) { + public async gotoDashboardEditMode(dashboardName: string) { await this.loadSavedDashboard(dashboardName); await this.switchToEditMode(); } - async renameDashboard(dashName) { - log.debug(`Naming dashboard ` + dashName); + public async renameDashboard(dashboardName: string) { + log.debug(`Naming dashboard ` + dashboardName); await testSubjects.click('dashboardRenameButton'); - await testSubjects.setValue('savedObjectTitle', dashName); + await testSubjects.setValue('savedObjectTitle', dashboardName); } /** @@ -309,11 +271,14 @@ export function DashboardPageProvider({ getService, getPageObjects }) { * verify that the save was successful, close the toast and return the * toast message * - * @param dashName {String} + * @param dashboardName {String} * @param saveOptions {{storeTimeWithDashboard: boolean, saveAsNew: boolean, needsConfirm: false, waitDialogIsClosed: boolean }} */ - async saveDashboard(dashName, saveOptions = { waitDialogIsClosed: true }) { - await this.enterDashboardTitleAndClickSave(dashName, saveOptions); + public async saveDashboard( + dashboardName: string, + saveOptions: SaveDashboardOptions = { waitDialogIsClosed: true } + ) { + await this.enterDashboardTitleAndClickSave(dashboardName, saveOptions); if (saveOptions.needsConfirm) { await this.clickSave(); @@ -328,37 +293,24 @@ export function DashboardPageProvider({ getService, getPageObjects }) { return message; } - async deleteDashboard(dashboardName, dashboardId) { - await this.gotoDashboardLandingPage(); - await this.searchForDashboardWithName(dashboardName); - await this.checkDashboardListingRow(dashboardId); - await this.clickDeleteSelectedDashboards(); - await PageObjects.common.clickConfirmOnModal(); - } - - async cancelSave() { + public async cancelSave() { log.debug('Canceling save'); await testSubjects.click('saveCancelButton'); } - async clickSave() { + public async clickSave() { log.debug('DashboardPage.clickSave'); await testSubjects.click('confirmSaveSavedObjectButton'); } - async pressEnterKey() { - log.debug('DashboardPage.pressEnterKey'); - await PageObjects.common.pressEnterKey(); - } - /** * * @param dashboardTitle {String} * @param saveOptions {{storeTimeWithDashboard: boolean, saveAsNew: boolean, waitDialogIsClosed: boolean}} */ - async enterDashboardTitleAndClickSave( - dashboardTitle, - saveOptions = { waitDialogIsClosed: true } + public async enterDashboardTitleAndClickSave( + dashboardTitle: string, + saveOptions: SaveDashboardOptions = { waitDialogIsClosed: true } ) { await testSubjects.click('dashboardSaveMenuItem'); const modalDialog = await testSubjects.find('savedObjectSaveModal'); @@ -380,128 +332,66 @@ export function DashboardPageProvider({ getService, getPageObjects }) { } } - async ensureDuplicateTitleCallout() { + public async ensureDuplicateTitleCallout() { await testSubjects.existOrFail('titleDupicateWarnMsg'); } /** * @param dashboardTitle {String} */ - async enterDashboardTitleAndPressEnter(dashboardTitle) { + public async enterDashboardTitleAndPressEnter(dashboardTitle: string) { await testSubjects.click('dashboardSaveMenuItem'); const modalDialog = await testSubjects.find('savedObjectSaveModal'); log.debug('entering new title'); await testSubjects.setValue('savedObjectTitle', dashboardTitle); - await this.pressEnterKey(); + await PageObjects.common.pressEnterKey(); await testSubjects.waitForDeleted(modalDialog); } - async selectDashboard(dashName) { - await testSubjects.click(`dashboardListingTitleLink-${dashName.split(' ').join('-')}`); - } - - async clearSearchValue() { - log.debug(`clearSearchValue`); - - await this.gotoDashboardLandingPage(); - - await retry.try(async () => { - const searchFilter = await this.getSearchFilter(); - await searchFilter.clearValue(); - await PageObjects.common.pressEnterKey(); - }); - } - - async getSearchFilterValue() { - const searchFilter = await this.getSearchFilter(); - return await searchFilter.getAttribute('value'); - } - - async getSearchFilter() { - const searchFilter = await find.allByCssSelector('.euiFieldSearch'); - return searchFilter[0]; - } - - async searchForDashboardWithName(dashName) { - log.debug(`searchForDashboardWithName: ${dashName}`); - - await this.gotoDashboardLandingPage(); - - await retry.try(async () => { - const searchFilter = await this.getSearchFilter(); - await searchFilter.clearValue(); - await searchFilter.click(); - // Note: this replacement of - to space is to preserve original logic but I'm not sure why or if it's needed. - await searchFilter.type(dashName.replace('-', ' ')); - await PageObjects.common.pressEnterKey(); - await find.waitForDeletedByCssSelector('.euiBasicTable-loading', 5000); - }); - - await PageObjects.header.waitUntilLoadingHasFinished(); - } - - async getCountOfDashboardsInListingTable() { - const dashboardTitles = await find.allByCssSelector( - '[data-test-subj^="dashboardListingTitleLink"]' - ); - return dashboardTitles.length; - } - - async getDashboardCountWithName(dashName) { - log.debug(`getDashboardCountWithName: ${dashName}`); - - await this.searchForDashboardWithName(dashName); - const links = await testSubjects.findAll( - `dashboardListingTitleLink-${dashName.replace(/ /g, '-')}` - ); - return links.length; - } - // use the search filter box to narrow the results down to a single // entry, or at least to a single page of results - async loadSavedDashboard(dashName) { - log.debug(`Load Saved Dashboard ${dashName}`); + public async loadSavedDashboard(dashboardName: string) { + log.debug(`Load Saved Dashboard ${dashboardName}`); await this.gotoDashboardLandingPage(); - await this.searchForDashboardWithName(dashName); + await listingTable.searchForItemWithName(dashboardName); await retry.try(async () => { - await this.selectDashboard(dashName); + await listingTable.clickItemLink('dashboard', dashboardName); await PageObjects.header.waitUntilLoadingHasFinished(); // check Dashboard landing page is not present await testSubjects.missingOrFail('dashboardLandingPage', { timeout: 10000 }); }); } - async getPanelTitles() { + public async getPanelTitles() { log.debug('in getPanelTitles'); const titleObjects = await testSubjects.findAll('dashboardPanelTitle'); return await Promise.all(titleObjects.map(async title => await title.getVisibleText())); } - async getPanelDimensions() { + public async getPanelDimensions() { const panels = await find.allByCssSelector('.react-grid-item'); // These are gridster-defined elements and classes - async function getPanelDimensions(panel) { - const size = await panel.getSize(); - return { - width: size.width, - height: size.height, - }; - } - - const getDimensionsPromises = _.map(panels, getPanelDimensions); - return await Promise.all(getDimensionsPromises); + return await Promise.all( + panels.map(async panel => { + const size = await panel.getSize(); + return { + width: size.width, + height: size.height, + }; + }) + ); } - async getPanelCount() { + public async getPanelCount() { log.debug('getPanelCount'); const panels = await testSubjects.findAll('embeddablePanel'); return panels.length; } - getTestVisualizations() { + public getTestVisualizations() { return [ { name: PIE_CHART_VIS_NAME, description: 'PieChart' }, { name: 'Visualization☺ VerticalBarChart', description: 'VerticalBarChart' }, @@ -513,69 +403,45 @@ export function DashboardPageProvider({ getService, getPageObjects }) { ]; } - getTestVisualizationNames() { + public getTestVisualizationNames() { return this.getTestVisualizations().map(visualization => visualization.name); } - getTestVisualizationDescriptions() { + public getTestVisualizationDescriptions() { return this.getTestVisualizations().map(visualization => visualization.description); } - async getDashboardPanels() { + public async getDashboardPanels() { return await testSubjects.findAll('embeddablePanel'); } - async addVisualizations(visualizations) { + public async addVisualizations(visualizations: string[]) { await dashboardAddPanel.addVisualizations(visualizations); } - async setTimepickerInHistoricalDataRange() { - await PageObjects.timePicker.setDefaultAbsoluteRange(); - } - - async setTimepickerInDataRange() { - const fromTime = 'Jan 1, 2018 @ 00:00:00.000'; - const toTime = 'Apr 13, 2018 @ 00:00:00.000'; - await PageObjects.timePicker.setAbsoluteRange(fromTime, toTime); - } - - async setTimepickerInLogstashDataRange() { - const fromTime = 'Apr 9, 2018 @ 00:00:00.000'; - const toTime = 'Apr 13, 2018 @ 00:00:00.000'; - await PageObjects.timePicker.setAbsoluteRange(fromTime, toTime); - } - - async setSaveAsNewCheckBox(checked) { + public async setSaveAsNewCheckBox(checked: boolean) { log.debug('saveAsNewCheckbox: ' + checked); - const saveAsNewCheckbox = await testSubjects.find('saveAsNewCheckbox'); + let saveAsNewCheckbox = await testSubjects.find('saveAsNewCheckbox'); const isAlreadyChecked = (await saveAsNewCheckbox.getAttribute('aria-checked')) === 'true'; if (isAlreadyChecked !== checked) { log.debug('Flipping save as new checkbox'); - const saveAsNewCheckbox = await testSubjects.find('saveAsNewCheckbox'); + saveAsNewCheckbox = await testSubjects.find('saveAsNewCheckbox'); await retry.try(() => saveAsNewCheckbox.click()); } } - async setStoreTimeWithDashboard(checked) { + public async setStoreTimeWithDashboard(checked: boolean) { log.debug('Storing time with dashboard: ' + checked); - const storeTimeCheckbox = await testSubjects.find('storeTimeWithDashboard'); + let storeTimeCheckbox = await testSubjects.find('storeTimeWithDashboard'); const isAlreadyChecked = (await storeTimeCheckbox.getAttribute('aria-checked')) === 'true'; if (isAlreadyChecked !== checked) { log.debug('Flipping store time checkbox'); - const storeTimeCheckbox = await testSubjects.find('storeTimeWithDashboard'); + storeTimeCheckbox = await testSubjects.find('storeTimeWithDashboard'); await retry.try(() => storeTimeCheckbox.click()); } } - async getFilterDescriptions(timeout = defaultFindTimeout) { - const filters = await find.allByCssSelector( - '.filter-bar > .filter > .filter-description', - timeout - ); - return _.map(filters, async filter => await filter.getVisibleText()); - } - - async getSharedItemsCount() { + public async getSharedItemsCount() { log.debug('in getSharedItemsCount'); const attributeName = 'data-shared-items-count'; const element = await find.byCssSelector(`[${attributeName}]`); @@ -586,13 +452,14 @@ export function DashboardPageProvider({ getService, getPageObjects }) { throw new Error('no element'); } - async waitForRenderComplete() { + public async waitForRenderComplete() { log.debug('waitForRenderComplete'); const count = await this.getSharedItemsCount(); + // eslint-disable-next-line radix await renderable.waitForRender(parseInt(count)); } - async getSharedContainerData() { + public async getSharedContainerData() { log.debug('getSharedContainerData'); const sharedContainer = await find.byCssSelector('[data-shared-items-container]'); return { @@ -602,7 +469,7 @@ export function DashboardPageProvider({ getService, getPageObjects }) { }; } - async getPanelSharedItemData() { + public async getPanelSharedItemData() { log.debug('in getPanelSharedItemData'); const sharedItems = await find.allByCssSelector('[data-shared-item]'); return await Promise.all( @@ -615,17 +482,17 @@ export function DashboardPageProvider({ getService, getPageObjects }) { ); } - async checkHideTitle() { + public async checkHideTitle() { log.debug('ensure that you can click on hide title checkbox'); await this.openOptions(); return await testSubjects.click('dashboardPanelTitlesCheckbox'); } - async expectMissingSaveOption() { + public async expectMissingSaveOption() { await testSubjects.missingOrFail('dashboardSaveMenuItem'); } - async getNotLoadedVisualizations(vizList) { + public async getNotLoadedVisualizations(vizList: string[]) { const checkList = []; for (const name of vizList) { const isPresent = await testSubjects.exists( diff --git a/test/functional/page_objects/index.ts b/test/functional/page_objects/index.ts index 5526243ea2bbd..4ba8ddb035913 100644 --- a/test/functional/page_objects/index.ts +++ b/test/functional/page_objects/index.ts @@ -22,7 +22,6 @@ import { CommonPageProvider } from './common_page'; import { ConsolePageProvider } from './console_page'; // @ts-ignore not TS yet import { ContextPageProvider } from './context_page'; -// @ts-ignore not TS yet import { DashboardPageProvider } from './dashboard_page'; // @ts-ignore not TS yet import { DiscoverPageProvider } from './discover_page'; diff --git a/test/functional/page_objects/time_picker.js b/test/functional/page_objects/time_picker.js index 8717517f44864..7c67678429478 100644 --- a/test/functional/page_objects/time_picker.js +++ b/test/functional/page_objects/time_picker.js @@ -264,6 +264,22 @@ export function TimePickerPageProvider({ getService, getPageObjects }) { await this.closeQuickSelectTimeMenu(); } + + async setHistoricalDataRange() { + await this.setDefaultAbsoluteRange(); + } + + async setDefaultDataRange() { + const fromTime = 'Jan 1, 2018 @ 00:00:00.000'; + const toTime = 'Apr 13, 2018 @ 00:00:00.000'; + await this.setAbsoluteRange(fromTime, toTime); + } + + async setLogstashDataRange() { + const fromTime = 'Apr 9, 2018 @ 00:00:00.000'; + const toTime = 'Apr 13, 2018 @ 00:00:00.000'; + await this.setAbsoluteRange(fromTime, toTime); + } } return new TimePickerPage(); diff --git a/test/functional/page_objects/visualize_page.ts b/test/functional/page_objects/visualize_page.ts index 4ba64ea771eff..0071b8d993f70 100644 --- a/test/functional/page_objects/visualize_page.ts +++ b/test/functional/page_objects/visualize_page.ts @@ -44,15 +44,7 @@ export function VisualizePageProvider({ getService, getPageObjects }: FtrProvide } public async clickNewVisualization() { - // newItemButton button is only visible when there are items in the listing table is displayed. - let exists = await testSubjects.exists('newItemButton'); - if (exists) { - return await testSubjects.click('newItemButton'); - } - - exists = await testSubjects.exists('createVisualizationPromptButton'); - // no viz exist, click createVisualizationPromptButton to create new dashboard - return await this.createVisualizationPromptButton(); + await listingTable.clickNewButton('createVisualizationPromptButton'); } public async createVisualizationPromptButton() { diff --git a/test/functional/services/dashboard/visualizations.js b/test/functional/services/dashboard/visualizations.js index 5e722ccce8970..f7a6fb7d2f694 100644 --- a/test/functional/services/dashboard/visualizations.js +++ b/test/functional/services/dashboard/visualizations.js @@ -24,7 +24,14 @@ export function DashboardVisualizationProvider({ getService, getPageObjects }) { const queryBar = getService('queryBar'); const testSubjects = getService('testSubjects'); const dashboardAddPanel = getService('dashboardAddPanel'); - const PageObjects = getPageObjects(['dashboard', 'visualize', 'visEditor', 'header', 'discover']); + const PageObjects = getPageObjects([ + 'dashboard', + 'visualize', + 'visEditor', + 'header', + 'discover', + 'timePicker', + ]); return new (class DashboardVisualizations { async createAndAddTSVBVisualization(name) { @@ -43,7 +50,7 @@ export function DashboardVisualizationProvider({ getService, getPageObjects }) { log.debug(`createSavedSearch(${name})`); await PageObjects.header.clickDiscover(); - await PageObjects.dashboard.setTimepickerInHistoricalDataRange(); + await PageObjects.timePicker.setHistoricalDataRange(); if (query) { await queryBar.setQuery(query); diff --git a/test/functional/services/listing_table.ts b/test/functional/services/listing_table.ts index ec886cf694f2e..c7667ae7b4049 100644 --- a/test/functional/services/listing_table.ts +++ b/test/functional/services/listing_table.ts @@ -25,20 +25,35 @@ export function ListingTableProvider({ getService, getPageObjects }: FtrProvider const log = getService('log'); const retry = getService('retry'); const { common, header } = getPageObjects(['common', 'header']); + const prefixMap = { visualize: 'vis', dashboard: 'dashboard' }; + /** + * This class provides functions for dashboard and visualize landing pages + */ class ListingTable { - public async getSearchFilter() { + private async getSearchFilter() { const searchFilter = await find.allByCssSelector('.euiFieldSearch'); return searchFilter[0]; } - public async clearFilter() { + /** + * Returns search input value on landing page + */ + public async getSearchFilterValue() { + const searchFilter = await this.getSearchFilter(); + return await searchFilter.getAttribute('value'); + } + + /** + * Clears search input on landing page + */ + public async clearSearchFilter() { const searchFilter = await this.getSearchFilter(); await searchFilter.clearValue(); await searchFilter.click(); } - public async getAllVisualizationNamesOnCurrentPage(): Promise { + private async getAllItemsNamesOnCurrentPage(): Promise { const visualizationNames = []; const links = await find.allByCssSelector('.kuiLink'); for (let i = 0; i < links.length; i++) { @@ -48,14 +63,39 @@ export function ListingTableProvider({ getService, getPageObjects }: FtrProvider return visualizationNames; } + /** + * Navigates through all pages on Landing page and returns array of items names + */ + public async getAllItemsNames(): Promise { + log.debug('ListingTable.getAllItemsNames'); + let morePages = true; + let visualizationNames: string[] = []; + while (morePages) { + visualizationNames = visualizationNames.concat(await this.getAllItemsNamesOnCurrentPage()); + morePages = !((await testSubjects.getAttribute('pagerNextButton', 'disabled')) === 'true'); + if (morePages) { + await testSubjects.click('pagerNextButton'); + await header.waitUntilLoadingHasFinished(); + } + } + return visualizationNames; + } + + /** + * Returns items count on landing page + * @param appName 'visualize' | 'dashboard' + */ public async getItemsCount(appName: 'visualize' | 'dashboard'): Promise { - const prefixMap = { visualize: 'vis', dashboard: 'dashboard' }; const elements = await find.allByCssSelector( `[data-test-subj^="${prefixMap[appName]}ListingTitleLink"]` ); return elements.length; } + /** + * Types name into search field on Landing page and waits till search completed + * @param name item name + */ public async searchForItemWithName(name: string) { log.debug(`searchForItemWithName: ${name}`); @@ -71,10 +111,51 @@ export function ListingTableProvider({ getService, getPageObjects }: FtrProvider await header.waitUntilLoadingHasFinished(); } + /** + * Searches for item on Landing page and retruns items count that match `ListingTitleLink-${name}` pattern + * @param appName 'visualize' | 'dashboard' + * @param name item name + */ + public async searchAndGetItemsCount(appName: 'visualize' | 'dashboard', name: string) { + await this.searchForItemWithName(name); + const links = await testSubjects.findAll( + `${prefixMap[appName]}ListingTitleLink-${name.replace(/ /g, '-')}` + ); + return links.length; + } + public async clickDeleteSelected() { await testSubjects.click('deleteSelectedItems'); } + public async clickItemCheckbox(id: string) { + await testSubjects.click(`checkboxSelectRow-${id}`); + } + + /** + * Searches for item by name, selects checbox and deletes it + * @param name item name + * @param id row id + */ + public async deleteItem(name: string, id: string) { + await this.searchForItemWithName(name); + await this.clickItemCheckbox(id); + await this.clickDeleteSelected(); + await common.clickConfirmOnModal(); + } + + /** + * Clicks item on Landing page by link name if it is present + * @param appName 'dashboard' | 'visualize' + * @param name item name + */ + public async clickItemLink(appName: 'dashboard' | 'visualize', name: string) { + await testSubjects.click(`${appName}ListingTitleLink-${name.split(' ').join('-')}`); + } + + /** + * Checks 'SelectAll' checkbox on + */ public async checkListingSelectAllCheckbox() { const element = await testSubjects.find('checkboxSelectAll'); const isSelected = await element.isSelected(); @@ -84,21 +165,20 @@ export function ListingTableProvider({ getService, getPageObjects }: FtrProvider } } - public async getAllVisualizationNames(): Promise { - log.debug('ListingTable.getAllVisualizationNames'); - let morePages = true; - let visualizationNames: string[] = []; - while (morePages) { - visualizationNames = visualizationNames.concat( - await this.getAllVisualizationNamesOnCurrentPage() - ); - morePages = !((await testSubjects.getAttribute('pagerNextButton', 'disabled')) === 'true'); - if (morePages) { - await testSubjects.click('pagerNextButton'); - await header.waitUntilLoadingHasFinished(); + /** + * Clicks NewItem button on Landing page + * @param promptBtnTestSubj testSubj locator for Prompt button + */ + public async clickNewButton(promptBtnTestSubj: string): Promise { + await retry.try(async () => { + // newItemButton button is only visible when there are items in the listing table is displayed. + if (await testSubjects.exists('newItemButton')) { + await testSubjects.click('newItemButton'); + } else { + // no items exist, click createPromptButton to create new dashboard/visualization + await testSubjects.click(promptBtnTestSubj); } - } - return visualizationNames; + }); } } diff --git a/x-pack/test/functional/apps/dashboard_mode/dashboard_view_mode.js b/x-pack/test/functional/apps/dashboard_mode/dashboard_view_mode.js index 510a8b035f053..bab798dacc453 100644 --- a/x-pack/test/functional/apps/dashboard_mode/dashboard_view_mode.js +++ b/x-pack/test/functional/apps/dashboard_mode/dashboard_view_mode.js @@ -43,7 +43,7 @@ export default function({ getService, getPageObjects }) { await browser.setWindowSize(1600, 1000); await PageObjects.common.navigateToApp('discover'); - await PageObjects.dashboard.setTimepickerInHistoricalDataRange(); + await PageObjects.timePicker.setHistoricalDataRange(); await PageObjects.discover.saveSearch(savedSearchName); await PageObjects.common.navigateToApp('dashboard'); @@ -142,7 +142,7 @@ export default function({ getService, getPageObjects }) { }); it('can filter on a visualization', async () => { - await PageObjects.dashboard.setTimepickerInHistoricalDataRange(); + await PageObjects.timePicker.setHistoricalDataRange(); await pieChart.filterOnPieSlice(); const filterCount = await filterBar.getFilterCount(); expect(filterCount).to.equal(1); diff --git a/x-pack/test/functional/apps/lens/lens_reporting.ts b/x-pack/test/functional/apps/lens/lens_reporting.ts index 8c742537431c8..3d70390a2de41 100644 --- a/x-pack/test/functional/apps/lens/lens_reporting.ts +++ b/x-pack/test/functional/apps/lens/lens_reporting.ts @@ -12,6 +12,7 @@ export default function({ getService, getPageObjects }: FtrProviderContext) { const PageObjects = getPageObjects(['common', 'dashboard', 'reporting']); const find = getService('find'); const esArchiver = getService('esArchiver'); + const listingTable = getService('listingTable'); describe('lens reporting', () => { before(async () => { @@ -24,7 +25,7 @@ export default function({ getService, getPageObjects }: FtrProviderContext) { it('should not cause PDF reports to fail', async () => { await PageObjects.common.navigateToApp('dashboard'); - await PageObjects.dashboard.selectDashboard('Lens reportz'); + await listingTable.clickItemLink('dashboard', 'Lens reportz'); await PageObjects.reporting.openPdfReportingPanel(); await PageObjects.reporting.clickGenerateReportButton(); diff --git a/x-pack/test/functional/apps/spaces/spaces_selection.ts b/x-pack/test/functional/apps/spaces/spaces_selection.ts index 3d1ef40262b1d..5af9bc135ae27 100644 --- a/x-pack/test/functional/apps/spaces/spaces_selection.ts +++ b/x-pack/test/functional/apps/spaces/spaces_selection.ts @@ -10,6 +10,7 @@ export default function spaceSelectorFunctonalTests({ getPageObjects, }: FtrProviderContext) { const esArchiver = getService('esArchiver'); + const listingTable = getService('listingTable'); const PageObjects = getPageObjects([ 'common', 'dashboard', @@ -55,8 +56,8 @@ export default function spaceSelectorFunctonalTests({ const sampleDataHash = '/home/tutorial_directory/sampleData'; const expectDashboardRenders = async (dashName: string) => { - await PageObjects.dashboard.searchForDashboardWithName(dashName); - await PageObjects.dashboard.selectDashboard(dashName); + await listingTable.searchForItemWithName(dashName); + await listingTable.clickItemLink('dashboard', dashName); await PageObjects.header.waitUntilLoadingHasFinished(); await PageObjects.dashboard.waitForRenderComplete(); // throws if all items are not rendered }; From 643912e4f58fe2a411a328325ca48c45b77b4c29 Mon Sep 17 00:00:00 2001 From: Nathan Reese Date: Tue, 14 Jan 2020 11:12:53 -0500 Subject: [PATCH 100/139] [Maps] add labels to sample data maps (#54671) * [Maps] add count labels to sample data maps * [Maps] add labels to sample data maps * review feedback Co-authored-by: Elastic Machine --- .../es_geo_grid_source/es_geo_grid_source.js | 19 ++++++----- .../es_pew_pew_source/es_pew_pew_source.js | 9 +----- .../sample_data/ecommerce_saved_objects.js | 32 +++++++++++++++---- .../sample_data/flights_saved_objects.js | 6 ---- .../sample_data/web_logs_saved_objects.js | 26 ++++++++++++--- 5 files changed, 58 insertions(+), 34 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/sources/es_geo_grid_source/es_geo_grid_source.js b/x-pack/legacy/plugins/maps/public/layers/sources/es_geo_grid_source/es_geo_grid_source.js index 4a18fdc1a2e96..d4f36a63e5989 100644 --- a/x-pack/legacy/plugins/maps/public/layers/sources/es_geo_grid_source/es_geo_grid_source.js +++ b/x-pack/legacy/plugins/maps/public/layers/sources/es_geo_grid_source/es_geo_grid_source.js @@ -23,12 +23,7 @@ import { RENDER_AS } from './render_as'; import { CreateSourceEditor } from './create_source_editor'; import { UpdateSourceEditor } from './update_source_editor'; import { GRID_RESOLUTION } from '../../grid_resolution'; -import { - SOURCE_DATA_ID_ORIGIN, - ES_GEO_GRID, - COUNT_PROP_LABEL, - COUNT_PROP_NAME, -} from '../../../../common/constants'; +import { SOURCE_DATA_ID_ORIGIN, ES_GEO_GRID, COUNT_PROP_NAME } from '../../../../common/constants'; import { i18n } from '@kbn/i18n'; import { getDataSourceLabel } from '../../../../common/i18n_getters'; import { AbstractESAggSource } from '../es_agg_source'; @@ -251,7 +246,6 @@ export class ESGeoGridSource extends AbstractESAggSource { options: { ...defaultDynamicProperties[VECTOR_STYLES.FILL_COLOR].options, field: { - label: COUNT_PROP_LABEL, name: COUNT_PROP_NAME, origin: SOURCE_DATA_ID_ORIGIN, }, @@ -275,7 +269,16 @@ export class ESGeoGridSource extends AbstractESAggSource { options: { ...defaultDynamicProperties[VECTOR_STYLES.ICON_SIZE].options, field: { - label: COUNT_PROP_LABEL, + name: COUNT_PROP_NAME, + origin: SOURCE_DATA_ID_ORIGIN, + }, + }, + }, + [VECTOR_STYLES.LABEL_TEXT]: { + type: DynamicStyleProperty.type, + options: { + ...defaultDynamicProperties[VECTOR_STYLES.LABEL_TEXT].options, + field: { name: COUNT_PROP_NAME, origin: SOURCE_DATA_ID_ORIGIN, }, diff --git a/x-pack/legacy/plugins/maps/public/layers/sources/es_pew_pew_source/es_pew_pew_source.js b/x-pack/legacy/plugins/maps/public/layers/sources/es_pew_pew_source/es_pew_pew_source.js index 66d62dd5644ac..3579027b27847 100644 --- a/x-pack/legacy/plugins/maps/public/layers/sources/es_pew_pew_source/es_pew_pew_source.js +++ b/x-pack/legacy/plugins/maps/public/layers/sources/es_pew_pew_source/es_pew_pew_source.js @@ -17,12 +17,7 @@ import { VECTOR_STYLES, } from '../../styles/vector/vector_style_defaults'; import { i18n } from '@kbn/i18n'; -import { - SOURCE_DATA_ID_ORIGIN, - ES_PEW_PEW, - COUNT_PROP_NAME, - COUNT_PROP_LABEL, -} from '../../../../common/constants'; +import { SOURCE_DATA_ID_ORIGIN, ES_PEW_PEW, COUNT_PROP_NAME } from '../../../../common/constants'; import { getDataSourceLabel } from '../../../../common/i18n_getters'; import { convertToLines } from './convert_to_lines'; import { Schemas } from 'ui/vis/editors/default/schemas'; @@ -138,7 +133,6 @@ export class ESPewPewSource extends AbstractESAggSource { options: { ...defaultDynamicProperties[VECTOR_STYLES.LINE_COLOR].options, field: { - label: COUNT_PROP_LABEL, name: COUNT_PROP_NAME, origin: SOURCE_DATA_ID_ORIGIN, }, @@ -150,7 +144,6 @@ export class ESPewPewSource extends AbstractESAggSource { options: { ...defaultDynamicProperties[VECTOR_STYLES.LINE_WIDTH].options, field: { - label: COUNT_PROP_LABEL, name: COUNT_PROP_NAME, origin: SOURCE_DATA_ID_ORIGIN, }, diff --git a/x-pack/legacy/plugins/maps/server/sample_data/ecommerce_saved_objects.js b/x-pack/legacy/plugins/maps/server/sample_data/ecommerce_saved_objects.js index d5bcfa7cd1512..a3dbf8b1438fa 100644 --- a/x-pack/legacy/plugins/maps/server/sample_data/ecommerce_saved_objects.js +++ b/x-pack/legacy/plugins/maps/server/sample_data/ecommerce_saved_objects.js @@ -39,7 +39,6 @@ const layerList = [ type: 'DYNAMIC', options: { field: { - label: 'count of kibana_sample_data_ecommerce:geoip.country_iso_code', name: '__kbnjoin__count_groupby_kibana_sample_data_ecommerce.geoip.country_iso_code', origin: 'join', }, @@ -104,7 +103,6 @@ const layerList = [ type: 'DYNAMIC', options: { field: { - label: 'count of kibana_sample_data_ecommerce:geoip.region_name', name: '__kbnjoin__count_groupby_kibana_sample_data_ecommerce.geoip.region_name', origin: 'join', }, @@ -169,7 +167,6 @@ const layerList = [ type: 'DYNAMIC', options: { field: { - label: 'count of kibana_sample_data_ecommerce:geoip.region_name', name: '__kbnjoin__count_groupby_kibana_sample_data_ecommerce.geoip.region_name', origin: 'join', }, @@ -234,7 +231,6 @@ const layerList = [ type: 'DYNAMIC', options: { field: { - label: 'count of kibana_sample_data_ecommerce:geoip.region_name', name: '__kbnjoin__count_groupby_kibana_sample_data_ecommerce.geoip.region_name', origin: 'join', }, @@ -314,7 +310,6 @@ const layerList = [ type: 'DYNAMIC', options: { field: { - label: 'taxful_total_price', name: 'taxful_total_price', origin: 'source', }, @@ -376,7 +371,6 @@ const layerList = [ type: 'DYNAMIC', options: { field: { - label: 'Count', name: 'doc_count', origin: 'source', }, @@ -399,7 +393,6 @@ const layerList = [ type: 'DYNAMIC', options: { field: { - label: 'sum of taxful_total_price', name: 'sum_of_taxful_total_price', origin: 'source', }, @@ -407,6 +400,31 @@ const layerList = [ maxSize: 20, }, }, + labelText: { + type: 'DYNAMIC', + options: { + field: { + name: 'sum_of_taxful_total_price', + origin: 'source', + }, + }, + }, + labelSize: { + type: 'DYNAMIC', + options: { + field: { + name: 'sum_of_taxful_total_price', + origin: 'source', + }, + minSize: 12, + maxSize: 24, + }, + }, + labelBorderSize: { + options: { + size: 'MEDIUM', + }, + }, }, }, type: 'VECTOR', diff --git a/x-pack/legacy/plugins/maps/server/sample_data/flights_saved_objects.js b/x-pack/legacy/plugins/maps/server/sample_data/flights_saved_objects.js index aa3d5488764ad..cff4ad8182a9d 100644 --- a/x-pack/legacy/plugins/maps/server/sample_data/flights_saved_objects.js +++ b/x-pack/legacy/plugins/maps/server/sample_data/flights_saved_objects.js @@ -54,7 +54,6 @@ const layerList = [ type: 'DYNAMIC', options: { field: { - label: 'FlightTimeMin', name: 'FlightTimeMin', origin: 'source', }, @@ -77,7 +76,6 @@ const layerList = [ type: 'DYNAMIC', options: { field: { - label: 'DistanceMiles', name: 'DistanceMiles', origin: 'source', }, @@ -122,7 +120,6 @@ const layerList = [ type: 'DYNAMIC', options: { field: { - label: 'Count', name: 'doc_count', origin: 'source', }, @@ -145,7 +142,6 @@ const layerList = [ type: 'DYNAMIC', options: { field: { - label: 'avg of FlightTimeMin', name: 'avg_of_FlightTimeMin', origin: 'source', }, @@ -190,7 +186,6 @@ const layerList = [ type: 'DYNAMIC', options: { field: { - label: 'Count', name: 'doc_count', origin: 'source', }, @@ -213,7 +208,6 @@ const layerList = [ type: 'DYNAMIC', options: { field: { - label: 'avg of FlightDelayMin', name: 'avg_of_FlightDelayMin', origin: 'source', }, diff --git a/x-pack/legacy/plugins/maps/server/sample_data/web_logs_saved_objects.js b/x-pack/legacy/plugins/maps/server/sample_data/web_logs_saved_objects.js index 74039b11db727..ec445567de21c 100644 --- a/x-pack/legacy/plugins/maps/server/sample_data/web_logs_saved_objects.js +++ b/x-pack/legacy/plugins/maps/server/sample_data/web_logs_saved_objects.js @@ -39,7 +39,6 @@ const layerList = [ type: 'DYNAMIC', options: { field: { - label: 'count of kibana_sample_data_logs:geo.src', name: '__kbnjoin__count_groupby_kibana_sample_data_logs.geo.src', origin: 'join', }, @@ -135,7 +134,6 @@ const layerList = [ type: 'DYNAMIC', options: { field: { - label: 'bytes', name: 'bytes', origin: 'source', }, @@ -179,7 +177,6 @@ const layerList = [ type: 'DYNAMIC', options: { field: { - label: 'Count', name: 'doc_count', origin: 'source', }, @@ -202,14 +199,33 @@ const layerList = [ type: 'DYNAMIC', options: { field: { - label: 'sum of bytes', name: 'sum_of_bytes', origin: 'source', }, - minSize: 1, + minSize: 7, maxSize: 25, }, }, + labelText: { + type: 'DYNAMIC', + options: { + field: { + name: 'doc_count', + origin: 'source', + }, + }, + }, + labelSize: { + type: 'DYNAMIC', + options: { + field: { + name: 'doc_count', + origin: 'source', + }, + minSize: 12, + maxSize: 24, + }, + }, }, }, type: 'VECTOR', From 8e64360212897aa3700612962a8e32edeb218eaf Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Tue, 14 Jan 2020 11:14:20 -0500 Subject: [PATCH 101/139] avoid react issue --- .../layers/styles/vector/components/color/color_map_select.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js index 62b3ea0c3fcd6..0349dbe3b92de 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/color_map_select.js @@ -15,7 +15,7 @@ const CUSTOM_COLOR_MAP = 'CUSTOM_COLOR_MAP'; export class ColorMapSelect extends Component { state = { - selected: null, + selected: '', }; static getDerivedStateFromProps(nextProps, prevState) { From 94dec923271cc08e37fdb4cd1e69f21848d86f61 Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Tue, 14 Jan 2020 11:22:33 -0500 Subject: [PATCH 102/139] deal with sparsity --- .../vector/properties/dynamic_style_property.js | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js index c4e909710e3d8..662b14c06743e 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js @@ -134,10 +134,13 @@ export class DynamicStyleProperty extends AbstractStyleProperty { for (let i = 0; i < features.length; i++) { const feature = features[i]; const term = feature.properties[fieldName]; - if (counts.has(term)) { - counts.set(term, counts.get(term) + 1); - } else { - counts.set(term, 1); + //properties object may be sparse, so need to check if the field is effectively present + if (typeof term !== undefined) { + if (counts.has(term)) { + counts.set(term, counts.get(term) + 1); + } else { + counts.set(term, 1); + } } } From 569b1f66064144763e6cf1e5fa2cb46eeecd5071 Mon Sep 17 00:00:00 2001 From: Garrett Spong Date: Tue, 14 Jan 2020 09:25:07 -0700 Subject: [PATCH 103/139] [SIEM] Use import/export API instead of client implementation (#54680) ## Summary This PR switches the Rule Import / Export functionality away from the client-side implementation (that was leveraging the create/read Rule API) to the new explicit `/rules/_import` & `/rules/_export` API introduced in https://github.com/elastic/kibana/pull/54332. Note: This PR also disables the ability to export `immutable` rules. ![image](https://user-images.githubusercontent.com/2946766/72311962-c0963680-3643-11ea-812f-237bc51be7dc.png) Sample error message: Screen Shot 2020-01-13 at 20 22 45 ### Checklist Use ~~strikethroughs~~ to remove checklist items you don't feel are applicable to this PR. - [X] This was checked for cross-browser compatibility, [including a check against IE11](https://github.com/elastic/kibana/blob/master/CONTRIBUTING.md#cross-browser-compatibility) - [X] Any text added follows [EUI's writing guidelines](https://elastic.github.io/eui/#/guidelines/writing), uses sentence case text and includes [i18n support](https://github.com/elastic/kibana/blob/master/packages/kbn-i18n/README.md) - [ ] ~[Documentation](https://github.com/elastic/kibana/blob/master/CONTRIBUTING.md#writing-documentation) was added for features that require explanation or tutorials~ - [X] [Unit or functional tests](https://github.com/elastic/kibana/blob/master/CONTRIBUTING.md#cross-browser-compatibility) were updated or added to match the most common scenarios - [ ] ~This was checked for [keyboard-only and screenreader accessibility](https://developer.mozilla.org/en-US/docs/Learn/Tools_and_testing/Cross_browser_testing/Accessibility#Accessibility_testing_checklist)~ ### For maintainers - [ ] ~This was checked for breaking API changes and was [labeled appropriately](https://github.com/elastic/kibana/blob/master/CONTRIBUTING.md#release-notes-process)~ - [ ] ~This includes a feature addition or change that requires a release note and was [labeled appropriately](https://github.com/elastic/kibana/blob/master/CONTRIBUTING.md#release-notes-process)~ --- .../siem/public/components/toasters/index.tsx | 28 ++++- .../containers/detection_engine/rules/api.ts | 79 +++++++++++++ .../detection_engine/rules/types.ts | 27 +++++ .../rules/all/batch_actions.tsx | 2 +- .../detection_engine/rules/all/columns.tsx | 1 + .../detection_engine/rules/all/index.tsx | 6 +- .../detection_engine/rules/all/reducer.ts | 6 +- .../__snapshots__/index.test.tsx.snap | 7 +- .../components/import_rule_modal/index.tsx | 105 ++++++++---------- .../import_rule_modal/translations.ts | 13 ++- .../__snapshots__/index.test.tsx.snap | 3 - .../components/json_downloader/index.test.tsx | 60 ---------- .../components/json_downloader/index.tsx | 75 ------------- .../__snapshots__/index.test.tsx.snap | 3 + .../components/rule_downloader/index.test.tsx | 18 +++ .../components/rule_downloader/index.tsx | 89 +++++++++++++++ .../rule_downloader/translations.ts | 14 +++ .../detection_engine/rules/translations.ts | 2 +- 18 files changed, 325 insertions(+), 213 deletions(-) delete mode 100644 x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/json_downloader/__snapshots__/index.test.tsx.snap delete mode 100644 x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/json_downloader/index.test.tsx delete mode 100644 x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/json_downloader/index.tsx create mode 100644 x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/rule_downloader/__snapshots__/index.test.tsx.snap create mode 100644 x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/rule_downloader/index.test.tsx create mode 100644 x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/rule_downloader/index.tsx create mode 100644 x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/rule_downloader/translations.ts diff --git a/x-pack/legacy/plugins/siem/public/components/toasters/index.tsx b/x-pack/legacy/plugins/siem/public/components/toasters/index.tsx index b046c91dcd912..6d13bbd778f53 100644 --- a/x-pack/legacy/plugins/siem/public/components/toasters/index.tsx +++ b/x-pack/legacy/plugins/siem/public/components/toasters/index.tsx @@ -4,9 +4,9 @@ * you may not use this file except in compliance with the Elastic License. */ -import { EuiGlobalToastList, EuiGlobalToastListToast as Toast, EuiButton } from '@elastic/eui'; +import { EuiButton, EuiGlobalToastList, EuiGlobalToastListToast as Toast } from '@elastic/eui'; import { noop } from 'lodash/fp'; -import React, { createContext, Dispatch, useReducer, useContext, useState } from 'react'; +import React, { createContext, Dispatch, useContext, useReducer, useState } from 'react'; import styled from 'styled-components'; import uuid from 'uuid'; @@ -143,7 +143,7 @@ export const displayErrorToast = ( errorTitle: string, errorMessages: string[], dispatchToaster: React.Dispatch -) => { +): void => { const toast: AppToast = { id: uuid.v4(), title: errorTitle, @@ -156,3 +156,25 @@ export const displayErrorToast = ( toast, }); }; + +/** + * Displays a success toast for the provided title and message + * + * @param title success message to display in toaster and modal + * @param dispatchToaster provided by useStateToaster() + */ +export const displaySuccessToast = ( + title: string, + dispatchToaster: React.Dispatch +): void => { + const toast: AppToast = { + id: uuid.v4(), + title, + color: 'success', + iconType: 'check', + }; + dispatchToaster({ + type: 'addToaster', + toast, + }); +}; diff --git a/x-pack/legacy/plugins/siem/public/containers/detection_engine/rules/api.ts b/x-pack/legacy/plugins/siem/public/containers/detection_engine/rules/api.ts index 8f8b66ae35a3b..a13d6b75af630 100644 --- a/x-pack/legacy/plugins/siem/public/containers/detection_engine/rules/api.ts +++ b/x-pack/legacy/plugins/siem/public/containers/detection_engine/rules/api.ts @@ -16,13 +16,17 @@ import { Rule, FetchRuleProps, BasicFetchProps, + ImportRulesProps, + ExportRulesProps, RuleError, + ImportRulesResponse, } from './types'; import { throwIfNotOk } from '../../../hooks/api/api'; import { DETECTION_ENGINE_RULES_URL, DETECTION_ENGINE_PREPACKAGED_URL, } from '../../../../common/constants'; +import * as i18n from '../../../pages/detection_engine/rules/translations'; /** * Add provided Rule @@ -223,3 +227,78 @@ export const createPrepackagedRules = async ({ signal }: BasicFetchProps): Promi await throwIfNotOk(response); return true; }; + +/** + * Imports rules in the same format as exported via the _export API + * + * @param fileToImport File to upload containing rules to import + * @param overwrite whether or not to overwrite rules with the same ruleId + * @param signal AbortSignal for cancelling request + * + * @throws An error if response is not OK + */ +export const importRules = async ({ + fileToImport, + overwrite = false, + signal, +}: ImportRulesProps): Promise => { + const formData = new FormData(); + formData.append('file', fileToImport); + + const response = await fetch( + `${chrome.getBasePath()}${DETECTION_ENGINE_RULES_URL}/_import?overwrite=${overwrite}`, + { + method: 'POST', + credentials: 'same-origin', + headers: { + 'kbn-xsrf': 'true', + }, + body: formData, + signal, + } + ); + + await throwIfNotOk(response); + return response.json(); +}; + +/** + * Export rules from the server as a file download + * + * @param excludeExportDetails whether or not to exclude additional details at bottom of exported file (defaults to false) + * @param filename of exported rules. Be sure to include `.ndjson` extension! (defaults to localized `rules_export.ndjson`) + * @param ruleIds array of rule_id's (not id!) to export (empty array exports _all_ rules) + * @param signal AbortSignal for cancelling request + * + * @throws An error if response is not OK + */ +export const exportRules = async ({ + excludeExportDetails = false, + filename = `${i18n.EXPORT_FILENAME}.ndjson`, + ruleIds = [], + signal, +}: ExportRulesProps): Promise => { + const body = + ruleIds.length > 0 + ? JSON.stringify({ objects: ruleIds.map(rule => ({ rule_id: rule })) }) + : undefined; + + const response = await fetch( + `${chrome.getBasePath()}${DETECTION_ENGINE_RULES_URL}/_export?exclude_export_details=${excludeExportDetails}&file_name=${encodeURIComponent( + filename + )}`, + { + method: 'POST', + credentials: 'same-origin', + headers: { + 'content-type': 'application/json', + 'kbn-xsrf': 'true', + }, + body, + signal, + } + ); + + await throwIfNotOk(response); + return response.blob(); +}; diff --git a/x-pack/legacy/plugins/siem/public/containers/detection_engine/rules/types.ts b/x-pack/legacy/plugins/siem/public/containers/detection_engine/rules/types.ts index 147b04567f6c7..7714779edf057 100644 --- a/x-pack/legacy/plugins/siem/public/containers/detection_engine/rules/types.ts +++ b/x-pack/legacy/plugins/siem/public/containers/detection_engine/rules/types.ts @@ -148,3 +148,30 @@ export interface DuplicateRulesProps { export interface BasicFetchProps { signal: AbortSignal; } + +export interface ImportRulesProps { + fileToImport: File; + overwrite?: boolean; + signal: AbortSignal; +} + +export interface ImportRulesResponseError { + rule_id: string; + error: { + status_code: number; + message: string; + }; +} + +export interface ImportRulesResponse { + success: boolean; + success_count: number; + errors: ImportRulesResponseError[]; +} + +export interface ExportRulesProps { + ruleIds?: string[]; + filename?: string; + excludeExportDetails?: boolean; + signal: AbortSignal; +} diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/batch_actions.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/batch_actions.tsx index 3356ef101677d..0971ef0149304 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/batch_actions.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/batch_actions.tsx @@ -51,7 +51,7 @@ export const getBatchItems = ( { closePopover(); await exportRulesAction( diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/columns.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/columns.tsx index 0c1804f26ecdd..ed5dc6913151a 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/columns.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/columns.tsx @@ -64,6 +64,7 @@ const getActions = ( icon: 'exportAction', name: i18n.EXPORT_RULE, onClick: (rowItem: TableData) => exportRulesAction([rowItem.sourceRule], dispatch), + enabled: (rowItem: TableData) => !rowItem.immutable, }, { description: i18n.DELETE_RULE, diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/index.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/index.tsx index 819b513ecc9bc..cb4ffa127781d 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/index.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/index.tsx @@ -31,7 +31,7 @@ import { getBatchItems } from './batch_actions'; import { EuiBasicTableOnChange, TableData } from '../types'; import { allRulesReducer, State } from './reducer'; import * as i18n from '../translations'; -import { JSONDownloader } from '../components/json_downloader'; +import { RuleDownloader } from '../components/rule_downloader'; import { useStateToaster } from '../../../../components/toasters'; const initialState: State = { @@ -150,9 +150,9 @@ export const AllRules = React.memo<{ return ( <> - { dispatchToaster({ type: 'addToaster', diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/reducer.ts b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/reducer.ts index 4a6be1a7e4da7..22d6ca2195fe6 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/reducer.ts +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/all/reducer.ts @@ -20,7 +20,7 @@ export interface State { filterOptions: FilterOptions; refreshToggle: boolean; tableData: TableData[]; - exportPayload?: object[]; + exportPayload?: Rule[]; } export type Action = @@ -28,7 +28,7 @@ export type Action = | { type: 'loading'; isLoading: boolean } | { type: 'deleteRules'; rules: Rule[] } | { type: 'duplicate'; rule: Rule } - | { type: 'setExportPayload'; exportPayload?: object[] } + | { type: 'setExportPayload'; exportPayload?: Rule[] } | { type: 'setSelected'; selectedItems: TableData[] } | { type: 'updateLoading'; ids: string[]; isLoading: boolean } | { type: 'updateRules'; rules: Rule[]; appendRuleId?: string; pagination?: PaginationOptions } @@ -143,7 +143,7 @@ export const allRulesReducer = (state: State, action: Action): State => { case 'setExportPayload': { return { ...state, - exportPayload: action.exportPayload, + exportPayload: [...(action.exportPayload ?? [])], }; } default: diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/import_rule_modal/__snapshots__/index.test.tsx.snap b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/import_rule_modal/__snapshots__/index.test.tsx.snap index 6b0aa02d4edfa..64b88912e53a3 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/import_rule_modal/__snapshots__/index.test.tsx.snap +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/import_rule_modal/__snapshots__/index.test.tsx.snap @@ -28,9 +28,8 @@ exports[`ImportRuleModal renders correctly against snapshot 1`] = ` display="large" fullWidth={true} id="rule-file-picker" - initialPromptText="Select or drag and drop files" + initialPromptText="Select or drag and drop a valid rules_export.ndjson file" isLoading={false} - multiple={true} onChange={[Function]} /> diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/import_rule_modal/index.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/import_rule_modal/index.tsx index 75be92f2fe846..91b2ee283609f 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/import_rule_modal/index.tsx +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/import_rule_modal/index.tsx @@ -8,28 +8,25 @@ import { EuiButton, EuiButtonEmpty, EuiCheckbox, + // @ts-ignore no-exported-member + EuiFilePicker, EuiModal, EuiModalBody, EuiModalFooter, EuiModalHeader, EuiModalHeaderTitle, EuiOverlayMask, - // @ts-ignore no-exported-member - EuiFilePicker, EuiSpacer, EuiText, } from '@elastic/eui'; -import { noop } from 'lodash/fp'; import React, { useCallback, useState } from 'react'; -import { failure } from 'io-ts/lib/PathReporter'; -import { identity } from 'fp-ts/lib/function'; -import { pipe } from 'fp-ts/lib/pipeable'; -import { fold } from 'fp-ts/lib/Either'; -import uuid from 'uuid'; - -import { duplicateRules, RulesSchema } from '../../../../../containers/detection_engine/rules'; -import { useStateToaster } from '../../../../../components/toasters'; -import { ndjsonToJSON } from '../json_downloader'; + +import { importRules } from '../../../../../containers/detection_engine/rules'; +import { + displayErrorToast, + displaySuccessToast, + useStateToaster, +} from '../../../../../components/toasters'; import * as i18n from './translations'; interface ImportRuleModalProps { @@ -40,10 +37,6 @@ interface ImportRuleModalProps { /** * Modal component for importing Rules from a json file - * - * @param filename name of file to be downloaded - * @param payload JSON string to write to file - * */ export const ImportRuleModalComponent = ({ showModal, @@ -52,6 +45,7 @@ export const ImportRuleModalComponent = ({ }: ImportRuleModalProps) => { const [selectedFiles, setSelectedFiles] = useState(null); const [isImporting, setIsImporting] = useState(false); + const [overwrite, setOverwrite] = useState(false); const [, dispatchToaster] = useStateToaster(); const cleanupAndCloseModal = () => { @@ -60,49 +54,41 @@ export const ImportRuleModalComponent = ({ closeModal(); }; - const importRules = useCallback(async () => { + const importRulesCallback = useCallback(async () => { if (selectedFiles != null) { setIsImporting(true); - const reader = new FileReader(); - reader.onload = async event => { - // @ts-ignore type is string, not ArrayBuffer as FileReader.readAsText is called - const importedRules = ndjsonToJSON(event?.target?.result ?? ''); - - const decodedRules = pipe( - RulesSchema.decode(importedRules), - fold(errors => { - cleanupAndCloseModal(); - dispatchToaster({ - type: 'addToaster', - toast: { - id: uuid.v4(), - title: i18n.IMPORT_FAILED, - color: 'danger', - iconType: 'alert', - errors: failure(errors), - }, - }); - throw new Error(failure(errors).join('\n')); - }, identity) - ); - - const duplicatedRules = await duplicateRules({ rules: decodedRules }); - importComplete(); - cleanupAndCloseModal(); + const abortCtrl = new AbortController(); - dispatchToaster({ - type: 'addToaster', - toast: { - id: uuid.v4(), - title: i18n.SUCCESSFULLY_IMPORTED_RULES(duplicatedRules.length), - color: 'success', - iconType: 'check', - }, + try { + const importResponse = await importRules({ + fileToImport: selectedFiles[0], + overwrite, + signal: abortCtrl.signal, }); - }; - Object.values(selectedFiles).map(f => reader.readAsText(f)); + + // TODO: Improve error toast details for better debugging failed imports + // e.g. When success == true && success_count === 0 that means no rules were overwritten, etc + if (importResponse.success) { + displaySuccessToast( + i18n.SUCCESSFULLY_IMPORTED_RULES(importResponse.success_count), + dispatchToaster + ); + } + if (importResponse.errors.length > 0) { + const formattedErrors = importResponse.errors.map(e => + i18n.IMPORT_FAILED_DETAILED(e.rule_id, e.error.status_code, e.error.message) + ); + displayErrorToast(i18n.IMPORT_FAILED, formattedErrors, dispatchToaster); + } + + importComplete(); + cleanupAndCloseModal(); + } catch (e) { + cleanupAndCloseModal(); + displayErrorToast(i18n.IMPORT_FAILED, [e.message], dispatchToaster); + } } - }, [selectedFiles]); + }, [selectedFiles, overwrite]); return ( <> @@ -121,7 +107,6 @@ export const ImportRuleModalComponent = ({ { setSelectedFiles(Object.keys(files).length > 0 ? files : null); @@ -134,14 +119,18 @@ export const ImportRuleModalComponent = ({ noop} + checked={overwrite} + onChange={() => setOverwrite(!overwrite)} /> {i18n.CANCEL_BUTTON} - + {i18n.IMPORT_RULE} diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/import_rule_modal/translations.ts b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/import_rule_modal/translations.ts index 50c3c75b6109f..dab1c9490591f 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/import_rule_modal/translations.ts +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/import_rule_modal/translations.ts @@ -23,14 +23,14 @@ export const SELECT_RULE = i18n.translate( export const INITIAL_PROMPT_TEXT = i18n.translate( 'xpack.siem.detectionEngine.components.importRuleModal.initialPromptTextDescription', { - defaultMessage: 'Select or drag and drop files', + defaultMessage: 'Select or drag and drop a valid rules_export.ndjson file', } ); export const OVERWRITE_WITH_SAME_NAME = i18n.translate( 'xpack.siem.detectionEngine.components.importRuleModal.overwriteDescription', { - defaultMessage: 'Automatically overwrite saved objects with the same name', + defaultMessage: 'Automatically overwrite saved objects with the same rule ID', } ); @@ -57,3 +57,12 @@ export const IMPORT_FAILED = i18n.translate( defaultMessage: 'Failed to import rules', } ); + +export const IMPORT_FAILED_DETAILED = (ruleId: string, statusCode: number, message: string) => + i18n.translate( + 'xpack.siem.detectionEngine.components.importRuleModal.importFailedDetailedTitle', + { + values: { ruleId, statusCode, message }, + defaultMessage: 'Rule ID: {ruleId}\n Status Code: {statusCode}\n Message: {message}', + } + ); diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/json_downloader/__snapshots__/index.test.tsx.snap b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/json_downloader/__snapshots__/index.test.tsx.snap deleted file mode 100644 index c4377c265c2c2..0000000000000 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/json_downloader/__snapshots__/index.test.tsx.snap +++ /dev/null @@ -1,3 +0,0 @@ -// Jest Snapshot v1, https://goo.gl/fbAQLP - -exports[`JSONDownloader renders correctly against snapshot 1`] = ``; diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/json_downloader/index.test.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/json_downloader/index.test.tsx deleted file mode 100644 index 859918cdc8e60..0000000000000 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/json_downloader/index.test.tsx +++ /dev/null @@ -1,60 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -import { shallow } from 'enzyme'; -import React from 'react'; -import { JSONDownloaderComponent, jsonToNDJSON, ndjsonToJSON } from './index'; - -const jsonArray = [ - { - description: 'Detecting root and admin users1', - created_by: 'elastic', - false_positives: [], - index: ['auditbeat-*', 'filebeat-*', 'packetbeat-*', 'winlogbeat-*'], - max_signals: 100, - }, - { - description: 'Detecting root and admin users2', - created_by: 'elastic', - false_positives: [], - index: ['auditbeat-*', 'packetbeat-*', 'winlogbeat-*'], - max_signals: 101, - }, -]; - -const ndjson = `{"description":"Detecting root and admin users1","created_by":"elastic","false_positives":[],"index":["auditbeat-*","filebeat-*","packetbeat-*","winlogbeat-*"],"max_signals":100} -{"description":"Detecting root and admin users2","created_by":"elastic","false_positives":[],"index":["auditbeat-*","packetbeat-*","winlogbeat-*"],"max_signals":101}`; - -const ndjsonSorted = `{"created_by":"elastic","description":"Detecting root and admin users1","false_positives":[],"index":["auditbeat-*","filebeat-*","packetbeat-*","winlogbeat-*"],"max_signals":100} -{"created_by":"elastic","description":"Detecting root and admin users2","false_positives":[],"index":["auditbeat-*","packetbeat-*","winlogbeat-*"],"max_signals":101}`; - -describe('JSONDownloader', () => { - test('renders correctly against snapshot', () => { - const wrapper = shallow( - - ); - expect(wrapper).toMatchSnapshot(); - }); - - describe('jsonToNDJSON', () => { - test('converts to NDJSON', () => { - const output = jsonToNDJSON(jsonArray, false); - expect(output).toEqual(ndjson); - }); - - test('converts to NDJSON with keys sorted', () => { - const output = jsonToNDJSON(jsonArray); - expect(output).toEqual(ndjsonSorted); - }); - }); - - describe('ndjsonToJSON', () => { - test('converts to JSON', () => { - const output = ndjsonToJSON(ndjson); - expect(output).toEqual(jsonArray); - }); - }); -}); diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/json_downloader/index.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/json_downloader/index.tsx deleted file mode 100644 index 2810e0b5e1680..0000000000000 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/json_downloader/index.tsx +++ /dev/null @@ -1,75 +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; - * you may not use this file except in compliance with the Elastic License. - */ - -import React, { useEffect, useRef } from 'react'; -import styled from 'styled-components'; - -const InvisibleAnchor = styled.a` - display: none; -`; - -export interface JSONDownloaderProps { - filename: string; - payload?: object[]; - onExportComplete: (exportCount: number) => void; -} - -/** - * Component for downloading JSON as a file. Download will occur on each update to `payload` param - * - * @param filename name of file to be downloaded - * @param payload JSON string to write to file - * - */ -export const JSONDownloaderComponent = ({ - filename, - payload, - onExportComplete, -}: JSONDownloaderProps) => { - const anchorRef = useRef(null); - - useEffect(() => { - if (anchorRef && anchorRef.current && payload != null) { - const blob = new Blob([jsonToNDJSON(payload)], { type: 'application/json' }); - // @ts-ignore function is not always defined -- this is for supporting IE - if (window.navigator.msSaveOrOpenBlob) { - window.navigator.msSaveBlob(blob); - } else { - const objectURL = window.URL.createObjectURL(blob); - anchorRef.current.href = objectURL; - anchorRef.current.download = filename; - anchorRef.current.click(); - window.URL.revokeObjectURL(objectURL); - } - onExportComplete(payload.length); - } - }, [payload]); - - return ; -}; - -JSONDownloaderComponent.displayName = 'JSONDownloaderComponent'; - -export const JSONDownloader = React.memo(JSONDownloaderComponent); - -JSONDownloader.displayName = 'JSONDownloader'; - -export const jsonToNDJSON = (jsonArray: object[], sortKeys = true): string => { - return jsonArray - .map(j => JSON.stringify(j, sortKeys ? Object.keys(j).sort() : null, 0)) - .join('\n'); -}; - -export const ndjsonToJSON = (ndjson: string): object[] => { - const jsonLines = ndjson.split(/\r?\n/); - return jsonLines.reduce((acc, line) => { - try { - return [...acc, JSON.parse(line)]; - } catch (e) { - return acc; - } - }, []); -}; diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/rule_downloader/__snapshots__/index.test.tsx.snap b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/rule_downloader/__snapshots__/index.test.tsx.snap new file mode 100644 index 0000000000000..4259b68bf14a2 --- /dev/null +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/rule_downloader/__snapshots__/index.test.tsx.snap @@ -0,0 +1,3 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`RuleDownloader renders correctly against snapshot 1`] = ``; diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/rule_downloader/index.test.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/rule_downloader/index.test.tsx new file mode 100644 index 0000000000000..6306260dfc872 --- /dev/null +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/rule_downloader/index.test.tsx @@ -0,0 +1,18 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { shallow } from 'enzyme'; +import React from 'react'; +import { RuleDownloaderComponent } from './index'; + +describe('RuleDownloader', () => { + test('renders correctly against snapshot', () => { + const wrapper = shallow( + + ); + expect(wrapper).toMatchSnapshot(); + }); +}); diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/rule_downloader/index.tsx b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/rule_downloader/index.tsx new file mode 100644 index 0000000000000..b41265adea6b1 --- /dev/null +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/rule_downloader/index.tsx @@ -0,0 +1,89 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import React, { useEffect, useRef } from 'react'; +import styled from 'styled-components'; +import { isFunction } from 'lodash/fp'; +import { exportRules, Rule } from '../../../../../containers/detection_engine/rules'; +import { displayErrorToast, useStateToaster } from '../../../../../components/toasters'; +import * as i18n from './translations'; + +const InvisibleAnchor = styled.a` + display: none; +`; + +export interface RuleDownloaderProps { + filename: string; + rules?: Rule[]; + onExportComplete: (exportCount: number) => void; +} + +/** + * Component for downloading Rules as an exported .ndjson file. Download will occur on each update to `rules` param + * + * @param filename of file to be downloaded + * @param payload Rule[] + * + */ +export const RuleDownloaderComponent = ({ + filename, + rules, + onExportComplete, +}: RuleDownloaderProps) => { + const anchorRef = useRef(null); + const [, dispatchToaster] = useStateToaster(); + + useEffect(() => { + let isSubscribed = true; + const abortCtrl = new AbortController(); + + async function exportData() { + if (anchorRef && anchorRef.current && rules != null) { + try { + const exportResponse = await exportRules({ + ruleIds: rules.map(r => r.rule_id), + signal: abortCtrl.signal, + }); + + if (isSubscribed) { + // this is for supporting IE + if (isFunction(window.navigator.msSaveOrOpenBlob)) { + window.navigator.msSaveBlob(exportResponse); + } else { + const objectURL = window.URL.createObjectURL(exportResponse); + // These are safe-assignments as writes to anchorRef are isolated to exportData + anchorRef.current.href = objectURL; // eslint-disable-line require-atomic-updates + anchorRef.current.download = filename; // eslint-disable-line require-atomic-updates + anchorRef.current.click(); + window.URL.revokeObjectURL(objectURL); + } + + onExportComplete(rules.length); + } + } catch (error) { + if (isSubscribed) { + displayErrorToast(i18n.EXPORT_FAILURE, [error.message], dispatchToaster); + } + } + } + } + + exportData(); + + return () => { + isSubscribed = false; + abortCtrl.abort(); + }; + }, [rules]); + + return ; +}; + +RuleDownloaderComponent.displayName = 'RuleDownloaderComponent'; + +export const RuleDownloader = React.memo(RuleDownloaderComponent); + +RuleDownloader.displayName = 'RuleDownloader'; diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/rule_downloader/translations.ts b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/rule_downloader/translations.ts new file mode 100644 index 0000000000000..72efefa1c461b --- /dev/null +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/components/rule_downloader/translations.ts @@ -0,0 +1,14 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { i18n } from '@kbn/i18n'; + +export const EXPORT_FAILURE = i18n.translate( + 'xpack.siem.detectionEngine.rules.components.ruleDownloader.exportFailureTitle', + { + defaultMessage: 'Failed to export rules…', + } +); diff --git a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/translations.ts b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/translations.ts index d55e08e9ecd73..1e47d1a57facc 100644 --- a/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/translations.ts +++ b/x-pack/legacy/plugins/siem/public/pages/detection_engine/rules/translations.ts @@ -123,7 +123,7 @@ export const SUCCESSFULLY_EXPORTED_RULES = (totalRules: number) => i18n.translate('xpack.siem.detectionEngine.rules.allRules.successfullyExportedRulesTitle', { values: { totalRules }, defaultMessage: - 'Successfully exported {totalRules} {totalRules, plural, =1 {rule} other {rules}}', + 'Successfully exported {totalRules, plural, =0 {all rules} =1 {{totalRules} rule} other {{totalRules} rules}}', }); export const ALL_RULES = i18n.translate('xpack.siem.detectionEngine.rules.allRules.tableTitle', { From ea82503f491bac8ff636eae7d8924ed7f182b198 Mon Sep 17 00:00:00 2001 From: Joe Portner <5295965+jportner@users.noreply.github.com> Date: Tue, 14 Jan 2020 11:38:14 -0500 Subject: [PATCH 104/139] Clarify the section on TLS for "Securing the reporting endpoints" (#54741) --- docs/user/security/reporting.asciidoc | 40 +++++++++++++++++---------- 1 file changed, 25 insertions(+), 15 deletions(-) diff --git a/docs/user/security/reporting.asciidoc b/docs/user/security/reporting.asciidoc index c2ed295e83ce9..5f5d85fe8d3be 100644 --- a/docs/user/security/reporting.asciidoc +++ b/docs/user/security/reporting.asciidoc @@ -125,23 +125,33 @@ the {reporting} endpoints to authorized users. This requires that you: . Enable {security} on your {es} cluster. For more information, see {ref}/security-getting-started.html[Getting Started with Security]. -. Configure an SSL certificate for Kibana. For more information, see -<>. -. Configure {watcher} to trust the Kibana server's certificate by adding it to -the {watcher} truststore on each node: -.. Import the {kib} server certificate into the {watcher} truststore using -Java Keytool: +. Configure TLS/SSL encryption for the {kib} server. For more information, see +<>. +. Specify the {kib} server's CA certificate chain in `elasticsearch.yml`: + -[source,shell] ---------------------------------------------------------- -keytool -importcert -keystore watcher-truststore.jks -file server.crt ---------------------------------------------------------- -+ -NOTE: If the truststore doesn't already exist, it is created. +-- +If you are using your own CA to sign the {kib} server certificate, then you need +to specify the CA certificate chain in {es} to properly establish trust in TLS +connections between {watcher} and {kib}. If your CA certificate chain is +contained in a PKCS #12 trust store, specify it like so: + +[source,yaml] +-------------------------------------------------------------------------------- +xpack.http.ssl.truststore.path: "/path/to/your/truststore.p12" +xpack.http.ssl.truststore.type: "PKCS12" +xpack.http.ssl.truststore.password: "optional decryption password" +-------------------------------------------------------------------------------- + +Otherwise, if your CA certificate chain is in PEM format, specify it like so: + +[source,yaml] +-------------------------------------------------------------------------------- +xpack.http.ssl.certificate_authorities: ["/path/to/your/cacert1.pem", "/path/to/your/cacert2.pem"] +-------------------------------------------------------------------------------- + +For more information, see {ref}/notification-settings.html#ssl-notification-settings[the {watcher} HTTP TLS/SSL Settings]. +-- -.. Make sure the `xpack.http.ssl.truststore.path` setting in -`elasticsearch.yml` specifies the location of the {watcher} -truststore. . Add one or more users who have the permissions necessary to use {kib} and {reporting}. For more information, see <>. From 64d0496bf0fbacf16b59590d5e5958f838857200 Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Tue, 14 Jan 2020 11:40:25 -0500 Subject: [PATCH 105/139] remove duplication --- .../components/color/dynamic_color_form.js | 18 ------------------ .../components/size/dynamic_size_form.js | 17 ----------------- .../vector/components/style_prop_editor.js | 13 +++++++++++++ .../properties/dynamic_style_property.js | 11 +++++++++++ .../styles/vector/properties/style_property.js | 4 ++++ 5 files changed, 28 insertions(+), 35 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js index 5cfda225804ea..0c9f7b9c65d38 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/color/dynamic_color_form.js @@ -10,7 +10,6 @@ import { FieldSelect } from '../field_select'; import { ColorMapSelect } from './color_map_select'; import { EuiFlexGroup, EuiFlexItem, EuiSpacer } from '@elastic/eui'; import { CATEGORICAL_DATA_TYPES, COLOR_MAP_TYPE } from '../../../../../../common/constants'; -import { OrdinalFieldMetaOptionsPopover } from '../ordinal_field_meta_options_popover'; import { COLOR_GRADIENTS, COLOR_PALETTES_INPUTS } from '../../../color_utils'; import { i18n } from '@kbn/i18n'; @@ -51,14 +50,6 @@ export class DynamicColorForm extends React.Component { } } - _onFieldMetaOptionsChange = fieldMetaOptions => { - const options = { - ...this.props.styleProperty.getOptions(), - fieldMetaOptions, - }; - this.props.onDynamicStyleChange(this.props.styleProperty.getStyleName(), options); - }; - _getColorSelector() { const { onDynamicStyleChange, styleProperty } = this.props; const styleOptions = styleProperty.getOptions(); @@ -146,14 +137,6 @@ export class DynamicColorForm extends React.Component { const colorSelect = this._getColorSelector(); - const fieldMetaOptionsPopover = - this.state.colorMapType === COLOR_MAP_TYPE.ORDINAL && styleProperty.supportsFieldMeta() ? ( - - ) : null; - return ( @@ -169,7 +152,6 @@ export class DynamicColorForm extends React.Component { {colorSelect} - {fieldMetaOptionsPopover} ); } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/size/dynamic_size_form.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/size/dynamic_size_form.js index 2f3a80684b3b1..8b069cd53b731 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/size/dynamic_size_form.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/size/dynamic_size_form.js @@ -9,7 +9,6 @@ import React, { Fragment } from 'react'; import { FieldSelect } from '../field_select'; import { SizeRangeSelector } from './size_range_selector'; import { EuiFlexGroup, EuiFlexItem, EuiSpacer } from '@elastic/eui'; -import { OrdinalFieldMetaOptionsPopover } from '../ordinal_field_meta_options_popover'; export function DynamicSizeForm({ fields, @@ -23,14 +22,6 @@ export function DynamicSizeForm({ onDynamicStyleChange(styleProperty.getStyleName(), { ...styleOptions, field }); }; - const onFieldMetaOptionsChange = fieldMetaOptions => { - const options = { - ...styleProperty.getOptions(), - fieldMetaOptions, - }; - onDynamicStyleChange(styleProperty.getStyleName(), options); - }; - const onSizeRangeChange = ({ minSize, maxSize }) => { onDynamicStyleChange(styleProperty.getStyleName(), { ...styleOptions, @@ -52,13 +43,6 @@ export function DynamicSizeForm({ ); } - const fieldMetaOptionsPopover = styleProperty.supportsFieldMeta() ? ( - - ) : null; - return ( @@ -74,7 +58,6 @@ export function DynamicSizeForm({ {sizeRange} - {fieldMetaOptionsPopover} ); } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/style_prop_editor.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/style_prop_editor.js index ed80e94358a10..e8b544d8ede16 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/style_prop_editor.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/components/style_prop_editor.js @@ -34,6 +34,14 @@ export class StylePropEditor extends Component { } }; + _onFieldMetaOptionsChange = fieldMetaOptions => { + const options = { + ...this.props.styleProperty.getOptions(), + fieldMetaOptions, + }; + this.props.onDynamicStyleChange(this.props.styleProperty.getStyleName(), options); + }; + renderStaticDynamicSelect() { const options = [ { @@ -71,6 +79,10 @@ export class StylePropEditor extends Component { } render() { + const fieldMetaOptionsPopover = this.props.styleProperty.renderFieldMetaPopover( + this._onFieldMetaOptionsChange + ); + return ( ); diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js index 662b14c06743e..98e87b0305b44 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_style_property.js @@ -12,6 +12,7 @@ import { scaleValue, getComputedFieldName } from '../style_util'; import React from 'react'; import { OrdinalLegend } from './components/ordinal_legend'; import { CategoricalLegend } from './components/categorical_legend'; +import { OrdinalFieldMetaOptionsPopover } from '../components/ordinal_field_meta_options_popover'; export class DynamicStyleProperty extends AbstractStyleProperty { static type = STYLE_TYPE.DYNAMIC; @@ -277,4 +278,14 @@ export class DynamicStyleProperty extends AbstractStyleProperty { return null; } } + + renderFieldMetaPopover(onFieldMetaOptionsChange) { + if (!this.isOrdinal() || !this.supportsFieldMeta()) { + return null; + } + + return ( + + ); + } } diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/style_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/style_property.js index 52e1a46a18e94..c49fe46664025 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/style_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/style_property.js @@ -45,6 +45,10 @@ export class AbstractStyleProperty { return null; } + renderFieldMetaPopover() { + return null; + } + getDisplayStyleName() { return getVectorStyleLabel(this.getStyleName()); } From b298dd4c20fa1c39e634f4d25c8d76978cd51f9e Mon Sep 17 00:00:00 2001 From: Tim Schnell Date: Tue, 14 Jan 2020 10:53:27 -0600 Subject: [PATCH 106/139] fixing color and toggle accessibility (#54661) * fixing color and toggle accessibility * updating snapshots * fixing more snapshots * fixing toggle console warning --- .../uis/arguments/palette.js | 4 ++- .../canvas_plugin_src/uis/arguments/shape.js | 1 + .../canvas_plugin_src/uis/arguments/toggle.js | 5 ++- .../legacy/plugins/canvas/i18n/components.ts | 10 +++++- .../color_palette.examples.storyshot | 36 +++++++++++++++++++ .../color_palette/color_palette.tsx | 1 + .../color_picker.examples.storyshot | 21 +++++++++++ .../color_picker_popover.examples.storyshot | 4 +++ .../color_picker_popover.examples.tsx | 4 +++ .../color_picker_popover.tsx | 10 ++++-- .../palette_picker/palette_picker.js | 4 +-- .../shape_picker_popover.tsx | 5 +-- .../text_style_picker/text_style_picker.js | 1 + .../workpad_color_picker.tsx | 11 +++++- .../expression_types/arg_types/color.js | 9 +++-- .../extended_template.examples.storyshot | 3 ++ .../simple_template.examples.storyshot | 2 ++ .../arg_types/container_style/border_form.tsx | 1 + .../container_style/simple_template.tsx | 4 +++ .../series_style/simple_template.tsx | 1 + 20 files changed, 125 insertions(+), 12 deletions(-) diff --git a/x-pack/legacy/plugins/canvas/canvas_plugin_src/uis/arguments/palette.js b/x-pack/legacy/plugins/canvas/canvas_plugin_src/uis/arguments/palette.js index 69f584af41556..d60dc13f0105b 100644 --- a/x-pack/legacy/plugins/canvas/canvas_plugin_src/uis/arguments/palette.js +++ b/x-pack/legacy/plugins/canvas/canvas_plugin_src/uis/arguments/palette.js @@ -61,7 +61,9 @@ const PaletteArgInput = ({ onValueChange, argValue, renderError }) => { const palette = astToPalette(argValue); - return ; + return ( + + ); }; PaletteArgInput.propTypes = { diff --git a/x-pack/legacy/plugins/canvas/canvas_plugin_src/uis/arguments/shape.js b/x-pack/legacy/plugins/canvas/canvas_plugin_src/uis/arguments/shape.js index c056e7d1f2281..baa2127b03c3c 100644 --- a/x-pack/legacy/plugins/canvas/canvas_plugin_src/uis/arguments/shape.js +++ b/x-pack/legacy/plugins/canvas/canvas_plugin_src/uis/arguments/shape.js @@ -20,6 +20,7 @@ const ShapeArgInput = ({ onValueChange, argValue, typeInstance }) => ( value={argValue} onChange={onValueChange} shapes={typeInstance.options.shapes} + ariaLabel={typeInstance.displayName} /> diff --git a/x-pack/legacy/plugins/canvas/canvas_plugin_src/uis/arguments/toggle.js b/x-pack/legacy/plugins/canvas/canvas_plugin_src/uis/arguments/toggle.js index de19d3e29221b..bcad4678e0b6a 100644 --- a/x-pack/legacy/plugins/canvas/canvas_plugin_src/uis/arguments/toggle.js +++ b/x-pack/legacy/plugins/canvas/canvas_plugin_src/uis/arguments/toggle.js @@ -12,7 +12,7 @@ import { ArgumentStrings } from '../../../i18n'; const { Toggle: strings } = ArgumentStrings; -const ToggleArgInput = ({ onValueChange, argValue, argId, renderError }) => { +const ToggleArgInput = ({ onValueChange, argValue, argId, renderError, typeInstance }) => { const handleChange = () => onValueChange(!argValue); if (typeof argValue !== 'boolean') { renderError(); @@ -26,6 +26,9 @@ const ToggleArgInput = ({ onValueChange, argValue, argId, renderError }) => { checked={argValue} onChange={handleChange} className="canvasArg__switch" + aria-label={typeInstance.displayName} + label="" + showLabel={false} /> ); diff --git a/x-pack/legacy/plugins/canvas/i18n/components.ts b/x-pack/legacy/plugins/canvas/i18n/components.ts index c898db7467b44..d0a9051d7af87 100644 --- a/x-pack/legacy/plugins/canvas/i18n/components.ts +++ b/x-pack/legacy/plugins/canvas/i18n/components.ts @@ -912,6 +912,10 @@ export const ComponentStrings = { i18n.translate('xpack.canvas.textStylePicker.styleUnderlineOption', { defaultMessage: 'Underline', }), + getFontColorLabel: () => + i18n.translate('xpack.canvas.textStylePicker.fontColorLabel', { + defaultMessage: 'Font Color', + }), }, TimePicker: { getApplyButtonLabel: () => @@ -1007,7 +1011,11 @@ export const ComponentStrings = { getUSLetterButtonLabel: () => i18n.translate('xpack.canvas.workpadConfig.USLetterButtonLabel', { defaultMessage: 'US Letter', - description: 'This is referring to the dimentions of U.S. standard letter paper.', + description: 'This is referring to the dimensions of U.S. standard letter paper.', + }), + getBackgroundColorLabel: () => + i18n.translate('xpack.canvas.workpadConfig.backgroundColorLabel', { + defaultMessage: 'Background color', }), }, WorkpadCreate: { diff --git a/x-pack/legacy/plugins/canvas/public/components/color_palette/__examples__/__snapshots__/color_palette.examples.storyshot b/x-pack/legacy/plugins/canvas/public/components/color_palette/__examples__/__snapshots__/color_palette.examples.storyshot index badbf96029f12..8610ed2f1b4a3 100644 --- a/x-pack/legacy/plugins/canvas/public/components/color_palette/__examples__/__snapshots__/color_palette.examples.storyshot +++ b/x-pack/legacy/plugins/canvas/public/components/color_palette/__examples__/__snapshots__/color_palette.examples.storyshot @@ -8,6 +8,7 @@ exports[`Storyshots components/Color/ColorPalette interactive 1`] = ` className="item-grid-row" > ); diff --git a/x-pack/legacy/plugins/canvas/public/components/shape_picker_popover/shape_picker_popover.tsx b/x-pack/legacy/plugins/canvas/public/components/shape_picker_popover/shape_picker_popover.tsx index 970f72da698ba..717ec6d0faecc 100644 --- a/x-pack/legacy/plugins/canvas/public/components/shape_picker_popover/shape_picker_popover.tsx +++ b/x-pack/legacy/plugins/canvas/public/components/shape_picker_popover/shape_picker_popover.tsx @@ -17,12 +17,13 @@ interface Props { }; onChange?: (key: string) => void; value?: string; + ariaLabel?: string; } -export const ShapePickerPopover = ({ shapes, onChange, value }: Props) => { +export const ShapePickerPopover = ({ shapes, onChange, value, ariaLabel }: Props) => { const button = (handleClick: (ev: MouseEvent) => void) => ( - + diff --git a/x-pack/legacy/plugins/canvas/public/components/text_style_picker/text_style_picker.js b/x-pack/legacy/plugins/canvas/public/components/text_style_picker/text_style_picker.js index 1a44181475091..179455e15b36e 100644 --- a/x-pack/legacy/plugins/canvas/public/components/text_style_picker/text_style_picker.js +++ b/x-pack/legacy/plugins/canvas/public/components/text_style_picker/text_style_picker.js @@ -127,6 +127,7 @@ export const TextStylePicker = ({ value={color} onChange={value => doChange('color', value)} colors={colors} + ariaLabel={strings.getFontColorLabel()} /> diff --git a/x-pack/legacy/plugins/canvas/public/components/workpad_color_picker/workpad_color_picker.tsx b/x-pack/legacy/plugins/canvas/public/components/workpad_color_picker/workpad_color_picker.tsx index 69401c89c79a5..c81f3e78efddd 100644 --- a/x-pack/legacy/plugins/canvas/public/components/workpad_color_picker/workpad_color_picker.tsx +++ b/x-pack/legacy/plugins/canvas/public/components/workpad_color_picker/workpad_color_picker.tsx @@ -6,9 +6,18 @@ import React from 'react'; import { ColorPickerPopover, Props } from '../color_picker_popover'; +import { ComponentStrings } from '../../../i18n'; + +const { WorkpadConfig: strings } = ComponentStrings; export const WorkpadColorPicker = (props: Props) => { - return ; + return ( + + ); }; WorkpadColorPicker.propTypes = ColorPickerPopover.propTypes; diff --git a/x-pack/legacy/plugins/canvas/public/expression_types/arg_types/color.js b/x-pack/legacy/plugins/canvas/public/expression_types/arg_types/color.js index 2a47150b4a1b9..8d756dd8111b1 100644 --- a/x-pack/legacy/plugins/canvas/public/expression_types/arg_types/color.js +++ b/x-pack/legacy/plugins/canvas/public/expression_types/arg_types/color.js @@ -13,10 +13,15 @@ import { ArgTypesStrings } from '../../../i18n'; const { Color: strings } = ArgTypesStrings; -const ColorArgInput = ({ onValueChange, argValue, workpad }) => ( +const ColorArgInput = ({ onValueChange, argValue, workpad, typeInstance }) => ( - + ); diff --git a/x-pack/legacy/plugins/canvas/public/expression_types/arg_types/container_style/__examples__/__snapshots__/extended_template.examples.storyshot b/x-pack/legacy/plugins/canvas/public/expression_types/arg_types/container_style/__examples__/__snapshots__/extended_template.examples.storyshot index 2915d3bfef57b..649d11cb2dbab 100644 --- a/x-pack/legacy/plugins/canvas/public/expression_types/arg_types/container_style/__examples__/__snapshots__/extended_template.examples.storyshot +++ b/x-pack/legacy/plugins/canvas/public/expression_types/arg_types/container_style/__examples__/__snapshots__/extended_template.examples.storyshot @@ -467,6 +467,7 @@ exports[`Storyshots arguments/ContainerStyle extended 1`] = ` className="euiPopover__anchor" >
); diff --git a/x-pack/legacy/plugins/canvas/public/expression_types/arg_types/series_style/simple_template.tsx b/x-pack/legacy/plugins/canvas/public/expression_types/arg_types/series_style/simple_template.tsx index e05c48b97f54a..ba1f4305167a4 100644 --- a/x-pack/legacy/plugins/canvas/public/expression_types/arg_types/series_style/simple_template.tsx +++ b/x-pack/legacy/plugins/canvas/public/expression_types/arg_types/series_style/simple_template.tsx @@ -76,6 +76,7 @@ export const SimpleTemplate: FunctionComponent = props => { colors={workpad.colors} onChange={val => handleChange('color', val)} value={color} + ariaLabel={strings.getColorLabel()} /> From 8c878bcaa8192f44fe783cbc481753a5d97d3fff Mon Sep 17 00:00:00 2001 From: Joe Reuter Date: Tue, 14 Jan 2020 18:02:49 +0100 Subject: [PATCH 107/139] add graph sample data (#54558) --- x-pack/plugins/graph/common/constants.ts | 11 + .../plugins/graph/server/lib/license_state.ts | 13 +- x-pack/plugins/graph/server/plugin.ts | 11 +- .../graph/server/sample_data/ecommerce.ts | 391 ++++ .../graph/server/sample_data/flights.ts | 1645 +++++++++++++++++ .../plugins/graph/server/sample_data/index.ts | 7 + .../plugins/graph/server/sample_data/logs.ts | 463 +++++ .../sample_data/register_sample_data.ts | 36 + 8 files changed, 2573 insertions(+), 4 deletions(-) create mode 100644 x-pack/plugins/graph/common/constants.ts create mode 100644 x-pack/plugins/graph/server/sample_data/ecommerce.ts create mode 100644 x-pack/plugins/graph/server/sample_data/flights.ts create mode 100644 x-pack/plugins/graph/server/sample_data/index.ts create mode 100644 x-pack/plugins/graph/server/sample_data/logs.ts create mode 100644 x-pack/plugins/graph/server/sample_data/register_sample_data.ts diff --git a/x-pack/plugins/graph/common/constants.ts b/x-pack/plugins/graph/common/constants.ts new file mode 100644 index 0000000000000..3c3ee2b125896 --- /dev/null +++ b/x-pack/plugins/graph/common/constants.ts @@ -0,0 +1,11 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export const APP_ICON = 'graphApp'; + +export function createWorkspacePath(id: string) { + return `/app/graph/#/workspace/${id}`; +} diff --git a/x-pack/plugins/graph/server/lib/license_state.ts b/x-pack/plugins/graph/server/lib/license_state.ts index 1f5744e41534d..d86cb5380a2e1 100644 --- a/x-pack/plugins/graph/server/lib/license_state.ts +++ b/x-pack/plugins/graph/server/lib/license_state.ts @@ -5,6 +5,7 @@ */ import Boom from 'boom'; +import { map } from 'rxjs/operators'; import { Observable, Subscription } from 'rxjs'; import { ILicense } from '../../../licensing/common/types'; import { checkLicense, GraphLicenseInformation } from '../../common/check_license'; @@ -12,13 +13,15 @@ import { checkLicense, GraphLicenseInformation } from '../../common/check_licens export class LicenseState { private licenseInformation: GraphLicenseInformation = checkLicense(undefined); private subscription: Subscription | null = null; + private observable: Observable | null = null; - private updateInformation(license: ILicense | undefined) { - this.licenseInformation = checkLicense(license); + private updateInformation(licenseInformation: GraphLicenseInformation) { + this.licenseInformation = licenseInformation; } public start(license$: Observable) { - this.subscription = license$.subscribe(this.updateInformation.bind(this)); + this.observable = license$.pipe(map(checkLicense)); + this.subscription = this.observable.subscribe(this.updateInformation.bind(this)); } public stop() { @@ -30,6 +33,10 @@ export class LicenseState { public getLicenseInformation() { return this.licenseInformation; } + + public getLicenseInformation$() { + return this.observable; + } } export function verifyApiAccess(licenseState: LicenseState) { diff --git a/x-pack/plugins/graph/server/plugin.ts b/x-pack/plugins/graph/server/plugin.ts index c7ada3af31b76..dcdf3f51d60bd 100644 --- a/x-pack/plugins/graph/server/plugin.ts +++ b/x-pack/plugins/graph/server/plugin.ts @@ -9,15 +9,24 @@ import { LicensingPluginSetup } from '../../licensing/server'; import { LicenseState } from './lib/license_state'; import { registerSearchRoute } from './routes/search'; import { registerExploreRoute } from './routes/explore'; +import { HomeServerPluginSetup } from '../../../../src/plugins/home/server'; +import { registerSampleData } from './sample_data'; export class GraphPlugin implements Plugin { private licenseState: LicenseState | null = null; - public async setup(core: CoreSetup, { licensing }: { licensing: LicensingPluginSetup }) { + public async setup( + core: CoreSetup, + { licensing, home }: { licensing: LicensingPluginSetup; home?: HomeServerPluginSetup } + ) { const licenseState = new LicenseState(); licenseState.start(licensing.license$); this.licenseState = licenseState; + if (home) { + registerSampleData(home.sampleData, licenseState); + } + const router = core.http.createRouter(); registerSearchRoute({ licenseState, router }); registerExploreRoute({ licenseState, router }); diff --git a/x-pack/plugins/graph/server/sample_data/ecommerce.ts b/x-pack/plugins/graph/server/sample_data/ecommerce.ts new file mode 100644 index 0000000000000..f70c7039b9b72 --- /dev/null +++ b/x-pack/plugins/graph/server/sample_data/ecommerce.ts @@ -0,0 +1,391 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { i18n } from '@kbn/i18n'; +import { SampleDataRegistrySetup } from '../../../../../src/plugins/home/server'; +import { APP_ICON, createWorkspacePath } from '../../common/constants'; + +const datasetId = 'ecommerce'; + +const wsState: any = { + selectedFields: [ + { + name: 'customer_gender', + hopSize: 5, + lastValidHopSize: 5, + color: '#7B000B', + selected: true, + iconClass: 'fa-user', + }, + { + name: 'geoip.continent_name', + hopSize: 5, + lastValidHopSize: 5, + color: '#B0916F', + selected: true, + iconClass: 'fa-map-marker', + }, + { + name: 'products.category.keyword', + hopSize: 5, + lastValidHopSize: 5, + color: '#34130C', + selected: true, + iconClass: 'fa-heart', + }, + ], + blacklist: [ + { + x: 491.3880229084531, + y: 572.375603969653, + label: 'South America', + color: '#B0916F', + field: 'geoip.continent_name', + term: 'South America', + parent: null, + size: 15, + }, + ], + vertices: [ + { + x: 458.033767981859, + y: 181.9021747060339, + label: "Women's Shoes", + color: '#34130C', + field: 'products.category.keyword', + term: "Women's Shoes", + parent: null, + size: 15, + }, + { + x: 236.16141155056786, + y: 371.69388982857515, + label: "Men's Accessories", + color: '#34130C', + field: 'products.category.keyword', + term: "Men's Accessories", + parent: null, + size: 15, + }, + { + x: 334.27149182482333, + y: 244.99855207230468, + label: "Women's Accessories", + color: '#34130C', + field: 'products.category.keyword', + term: "Women's Accessories", + parent: null, + size: 15, + }, + { + x: 452.21475063865597, + y: 330.39076195279216, + label: 'Asia', + color: '#B0916F', + field: 'geoip.continent_name', + term: 'Asia', + parent: null, + size: 15, + }, + { + x: 397.79868111013536, + y: 280.55152377990424, + label: 'Europe', + color: '#B0916F', + field: 'geoip.continent_name', + term: 'Europe', + parent: null, + size: 15, + }, + { + x: 324.72030800021247, + y: 352.6641597050945, + label: "Men's Shoes", + color: '#34130C', + field: 'products.category.keyword', + term: "Men's Shoes", + parent: null, + size: 15, + }, + { + x: 372.16854727881645, + y: 390.62646298282147, + label: "Men's Clothing", + color: '#34130C', + field: 'products.category.keyword', + term: "Men's Clothing", + parent: null, + size: 15, + }, + { + x: 508.049093768632, + y: 242.4089619805834, + label: "Women's Clothing", + color: '#34130C', + field: 'products.category.keyword', + term: "Women's Clothing", + parent: null, + size: 15, + }, + { + x: 440.1331838313072, + y: 289.96431350734645, + label: 'Africa', + color: '#B0916F', + field: 'geoip.continent_name', + term: 'Africa', + parent: null, + size: 15, + }, + { + x: 387.0908385779075, + y: 210.10263143650025, + label: 'FEMALE', + color: '#7B000B', + field: 'customer_gender', + term: 'FEMALE', + parent: null, + size: 15, + }, + { + x: 290.59483393305874, + y: 298.89363320612324, + label: 'MALE', + color: '#7B000B', + field: 'customer_gender', + term: 'MALE', + parent: null, + size: 15, + }, + { + x: 413.02719526683677, + y: 322.2286023727188, + label: 'North America', + color: '#B0916F', + field: 'geoip.continent_name', + term: 'North America', + parent: null, + size: 15, + }, + ], + links: [ + { + weight: 0.005857130017177792, + width: 8.232101279777059, + inferred: false, + source: 7, + target: 7, + }, + { weight: 0.00040740358951793883, width: 2, inferred: false, source: 2, target: 10 }, + { weight: 0.00013791546585173228, width: 2, inferred: false, source: 5, target: 1 }, + { weight: 0.0004858267848737237, width: 2, inferred: false, source: 4, target: 2 }, + { weight: 0.0010153751000293245, width: 2, inferred: false, source: 10, target: 11 }, + { weight: 0.0028264125846644674, width: 2, inferred: false, source: 2, target: 9 }, + { weight: 0.0005650580249547761, width: 2, inferred: false, source: 3, target: 0 }, + { weight: 0.0009324185728321393, width: 2, inferred: false, source: 6, target: 11 }, + { + weight: 0.0014323721292750112, + width: 2.0131758052049205, + inferred: false, + source: 4, + target: 4, + }, + { + weight: 0.002342547575207893, + width: 3.2924126381437944, + inferred: false, + source: 0, + target: 0, + }, + { weight: 0.000591872989689757, width: 2, inferred: false, source: 8, target: 5 }, + { weight: 0.0008255717897066532, width: 2, inferred: false, source: 3, target: 5 }, + { weight: 0.0006448216532672799, width: 2, inferred: false, source: 7, target: 8 }, + { weight: 0.0002511052407839208, width: 2, inferred: false, source: 8, target: 0 }, + { weight: 0.0013789044568299467, width: 2, inferred: false, source: 8, target: 10 }, + { weight: 0.000783301409144887, width: 2, inferred: false, source: 8, target: 9 }, + { + weight: 0.00560336629275442, + width: 7.875440479272377, + inferred: false, + source: 10, + target: 6, + }, + { weight: 0.0005016633048258001, width: 2, inferred: false, source: 5, target: 11 }, + { weight: 0.0003926052511049418, width: 2, inferred: false, source: 2, target: 3 }, + { weight: 0.0008115500826586831, width: 2, inferred: false, source: 8, target: 8 }, + { weight: 0.0014948001891181592, width: 2, inferred: false, source: 3, target: 9 }, + { weight: 0.000029981623011246145, width: 2, inferred: false, source: 2, target: 5 }, + { + weight: 0.002480454462292142, + width: 3.4862385321100913, + inferred: false, + source: 9, + target: 4, + }, + { weight: 0.002025814694014704, width: 2, inferred: false, source: 11, target: 7 }, + { + weight: 0.0026700604482252604, + width: 2.137643910722111, + inferred: false, + source: 3, + target: 10, + }, + { weight: 0.00010444018788598492, width: 2, inferred: false, source: 9, target: 6 }, + { + weight: 0.0024519155063363668, + width: 3.44612749220522, + inferred: false, + source: 6, + target: 3, + }, + { weight: 0.0006267747531045212, width: 2, inferred: false, source: 10, target: 1 }, + { weight: 0.00016502073678324177, width: 2, inferred: false, source: 2, target: 8 }, + { weight: 0.0005870783606720878, width: 2, inferred: false, source: 6, target: 4 }, + { weight: 0.00038852356835608306, width: 2, inferred: false, source: 6, target: 2 }, + { + weight: 0.001950556798534224, + width: 2.741475956722648, + inferred: false, + source: 5, + target: 5, + }, + { weight: 0.0005728452602402718, width: 2, inferred: false, source: 2, target: 11 }, + { + weight: 0.0068966839555125534, + width: 9.693177486223698, + inferred: false, + source: 9, + target: 9, + }, + { + weight: 0.003985530212040768, + width: 3.2924126381437944, + inferred: false, + source: 0, + target: 7, + }, + { weight: 0.0005390262876698882, width: 2, inferred: false, source: 4, target: 10 }, + { weight: 0.001230534654985059, width: 2, inferred: false, source: 3, target: 7 }, + { weight: 0.0012265720435530507, width: 2, inferred: false, source: 2, target: 2 }, + { weight: 0.00010444018788598492, width: 2, inferred: false, source: 9, target: 5 }, + { weight: 0.00246087192706352, width: 2, inferred: false, source: 11, target: 9 }, + { weight: 0.001266247444586856, width: 2, inferred: false, source: 6, target: 8 }, + { + weight: 0.0040928391377725235, + width: 5.752419052533403, + inferred: false, + source: 10, + target: 5, + }, + { + weight: 0.003998804111234147, + width: 2.741475956722648, + inferred: false, + source: 5, + target: 6, + }, + { weight: 0.0000201191575509262, width: 2, inferred: false, source: 2, target: 1 }, + { weight: 0.0019559590149107486, width: 2, inferred: false, source: 4, target: 7 }, + { + weight: 0.005399134008600699, + width: 7.588395315032752, + inferred: false, + source: 10, + target: 10, + }, + { weight: 0.0008406249972756651, width: 2, inferred: false, source: 11, target: 0 }, + { weight: 0.002434040312854235, width: 2, inferred: false, source: 2, target: 7 }, + { weight: 0.0007632277713300751, width: 2, inferred: false, source: 4, target: 0 }, + { weight: 0.007114987799732724, width: 10, inferred: false, source: 9, target: 7 }, + { weight: 0.00029149607092423423, width: 2, inferred: false, source: 4, target: 5 }, + { + weight: 0.004628005825697707, + width: 3.2924126381437944, + inferred: false, + source: 0, + target: 9, + }, + { weight: 0.0001769629690348846, width: 2, inferred: false, source: 0, target: 2 }, + { + weight: 0.0017862657198589743, + width: 2.510567509231816, + inferred: false, + source: 11, + target: 11, + }, + { + weight: 0.0023385207220538266, + width: 3.286752961321555, + inferred: false, + source: 3, + target: 3, + }, + { weight: 0.0005977285667016662, width: 2, inferred: false, source: 6, target: 1 }, + { + weight: 0.00523765988442745, + width: 7.361446051424297, + inferred: false, + source: 6, + target: 6, + }, + ], + urlTemplates: [ + { + url: + '/app/kibana#/discover?_a=(columns%3A!(_source)%2Cindex%3Aff959d40-b880-11e8-a6d9-e546fe2bba5f%2Cinterval%3Aauto%2Cquery%3A(language%3Akuery%2Cquery%3A{{gquery}})%2Csort%3A!(_score%2Cdesc))', + description: 'Raw documents', + isDefault: true, + encoderID: 'kql-loose', + }, + ], + exploreControls: { + useSignificance: false, + sampleSize: 2000, + timeoutMillis: 5000, + maxValuesPerDoc: 1, + minDocCount: 3, + }, + indexPatternRefName: 'indexPattern_0', +}; + +export function registerEcommerceSampleData(sampleDataRegistry: SampleDataRegistrySetup) { + sampleDataRegistry.addSavedObjectsToSampleDataset(datasetId, [ + { + type: 'graph-workspace', + id: '46fa9d30-319c-11ea-bbe4-818d9c786051', + version: '2', + attributes: { + title: 'Kibana Sample Data - eCommerce', + description: + 'This is a sample graph based on an eCommerce data set. It shows the gender, continent, and product category of purchases. The thicker the line is, there are more correlated documents between the vertices.', + numLinks: 57, + numVertices: 12, + version: 1, + wsState: JSON.stringify(JSON.stringify(wsState)), + }, + references: [ + { + name: 'indexPattern_0', + type: 'index-pattern', + id: 'kibana_sample_data_ecommerce', + }, + ], + migrationVersion: { + 'graph-workspace': '7.0.0', + }, + updated_at: '2020-01-09T16:40:36.122Z', + }, + ]); +} +export function registerEcommerceSampleDataLink(sampleDataRegistry: SampleDataRegistrySetup) { + sampleDataRegistry.addAppLinksToSampleDataset(datasetId, [ + { + path: createWorkspacePath('46fa9d30-319c-11ea-bbe4-818d9c786051'), + label: i18n.translate('xpack.graph.sampleData.label', { defaultMessage: 'Graph' }), + icon: APP_ICON, + }, + ]); +} diff --git a/x-pack/plugins/graph/server/sample_data/flights.ts b/x-pack/plugins/graph/server/sample_data/flights.ts new file mode 100644 index 0000000000000..3a61eb49cb5b1 --- /dev/null +++ b/x-pack/plugins/graph/server/sample_data/flights.ts @@ -0,0 +1,1645 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { i18n } from '@kbn/i18n'; +import { SampleDataRegistrySetup } from '../../../../../src/plugins/home/server'; +import { APP_ICON, createWorkspacePath } from '../../common/constants'; + +const datasetId = 'flights'; + +const wsState: any = { + selectedFields: [ + { + name: 'Carrier', + hopSize: 5, + lastValidHopSize: 5, + color: '#CE0060', + selected: true, + iconClass: 'fa-plane', + }, + { + name: 'Dest', + hopSize: 5, + lastValidHopSize: 5, + color: '#38007E', + selected: true, + iconClass: 'fa-map-marker', + }, + { + name: 'DestWeather', + hopSize: 5, + lastValidHopSize: 5, + color: '#34130C', + selected: true, + iconClass: 'fa-cube', + }, + ], + blacklist: [], + vertices: [ + { + x: 324.55695700802687, + y: 346.73294548497137, + label: 'Sydney Kingsford Smith International Airport', + color: '#38007E', + field: 'Dest', + term: 'Sydney Kingsford Smith International Airport', + parent: null, + size: 15, + }, + { + x: 438.93290232680494, + y: 677.3830617564242, + label: 'Charles de Gaulle International Airport', + color: '#38007E', + field: 'Dest', + term: 'Charles de Gaulle International Airport', + parent: null, + size: 15, + }, + { + x: 499.6180566078833, + y: -5.098830831803902, + label: 'Bologna Guglielmo Marconi Airport', + color: '#38007E', + field: 'Dest', + term: 'Bologna Guglielmo Marconi Airport', + parent: null, + size: 15, + }, + { + x: 389.5752820793805, + y: 386.37176544482463, + label: 'Rain', + color: '#34130C', + field: 'DestWeather', + term: 'Rain', + parent: null, + size: 15, + }, + { + x: 490.9417508188848, + y: 391.65617271236334, + label: 'Milano Linate Airport', + color: '#38007E', + field: 'Dest', + term: 'Milano Linate Airport', + parent: null, + size: 15, + }, + { + x: 614.188166571076, + y: 572.9459065381061, + label: 'Cloudy', + color: '#34130C', + field: 'DestWeather', + term: 'Cloudy', + parent: null, + size: 15, + }, + { + x: 330.387175680331, + y: 695.0441997424184, + label: 'Guangzhou Baiyun International Airport', + color: '#38007E', + field: 'Dest', + term: 'Guangzhou Baiyun International Airport', + parent: null, + size: 15, + }, + { + x: 379.9660844804916, + y: 638.9082566905925, + label: 'Ottawa Macdonald-Cartier International Airport', + color: '#38007E', + field: 'Dest', + term: 'Ottawa Macdonald-Cartier International Airport', + parent: null, + size: 15, + }, + { + x: 57.947780190100346, + y: 360.393931221208, + label: 'Hail', + color: '#34130C', + field: 'DestWeather', + term: 'Hail', + parent: null, + size: 15, + }, + { + x: 397.4430051185168, + y: 504.8512181744145, + label: 'Logstash Airways', + color: '#CE0060', + field: 'Carrier', + term: 'Logstash Airways', + parent: null, + size: 15, + }, + { + x: 424.42756723778075, + y: 354.33078205093506, + label: 'Sunny', + color: '#34130C', + field: 'DestWeather', + term: 'Sunny', + parent: null, + size: 15, + }, + { + x: 254.09885556506697, + y: 434.3607906063371, + label: 'Norfolk International Airport', + color: '#38007E', + field: 'Dest', + term: 'Norfolk International Airport', + parent: null, + size: 15, + }, + { + x: 568.6877204517741, + y: 340.3641831872856, + label: 'Heavy Fog', + color: '#34130C', + field: 'DestWeather', + term: 'Heavy Fog', + parent: null, + size: 15, + }, + { + x: 429.8163554957372, + y: -28.901855935511612, + label: 'Dublin Airport', + color: '#38007E', + field: 'Dest', + term: 'Dublin Airport', + parent: null, + size: 15, + }, + { + x: 420.5639687132341, + y: 247.7760184038354, + label: 'JetBeats', + color: '#CE0060', + field: 'Carrier', + term: 'JetBeats', + parent: null, + size: 15, + }, + { + x: 384.3810911831613, + y: 437.9949106467699, + label: 'Clear', + color: '#34130C', + field: 'DestWeather', + term: 'Clear', + parent: null, + size: 15, + }, + { + x: 493.9944277688558, + y: 431.38149316403536, + label: 'Kempegowda International Airport', + color: '#38007E', + field: 'Dest', + term: 'Kempegowda International Airport', + parent: null, + size: 15, + }, + { + x: 595.7619057497752, + y: 497.83788593573075, + label: 'Helsinki Vantaa Airport', + color: '#38007E', + field: 'Dest', + term: 'Helsinki Vantaa Airport', + parent: null, + size: 15, + }, + { + x: 185.93617979891062, + y: 422.59954588194796, + label: 'Falcone Borsellino Airport', + color: '#38007E', + field: 'Dest', + term: 'Falcone Borsellino Airport', + parent: null, + size: 15, + }, + { + x: 310.7985722936307, + y: 565.8106567909418, + label: 'Damaging Wind', + color: '#34130C', + field: 'DestWeather', + term: 'Damaging Wind', + parent: null, + size: 15, + }, + { + x: 226.7458591666634, + y: 107.70616617436147, + label: 'Thunder & Lightning', + color: '#34130C', + field: 'DestWeather', + term: 'Thunder & Lightning', + parent: null, + size: 15, + }, + { + x: 841.0362982575906, + y: 271.86719405075036, + label: 'Turin Airport', + color: '#38007E', + field: 'Dest', + term: 'Turin Airport', + parent: null, + size: 15, + }, + { + x: 607.8580597431672, + y: 674.8142192796432, + label: 'ES-Air', + color: '#CE0060', + field: 'Carrier', + term: 'ES-Air', + parent: null, + size: 15, + }, + { + x: 147.48792054443953, + y: 564.0675506645817, + label: 'Philadelphia International Airport', + color: '#38007E', + field: 'Dest', + term: 'Philadelphia International Airport', + parent: null, + size: 15, + }, + { + x: 195.87484752441807, + y: 187.0207407631843, + label: 'Mariscal Sucre International Airport', + color: '#38007E', + field: 'Dest', + term: 'Mariscal Sucre International Airport', + parent: null, + size: 15, + }, + { + x: 284.28484320054537, + y: 126.299295414221, + label: 'Kibana Airlines', + color: '#CE0060', + field: 'Carrier', + term: 'Kibana Airlines', + parent: null, + size: 15, + }, + { + x: 194.4295924748303, + y: 272.79043826611775, + label: 'Indianapolis International Airport', + color: '#38007E', + field: 'Dest', + term: 'Indianapolis International Airport', + parent: null, + size: 15, + }, + { + x: 465.97943124701703, + y: 142.61050933505095, + label: 'Spokane International Airport', + color: '#38007E', + field: 'Dest', + term: 'Spokane International Airport', + parent: null, + size: 15, + }, + { + x: 563.1081895874394, + y: 461.0383551052199, + label: 'Savannah Hilton Head International Airport', + color: '#38007E', + field: 'Dest', + term: 'Savannah Hilton Head International Airport', + parent: null, + size: 15, + }, + { + x: 174.0117366992591, + y: 221.18597939550128, + label: 'Olenya Air Base', + color: '#38007E', + field: 'Dest', + term: 'Olenya Air Base', + parent: null, + size: 15, + }, + { + x: -148.89474582077094, + y: 464.5050002661098, + label: "Xi'an Xianyang International Airport", + color: '#38007E', + field: 'Dest', + term: "Xi'an Xianyang International Airport", + parent: null, + size: 15, + }, + { + x: 541.411089567981, + y: 580.3869624463574, + label: 'Kansas City International Airport', + color: '#38007E', + field: 'Dest', + term: 'Kansas City International Airport', + parent: null, + size: 15, + }, + { + x: -162.65034295458753, + y: 413.712547647303, + label: 'Brisbane International Airport', + color: '#38007E', + field: 'Dest', + term: 'Brisbane International Airport', + parent: null, + size: 15, + }, + { + x: -116.84605252338424, + y: 517.8977089765682, + label: 'Cape Town International Airport', + color: '#38007E', + field: 'Dest', + term: 'Cape Town International Airport', + parent: null, + size: 15, + }, + { + x: 596.9667234907166, + y: 194.18359952998938, + label: 'Wichita Mid Continent Airport', + color: '#38007E', + field: 'Dest', + term: 'Wichita Mid Continent Airport', + parent: null, + size: 15, + }, + { + x: 500.4899840585019, + y: 177.09233549147297, + label: 'Ministro Pistarini International Airport', + color: '#38007E', + field: 'Dest', + term: 'Ministro Pistarini International Airport', + parent: null, + size: 15, + }, + { + x: 826.9908015391406, + y: 416.75687496452565, + label: 'OR Tambo International Airport', + color: '#38007E', + field: 'Dest', + term: 'OR Tambo International Airport', + parent: null, + size: 15, + }, + { + x: 555.157034647214, + y: 166.9646207668324, + label: 'Shanghai Hongqiao International Airport', + color: '#38007E', + field: 'Dest', + term: 'Shanghai Hongqiao International Airport', + parent: null, + size: 15, + }, + { + x: 580.8551934489927, + y: 241.47782924175658, + label: 'Indira Gandhi International Airport', + color: '#38007E', + field: 'Dest', + term: 'Indira Gandhi International Airport', + parent: null, + size: 15, + }, + { + x: 142.49629635003708, + y: 518.4470370636079, + label: 'Frankfurt am Main Airport', + color: '#38007E', + field: 'Dest', + term: 'Frankfurt am Main Airport', + parent: null, + size: 15, + }, + { + x: 716.6279150760975, + y: 545.8773030597199, + label: 'Vienna International Airport', + color: '#38007E', + field: 'Dest', + term: 'Vienna International Airport', + parent: null, + size: 15, + }, + { + x: -70.06067646092055, + y: 561.1605661590851, + label: 'Cagliari Elmas Airport', + color: '#38007E', + field: 'Dest', + term: 'Cagliari Elmas Airport', + parent: null, + size: 15, + }, + { + x: 533.2686334784598, + y: 219.21154460683562, + label: 'Tucson International Airport', + color: '#38007E', + field: 'Dest', + term: 'Tucson International Airport', + parent: null, + size: 15, + }, + { + x: -93.03511592199457, + y: 381.08072776851094, + label: 'Louisville International Standiford Field', + color: '#38007E', + field: 'Dest', + term: 'Louisville International Standiford Field', + parent: null, + size: 15, + }, + { + x: -182.53556363207895, + y: 361.554383031446, + label: 'Salt Lake City International Airport', + color: '#38007E', + field: 'Dest', + term: 'Salt Lake City International Airport', + parent: null, + size: 15, + }, + { + x: 506.6699374507708, + y: 547.2465972305006, + label: 'Rochester International Airport', + color: '#38007E', + field: 'Dest', + term: 'Rochester International Airport', + parent: null, + size: 15, + }, + { + x: -148.82859321240085, + y: 318.0132218264011, + label: 'Itami Airport', + color: '#38007E', + field: 'Dest', + term: 'Itami Airport', + parent: null, + size: 15, + }, + { + x: 222.5302956739488, + y: 232.51590505210746, + label: 'Portland International Airport', + color: '#38007E', + field: 'Dest', + term: 'Portland International Airport', + parent: null, + size: 15, + }, + { + x: -80.62574246014822, + y: 303.3255679653993, + label: 'Dubai International Airport', + color: '#38007E', + field: 'Dest', + term: 'Dubai International Airport', + parent: null, + size: 15, + }, + { + x: -34.72394927217507, + y: 217.5466871636975, + label: 'Zurich Airport', + color: '#38007E', + field: 'Dest', + term: 'Zurich Airport', + parent: null, + size: 15, + }, + { + x: -9.750451947080853, + y: 568.5500808550931, + label: 'Leonardo da Vinci - Fiumicino Airport', + color: '#38007E', + field: 'Dest', + term: 'Leonardo da Vinci - Fiumicino Airport', + parent: null, + size: 15, + }, + { + x: -171.03799922521074, + y: 268.04401840229406, + label: 'Jorge Chavez International Airport', + color: '#38007E', + field: 'Dest', + term: 'Jorge Chavez International Airport', + parent: null, + size: 15, + }, + { + x: 254.95546516251608, + y: 360.7470259628306, + label: 'Newport News Williamsburg International Airport', + color: '#38007E', + field: 'Dest', + term: 'Newport News Williamsburg International Airport', + parent: null, + size: 15, + }, + { + x: 705.9928093405911, + y: 260.92721232939704, + label: 'Narita International Airport', + color: '#38007E', + field: 'Dest', + term: 'Narita International Airport', + parent: null, + size: 15, + }, + { + x: 300.39350107798504, + y: 296.31322539642935, + label: 'Phoenix Sky Harbor International Airport', + color: '#38007E', + field: 'Dest', + term: 'Phoenix Sky Harbor International Airport', + parent: null, + size: 15, + }, + { + x: 841.3679622941146, + y: 362.994358559615, + label: 'Gulfport Biloxi International Airport', + color: '#38007E', + field: 'Dest', + term: 'Gulfport Biloxi International Airport', + parent: null, + size: 15, + }, + { + x: -141.05365305439858, + y: 210.2303430439021, + label: 'Copenhagen Kastrup Airport', + color: '#38007E', + field: 'Dest', + term: 'Copenhagen Kastrup Airport', + parent: null, + size: 15, + }, + { + x: 743.5349870766893, + y: 126.70030466255093, + label: 'Syracuse Hancock International Airport', + color: '#38007E', + field: 'Dest', + term: 'Syracuse Hancock International Airport', + parent: null, + size: 15, + }, + { + x: 764.618951678557, + y: 248.832832419093, + label: 'Tokyo Haneda International Airport', + color: '#38007E', + field: 'Dest', + term: 'Tokyo Haneda International Airport', + parent: null, + size: 15, + }, + { + x: 763.09219411721, + y: 513.1544667969338, + label: 'Munich Airport', + color: '#38007E', + field: 'Dest', + term: 'Munich Airport', + parent: null, + size: 15, + }, + { + x: 156.05708853251238, + y: 473.87653900869924, + label: 'Washington Dulles International Airport', + color: '#38007E', + field: 'Dest', + term: 'Washington Dulles International Airport', + parent: null, + size: 15, + }, + { + x: -86.411003945306, + y: 240.80939633249233, + label: 'Malpensa International Airport', + color: '#38007E', + field: 'Dest', + term: 'Malpensa International Airport', + parent: null, + size: 15, + }, + { + x: 685.9006745563539, + y: 80.38825995741794, + label: 'Tulsa International Airport', + color: '#38007E', + field: 'Dest', + term: 'Tulsa International Airport', + parent: null, + size: 15, + }, + { + x: 813.5591404529398, + y: 319.41126742174833, + label: 'Chhatrapati Shivaji International Airport', + color: '#38007E', + field: 'Dest', + term: 'Chhatrapati Shivaji International Airport', + parent: null, + size: 15, + }, + { + x: 764.1118449187941, + y: 425.24554477772796, + label: 'King Shaka International Airport', + color: '#38007E', + field: 'Dest', + term: 'King Shaka International Airport', + parent: null, + size: 15, + }, + { + x: 703.5657989067569, + y: 465.484110126664, + label: 'London Gatwick Airport', + color: '#38007E', + field: 'Dest', + term: 'London Gatwick Airport', + parent: null, + size: 15, + }, + { + x: 344.9519826614776, + y: -13.093056231864056, + label: 'Nashville International Airport', + color: '#38007E', + field: 'Dest', + term: 'Nashville International Airport', + parent: null, + size: 15, + }, + { + x: -81.11616869938695, + y: 450.9378117999539, + label: 'Jeju International Airport', + color: '#38007E', + field: 'Dest', + term: 'Jeju International Airport', + parent: null, + size: 15, + }, + { + x: 520.9186276242698, + y: 119.42964509536168, + label: 'Naples International Airport', + color: '#38007E', + field: 'Dest', + term: 'Naples International Airport', + parent: null, + size: 15, + }, + { + x: 816.422014720576, + y: 212.4314895109656, + label: 'Seattle Tacoma International Airport', + color: '#38007E', + field: 'Dest', + term: 'Seattle Tacoma International Airport', + parent: null, + size: 15, + }, + { + x: 25.734384706872138, + y: 124.10051087501682, + label: 'London Luton Airport', + color: '#38007E', + field: 'Dest', + term: 'London Luton Airport', + parent: null, + size: 15, + }, + { + x: 185.9498162384016, + y: 590.068422735089, + label: 'Quad City International Airport', + color: '#38007E', + field: 'Dest', + term: 'Quad City International Airport', + parent: null, + size: 15, + }, + { + x: 213.56366767998443, + y: 470.3771672046229, + label: 'San Diego International Airport', + color: '#38007E', + field: 'Dest', + term: 'San Diego International Airport', + parent: null, + size: 15, + }, + { + x: 349.5963617759899, + y: 42.24365374774675, + label: 'Genoa Cristoforo Colombo Airport', + color: '#38007E', + field: 'Dest', + term: 'Genoa Cristoforo Colombo Airport', + parent: null, + size: 15, + }, + { + x: 674.2709501560455, + y: 132.40588179256156, + label: 'Rajiv Gandhi International Airport', + color: '#38007E', + field: 'Dest', + term: 'Rajiv Gandhi International Airport', + parent: null, + size: 15, + }, + { + x: -93.72766628851922, + y: 163.56728717209475, + label: 'Tampa International Airport', + color: '#38007E', + field: 'Dest', + term: 'Tampa International Airport', + parent: null, + size: 15, + }, + { + x: 569.5207860148963, + y: 130.37661454397244, + label: 'Kansai International Airport', + color: '#38007E', + field: 'Dest', + term: 'Kansai International Airport', + parent: null, + size: 15, + }, + { + x: 750.1154214852191, + y: 323.5264978888758, + label: 'Chengdu Shuangliu International Airport', + color: '#38007E', + field: 'Dest', + term: 'Chengdu Shuangliu International Airport', + parent: null, + size: 15, + }, + { + x: 802.7414370705463, + y: 473.82537149991913, + label: 'Scott AFB/Midamerica Airport', + color: '#38007E', + field: 'Dest', + term: 'Scott AFB/Midamerica Airport', + parent: null, + size: 15, + }, + { + x: 418.5925126330155, + y: 24.230521636621365, + label: 'Edmonton International Airport', + color: '#38007E', + field: 'Dest', + term: 'Edmonton International Airport', + parent: null, + size: 15, + }, + { + x: 722.7028867550214, + y: 384.02115146468276, + label: 'Venice Marco Polo Airport', + color: '#38007E', + field: 'Dest', + term: 'Venice Marco Polo Airport', + parent: null, + size: 15, + }, + { + x: 566.9547084529621, + y: 536.9780471490457, + label: 'Licenciado Benito Juarez International Airport', + color: '#38007E', + field: 'Dest', + term: 'Licenciado Benito Juarez International Airport', + parent: null, + size: 15, + }, + { + x: 9.092519123754876, + y: 180.41434896279804, + label: 'Richmond International Airport', + color: '#38007E', + field: 'Dest', + term: 'Richmond International Airport', + parent: null, + size: 15, + }, + { + x: 526.9718956870161, + y: 499.9130353149581, + label: 'Oslo Gardermoen Airport', + color: '#38007E', + field: 'Dest', + term: 'Oslo Gardermoen Airport', + parent: null, + size: 15, + }, + { + x: 776.8528805322672, + y: 172.1720828990032, + label: 'Orlando Sanford International Airport', + color: '#38007E', + field: 'Dest', + term: 'Orlando Sanford International Airport', + parent: null, + size: 15, + }, + { + x: 194.56093032633905, + y: 506.61947778758895, + label: 'Manchester Airport', + color: '#38007E', + field: 'Dest', + term: 'Manchester Airport', + parent: null, + size: 15, + }, + { + x: 708.6785061187419, + y: 191.9304211208653, + label: 'Cologne Bonn Airport', + color: '#38007E', + field: 'Dest', + term: 'Cologne Bonn Airport', + parent: null, + size: 15, + }, + { + x: -37.77191138443358, + y: 501.2430928096333, + label: 'Verona Villafranca Airport', + color: '#38007E', + field: 'Dest', + term: 'Verona Villafranca Airport', + parent: null, + size: 15, + }, + { + x: -40.417571635448624, + y: 123.95944445826335, + label: "Treviso-Sant'Angelo Airport", + color: '#38007E', + field: 'Dest', + term: "Treviso-Sant'Angelo Airport", + parent: null, + size: 15, + }, + { + x: 429.6512757101672, + y: 754.2512422806057, + label: 'Ukrainka Air Base', + color: '#38007E', + field: 'Dest', + term: 'Ukrainka Air Base', + parent: null, + size: 15, + }, + { + x: 210.79822994078665, + y: 547.8887998341944, + label: 'London Heathrow Airport', + color: '#38007E', + field: 'Dest', + term: 'London Heathrow Airport', + parent: null, + size: 15, + }, + ], + links: [ + { weight: 0.00036108815767164356, width: 2, inferred: false, source: 16, target: 15 }, + { weight: 0.00006920523704931667, width: 2, inferred: false, source: 10, target: 16 }, + { weight: 0.000025994919070600338, width: 2, inferred: false, source: 14, target: 2 }, + { weight: 0.0018162486758829953, width: 2, inferred: false, source: 4, target: 12 }, + { weight: 0.00018081732691649835, width: 2, inferred: false, source: 9, target: 16 }, + { weight: 0.000021285526043182752, width: 2, inferred: false, source: 12, target: 14 }, + { weight: 0.0007282200503396025, width: 2, inferred: false, source: 9, target: 0 }, + { weight: 0.004793219772186124, width: 2, inferred: false, source: 15, target: 14 }, + { weight: 0.0007516261919537721, width: 2, inferred: false, source: 11, target: 3 }, + { weight: 0.00001604668217899462, width: 2, inferred: false, source: 15, target: 6 }, + { + weight: 0.00102064538814533, + width: 2.129352369920287, + inferred: false, + source: 10, + target: 0, + }, + { weight: 0.0005756894672209474, width: 2, inferred: false, source: 11, target: 9 }, + { weight: 0.00043176411158517205, width: 2, inferred: false, source: 16, target: 14 }, + { weight: 0.000298574093986214, width: 2, inferred: false, source: 15, target: 4 }, + { weight: 0.00026684563135348044, width: 2, inferred: false, source: 3, target: 9 }, + { + weight: 0.0015570439724214619, + width: 3.2484301710023926, + inferred: false, + source: 3, + target: 16, + }, + { weight: 0.00034139370106102624, width: 2, inferred: false, source: 12, target: 16 }, + { weight: 0.000019807816572852395, width: 2, inferred: false, source: 15, target: 7 }, + { weight: 0.0018795555437956094, width: 2, inferred: false, source: 0, target: 12 }, + { weight: 0.00008480623691842954, width: 2, inferred: false, source: 14, target: 4 }, + { weight: 0.0005396046174994674, width: 2, inferred: false, source: 0, target: 14 }, + { weight: 0.00030597266180943495, width: 2, inferred: false, source: 11, target: 15 }, + { weight: 0.00016510683587379307, width: 2, inferred: false, source: 12, target: 9 }, + { weight: 0.000877528177750529, width: 2, inferred: false, source: 3, target: 4 }, + { + weight: 0.004021590274418162, + width: 8.390164577377533, + inferred: false, + source: 9, + target: 15, + }, + { weight: 0.00005090637270674858, width: 2, inferred: false, source: 4, target: 5 }, + { weight: 0.000021160301063872648, width: 2, inferred: false, source: 9, target: 7 }, + { weight: 0.0007218599824419075, width: 2, inferred: false, source: 4, target: 9 }, + { weight: 0.000020271897051582118, width: 2, inferred: false, source: 15, target: 1 }, + { weight: 0.0001452986212793978, width: 2, inferred: false, source: 11, target: 8 }, + { weight: 0.0000382567038512752, width: 2, inferred: false, source: 10, target: 14 }, + { weight: 0.00002190156221770533, width: 2, inferred: false, source: 10, target: 9 }, + { + weight: 0.004042935452811213, + width: 8.434696602628934, + inferred: false, + source: 3, + target: 0, + }, + { weight: 0.000048696788032371897, width: 2, inferred: false, source: 3, target: 14 }, + { weight: 0.000005506428294426271, width: 2, inferred: false, source: 0, target: 8 }, + { weight: 0.00037127137164506553, width: 2, inferred: false, source: 10, target: 4 }, + { weight: 0.000022370205464624682, width: 2, inferred: false, source: 14, target: 13 }, + { weight: 0.00001466782860711787, width: 2, inferred: false, source: 16, target: 5 }, + { weight: 0.0001456026369222754, width: 2, inferred: false, source: 15, target: 0 }, + { + weight: 0.006907860404869038, + width: 4.55482755826747, + inferred: false, + source: 12, + target: 21, + }, + { + weight: 0.008296001497090972, + width: 5.470124470920678, + inferred: false, + source: 12, + target: 17, + }, + { weight: 0.00648290935725332, width: 4.2746281000922, inferred: false, source: 8, target: 24 }, + { weight: 0.0009981800125248449, width: 2, inferred: false, source: 9, target: 23 }, + { weight: 0.0015459070412640408, width: 2, inferred: false, source: 9, target: 18 }, + { weight: 0.01516601960557338, width: 10, inferred: false, source: 16, target: 22 }, + { + weight: 0.005893794668845864, + width: 3.886184260687587, + inferred: false, + source: 0, + target: 25, + }, + { + weight: 0.005313459755140434, + width: 3.50352953070678, + inferred: false, + source: 0, + target: 20, + }, + { weight: 0.0008193770353314001, width: 2, inferred: false, source: 9, target: 17 }, + { + weight: 0.005369162122122355, + width: 3.5402579330368495, + inferred: false, + source: 8, + target: 18, + }, + { + weight: 0.0041502680719532024, + width: 2.736557237752755, + inferred: false, + source: 14, + target: 24, + }, + { + weight: 0.005575455098137172, + width: 3.6762810830656187, + inferred: false, + source: 8, + target: 23, + }, + { weight: 0.0006592549345612115, width: 2, inferred: false, source: 0, target: 19 }, + { + weight: 0.0028878207958795113, + width: 2.744516404276922, + inferred: false, + source: 14, + target: 29, + }, + { + weight: 0.00541445375382345, + width: 5.145768452381221, + inferred: false, + source: 14, + target: 26, + }, + { + weight: 0.0077101087361939056, + width: 7.327504509779791, + inferred: false, + source: 12, + target: 28, + }, + { weight: 0.001086168788022982, width: 2, inferred: false, source: 9, target: 28 }, + { + weight: 0.005830015792513137, + width: 5.540708759551927, + inferred: false, + source: 12, + target: 27, + }, + { weight: 0.010522148059961567, width: 10, inferred: false, source: 8, target: 30 }, + { + weight: 0.008028304360541931, + width: 7.629910085651518, + inferred: false, + source: 14, + target: 27, + }, + { + weight: 0.008323509700335742, + width: 7.910466240261349, + inferred: false, + source: 8, + target: 29, + }, + { + weight: 0.00701726324791995, + width: 6.669040587464972, + inferred: false, + source: 8, + target: 26, + }, + { + weight: 0.008035893034703851, + width: 7.493359138625227, + inferred: false, + source: 12, + target: 34, + }, + { + weight: 0.009872040172040198, + width: 9.205540954883924, + inferred: false, + source: 8, + target: 32, + }, + { + weight: 0.006969610945500717, + width: 6.499065834448964, + inferred: false, + source: 12, + target: 31, + }, + { + weight: 0.0033592096430033543, + width: 3.1324165426605663, + inferred: false, + source: 14, + target: 34, + }, + { weight: 0.0020881160512555767, width: 2, inferred: false, source: 9, target: 31 }, + { + weight: 0.005672517253512455, + width: 5.289543902220858, + inferred: false, + source: 12, + target: 35, + }, + { + weight: 0.0038532137077538194, + width: 3.5930685022037694, + inferred: false, + source: 14, + target: 35, + }, + { weight: 0.010724019609953143, width: 10, inferred: false, source: 8, target: 33 }, + { weight: 0.009999612232220277, width: 10, inferred: false, source: 12, target: 36 }, + { + weight: 0.00520836804658599, + width: 5.208570018149137, + inferred: false, + source: 14, + target: 37, + }, + { + weight: 0.0065791804178040895, + width: 6.579435547115483, + inferred: false, + source: 12, + target: 38, + }, + { + weight: 0.0035543396019111486, + width: 3.5544774330933793, + inferred: false, + source: 9, + target: 39, + }, + { + weight: 0.007640437421149957, + width: 7.640733704184349, + inferred: false, + source: 12, + target: 40, + }, + { + weight: 0.005772892244324483, + width: 5.773116107165979, + inferred: false, + source: 12, + target: 37, + }, + { + weight: 0.00683892215386792, + width: 6.839187355517515, + inferred: false, + source: 8, + target: 39, + }, + { + weight: 0.0035554369106046754, + width: 3.5555747843386514, + inferred: false, + source: 14, + target: 38, + }, + { + weight: 0.006442257454823214, + width: 6.700837532628826, + inferred: false, + source: 12, + target: 42, + }, + { + weight: 0.008768456755896941, + width: 9.120406091370558, + inferred: false, + source: 8, + target: 43, + }, + { + weight: 0.002463336629511846, + width: 2.5622103211932767, + inferred: false, + source: 14, + target: 42, + }, + { weight: 0.009614107823766071, width: 10, inferred: false, source: 8, target: 44 }, + { + weight: 0.005362282501083629, + width: 5.577514418787844, + inferred: false, + source: 12, + target: 45, + }, + { + weight: 0.004211820280840009, + width: 4.38087481235481, + inferred: false, + source: 9, + target: 45, + }, + { + weight: 0.008768456755896941, + width: 9.120406091370558, + inferred: false, + source: 8, + target: 41, + }, + { + weight: 0.00901282169263535, + width: 9.230629866820077, + inferred: false, + source: 8, + target: 48, + }, + { + weight: 0.006864761661424646, + width: 7.030658786063203, + inferred: false, + source: 8, + target: 47, + }, + { weight: 0.009764037582128985, width: 10, inferred: false, source: 8, target: 49 }, + { + weight: 0.002218700052240432, + width: 2.272318222434227, + inferred: false, + source: 14, + target: 47, + }, + { + weight: 0.009069404566965875, + width: 9.288580150045213, + inferred: false, + source: 8, + target: 50, + }, + { + weight: 0.008849408882060712, + width: 9.063267943844963, + inferred: false, + source: 8, + target: 46, + }, + { + weight: 0.005626664661994386, + width: 5.715730944253917, + inferred: false, + source: 8, + target: 52, + }, + { + weight: 0.007560194330975868, + width: 7.679867075429226, + inferred: false, + source: 8, + target: 51, + }, + { weight: 0.001752663718499857, width: 2, inferred: false, source: 9, target: 52 }, + { + weight: 0.008026220513934599, + width: 8.153270136528944, + inferred: false, + source: 12, + target: 53, + }, + { + weight: 0.004827356344509919, + width: 4.903770118668455, + inferred: false, + source: 8, + target: 54, + }, + { weight: 0.00984417341696416, width: 10, inferred: false, source: 12, target: 55 }, + { + weight: 0.006914338939083934, + width: 7.023788231085676, + inferred: false, + source: 12, + target: 54, + }, + { + weight: 0.0050433680321645925, + width: 5.123201124711509, + inferred: false, + source: 14, + target: 52, + }, + { + weight: 0.008168227180792522, + width: 9.420967741935492, + inferred: false, + source: 12, + target: 57, + }, + { weight: 0.008670263400259132, width: 10, inferred: false, source: 12, target: 58 }, + { + weight: 0.005167622324806284, + width: 5.960167628415806, + inferred: false, + source: 9, + target: 60, + }, + { + weight: 0.0038411902891512147, + width: 4.430304030943756, + inferred: false, + source: 8, + target: 60, + }, + { + weight: 0.0075177233690892475, + width: 8.670697788563796, + inferred: false, + source: 12, + target: 59, + }, + { + weight: 0.00821636644295359, + width: 9.476490002262242, + inferred: false, + source: 8, + target: 56, + }, + { + weight: 0.008567041135861564, + width: 9.505916995325613, + inferred: false, + source: 12, + target: 62, + }, + { weight: 0.009012324786839896, width: 10, inferred: false, source: 12, target: 64 }, + { + weight: 0.007978951597732759, + width: 8.853377775936234, + inferred: false, + source: 12, + target: 63, + }, + { + weight: 0.007990477494073249, + width: 8.866166813851645, + inferred: false, + source: 8, + target: 61, + }, + { + weight: 0.0068326370809723485, + width: 7.581436801911088, + inferred: false, + source: 12, + target: 65, + }, + { weight: 0.0069628576746968325, width: 10, inferred: false, source: 14, target: 66 }, + { + weight: 0.00630579175761646, + width: 9.056327232612892, + inferred: false, + source: 12, + target: 69, + }, + { + weight: 0.004993595139087726, + width: 7.171761038911585, + inferred: false, + source: 12, + target: 68, + }, + { + weight: 0.006440422196382008, + width: 9.249682382258989, + inferred: false, + source: 8, + target: 70, + }, + { + weight: 0.006461917139048282, + width: 9.280553245445503, + inferred: false, + source: 8, + target: 67, + }, + { weight: 0.0012299141681236386, width: 2, inferred: false, source: 14, target: 68 }, + { + weight: 0.006121250009532553, + width: 8.223889291692453, + inferred: false, + source: 14, + target: 73, + }, + { weight: 0.007443254392682634, width: 10, inferred: false, source: 12, target: 74 }, + { + weight: 0.0036956382919431487, + width: 4.965083949805991, + inferred: false, + source: 8, + target: 72, + }, + { + weight: 0.00417209586464865, + width: 5.605203912888136, + inferred: false, + source: 8, + target: 71, + }, + { + weight: 0.006226305772632526, + width: 8.365031536143016, + inferred: false, + source: 8, + target: 75, + }, + { + weight: 0.00457964360497232, + width: 6.152743629822068, + inferred: false, + source: 9, + target: 72, + }, + { + weight: 0.004811414885204741, + width: 6.464127962541197, + inferred: false, + source: 9, + target: 71, + }, + { + weight: 0.008658220862662045, + width: 9.39624265947584, + inferred: false, + source: 12, + target: 77, + }, + { + weight: 0.005652490696892165, + width: 6.134305772617896, + inferred: false, + source: 14, + target: 76, + }, + { weight: 0.009214556473730996, width: 10, inferred: false, source: 14, target: 79 }, + { + weight: 0.004748575495037549, + width: 5.153341355685282, + inferred: false, + source: 12, + target: 76, + }, + { + weight: 0.0077464423601241485, + width: 8.406744678604802, + inferred: false, + source: 12, + target: 80, + }, + { + weight: 0.008124466937893192, + width: 8.816991855283053, + inferred: false, + source: 12, + target: 78, + }, + { + weight: 0.0060785494322330245, + width: 5.642184271849482, + inferred: false, + source: 12, + target: 81, + }, + { + weight: 0.0055135463710868065, + width: 5.117741488141641, + inferred: false, + source: 9, + target: 83, + }, + { + weight: 0.009734577561953504, + width: 9.035754504504519, + inferred: false, + source: 8, + target: 85, + }, + { weight: 0.0006290814048138334, width: 2, inferred: false, source: 9, target: 85 }, + { + weight: 0.006117429813459821, + width: 5.6782735194384015, + inferred: false, + source: 12, + target: 83, + }, + { + weight: 0.009450881532944542, + width: 8.772424364525301, + inferred: false, + source: 12, + target: 84, + }, + { + weight: 0.005227004044795189, + width: 4.851769380051405, + inferred: false, + source: 9, + target: 81, + }, + { weight: 0.010773397569733226, width: 10, inferred: false, source: 8, target: 82 }, + { + weight: 0.011920043127675903, + width: 6.530170805646604, + inferred: false, + source: 8, + target: 90, + }, + { weight: 0.0034745412270287637, width: 2, inferred: false, source: 12, target: 86 }, + { + weight: 0.015665658081851157, + width: 8.582135312902338, + inferred: false, + source: 8, + target: 88, + }, + { + weight: 0.01040035726960635, + width: 5.697639570832633, + inferred: false, + source: 8, + target: 87, + }, + { + weight: 0.00718982708389688, + width: 3.9388111618405564, + inferred: false, + source: 9, + target: 90, + }, + { weight: 0.018253799911893125, width: 10, inferred: false, source: 9, target: 89 }, + ], + urlTemplates: [ + { + url: + '/app/kibana#/discover?_a=(columns%3A!(_source)%2Cindex%3Ad3d7af60-4c81-11e8-b3d7-01146121b73d%2Cinterval%3Aauto%2Cquery%3A(language%3Akuery%2Cquery%3A{{gquery}})%2Csort%3A!(_score%2Cdesc))', + description: 'Raw documents', + isDefault: true, + encoderID: 'kql-loose', + }, + ], + exploreControls: { + useSignificance: true, + sampleSize: 2000, + timeoutMillis: 5000, + maxValuesPerDoc: 1, + minDocCount: 3, + }, + indexPatternRefName: 'indexPattern_0', +}; + +export function registerFlightsSampleData(sampleDataRegistry: SampleDataRegistrySetup) { + sampleDataRegistry.addSavedObjectsToSampleDataset(datasetId, [ + { + type: 'graph-workspace', + id: '5dc018d0-32f8-11ea-bbe4-818d9c786051', + version: '2', + attributes: { + title: 'Kibana Sample Data - Flights', + description: + 'This is a sample graph of the flights demo database. It shows all flights destinations, weather, and which carrier was used.', + numLinks: 142, + numVertices: 91, + version: 1, + wsState: JSON.stringify(JSON.stringify(wsState)), + }, + references: [ + { + name: 'indexPattern_0', + type: 'index-pattern', + id: 'kibana_sample_data_flights', + }, + ], + migrationVersion: { + 'graph-workspace': '7.0.0', + }, + updated_at: '2020-01-09T15:55:24.013Z', + }, + ]); +} +export function registerFlightsSampleDataLink(sampleDataRegistry: SampleDataRegistrySetup) { + sampleDataRegistry.addAppLinksToSampleDataset(datasetId, [ + { + path: createWorkspacePath('5dc018d0-32f8-11ea-bbe4-818d9c786051'), + label: i18n.translate('xpack.graph.sampleData.label', { defaultMessage: 'Graph' }), + icon: APP_ICON, + }, + ]); +} diff --git a/x-pack/plugins/graph/server/sample_data/index.ts b/x-pack/plugins/graph/server/sample_data/index.ts new file mode 100644 index 0000000000000..a12142c84ccb1 --- /dev/null +++ b/x-pack/plugins/graph/server/sample_data/index.ts @@ -0,0 +1,7 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +export { registerSampleData } from './register_sample_data'; diff --git a/x-pack/plugins/graph/server/sample_data/logs.ts b/x-pack/plugins/graph/server/sample_data/logs.ts new file mode 100644 index 0000000000000..b524e3ccd0072 --- /dev/null +++ b/x-pack/plugins/graph/server/sample_data/logs.ts @@ -0,0 +1,463 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { i18n } from '@kbn/i18n'; +import { SampleDataRegistrySetup } from '../../../../../src/plugins/home/server'; +import { APP_ICON, createWorkspacePath } from '../../common/constants'; + +const datasetId = 'logs'; + +const wsState: any = { + selectedFields: [ + { + name: 'agent.keyword', + hopSize: 5, + lastValidHopSize: 5, + color: '#CE0060', + selected: true, + iconClass: 'fa-key', + }, + { + name: 'extension.keyword', + hopSize: 5, + lastValidHopSize: 5, + color: '#B0916F', + selected: true, + iconClass: 'fa-key', + }, + { + name: 'geo.src', + hopSize: 5, + lastValidHopSize: 5, + color: '#1EA593', + selected: true, + iconClass: 'fa-map-marker', + }, + { + name: 'response.keyword', + hopSize: 5, + lastValidHopSize: 5, + color: '#7B000B', + selected: true, + iconClass: 'fa-key', + }, + ], + blacklist: [ + { + x: 349.9814471314239, + y: 274.1259761174194, + label: '200', + color: '#7B000B', + field: 'response.keyword', + term: '200', + parent: null, + size: 15, + }, + { + x: 264.83032783224775, + y: 149.28911778947068, + label: '404', + color: '#7B000B', + field: 'response.keyword', + term: '404', + parent: null, + size: 15, + }, + ], + vertices: [ + { + x: 705.0456564066692, + y: 40.62170801995693, + label: 'US', + color: '#1EA593', + field: 'geo.src', + term: 'US', + parent: null, + size: 15, + }, + { + x: 403.9630841139531, + y: 343.70678387260784, + label: 'rpm', + color: '#B0916F', + field: 'extension.keyword', + term: 'rpm', + parent: null, + size: 15, + }, + { + x: 725.3403430314892, + y: 531.7559897276761, + label: 'NG', + color: '#1EA593', + field: 'geo.src', + term: 'NG', + parent: null, + size: 15, + }, + { + x: 226.82596303052026, + y: 412.0884666842448, + label: 'Mozilla/5.0 (X11; Linux x86_64; rv:6.0a1) Gecko/20110421 Firefox/6.0a1', + color: '#CE0060', + field: 'agent.keyword', + term: 'Mozilla/5.0 (X11; Linux x86_64; rv:6.0a1) Gecko/20110421 Firefox/6.0a1', + parent: null, + size: 15, + }, + { + x: 292.5918164195066, + y: 268.48941070600534, + label: 'Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322)', + color: '#CE0060', + field: 'agent.keyword', + term: 'Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322)', + parent: null, + size: 15, + }, + { + x: 778.0887942801058, + y: 182.63288692820015, + label: 'LK', + color: '#1EA593', + field: 'geo.src', + term: 'LK', + parent: null, + size: 15, + }, + { + x: 341.01411891217134, + y: 416.2991570121247, + label: 'CN', + color: '#1EA593', + field: 'geo.src', + term: 'CN', + parent: null, + size: 15, + }, + { + x: 190.18900623537502, + y: 474.94911053447447, + label: 'deb', + color: '#B0916F', + field: 'extension.keyword', + term: 'deb', + parent: null, + size: 15, + }, + { + x: 232.7845499845522, + y: 292.79169517403824, + label: 'zip', + color: '#B0916F', + field: 'extension.keyword', + term: 'zip', + parent: null, + size: 15, + }, + { + x: 138.90354356936942, + y: 439.57743024730985, + label: 'gz', + color: '#B0916F', + field: 'extension.keyword', + term: 'gz', + parent: null, + size: 15, + }, + { + x: 365.6408169826396, + y: 249.99925380062638, + label: + 'Mozilla/5.0 (X11; Linux i686) AppleWebKit/534.24 (KHTML, like Gecko) Chrome/11.0.696.50 Safari/534.24', + color: '#CE0060', + field: 'agent.keyword', + term: + 'Mozilla/5.0 (X11; Linux i686) AppleWebKit/534.24 (KHTML, like Gecko) Chrome/11.0.696.50 Safari/534.24', + parent: null, + size: 15, + }, + { + x: 265.07380044771776, + y: 329.42267335684767, + label: 'css', + color: '#B0916F', + field: 'extension.keyword', + term: 'css', + parent: null, + size: 15, + }, + { + x: 580.3896044080259, + y: 667.66318599786, + label: 'ET', + color: '#1EA593', + field: 'geo.src', + term: 'ET', + parent: null, + size: 15, + }, + { + x: 568.0601884734044, + y: -49.27073508690644, + label: 'ZW', + color: '#1EA593', + field: 'geo.src', + term: 'ZW', + parent: null, + size: 15, + }, + { + x: 227.5383201433136, + y: 199.48377517208598, + label: '', + color: '#B0916F', + field: 'extension.keyword', + term: '', + parent: null, + size: 15, + }, + { + x: 288.39123736592035, + y: 393.4288970445101, + label: 'GT', + color: '#1EA593', + field: 'geo.src', + term: 'GT', + parent: null, + size: 15, + }, + { + x: 155.466542394056, + y: 339.05104397852546, + label: 'ES', + color: '#1EA593', + field: 'geo.src', + term: 'ES', + parent: null, + size: 15, + }, + { + x: 401.32323264585983, + y: -108.02214607103728, + label: 'CO', + color: '#1EA593', + field: 'geo.src', + term: 'CO', + parent: null, + size: 15, + }, + { + x: 792.1054319493805, + y: 358.6366312643674, + label: 'PA', + color: '#1EA593', + field: 'geo.src', + term: 'PA', + parent: null, + size: 15, + }, + { + x: 314.32050042836784, + y: 319.42284908520816, + label: '503', + color: '#7B000B', + field: 'response.keyword', + term: '503', + parent: null, + size: 15, + }, + { + x: 340.8606114563168, + y: 186.9348337340475, + label: 'IN', + color: '#1EA593', + field: 'geo.src', + term: 'IN', + parent: null, + size: 15, + }, + { + x: 164.94735578931335, + y: 303.33721636577303, + label: 'SY', + color: '#1EA593', + field: 'geo.src', + term: 'SY', + parent: null, + size: 15, + }, + { + x: 301.2853960233053, + y: 435.9520992987688, + label: 'MM', + color: '#1EA593', + field: 'geo.src', + term: 'MM', + parent: null, + size: 15, + }, + { + x: 184.25271122815448, + y: 64.76252387726619, + label: 'BI', + color: '#1EA593', + field: 'geo.src', + term: 'BI', + parent: null, + size: 15, + }, + { + x: 547.7017436962481, + y: 363.41281417686463, + label: 'JP', + color: '#1EA593', + field: 'geo.src', + term: 'JP', + parent: null, + size: 15, + }, + { + x: 530.0067122142244, + y: 267.5235740844544, + label: 'IT', + color: '#1EA593', + field: 'geo.src', + term: 'IT', + parent: null, + size: 15, + }, + { + x: 502.58809919406076, + y: 453.01592357006285, + label: 'YE', + color: '#1EA593', + field: 'geo.src', + term: 'YE', + parent: null, + size: 15, + }, + ], + links: [ + { weight: 0.0040634810444444, width: 2, inferred: false, source: 8, target: 6 }, + { weight: 0.00001660379672906535, width: 2, inferred: false, source: 11, target: 3 }, + { weight: 0.00001687128485592423, width: 2, inferred: false, source: 1, target: 4 }, + { weight: 0.000042381532626601156, width: 2, inferred: false, source: 3, target: 7 }, + { weight: 0.0020092062171401465, width: 2, inferred: false, source: 6, target: 11 }, + { weight: 0.009186429989786131, width: 2, inferred: false, source: 6, target: 7 }, + { weight: 0.0000305247789830849, width: 2, inferred: false, source: 8, target: 4 }, + { weight: 0.000001708437364178419, width: 2, inferred: false, source: 11, target: 10 }, + { weight: 0.004598490556833276, width: 2, inferred: false, source: 1, target: 6 }, + { weight: 0.0000010807159115480025, width: 2, inferred: false, source: 3, target: 9 }, + { weight: 0.011760987925777693, width: 2, inferred: false, source: 6, target: 3 }, + { weight: 0.00000572246876958705, width: 2, inferred: false, source: 3, target: 8 }, + { weight: 0.00003799465167914097, width: 2, inferred: false, source: 1, target: 10 }, + { weight: 0.00019306796701208605, width: 2, inferred: false, source: 20, target: 10 }, + { weight: 0.001410620591413074, width: 2, inferred: false, source: 16, target: 19 }, + { weight: 0.00000260088891060836, width: 2, inferred: false, source: 16, target: 8 }, + { weight: 0.000004221034247288931, width: 2, inferred: false, source: 21, target: 9 }, + { weight: 0.0003983945660073508, width: 2, inferred: false, source: 19, target: 3 }, + { weight: 8.558271008580196e-7, width: 2, inferred: false, source: 14, target: 23 }, + { weight: 0.00002868576516354896, width: 2, inferred: false, source: 14, target: 10 }, + { weight: 0.0000016586853264248163, width: 2, inferred: false, source: 21, target: 4 }, + { weight: 5.648882390462957e-7, width: 2, inferred: false, source: 21, target: 14 }, + { weight: 0.00003419153715339904, width: 2, inferred: false, source: 19, target: 4 }, + { weight: 0.0005988902747672857, width: 2, inferred: false, source: 8, target: 19 }, + { weight: 0.000993973548776136, width: 2, inferred: false, source: 19, target: 1 }, + { weight: 3.835478702669183e-7, width: 2, inferred: false, source: 20, target: 1 }, + { weight: 0.00000739937347045766, width: 2, inferred: false, source: 16, target: 3 }, + { weight: 0.0014120620624644335, width: 2, inferred: false, source: 21, target: 19 }, + { weight: 0.00011448660448075209, width: 2, inferred: false, source: 20, target: 14 }, + { weight: 0.000029650891466752718, width: 2, inferred: false, source: 10, target: 19 }, + { weight: 0.0016870823187632464, width: 2, inferred: false, source: 19, target: 15 }, + { weight: 0.000008712259181870499, width: 2, inferred: false, source: 8, target: 20 }, + { weight: 0.0006524448834525575, width: 2, inferred: false, source: 19, target: 6 }, + { weight: 0.000003916666394077713, width: 2, inferred: false, source: 8, target: 10 }, + { weight: 0.0000018561676077277568, width: 2, inferred: false, source: 16, target: 9 }, + { weight: 0.000006461917090181791, width: 2, inferred: false, source: 20, target: 19 }, + { weight: 0.000813581545225818, width: 2, inferred: false, source: 19, target: 22 }, + { weight: 0.0000790962811304827, width: 2, inferred: false, source: 14, target: 19 }, + { weight: 0.0000038232332387185065, width: 2, inferred: false, source: 8, target: 15 }, + { weight: 1.3666472391330093e-8, width: 2, inferred: false, source: 4, target: 22 }, + { weight: 6.868214506521744e-7, width: 2, inferred: false, source: 15, target: 7 }, + { weight: 0.000005170326226968777, width: 2, inferred: false, source: 22, target: 1 }, + { weight: 0.000018344494132865016, width: 2, inferred: false, source: 3, target: 22 }, + { weight: 0.000020468166046825227, width: 2, inferred: false, source: 3, target: 1 }, + { weight: 0.0000020332506548392678, width: 2, inferred: false, source: 21, target: 11 }, + { weight: 0.0000019831315870577016, width: 2, inferred: false, source: 21, target: 7 }, + { weight: 3.630137259008554e-7, width: 2, inferred: false, source: 22, target: 9 }, + { weight: 0.000003238006460439622, width: 2, inferred: false, source: 4, target: 15 }, + { weight: 0.0000010228580484196547, width: 2, inferred: false, source: 4, target: 6 }, + { weight: 7.524068083846899e-7, width: 2, inferred: false, source: 1, target: 24 }, + { weight: 0.00000647545523418574, width: 2, inferred: false, source: 22, target: 8 }, + { weight: 0.000005887870505895788, width: 2, inferred: false, source: 15, target: 10 }, + { weight: 8.428178658580805e-7, width: 2, inferred: false, source: 16, target: 14 }, + { weight: 4.0006658216459443e-7, width: 2, inferred: false, source: 1, target: 25 }, + { weight: 9.694642023468333e-7, width: 2, inferred: false, source: 1, target: 26 }, + { weight: 4.714506544331047e-7, width: 2, inferred: false, source: 3, target: 21 }, + { weight: 8.212604651861594e-7, width: 2, inferred: false, source: 16, target: 11 }, + { weight: 3.477810450648006e-7, width: 2, inferred: false, source: 16, target: 7 }, + { weight: 9.208171070957436e-8, width: 2, inferred: false, source: 3, target: 15 }, + { weight: 0.0000010905102327000433, width: 2, inferred: false, source: 4, target: 16 }, + { weight: 0.000014782307685187607, width: 2, inferred: false, source: 15, target: 9 }, + ], + urlTemplates: [ + { + url: + '/app/kibana#/discover?_a=(columns%3A!(_source)%2Cindex%3A%2790943e30-9a47-11e8-b64d-95841ca0b247%27%2Cinterval%3Aauto%2Cquery%3A(language%3Akuery%2Cquery%3A{{gquery}})%2Csort%3A!(_score%2Cdesc))', + description: 'Raw documents', + isDefault: true, + encoderID: 'kql-loose', + }, + ], + exploreControls: { + useSignificance: true, + sampleSize: 2000, + timeoutMillis: 5000, + maxValuesPerDoc: 1, + minDocCount: 3, + }, + indexPatternRefName: 'indexPattern_0', +}; + +export function registerLogsSampleData(sampleDataRegistry: SampleDataRegistrySetup) { + sampleDataRegistry.addSavedObjectsToSampleDataset(datasetId, [ + { + type: 'graph-workspace', + id: 'e2141080-32fa-11ea-bbe4-818d9c786051', + version: '2', + attributes: { + title: 'Kibana Sample Data - Data Logs', + description: + 'This is a sample graph based on the data logs index, which shows agents, extensions, source geography of the log, and response codes. The graph has 200 and 404 response codes blocked, as they have low cardinality.', + numLinks: 61, + numVertices: 27, + version: 1, + wsState: JSON.stringify(JSON.stringify(wsState)), + }, + references: [ + { + name: 'indexPattern_0', + type: 'index-pattern', + id: 'kibana_sample_data_logs', + }, + ], + migrationVersion: { + 'graph-workspace': '7.0.0', + }, + updated_at: '2020-01-09T16:40:36.122Z', + }, + ]); +} +export function registerLogsSampleDataLink(sampleDataRegistry: SampleDataRegistrySetup) { + sampleDataRegistry.addAppLinksToSampleDataset(datasetId, [ + { + path: createWorkspacePath('e2141080-32fa-11ea-bbe4-818d9c786051'), + label: i18n.translate('xpack.graph.sampleData.label', { defaultMessage: 'Graph' }), + icon: APP_ICON, + }, + ]); +} diff --git a/x-pack/plugins/graph/server/sample_data/register_sample_data.ts b/x-pack/plugins/graph/server/sample_data/register_sample_data.ts new file mode 100644 index 0000000000000..9a05b656b61a4 --- /dev/null +++ b/x-pack/plugins/graph/server/sample_data/register_sample_data.ts @@ -0,0 +1,36 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import { SampleDataRegistrySetup } from '../../../../../src/plugins/home/server'; +import { registerLogsSampleData, registerLogsSampleDataLink } from './logs'; +import { registerEcommerceSampleData, registerEcommerceSampleDataLink } from './ecommerce'; +import { registerFlightsSampleData, registerFlightsSampleDataLink } from './flights'; +import { LicenseState } from '../lib/license_state'; + +export function registerSampleData( + sampleDataRegistry: SampleDataRegistrySetup, + licenseState: LicenseState +) { + // always register the saved objects... + registerEcommerceSampleData(sampleDataRegistry); + registerFlightsSampleData(sampleDataRegistry); + registerLogsSampleData(sampleDataRegistry); + + // but wait for a license actually supporting Graph to add links to the sample data panels + const licenseUpdates = licenseState.getLicenseInformation$(); + if (licenseUpdates === null) { + throw new Error('License state has to be initialized before registering sample data'); + } + let registered = false; + licenseUpdates.subscribe(licenseInformation => { + if (!registered && licenseInformation.showAppLink) { + registered = true; + registerEcommerceSampleDataLink(sampleDataRegistry); + registerFlightsSampleDataLink(sampleDataRegistry); + registerLogsSampleDataLink(sampleDataRegistry); + } + }); +} From 8c0440f29ddc1d6966aa6556e0401e8580e10c6b Mon Sep 17 00:00:00 2001 From: Chris Davies Date: Tue, 14 Jan 2020 12:06:51 -0500 Subject: [PATCH 108/139] [Lens] Add clear layer feature (#53627) * [Lens] Add clear layer feature * Move clear / remove layer out of the context menu * Address code review comments * Remove xpack.lens.xyChart.deleteLayer translation * Get rid of unused Lens translations Co-authored-by: Elastic Machine --- .../visualization.test.tsx | 40 ++ .../visualization.tsx | 84 ++-- .../editor_frame/chart_switch.tsx | 1 - .../editor_frame/config_panel_wrapper.tsx | 279 +++++++++++-- .../editor_frame/editor_frame.test.tsx | 88 ++-- .../editor_frame/editor_frame.tsx | 36 +- .../editor_frame/layer_actions.test.ts | 115 ++++++ .../editor_frame/layer_actions.ts | 88 ++++ .../editor_frame/state_management.test.ts | 1 + .../editor_frame/state_management.ts | 16 + .../editor_frame/suggestion_helpers.ts | 3 +- .../editor_frame/suggestion_panel.tsx | 2 +- .../editor_frame/workspace_panel.test.tsx | 2 +- .../editor_frame/workspace_panel.tsx | 7 +- .../lens/public/editor_frame_plugin/mocks.tsx | 9 +- .../indexpattern_plugin/indexpattern.tsx | 24 +- .../metric_config_panel.test.tsx | 1 + .../metric_config_panel.tsx | 51 +-- .../metric_visualization.test.ts | 16 + .../metric_visualization.tsx | 13 +- x-pack/legacy/plugins/lens/public/types.ts | 18 +- .../xy_config_panel.test.tsx | 266 +++--------- .../xy_config_panel.tsx | 381 ++++++------------ .../xy_visualization.test.ts | 48 +++ .../xy_visualization.tsx | 64 ++- .../translations/translations/ja-JP.json | 2 - .../translations/translations/zh-CN.json | 2 - 27 files changed, 1018 insertions(+), 639 deletions(-) create mode 100644 x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/layer_actions.test.ts create mode 100644 x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/layer_actions.ts diff --git a/x-pack/legacy/plugins/lens/public/datatable_visualization_plugin/visualization.test.tsx b/x-pack/legacy/plugins/lens/public/datatable_visualization_plugin/visualization.test.tsx index 25d88fbae5b34..cb9350226575c 100644 --- a/x-pack/legacy/plugins/lens/public/datatable_visualization_plugin/visualization.test.tsx +++ b/x-pack/legacy/plugins/lens/public/datatable_visualization_plugin/visualization.test.tsx @@ -72,6 +72,42 @@ describe('Datatable Visualization', () => { }); }); + describe('#getLayerIds', () => { + it('return the layer ids', () => { + const state: DatatableVisualizationState = { + layers: [ + { + layerId: 'baz', + columns: ['a', 'b', 'c'], + }, + ], + }; + expect(datatableVisualization.getLayerIds(state)).toEqual(['baz']); + }); + }); + + describe('#clearLayer', () => { + it('should reset the layer', () => { + (generateId as jest.Mock).mockReturnValueOnce('testid'); + const state: DatatableVisualizationState = { + layers: [ + { + layerId: 'baz', + columns: ['a', 'b', 'c'], + }, + ], + }; + expect(datatableVisualization.clearLayer(state, 'baz')).toMatchObject({ + layers: [ + { + layerId: 'baz', + columns: ['testid'], + }, + ], + }); + }); + }); + describe('#getSuggestions', () => { function numCol(columnId: string): TableSuggestionColumn { return { @@ -188,6 +224,7 @@ describe('Datatable Visualization', () => { mount( {} }} frame={frame} layer={layer} @@ -224,6 +261,7 @@ describe('Datatable Visualization', () => { frame.datasourceLayers = { a: datasource.publicAPIMock }; const component = mount( {} }} frame={frame} layer={layer} @@ -258,6 +296,7 @@ describe('Datatable Visualization', () => { frame.datasourceLayers = { a: datasource.publicAPIMock }; const component = mount( {} }} frame={frame} layer={layer} @@ -290,6 +329,7 @@ describe('Datatable Visualization', () => { frame.datasourceLayers = { a: datasource.publicAPIMock }; const component = mount( {} }} frame={frame} layer={layer} diff --git a/x-pack/legacy/plugins/lens/public/datatable_visualization_plugin/visualization.tsx b/x-pack/legacy/plugins/lens/public/datatable_visualization_plugin/visualization.tsx index f9a7ec419a9b9..79a018635134f 100644 --- a/x-pack/legacy/plugins/lens/public/datatable_visualization_plugin/visualization.tsx +++ b/x-pack/legacy/plugins/lens/public/datatable_visualization_plugin/visualization.tsx @@ -6,19 +6,18 @@ import React from 'react'; import { render } from 'react-dom'; -import { EuiForm, EuiFormRow, EuiPanel, EuiSpacer } from '@elastic/eui'; +import { EuiFormRow } from '@elastic/eui'; import { i18n } from '@kbn/i18n'; import { I18nProvider } from '@kbn/i18n/react'; import { MultiColumnEditor } from '../multi_column_editor'; import { SuggestionRequest, Visualization, - VisualizationProps, + VisualizationLayerConfigProps, VisualizationSuggestion, Operation, } from '../types'; import { generateId } from '../id_generator'; -import { NativeRenderer } from '../native_renderer'; import chartTableSVG from '../assets/chart_datatable.svg'; export interface LayerState { @@ -56,7 +55,7 @@ export function DataTableLayer({ state, setState, dragDropContext, -}: { layer: LayerState } & VisualizationProps) { +}: { layer: LayerState } & VisualizationLayerConfigProps) { const datasource = frame.datasourceLayers[layer.layerId]; const originalOrder = datasource.getTableSpec().map(({ columnId }) => columnId); @@ -64,32 +63,24 @@ export function DataTableLayer({ const sortedColumns = Array.from(new Set(originalOrder.concat(layer.columns))); return ( - - + setState(updateColumns(state, layer, columns => [...columns, generateId()]))} + onRemove={column => + setState(updateColumns(state, layer, columns => columns.filter(c => c !== column))) + } + testSubj="datatable_columns" + data-test-subj="datatable_multicolumnEditor" /> - - - - setState(updateColumns(state, layer, columns => [...columns, generateId()]))} - onRemove={column => - setState(updateColumns(state, layer, columns => columns.filter(c => c !== column))) - } - testSubj="datatable_columns" - data-test-subj="datatable_multicolumnEditor" - /> - - + ); } @@ -110,7 +101,17 @@ export const datatableVisualization: Visualization< }, ], - getDescription(state) { + getLayerIds(state) { + return state.layers.map(l => l.layerId); + }, + + clearLayer(state) { + return { + layers: state.layers.map(l => newLayerState(l.layerId)), + }; + }, + + getDescription() { return { icon: chartTableSVG, label: i18n.translate('xpack.lens.datatable.label', { @@ -187,17 +188,18 @@ export const datatableVisualization: Visualization< ]; }, - renderConfigPanel: (domElement, props) => - render( - - - {props.state.layers.map(layer => ( - - ))} - - , - domElement - ), + renderLayerConfigPanel(domElement, props) { + const layer = props.state.layers.find(l => l.layerId === props.layerId); + + if (layer) { + render( + + + , + domElement + ); + } + }, toExpression(state, frame) { const layer = state.layers[0]; diff --git a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/chart_switch.tsx b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/chart_switch.tsx index dca6b3e7616d6..5e2fced577724 100644 --- a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/chart_switch.tsx +++ b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/chart_switch.tsx @@ -81,7 +81,6 @@ export function ChartSwitch(props: Props) { trackUiEvent(`chart_switch`); switchToSuggestion( - props.framePublicAPI, props.dispatch, { ...selection, diff --git a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/config_panel_wrapper.tsx b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/config_panel_wrapper.tsx index 4179a9455eefa..1422ee86be3e9 100644 --- a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/config_panel_wrapper.tsx +++ b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/config_panel_wrapper.tsx @@ -4,14 +4,36 @@ * you may not use this file except in compliance with the Elastic License. */ -import React, { useMemo, useContext, memo } from 'react'; +import React, { useMemo, useContext, memo, useState } from 'react'; +import { + EuiPanel, + EuiSpacer, + EuiPopover, + EuiButtonIcon, + EuiFlexGroup, + EuiFlexItem, + EuiButtonEmpty, + EuiToolTip, + EuiButton, + EuiForm, +} from '@elastic/eui'; +import { i18n } from '@kbn/i18n'; import { NativeRenderer } from '../../native_renderer'; import { Action } from './state_management'; -import { Visualization, FramePublicAPI, Datasource } from '../../types'; +import { + Visualization, + FramePublicAPI, + Datasource, + VisualizationLayerConfigProps, +} from '../../types'; import { DragContext } from '../../drag_drop'; import { ChartSwitch } from './chart_switch'; +import { trackUiEvent } from '../../lens_ui_telemetry'; +import { generateId } from '../../id_generator'; +import { removeLayer, appendLayer } from './layer_actions'; interface ConfigPanelWrapperProps { + activeDatasourceId: string; visualizationState: unknown; visualizationMap: Record; activeVisualizationId: string | null; @@ -28,17 +50,8 @@ interface ConfigPanelWrapperProps { } export const ConfigPanelWrapper = memo(function ConfigPanelWrapper(props: ConfigPanelWrapperProps) { - const context = useContext(DragContext); - const setVisualizationState = useMemo( - () => (newState: unknown) => { - props.dispatch({ - type: 'UPDATE_VISUALIZATION_STATE', - newState, - clearStagedPreview: false, - }); - }, - [props.dispatch] - ); + const activeVisualization = props.visualizationMap[props.activeVisualizationId || '']; + const { visualizationState } = props; return ( <> @@ -52,19 +65,235 @@ export const ConfigPanelWrapper = memo(function ConfigPanelWrapper(props: Config dispatch={props.dispatch} framePublicAPI={props.framePublicAPI} /> - {props.activeVisualizationId && props.visualizationState !== null && ( -
- -
+ {activeVisualization && visualizationState && ( + )} ); }); + +function LayerPanels( + props: ConfigPanelWrapperProps & { + activeDatasourceId: string; + activeVisualization: Visualization; + } +) { + const { + framePublicAPI, + activeVisualization, + visualizationState, + dispatch, + activeDatasourceId, + datasourceMap, + } = props; + const dragDropContext = useContext(DragContext); + const setState = useMemo( + () => (newState: unknown) => { + props.dispatch({ + type: 'UPDATE_VISUALIZATION_STATE', + visualizationId: activeVisualization.id, + newState, + clearStagedPreview: false, + }); + }, + [props.dispatch, activeVisualization] + ); + const layerIds = activeVisualization.getLayerIds(visualizationState); + + return ( + + {layerIds.map(layerId => ( + { + dispatch({ + type: 'UPDATE_STATE', + subType: 'REMOVE_OR_CLEAR_LAYER', + updater: state => + removeLayer({ + activeVisualization, + layerId, + trackUiEvent, + datasourceMap, + state, + }), + }); + }} + /> + ))} + {activeVisualization.appendLayer && ( + + + { + dispatch({ + type: 'UPDATE_STATE', + subType: 'ADD_LAYER', + updater: state => + appendLayer({ + activeVisualization, + generateId, + trackUiEvent, + activeDatasource: datasourceMap[activeDatasourceId], + state, + }), + }); + }} + iconType="plusInCircleFilled" + /> + + + )} + + ); +} + +function LayerPanel( + props: ConfigPanelWrapperProps & + VisualizationLayerConfigProps & { + isOnlyLayer: boolean; + activeVisualization: Visualization; + onRemove: () => void; + } +) { + const { framePublicAPI, layerId, activeVisualization, isOnlyLayer, onRemove } = props; + const datasourcePublicAPI = framePublicAPI.datasourceLayers[layerId]; + const layerConfigProps = { + layerId, + dragDropContext: props.dragDropContext, + state: props.visualizationState, + setState: props.setState, + frame: props.framePublicAPI, + }; + + return ( + + + + + + + {datasourcePublicAPI && ( + + + + )} + + + + + + + + + + + { + // If we don't blur the remove / clear button, it remains focused + // which is a strange UX in this case. e.target.blur doesn't work + // due to who knows what, but probably event re-writing. Additionally, + // activeElement does not have blur so, we need to do some casting + safeguards. + const el = (document.activeElement as unknown) as { blur: () => void }; + + if (el && el.blur) { + el.blur(); + } + + onRemove(); + }} + > + {isOnlyLayer + ? i18n.translate('xpack.lens.resetLayer', { + defaultMessage: 'Reset layer', + }) + : i18n.translate('xpack.lens.deleteLayer', { + defaultMessage: 'Delete layer', + })} + + + + + ); +} + +function LayerSettings({ + layerId, + activeVisualization, + layerConfigProps, +}: { + layerId: string; + activeVisualization: Visualization; + layerConfigProps: VisualizationLayerConfigProps; +}) { + const [isOpen, setIsOpen] = useState(false); + + if (!activeVisualization.renderLayerContextMenu) { + return null; + } + + return ( + setIsOpen(!isOpen)} + data-test-subj="lns_layer_settings" + /> + } + isOpen={isOpen} + closePopover={() => setIsOpen(false)} + anchorPosition="leftUp" + > + + + ); +} diff --git a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/editor_frame.test.tsx b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/editor_frame.test.tsx index cf711eea29b96..c9b9a43376651 100644 --- a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/editor_frame.test.tsx +++ b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/editor_frame.test.tsx @@ -9,7 +9,7 @@ import { ReactWrapper } from 'enzyme'; import { EuiPanel, EuiToolTip } from '@elastic/eui'; import { mountWithIntl as mount } from 'test_utils/enzyme_helpers'; import { EditorFrame } from './editor_frame'; -import { Visualization, DatasourcePublicAPI, DatasourceSuggestion } from '../../types'; +import { DatasourcePublicAPI, DatasourceSuggestion, Visualization } from '../../types'; import { act } from 'react-dom/test-utils'; import { coreMock } from 'src/core/public/mocks'; import { @@ -24,7 +24,11 @@ import { FrameLayout } from './frame_layout'; // calling this function will wait for all pending Promises from mock // datasources to be processed by its callers. -const waitForPromises = () => new Promise(resolve => setTimeout(resolve)); +async function waitForPromises(n = 3) { + for (let i = 0; i < n; ++i) { + await Promise.resolve(); + } +} function generateSuggestion(state = {}): DatasourceSuggestion { return { @@ -88,6 +92,9 @@ describe('editor_frame', () => { ], }; + mockVisualization.getLayerIds.mockReturnValue(['first']); + mockVisualization2.getLayerIds.mockReturnValue(['second']); + mockDatasource = createMockDatasource(); mockDatasource2 = createMockDatasource(); @@ -202,7 +209,7 @@ describe('editor_frame', () => { ); }); - expect(mockVisualization.renderConfigPanel).not.toHaveBeenCalled(); + expect(mockVisualization.renderLayerConfigPanel).not.toHaveBeenCalled(); expect(mockDatasource.renderDataPanel).not.toHaveBeenCalled(); }); @@ -294,6 +301,7 @@ describe('editor_frame', () => { it('should remove layer on active datasource on frame api call', async () => { const initialState = { datasource2: '' }; + mockDatasource.getLayers.mockReturnValue(['first']); mockDatasource2.initialize.mockReturnValue(Promise.resolve(initialState)); mockDatasource2.getLayers.mockReturnValue(['abc', 'def']); mockDatasource2.removeLayer.mockReturnValue({ removed: true }); @@ -361,7 +369,7 @@ describe('editor_frame', () => { it('should initialize visualization state and render config panel', async () => { const initialState = {}; - + mockDatasource.getLayers.mockReturnValue(['first']); mount( { await waitForPromises(); - expect(mockVisualization.renderConfigPanel).toHaveBeenCalledWith( + expect(mockVisualization.renderLayerConfigPanel).toHaveBeenCalledWith( expect.any(Element), expect.objectContaining({ state: initialState }) ); @@ -390,6 +398,7 @@ describe('editor_frame', () => { it('should render the resulting expression using the expression renderer', async () => { mockDatasource.getLayers.mockReturnValue(['first']); + const instance = mount( { /> ); - await waitForPromises(); await waitForPromises(); instance.update(); @@ -601,6 +609,7 @@ describe('editor_frame', () => { describe('state update', () => { it('should re-render config panel after state update', async () => { + mockDatasource.getLayers.mockReturnValue(['first']); mount( { await waitForPromises(); const updatedState = {}; - const setVisualizationState = (mockVisualization.renderConfigPanel as jest.Mock).mock + const setVisualizationState = (mockVisualization.renderLayerConfigPanel as jest.Mock).mock .calls[0][1].setState; act(() => { setVisualizationState(updatedState); }); - expect(mockVisualization.renderConfigPanel).toHaveBeenCalledTimes(2); - expect(mockVisualization.renderConfigPanel).toHaveBeenLastCalledWith( + expect(mockVisualization.renderLayerConfigPanel).toHaveBeenCalledTimes(2); + expect(mockVisualization.renderLayerConfigPanel).toHaveBeenLastCalledWith( expect.any(Element), expect.objectContaining({ state: updatedState, @@ -635,6 +644,7 @@ describe('editor_frame', () => { }); it('should re-render data panel after state update', async () => { + mockDatasource.getLayers.mockReturnValue(['first']); mount( { await waitForPromises(); - const updatedPublicAPI = {}; - mockDatasource.getPublicAPI.mockReturnValue( - (updatedPublicAPI as unknown) as DatasourcePublicAPI - ); + const updatedPublicAPI: DatasourcePublicAPI = { + renderLayerPanel: jest.fn(), + renderDimensionPanel: jest.fn(), + getOperationForColumnId: jest.fn(), + getTableSpec: jest.fn(), + }; + mockDatasource.getPublicAPI.mockReturnValue(updatedPublicAPI); const setDatasourceState = (mockDatasource.renderDataPanel as jest.Mock).mock.calls[0][1] .setState; @@ -700,8 +713,8 @@ describe('editor_frame', () => { setDatasourceState({}); }); - expect(mockVisualization.renderConfigPanel).toHaveBeenCalledTimes(2); - expect(mockVisualization.renderConfigPanel).toHaveBeenLastCalledWith( + expect(mockVisualization.renderLayerConfigPanel).toHaveBeenCalledTimes(2); + expect(mockVisualization.renderLayerConfigPanel).toHaveBeenLastCalledWith( expect.any(Element), expect.objectContaining({ frame: expect.objectContaining({ @@ -754,10 +767,10 @@ describe('editor_frame', () => { await waitForPromises(); - expect(mockVisualization.renderConfigPanel).toHaveBeenCalled(); + expect(mockVisualization.renderLayerConfigPanel).toHaveBeenCalled(); const datasourceLayers = - mockVisualization.renderConfigPanel.mock.calls[0][1].frame.datasourceLayers; + mockVisualization.renderLayerConfigPanel.mock.calls[0][1].frame.datasourceLayers; expect(datasourceLayers.first).toBe(mockDatasource.publicAPIMock); expect(datasourceLayers.second).toBe(mockDatasource2.publicAPIMock); expect(datasourceLayers.third).toBe(mockDatasource2.publicAPIMock); @@ -919,7 +932,7 @@ describe('editor_frame', () => { } beforeEach(async () => { - mockDatasource.getLayers.mockReturnValue(['first']); + mockDatasource.getLayers.mockReturnValue(['first', 'second']); mockDatasource.getDatasourceSuggestionsFromCurrentState.mockReturnValue([ { state: {}, @@ -1018,7 +1031,7 @@ describe('editor_frame', () => { expect(mockVisualization2.getSuggestions).toHaveBeenCalled(); expect(mockVisualization2.initialize).toHaveBeenCalledWith(expect.anything(), initialState); - expect(mockVisualization2.renderConfigPanel).toHaveBeenCalledWith( + expect(mockVisualization2.renderLayerConfigPanel).toHaveBeenCalledWith( expect.any(Element), expect.objectContaining({ state: { initial: true } }) ); @@ -1032,9 +1045,11 @@ describe('editor_frame', () => { expect(mockDatasource.publicAPIMock.getTableSpec).toHaveBeenCalled(); expect(mockVisualization2.getSuggestions).toHaveBeenCalled(); expect(mockVisualization2.initialize).toHaveBeenCalledWith( - expect.objectContaining({ datasourceLayers: { first: mockDatasource.publicAPIMock } }) + expect.objectContaining({ + datasourceLayers: expect.objectContaining({ first: mockDatasource.publicAPIMock }), + }) ); - expect(mockVisualization2.renderConfigPanel).toHaveBeenCalledWith( + expect(mockVisualization2.renderLayerConfigPanel).toHaveBeenCalledWith( expect.any(Element), expect.objectContaining({ state: { initial: true } }) ); @@ -1102,6 +1117,7 @@ describe('editor_frame', () => { }); it('should display top 5 suggestions in descending order', async () => { + mockDatasource.getLayers.mockReturnValue(['first']); const instance = mount( { }); it('should switch to suggested visualization', async () => { + mockDatasource.getLayers.mockReturnValue(['first', 'second', 'third']); const newDatasourceState = {}; const suggestionVisState = {}; const instance = mount( @@ -1228,8 +1245,8 @@ describe('editor_frame', () => { .simulate('click'); }); - expect(mockVisualization.renderConfigPanel).toHaveBeenCalledTimes(1); - expect(mockVisualization.renderConfigPanel).toHaveBeenCalledWith( + expect(mockVisualization.renderLayerConfigPanel).toHaveBeenCalledTimes(1); + expect(mockVisualization.renderLayerConfigPanel).toHaveBeenCalledWith( expect.any(Element), expect.objectContaining({ state: suggestionVisState, @@ -1244,6 +1261,7 @@ describe('editor_frame', () => { }); it('should switch to best suggested visualization on field drop', async () => { + mockDatasource.getLayers.mockReturnValue(['first']); const suggestionVisState = {}; const instance = mount( { .simulate('drop'); }); - expect(mockVisualization.renderConfigPanel).toHaveBeenCalledWith( + expect(mockVisualization.renderLayerConfigPanel).toHaveBeenCalledWith( expect.any(Element), expect.objectContaining({ state: suggestionVisState, @@ -1302,6 +1320,7 @@ describe('editor_frame', () => { }); it('should use the currently selected visualization if possible on field drop', async () => { + mockDatasource.getLayers.mockReturnValue(['first', 'second', 'third']); const suggestionVisState = {}; const instance = mount( { }); }); - expect(mockVisualization2.renderConfigPanel).toHaveBeenCalledWith( + expect(mockVisualization2.renderLayerConfigPanel).toHaveBeenCalledWith( expect.any(Element), expect.objectContaining({ state: suggestionVisState, @@ -1375,10 +1394,12 @@ describe('editor_frame', () => { }); it('should use the highest priority suggestion available', async () => { + mockDatasource.getLayers.mockReturnValue(['first', 'second', 'third']); const suggestionVisState = {}; const mockVisualization3 = { ...createMockVisualization(), id: 'testVis3', + getLayerIds: () => ['third'], visualizationTypes: [ { icon: 'empty', @@ -1460,7 +1481,7 @@ describe('editor_frame', () => { }); }); - expect(mockVisualization3.renderConfigPanel).toHaveBeenCalledWith( + expect(mockVisualization3.renderLayerConfigPanel).toHaveBeenCalledWith( expect.any(Element), expect.objectContaining({ state: suggestionVisState, @@ -1633,13 +1654,16 @@ describe('editor_frame', () => { await waitForPromises(); expect(onChange).toHaveBeenCalledTimes(2); - (instance.find(FrameLayout).prop('dataPanel') as ReactElement)!.props.dispatch({ - type: 'UPDATE_DATASOURCE_STATE', - updater: () => ({ - newState: true, - }), - datasourceId: 'testDatasource', + act(() => { + (instance.find(FrameLayout).prop('dataPanel') as ReactElement)!.props.dispatch({ + type: 'UPDATE_DATASOURCE_STATE', + updater: () => ({ + newState: true, + }), + datasourceId: 'testDatasource', + }); }); + await waitForPromises(); expect(onChange).toHaveBeenCalledTimes(3); diff --git a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/editor_frame.tsx b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/editor_frame.tsx index a2745818e19bb..3284f69b503c5 100644 --- a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/editor_frame.tsx +++ b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/editor_frame.tsx @@ -52,6 +52,8 @@ export interface EditorFrameProps { export function EditorFrame(props: EditorFrameProps) { const [state, dispatch] = useReducer(reducer, props, getInitialState); const { onError } = props; + const activeVisualization = + state.visualization.activeId && props.visualizationMap[state.visualization.activeId]; const allLoaded = Object.values(state.datasourceStates).every( ({ isLoading }) => typeof isLoading === 'boolean' && !isLoading @@ -125,7 +127,20 @@ export function EditorFrame(props: EditorFrameProps) { return newLayerId; }, - removeLayers: (layerIds: string[]) => { + + removeLayers(layerIds: string[]) { + if (activeVisualization && activeVisualization.removeLayer && state.visualization.state) { + dispatch({ + type: 'UPDATE_VISUALIZATION_STATE', + visualizationId: activeVisualization.id, + newState: layerIds.reduce( + (acc, layerId) => + activeVisualization.removeLayer ? activeVisualization.removeLayer(acc, layerId) : acc, + state.visualization.state + ), + }); + } + layerIds.forEach(layerId => { const layerDatasourceId = Object.entries(props.datasourceMap).find( ([datasourceId, datasource]) => @@ -158,16 +173,15 @@ export function EditorFrame(props: EditorFrameProps) { // Initialize visualization as soon as all datasources are ready useEffect(() => { - if (allLoaded && state.visualization.state === null && state.visualization.activeId !== null) { - const initialVisualizationState = props.visualizationMap[ - state.visualization.activeId - ].initialize(framePublicAPI); + if (allLoaded && state.visualization.state === null && activeVisualization) { + const initialVisualizationState = activeVisualization.initialize(framePublicAPI); dispatch({ type: 'UPDATE_VISUALIZATION_STATE', + visualizationId: activeVisualization.id, newState: initialVisualizationState, }); } - }, [allLoaded, state.visualization.activeId, state.visualization.state]); + }, [allLoaded, activeVisualization, state.visualization.state]); // The frame needs to call onChange every time its internal state changes useEffect(() => { @@ -176,11 +190,7 @@ export function EditorFrame(props: EditorFrameProps) { ? props.datasourceMap[state.activeDatasourceId] : undefined; - const visualization = state.visualization.activeId - ? props.visualizationMap[state.visualization.activeId] - : undefined; - - if (!activeDatasource || !visualization) { + if (!activeDatasource || !activeVisualization) { return; } @@ -208,13 +218,14 @@ export function EditorFrame(props: EditorFrameProps) { }), {} ), - visualization, + visualization: activeVisualization, state, framePublicAPI, }); props.onChange({ filterableIndexPatterns: indexPatterns, doc }); }, [ + activeVisualization, state.datasourceStates, state.visualization, props.query, @@ -248,6 +259,7 @@ export function EditorFrame(props: EditorFrameProps) { configPanel={ allLoaded && ( ({ + id: datasourceId, + clearLayer: (layerIds: unknown, layerId: string) => + (layerIds as string[]).map((id: string) => + id === layerId ? `${datasourceId}_clear_${layerId}` : id + ), + removeLayer: (layerIds: unknown, layerId: string) => + (layerIds as string[]).filter((id: string) => id !== layerId), + insertLayer: (layerIds: unknown, layerId: string) => [...(layerIds as string[]), layerId], + }); + + const activeVisualization = { + clearLayer: (layerIds: unknown, layerId: string) => + (layerIds as string[]).map((id: string) => (id === layerId ? `vis_clear_${layerId}` : id)), + removeLayer: (layerIds: unknown, layerId: string) => + (layerIds as string[]).filter((id: string) => id !== layerId), + getLayerIds: (layerIds: unknown) => layerIds as string[], + appendLayer: (layerIds: unknown, layerId: string) => [...(layerIds as string[]), layerId], + }; + + return { + state: { + activeDatasourceId: 'ds1', + datasourceStates: { + ds1: { + isLoading: false, + state: initialLayerIds.slice(0, 1), + }, + ds2: { + isLoading: false, + state: initialLayerIds.slice(1), + }, + }, + title: 'foo', + visualization: { + activeId: 'vis1', + state: initialLayerIds, + }, + }, + activeVisualization, + datasourceMap: { + ds1: testDatasource('ds1'), + ds2: testDatasource('ds2'), + }, + trackUiEvent, + }; +} + +describe('removeLayer', () => { + it('should clear the layer if it is the only layer', () => { + const { state, trackUiEvent, datasourceMap, activeVisualization } = createTestArgs(['layer1']); + const newState = removeLayer({ + activeVisualization, + datasourceMap, + layerId: 'layer1', + state, + trackUiEvent, + }); + + expect(newState.visualization.state).toEqual(['vis_clear_layer1']); + expect(newState.datasourceStates.ds1.state).toEqual(['ds1_clear_layer1']); + expect(newState.datasourceStates.ds2.state).toEqual([]); + expect(trackUiEvent).toHaveBeenCalledWith('layer_cleared'); + }); + + it('should remove the layer if it is not the only layer', () => { + const { state, trackUiEvent, datasourceMap, activeVisualization } = createTestArgs([ + 'layer1', + 'layer2', + ]); + const newState = removeLayer({ + activeVisualization, + datasourceMap, + layerId: 'layer1', + state, + trackUiEvent, + }); + + expect(newState.visualization.state).toEqual(['layer2']); + expect(newState.datasourceStates.ds1.state).toEqual([]); + expect(newState.datasourceStates.ds2.state).toEqual(['layer2']); + expect(trackUiEvent).toHaveBeenCalledWith('layer_removed'); + }); +}); + +describe('appendLayer', () => { + it('should add the layer to the datasource and visualization', () => { + const { state, trackUiEvent, datasourceMap, activeVisualization } = createTestArgs([ + 'layer1', + 'layer2', + ]); + const newState = appendLayer({ + activeDatasource: datasourceMap.ds1, + activeVisualization, + generateId: () => 'foo', + state, + trackUiEvent, + }); + + expect(newState.visualization.state).toEqual(['layer1', 'layer2', 'foo']); + expect(newState.datasourceStates.ds1.state).toEqual(['layer1', 'foo']); + expect(newState.datasourceStates.ds2.state).toEqual(['layer2']); + expect(trackUiEvent).toHaveBeenCalledWith('layer_added'); + }); +}); diff --git a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/layer_actions.ts b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/layer_actions.ts new file mode 100644 index 0000000000000..e0562e8ca8e11 --- /dev/null +++ b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/layer_actions.ts @@ -0,0 +1,88 @@ +/* + * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one + * or more contributor license agreements. Licensed under the Elastic License; + * you may not use this file except in compliance with the Elastic License. + */ + +import _ from 'lodash'; +import { EditorFrameState } from './state_management'; +import { Datasource, Visualization } from '../../types'; + +interface RemoveLayerOptions { + trackUiEvent: (name: string) => void; + state: EditorFrameState; + layerId: string; + activeVisualization: Pick; + datasourceMap: Record>; +} + +interface AppendLayerOptions { + trackUiEvent: (name: string) => void; + state: EditorFrameState; + generateId: () => string; + activeDatasource: Pick; + activeVisualization: Pick; +} + +export function removeLayer(opts: RemoveLayerOptions): EditorFrameState { + const { state, trackUiEvent: trackUiEvent, activeVisualization, layerId, datasourceMap } = opts; + const isOnlyLayer = activeVisualization + .getLayerIds(state.visualization.state) + .every(id => id === opts.layerId); + + trackUiEvent(isOnlyLayer ? 'layer_cleared' : 'layer_removed'); + + return { + ...state, + datasourceStates: _.mapValues(state.datasourceStates, (datasourceState, datasourceId) => { + const datasource = datasourceMap[datasourceId!]; + return { + ...datasourceState, + state: isOnlyLayer + ? datasource.clearLayer(datasourceState.state, layerId) + : datasource.removeLayer(datasourceState.state, layerId), + }; + }), + visualization: { + ...state.visualization, + state: + isOnlyLayer || !activeVisualization.removeLayer + ? activeVisualization.clearLayer(state.visualization.state, layerId) + : activeVisualization.removeLayer(state.visualization.state, layerId), + }, + }; +} + +export function appendLayer({ + trackUiEvent, + activeVisualization, + state, + generateId, + activeDatasource, +}: AppendLayerOptions): EditorFrameState { + trackUiEvent('layer_added'); + + if (!activeVisualization.appendLayer) { + return state; + } + + const layerId = generateId(); + + return { + ...state, + datasourceStates: { + ...state.datasourceStates, + [activeDatasource.id]: { + ...state.datasourceStates[activeDatasource.id], + state: activeDatasource.insertLayer( + state.datasourceStates[activeDatasource.id].state, + layerId + ), + }, + }, + visualization: { + ...state.visualization, + state: activeVisualization.appendLayer(state.visualization.state, layerId), + }, + }; +} diff --git a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/state_management.test.ts b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/state_management.test.ts index 5168059a33258..4aaf2a3ee9e81 100644 --- a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/state_management.test.ts +++ b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/state_management.test.ts @@ -119,6 +119,7 @@ describe('editor_frame state management', () => { }, { type: 'UPDATE_VISUALIZATION_STATE', + visualizationId: 'testVis', newState: newVisState, } ); diff --git a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/state_management.ts b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/state_management.ts index 78a9a13f48d6a..7d763bcac2cc9 100644 --- a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/state_management.ts +++ b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/state_management.ts @@ -31,6 +31,13 @@ export type Action = type: 'UPDATE_TITLE'; title: string; } + | { + type: 'UPDATE_STATE'; + // Just for diagnostics, so we can determine what action + // caused this update. + subType: string; + updater: (prevState: EditorFrameState) => EditorFrameState; + } | { type: 'UPDATE_DATASOURCE_STATE'; updater: unknown | ((prevState: unknown) => unknown); @@ -39,6 +46,7 @@ export type Action = } | { type: 'UPDATE_VISUALIZATION_STATE'; + visualizationId: string; newState: unknown; clearStagedPreview?: boolean; } @@ -128,6 +136,8 @@ export const reducer = (state: EditorFrameState, action: Action): EditorFrameSta return action.state; case 'UPDATE_TITLE': return { ...state, title: action.title }; + case 'UPDATE_STATE': + return action.updater(state); case 'UPDATE_LAYER': return { ...state, @@ -249,6 +259,12 @@ export const reducer = (state: EditorFrameState, action: Action): EditorFrameSta if (!state.visualization.activeId) { throw new Error('Invariant: visualization state got updated without active visualization'); } + // This is a safeguard that prevents us from accidentally updating the + // wrong visualization. This occurs in some cases due to the uncoordinated + // way we manage state across plugins. + if (state.visualization.activeId !== action.visualizationId) { + return state; + } return { ...state, visualization: { diff --git a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/suggestion_helpers.ts b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/suggestion_helpers.ts index 173f64c6292a8..eabcdfa7a24ab 100644 --- a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/suggestion_helpers.ts +++ b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/suggestion_helpers.ts @@ -10,7 +10,6 @@ import { IconType } from '@elastic/eui/src/components/icon/icon'; import { Visualization, Datasource, - FramePublicAPI, TableChangeType, TableSuggestion, DatasourceSuggestion, @@ -130,7 +129,6 @@ function getVisualizationSuggestions( } export function switchToSuggestion( - frame: FramePublicAPI, dispatch: (action: Action) => void, suggestion: Pick< Suggestion, @@ -145,5 +143,6 @@ export function switchToSuggestion( datasourceState: suggestion.datasourceState, datasourceId: suggestion.datasourceId!, }; + dispatch(action); } diff --git a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/suggestion_panel.tsx b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/suggestion_panel.tsx index 2408d004689c9..46e226afe9c59 100644 --- a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/suggestion_panel.tsx +++ b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/suggestion_panel.tsx @@ -320,7 +320,7 @@ export function SuggestionPanel({ } else { trackSuggestionEvent(`position_${index}_of_${suggestions.length}`); setLastSelectedSuggestion(index); - switchToSuggestion(frame, dispatch, suggestion); + switchToSuggestion(dispatch, suggestion); } }} selected={index === lastSelectedSuggestion} diff --git a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/workspace_panel.test.tsx b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/workspace_panel.test.tsx index fb3fe770b315b..74dacd50d7a15 100644 --- a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/workspace_panel.test.tsx +++ b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/workspace_panel.test.tsx @@ -6,7 +6,7 @@ import React from 'react'; import { ExpressionRendererProps } from '../../../../../../../src/plugins/expressions/public'; -import { Visualization, FramePublicAPI, TableSuggestion } from '../../types'; +import { FramePublicAPI, TableSuggestion, Visualization } from '../../types'; import { createMockVisualization, createMockDatasource, diff --git a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/workspace_panel.tsx b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/workspace_panel.tsx index 05dcafcaeba31..1058ccd81d669 100644 --- a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/workspace_panel.tsx +++ b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/editor_frame/workspace_panel.tsx @@ -126,12 +126,7 @@ export function InnerWorkspacePanel({ if (suggestionForDraggedField) { trackUiEvent('drop_onto_workspace'); trackUiEvent(expression ? 'drop_non_empty' : 'drop_empty'); - switchToSuggestion( - framePublicAPI, - dispatch, - suggestionForDraggedField, - 'SWITCH_VISUALIZATION' - ); + switchToSuggestion(dispatch, suggestionForDraggedField, 'SWITCH_VISUALIZATION'); } } diff --git a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/mocks.tsx b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/mocks.tsx index 5df6cc8106d6a..7257647d5953e 100644 --- a/x-pack/legacy/plugins/lens/public/editor_frame_plugin/mocks.tsx +++ b/x-pack/legacy/plugins/lens/public/editor_frame_plugin/mocks.tsx @@ -14,12 +14,14 @@ import { import { embeddablePluginMock } from '../../../../../../src/plugins/embeddable/public/mocks'; // eslint-disable-next-line @kbn/eslint/no-restricted-paths import { expressionsPluginMock } from '../../../../../../src/plugins/expressions/public/mocks'; -import { DatasourcePublicAPI, FramePublicAPI, Visualization, Datasource } from '../types'; +import { DatasourcePublicAPI, FramePublicAPI, Datasource, Visualization } from '../types'; import { EditorFrameSetupPlugins, EditorFrameStartPlugins } from './plugin'; export function createMockVisualization(): jest.Mocked { return { id: 'TEST_VIS', + clearLayer: jest.fn((state, _layerId) => state), + getLayerIds: jest.fn(_state => ['layer1']), visualizationTypes: [ { icon: 'empty', @@ -32,7 +34,7 @@ export function createMockVisualization(): jest.Mocked { getPersistableState: jest.fn(_state => _state), getSuggestions: jest.fn(_options => []), initialize: jest.fn((_frame, _state?) => ({})), - renderConfigPanel: jest.fn(), + renderLayerConfigPanel: jest.fn(), toExpression: jest.fn((_state, _frame) => null), toPreviewExpression: jest.fn((_state, _frame) => null), }; @@ -52,7 +54,8 @@ export function createMockDatasource(): DatasourceMock { return { id: 'mockindexpattern', - getDatasourceSuggestionsForField: jest.fn((_state, item) => []), + clearLayer: jest.fn((state, _layerId) => state), + getDatasourceSuggestionsForField: jest.fn((_state, _item) => []), getDatasourceSuggestionsFromCurrentState: jest.fn(_state => []), getPersistableState: jest.fn(), getPublicAPI: jest.fn().mockReturnValue(publicAPIMock), diff --git a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/indexpattern.tsx b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/indexpattern.tsx index b58a2d8ca52c7..2426d7fc14b5d 100644 --- a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/indexpattern.tsx +++ b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/indexpattern.tsx @@ -132,11 +132,7 @@ export function getIndexPatternDatasource({ ...state, layers: { ...state.layers, - [newLayerId]: { - indexPatternId: state.currentIndexPatternId, - columns: {}, - columnOrder: [], - }, + [newLayerId]: blankLayer(state.currentIndexPatternId), }, }; }, @@ -151,6 +147,16 @@ export function getIndexPatternDatasource({ }; }, + clearLayer(state: IndexPatternPrivateState, layerId: string) { + return { + ...state, + layers: { + ...state.layers, + [layerId]: blankLayer(state.currentIndexPatternId), + }, + }; + }, + getLayers(state: IndexPatternPrivateState) { return Object.keys(state.layers); }, @@ -280,3 +286,11 @@ export function getIndexPatternDatasource({ return indexPatternDatasource; } + +function blankLayer(indexPatternId: string) { + return { + indexPatternId, + columns: {}, + columnOrder: [], + }; +} diff --git a/x-pack/legacy/plugins/lens/public/metric_visualization_plugin/metric_config_panel.test.tsx b/x-pack/legacy/plugins/lens/public/metric_visualization_plugin/metric_config_panel.test.tsx index ff2e55ac83dcc..a66239e5d30f6 100644 --- a/x-pack/legacy/plugins/lens/public/metric_visualization_plugin/metric_config_panel.test.tsx +++ b/x-pack/legacy/plugins/lens/public/metric_visualization_plugin/metric_config_panel.test.tsx @@ -38,6 +38,7 @@ describe('MetricConfigPanel', () => { const state = testState(); const component = mount( !op.isBucketed && op.dataType === 'number'; -export function MetricConfigPanel(props: VisualizationProps) { - const { state, frame } = props; - const [datasource] = Object.values(frame.datasourceLayers); - const [layerId] = Object.keys(frame.datasourceLayers); +export function MetricConfigPanel(props: VisualizationLayerConfigProps) { + const { state, frame, layerId } = props; + const datasource = frame.datasourceLayers[layerId]; return ( - - - - - - - - - + + + ); } diff --git a/x-pack/legacy/plugins/lens/public/metric_visualization_plugin/metric_visualization.test.ts b/x-pack/legacy/plugins/lens/public/metric_visualization_plugin/metric_visualization.test.ts index a95b5a2b27631..c131612399cca 100644 --- a/x-pack/legacy/plugins/lens/public/metric_visualization_plugin/metric_visualization.test.ts +++ b/x-pack/legacy/plugins/lens/public/metric_visualization_plugin/metric_visualization.test.ts @@ -50,6 +50,22 @@ describe('metric_visualization', () => { }); }); + describe('#getLayerIds', () => { + it('returns the layer id', () => { + expect(metricVisualization.getLayerIds(exampleState())).toEqual(['l1']); + }); + }); + + describe('#clearLayer', () => { + it('returns a clean layer', () => { + (generateId as jest.Mock).mockReturnValueOnce('test-id1'); + expect(metricVisualization.clearLayer(exampleState(), 'l1')).toEqual({ + accessor: 'test-id1', + layerId: 'l1', + }); + }); + }); + describe('#getPersistableState', () => { it('persists the state as given', () => { expect(metricVisualization.getPersistableState(exampleState())).toEqual(exampleState()); diff --git a/x-pack/legacy/plugins/lens/public/metric_visualization_plugin/metric_visualization.tsx b/x-pack/legacy/plugins/lens/public/metric_visualization_plugin/metric_visualization.tsx index 00e945c0ce6e5..6714c05787837 100644 --- a/x-pack/legacy/plugins/lens/public/metric_visualization_plugin/metric_visualization.tsx +++ b/x-pack/legacy/plugins/lens/public/metric_visualization_plugin/metric_visualization.tsx @@ -54,6 +54,17 @@ export const metricVisualization: Visualization = { }, ], + clearLayer(state) { + return { + ...state, + accessor: generateId(), + }; + }, + + getLayerIds(state) { + return [state.layerId]; + }, + getDescription() { return { icon: chartMetricSVG, @@ -76,7 +87,7 @@ export const metricVisualization: Visualization = { getPersistableState: state => state, - renderConfigPanel: (domElement, props) => + renderLayerConfigPanel: (domElement, props) => render( diff --git a/x-pack/legacy/plugins/lens/public/types.ts b/x-pack/legacy/plugins/lens/public/types.ts index f83157b2a8000..923e0aff5ae0e 100644 --- a/x-pack/legacy/plugins/lens/public/types.ts +++ b/x-pack/legacy/plugins/lens/public/types.ts @@ -135,6 +135,7 @@ export interface Datasource { insertLayer: (state: T, newLayerId: string) => T; removeLayer: (state: T, layerId: string) => T; + clearLayer: (state: T, layerId: string) => T; getLayers: (state: T) => string[]; renderDataPanel: (domElement: Element, props: DatasourceDataPanelProps) => void; @@ -237,7 +238,8 @@ export interface LensMultiTable { }; } -export interface VisualizationProps { +export interface VisualizationLayerConfigProps { + layerId: string; dragDropContext: DragContextState; frame: FramePublicAPI; state: T; @@ -325,6 +327,18 @@ export interface Visualization { visualizationTypes: VisualizationType[]; + getLayerIds: (state: T) => string[]; + + clearLayer: (state: T, layerId: string) => T; + + removeLayer?: (state: T, layerId: string) => T; + + appendLayer?: (state: T, layerId: string) => T; + + getLayerContextMenuIcon?: (opts: { state: T; layerId: string }) => IconType | undefined; + + renderLayerContextMenu?: (domElement: Element, props: VisualizationLayerConfigProps) => void; + getDescription: ( state: T ) => { @@ -339,7 +353,7 @@ export interface Visualization { getPersistableState: (state: T) => P; - renderConfigPanel: (domElement: Element, props: VisualizationProps) => void; + renderLayerConfigPanel: (domElement: Element, props: VisualizationLayerConfigProps) => void; toExpression: (state: T, frame: FramePublicAPI) => Ast | string | null; diff --git a/x-pack/legacy/plugins/lens/public/xy_visualization_plugin/xy_config_panel.test.tsx b/x-pack/legacy/plugins/lens/public/xy_visualization_plugin/xy_config_panel.test.tsx index 5cdf1031a22b0..6ed827bc71c68 100644 --- a/x-pack/legacy/plugins/lens/public/xy_visualization_plugin/xy_config_panel.test.tsx +++ b/x-pack/legacy/plugins/lens/public/xy_visualization_plugin/xy_config_panel.test.tsx @@ -8,9 +8,9 @@ import React from 'react'; import { ReactWrapper } from 'enzyme'; import { mountWithIntl as mount } from 'test_utils/enzyme_helpers'; import { EuiButtonGroupProps } from '@elastic/eui'; -import { XYConfigPanel } from './xy_config_panel'; +import { XYConfigPanel, LayerContextMenu } from './xy_config_panel'; import { DatasourceDimensionPanelProps, Operation, FramePublicAPI } from '../types'; -import { State, XYState } from './types'; +import { State } from './types'; import { Position } from '@elastic/charts'; import { NativeRendererProps } from '../native_renderer'; import { generateId } from '../id_generator'; @@ -46,15 +46,6 @@ describe('XYConfigPanel', () => { .props(); } - function openComponentPopover(component: ReactWrapper, layerId: string) { - component - .find(`[data-test-subj="lnsXY_layer_${layerId}"]`) - .first() - .find(`[data-test-subj="lnsXY_layer_advanced"]`) - .first() - .simulate('click'); - } - beforeEach(() => { frame = createMockFramePublicAPI(); frame.datasourceLayers = { @@ -67,55 +58,55 @@ describe('XYConfigPanel', () => { test.skip('allows toggling the y axis gridlines', () => {}); test.skip('allows toggling the x axis gridlines', () => {}); - test('enables stacked chart types even when there is no split series', () => { - const state = testState(); - const component = mount( - - ); - - openComponentPopover(component, 'first'); - - const options = component - .find('[data-test-subj="lnsXY_seriesType"]') - .first() - .prop('options') as EuiButtonGroupProps['options']; + describe('LayerContextMenu', () => { + test('enables stacked chart types even when there is no split series', () => { + const state = testState(); + const component = mount( + + ); - expect(options!.map(({ id }) => id)).toEqual([ - 'bar', - 'bar_stacked', - 'line', - 'area', - 'area_stacked', - ]); + const options = component + .find('[data-test-subj="lnsXY_seriesType"]') + .first() + .prop('options') as EuiButtonGroupProps['options']; - expect(options!.filter(({ isDisabled }) => isDisabled).map(({ id }) => id)).toEqual([]); - }); + expect(options!.map(({ id }) => id)).toEqual([ + 'bar', + 'bar_stacked', + 'line', + 'area', + 'area_stacked', + ]); - test('shows only horizontal bar options when in horizontal mode', () => { - const state = testState(); - const component = mount( - - ); + expect(options!.filter(({ isDisabled }) => isDisabled).map(({ id }) => id)).toEqual([]); + }); - openComponentPopover(component, 'first'); + test('shows only horizontal bar options when in horizontal mode', () => { + const state = testState(); + const component = mount( + + ); - const options = component - .find('[data-test-subj="lnsXY_seriesType"]') - .first() - .prop('options') as EuiButtonGroupProps['options']; + const options = component + .find('[data-test-subj="lnsXY_seriesType"]') + .first() + .prop('options') as EuiButtonGroupProps['options']; - expect(options!.map(({ id }) => id)).toEqual(['bar_horizontal', 'bar_horizontal_stacked']); - expect(options!.filter(({ isDisabled }) => isDisabled).map(({ id }) => id)).toEqual([]); + expect(options!.map(({ id }) => id)).toEqual(['bar_horizontal', 'bar_horizontal_stacked']); + expect(options!.filter(({ isDisabled }) => isDisabled).map(({ id }) => id)).toEqual([]); + }); }); test('the x dimension panel accepts only bucketed operations', () => { @@ -123,6 +114,7 @@ describe('XYConfigPanel', () => { const state = testState(); const component = mount( { const state = testState(); const component = mount( { const state = testState(); const component = mount( { /> ); - openComponentPopover(component, 'first'); - const onRemove = component .find('[data-test-subj="lensXY_yDimensionPanel"]') .first() @@ -223,6 +215,7 @@ describe('XYConfigPanel', () => { const state = testState(); const component = mount( { ], }); }); - - describe('layers', () => { - it('adds layers', () => { - frame.addNewLayer = jest.fn().mockReturnValue('newLayerId'); - (generateId as jest.Mock).mockReturnValue('accessor'); - const setState = jest.fn(); - const state = testState(); - const component = mount( - - ); - - component - .find('[data-test-subj="lnsXY_layer_add"]') - .first() - .simulate('click'); - - expect(frame.addNewLayer).toHaveBeenCalled(); - expect(setState).toHaveBeenCalledTimes(1); - expect(generateId).toHaveBeenCalledTimes(4); - expect(setState.mock.calls[0][0]).toMatchObject({ - layers: [ - ...state.layers, - expect.objectContaining({ - layerId: 'newLayerId', - xAccessor: 'accessor', - accessors: ['accessor'], - splitAccessor: 'accessor', - }), - ], - }); - }); - - it('should use series type of existing layers if they all have the same', () => { - frame.addNewLayer = jest.fn().mockReturnValue('newLayerId'); - frame.datasourceLayers.second = createMockDatasource().publicAPIMock; - (generateId as jest.Mock).mockReturnValue('accessor'); - const setState = jest.fn(); - const state: XYState = { - ...testState(), - preferredSeriesType: 'bar', - layers: [ - { - seriesType: 'line', - layerId: 'first', - splitAccessor: 'baz', - xAccessor: 'foo', - accessors: ['bar'], - }, - { - seriesType: 'line', - layerId: 'second', - splitAccessor: 'baz', - xAccessor: 'foo', - accessors: ['bar'], - }, - ], - }; - const component = mount( - - ); - - component - .find('[data-test-subj="lnsXY_layer_add"]') - .first() - .simulate('click'); - - expect(setState.mock.calls[0][0]).toMatchObject({ - layers: [ - ...state.layers, - expect.objectContaining({ - seriesType: 'line', - }), - ], - }); - }); - - it('should use preffered series type if there are already various different layers', () => { - frame.addNewLayer = jest.fn().mockReturnValue('newLayerId'); - frame.datasourceLayers.second = createMockDatasource().publicAPIMock; - (generateId as jest.Mock).mockReturnValue('accessor'); - const setState = jest.fn(); - const state: XYState = { - ...testState(), - preferredSeriesType: 'bar', - layers: [ - { - seriesType: 'area', - layerId: 'first', - splitAccessor: 'baz', - xAccessor: 'foo', - accessors: ['bar'], - }, - { - seriesType: 'line', - layerId: 'second', - splitAccessor: 'baz', - xAccessor: 'foo', - accessors: ['bar'], - }, - ], - }; - const component = mount( - - ); - - component - .find('[data-test-subj="lnsXY_layer_add"]') - .first() - .simulate('click'); - - expect(setState.mock.calls[0][0]).toMatchObject({ - layers: [ - ...state.layers, - expect.objectContaining({ - seriesType: 'bar', - }), - ], - }); - }); - - it('removes layers', () => { - const setState = jest.fn(); - const state = testState(); - const component = mount( - - ); - - openComponentPopover(component, 'first'); - - component - .find('[data-test-subj="lnsXY_layer_remove"]') - .first() - .simulate('click'); - - expect(frame.removeLayers).toHaveBeenCalled(); - expect(setState).toHaveBeenCalledTimes(1); - expect(setState.mock.calls[0][0]).toMatchObject({ - layers: [], - }); - }); - }); }); diff --git a/x-pack/legacy/plugins/lens/public/xy_visualization_plugin/xy_config_panel.tsx b/x-pack/legacy/plugins/lens/public/xy_visualization_plugin/xy_config_panel.tsx index f59b1520dbbb4..dbcfa24395001 100644 --- a/x-pack/legacy/plugins/lens/public/xy_visualization_plugin/xy_config_panel.tsx +++ b/x-pack/legacy/plugins/lens/public/xy_visualization_plugin/xy_config_panel.tsx @@ -5,25 +5,11 @@ */ import _ from 'lodash'; -import React, { useState } from 'react'; +import React from 'react'; import { i18n } from '@kbn/i18n'; -import { - EuiButton, - EuiButtonGroup, - EuiFlexGroup, - EuiFlexItem, - EuiForm, - EuiFormRow, - EuiPanel, - EuiButtonIcon, - EuiPopover, - EuiSpacer, - EuiButtonEmpty, - EuiPopoverFooter, - EuiToolTip, -} from '@elastic/eui'; -import { State, SeriesType, LayerConfig, visualizationTypes } from './types'; -import { VisualizationProps, OperationMetadata } from '../types'; +import { EuiButtonGroup, EuiFormRow } from '@elastic/eui'; +import { State, SeriesType, visualizationTypes } from './types'; +import { VisualizationLayerConfigProps, OperationMetadata } from '../types'; import { NativeRenderer } from '../native_renderer'; import { MultiColumnEditor } from '../multi_column_editor'; import { generateId } from '../id_generator'; @@ -45,253 +31,140 @@ function updateLayer(state: State, layer: UnwrapArray, index: n }; } -function newLayerState(seriesType: SeriesType, layerId: string): LayerConfig { - return { - layerId, - seriesType, - xAccessor: generateId(), - accessors: [generateId()], - splitAccessor: generateId(), - }; -} +export function LayerContextMenu(props: VisualizationLayerConfigProps) { + const { state, layerId } = props; + const horizontalOnly = isHorizontalChart(state.layers); + const index = state.layers.findIndex(l => l.layerId === layerId); + const layer = state.layers[index]; -function LayerSettings({ - layer, - horizontalOnly, - setSeriesType, - removeLayer, -}: { - layer: LayerConfig; - horizontalOnly: boolean; - setSeriesType: (seriesType: SeriesType) => void; - removeLayer: () => void; -}) { - const [isOpen, setIsOpen] = useState(false); - const { icon } = visualizationTypes.find(c => c.id === layer.seriesType)!; + if (!layer) { + return null; + } return ( - setIsOpen(!isOpen)} - data-test-subj="lnsXY_layer_advanced" - /> - } - isOpen={isOpen} - closePopover={() => setIsOpen(false)} - anchorPosition="leftUp" + - - isHorizontalSeries(t.id as SeriesType) === horizontalOnly) - .map(t => ({ - id: t.id, - label: t.label, - iconType: t.icon || 'empty', - }))} - idSelected={layer.seriesType} - onChange={seriesType => { - trackUiEvent('xy_change_layer_display'); - setSeriesType(seriesType as SeriesType); - }} - isIconOnly - buttonSize="compressed" - /> - - - - {i18n.translate('xpack.lens.xyChart.deleteLayer', { - defaultMessage: 'Delete layer', - })} - - - + name="chartType" + className="eui-displayInlineBlock" + data-test-subj="lnsXY_seriesType" + options={visualizationTypes + .filter(t => isHorizontalSeries(t.id as SeriesType) === horizontalOnly) + .map(t => ({ + id: t.id, + label: t.label, + iconType: t.icon || 'empty', + }))} + idSelected={layer.seriesType} + onChange={seriesType => { + trackUiEvent('xy_change_layer_display'); + props.setState( + updateLayer(state, { ...layer, seriesType: seriesType as SeriesType }, index) + ); + }} + isIconOnly + buttonSize="compressed" + /> + ); } -export function XYConfigPanel(props: VisualizationProps) { - const { state, setState, frame } = props; - const horizontalOnly = isHorizontalChart(state.layers); - - return ( - - {state.layers.map((layer, index) => ( - - - - - setState(updateLayer(state, { ...layer, seriesType }, index)) - } - removeLayer={() => { - trackUiEvent('xy_layer_removed'); - frame.removeLayers([layer.layerId]); - setState({ ...state, layers: state.layers.filter(l => l !== layer) }); - }} - /> - - - - - - +export function XYConfigPanel(props: VisualizationLayerConfigProps) { + const { state, setState, frame, layerId } = props; + const index = props.state.layers.findIndex(l => l.layerId === layerId); - + if (index < 0) { + return null; + } - - - - - - setState( - updateLayer( - state, - { - ...layer, - accessors: [...layer.accessors, generateId()], - }, - index - ) - ) - } - onRemove={accessor => - setState( - updateLayer( - state, - { - ...layer, - accessors: layer.accessors.filter(col => col !== accessor), - }, - index - ) - ) - } - filterOperations={isNumericMetric} - data-test-subj="lensXY_yDimensionPanel" - testSubj="lensXY_yDimensionPanel" - layerId={layer.layerId} - /> - - - - - - ))} + const layer = props.state.layers[index]; - - - { - trackUiEvent('xy_layer_added'); - const usedSeriesTypes = _.uniq(state.layers.map(layer => layer.seriesType)); - setState({ - ...state, - layers: [ - ...state.layers, - newLayerState( - usedSeriesTypes.length === 1 ? usedSeriesTypes[0] : state.preferredSeriesType, - frame.addNewLayer() - ), - ], - }); - }} - iconType="plusInCircleFilled" - /> - - - + return ( + <> + + + + + + setState( + updateLayer( + state, + { + ...layer, + accessors: [...layer.accessors, generateId()], + }, + index + ) + ) + } + onRemove={accessor => + setState( + updateLayer( + state, + { + ...layer, + accessors: layer.accessors.filter(col => col !== accessor), + }, + index + ) + ) + } + filterOperations={isNumericMetric} + data-test-subj="lensXY_yDimensionPanel" + testSubj="lensXY_yDimensionPanel" + layerId={layer.layerId} + /> + + + + + ); } diff --git a/x-pack/legacy/plugins/lens/public/xy_visualization_plugin/xy_visualization.test.ts b/x-pack/legacy/plugins/lens/public/xy_visualization_plugin/xy_visualization.test.ts index db28e76f82946..89794ec74eaec 100644 --- a/x-pack/legacy/plugins/lens/public/xy_visualization_plugin/xy_visualization.test.ts +++ b/x-pack/legacy/plugins/lens/public/xy_visualization_plugin/xy_visualization.test.ts @@ -137,6 +137,54 @@ describe('xy_visualization', () => { }); }); + describe('#removeLayer', () => { + it('removes the specified layer', () => { + const prevState: State = { + ...exampleState(), + layers: [ + ...exampleState().layers, + { + layerId: 'second', + seriesType: 'area', + splitAccessor: 'e', + xAccessor: 'f', + accessors: ['g', 'h'], + }, + ], + }; + + expect(xyVisualization.removeLayer!(prevState, 'second')).toEqual(exampleState()); + }); + }); + + describe('#appendLayer', () => { + it('adds a layer', () => { + const layers = xyVisualization.appendLayer!(exampleState(), 'foo').layers; + expect(layers.length).toEqual(exampleState().layers.length + 1); + expect(layers[layers.length - 1]).toMatchObject({ layerId: 'foo' }); + }); + }); + + describe('#clearLayer', () => { + it('clears the specified layer', () => { + (generateId as jest.Mock).mockReturnValue('test_empty_id'); + const layer = xyVisualization.clearLayer(exampleState(), 'first').layers[0]; + expect(layer).toMatchObject({ + accessors: ['test_empty_id'], + layerId: 'first', + seriesType: 'bar', + splitAccessor: 'test_empty_id', + xAccessor: 'test_empty_id', + }); + }); + }); + + describe('#getLayerIds', () => { + it('returns layerids', () => { + expect(xyVisualization.getLayerIds(exampleState())).toEqual(['first']); + }); + }); + describe('#toExpression', () => { let mockDatasource: ReturnType; let frame: ReturnType; diff --git a/x-pack/legacy/plugins/lens/public/xy_visualization_plugin/xy_visualization.tsx b/x-pack/legacy/plugins/lens/public/xy_visualization_plugin/xy_visualization.tsx index 5ba77cb39d5f8..75d6fcc7d160b 100644 --- a/x-pack/legacy/plugins/lens/public/xy_visualization_plugin/xy_visualization.tsx +++ b/x-pack/legacy/plugins/lens/public/xy_visualization_plugin/xy_visualization.tsx @@ -11,9 +11,9 @@ import { Position } from '@elastic/charts'; import { I18nProvider } from '@kbn/i18n/react'; import { i18n } from '@kbn/i18n'; import { getSuggestions } from './xy_suggestions'; -import { XYConfigPanel } from './xy_config_panel'; +import { XYConfigPanel, LayerContextMenu } from './xy_config_panel'; import { Visualization } from '../types'; -import { State, PersistableState, SeriesType, visualizationTypes } from './types'; +import { State, PersistableState, SeriesType, visualizationTypes, LayerConfig } from './types'; import { toExpression, toPreviewExpression } from './to_expression'; import { generateId } from '../id_generator'; import chartBarStackedSVG from '../assets/chart_bar_stacked.svg'; @@ -67,6 +67,40 @@ export const xyVisualization: Visualization = { visualizationTypes, + getLayerIds(state) { + return state.layers.map(l => l.layerId); + }, + + removeLayer(state, layerId) { + return { + ...state, + layers: state.layers.filter(l => l.layerId !== layerId), + }; + }, + + appendLayer(state, layerId) { + const usedSeriesTypes = _.uniq(state.layers.map(layer => layer.seriesType)); + return { + ...state, + layers: [ + ...state.layers, + newLayerState( + usedSeriesTypes.length === 1 ? usedSeriesTypes[0] : state.preferredSeriesType, + layerId + ), + ], + }; + }, + + clearLayer(state, layerId) { + return { + ...state, + layers: state.layers.map(l => + l.layerId !== layerId ? l : newLayerState(state.preferredSeriesType, layerId) + ), + }; + }, + getDescription(state) { const { icon, label } = getDescription(state); const chartLabel = i18n.translate('xpack.lens.xyVisualization.chartLabel', { @@ -113,7 +147,7 @@ export const xyVisualization: Visualization = { getPersistableState: state => state, - renderConfigPanel: (domElement, props) => + renderLayerConfigPanel: (domElement, props) => render( @@ -121,6 +155,30 @@ export const xyVisualization: Visualization = { domElement ), + getLayerContextMenuIcon({ state, layerId }) { + const layer = state.layers.find(l => l.layerId === layerId); + return visualizationTypes.find(t => t.id === layer?.seriesType)?.icon; + }, + + renderLayerContextMenu(domElement, props) { + render( + + + , + domElement + ); + }, + toExpression, toPreviewExpression, }; + +function newLayerState(seriesType: SeriesType, layerId: string): LayerConfig { + return { + layerId, + seriesType, + xAccessor: generateId(), + accessors: [generateId()], + splitAccessor: generateId(), + }; +} diff --git a/x-pack/plugins/translations/translations/ja-JP.json b/x-pack/plugins/translations/translations/ja-JP.json index ca49aea3ee885..36c3d4a6c1805 100644 --- a/x-pack/plugins/translations/translations/ja-JP.json +++ b/x-pack/plugins/translations/translations/ja-JP.json @@ -6935,10 +6935,8 @@ "xpack.lens.xyChart.addLayerTooltip": "複数のレイヤーを使用すると、グラフタイプを組み合わせたり、別のインデックスパターンを可視化したりすることができます。", "xpack.lens.xyChart.chartTypeLabel": "チャートタイプ", "xpack.lens.xyChart.chartTypeLegend": "チャートタイプ", - "xpack.lens.xyChart.deleteLayer": "レイヤーを削除", "xpack.lens.xyChart.help": "X/Y チャート", "xpack.lens.xyChart.isVisible.help": "判例の表示・非表示を指定します。", - "xpack.lens.xyChart.layerSettings": "レイヤー設定を編集", "xpack.lens.xyChart.legend.help": "チャートの凡例を構成します。", "xpack.lens.xyChart.nestUnderRoot": "データセット全体", "xpack.lens.xyChart.position.help": "凡例の配置を指定します。", diff --git a/x-pack/plugins/translations/translations/zh-CN.json b/x-pack/plugins/translations/translations/zh-CN.json index ba6ff117c688d..a0c514a89feb0 100644 --- a/x-pack/plugins/translations/translations/zh-CN.json +++ b/x-pack/plugins/translations/translations/zh-CN.json @@ -6934,10 +6934,8 @@ "xpack.lens.xyChart.addLayerTooltip": "使用多个图层以组合图表类型或可视化不同的索引模式。", "xpack.lens.xyChart.chartTypeLabel": "图表类型", "xpack.lens.xyChart.chartTypeLegend": "图表类型", - "xpack.lens.xyChart.deleteLayer": "删除图层", "xpack.lens.xyChart.help": "X/Y 图表", "xpack.lens.xyChart.isVisible.help": "指定图例是否可见。", - "xpack.lens.xyChart.layerSettings": "编辑图层设置", "xpack.lens.xyChart.legend.help": "配置图表图例。", "xpack.lens.xyChart.nestUnderRoot": "整个数据集", "xpack.lens.xyChart.position.help": "指定图例位置。", From 35715e0399677b19ea9efe5c45d82e2bc13ce9a6 Mon Sep 17 00:00:00 2001 From: Thomas Neirynck Date: Tue, 14 Jan 2020 12:22:59 -0500 Subject: [PATCH 109/139] feedback --- .../properties/dynamic_color_property.js | 34 ++++++------------- 1 file changed, 11 insertions(+), 23 deletions(-) diff --git a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js index 7cf85e936d4eb..e1663f3f9ca7c 100644 --- a/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js +++ b/x-pack/legacy/plugins/maps/public/layers/styles/vector/properties/dynamic_color_property.js @@ -109,9 +109,12 @@ export class DynamicColorProperty extends DynamicStyleProperty { return null; } - return this._getMBDataDrivenColor({ - targetName: getComputedFieldName(this._styleName, this._options.field.name), - }); + const targetName = getComputedFieldName(this._styleName, this._options.field.name); + if (this.isCategorical()) { + return this._getMbDataDrivenCategoricalColor({ targetName }); + } else { + return this._getMbDataDrivenOrdinalColor({ targetName }); + } } _getMbDataDrivenOrdinalColor({ targetName }) { @@ -159,13 +162,11 @@ export class DynamicColorProperty extends DynamicStyleProperty { stops.push({ stop: config.stop, color: config.color, - isDefault: false, }); } stops.push({ stop: this._options.customColorPalette[0].stop, color: this._options.customColorPalette[0].color, - isDefault: true, }); return stops; } @@ -186,7 +187,6 @@ export class DynamicColorProperty extends DynamicStyleProperty { const isDefault = i === maxLength - 1; stops.push({ stop: isDefault ? '__DEFAULT__' : fieldMeta.categories[i].key, - isDefault: isDefault, color: colors[i], }); } @@ -211,7 +211,7 @@ export class DynamicColorProperty extends DynamicStyleProperty { let defaultColor = null; for (let i = 0; i < paletteStops.length; i++) { const stop = paletteStops[i]; - if (stop.isDefault) { + if (i === paletteStops.length - 1) { defaultColor = stop.color; } else { mbStops.push(stop.stop); @@ -225,23 +225,11 @@ export class DynamicColorProperty extends DynamicStyleProperty { return ['match', ['get', this._options.field.name], ...mbStops]; } - _getMBDataDrivenColor({ targetName }) { - if (this.isCategorical()) { - return this._getMbDataDrivenCategoricalColor({ targetName }); - } else { - return this._getMbDataDrivenOrdinalColor({ targetName }); - } - } - - _getOrdinalColorStopsFromCustom() { - return this._options.customColorRamp.reduce((accumulatedStops, nextStop) => { - return [...accumulatedStops, nextStop.stop, nextStop.color]; - }, []); - } - _getMbOrdinalColorStops() { if (this._options.useCustomColorRamp) { - return this._getOrdinalColorStopsFromCustom(); + return this._options.customColorRamp.reduce((accumulatedStops, nextStop) => { + return [...accumulatedStops, nextStop.stop, nextStop.color]; + }, []); } else { return getOrdinalColorRampStops(this._options.color); } @@ -299,7 +287,7 @@ export class DynamicColorProperty extends DynamicStyleProperty { const stops = this._getColorStops(); return stops.map((config, index) => { let textValue; - if (config.isDefault) { + if (index === stops.length - 1) { textValue = ( {getOtherCategoryLabel()} From 79054afb5a3023583d27fa9cafb1fff476cb8b86 Mon Sep 17 00:00:00 2001 From: Chris Davies Date: Tue, 14 Jan 2020 12:39:50 -0500 Subject: [PATCH 110/139] [Lens] Add support for scripted fields and aliases to the existence API (#54064) * Add support for scripted fields and default index pattern * Add scripted fields and aliases to existence API * Fix TypeScript errors. * Fix mappings parsing * Default to the index pattern timeFieldName Co-authored-by: Elastic Machine --- .../indexpattern_plugin/datapanel.test.tsx | 46 +-- .../public/indexpattern_plugin/datapanel.tsx | 1 + .../public/indexpattern_plugin/loader.test.ts | 2 +- .../lens/public/indexpattern_plugin/loader.ts | 24 +- .../operations/definitions/date_histogram.tsx | 2 +- .../lens/public/indexpattern_plugin/types.ts | 24 +- .../server/routes/existing_fields.test.ts | 117 ++++++-- .../lens/server/routes/existing_fields.ts | 284 ++++++++++++------ .../apis/lens/existing_fields.ts | 4 +- 9 files changed, 345 insertions(+), 159 deletions(-) diff --git a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/datapanel.test.tsx b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/datapanel.test.tsx index 52f00a7cd4e9d..b04bd3a4e9be9 100644 --- a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/datapanel.test.tsx +++ b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/datapanel.test.tsx @@ -282,7 +282,7 @@ describe('IndexPattern Data Panel', () => { const parts = url.split('/'); const indexPatternTitle = parts[parts.length - 1]; return { - indexPatternTitle, + indexPatternTitle: `${indexPatternTitle}_testtitle`, existingFieldNames: ['field_1', 'field_2'].map( fieldName => `${indexPatternTitle}_${fieldName}` ), @@ -352,9 +352,9 @@ describe('IndexPattern Data Panel', () => { }); expect(nextState.existingFields).toEqual({ - aaa: { - aaa_field_1: true, - aaa_field_2: true, + a_testtitle: { + a_field_1: true, + a_field_2: true, }, }); }); @@ -369,13 +369,13 @@ describe('IndexPattern Data Panel', () => { }); expect(nextState.existingFields).toEqual({ - aaa: { - aaa_field_1: true, - aaa_field_2: true, + a_testtitle: { + a_field_1: true, + a_field_2: true, }, - bbb: { - bbb_field_1: true, - bbb_field_2: true, + b_testtitle: { + b_field_1: true, + b_field_2: true, }, }); }); @@ -397,7 +397,7 @@ describe('IndexPattern Data Panel', () => { expect(setState).toHaveBeenCalledTimes(2); expect(core.http.get).toHaveBeenCalledTimes(2); - expect(core.http.get).toHaveBeenCalledWith('/api/lens/existing_fields/aaa', { + expect(core.http.get).toHaveBeenCalledWith('/api/lens/existing_fields/a', { query: { fromDate: '2019-01-01', toDate: '2020-01-01', @@ -405,7 +405,7 @@ describe('IndexPattern Data Panel', () => { }, }); - expect(core.http.get).toHaveBeenCalledWith('/api/lens/existing_fields/aaa', { + expect(core.http.get).toHaveBeenCalledWith('/api/lens/existing_fields/a', { query: { fromDate: '2019-01-01', toDate: '2020-01-02', @@ -418,9 +418,9 @@ describe('IndexPattern Data Panel', () => { }); expect(nextState.existingFields).toEqual({ - aaa: { - aaa_field_1: true, - aaa_field_2: true, + a_testtitle: { + a_field_1: true, + a_field_2: true, }, }); }); @@ -436,7 +436,7 @@ describe('IndexPattern Data Panel', () => { expect(setState).toHaveBeenCalledTimes(2); - expect(core.http.get).toHaveBeenCalledWith('/api/lens/existing_fields/aaa', { + expect(core.http.get).toHaveBeenCalledWith('/api/lens/existing_fields/a', { query: { fromDate: '2019-01-01', toDate: '2020-01-01', @@ -444,7 +444,7 @@ describe('IndexPattern Data Panel', () => { }, }); - expect(core.http.get).toHaveBeenCalledWith('/api/lens/existing_fields/bbb', { + expect(core.http.get).toHaveBeenCalledWith('/api/lens/existing_fields/b', { query: { fromDate: '2019-01-01', toDate: '2020-01-01', @@ -457,13 +457,13 @@ describe('IndexPattern Data Panel', () => { }); expect(nextState.existingFields).toEqual({ - aaa: { - aaa_field_1: true, - aaa_field_2: true, + a_testtitle: { + a_field_1: true, + a_field_2: true, }, - bbb: { - bbb_field_1: true, - bbb_field_2: true, + b_testtitle: { + b_field_1: true, + b_field_2: true, }, }); }); diff --git a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/datapanel.tsx b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/datapanel.tsx index 6a2f6234279c7..3231ab7d7ff12 100644 --- a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/datapanel.tsx +++ b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/datapanel.tsx @@ -109,6 +109,7 @@ export function IndexPatternDataPanel({ .sort((a, b) => a.localeCompare(b)) .filter(id => !!indexPatterns[id]) .map(id => ({ + id, title: indexPatterns[id].title, timeFieldName: indexPatterns[id].timeFieldName, })); diff --git a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/loader.test.ts b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/loader.test.ts index e180ab690d418..6bea13c32830f 100644 --- a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/loader.test.ts +++ b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/loader.test.ts @@ -551,7 +551,7 @@ describe('loader', () => { dateRange: { fromDate: '1900-01-01', toDate: '2000-01-01' }, // eslint-disable-next-line @typescript-eslint/no-explicit-any fetchJson: fetchJson as any, - indexPatterns: [{ title: 'a' }, { title: 'b' }, { title: 'c' }], + indexPatterns: [{ id: 'a' }, { id: 'b' }, { id: 'c' }], setState, }); diff --git a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/loader.ts b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/loader.ts index 7f46f50786cf4..c196cb886e575 100644 --- a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/loader.ts +++ b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/loader.ts @@ -15,6 +15,7 @@ import { IndexPatternPersistedState, IndexPatternPrivateState, IndexPatternField, + AggregationRestrictions, } from './types'; import { updateLayerIndexPattern } from './state_helpers'; import { DateRange, ExistingFields } from '../../common/types'; @@ -30,19 +31,7 @@ interface SavedIndexPatternAttributes extends SavedObjectAttributes { } interface SavedRestrictionsObject { - aggs: Record< - string, - Record< - string, - { - agg: string; - fixed_interval?: string; - calendar_interval?: string; - delay?: string; - time_zone?: string; - } - > - >; + aggs: Record; } type SetState = StateSetter; @@ -230,7 +219,7 @@ export async function syncExistingFields({ setState, }: { dateRange: DateRange; - indexPatterns: Array<{ title: string; timeFieldName?: string | null }>; + indexPatterns: Array<{ id: string; timeFieldName?: string | null }>; fetchJson: HttpSetup['get']; setState: SetState; }) { @@ -245,7 +234,7 @@ export async function syncExistingFields({ query.timeFieldName = pattern.timeFieldName; } - return fetchJson(`${BASE_API_URL}/existing_fields/${pattern.title}`, { + return fetchJson(`${BASE_API_URL}/existing_fields/${pattern.id}`, { query, }) as Promise; }) @@ -301,8 +290,9 @@ function fromSavedObject( newFields.forEach((field, index) => { const restrictionsObj: IndexPatternField['aggregationRestrictions'] = {}; aggs.forEach(agg => { - if (typeMeta.aggs[agg] && typeMeta.aggs[agg][field.name]) { - restrictionsObj[agg] = typeMeta.aggs[agg][field.name]; + const restriction = typeMeta.aggs[agg] && typeMeta.aggs[agg][field.name]; + if (restriction) { + restrictionsObj[agg] = restriction; } }); if (Object.keys(restrictionsObj).length) { diff --git a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/operations/definitions/date_histogram.tsx b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/operations/definitions/date_histogram.tsx index 0bb653ac1e0c2..dbb6278352f09 100644 --- a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/operations/definitions/date_histogram.tsx +++ b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/operations/definitions/date_histogram.tsx @@ -322,7 +322,7 @@ function parseInterval(currentInterval: string) { }; } -function restrictedInterval(aggregationRestrictions?: AggregationRestrictions) { +function restrictedInterval(aggregationRestrictions?: Partial) { if (!aggregationRestrictions || !aggregationRestrictions.date_histogram) { return; } diff --git a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/types.ts b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/types.ts index 50478515d19ce..e556ddda10679 100644 --- a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/types.ts +++ b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/types.ts @@ -20,18 +20,16 @@ export interface IndexPattern { >; } -export type AggregationRestrictions = Partial< - Record< - string, - { - agg: string; - interval?: number; - fixed_interval?: string; - calendar_interval?: string; - delay?: string; - time_zone?: string; - } - > +export type AggregationRestrictions = Record< + string, + { + agg?: string; + interval?: number; + fixed_interval?: string; + calendar_interval?: string; + delay?: string; + time_zone?: string; + } >; export interface IndexPatternField { @@ -41,7 +39,7 @@ export interface IndexPatternField { aggregatable: boolean; scripted?: boolean; searchable: boolean; - aggregationRestrictions?: AggregationRestrictions; + aggregationRestrictions?: Partial; } export interface IndexPatternLayer { diff --git a/x-pack/legacy/plugins/lens/server/routes/existing_fields.test.ts b/x-pack/legacy/plugins/lens/server/routes/existing_fields.test.ts index 1647dcccaed3c..1f19671826807 100644 --- a/x-pack/legacy/plugins/lens/server/routes/existing_fields.test.ts +++ b/x-pack/legacy/plugins/lens/server/routes/existing_fields.test.ts @@ -4,24 +4,29 @@ * you may not use this file except in compliance with the Elastic License. */ -import { existingFields } from './existing_fields'; +import { existingFields, Field, buildFieldList } from './existing_fields'; describe('existingFields', () => { - function field(name: string, parent?: string) { + function field(opts: string | Partial): Field { + const obj = typeof opts === 'object' ? opts : {}; + const name = (typeof opts === 'string' ? opts : opts.name) || 'test'; + return { name, - subType: parent ? { multi: { parent } } : undefined, - aggregatable: true, - esTypes: [], - readFromDocValues: true, - searchable: true, - type: 'string', + isScript: false, + isAlias: false, + path: name.split('.'), + ...obj, }; } + function indexPattern(_source: unknown, fields: unknown = {}) { + return { _source, fields }; + } + it('should handle root level fields', () => { const result = existingFields( - [{ _source: { foo: 'bar' } }, { _source: { baz: 0 } }], + [indexPattern({ foo: 'bar' }), indexPattern({ baz: 0 })], [field('foo'), field('bar'), field('baz')] ); @@ -30,7 +35,7 @@ describe('existingFields', () => { it('should handle arrays of objects', () => { const result = existingFields( - [{ _source: { stuff: [{ foo: 'bar' }, { baz: 0 }] } }], + [indexPattern({ stuff: [{ foo: 'bar' }, { baz: 0 }] })], [field('stuff.foo'), field('stuff.bar'), field('stuff.baz')] ); @@ -38,14 +43,14 @@ describe('existingFields', () => { }); it('should handle basic arrays', () => { - const result = existingFields([{ _source: { stuff: ['heyo', 'there'] } }], [field('stuff')]); + const result = existingFields([indexPattern({ stuff: ['heyo', 'there'] })], [field('stuff')]); expect(result).toEqual(['stuff']); }); it('should handle deep object structures', () => { const result = existingFields( - [{ _source: { geo: { coordinates: { lat: 40, lon: -77 } } } }], + [indexPattern({ geo: { coordinates: { lat: 40, lon: -77 } } })], [field('geo.coordinates')] ); @@ -54,19 +59,97 @@ describe('existingFields', () => { it('should be false if it hits a positive leaf before the end of the path', () => { const result = existingFields( - [{ _source: { geo: { coordinates: 32 } } }], + [indexPattern({ geo: { coordinates: 32 } })], [field('geo.coordinates.lat')] ); expect(result).toEqual([]); }); - it('should prefer parent to name', () => { + it('should use path, not name', () => { const result = existingFields( - [{ _source: { stuff: [{ foo: 'bar' }, { baz: 0 }] } }], - [field('goober', 'stuff.foo'), field('soup', 'stuff.bar'), field('pea', 'stuff.baz')] + [indexPattern({ stuff: [{ foo: 'bar' }, { baz: 0 }] })], + [field({ name: 'goober', path: ['stuff', 'foo'] })] ); - expect(result).toEqual(['goober', 'pea']); + expect(result).toEqual(['goober']); + }); + + it('supports scripted fields', () => { + const result = existingFields( + [indexPattern({}, { bar: 'scriptvalue' })], + [field({ name: 'baz', isScript: true, path: ['bar'] })] + ); + + expect(result).toEqual(['baz']); + }); +}); + +describe('buildFieldList', () => { + const indexPattern = { + id: '', + type: 'indexpattern', + attributes: { + title: 'testpattern', + fields: JSON.stringify([ + { name: 'foo', scripted: true, lang: 'painless', script: '2+2' }, + { name: 'bar' }, + { name: '@bar' }, + { name: 'baz' }, + ]), + }, + references: [], + }; + + const mappings = { + testpattern: { + mappings: { + properties: { + '@bar': { + type: 'alias', + path: 'bar', + }, + }, + }, + }, + }; + + const fieldDescriptors = [ + { + name: 'baz', + subType: { multi: { parent: 'a.b.c' } }, + }, + ]; + + it('uses field descriptors to determine the path', () => { + const fields = buildFieldList(indexPattern, mappings, fieldDescriptors); + expect(fields.find(f => f.name === 'baz')).toMatchObject({ + isAlias: false, + isScript: false, + name: 'baz', + path: ['a', 'b', 'c'], + }); + }); + + it('uses aliases to determine the path', () => { + const fields = buildFieldList(indexPattern, mappings, fieldDescriptors); + expect(fields.find(f => f.isAlias)).toMatchObject({ + isAlias: true, + isScript: false, + name: '@bar', + path: ['bar'], + }); + }); + + it('supports scripted fields', () => { + const fields = buildFieldList(indexPattern, mappings, fieldDescriptors); + expect(fields.find(f => f.isScript)).toMatchObject({ + isAlias: false, + isScript: true, + name: 'foo', + path: ['foo'], + lang: 'painless', + script: '2+2', + }); }); }); diff --git a/x-pack/legacy/plugins/lens/server/routes/existing_fields.ts b/x-pack/legacy/plugins/lens/server/routes/existing_fields.ts index ad1af966983fb..55f8fd3b1a72b 100644 --- a/x-pack/legacy/plugins/lens/server/routes/existing_fields.ts +++ b/x-pack/legacy/plugins/lens/server/routes/existing_fields.ts @@ -6,28 +6,50 @@ import Boom from 'boom'; import { schema } from '@kbn/config-schema'; -import { SearchResponse } from 'elasticsearch'; import _ from 'lodash'; -import { IScopedClusterClient } from 'src/core/server'; +import { IScopedClusterClient, SavedObject, RequestHandlerContext } from 'src/core/server'; import { CoreSetup } from 'src/core/server'; import { BASE_API_URL } from '../../common'; -import { FieldDescriptor, IndexPatternsFetcher } from '../../../../../../src/plugins/data/server'; +import { IndexPatternsFetcher } from '../../../../../../src/plugins/data/server'; /** * The number of docs to sample to determine field empty status. */ const SAMPLE_SIZE = 500; -type Document = Record; +interface MappingResult { + [indexPatternTitle: string]: { + mappings: { + properties: Record; + }; + }; +} + +interface FieldDescriptor { + name: string; + subType?: { multi?: { parent?: string } }; +} + +export interface Field { + name: string; + isScript: boolean; + isAlias: boolean; + path: string[]; + lang?: string; + script?: string; +} + +// TODO: Pull this from kibana advanced settings +const metaFields = ['_source', '_id', '_type', '_index', '_score']; export async function existingFieldsRoute(setup: CoreSetup) { const router = setup.http.createRouter(); router.get( { - path: `${BASE_API_URL}/existing_fields/{indexPatternTitle}`, + path: `${BASE_API_URL}/existing_fields/{indexPatternId}`, validate: { params: schema.object({ - indexPatternTitle: schema.string(), + indexPatternId: schema.string(), }), query: schema.object({ fromDate: schema.maybe(schema.string()), @@ -37,31 +59,13 @@ export async function existingFieldsRoute(setup: CoreSetup) { }, }, async (context, req, res) => { - const { indexPatternTitle } = req.params; - const requestClient = context.core.elasticsearch.dataClient; - const indexPatternsFetcher = new IndexPatternsFetcher(requestClient.callAsCurrentUser); - const { fromDate, toDate, timeFieldName } = req.query; - try { - const fields = await indexPatternsFetcher.getFieldsForWildcard({ - pattern: indexPatternTitle, - // TODO: Pull this from kibana advanced settings - metaFields: ['_source', '_id', '_type', '_index', '_score'], - }); - - const results = await fetchIndexPatternStats({ - fromDate, - toDate, - client: requestClient, - index: indexPatternTitle, - timeFieldName, - }); - return res.ok({ - body: { - indexPatternTitle, - existingFieldNames: existingFields(results.hits.hits, fields), - }, + body: await fetchFieldExistence({ + ...req.query, + ...req.params, + context, + }), }); } catch (e) { if (e.status === 404) { @@ -82,6 +86,166 @@ export async function existingFieldsRoute(setup: CoreSetup) { ); } +async function fetchFieldExistence({ + context, + indexPatternId, + fromDate, + toDate, + timeFieldName, +}: { + indexPatternId: string; + context: RequestHandlerContext; + fromDate?: string; + toDate?: string; + timeFieldName?: string; +}) { + const { + indexPattern, + indexPatternTitle, + mappings, + fieldDescriptors, + } = await fetchIndexPatternDefinition(indexPatternId, context); + + const fields = buildFieldList(indexPattern, mappings, fieldDescriptors); + + const docs = await fetchIndexPatternStats({ + fromDate, + toDate, + client: context.core.elasticsearch.dataClient, + index: indexPatternTitle, + timeFieldName: timeFieldName || indexPattern.attributes.timeFieldName, + fields, + }); + + return { + indexPatternTitle, + existingFieldNames: existingFields(docs, fields), + }; +} + +async function fetchIndexPatternDefinition(indexPatternId: string, context: RequestHandlerContext) { + const savedObjectsClient = context.core.savedObjects.client; + const requestClient = context.core.elasticsearch.dataClient; + const indexPattern = await savedObjectsClient.get('index-pattern', indexPatternId); + const indexPatternTitle = indexPattern.attributes.title; + // TODO: maybe don't use IndexPatternsFetcher at all, since we're only using it + // to look up field values in the resulting documents. We can accomplish the same + // using the mappings which we're also fetching here. + const indexPatternsFetcher = new IndexPatternsFetcher(requestClient.callAsCurrentUser); + const [mappings, fieldDescriptors] = await Promise.all([ + requestClient.callAsCurrentUser('indices.getMapping', { + index: indexPatternTitle, + }), + + indexPatternsFetcher.getFieldsForWildcard({ + pattern: indexPatternTitle, + // TODO: Pull this from kibana advanced settings + metaFields, + }), + ]); + + return { + indexPattern, + indexPatternTitle, + mappings, + fieldDescriptors, + }; +} + +/** + * Exported only for unit tests. + */ +export function buildFieldList( + indexPattern: SavedObject, + mappings: MappingResult, + fieldDescriptors: FieldDescriptor[] +): Field[] { + const aliasMap = Object.entries(Object.values(mappings)[0].mappings.properties) + .map(([name, v]) => ({ ...v, name })) + .filter(f => f.type === 'alias') + .reduce((acc, f) => { + acc[f.name] = f.path; + return acc; + }, {} as Record); + + const descriptorMap = fieldDescriptors.reduce((acc, f) => { + acc[f.name] = f; + return acc; + }, {} as Record); + + return JSON.parse(indexPattern.attributes.fields).map( + (field: { name: string; lang: string; scripted?: boolean; script?: string }) => { + const path = + aliasMap[field.name] || descriptorMap[field.name]?.subType?.multi?.parent || field.name; + return { + name: field.name, + isScript: !!field.scripted, + isAlias: !!aliasMap[field.name], + path: path.split('.'), + lang: field.lang, + script: field.script, + }; + } + ); +} + +async function fetchIndexPatternStats({ + client, + index, + timeFieldName, + fromDate, + toDate, + fields, +}: { + client: IScopedClusterClient; + index: string; + timeFieldName?: string; + fromDate?: string; + toDate?: string; + fields: Field[]; +}) { + if (!timeFieldName || !fromDate || !toDate) { + return []; + } + const viableFields = fields.filter( + f => !f.isScript && !f.isAlias && !metaFields.includes(f.name) + ); + const scriptedFields = fields.filter(f => f.isScript); + + const result = await client.callAsCurrentUser('search', { + index, + body: { + size: SAMPLE_SIZE, + _source: viableFields.map(f => f.name), + query: { + bool: { + filter: [ + { + range: { + [timeFieldName]: { + gte: fromDate, + lte: toDate, + }, + }, + }, + ], + }, + }, + script_fields: scriptedFields.reduce((acc, field) => { + acc[field.name] = { + script: { + lang: field.lang, + source: field.script, + }, + }; + return acc; + }, {} as Record), + }, + }); + + return result.hits.hits; +} + function exists(obj: unknown, path: string[], i = 0): boolean { if (obj == null) { return false; @@ -103,21 +267,13 @@ function exists(obj: unknown, path: string[], i = 0): boolean { } /** - * Exported for testing purposes only. + * Exported only for unit tests. */ export function existingFields( - docs: Array<{ _source: Document }>, - fields: FieldDescriptor[] + docs: Array<{ _source: unknown; fields: unknown }>, + fields: Field[] ): string[] { - const allFields = fields.map(field => { - const parent = field.subType && field.subType.multi && field.subType.multi.parent; - return { - name: field.name, - parent, - path: (parent || field.name).split('.'), - }; - }); - const missingFields = new Set(allFields); + const missingFields = new Set(fields); for (const doc of docs) { if (missingFields.size === 0) { @@ -125,53 +281,11 @@ export function existingFields( } missingFields.forEach(field => { - if (exists(doc._source, field.path)) { + if (exists(field.isScript ? doc.fields : doc._source, field.path)) { missingFields.delete(field); } }); } - return allFields.filter(field => !missingFields.has(field)).map(f => f.name); -} - -async function fetchIndexPatternStats({ - client, - fromDate, - index, - toDate, - timeFieldName, -}: { - client: IScopedClusterClient; - fromDate?: string; - index: string; - toDate?: string; - timeFieldName?: string; -}) { - const body = - !timeFieldName || !fromDate || !toDate - ? {} - : { - query: { - bool: { - filter: [ - { - range: { - [timeFieldName]: { - gte: fromDate, - lte: toDate, - }, - }, - }, - ], - }, - }, - }; - - return (await client.callAsCurrentUser('search', { - index, - body: { - ...body, - size: SAMPLE_SIZE, - }, - })) as SearchResponse; + return fields.filter(field => !missingFields.has(field)).map(f => f.name); } diff --git a/x-pack/test/api_integration/apis/lens/existing_fields.ts b/x-pack/test/api_integration/apis/lens/existing_fields.ts index a16204408ea44..bceb8250edd2d 100644 --- a/x-pack/test/api_integration/apis/lens/existing_fields.ts +++ b/x-pack/test/api_integration/apis/lens/existing_fields.ts @@ -114,13 +114,13 @@ export default ({ getService }: FtrProviderContext) => { const { body } = await supertest .get( `/api/lens/existing_fields/${encodeURIComponent( - 'logstash-2015.09.22' + 'logstash-*' )}?fromDate=${TEST_START_TIME}&toDate=${TEST_END_TIME}` ) .set(COMMON_HEADERS) .expect(200); - expect(body.indexPatternTitle).to.eql('logstash-2015.09.22'); + expect(body.indexPatternTitle).to.eql('logstash-*'); expect(body.existingFieldNames.sort()).to.eql(fieldsWithData.sort()); }); From 97d460e051bf8232297b1255f5ca08256dbe9c89 Mon Sep 17 00:00:00 2001 From: Joe Reuter Date: Tue, 14 Jan 2020 18:40:12 +0100 Subject: [PATCH 111/139] Fix safari layout issue in Visualize, Graph and Lens (#54694) --- .../kibana/public/dashboard/np_ready/application.ts | 8 +++----- src/legacy/core_plugins/kibana/public/index.scss | 3 +++ .../kibana/public/local_application_service/_index.scss | 1 + .../_local_application_service.scss | 5 +++++ .../local_application_service.ts | 2 +- .../kibana/public/visualize/np_ready/application.ts | 5 ++--- x-pack/legacy/plugins/graph/public/application.ts | 5 ++--- 7 files changed, 17 insertions(+), 12 deletions(-) create mode 100644 src/legacy/core_plugins/kibana/public/local_application_service/_index.scss create mode 100644 src/legacy/core_plugins/kibana/public/local_application_service/_local_application_service.scss diff --git a/src/legacy/core_plugins/kibana/public/dashboard/np_ready/application.ts b/src/legacy/core_plugins/kibana/public/dashboard/np_ready/application.ts index 2a5dedab98151..7f7bf7cf47bda 100644 --- a/src/legacy/core_plugins/kibana/public/dashboard/np_ready/application.ts +++ b/src/legacy/core_plugins/kibana/public/dashboard/np_ready/application.ts @@ -86,11 +86,9 @@ export const renderApp = (element: HTMLElement, appBasePath: string, deps: Rende }; }; -const mainTemplate = (basePath: string) => `
+const mainTemplate = (basePath: string) => `
-
-
-`; +
`; const moduleName = 'app/dashboard'; @@ -98,7 +96,7 @@ const thirdPartyAngularDependencies = ['ngSanitize', 'ngRoute', 'react']; function mountDashboardApp(appBasePath: string, element: HTMLElement) { const mountpoint = document.createElement('div'); - mountpoint.setAttribute('style', 'height: 100%'); + mountpoint.setAttribute('class', 'kbnLocalApplicationWrapper'); // eslint-disable-next-line mountpoint.innerHTML = mainTemplate(appBasePath); // bootstrap angular into detached element and attach it later to diff --git a/src/legacy/core_plugins/kibana/public/index.scss b/src/legacy/core_plugins/kibana/public/index.scss index 3b49af9a4a6a6..dfe4aa1fd3b9f 100644 --- a/src/legacy/core_plugins/kibana/public/index.scss +++ b/src/legacy/core_plugins/kibana/public/index.scss @@ -26,6 +26,9 @@ // Management styles @import './management/index'; +// Local application mount wrapper styles +@import 'local_application_service/index'; + // Dashboard styles // MUST STAY AT THE BOTTOM BECAUSE OF DARK THEME IMPORTS @import './dashboard/index'; diff --git a/src/legacy/core_plugins/kibana/public/local_application_service/_index.scss b/src/legacy/core_plugins/kibana/public/local_application_service/_index.scss new file mode 100644 index 0000000000000..12cc1444101e7 --- /dev/null +++ b/src/legacy/core_plugins/kibana/public/local_application_service/_index.scss @@ -0,0 +1 @@ +@import 'local_application_service'; diff --git a/src/legacy/core_plugins/kibana/public/local_application_service/_local_application_service.scss b/src/legacy/core_plugins/kibana/public/local_application_service/_local_application_service.scss new file mode 100644 index 0000000000000..33a6100c43975 --- /dev/null +++ b/src/legacy/core_plugins/kibana/public/local_application_service/_local_application_service.scss @@ -0,0 +1,5 @@ +.kbnLocalApplicationWrapper { + display: flex; + flex-direction: column; + flex-grow: 1; +} diff --git a/src/legacy/core_plugins/kibana/public/local_application_service/local_application_service.ts b/src/legacy/core_plugins/kibana/public/local_application_service/local_application_service.ts index c09995caab669..d52bec8304ff9 100644 --- a/src/legacy/core_plugins/kibana/public/local_application_service/local_application_service.ts +++ b/src/legacy/core_plugins/kibana/public/local_application_service/local_application_service.ts @@ -56,7 +56,7 @@ export class LocalApplicationService { outerAngularWrapperRoute: true, reloadOnSearch: false, reloadOnUrl: false, - template: `
`, + template: `
`, controller($scope: IScope) { const element = document.getElementById(wrapperElementId)!; let unmountHandler: AppUnmount | null = null; diff --git a/src/legacy/core_plugins/kibana/public/visualize/np_ready/application.ts b/src/legacy/core_plugins/kibana/public/visualize/np_ready/application.ts index dcd68a26743ab..222b035708976 100644 --- a/src/legacy/core_plugins/kibana/public/visualize/np_ready/application.ts +++ b/src/legacy/core_plugins/kibana/public/visualize/np_ready/application.ts @@ -63,9 +63,8 @@ export const renderApp = async ( return () => $injector.get('$rootScope').$destroy(); }; -const mainTemplate = (basePath: string) => `
+const mainTemplate = (basePath: string) => `
-
`; @@ -75,7 +74,7 @@ const thirdPartyAngularDependencies = ['ngSanitize', 'ngRoute', 'react']; function mountVisualizeApp(appBasePath: string, element: HTMLElement) { const mountpoint = document.createElement('div'); - mountpoint.setAttribute('style', 'height: 100%'); + mountpoint.setAttribute('class', 'kbnLocalApplicationWrapper'); mountpoint.innerHTML = mainTemplate(appBasePath); // bootstrap angular into detached element and attach it later to // make angular-within-angular possible diff --git a/x-pack/legacy/plugins/graph/public/application.ts b/x-pack/legacy/plugins/graph/public/application.ts index 69bc789974632..8f486ab6ad51a 100644 --- a/x-pack/legacy/plugins/graph/public/application.ts +++ b/x-pack/legacy/plugins/graph/public/application.ts @@ -96,9 +96,8 @@ export const renderApp = ({ appBasePath, element, ...deps }: GraphDependencies) }; }; -const mainTemplate = (basePath: string) => `
+const mainTemplate = (basePath: string) => `
-
`; @@ -108,7 +107,7 @@ const thirdPartyAngularDependencies = ['ngSanitize', 'ngRoute', 'react', 'ui.boo function mountGraphApp(appBasePath: string, element: HTMLElement) { const mountpoint = document.createElement('div'); - mountpoint.setAttribute('style', 'height: 100%'); + mountpoint.setAttribute('class', 'kbnLocalApplicationWrapper'); // eslint-disable-next-line mountpoint.innerHTML = mainTemplate(appBasePath); // bootstrap angular into detached element and attach it later to From e4c73ffbbb91ae318a7979f8c32ccfcb6d978ebb Mon Sep 17 00:00:00 2001 From: Jean-Louis Leysens Date: Tue, 14 Jan 2020 18:47:13 +0100 Subject: [PATCH 112/139] [Console][Chore] Update spec (#54564) * Update spec conversion to exclude deprecated completions * Update OSS spec * Remove console.log * Add skip deprecated endpoints option to script * Actually, remove skip deprecated flag for now. Just do not include deprecated. See this issue: https://github.com/elastic/kibana/issues/48375 * x-pack: Delete data from transform completions * Update to existing x-pack autocomplete extensions * Added ml explain with overrides * Added put trained model with doc override * Added SLM get_status, start and stop with URL param overrides where needed * Add data completion for clear scroll * Remove include_type_name flag from indices and delete create.json override Co-authored-by: Elastic Machine --- packages/kbn-spec-to-console/lib/convert.js | 20 +++++++--- .../spec/generated/cat.indices.json | 9 ++++- .../spec/generated/clear_scroll.json | 3 +- .../api_server/spec/generated/create.json | 3 +- .../api_server/spec/generated/delete.json | 3 +- .../spec/generated/delete_by_query.json | 2 +- .../spec/generated/exists_source.json | 3 +- .../spec/generated/get_script_languages.json | 10 +++++ .../spec/generated/indices.shrink.json | 1 + .../spec/generated/indices.split.json | 1 + .../generated/indices.validate_query.json | 3 +- .../spec/generated/msearch_template.json | 3 +- .../spec/generated/nodes.hot_threads.json | 8 +--- .../api_server/spec/generated/rank_eval.json | 4 ++ .../api_server/spec/generated/scroll.json | 3 +- .../spec/generated/search_template.json | 3 +- .../api_server/spec/generated/update.json | 3 +- .../spec/generated/update_by_query.json | 1 + .../spec/overrides/clear_scroll.json | 7 ++++ .../api_server/spec/overrides/create.json | 16 -------- ...transform_deprecated.delete_transform.json | 14 ------- ...me_transform_deprecated.get_transform.json | 17 --------- ...nsform_deprecated.get_transform_stats.json | 16 -------- ...ransform_deprecated.preview_transform.json | 11 ------ ...me_transform_deprecated.put_transform.json | 14 ------- ..._transform_deprecated.start_transform.json | 14 ------- ...e_transform_deprecated.stop_transform.json | 16 -------- ...transform_deprecated.update_transform.json | 14 ------- .../spec/generated/license.get.json | 3 +- .../ml.delete_data_frame_analytics.json | 3 ++ .../ml.explain_data_frame_analytics.json | 13 +++++++ .../spec/generated/ml.put_trained_model.json | 11 ++++++ .../spec/generated/monitoring.bulk.json | 3 +- .../spec/generated/rollup.rollup_search.json | 3 +- .../spec/generated/security.get_api_key.json | 3 +- .../spec/generated/slm.get_status.json | 11 ++++++ .../spec/generated/slm.start.json | 11 ++++++ .../spec/generated/slm.stop.json | 11 ++++++ .../generated/transform.stop_transform.json | 4 +- ...ransform_deprecated.preview_transform.json | 26 ------------- ...me_transform_deprecated.put_transform.json | 29 -------------- ...transform_deprecated.update_transform.json | 24 ------------ .../ml.explain_data_frame_analytics.json | 38 +++++++++++++++++++ .../spec/overrides/ml.put_trained_model.json | 5 +++ .../spec/overrides/slm.start.json | 8 ++++ .../spec/overrides/slm.stop.json | 8 ++++ 46 files changed, 185 insertions(+), 251 deletions(-) create mode 100644 src/legacy/core_plugins/console/server/api_server/spec/generated/get_script_languages.json create mode 100644 src/legacy/core_plugins/console/server/api_server/spec/overrides/clear_scroll.json delete mode 100644 src/legacy/core_plugins/console/server/api_server/spec/overrides/create.json delete mode 100644 x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.delete_transform.json delete mode 100644 x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.get_transform.json delete mode 100644 x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.get_transform_stats.json delete mode 100644 x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.preview_transform.json delete mode 100644 x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.put_transform.json delete mode 100644 x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.start_transform.json delete mode 100644 x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.stop_transform.json delete mode 100644 x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.update_transform.json create mode 100644 x-pack/legacy/plugins/console_extensions/spec/generated/ml.explain_data_frame_analytics.json create mode 100644 x-pack/legacy/plugins/console_extensions/spec/generated/ml.put_trained_model.json create mode 100644 x-pack/legacy/plugins/console_extensions/spec/generated/slm.get_status.json create mode 100644 x-pack/legacy/plugins/console_extensions/spec/generated/slm.start.json create mode 100644 x-pack/legacy/plugins/console_extensions/spec/generated/slm.stop.json delete mode 100644 x-pack/legacy/plugins/console_extensions/spec/overrides/data_frame_transform_deprecated.preview_transform.json delete mode 100644 x-pack/legacy/plugins/console_extensions/spec/overrides/data_frame_transform_deprecated.put_transform.json delete mode 100644 x-pack/legacy/plugins/console_extensions/spec/overrides/data_frame_transform_deprecated.update_transform.json create mode 100644 x-pack/legacy/plugins/console_extensions/spec/overrides/ml.explain_data_frame_analytics.json create mode 100644 x-pack/legacy/plugins/console_extensions/spec/overrides/ml.put_trained_model.json create mode 100644 x-pack/legacy/plugins/console_extensions/spec/overrides/slm.start.json create mode 100644 x-pack/legacy/plugins/console_extensions/spec/overrides/slm.stop.json diff --git a/packages/kbn-spec-to-console/lib/convert.js b/packages/kbn-spec-to-console/lib/convert.js index 4c31281860767..5dbdd6e1c94e4 100644 --- a/packages/kbn-spec-to-console/lib/convert.js +++ b/packages/kbn-spec-to-console/lib/convert.js @@ -24,10 +24,16 @@ const convertParts = require('./convert/parts'); module.exports = spec => { const result = {}; - // TODO: - // Since https://github.com/elastic/elasticsearch/pull/42346 has been merged into ES master - // the JSON doc specification has been updated. We need to update this script to take advantage - // of the added information but it will also require updating console's editor autocomplete. + /** + * TODO: + * Since https://github.com/elastic/elasticsearch/pull/42346 has been merged into ES master + * the JSON doc specification has been updated. We need to update this script to take advantage + * of the added information but it will also require updating console editor autocomplete. + * + * Note: for now we exclude all deprecated patterns from the generated spec to prevent them + * from being used in autocompletion. It would be really nice if we could use this information + * instead of just not including it. + */ Object.keys(spec).forEach(api => { const source = spec[api]; if (!source.url) { @@ -46,8 +52,10 @@ module.exports = spec => { const urlComponents = {}; if (source.url.paths) { - patterns = convertPaths(source.url.paths); - source.url.paths.forEach(pathsObject => { + // We filter out all deprecated url patterns here. + const paths = source.url.paths.filter(path => !path.deprecated); + patterns = convertPaths(paths); + paths.forEach(pathsObject => { pathsObject.methods.forEach(method => methodSet.add(method)); if (pathsObject.parts) { for (const partName of Object.keys(pathsObject.parts)) { diff --git a/src/legacy/core_plugins/console/server/api_server/spec/generated/cat.indices.json b/src/legacy/core_plugins/console/server/api_server/spec/generated/cat.indices.json index 45da7f054bfb4..e6ca1fb575396 100644 --- a/src/legacy/core_plugins/console/server/api_server/spec/generated/cat.indices.json +++ b/src/legacy/core_plugins/console/server/api_server/spec/generated/cat.indices.json @@ -5,8 +5,15 @@ "bytes": [ "b", "k", + "kb", "m", - "g" + "mb", + "g", + "gb", + "t", + "tb", + "p", + "pb" ], "local": "__flag__", "master_timeout": "", diff --git a/src/legacy/core_plugins/console/server/api_server/spec/generated/clear_scroll.json b/src/legacy/core_plugins/console/server/api_server/spec/generated/clear_scroll.json index 55d9673054276..7e6e6692f931b 100644 --- a/src/legacy/core_plugins/console/server/api_server/spec/generated/clear_scroll.json +++ b/src/legacy/core_plugins/console/server/api_server/spec/generated/clear_scroll.json @@ -4,8 +4,7 @@ "DELETE" ], "patterns": [ - "_search/scroll", - "_search/scroll/{scroll_id}" + "_search/scroll" ], "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/master/search-request-body.html#_clear_scroll_api" } diff --git a/src/legacy/core_plugins/console/server/api_server/spec/generated/create.json b/src/legacy/core_plugins/console/server/api_server/spec/generated/create.json index 6c0ee8a2425ee..8bbee143c299f 100644 --- a/src/legacy/core_plugins/console/server/api_server/spec/generated/create.json +++ b/src/legacy/core_plugins/console/server/api_server/spec/generated/create.json @@ -22,8 +22,7 @@ "POST" ], "patterns": [ - "{indices}/_create/{id}", - "{indices}/{type}/{id}/_create" + "{indices}/_create/{id}" ], "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/master/docs-index_.html" } diff --git a/src/legacy/core_plugins/console/server/api_server/spec/generated/delete.json b/src/legacy/core_plugins/console/server/api_server/spec/generated/delete.json index aba84d0a10fc2..0852d8d184831 100644 --- a/src/legacy/core_plugins/console/server/api_server/spec/generated/delete.json +++ b/src/legacy/core_plugins/console/server/api_server/spec/generated/delete.json @@ -23,8 +23,7 @@ "DELETE" ], "patterns": [ - "{indices}/_doc/{id}", - "{indices}/{type}/{id}" + "{indices}/_doc/{id}" ], "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/master/docs-delete.html" } diff --git a/src/legacy/core_plugins/console/server/api_server/spec/generated/delete_by_query.json b/src/legacy/core_plugins/console/server/api_server/spec/generated/delete_by_query.json index 3867efd814238..2d1636d5f2c02 100644 --- a/src/legacy/core_plugins/console/server/api_server/spec/generated/delete_by_query.json +++ b/src/legacy/core_plugins/console/server/api_server/spec/generated/delete_by_query.json @@ -1,7 +1,6 @@ { "delete_by_query": { "url_params": { - "analyzer": "", "analyze_wildcard": "__flag__", "default_operator": [ "AND", @@ -31,6 +30,7 @@ "dfs_query_then_fetch" ], "search_timeout": "", + "size": "", "max_docs": "all documents", "sort": [], "_source": [], diff --git a/src/legacy/core_plugins/console/server/api_server/spec/generated/exists_source.json b/src/legacy/core_plugins/console/server/api_server/spec/generated/exists_source.json index e96273ffbc083..9ffc4b55f3037 100644 --- a/src/legacy/core_plugins/console/server/api_server/spec/generated/exists_source.json +++ b/src/legacy/core_plugins/console/server/api_server/spec/generated/exists_source.json @@ -20,8 +20,7 @@ "HEAD" ], "patterns": [ - "{indices}/_source/{id}", - "{indices}/{type}/{id}/_source" + "{indices}/_source/{id}" ], "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/master/docs-get.html" } diff --git a/src/legacy/core_plugins/console/server/api_server/spec/generated/get_script_languages.json b/src/legacy/core_plugins/console/server/api_server/spec/generated/get_script_languages.json new file mode 100644 index 0000000000000..10ea433ca68c5 --- /dev/null +++ b/src/legacy/core_plugins/console/server/api_server/spec/generated/get_script_languages.json @@ -0,0 +1,10 @@ +{ + "get_script_languages": { + "methods": [ + "GET" + ], + "patterns": [ + "_script_language" + ] + } +} diff --git a/src/legacy/core_plugins/console/server/api_server/spec/generated/indices.shrink.json b/src/legacy/core_plugins/console/server/api_server/spec/generated/indices.shrink.json index 31acc86a2fa56..6fbdea0f1244b 100644 --- a/src/legacy/core_plugins/console/server/api_server/spec/generated/indices.shrink.json +++ b/src/legacy/core_plugins/console/server/api_server/spec/generated/indices.shrink.json @@ -1,6 +1,7 @@ { "indices.shrink": { "url_params": { + "copy_settings": "__flag__", "timeout": "", "master_timeout": "", "wait_for_active_shards": "" diff --git a/src/legacy/core_plugins/console/server/api_server/spec/generated/indices.split.json b/src/legacy/core_plugins/console/server/api_server/spec/generated/indices.split.json index 1bfbaa078b796..68f2e338cd201 100644 --- a/src/legacy/core_plugins/console/server/api_server/spec/generated/indices.split.json +++ b/src/legacy/core_plugins/console/server/api_server/spec/generated/indices.split.json @@ -1,6 +1,7 @@ { "indices.split": { "url_params": { + "copy_settings": "__flag__", "timeout": "", "master_timeout": "", "wait_for_active_shards": "" diff --git a/src/legacy/core_plugins/console/server/api_server/spec/generated/indices.validate_query.json b/src/legacy/core_plugins/console/server/api_server/spec/generated/indices.validate_query.json index ceffec26beecc..33720576ef8a3 100644 --- a/src/legacy/core_plugins/console/server/api_server/spec/generated/indices.validate_query.json +++ b/src/legacy/core_plugins/console/server/api_server/spec/generated/indices.validate_query.json @@ -28,8 +28,7 @@ ], "patterns": [ "_validate/query", - "{indices}/_validate/query", - "{indices}/{type}/_validate/query" + "{indices}/_validate/query" ], "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/master/search-validate.html" } diff --git a/src/legacy/core_plugins/console/server/api_server/spec/generated/msearch_template.json b/src/legacy/core_plugins/console/server/api_server/spec/generated/msearch_template.json index 0b0ca087b1819..c2f741066bbdb 100644 --- a/src/legacy/core_plugins/console/server/api_server/spec/generated/msearch_template.json +++ b/src/legacy/core_plugins/console/server/api_server/spec/generated/msearch_template.json @@ -9,8 +9,7 @@ ], "typed_keys": "__flag__", "max_concurrent_searches": "", - "rest_total_hits_as_int": "__flag__", - "ccs_minimize_roundtrips": "__flag__" + "rest_total_hits_as_int": "__flag__" }, "methods": [ "GET", diff --git a/src/legacy/core_plugins/console/server/api_server/spec/generated/nodes.hot_threads.json b/src/legacy/core_plugins/console/server/api_server/spec/generated/nodes.hot_threads.json index b8aa5dd4ca711..b3cbbe80e0d00 100644 --- a/src/legacy/core_plugins/console/server/api_server/spec/generated/nodes.hot_threads.json +++ b/src/legacy/core_plugins/console/server/api_server/spec/generated/nodes.hot_threads.json @@ -17,13 +17,7 @@ ], "patterns": [ "_nodes/hot_threads", - "_nodes/{nodes}/hot_threads", - "_cluster/nodes/hotthreads", - "_cluster/nodes/{nodes}/hotthreads", - "_nodes/hotthreads", - "_nodes/{nodes}/hotthreads", - "_cluster/nodes/hot_threads", - "_cluster/nodes/{nodes}/hot_threads" + "_nodes/{nodes}/hot_threads" ], "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/master/cluster-nodes-hot-threads.html" } diff --git a/src/legacy/core_plugins/console/server/api_server/spec/generated/rank_eval.json b/src/legacy/core_plugins/console/server/api_server/spec/generated/rank_eval.json index 620f1c629d959..c2bed081124a8 100644 --- a/src/legacy/core_plugins/console/server/api_server/spec/generated/rank_eval.json +++ b/src/legacy/core_plugins/console/server/api_server/spec/generated/rank_eval.json @@ -8,6 +8,10 @@ "closed", "none", "all" + ], + "search_type": [ + "query_then_fetch", + "dfs_query_then_fetch" ] }, "methods": [ diff --git a/src/legacy/core_plugins/console/server/api_server/spec/generated/scroll.json b/src/legacy/core_plugins/console/server/api_server/spec/generated/scroll.json index 3e959b9630e98..4ce82a2c25e0e 100644 --- a/src/legacy/core_plugins/console/server/api_server/spec/generated/scroll.json +++ b/src/legacy/core_plugins/console/server/api_server/spec/generated/scroll.json @@ -10,8 +10,7 @@ "POST" ], "patterns": [ - "_search/scroll", - "_search/scroll/{scroll_id}" + "_search/scroll" ], "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/master/search-request-body.html#request-body-search-scroll" } diff --git a/src/legacy/core_plugins/console/server/api_server/spec/generated/search_template.json b/src/legacy/core_plugins/console/server/api_server/spec/generated/search_template.json index 582ecab1dd614..cf5a5c5f32db3 100644 --- a/src/legacy/core_plugins/console/server/api_server/spec/generated/search_template.json +++ b/src/legacy/core_plugins/console/server/api_server/spec/generated/search_template.json @@ -22,8 +22,7 @@ "explain": "__flag__", "profile": "__flag__", "typed_keys": "__flag__", - "rest_total_hits_as_int": "__flag__", - "ccs_minimize_roundtrips": "__flag__" + "rest_total_hits_as_int": "__flag__" }, "methods": [ "GET", diff --git a/src/legacy/core_plugins/console/server/api_server/spec/generated/update.json b/src/legacy/core_plugins/console/server/api_server/spec/generated/update.json index 4e103b0af2195..43945dfada35c 100644 --- a/src/legacy/core_plugins/console/server/api_server/spec/generated/update.json +++ b/src/legacy/core_plugins/console/server/api_server/spec/generated/update.json @@ -21,8 +21,7 @@ "POST" ], "patterns": [ - "{indices}/_update/{id}", - "{indices}/{type}/{id}/_update" + "{indices}/_update/{id}" ], "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/master/docs-update.html" } diff --git a/src/legacy/core_plugins/console/server/api_server/spec/generated/update_by_query.json b/src/legacy/core_plugins/console/server/api_server/spec/generated/update_by_query.json index 739ea16888146..393197949e86c 100644 --- a/src/legacy/core_plugins/console/server/api_server/spec/generated/update_by_query.json +++ b/src/legacy/core_plugins/console/server/api_server/spec/generated/update_by_query.json @@ -32,6 +32,7 @@ "dfs_query_then_fetch" ], "search_timeout": "", + "size": "", "max_docs": "all documents", "sort": [], "_source": [], diff --git a/src/legacy/core_plugins/console/server/api_server/spec/overrides/clear_scroll.json b/src/legacy/core_plugins/console/server/api_server/spec/overrides/clear_scroll.json new file mode 100644 index 0000000000000..e9d4a6cee54ce --- /dev/null +++ b/src/legacy/core_plugins/console/server/api_server/spec/overrides/clear_scroll.json @@ -0,0 +1,7 @@ +{ + "clear_scroll": { + "data_autocomplete_rules": { + "scroll_id": "" + } + } +} diff --git a/src/legacy/core_plugins/console/server/api_server/spec/overrides/create.json b/src/legacy/core_plugins/console/server/api_server/spec/overrides/create.json deleted file mode 100644 index 0bbf456245c84..0000000000000 --- a/src/legacy/core_plugins/console/server/api_server/spec/overrides/create.json +++ /dev/null @@ -1,16 +0,0 @@ -{ - "create": { - "url_params": { - "timeout": "1m", - "ttl": "5m", - "version": "1" - }, - "methods": [ - "PUT", - "POST" - ], - "patterns": [ - "{indices}/{type}/{id}/_create" - ] - } -} diff --git a/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.delete_transform.json b/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.delete_transform.json deleted file mode 100644 index 4401c85da7215..0000000000000 --- a/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.delete_transform.json +++ /dev/null @@ -1,14 +0,0 @@ -{ - "data_frame_transform_deprecated.delete_transform": { - "url_params": { - "force": "__flag__" - }, - "methods": [ - "DELETE" - ], - "patterns": [ - "_data_frame/transforms/{transform_id}" - ], - "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/current/delete-transform.html" - } -} diff --git a/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.get_transform.json b/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.get_transform.json deleted file mode 100644 index d1060d562c626..0000000000000 --- a/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.get_transform.json +++ /dev/null @@ -1,17 +0,0 @@ -{ - "data_frame_transform_deprecated.get_transform": { - "url_params": { - "from": 0, - "size": 0, - "allow_no_match": "__flag__" - }, - "methods": [ - "GET" - ], - "patterns": [ - "_data_frame/transforms/{transform_id}", - "_data_frame/transforms" - ], - "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/current/get-transform.html" - } -} diff --git a/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.get_transform_stats.json b/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.get_transform_stats.json deleted file mode 100644 index aa3c1a21f36ce..0000000000000 --- a/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.get_transform_stats.json +++ /dev/null @@ -1,16 +0,0 @@ -{ - "data_frame_transform_deprecated.get_transform_stats": { - "url_params": { - "from": "", - "size": "", - "allow_no_match": "__flag__" - }, - "methods": [ - "GET" - ], - "patterns": [ - "_data_frame/transforms/{transform_id}/_stats" - ], - "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/current/get-transform-stats.html" - } -} diff --git a/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.preview_transform.json b/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.preview_transform.json deleted file mode 100644 index 1c878641d02b5..0000000000000 --- a/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.preview_transform.json +++ /dev/null @@ -1,11 +0,0 @@ -{ - "data_frame_transform_deprecated.preview_transform": { - "methods": [ - "POST" - ], - "patterns": [ - "_data_frame/transforms/_preview" - ], - "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/current/preview-transform.html" - } -} diff --git a/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.put_transform.json b/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.put_transform.json deleted file mode 100644 index 89c124280a4a1..0000000000000 --- a/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.put_transform.json +++ /dev/null @@ -1,14 +0,0 @@ -{ - "data_frame_transform_deprecated.put_transform": { - "url_params": { - "defer_validation": "__flag__" - }, - "methods": [ - "PUT" - ], - "patterns": [ - "_data_frame/transforms/{transform_id}" - ], - "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/current/put-transform.html" - } -} diff --git a/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.start_transform.json b/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.start_transform.json deleted file mode 100644 index 49e09b7922b68..0000000000000 --- a/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.start_transform.json +++ /dev/null @@ -1,14 +0,0 @@ -{ - "data_frame_transform_deprecated.start_transform": { - "url_params": { - "timeout": "" - }, - "methods": [ - "POST" - ], - "patterns": [ - "_data_frame/transforms/{transform_id}/_start" - ], - "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/current/start-transform.html" - } -} diff --git a/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.stop_transform.json b/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.stop_transform.json deleted file mode 100644 index 90e89269aec00..0000000000000 --- a/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.stop_transform.json +++ /dev/null @@ -1,16 +0,0 @@ -{ - "data_frame_transform_deprecated.stop_transform": { - "url_params": { - "wait_for_completion": "__flag__", - "timeout": "", - "allow_no_match": "__flag__" - }, - "methods": [ - "POST" - ], - "patterns": [ - "_data_frame/transforms/{transform_id}/_stop" - ], - "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/current/stop-transform.html" - } -} diff --git a/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.update_transform.json b/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.update_transform.json deleted file mode 100644 index ac8c854ab6bfc..0000000000000 --- a/x-pack/legacy/plugins/console_extensions/spec/generated/data_frame_transform_deprecated.update_transform.json +++ /dev/null @@ -1,14 +0,0 @@ -{ - "data_frame_transform_deprecated.update_transform": { - "url_params": { - "defer_validation": "__flag__" - }, - "methods": [ - "POST" - ], - "patterns": [ - "_data_frame/transforms/{transform_id}/_update" - ], - "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/current/update-transform.html" - } -} diff --git a/x-pack/legacy/plugins/console_extensions/spec/generated/license.get.json b/x-pack/legacy/plugins/console_extensions/spec/generated/license.get.json index f37602296f5a9..2404d65ce1e01 100644 --- a/x-pack/legacy/plugins/console_extensions/spec/generated/license.get.json +++ b/x-pack/legacy/plugins/console_extensions/spec/generated/license.get.json @@ -1,7 +1,8 @@ { "license.get": { "url_params": { - "local": "__flag__" + "local": "__flag__", + "accept_enterprise": "__flag__" }, "methods": [ "GET" diff --git a/x-pack/legacy/plugins/console_extensions/spec/generated/ml.delete_data_frame_analytics.json b/x-pack/legacy/plugins/console_extensions/spec/generated/ml.delete_data_frame_analytics.json index c2c6baf906db6..c3d7048406ef6 100644 --- a/x-pack/legacy/plugins/console_extensions/spec/generated/ml.delete_data_frame_analytics.json +++ b/x-pack/legacy/plugins/console_extensions/spec/generated/ml.delete_data_frame_analytics.json @@ -1,5 +1,8 @@ { "ml.delete_data_frame_analytics": { + "url_params": { + "force": "__flag__" + }, "methods": [ "DELETE" ], diff --git a/x-pack/legacy/plugins/console_extensions/spec/generated/ml.explain_data_frame_analytics.json b/x-pack/legacy/plugins/console_extensions/spec/generated/ml.explain_data_frame_analytics.json new file mode 100644 index 0000000000000..212098cc3a202 --- /dev/null +++ b/x-pack/legacy/plugins/console_extensions/spec/generated/ml.explain_data_frame_analytics.json @@ -0,0 +1,13 @@ +{ + "ml.explain_data_frame_analytics": { + "methods": [ + "GET", + "POST" + ], + "patterns": [ + "_ml/data_frame/analytics/_explain", + "_ml/data_frame/analytics/{id}/_explain" + ], + "documentation": "http://www.elastic.co/guide/en/elasticsearch/reference/current/explain-dfanalytics.html" + } +} diff --git a/x-pack/legacy/plugins/console_extensions/spec/generated/ml.put_trained_model.json b/x-pack/legacy/plugins/console_extensions/spec/generated/ml.put_trained_model.json new file mode 100644 index 0000000000000..27d0393be6086 --- /dev/null +++ b/x-pack/legacy/plugins/console_extensions/spec/generated/ml.put_trained_model.json @@ -0,0 +1,11 @@ +{ + "ml.put_trained_model": { + "methods": [ + "PUT" + ], + "patterns": [ + "_ml/inference/{model_id}" + ], + "documentation": "TODO" + } +} diff --git a/x-pack/legacy/plugins/console_extensions/spec/generated/monitoring.bulk.json b/x-pack/legacy/plugins/console_extensions/spec/generated/monitoring.bulk.json index 9f718501e25b5..2b27950e7b097 100644 --- a/x-pack/legacy/plugins/console_extensions/spec/generated/monitoring.bulk.json +++ b/x-pack/legacy/plugins/console_extensions/spec/generated/monitoring.bulk.json @@ -10,8 +10,7 @@ "PUT" ], "patterns": [ - "_monitoring/bulk", - "_monitoring/{type}/bulk" + "_monitoring/bulk" ], "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/master/es-monitoring.html" } diff --git a/x-pack/legacy/plugins/console_extensions/spec/generated/rollup.rollup_search.json b/x-pack/legacy/plugins/console_extensions/spec/generated/rollup.rollup_search.json index a5763646990a5..a1771126a71b4 100644 --- a/x-pack/legacy/plugins/console_extensions/spec/generated/rollup.rollup_search.json +++ b/x-pack/legacy/plugins/console_extensions/spec/generated/rollup.rollup_search.json @@ -9,8 +9,7 @@ "POST" ], "patterns": [ - "{indices}/_rollup_search", - "{indices}/{type}/_rollup_search" + "{indices}/_rollup_search" ] } } diff --git a/x-pack/legacy/plugins/console_extensions/spec/generated/security.get_api_key.json b/x-pack/legacy/plugins/console_extensions/spec/generated/security.get_api_key.json index 431b345a1bcc2..a8cd5de2656b9 100644 --- a/x-pack/legacy/plugins/console_extensions/spec/generated/security.get_api_key.json +++ b/x-pack/legacy/plugins/console_extensions/spec/generated/security.get_api_key.json @@ -4,7 +4,8 @@ "id": "", "name": "", "username": "", - "realm_name": "" + "realm_name": "", + "owner": "__flag__" }, "methods": [ "GET" diff --git a/x-pack/legacy/plugins/console_extensions/spec/generated/slm.get_status.json b/x-pack/legacy/plugins/console_extensions/spec/generated/slm.get_status.json new file mode 100644 index 0000000000000..a7ffde10b316d --- /dev/null +++ b/x-pack/legacy/plugins/console_extensions/spec/generated/slm.get_status.json @@ -0,0 +1,11 @@ +{ + "slm.get_status": { + "methods": [ + "GET" + ], + "patterns": [ + "_slm/status" + ], + "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/current/slm-get-status.html" + } +} diff --git a/x-pack/legacy/plugins/console_extensions/spec/generated/slm.start.json b/x-pack/legacy/plugins/console_extensions/spec/generated/slm.start.json new file mode 100644 index 0000000000000..a5b94d98f08fb --- /dev/null +++ b/x-pack/legacy/plugins/console_extensions/spec/generated/slm.start.json @@ -0,0 +1,11 @@ +{ + "slm.start": { + "methods": [ + "POST" + ], + "patterns": [ + "_slm/start" + ], + "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/current/slm-start.html" + } +} diff --git a/x-pack/legacy/plugins/console_extensions/spec/generated/slm.stop.json b/x-pack/legacy/plugins/console_extensions/spec/generated/slm.stop.json new file mode 100644 index 0000000000000..0b76fe68d2b5e --- /dev/null +++ b/x-pack/legacy/plugins/console_extensions/spec/generated/slm.stop.json @@ -0,0 +1,11 @@ +{ + "slm.stop": { + "methods": [ + "POST" + ], + "patterns": [ + "_slm/stop" + ], + "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/current/slm-stop.html" + } +} diff --git a/x-pack/legacy/plugins/console_extensions/spec/generated/transform.stop_transform.json b/x-pack/legacy/plugins/console_extensions/spec/generated/transform.stop_transform.json index 5ce118b8f7925..27fedcd994ccf 100644 --- a/x-pack/legacy/plugins/console_extensions/spec/generated/transform.stop_transform.json +++ b/x-pack/legacy/plugins/console_extensions/spec/generated/transform.stop_transform.json @@ -1,9 +1,11 @@ { "transform.stop_transform": { "url_params": { + "force": "__flag__", "wait_for_completion": "__flag__", "timeout": "", - "allow_no_match": "__flag__" + "allow_no_match": "__flag__", + "wait_for_checkpoint": "__flag__" }, "methods": [ "POST" diff --git a/x-pack/legacy/plugins/console_extensions/spec/overrides/data_frame_transform_deprecated.preview_transform.json b/x-pack/legacy/plugins/console_extensions/spec/overrides/data_frame_transform_deprecated.preview_transform.json deleted file mode 100644 index fe7148e7fb890..0000000000000 --- a/x-pack/legacy/plugins/console_extensions/spec/overrides/data_frame_transform_deprecated.preview_transform.json +++ /dev/null @@ -1,26 +0,0 @@ -{ - "data_frame_transform_deprecated.preview_transform": { - "data_autocomplete_rules": { - "source": { - "index": "SOURCE_INDEX_NAME", - "query": { - "__scope_link": "GLOBAL.query" - } - }, - "pivot": { - "group_by": { - "__template": { - "NAME": {} - }, - "__scope_link": "GLOBAL.groupByAggs" - }, - "aggregations": { - "__template": { - "NAME": {} - }, - "__scope_link": "GLOBAL.aggregations" - } - } - } - } -} diff --git a/x-pack/legacy/plugins/console_extensions/spec/overrides/data_frame_transform_deprecated.put_transform.json b/x-pack/legacy/plugins/console_extensions/spec/overrides/data_frame_transform_deprecated.put_transform.json deleted file mode 100644 index 1a940888fd770..0000000000000 --- a/x-pack/legacy/plugins/console_extensions/spec/overrides/data_frame_transform_deprecated.put_transform.json +++ /dev/null @@ -1,29 +0,0 @@ -{ - "data_frame_transform_deprecated.put_transform": { - "data_autocomplete_rules": { - "source": { - "index": "SOURCE_INDEX_NAME", - "query": { - "__scope_link": "GLOBAL.query" - } - }, - "dest": { - "index": "DEST_INDEX_NAME" - }, - "pivot": { - "group_by": { - "__template": { - "NAME": {} - }, - "__scope_link": "GLOBAL.groupByAggs" - }, - "aggregations": { - "__template": { - "NAME": {} - }, - "__scope_link": "GLOBAL.aggregations" - } - } - } - } -} diff --git a/x-pack/legacy/plugins/console_extensions/spec/overrides/data_frame_transform_deprecated.update_transform.json b/x-pack/legacy/plugins/console_extensions/spec/overrides/data_frame_transform_deprecated.update_transform.json deleted file mode 100644 index 3c03dc5fa5c50..0000000000000 --- a/x-pack/legacy/plugins/console_extensions/spec/overrides/data_frame_transform_deprecated.update_transform.json +++ /dev/null @@ -1,24 +0,0 @@ -{ - "data_frame_transform_deprecated.update_transform": { - "data_autocomplete_rules": { - "description": "", - "dest": { - "index": "SOURCE_INDEX_NAME", - "pipeline": "" - }, - "frequency": "", - "source": { - "index": "SOURCE_INDEX_NAME", - "query": { - "__scope_link": "GLOBAL.query" - } - }, - "sync": { - "time": { - "field": "FIELD_NAME", - "delay": "" - } - } - } - } -} diff --git a/x-pack/legacy/plugins/console_extensions/spec/overrides/ml.explain_data_frame_analytics.json b/x-pack/legacy/plugins/console_extensions/spec/overrides/ml.explain_data_frame_analytics.json new file mode 100644 index 0000000000000..859ba52d37491 --- /dev/null +++ b/x-pack/legacy/plugins/console_extensions/spec/overrides/ml.explain_data_frame_analytics.json @@ -0,0 +1,38 @@ +{ + "ml.explain_data_frame_analytics": { + "data_autocomplete_rules": { + "data_frame_analytics_config": { + "source": { + "index": { "__one_of": ["SOURCE_INDEX_NAME", []] }, + "query": {} + }, + "dest": { + "index": "", + "results_field": "" + }, + "analysis": { + "outlier_detection": { + "n_neighbors": 1, + "method": {"__one_of": ["lof", "ldof", "distance_knn_nn", "distance_knn"]}, + "feature_influence_threshold": 1.0 + } + }, + "analyzed_fields": { + "__one_of": [ + "FIELD_NAME", + [], + { + "includes": { + "__one_of": ["FIELD_NAME", []] + }, + "excludes": { + "__one_of": ["FIELD_NAME", []] + } + } + ] + }, + "model_memory_limit": "" + } + } + } +} diff --git a/x-pack/legacy/plugins/console_extensions/spec/overrides/ml.put_trained_model.json b/x-pack/legacy/plugins/console_extensions/spec/overrides/ml.put_trained_model.json new file mode 100644 index 0000000000000..9eabbaac9085b --- /dev/null +++ b/x-pack/legacy/plugins/console_extensions/spec/overrides/ml.put_trained_model.json @@ -0,0 +1,5 @@ +{ + "ml.put_trained_model": { + "documentation": "https://www.elastic.co/guide/en/elasticsearch/reference/current/ml-df-analytics-apis.html" + } +} diff --git a/x-pack/legacy/plugins/console_extensions/spec/overrides/slm.start.json b/x-pack/legacy/plugins/console_extensions/spec/overrides/slm.start.json new file mode 100644 index 0000000000000..2949920313df7 --- /dev/null +++ b/x-pack/legacy/plugins/console_extensions/spec/overrides/slm.start.json @@ -0,0 +1,8 @@ +{ + "slm.start": { + "url_params": { + "timeout": "", + "master_timeout": "" + } + } +} diff --git a/x-pack/legacy/plugins/console_extensions/spec/overrides/slm.stop.json b/x-pack/legacy/plugins/console_extensions/spec/overrides/slm.stop.json new file mode 100644 index 0000000000000..c401aa65b9c6b --- /dev/null +++ b/x-pack/legacy/plugins/console_extensions/spec/overrides/slm.stop.json @@ -0,0 +1,8 @@ +{ + "slm.stop": { + "url_params": { + "timeout": "", + "master_timeout": "" + } + } +} From 14be0ee8f4b6616c8c53ab03b8e46b625d279a19 Mon Sep 17 00:00:00 2001 From: patrykkopycinski Date: Tue, 14 Jan 2020 18:53:20 +0100 Subject: [PATCH 113/139] Bump to stable styled-components@5 (#54698) --- package.json | 2 +- .../__snapshots__/index.test.tsx.snap | 86 +++++++++---------- x-pack/package.json | 6 +- yarn.lock | 33 +++---- 4 files changed, 61 insertions(+), 66 deletions(-) diff --git a/package.json b/package.json index 6b9640d214a5e..546a19c6eaba5 100644 --- a/package.json +++ b/package.json @@ -365,7 +365,7 @@ "@types/semver": "^5.5.0", "@types/sinon": "^7.0.13", "@types/strip-ansi": "^3.0.0", - "@types/styled-components": "^4.4.1", + "@types/styled-components": "^4.4.2", "@types/supertest": "^2.0.5", "@types/supertest-as-promised": "^2.0.38", "@types/testing-library__react": "^9.1.2", diff --git a/x-pack/legacy/plugins/siem/public/components/stat_items/__snapshots__/index.test.tsx.snap b/x-pack/legacy/plugins/siem/public/components/stat_items/__snapshots__/index.test.tsx.snap index ca06c484dc8a2..31456ba8c4ada 100644 --- a/x-pack/legacy/plugins/siem/public/components/stat_items/__snapshots__/index.test.tsx.snap +++ b/x-pack/legacy/plugins/siem/public/components/stat_items/__snapshots__/index.test.tsx.snap @@ -38,18 +38,18 @@ exports[`Stat Items Component disable charts it renders the default widget 1`] = data-test-subj="stat-item" >

@@ -272,18 +272,18 @@ exports[`Stat Items Component disable charts it renders the default widget 2`] = data-test-subj="stat-item" >

@@ -576,18 +576,18 @@ exports[`Stat Items Component rendering kpis with charts it renders the default data-test-subj="stat-item" >

1,714 @@ -799,10 +799,10 @@ exports[`Stat Items Component rendering kpis with charts it renders the default key="stat-items-field-uniqueDestinationIps" >

2,359 @@ -903,10 +903,10 @@ exports[`Stat Items Component rendering kpis with charts it renders the default >

= 1" css-to-react-native "^3.0.0" + hoist-non-react-statics "^3.0.0" shallowequal "^1.1.0" - stylis-rule-sheet "^0.0.10" supports-color "^5.5.0" -stylis-rule-sheet@^0.0.10: - version "0.0.10" - resolved "https://registry.yarnpkg.com/stylis-rule-sheet/-/stylis-rule-sheet-0.0.10.tgz#44e64a2b076643f4b52e5ff71efc04d8c3c4a430" - integrity sha512-nTbZoaqoBnmK+ptANthb10ZRZOGC+EmTLLUxeYIuHNkEKcmKgXX1XWKkUBT2Ac4es3NybooPe0SmvKdhKJZAuw== - stylis@3.5.0: version "3.5.0" resolved "https://registry.yarnpkg.com/stylis/-/stylis-3.5.0.tgz#016fa239663d77f868fef5b67cf201c4b7c701e1" From b598c9dc7fdfe6a67b6aad43963af6e2cfdc6729 Mon Sep 17 00:00:00 2001 From: James Gowdy Date: Tue, 14 Jan 2020 17:53:52 +0000 Subject: [PATCH 114/139] [ML] Categorization jobs improvements (#54579) * chunking token examples * disabling bucket span estimator * passing sample size to client * better handing of token errors * changes based on review --- .../plugins/ml/common/constants/new_job.ts | 4 +- .../job_creator/categorization_job_creator.ts | 4 +- .../categorization_examples_loader.ts | 2 +- .../bucket_span_estimator.tsx | 23 +++++- .../categorization_field/description.tsx | 2 +- .../examples_valid_callout.tsx | 20 ++++-- .../categorization_view/metric_selection.tsx | 21 ++++-- .../services/ml_api_service/index.d.ts | 2 +- .../job_service/new_job/categorization.ts | 70 ++++++++++++------- 9 files changed, 104 insertions(+), 44 deletions(-) diff --git a/x-pack/legacy/plugins/ml/common/constants/new_job.ts b/x-pack/legacy/plugins/ml/common/constants/new_job.ts index ccd108cd2698f..3c98b372afdf7 100644 --- a/x-pack/legacy/plugins/ml/common/constants/new_job.ts +++ b/x-pack/legacy/plugins/ml/common/constants/new_job.ts @@ -27,6 +27,6 @@ export const DEFAULT_QUERY_DELAY = '60s'; export const SHARED_RESULTS_INDEX_NAME = 'shared'; export const NUMBER_OF_CATEGORY_EXAMPLES = 5; -export const CATEGORY_EXAMPLES_MULTIPLIER = 20; +export const CATEGORY_EXAMPLES_SAMPLE_SIZE = 1000; export const CATEGORY_EXAMPLES_WARNING_LIMIT = 0.75; -export const CATEGORY_EXAMPLES_ERROR_LIMIT = 0.2; +export const CATEGORY_EXAMPLES_ERROR_LIMIT = 0.02; diff --git a/x-pack/legacy/plugins/ml/public/application/jobs/new_job/common/job_creator/categorization_job_creator.ts b/x-pack/legacy/plugins/ml/public/application/jobs/new_job/common/job_creator/categorization_job_creator.ts index cea99eb5ec64c..7c070ccc6bc53 100644 --- a/x-pack/legacy/plugins/ml/public/application/jobs/new_job/common/job_creator/categorization_job_creator.ts +++ b/x-pack/legacy/plugins/ml/public/application/jobs/new_job/common/job_creator/categorization_job_creator.ts @@ -102,10 +102,10 @@ export class CategorizationJobCreator extends JobCreator { } public async loadCategorizationFieldExamples() { - const { valid, examples } = await this._examplesLoader.loadExamples(); + const { valid, examples, sampleSize } = await this._examplesLoader.loadExamples(); this._categoryFieldExamples = examples; this._categoryFieldValid = valid; - return { valid, examples }; + return { valid, examples, sampleSize }; } public get categoryFieldExamples() { diff --git a/x-pack/legacy/plugins/ml/public/application/jobs/new_job/common/results_loader/categorization_examples_loader.ts b/x-pack/legacy/plugins/ml/public/application/jobs/new_job/common/results_loader/categorization_examples_loader.ts index 16f127ae3d728..ce1ea0bdaf181 100644 --- a/x-pack/legacy/plugins/ml/public/application/jobs/new_job/common/results_loader/categorization_examples_loader.ts +++ b/x-pack/legacy/plugins/ml/public/application/jobs/new_job/common/results_loader/categorization_examples_loader.ts @@ -36,7 +36,7 @@ export class CategorizationExamplesLoader { const analyzer = this._jobCreator.categorizationAnalyzer; const categorizationFieldName = this._jobCreator.categorizationFieldName; if (categorizationFieldName === null) { - return { valid: 0, examples: [] }; + return { valid: 0, examples: [], sampleSize: 0 }; } const start = Math.floor( diff --git a/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/components/pick_fields_step/components/bucket_span_estimator/bucket_span_estimator.tsx b/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/components/pick_fields_step/components/bucket_span_estimator/bucket_span_estimator.tsx index b0f090a993f89..72ebbb0b438a2 100644 --- a/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/components/pick_fields_step/components/bucket_span_estimator/bucket_span_estimator.tsx +++ b/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/components/pick_fields_step/components/bucket_span_estimator/bucket_span_estimator.tsx @@ -7,7 +7,9 @@ import React, { FC, useState, useEffect, useContext } from 'react'; import { FormattedMessage } from '@kbn/i18n/react'; import { EuiButton } from '@elastic/eui'; +import { isAdvancedJobCreator } from '../../../../../common/job_creator'; import { JobCreatorContext } from '../../../job_creator_context'; +import { MLCATEGORY } from '../../../../../../../../../common/constants/field_types'; import { useEstimateBucketSpan, ESTIMATE_STATUS } from './estimate_bucket_span'; @@ -19,6 +21,7 @@ export const BucketSpanEstimator: FC = ({ setEstimating }) => { const { jobCreator, jobCreatorUpdate } = useContext(JobCreatorContext); const { status, estimateBucketSpan } = useEstimateBucketSpan(); const [noDetectors, setNoDetectors] = useState(jobCreator.detectors.length === 0); + const [isUsingMlCategory, setIsUsingMlCategory] = useState(checkIsUsingMlCategory()); useEffect(() => { setEstimating(status === ESTIMATE_STATUS.RUNNING); @@ -26,11 +29,29 @@ export const BucketSpanEstimator: FC = ({ setEstimating }) => { useEffect(() => { setNoDetectors(jobCreator.detectors.length === 0); + setIsUsingMlCategory(checkIsUsingMlCategory()); }, [jobCreatorUpdate]); + function checkIsUsingMlCategory() { + return ( + isAdvancedJobCreator(jobCreator) && + jobCreator.detectors.some(d => { + if ( + d.partition_field_name === MLCATEGORY || + d.over_field_name === MLCATEGORY || + d.by_field_name === MLCATEGORY + ) { + return true; + } + }) + ); + } + return ( = memo(({ children, isOptional }) => { ) : ( )} diff --git a/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/components/pick_fields_step/components/categorization_view/examples_valid_callout.tsx b/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/components/pick_fields_step/components/categorization_view/examples_valid_callout.tsx index 04934d2dc9a36..270ba99d938cd 100644 --- a/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/components/pick_fields_step/components/categorization_view/examples_valid_callout.tsx +++ b/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/components/pick_fields_step/components/categorization_view/examples_valid_callout.tsx @@ -12,8 +12,6 @@ import { FormattedMessage } from '@kbn/i18n/react'; import { CategorizationAnalyzer } from '../../../../../../../services/ml_server_info'; import { EditCategorizationAnalyzerFlyout } from '../../../common/edit_categorization_analyzer_flyout'; import { - NUMBER_OF_CATEGORY_EXAMPLES, - CATEGORY_EXAMPLES_MULTIPLIER, CATEGORY_EXAMPLES_ERROR_LIMIT, CATEGORY_EXAMPLES_WARNING_LIMIT, } from '../../../../../../../../../common/constants/new_job'; @@ -22,11 +20,16 @@ type CategorizationAnalyzerType = CategorizationAnalyzer | null; interface Props { examplesValid: number; + sampleSize: number; categorizationAnalyzer: CategorizationAnalyzerType; } -export const ExamplesValidCallout: FC = ({ examplesValid, categorizationAnalyzer }) => { - const percentageText = ; +export const ExamplesValidCallout: FC = ({ + examplesValid, + categorizationAnalyzer, + sampleSize, +}) => { + const percentageText = ; const analyzerUsed = ; let color: EuiCallOutProps['color'] = 'success'; @@ -64,13 +67,16 @@ export const ExamplesValidCallout: FC = ({ examplesValid, categorizationA ); }; -const PercentageText: FC<{ examplesValid: number }> = ({ examplesValid }) => ( +const PercentageText: FC<{ examplesValid: number; sampleSize: number }> = ({ + examplesValid, + sampleSize, +}) => (
diff --git a/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/components/pick_fields_step/components/categorization_view/metric_selection.tsx b/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/components/pick_fields_step/components/categorization_view/metric_selection.tsx index fda0066f9cd37..52b5c61e70fe5 100644 --- a/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/components/pick_fields_step/components/categorization_view/metric_selection.tsx +++ b/x-pack/legacy/plugins/ml/public/application/jobs/new_job/pages/components/pick_fields_step/components/categorization_view/metric_selection.tsx @@ -6,6 +6,7 @@ import React, { FC, useContext, useEffect, useState } from 'react'; import { EuiHorizontalRule } from '@elastic/eui'; +import { mlMessageBarService } from '../../../../../../../components/messagebar'; import { JobCreatorContext } from '../../../job_creator_context'; import { CategorizationJobCreator } from '../../../../../common/job_creator'; @@ -32,6 +33,7 @@ export const CategorizationDetectors: FC = ({ setIsValid }) => { ); const [fieldExamples, setFieldExamples] = useState(null); const [examplesValid, setExamplesValid] = useState(0); + const [sampleSize, setSampleSize] = useState(0); const [categorizationFieldName, setCategorizationFieldName] = useState( jobCreator.categorizationFieldName @@ -69,10 +71,20 @@ export const CategorizationDetectors: FC = ({ setIsValid }) => { async function loadFieldExamples() { if (categorizationFieldName !== null) { setLoadingData(true); - const { valid, examples } = await jobCreator.loadCategorizationFieldExamples(); - setFieldExamples(examples); - setExamplesValid(valid); - setLoadingData(false); + try { + const { + valid, + examples, + sampleSize: tempSampleSize, + } = await jobCreator.loadCategorizationFieldExamples(); + setFieldExamples(examples); + setExamplesValid(valid); + setLoadingData(false); + setSampleSize(tempSampleSize); + } catch (error) { + setLoadingData(false); + mlMessageBarService.notify.error(error); + } } else { setFieldExamples(null); setExamplesValid(0); @@ -97,6 +109,7 @@ export const CategorizationDetectors: FC = ({ setIsValid }) => { {fieldExamples !== null && loadingData === false && ( <> diff --git a/x-pack/legacy/plugins/ml/public/application/services/ml_api_service/index.d.ts b/x-pack/legacy/plugins/ml/public/application/services/ml_api_service/index.d.ts index bca32e9528f64..db9d158c0ead9 100644 --- a/x-pack/legacy/plugins/ml/public/application/services/ml_api_service/index.d.ts +++ b/x-pack/legacy/plugins/ml/public/application/services/ml_api_service/index.d.ts @@ -185,7 +185,7 @@ declare interface Ml { start: number, end: number, analyzer: any - ): Promise<{ valid: number; examples: any[] }>; + ): Promise<{ valid: number; examples: any[]; sampleSize: number }>; topCategories( jobId: string, count: number diff --git a/x-pack/legacy/plugins/ml/server/models/job_service/new_job/categorization.ts b/x-pack/legacy/plugins/ml/server/models/job_service/new_job/categorization.ts index 34e871a936088..b3c70bf589cd0 100644 --- a/x-pack/legacy/plugins/ml/server/models/job_service/new_job/categorization.ts +++ b/x-pack/legacy/plugins/ml/server/models/job_service/new_job/categorization.ts @@ -4,11 +4,15 @@ * you may not use this file except in compliance with the Elastic License. */ +import { chunk } from 'lodash'; import { ML_RESULTS_INDEX_PATTERN } from '../../../../common/constants/index_patterns'; -import { CATEGORY_EXAMPLES_MULTIPLIER } from '../../../../common/constants/new_job'; +import { CATEGORY_EXAMPLES_SAMPLE_SIZE } from '../../../../common/constants/new_job'; import { CategoryId, Category, Token } from '../../../../common/types/categories'; import { callWithRequestType } from '../../../../common/types/kibana'; +const VALID_TOKEN_COUNT = 3; +const CHUNK_SIZE = 100; + export function categorizationExamplesProvider(callWithRequest: callWithRequestType) { async function categorizationExamples( indexPatternTitle: string, @@ -54,21 +58,31 @@ export function categorizationExamplesProvider(callWithRequest: callWithRequestT }); const examples: string[] = results.hits?.hits ?.map((doc: any) => doc._source[categorizationFieldName]) - .filter((example: string | undefined) => example !== undefined); + .filter((example: string | null | undefined) => example !== undefined && example !== null); - let tokens: Token[] = []; + async function loadTokens(chunkSize: number) { + const exampleChunks = chunk(examples, chunkSize); + const tokensPerChunks = await Promise.all(exampleChunks.map(c => getTokens(c, analyzer))); + const tokensPerExample = tokensPerChunks.flat(); + return examples.map((e, i) => ({ text: e, tokens: tokensPerExample[i] })); + } try { - const { tokens: tempTokens } = await callWithRequest('indices.analyze', { - body: { - ...getAnalyzer(analyzer), - text: examples, - }, - }); - tokens = tempTokens; + return loadTokens(CHUNK_SIZE); } catch (error) { - // fail silently, the tokens could not be loaded - // an empty list of tokens will be returned for each example + // if an error is thrown when loading the tokens, lower the chunk size by half and try again + // the error may have been caused by too many tokens being found. + // the _analyze endpoint has a maximum of 10000 tokens. + return loadTokens(CHUNK_SIZE / 2); } + } + + async function getTokens(examples: string[], analyzer?: any) { + const { tokens }: { tokens: Token[] } = await callWithRequest('indices.analyze', { + body: { + ...getAnalyzer(analyzer), + text: examples, + }, + }); const lengths = examples.map(e => e.length); const sumLengths = lengths.map((s => (a: number) => (s += a))(0)); @@ -88,8 +102,7 @@ export function categorizationExamplesProvider(callWithRequest: callWithRequestT } } }); - - return examples.map((e, i) => ({ text: e, tokens: tokensPerExample[i] })); + return tokensPerExample; } function getAnalyzer(analyzer: any) { @@ -110,10 +123,10 @@ export function categorizationExamplesProvider(callWithRequest: callWithRequestT end: number, analyzer?: any ) { - const examples = await categorizationExamples( + const resp = await categorizationExamples( indexPatternTitle, query, - size * CATEGORY_EXAMPLES_MULTIPLIER, + CATEGORY_EXAMPLES_SAMPLE_SIZE, categorizationFieldName, timeField, start, @@ -121,20 +134,27 @@ export function categorizationExamplesProvider(callWithRequest: callWithRequestT analyzer ); - const sortedExamples = examples + const sortedExamples = resp .map((e, i) => ({ ...e, origIndex: i })) .sort((a, b) => b.tokens.length - a.tokens.length); - const validExamples = sortedExamples.filter(e => e.tokens.length > 1); + const validExamples = sortedExamples.filter(e => e.tokens.length >= VALID_TOKEN_COUNT); + const sampleSize = sortedExamples.length; + + const multiple = Math.floor(sampleSize / size) || sampleSize; + const filteredExamples = []; + let i = 0; + while (filteredExamples.length < size && i < sortedExamples.length) { + filteredExamples.push(sortedExamples[i]); + i += multiple; + } + const examples = filteredExamples + .sort((a, b) => a.origIndex - b.origIndex) + .map(e => ({ text: e.text, tokens: e.tokens })); return { + sampleSize, valid: sortedExamples.length === 0 ? 0 : validExamples.length / sortedExamples.length, - examples: sortedExamples - .filter( - (e, i) => - i / CATEGORY_EXAMPLES_MULTIPLIER - Math.floor(i / CATEGORY_EXAMPLES_MULTIPLIER) === 0 - ) - .sort((a, b) => a.origIndex - b.origIndex) - .map(e => ({ text: e.text, tokens: e.tokens })), + examples, }; } From 46b34db465ebcee8a4a42838a97f7776d6c1876c Mon Sep 17 00:00:00 2001 From: Maja Grubic Date: Tue, 14 Jan 2020 17:54:53 +0000 Subject: [PATCH 115/139] [Dashboard] decode url params, so they are not encoded twice (#54738) Co-authored-by: Elastic Machine --- .../kibana/public/dashboard/__tests__/url_helper.test.ts | 5 +++-- .../kibana/public/dashboard/np_ready/url_helper.ts | 2 +- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/src/legacy/core_plugins/kibana/public/dashboard/__tests__/url_helper.test.ts b/src/legacy/core_plugins/kibana/public/dashboard/__tests__/url_helper.test.ts index 16773c02f5a7b..df2dbfd54c130 100644 --- a/src/legacy/core_plugins/kibana/public/dashboard/__tests__/url_helper.test.ts +++ b/src/legacy/core_plugins/kibana/public/dashboard/__tests__/url_helper.test.ts @@ -82,10 +82,11 @@ describe('Dashboard URL Helper', () => { x: 'y', y: 'z', }); - url = 'http://notDashboardUrl'; - expect(getUrlVars(url)).toEqual({}); url = 'http://localhost:5601/app/kibana#/dashboard/777182'; expect(getUrlVars(url)).toEqual({}); + url = + 'http://localhost:5601/app/kibana#/dashboard/777182?title=Some%20Dashboard%20With%20Spaces'; + expect(getUrlVars(url)).toEqual({ title: 'Some Dashboard With Spaces' }); }); it('getLensUrlFromDashboardAbsoluteUrl', () => { diff --git a/src/legacy/core_plugins/kibana/public/dashboard/np_ready/url_helper.ts b/src/legacy/core_plugins/kibana/public/dashboard/np_ready/url_helper.ts index ee9e3c4ef4781..2e360567c4653 100644 --- a/src/legacy/core_plugins/kibana/public/dashboard/np_ready/url_helper.ts +++ b/src/legacy/core_plugins/kibana/public/dashboard/np_ready/url_helper.ts @@ -28,7 +28,7 @@ export function getUrlVars(url: string): Record { // @ts-ignore url.replace(/[?&]+([^=&]+)=([^&]*)/gi, function(_, key, value) { // @ts-ignore - vars[key] = value; + vars[key] = decodeURIComponent(value); }); return vars; } From 8d57df0fe615352f09120393eda9e722c2dc1c95 Mon Sep 17 00:00:00 2001 From: Dario Gieselaar Date: Tue, 14 Jan 2020 18:57:21 +0100 Subject: [PATCH 116/139] [APM]: Fix render error when license has not been loaded (#54718) --- .../plugins/apm/public/context/LicenseContext/index.tsx | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/x-pack/legacy/plugins/apm/public/context/LicenseContext/index.tsx b/x-pack/legacy/plugins/apm/public/context/LicenseContext/index.tsx index 0bd3896782603..62cdbd3bbc995 100644 --- a/x-pack/legacy/plugins/apm/public/context/LicenseContext/index.tsx +++ b/x-pack/legacy/plugins/apm/public/context/LicenseContext/index.tsx @@ -16,8 +16,9 @@ export const LicenseContext = React.createContext( export function LicenseProvider({ children }: { children: React.ReactChild }) { const { license$ } = useApmPluginContext().plugins.licensing; - const license = useObservable(license$, { isActive: true } as ILicense); - const hasInvalidLicense = !license.isActive; + const license = useObservable(license$); + // if license is not loaded yet, consider it valid + const hasInvalidLicense = license?.isActive === false; // if license is invalid show an error message if (hasInvalidLicense) { From fdf51a5f8b6ba26a4dfff46362a4845b32a38762 Mon Sep 17 00:00:00 2001 From: Tiago Costa Date: Tue, 14 Jan 2020 18:06:53 +0000 Subject: [PATCH 117/139] Splits dll in chunks (#54600) * feat(NA): implement dll split feature * chore(NA): improve logic to split dlls * feat(NA): support multiple manifests in the clean dll task * fix(NA): patch clean dll task to support multiple manifest files * feat(NA): shuffle seed before split dll in chunks * chore(NA): correctly load chunks into the templates * chore(NA): correctly load chunks on karma tests * docs(NA): add explanation why we need a single runtime for dll chunks * teste(NA): fix jest tests --- package.json | 1 + src/dev/build/README.md | 2 +- .../clean_client_modules_on_dll_task.js | 10 +- .../build/tasks/nodejs_modules/webpack_dll.js | 44 +++--- .../tasks/nodejs_modules/webpack_dll.test.js | 10 +- .../ui/ui_render/bootstrap/template.js.hbs | 5 +- src/legacy/ui/ui_render/ui_render_mixin.js | 10 +- .../dynamic_dll_plugin/dll_compiler.js | 137 ++++++++++++++---- .../dynamic_dll_plugin/dll_config_model.js | 15 +- .../dynamic_dll_plugin/dll_entry_template.js | 16 ++ .../dynamic_dll_plugin/dynamic_dll_plugin.js | 20 ++- tasks/config/karma.js | 10 +- yarn.lock | 5 + 13 files changed, 216 insertions(+), 69 deletions(-) diff --git a/package.json b/package.json index 546a19c6eaba5..c8ad736ea976f 100644 --- a/package.json +++ b/package.json @@ -254,6 +254,7 @@ "rison-node": "1.0.2", "rxjs": "^6.5.3", "script-loader": "0.7.2", + "seedrandom": "^3.0.5", "semver": "^5.5.0", "style-it": "^2.1.3", "style-loader": "0.23.1", diff --git a/src/dev/build/README.md b/src/dev/build/README.md index af08414f0bf4b..3b579033fabe1 100644 --- a/src/dev/build/README.md +++ b/src/dev/build/README.md @@ -44,7 +44,7 @@ The majority of this logic is extracted from the grunt build that has existed fo We have introduced in our bundle a webpack dll for the client vendor modules in order to improve the optimization time both in dev and in production. As for those modules we already have the -code into the vendors.bundle.dll.js we have decided to delete those bundled modules from the +code into the vendors_${chunk_number}.bundle.dll.js we have decided to delete those bundled modules from the distributable node_modules folder. However, in order to accomplish this, we need to exclude every node_module used in the server side code. This logic is performed under `nodejs_modules/clean_client_modules_on_dll_task.js`. In case we need to add any new cli diff --git a/src/dev/build/tasks/nodejs_modules/clean_client_modules_on_dll_task.js b/src/dev/build/tasks/nodejs_modules/clean_client_modules_on_dll_task.js index 19d74bcf89e30..52928d6e47fc4 100644 --- a/src/dev/build/tasks/nodejs_modules/clean_client_modules_on_dll_task.js +++ b/src/dev/build/tasks/nodejs_modules/clean_client_modules_on_dll_task.js @@ -98,12 +98,16 @@ export const CleanClientModulesOnDLLTask = { // Consider this as our whiteList for the modules we can't delete const whiteListedModules = [...serverDependencies, ...kbnWebpackLoaders, ...manualExceptions]; - // Resolve the client vendors dll manifest path - const dllManifestPath = `${baseDir}/built_assets/dlls/vendors.manifest.dll.json`; + // Resolve the client vendors dll manifest paths + // excluding the runtime one + const dllManifestPaths = await globby([ + `${baseDir}/built_assets/dlls/vendors_*.manifest.dll.json`, + `!${baseDir}/built_assets/dlls/vendors_runtime.manifest.dll.json`, + ]); // Get dll entries filtering out the ones // from any whitelisted module - const dllEntries = await getDllEntries(dllManifestPath, whiteListedModules, baseDir); + const dllEntries = await getDllEntries(dllManifestPaths, whiteListedModules, baseDir); for (const relativeEntryPath of dllEntries) { const entryPath = `${baseDir}/${relativeEntryPath}`; diff --git a/src/dev/build/tasks/nodejs_modules/webpack_dll.js b/src/dev/build/tasks/nodejs_modules/webpack_dll.js index ea8cc1e286407..72910226bb04a 100644 --- a/src/dev/build/tasks/nodejs_modules/webpack_dll.js +++ b/src/dev/build/tasks/nodejs_modules/webpack_dll.js @@ -28,27 +28,37 @@ function checkDllEntryAccess(entry, baseDir = '') { return isFileAccessible(resolvedPath); } -export async function getDllEntries(manifestPath, whiteListedModules, baseDir = '') { - const manifest = JSON.parse(await read(manifestPath)); - - if (!manifest || !manifest.content) { - // It should fails because if we don't have the manifest file - // or it is malformed something wrong is happening and we - // should stop - throw new Error(`The following dll manifest doesn't exists: ${manifestPath}`); - } +export async function getDllEntries(manifestPaths, whiteListedModules, baseDir = '') { + // Read and parse all manifests + const manifests = await Promise.all( + manifestPaths.map(async manifestPath => JSON.parse(await read(manifestPath))) + ); - const modules = Object.keys(manifest.content); - if (!modules.length) { - // It should fails because if we don't have any - // module inside the client vendors dll something - // wrong is happening and we should stop too - throw new Error(`The following dll manifest is reporting an empty dll: ${manifestPath}`); - } + // Process and group modules from all manifests + const manifestsModules = manifests.flatMap((manifest, idx) => { + if (!manifest || !manifest.content) { + // It should fails because if we don't have the manifest file + // or it is malformed something wrong is happening and we + // should stop + throw new Error(`The following dll manifest doesn't exists: ${manifestPaths[idx]}`); + } + + const modules = Object.keys(manifest.content); + if (!modules.length) { + // It should fails because if we don't have any + // module inside the client vendors dll something + // wrong is happening and we should stop too + throw new Error( + `The following dll manifest is reporting an empty dll: ${manifestPaths[idx]}` + ); + } + + return modules; + }); // Only includes modules who are not in the white list of modules // and that are node_modules - return modules.filter(entry => { + return manifestsModules.filter(entry => { const isWhiteListed = whiteListedModules.some(nonEntry => normalizePosixPath(entry).includes(`node_modules/${nonEntry}`) ); diff --git a/src/dev/build/tasks/nodejs_modules/webpack_dll.test.js b/src/dev/build/tasks/nodejs_modules/webpack_dll.test.js index 1fdd7d8d4f5ff..ce305169a777b 100644 --- a/src/dev/build/tasks/nodejs_modules/webpack_dll.test.js +++ b/src/dev/build/tasks/nodejs_modules/webpack_dll.test.js @@ -52,7 +52,7 @@ describe('Webpack DLL Build Tasks Utils', () => { isFileAccessible.mockImplementation(() => true); - const mockManifestPath = '/mock/mock_dll_manifest.json'; + const mockManifestPath = ['/mock/mock_dll_manifest.json']; const mockModulesWhitelist = ['dep1']; const dllEntries = await getDllEntries(mockManifestPath, mockModulesWhitelist); @@ -66,7 +66,7 @@ describe('Webpack DLL Build Tasks Utils', () => { isFileAccessible.mockImplementation(() => false); - const mockManifestPath = '/mock/mock_dll_manifest.json'; + const mockManifestPath = ['/mock/mock_dll_manifest.json']; const mockModulesWhitelist = ['dep1']; const dllEntries = await getDllEntries(mockManifestPath, mockModulesWhitelist); @@ -78,7 +78,7 @@ describe('Webpack DLL Build Tasks Utils', () => { it('should throw an error for no manifest file', async () => { read.mockImplementationOnce(async () => noManifestMock); - const mockManifestPath = '/mock/mock_dll_manifest.json'; + const mockManifestPath = ['/mock/mock_dll_manifest.json']; try { await getDllEntries(mockManifestPath, []); @@ -92,7 +92,7 @@ describe('Webpack DLL Build Tasks Utils', () => { it('should throw an error for no manifest content field', async () => { read.mockImplementation(async () => noContentFieldManifestMock); - const mockManifestPath = '/mock/mock_dll_manifest.json'; + const mockManifestPath = ['/mock/mock_dll_manifest.json']; try { await getDllEntries(mockManifestPath, []); @@ -106,7 +106,7 @@ describe('Webpack DLL Build Tasks Utils', () => { it('should throw an error for manifest file without any content', async () => { read.mockImplementation(async () => emptyManifestContentMock); - const mockManifestPath = '/mock/mock_dll_manifest.json'; + const mockManifestPath = ['/mock/mock_dll_manifest.json']; try { await getDllEntries(mockManifestPath, []); diff --git a/src/legacy/ui/ui_render/bootstrap/template.js.hbs b/src/legacy/ui/ui_render/bootstrap/template.js.hbs index 85b6de26b9516..72dd97ff58642 100644 --- a/src/legacy/ui/ui_render/bootstrap/template.js.hbs +++ b/src/legacy/ui/ui_render/bootstrap/template.js.hbs @@ -13,7 +13,10 @@ if (window.__kbnStrictCsp__ && window.__kbnCspNotEnforced__) { window.onload = function () { var files = [ - '{{dllBundlePath}}/vendors.bundle.dll.js', + '{{dllBundlePath}}/vendors_runtime.bundle.dll.js', + {{#each dllJsChunks}} + '{{this}}', + {{/each}} '{{regularBundlePath}}/kbn-ui-shared-deps/{{sharedDepsFilename}}', '{{regularBundlePath}}/commons.bundle.js', '{{regularBundlePath}}/{{appId}}.bundle.js' diff --git a/src/legacy/ui/ui_render/ui_render_mixin.js b/src/legacy/ui/ui_render/ui_render_mixin.js index a935270d23fce..4158af19bd858 100644 --- a/src/legacy/ui/ui_render/ui_render_mixin.js +++ b/src/legacy/ui/ui_render/ui_render_mixin.js @@ -26,6 +26,7 @@ import { AppBootstrap } from './bootstrap'; // eslint-disable-next-line @kbn/eslint/no-restricted-paths import { fromRoot } from '../../../core/server/utils'; import { getApmConfig } from '../apm'; +import { DllCompiler } from '../../../optimize/dynamic_dll_plugin'; /** * @typedef {import('../../server/kbn_server').default} KbnServer @@ -103,8 +104,14 @@ export function uiRenderMixin(kbnServer, server, config) { const basePath = config.get('server.basePath'); const regularBundlePath = `${basePath}/bundles`; const dllBundlePath = `${basePath}/built_assets/dlls`; + const dllStyleChunks = DllCompiler.getRawDllConfig().chunks.map( + chunk => `${dllBundlePath}/vendors${chunk}.style.dll.css` + ); + const dllJsChunks = DllCompiler.getRawDllConfig().chunks.map( + chunk => `${dllBundlePath}/vendors${chunk}.bundle.dll.js` + ); const styleSheetPaths = [ - `${dllBundlePath}/vendors.style.dll.css`, + ...dllStyleChunks, ...(darkMode ? [ `${basePath}/bundles/kbn-ui-shared-deps/${UiSharedDeps.darkCssDistFilename}`, @@ -132,6 +139,7 @@ export function uiRenderMixin(kbnServer, server, config) { appId: isCore ? 'core' : app.getId(), regularBundlePath, dllBundlePath, + dllJsChunks, styleSheetPaths, sharedDepsFilename: UiSharedDeps.distFilename, }, diff --git a/src/optimize/dynamic_dll_plugin/dll_compiler.js b/src/optimize/dynamic_dll_plugin/dll_compiler.js index 7d558367c032d..9889c1f71c3bf 100644 --- a/src/optimize/dynamic_dll_plugin/dll_compiler.js +++ b/src/optimize/dynamic_dll_plugin/dll_compiler.js @@ -23,6 +23,11 @@ import { notInNodeModules, inDllPluginPublic, } from './dll_allowed_modules'; +import { + dllEntryFileContentArrayToString, + dllEntryFileContentStringToArray, + dllMergeAllEntryFilesContent, +} from './dll_entry_template'; import { fromRoot } from '../../core/server/utils'; import { PUBLIC_PATH_PLACEHOLDER } from '../public_path_placeholder'; import fs from 'fs'; @@ -30,6 +35,8 @@ import webpack from 'webpack'; import { promisify } from 'util'; import path from 'path'; import del from 'del'; +import { chunk } from 'lodash'; +import seedrandom from 'seedrandom'; const readFileAsync = promisify(fs.readFile); const mkdirAsync = promisify(fs.mkdir); @@ -37,11 +44,17 @@ const accessAsync = promisify(fs.access); const writeFileAsync = promisify(fs.writeFile); export class DllCompiler { - static getRawDllConfig(uiBundles = {}, babelLoaderCacheDir = '', threadLoaderPoolConfig = {}) { + static getRawDllConfig( + uiBundles = {}, + babelLoaderCacheDir = '', + threadLoaderPoolConfig = {}, + chunks = Array.from(Array(4).keys()).map(chunkN => `_${chunkN}`) + ) { return { uiBundles, babelLoaderCacheDir, threadLoaderPoolConfig, + chunks, context: fromRoot('.'), entryName: 'vendors', dllName: '[name]', @@ -66,13 +79,49 @@ export class DllCompiler { } async init() { - await this.ensureEntryFileExists(); - await this.ensureManifestFileExists(); + await this.ensureEntryFilesExists(); + await this.ensureManifestFilesExists(); await this.ensureOutputPathExists(); } - async upsertEntryFile(content) { - await this.upsertFile(this.getEntryPath(), content); + seededShuffle(array) { + // Implementation based on https://github.com/TimothyGu/knuth-shuffle-seeded/blob/gh-pages/index.js#L46 + let currentIndex; + let temporaryValue; + let randomIndex; + const rand = seedrandom('predictable', { global: false }); + + if (array.constructor !== Array) throw new Error('Input is not an array'); + currentIndex = array.length; + + // While there remain elements to shuffle... + while (0 !== currentIndex) { + // Pick a remaining element... + randomIndex = Math.floor(rand() * currentIndex--); + + // And swap it with the current element. + temporaryValue = array[currentIndex]; + array[currentIndex] = array[randomIndex]; + array[randomIndex] = temporaryValue; + } + + return array; + } + + async upsertEntryFiles(content) { + const arrayContent = this.seededShuffle(dllEntryFileContentStringToArray(content)); + const chunks = chunk( + arrayContent, + Math.ceil(arrayContent.length / this.rawDllConfig.chunks.length) + ); + const entryPaths = this.getEntryPaths(); + + await Promise.all( + entryPaths.map( + async (entryPath, idx) => + await this.upsertFile(entryPath, dllEntryFileContentArrayToString(chunks[idx])) + ) + ); } async upsertFile(filePath, content = '') { @@ -80,38 +129,57 @@ export class DllCompiler { await writeFileAsync(filePath, content, 'utf8'); } - getDllPath() { - return this.resolvePath(`${this.rawDllConfig.entryName}${this.rawDllConfig.dllExt}`); + getDllPaths() { + return this.rawDllConfig.chunks.map(chunk => + this.resolvePath(`${this.rawDllConfig.entryName}${chunk}${this.rawDllConfig.dllExt}`) + ); } - getEntryPath() { - return this.resolvePath(`${this.rawDllConfig.entryName}${this.rawDllConfig.entryExt}`); + getEntryPaths() { + return this.rawDllConfig.chunks.map(chunk => + this.resolvePath(`${this.rawDllConfig.entryName}${chunk}${this.rawDllConfig.entryExt}`) + ); } - getManifestPath() { - return this.resolvePath(`${this.rawDllConfig.entryName}${this.rawDllConfig.manifestExt}`); + getManifestPaths() { + return this.rawDllConfig.chunks.map(chunk => + this.resolvePath(`${this.rawDllConfig.entryName}${chunk}${this.rawDllConfig.manifestExt}`) + ); } - getStylePath() { - return this.resolvePath(`${this.rawDllConfig.entryName}${this.rawDllConfig.styleExt}`); + getStylePaths() { + return this.rawDllConfig.chunks.map(chunk => + this.resolvePath(`${this.rawDllConfig.entryName}${chunk}${this.rawDllConfig.styleExt}`) + ); } - async ensureEntryFileExists() { - await this.ensureFileExists(this.getEntryPath()); + async ensureEntryFilesExists() { + const entryPaths = this.getEntryPaths(); + + await Promise.all(entryPaths.map(async entryPath => await this.ensureFileExists(entryPath))); } - async ensureManifestFileExists() { - await this.ensureFileExists( - this.getManifestPath(), - JSON.stringify({ - name: this.rawDllConfig.entryName, - content: {}, - }) + async ensureManifestFilesExists() { + const manifestPaths = this.getManifestPaths(); + + await Promise.all( + manifestPaths.map( + async (manifestPath, idx) => + await this.ensureFileExists( + manifestPath, + JSON.stringify({ + name: `${this.rawDllConfig.entryName}${this.rawDllConfig.chunks[idx]}`, + content: {}, + }) + ) + ) ); } async ensureStyleFileExists() { - await this.ensureFileExists(this.getStylePath()); + const stylePaths = this.getStylePaths(); + + await Promise.all(stylePaths.map(async stylePath => await this.ensureFileExists(stylePath))); } async ensureFileExists(filePath, content) { @@ -137,8 +205,10 @@ export class DllCompiler { await this.ensurePathExists(this.rawDllConfig.outputPath); } - dllExistsSync() { - return this.existsSync(this.getDllPath()); + dllsExistsSync() { + const dllPaths = this.getDllPaths(); + + return dllPaths.every(dllPath => this.existsSync(dllPath)); } existsSync(filePath) { @@ -149,8 +219,16 @@ export class DllCompiler { return path.resolve(this.rawDllConfig.outputPath, ...arguments); } - async readEntryFile() { - return await this.readFile(this.getEntryPath()); + async readEntryFiles() { + const entryPaths = this.getEntryPaths(); + + const entryFilesContent = await Promise.all( + entryPaths.map(async entryPath => await this.readFile(entryPath)) + ); + + // merge all the module contents from entry files again into + // sorted single one + return dllMergeAllEntryFilesContent(entryFilesContent); } async readFile(filePath, content) { @@ -160,7 +238,7 @@ export class DllCompiler { async run(dllEntries) { const dllConfig = this.dllConfigGenerator(this.rawDllConfig); - await this.upsertEntryFile(dllEntries); + await this.upsertEntryFiles(dllEntries); try { this.logWithMetadata( @@ -234,7 +312,7 @@ export class DllCompiler { // ignore if this module represents the // dll entry file - if (module.resource === this.getEntryPath()) { + if (this.getEntryPaths().includes(module.resource)) { return; } @@ -259,7 +337,6 @@ export class DllCompiler { // node_module or no? if (notInNodeModules(reason.module.resource)) { notAllowedModules.push(module.resource); - return; } }); } diff --git a/src/optimize/dynamic_dll_plugin/dll_config_model.js b/src/optimize/dynamic_dll_plugin/dll_config_model.js index ecf5def5aa6ca..c7ab2fe30dd14 100644 --- a/src/optimize/dynamic_dll_plugin/dll_config_model.js +++ b/src/optimize/dynamic_dll_plugin/dll_config_model.js @@ -140,6 +140,13 @@ function generateDLL(config) { filename: dllStyleFilename, }), ], + // Single runtime for the dll bundles which assures that common transient dependencies won't be evaluated twice. + // The module cache will be shared, even when module code may be duplicated across chunks. + optimization: { + runtimeChunk: { + name: 'vendors_runtime', + }, + }, performance: { // NOTE: we are disabling this as those hints // are more tailored for the final bundles result @@ -158,6 +165,7 @@ function extendRawConfig(rawConfig) { const dllNoParseRules = rawConfig.uiBundles.getWebpackNoParseRules(); const dllDevMode = rawConfig.uiBundles.isDevMode(); const dllContext = rawConfig.context; + const dllChunks = rawConfig.chunks; const dllEntry = {}; const dllEntryName = rawConfig.entryName; const dllBundleName = rawConfig.dllName; @@ -176,7 +184,12 @@ function extendRawConfig(rawConfig) { const threadLoaderPoolConfig = rawConfig.threadLoaderPoolConfig; // Create webpack entry object key with the provided dllEntryName - dllEntry[dllEntryName] = [`${dllOutputPath}/${dllEntryName}${dllEntryExt}`]; + dllChunks.reduce((dllEntryObj, chunk) => { + dllEntryObj[`${dllEntryName}${chunk}`] = [ + `${dllOutputPath}/${dllEntryName}${chunk}${dllEntryExt}`, + ]; + return dllEntryObj; + }, dllEntry); // Export dll config map return { diff --git a/src/optimize/dynamic_dll_plugin/dll_entry_template.js b/src/optimize/dynamic_dll_plugin/dll_entry_template.js index 584bf0c9e3d35..0c286896d0b71 100644 --- a/src/optimize/dynamic_dll_plugin/dll_entry_template.js +++ b/src/optimize/dynamic_dll_plugin/dll_entry_template.js @@ -23,3 +23,19 @@ export function dllEntryTemplate(requirePaths = []) { .sort() .join('\n'); } + +export function dllEntryFileContentStringToArray(content = '') { + return content.split('\n'); +} + +export function dllEntryFileContentArrayToString(content = []) { + return content.join('\n'); +} + +export function dllMergeAllEntryFilesContent(content = []) { + return content + .join('\n') + .split('\n') + .sort() + .join('\n'); +} diff --git a/src/optimize/dynamic_dll_plugin/dynamic_dll_plugin.js b/src/optimize/dynamic_dll_plugin/dynamic_dll_plugin.js index cb941d2ba5683..484c7dfbfd595 100644 --- a/src/optimize/dynamic_dll_plugin/dynamic_dll_plugin.js +++ b/src/optimize/dynamic_dll_plugin/dynamic_dll_plugin.js @@ -44,7 +44,7 @@ export class DynamicDllPlugin { async init() { await this.dllCompiler.init(); - this.entryPaths = await this.dllCompiler.readEntryFile(); + this.entryPaths = await this.dllCompiler.readEntryFiles(); } apply(compiler) { @@ -70,12 +70,14 @@ export class DynamicDllPlugin { bindDllReferencePlugin(compiler) { const rawDllConfig = this.dllCompiler.rawDllConfig; const dllContext = rawDllConfig.context; - const dllManifestPath = this.dllCompiler.getManifestPath(); + const dllManifestPaths = this.dllCompiler.getManifestPaths(); - new webpack.DllReferencePlugin({ - context: dllContext, - manifest: dllManifestPath, - }).apply(compiler); + dllManifestPaths.forEach(dllChunkManifestPath => { + new webpack.DllReferencePlugin({ + context: dllContext, + manifest: dllChunkManifestPath, + }).apply(compiler); + }); } registerInitBasicHooks(compiler) { @@ -192,7 +194,7 @@ export class DynamicDllPlugin { // then will be set to false compilation.needsDLLCompilation = this.afterCompilationEntryPaths !== this.entryPaths || - !this.dllCompiler.dllExistsSync() || + !this.dllCompiler.dllsExistsSync() || (this.isToForceDLLCreation() && this.performedCompilations === 0); this.entryPaths = this.afterCompilationEntryPaths; @@ -337,7 +339,9 @@ export class DynamicDllPlugin { // We need to purge the cache into the inputFileSystem // for every single built in previous compilation // that we rely in next ones. - mainCompiler.inputFileSystem.purge(this.dllCompiler.getManifestPath()); + this.dllCompiler + .getManifestPaths() + .forEach(chunkDllManifestPath => mainCompiler.inputFileSystem.purge(chunkDllManifestPath)); this.performedCompilations++; diff --git a/tasks/config/karma.js b/tasks/config/karma.js index 0acd452530b30..ec37277cae0f8 100644 --- a/tasks/config/karma.js +++ b/tasks/config/karma.js @@ -21,6 +21,7 @@ import { dirname } from 'path'; import { times } from 'lodash'; import { makeJunitReportPath } from '@kbn/test'; import * as UiSharedDeps from '@kbn/ui-shared-deps'; +import { DllCompiler } from '../../src/optimize/dynamic_dll_plugin'; const TOTAL_CI_SHARDS = 4; const ROOT = dirname(require.resolve('../../package.json')); @@ -54,7 +55,10 @@ module.exports = function(grunt) { 'http://localhost:5610/test_bundle/built_css.css', `http://localhost:5610/bundles/kbn-ui-shared-deps/${UiSharedDeps.distFilename}`, - 'http://localhost:5610/built_assets/dlls/vendors.bundle.dll.js', + 'http://localhost:5610/built_assets/dlls/vendors_runtime.bundle.dll.js', + ...DllCompiler.getRawDllConfig().chunks.map( + chunk => `http://localhost:5610/built_assets/dlls/vendors${chunk}.bundle.dll.js` + ), shardNum === undefined ? `http://localhost:5610/bundles/tests.bundle.js` @@ -63,7 +67,9 @@ module.exports = function(grunt) { // this causes tilemap tests to fail, probably because the eui styles haven't been // included in the karma harness a long some time, if ever // `http://localhost:5610/bundles/kbn-ui-shared-deps/${UiSharedDeps.lightCssDistFilename}`, - 'http://localhost:5610/built_assets/dlls/vendors.style.dll.css', + ...DllCompiler.getRawDllConfig().chunks.map( + chunk => `http://localhost:5610/built_assets/dlls/vendors${chunk}.style.dll.css` + ), 'http://localhost:5610/bundles/tests.style.css', ]; } diff --git a/yarn.lock b/yarn.lock index dfce24ad77d2e..3590b10607e14 100644 --- a/yarn.lock +++ b/yarn.lock @@ -25382,6 +25382,11 @@ scss-tokenizer@^0.2.3: js-base64 "^2.1.8" source-map "^0.4.2" +seedrandom@^3.0.5: + version "3.0.5" + resolved "https://registry.yarnpkg.com/seedrandom/-/seedrandom-3.0.5.tgz#54edc85c95222525b0c7a6f6b3543d8e0b3aa0a7" + integrity sha512-8OwmbklUNzwezjGInmZ+2clQmExQPvomqjL7LFqOYqtmuxRgQYqOD3mHaU+MvZn5FLUeVxVfQjwLZW/n/JFuqg== + seek-bzip@^1.0.5: version "1.0.5" resolved "https://registry.yarnpkg.com/seek-bzip/-/seek-bzip-1.0.5.tgz#cfe917cb3d274bcffac792758af53173eb1fabdc" From 6bed80bbd8d51fa30b104eed35cca23b00ee1613 Mon Sep 17 00:00:00 2001 From: Chandler Prall Date: Tue, 14 Jan 2020 11:23:43 -0700 Subject: [PATCH 118/139] Upgraded EUI to 18.0.0 (#54042) * Upgraded EUI to 18.0.0 * Fix breaks from `palette._.colors` changes * snapshots * Updated hard coded hex color codes in tests, fixed TS errors * Updated a functional test's selector; added (BSD-3-Clause AND Apache-2.0) to license checker whitelist * Functional test selector update * Updated vega browser-ci tests for palette changes * rebased on master * One more location for EUI package number update and yarn lock * Fixed lurking [but introduced] TypeScript logic bug * Swap a prop definition for the same value but tied closer to its source Co-authored-by: Caroline Horn <549577+cchaos@users.noreply.github.com> Co-authored-by: Elastic Machine --- package.json | 2 +- packages/kbn-ui-shared-deps/package.json | 2 +- src/dev/license_checker/config.ts | 1 + .../shard_failure_table.test.tsx.snap | 1 + .../__snapshots__/controls_tab.test.tsx.snap | 4 - .../list_control_editor.test.tsx.snap | 4 - .../components/editor/list_control_editor.tsx | 11 +- .../__snapshots__/list_control.test.tsx.snap | 3 - .../kbn_vislib_vis_types/public/area.js | 4 +- .../kbn_vislib_vis_types/public/histogram.js | 4 +- .../public/horizontal_bar.js | 4 +- .../kbn_vislib_vis_types/public/line.js | 4 +- .../__snapshots__/clone_modal.test.js.snap | 3 - .../__snapshots__/header.test.js.snap | 6 - .../__snapshots__/time_field.test.js.snap | 10 - .../__jest__/__snapshots__/table.test.js.snap | 1 + .../__jest__/__snapshots__/table.test.js.snap | 1 + .../__snapshots__/add_filter.test.js.snap | 4 - .../__jest__/__snapshots__/table.test.js.snap | 3 +- .../__snapshots__/objects_table.test.js.snap | 1 + .../__snapshots__/flyout.test.js.snap | 2 + .../__snapshots__/relationships.test.js.snap | 4 + .../__jest__/__snapshots__/table.test.js.snap | 2 + .../field/__snapshots__/field.test.js.snap | 45 - .../__snapshots__/new_vis_modal.test.tsx.snap | 118 +++ .../__snapshots__/status_table.test.js.snap | 1 + .../splits/__snapshots__/terms.test.js.snap | 6 - .../public/__tests__/vega_image_512.png | Bin 31097 -> 30730 bytes .../data_model/__tests__/vega_parser.js | 20 +- .../bytes/__snapshots__/bytes.test.js.snap | 3 - .../color/__snapshots__/color.test.js.snap | 3 + .../date/__snapshots__/date.test.js.snap | 3 - .../__snapshots__/date_nanos.test.js.snap | 3 - .../__snapshots__/duration.test.js.snap | 16 - .../number/__snapshots__/number.test.js.snap | 3 - .../__snapshots__/percent.test.js.snap | 3 - .../__snapshots__/static_lookup.test.js.snap | 8 +- .../string/__snapshots__/string.test.js.snap | 4 - .../label_template_flyout.test.js.snap | 1 + .../url/__snapshots__/url.test.js.snap | 40 - .../url_template_flyout.test.js.snap | 1 + .../__snapshots__/samples.test.js.snap | 1 + .../public/field_editor/field_editor.test.js | 4 +- .../__snapshots__/metric_agg.test.tsx.snap | 2 - .../__snapshots__/top_aggregate.test.tsx.snap | 2 - .../point_series/_point_series.js | 4 +- .../query_string_input.test.tsx.snap | 24 +- .../query_string_input/query_bar_top_row.tsx | 3 +- .../query_string_input/query_string_input.tsx | 2 +- .../__snapshots__/field_icon.test.tsx.snap | 6 +- .../public/field_icon/field_icon.tsx | 4 +- .../saved_object_save_modal.test.tsx.snap | 2 - .../page_objects/visualize_chart_page.ts | 3 +- .../page_objects/visualize_editor_page.ts | 5 +- .../plugins/kbn_tp_run_pipeline/package.json | 2 +- .../kbn_tp_custom_visualizations/package.json | 2 +- .../kbn_tp_embeddable_explorer/package.json | 2 +- .../kbn_tp_sample_panel_action/package.json | 2 +- .../waterfall_helpers.test.ts.snap | 6 +- .../__snapshots__/ManagedTable.test.js.snap | 2 + .../shared/SelectWithPlaceholder/index.tsx | 2 +- .../__snapshots__/CustomPlot.test.js.snap | 840 +++++++++--------- .../__snapshots__/Histogram.test.js.snap | 112 +-- .../__tests__/chartSelectors.test.ts | 8 +- .../lib/transactions/breakdown/index.test.ts | 4 +- .../public/components/inputs/input.tsx | 7 +- .../components/field_manager/field_icon.tsx | 4 +- .../graph/public/helpers/style_choices.ts | 4 +- .../services/persistence/deserialize.test.ts | 2 +- .../indexpattern_plugin/field_icon.test.tsx | 50 +- .../public/indexpattern_plugin/field_icon.tsx | 4 +- .../lens_field_icon.test.tsx | 4 +- .../indexpattern_plugin/lens_field_icon.tsx | 4 +- .../operations/definitions/terms.test.tsx | 4 +- .../__snapshots__/xy_expression.test.tsx.snap | 154 ++-- .../pipeline_editor.test.js.snap | 68 -- .../pipelines_table.test.js.snap | 1 + .../geometry_filter_form.test.js.snap | 14 - .../__snapshots__/tooltip_header.test.js.snap | 2 - .../update_source_editor.test.js.snap | 9 - .../maps/public/layers/styles/color_utils.js | 4 +- .../annotations_table.test.js.snap | 1 + .../__snapshots__/filter_bar.test.js.snap | 2 + .../condition_expression.test.js.snap | 16 - .../scope_expression.test.js.snap | 24 - .../__snapshots__/editor.test.tsx.snap | 40 - .../__snapshots__/list.test.tsx.snap | 24 - .../__snapshots__/calendar_form.test.js.snap | 6 - .../__snapshots__/events_table.test.js.snap | 2 + .../table/__snapshots__/table.test.js.snap | 1 + .../edit_description_popover.test.js.snap | 9 - .../edit/__snapshots__/header.test.js.snap | 6 - .../list/__snapshots__/table.test.js.snap | 2 + .../__snapshots__/latest_active.test.js.snap | 1 + .../__snapshots__/latest_types.test.js.snap | 1 + .../latest_versions.test.js.snap | 1 + .../ccr/__snapshots__/ccr.test.js.snap | 1 + .../__snapshots__/ccr_shard.test.js.snap | 1 + .../logs/__snapshots__/logs.test.js.snap | 1 + .../flyout/__snapshots__/flyout.test.js.snap | 10 - .../report_listing.test.tsx.snap | 3 + .../basic_login_form.test.tsx.snap | 6 - .../__snapshots__/feature_table.test.tsx.snap | 1 + .../__snapshots__/index.test.tsx.snap | 1 + .../__snapshots__/jobs_table.test.tsx.snap | 1 + .../note_card_body.test.tsx.snap | 48 +- .../__snapshots__/index.test.tsx.snap | 48 +- .../confirm_delete_modal.test.tsx.snap | 3 - .../customize_space_avatar.test.tsx.snap | 5 +- .../space_identifier.test.tsx.snap | 2 - .../spaces_grid_pages.test.tsx.snap | 11 +- .../__snapshots__/space_avatar.test.tsx.snap | 8 +- .../__snapshots__/popover_form.test.tsx.snap | 3 - .../__snapshots__/popover_form.test.tsx.snap | 7 - .../checkup/deprecations/index_table.test.tsx | 125 +-- .../filter_popover.test.tsx.snap | 2 + .../__snapshots__/monitor_list.test.tsx.snap | 2 + .../monitor_list_pagination.test.tsx.snap | 2 + .../__snapshots__/ping_list.test.tsx.snap | 9 +- x-pack/package.json | 2 +- .../nav_control/nav_control_service.test.ts | 2 +- yarn.lock | 29 +- 122 files changed, 974 insertions(+), 1233 deletions(-) diff --git a/package.json b/package.json index c8ad736ea976f..7a8596da9d377 100644 --- a/package.json +++ b/package.json @@ -118,7 +118,7 @@ "@elastic/charts": "^16.1.0", "@elastic/datemath": "5.0.2", "@elastic/ems-client": "1.0.5", - "@elastic/eui": "17.3.1", + "@elastic/eui": "18.0.0", "@elastic/filesaver": "1.1.2", "@elastic/good": "8.1.1-kibana2", "@elastic/numeral": "2.3.3", diff --git a/packages/kbn-ui-shared-deps/package.json b/packages/kbn-ui-shared-deps/package.json index 014467d204d96..2e62eb3504aca 100644 --- a/packages/kbn-ui-shared-deps/package.json +++ b/packages/kbn-ui-shared-deps/package.json @@ -9,7 +9,7 @@ "kbn:watch": "node scripts/build --watch" }, "devDependencies": { - "@elastic/eui": "17.3.1", + "@elastic/eui": "18.0.0", "@elastic/charts": "^16.1.0", "@kbn/dev-utils": "1.0.0", "@yarnpkg/lockfile": "^1.1.0", diff --git a/src/dev/license_checker/config.ts b/src/dev/license_checker/config.ts index a4aa3474c0762..bd084767a723f 100644 --- a/src/dev/license_checker/config.ts +++ b/src/dev/license_checker/config.ts @@ -23,6 +23,7 @@ export const LICENSE_WHITELIST = [ 'Elastic-License', '(BSD-2-Clause OR MIT OR Apache-2.0)', '(BSD-2-Clause OR MIT)', + '(BSD-3-Clause AND Apache-2.0)', '(GPL-2.0 OR MIT)', '(MIT AND CC-BY-3.0)', '(MIT AND Zlib)', diff --git a/src/legacy/core_plugins/data/public/search/fetch/components/__snapshots__/shard_failure_table.test.tsx.snap b/src/legacy/core_plugins/data/public/search/fetch/components/__snapshots__/shard_failure_table.test.tsx.snap index 55e2c63f608d4..257513f20fa94 100644 --- a/src/legacy/core_plugins/data/public/search/fetch/components/__snapshots__/shard_failure_table.test.tsx.snap +++ b/src/legacy/core_plugins/data/public/search/fetch/components/__snapshots__/shard_failure_table.test.tsx.snap @@ -72,5 +72,6 @@ exports[`ShardFailureTable renders matching snapshot given valid properties 1`] }, } } + tableLayout="fixed" /> `; diff --git a/src/legacy/core_plugins/input_control_vis/public/components/editor/__snapshots__/controls_tab.test.tsx.snap b/src/legacy/core_plugins/input_control_vis/public/components/editor/__snapshots__/controls_tab.test.tsx.snap index 632fe63e9e148..278811ca85df9 100644 --- a/src/legacy/core_plugins/input_control_vis/public/components/editor/__snapshots__/controls_tab.test.tsx.snap +++ b/src/legacy/core_plugins/input_control_vis/public/components/editor/__snapshots__/controls_tab.test.tsx.snap @@ -135,11 +135,7 @@ exports[`renders ControlsTab 1`] = ` > ) => void; handleParentChange: (controlIndex: number, event: ChangeEvent) => void; - parentCandidates: EuiSelectProps['options']; + parentCandidates: React.ComponentProps['options']; deps: InputControlVisDependencies; } diff --git a/src/legacy/core_plugins/input_control_vis/public/components/vis/__snapshots__/list_control.test.tsx.snap b/src/legacy/core_plugins/input_control_vis/public/components/vis/__snapshots__/list_control.test.tsx.snap index 31c221b36e2b2..99482a4be2d7b 100644 --- a/src/legacy/core_plugins/input_control_vis/public/components/vis/__snapshots__/list_control.test.tsx.snap +++ b/src/legacy/core_plugins/input_control_vis/public/components/vis/__snapshots__/list_control.test.tsx.snap @@ -8,10 +8,7 @@ exports[`disableMsg 1`] = ` label="list control" > diff --git a/src/legacy/core_plugins/kbn_vislib_vis_types/public/area.js b/src/legacy/core_plugins/kbn_vislib_vis_types/public/area.js index 049544b504918..fd13067c84cc0 100644 --- a/src/legacy/core_plugins/kbn_vislib_vis_types/public/area.js +++ b/src/legacy/core_plugins/kbn_vislib_vis_types/public/area.js @@ -33,7 +33,7 @@ import { getConfigCollections, } from './utils/collections'; import { getAreaOptionTabs, countLabel } from './utils/common_config'; -import { palettes } from '@elastic/eui/lib/services'; +import { euiPaletteColorBlind } from '@elastic/eui/lib/services'; import { vislibVisController } from './controller'; export const areaDefinition = { @@ -117,7 +117,7 @@ export const areaDefinition = { value: 10, width: 1, style: ThresholdLineStyles.FULL, - color: palettes.euiPaletteColorBlind.colors[9], + color: euiPaletteColorBlind()[9], }, labels: {}, }, diff --git a/src/legacy/core_plugins/kbn_vislib_vis_types/public/histogram.js b/src/legacy/core_plugins/kbn_vislib_vis_types/public/histogram.js index fdc18f5bfa0e6..bc017b5a1a871 100644 --- a/src/legacy/core_plugins/kbn_vislib_vis_types/public/histogram.js +++ b/src/legacy/core_plugins/kbn_vislib_vis_types/public/histogram.js @@ -32,7 +32,7 @@ import { getConfigCollections, } from './utils/collections'; import { getAreaOptionTabs, countLabel } from './utils/common_config'; -import { palettes } from '@elastic/eui/lib/services'; +import { euiPaletteColorBlind } from '@elastic/eui/lib/services'; import { vislibVisController } from './controller'; export const histogramDefinition = { @@ -120,7 +120,7 @@ export const histogramDefinition = { value: 10, width: 1, style: ThresholdLineStyles.FULL, - color: palettes.euiPaletteColorBlind.colors[9], + color: euiPaletteColorBlind()[9], }, }, }, diff --git a/src/legacy/core_plugins/kbn_vislib_vis_types/public/horizontal_bar.js b/src/legacy/core_plugins/kbn_vislib_vis_types/public/horizontal_bar.js index 15bbf9c01cd77..ee3570314618a 100644 --- a/src/legacy/core_plugins/kbn_vislib_vis_types/public/horizontal_bar.js +++ b/src/legacy/core_plugins/kbn_vislib_vis_types/public/horizontal_bar.js @@ -32,7 +32,7 @@ import { getConfigCollections, } from './utils/collections'; import { getAreaOptionTabs, countLabel } from './utils/common_config'; -import { palettes } from '@elastic/eui/lib/services'; +import { euiPaletteColorBlind } from '@elastic/eui/lib/services'; import { vislibVisController } from './controller'; export const horizontalBarDefinition = { @@ -119,7 +119,7 @@ export const horizontalBarDefinition = { value: 10, width: 1, style: ThresholdLineStyles.FULL, - color: palettes.euiPaletteColorBlind.colors[9], + color: euiPaletteColorBlind()[9], }, }, }, diff --git a/src/legacy/core_plugins/kbn_vislib_vis_types/public/line.js b/src/legacy/core_plugins/kbn_vislib_vis_types/public/line.js index a3fb874b5aa1b..d6d075f452fed 100644 --- a/src/legacy/core_plugins/kbn_vislib_vis_types/public/line.js +++ b/src/legacy/core_plugins/kbn_vislib_vis_types/public/line.js @@ -32,7 +32,7 @@ import { InterpolationModes, getConfigCollections, } from './utils/collections'; -import { palettes } from '@elastic/eui/lib/services'; +import { euiPaletteColorBlind } from '@elastic/eui/lib/services'; import { getAreaOptionTabs, countLabel } from './utils/common_config'; import { vislibVisController } from './controller'; @@ -118,7 +118,7 @@ export const lineDefinition = { value: 10, width: 1, style: ThresholdLineStyles.FULL, - color: palettes.euiPaletteColorBlind.colors[9], + color: euiPaletteColorBlind()[9], }, }, }, diff --git a/src/legacy/core_plugins/kibana/public/dashboard/np_ready/top_nav/__snapshots__/clone_modal.test.js.snap b/src/legacy/core_plugins/kibana/public/dashboard/np_ready/top_nav/__snapshots__/clone_modal.test.js.snap index 6def1b1a198b8..e76f65c45e428 100644 --- a/src/legacy/core_plugins/kibana/public/dashboard/np_ready/top_nav/__snapshots__/clone_modal.test.js.snap +++ b/src/legacy/core_plugins/kibana/public/dashboard/np_ready/top_nav/__snapshots__/clone_modal.test.js.snap @@ -30,11 +30,8 @@ exports[`renders DashboardCloneModal 1`] = ` diff --git a/src/legacy/core_plugins/kibana/public/management/sections/index_patterns/create_index_pattern_wizard/components/step_index_pattern/components/header/__jest__/__snapshots__/header.test.js.snap b/src/legacy/core_plugins/kibana/public/management/sections/index_patterns/create_index_pattern_wizard/components/step_index_pattern/components/header/__jest__/__snapshots__/header.test.js.snap index 11c41425a0bb5..f2fb17cdb0d60 100644 --- a/src/legacy/core_plugins/kibana/public/management/sections/index_patterns/create_index_pattern_wizard/components/step_index_pattern/components/header/__jest__/__snapshots__/header.test.js.snap +++ b/src/legacy/core_plugins/kibana/public/management/sections/index_patterns/create_index_pattern_wizard/components/step_index_pattern/components/header/__jest__/__snapshots__/header.test.js.snap @@ -78,11 +78,8 @@ exports[`Header should mark the input as invalid 1`] = ` labelType="label" > `; diff --git a/src/legacy/core_plugins/kibana/public/management/sections/index_patterns/edit_index_pattern/scripted_fields_table/components/table/__jest__/__snapshots__/table.test.js.snap b/src/legacy/core_plugins/kibana/public/management/sections/index_patterns/edit_index_pattern/scripted_fields_table/components/table/__jest__/__snapshots__/table.test.js.snap index 4716fb8f77633..2da4d84463b29 100644 --- a/src/legacy/core_plugins/kibana/public/management/sections/index_patterns/edit_index_pattern/scripted_fields_table/components/table/__jest__/__snapshots__/table.test.js.snap +++ b/src/legacy/core_plugins/kibana/public/management/sections/index_patterns/edit_index_pattern/scripted_fields_table/components/table/__jest__/__snapshots__/table.test.js.snap @@ -76,6 +76,7 @@ exports[`Table should render normally 1`] = ` } responsive={true} sorting={true} + tableLayout="fixed" /> `; diff --git a/src/legacy/core_plugins/kibana/public/management/sections/index_patterns/edit_index_pattern/source_filters_table/components/add_filter/__jest__/__snapshots__/add_filter.test.js.snap b/src/legacy/core_plugins/kibana/public/management/sections/index_patterns/edit_index_pattern/source_filters_table/components/add_filter/__jest__/__snapshots__/add_filter.test.js.snap index 432c57d4f473d..879ea555d3300 100644 --- a/src/legacy/core_plugins/kibana/public/management/sections/index_patterns/edit_index_pattern/source_filters_table/components/add_filter/__jest__/__snapshots__/add_filter.test.js.snap +++ b/src/legacy/core_plugins/kibana/public/management/sections/index_patterns/edit_index_pattern/source_filters_table/components/add_filter/__jest__/__snapshots__/add_filter.test.js.snap @@ -6,9 +6,7 @@ exports[`AddFilter should ignore strings with just spaces 1`] = ` grow={10} > `; diff --git a/src/legacy/core_plugins/kibana/public/management/sections/objects/components/objects_table/__jest__/__snapshots__/objects_table.test.js.snap b/src/legacy/core_plugins/kibana/public/management/sections/objects/components/objects_table/__jest__/__snapshots__/objects_table.test.js.snap index 2aaa291f6122b..4ba0fe480ac42 100644 --- a/src/legacy/core_plugins/kibana/public/management/sections/objects/components/objects_table/__jest__/__snapshots__/objects_table.test.js.snap +++ b/src/legacy/core_plugins/kibana/public/management/sections/objects/components/objects_table/__jest__/__snapshots__/objects_table.test.js.snap @@ -71,6 +71,7 @@ exports[`ObjectsTable delete should show a confirm modal 1`] = ` pagination={true} responsive={true} sorting={false} + tableLayout="fixed" /> `; diff --git a/src/legacy/core_plugins/kibana/public/management/sections/objects/components/objects_table/components/flyout/__jest__/__snapshots__/flyout.test.js.snap b/src/legacy/core_plugins/kibana/public/management/sections/objects/components/objects_table/components/flyout/__jest__/__snapshots__/flyout.test.js.snap index ace06e0420a7c..34ce8394232ed 100644 --- a/src/legacy/core_plugins/kibana/public/management/sections/objects/components/objects_table/components/flyout/__jest__/__snapshots__/flyout.test.js.snap +++ b/src/legacy/core_plugins/kibana/public/management/sections/objects/components/objects_table/components/flyout/__jest__/__snapshots__/flyout.test.js.snap @@ -115,6 +115,7 @@ exports[`Flyout conflicts should allow conflict resolution 1`] = ` } } responsive={true} + tableLayout="fixed" /> @@ -445,6 +446,7 @@ exports[`Flyout legacy conflicts should allow conflict resolution 1`] = ` } } responsive={true} + tableLayout="fixed" /> diff --git a/src/legacy/core_plugins/kibana/public/management/sections/objects/components/objects_table/components/relationships/__jest__/__snapshots__/relationships.test.js.snap b/src/legacy/core_plugins/kibana/public/management/sections/objects/components/objects_table/components/relationships/__jest__/__snapshots__/relationships.test.js.snap index 941a0ffded820..c1241d5d7c1e5 100644 --- a/src/legacy/core_plugins/kibana/public/management/sections/objects/components/objects_table/components/relationships/__jest__/__snapshots__/relationships.test.js.snap +++ b/src/legacy/core_plugins/kibana/public/management/sections/objects/components/objects_table/components/relationships/__jest__/__snapshots__/relationships.test.js.snap @@ -154,6 +154,7 @@ exports[`Relationships should render dashboards normally 1`] = ` ], } } + tableLayout="fixed" />
@@ -368,6 +369,7 @@ exports[`Relationships should render index patterns normally 1`] = ` ], } } + tableLayout="fixed" />
@@ -533,6 +535,7 @@ exports[`Relationships should render searches normally 1`] = ` ], } } + tableLayout="fixed" />
@@ -693,6 +696,7 @@ exports[`Relationships should render visualizations normally 1`] = ` ], } } + tableLayout="fixed" />
diff --git a/src/legacy/core_plugins/kibana/public/management/sections/objects/components/objects_table/components/table/__jest__/__snapshots__/table.test.js.snap b/src/legacy/core_plugins/kibana/public/management/sections/objects/components/objects_table/components/table/__jest__/__snapshots__/table.test.js.snap index daac04d07da28..805131042f385 100644 --- a/src/legacy/core_plugins/kibana/public/management/sections/objects/components/objects_table/components/table/__jest__/__snapshots__/table.test.js.snap +++ b/src/legacy/core_plugins/kibana/public/management/sections/objects/components/objects_table/components/table/__jest__/__snapshots__/table.test.js.snap @@ -203,6 +203,7 @@ exports[`Table prevents saved objects from being deleted 1`] = ` "onSelectionChange": [Function], } } + tableLayout="fixed" />
@@ -410,6 +411,7 @@ exports[`Table should render normally 1`] = ` "onSelectionChange": [Function], } } + tableLayout="fixed" />
diff --git a/src/legacy/core_plugins/kibana/public/management/sections/settings/components/field/__snapshots__/field.test.js.snap b/src/legacy/core_plugins/kibana/public/management/sections/settings/components/field/__snapshots__/field.test.js.snap index ae168e76d359b..f4d20b4565880 100644 --- a/src/legacy/core_plugins/kibana/public/management/sections/settings/components/field/__snapshots__/field.test.js.snap +++ b/src/legacy/core_plugins/kibana/public/management/sections/settings/components/field/__snapshots__/field.test.js.snap @@ -50,10 +50,8 @@ exports[`Field for array setting should render as read only if saving is disable >
+
+ +
@@ -565,6 +585,26 @@ exports[`NewVisModal filter for visualization types should render as expected 1` />
+
+ +
@@ -835,6 +875,26 @@ exports[`NewVisModal filter for visualization types should render as expected 1` />
+
+ +
@@ -1139,12 +1199,18 @@ exports[`NewVisModal filter for visualization types should render as expected 1` data-test-subj="filterVisType" fullWidth={true} incremental={false} + isClearable={true} isLoading={false} onChange={[Function]} placeholder="Filter" value="with" > @@ -1209,6 +1280,50 @@ exports[`NewVisModal filter for visualization types should render as expected 1`
+
+ + + + + +
@@ -2775,12 +2890,14 @@ exports[`NewVisModal should render as expected 1`] = ` data-test-subj="filterVisType" fullWidth={true} incremental={false} + isClearable={true} isLoading={false} onChange={[Function]} placeholder="Filter" value="" > diff --git a/src/legacy/core_plugins/status_page/public/components/__snapshots__/status_table.test.js.snap b/src/legacy/core_plugins/status_page/public/components/__snapshots__/status_table.test.js.snap index cc9cdd6af1f39..3379d6cd649c4 100644 --- a/src/legacy/core_plugins/status_page/public/components/__snapshots__/status_table.test.js.snap +++ b/src/legacy/core_plugins/status_page/public/components/__snapshots__/status_table.test.js.snap @@ -37,5 +37,6 @@ exports[`render 1`] = ` noItemsMessage="No items found" responsive={true} rowProps={[Function]} + tableLayout="fixed" /> `; diff --git a/src/legacy/core_plugins/vis_type_timeseries/public/components/splits/__snapshots__/terms.test.js.snap b/src/legacy/core_plugins/vis_type_timeseries/public/components/splits/__snapshots__/terms.test.js.snap index ffd4d08204a7e..654e7d9da4dca 100644 --- a/src/legacy/core_plugins/vis_type_timeseries/public/components/splits/__snapshots__/terms.test.js.snap +++ b/src/legacy/core_plugins/vis_type_timeseries/public/components/splits/__snapshots__/terms.test.js.snap @@ -87,9 +87,6 @@ exports[`src/legacy/core_plugins/metrics/public/components/splits/terms.test.js labelType="label" > @@ -112,9 +109,6 @@ exports[`src/legacy/core_plugins/metrics/public/components/splits/terms.test.js labelType="label" > diff --git a/src/legacy/core_plugins/vis_type_vega/public/__tests__/vega_image_512.png b/src/legacy/core_plugins/vis_type_vega/public/__tests__/vega_image_512.png index 44cd0d320931facaa78b5095e7cf01c91c45a6ce..cc28886794f0359da3097fa2320dcc35b3257ff8 100644 GIT binary patch literal 30730 zcmeFY^;eYd7dHCLFu)8b3?Lv%3?QMTbTc&4-6Q9xrh7$y!rB;bgd!cS;g4AD(RV(HvQcukS((^;)wM8osVknz`Xd2-VRtu;!^d{7 zKleia&H2DlTv0u*&#v4&F_{Ha1%u#*Fe62vw_9SGEts*eOyK&jfG;o~`|l_4FK9So zA3%1Mcz*fsYb*@>)$#xS`hQ3R6@?D^*kMa1JIIsrYmboNi)ALp5fql&O%8lps0vC2 z#%J}V7)U+=_--Mqm*`O{Ge>rnV!&~|YehDA57F=uers2Bp<_bQCmD<^&ExyxB=ZnV zHR1KWps8S+-^UuG_Lpd7_K_NRhEKh70Aj#}Z1ou22rM0o>oZ3~)ey8@59}w*#^@xe z8K$a;kr=>DGF`#@o1Yr1bpz*lpjsgDvW!u-o{nZtz`Jox6qd$``4gE9PW8$~l5!AS zNEp_Dx0R1}bD4X{?YQaQm@BsZ6*i5+;$ZIT2s4A~5z69LR{NJ4e>;-k{w*m#h1U{W z#nMib&k??I7<`~w(UTTj2r7qm{G5q4&^OTR6VuLbEZ{bN_ZT{hoQGiV4&+84xI+Pw zQo-ywqIof8U|70O8q>kQxv4-24|Ws`dXU> z&O{v=dzXhr0Zzx&!u{#2-}<~>?yMGv%qwK8%>4Q0d6Y`>%rpywgo*+1&d*ZU za>9Xp`z%3--s60u7h!Q&n3{c`1@DXpLUKKmRI=5znfpRBW}E)rW^t%y`=H^`Zd+oT zu}>j2nI#O6359_|2$TZ9!omnp8u&OET}L>VKXuweZpVI0f9z<@Vij&}^_WQ16ZY z_awg}q1wSyBcpVLalNlH(Zk@mSnp7YUY|<7>upK4#2HqF}$T>Dz0WBM$`?9VaDR1hd)n*g1hA=X<~or_a^?hbv=8> zz==Bl25a_%Ubg4pKDvh<8-qKQRw$VLY$k>7xMe0JOvkTXfAv6&6W>qJ=xyHFJWK^f9=dRH}b!5jpZn zBQK(}W5}FK)vA8Vi{EPtZTq*>&3{V~!({1z5i)DovGMDwn5oB^qF-P!pwB>))J&v; z8{S8{EdT|1^NpD;BI05?&01M-&{VVq4G2M@d`BXK0S&G+n$Pb?r#%lM@Qd%~MucC> z{*^sHWgmEwhcFW%ptScd3HIp1C{fZhPT-vll;L`cFos?*V4*Z%n{g|>49jEwTDKN5 z`gP7Z)jixvncZ%KI&kdqFVIoTp?T}_Aq8h*kY{dfSvnnCk2ux3z_b1@m<@@B`hPr? zfcXAa&jNOxzmF0&(Wzh^p@H~V$Hm-4&_Qn?p2)AN1M6R;#NqqWudCXX{aM+$-LA!D zqTGzS78g?i)fgU-sppaly>Qmne~tUIj*1L)XFs56tM|D-O!v=s7-hh^IbH+)xNQaj>fVIdU1{vrgy4S+Kcu@q409g$!ka+RUF@_LFy zroZOq#)1wGJN_?6m{)}!^n7$>iE1}Mpa|qyIF$058%djm?S!t=g@Ja@QE-{RXmFW! z3_w1ak^fov&3*ne^Xc3FKmVST2fET=0?b@#xCTS+RB8-Yg{;c}l^S@~@cKOyeo$oM z$f3CYIbdHV4I=}{r&N_ZNY3$me(fR_wng>7f$E{22z(#Ylg-pX2+8iFwUsV>nLIoP z+(64j4A;|oA{Sh9 zv^Jf|$*|E`m_fvojqTSMFC&|;1^(LVnQ5cg$&b<~HykXJJsXMUyn^ihWewl28WA6y z?}Ow~9IG_l(i1_P&Fo-!n888Id?nDT;_W=JRl0C#ww%aE+>%CV;9$}R0&$V9_lx$i zQ>YS}t`8Jj^|XY6l_n@M))Z_;eE+hTg=3Z_tZB(rMLakegQgBc{8dJAxu#KoZJi(WAzqabL< z8UdWnq9O0<{je+h%}u|EoO&iQI3=W#J_lNeOR6(tySXWZ@Tv(%BKI$V0;)+#$PkOn zQ2B2qS(ThG$GR)Hmafc56{xrUmY!^r$@5JI2EOH0;phvVCzdxmndi44pd${B#8eSK zjfLq&{?+BpIxfaWQO6))VW5})2Dqi)=w_YIZBop?sJLNdAX9@lehLhISC)i5x#F1E zAu)dm_1a|+|5bDRnK~J9oPln$Y*PYWgNXzEasOiKsRC6)&2tN~{T1Na_l+!z9C0yX zj_^K+yXYuvIq3|vF;dOV%X=k!ft}0GFB+#O#xHxMiQ&w{tzo{ZDYRD+b3%1yS0vzg z4OfFX79d#v-KVX1B<&NW-(^-zi&pP3BtxrqI#Cw#*>y-4fs{>Z`@c0wSknC&pn#)B zO$s-i6zy&CVNuRf)}A+QUM|$EW|dlttW>a~niTu(cT`bGrvIYM?{!NiDW>@j2`Vo)Kz?9kF13;|(l_5p zladkoYNxg1*V{=pxrk*U6|5_akMWEfc*&9M0*2aBS$_j1G~(D6Xj(3bRFGqBNrlf+ z44LVavd{WANY4vb-n&jpLBm5u=L%X+@Xh3AJV{m}i$zdF=57FBP!2$Qna+!#WTXg! zM{@68mEX`Zz#-dzff118rDkZF`kEWDEd8neZptsFh>5zJWUOfzE<8-^s-Sw5d@c)M z@whCa&fFZfPgg>_CZ`aX9G-v|E9BO3^WA>{|V;=M|3tSsK46| z`%$??>PP&-oq!pI3*m6SfFi5XrTZ-zkn_9prWd(REe7f}a79UA|9uECm(ai5X>Q$8 zUacGUK&fE1=28iut16A6eZhz&i*NCd`QP{AfJw09pYSTR;KRKIrg2hlyxib3-8ahh z9B(5VJ>McphvHNSfw4Y45y-a7_tE6KjmP4h45$MDJ9o+EQF}2lGU}>-kC(*;N=usQ zvlJ8h;k79ZZ3#PPnkplh2OloxPGlo)siA*D<`?f?J`~V0z2K`p=W5MjU`JR;vJPyh zdfIicGSGq{vW^tgIkj;3)2sO8-%CKdYb|YtUViG3fsQ7uhz4kANQ1#%mpV)sz#$Ax zmG_Iy=hx=ziz z2a|>!n|3oQ1(HyspQm)_W2um*V* zIzp^BU|UGV0+-GX+gGH?!O4yzUlKbm-g^34afY_7XW|RRq4;K*dQ*c`GCtu`JfTGO#%Zr83E6Q-HS$msFXVWsT(Wufvw9fIAg)(9X4IMAK^r-*~*e%LW}S zPE-IsMn{|^262M$$o`^JsSWQsv^i!K>AZL+>P zM4w?|V47Ud3)nYC-d9$W0~~X_yyd?@CXx|OcSuo*rPgJ_~KUb%c z^MvLhMyS5g$+^+)gjC=LbYxH2l9tUFt1m0^AVa{415C2qsku*M8~Ob zfO^_;2N}GO;lLfHeRu7X@kL>V_h}@$8~;BiB%3=5=bn(9=&BrntTc3=R`hnMhL#_( zfl%w56bSO1<`=&0+VWs_TYt8~*bGWe2Oc)yK5$`VCR?%n1PXHtNU6G{OtFLp-vdK| zG90x)xuaObUqY%HJp5JULZ;w14qC*M3zfG=XI;^d10;KTXgeIHs60a)$Ae-v1}q9) zy%^2xn3v{`;>{>F??TCG0M2Hc?tA^-l~S0{cKROaITU)xqD1GVJ2ymoGiF)kg+M~IHuTk-<5{9&N4xWf2+iO}D$Im1t+s6U( zfHQGa%K)(v@wl%=pz+^4Lav63lAMD+)q=V1&(#ohUS%n2%{R5&!j_Duz-R zr}OceY~^u&OHO*`@~sNR(?QVm9LzU zi*8G94g*5&H}})7&|?|FsPmkzvEJ4X;VS_=v1dcTpSLO+7)HaW(PG0YJ^5V2`7@cA zau}!w5|Did{gfth>Q|#GZ?$I#2HihC!v29^^sn%bq!~Y5IV<&a&`uLH^GK4Fy4LKn zge9Id;%V!PUj^*w>s5T+<>ND#=4RpNxnAnT)z(n& zo0ICO;e2HxRK#nZ!4W%-Bx!K0Cp~rs#QefkjkU}nr29_5P~5f$uo%yN?)Nga@U$7{!%wy5wHCq; zO76CF%%~Tjp4o(2q<_vNk8121870<1alN_03Q@DGoR| zkD+PI*O;xmY>BP%b?bT4myxB$m2L}H=KU*J>m6W~ROmbr6{tU}%=lZEWw7Hk?%4v{ zOSbd~?8oFm(ANlG9stC=iNNvw9y$qVxSO}O)=Rqf zzUIe<@F#?o+Sup4*2CHfME^rW?P9|dy-ei;>%l5W7Z$Gb!Y+XA3>OiVK`#n5)lC?An0pDhAo}3^vI) zw6ZS$OOGk?=&({Hni$ZC&k&yZD%T-+@M&!(b};#)EOrHg1*wHVK^1iK*en7y zbj7zBO~=CsLgCO@N-;kE!cPMJX@eJHP17Swb}jjlyy2mkDIBa8bUv25w zH*|kB_tPP?ALP(dRSO0_2O~o-HJ_sVpiX?=-q~Uv2GRM5CIJApaI7jRsAsejHJ
(OVW zE5!hMTR}#w{xhAFFw+zYCdnp#MSgdVH2V2PAgPTqYM@%hFjv*t9Z1dQI(GSGmYf8I(KgXkicDv)aPGy@JWK++)q1BR>?L{ zc7u;_8F<{e-}kz+Y&~8nYCR-JE4muLlC!Ee09theOyb($fa_5^^}sqWG(a&rxWIll zYi67#dArvA08id~nZq)Ls84JyhD0l+~Zp$Z4i;}f{5!w@JeW8;Sk-s%s# zB5y2M1gxPKNYGiEF@(LxCB8LTk{5+n%~|!?5$bXSs0OgV%qY7~&ebsg$fA=rf-x>) zNM)x7=2OU*6r;b8?@aY(;0Y;X3gN- z3&}(q!Z_RfCRJGS&2{yVSubgXMq8DFOl+eoRD+?9@iBO_m-?6KUn`IyuAA->n>wo$ zC$h#tEhj1A1Nngr@1JDFK=TdxGRD8%x|u+efC5*$4l<~)*vy9@{sTy+CsVb!I7jm@ zGSPxyo)wIP3BF@+2i}sUa~En%N4biCyaMBI(hN*iTTFA{QJ9KFa#?u>ZZo>-n<=OE=T8h)P?bAsBxwx$sSn$Kjx5=$U1+!djvDn3T~3UTcnu;X8FTjbIGK+?M^ym0fT zk{394=^^1Jan5tBD%9dv$ zdJ+d)Oqh|kF>$DMbkD<@c}NrjH7EzB6$LKFKsv!rZ-LpZGoB5PDCVhmcqo+Qy!C!@ zFyoCzkN90AYXAVk)Asl%NiPLj1sjlyM?2woTq@o6D`0$oQGH|*w9p9^pJYeFI3L#S z>06wlkv zARDB-#lVpD@y2JG)<7FoHE@8Ry)xG!*y}f7IGQ|oO>df<;5U5cs%n)rt z6+d4$wf4#UsUV|5^}YXy<-qqZ?udPjZ<~=)v5!g9Sr~qoo#Nv#erTxj7gWG63^u)K~?QPUuO3 zbAIta=*T9BV1tZ{p6G!;0uKhAf3AqRnr3`HYbqI18o#k+2>ALK0J1O7kEg0d>=X<( zS46r=SzQ6{3Ub(faP14BJ7h^=SY_Z?4BCobZ$)a(N0<*jsz{Tjid|0wxn>avJ>OhR zbZ$zHR(<}mau_02x?uS~)`3;aw5=nxX!|29@DZ?pByB~{$Uv|^Gz*zJ)R@fnZ8#ve zf;Qrn6Wt3BTY&U2$482NZ|-QlxTs?xYa}kA>yc%uH;M%7oq_&ObWFz zly%qpJywyn^(uWJ7?wm^kqh19O$qbNS?!_p&(Gq;3q^mqzPp)#D{~qc+ysXVsc1n4 zSd;wf42}6S|IL#$Fhd13-7anaN-QNj*mg78)jvG*2P_U81~Pu)a=_lr+r*ra2sk4e zHr3LR%+U2rS67C%btfjpvn$NA;5~Ba#+CqZTMfp3X7kdiw`nPd-SE_e@OX1I^bdI#nerP!!!90nv66Nxzq1qN_T*+ z1pGNaugtFkO$aHE;&Fdm@H-B2DZzH{E$gckMX=;J;n~LTl&Wq^#b+F#`3= zlg00>uWy+J`-X~OdzeX3TujNma6y#(MZs5M}TbdZnr&|z(> zvXN%yWG3RTDgfbuanFs6o@MF&f^FX6$)I1@=?*xZ!y#WO>S?a;a)%aPO)=@>f`g4@ zFFDSAdE#^I9TNVNA1_SXz=DAKxm-^J>_N@ z(Q0?2U(HxY!*`vO$|xys#NEuo=D=d^0GpKT!tu9OG)sEHvMxT%7tRX*-M!H-${00B zX-%!d_;qAdmRou0?esm3X&`C9L?%kG>3)1= zrZ(@!xtRUoVl~=UO`ts@RZwA~!W5=3cLRdbrnT?#zt^fQxgBVy(Lw8<>z#vMbcyB*g z`z^f<`7ttj8e@~eS8Ho92*rM2N?VI($5-R8)}lLNrm{m2gfid(TS_Q{+o@g6M9lN* zP~Y~l-m7`_o!!#0I44S=dpdeIqcqU;xLBKKgFO)7=IOw}4t}|p*9g|`NU*&`+dtjM z#K%o1$lHI;8P%o_3;;!={b8$F{*NJ^7SL`a>tmqi9f1AxIINxntl4lPQO8wTTGc-E zb$ilgKa(!PW&YaDAt_oEc0{aBwqgkYr)c8u|4Oc%{CCkSWdiif+$Qg{~fX zWv&Zk!NvQU(HVud>q>5)SSI?_^;#g^L6m?x%31km~%gE zZ|t-w!c2KD0Q5qMI9T&mitZEeAgrN4CzGvG+iRG*dCL>|r<6eaezC8Q?40Z71G@2D zqA9fej^}k0cR_!0gc=G{c7x3vD88Id6TS{VX}(3Ln`VSxOW_Mtyk+h0CMU_fKW`8Ix`J81R)!%BouQf9`Y_t(bDoz~x& zu2wL9&5^gO19KeWd;vTVW(@=sR`aSnR_$VkKYIK@@?30gwxtb#K48eG_F&zY@~rAJ zpAH;t=!@QQ1Pr8s=)Olw{h*4cDq(>3@uG4`)=~4PlHY2cLVym)e!BdE4OkdSF}CTz zFb$7yfwi&-KgdB$mrLwG0&=A z8mKrC0Jfyy0l(5;>~gP_s$lOzW$}?a+IJ5;&3-e#5;WY5@ArZ4`@7biuoHI4fVNpM zs8c^pK(g)(c9vlzjObN!(?Qd)gt@&c>s=!tWRWTm`PhOFkzfnGMa5LX<9*=FLtv%) zn`GS&P&5vJSVjeU7?OZ)MUJdyqwN}`%AGyh1WWA>Kqh@ztJ2p^Zf|dmVmY_q5Tx%{ zu!`273m1^sAwH>i0lMB`1ghkl_4(W2oj?n)qIWdz1AS#ul-SULO~H*MeGmIzoQbcW=wbd_6pesjkq|iZ5T{FQVxQ%?`$8qC;S_r*Le|I~;7& zCH2V~c(KQk0K}=Ps^n<)X+(z){>b+%W8fFtCA~SM81C6$WEa5h=`6G*q zY_YmX_iNX+NDv1g>yHYFomxb143HBL|kBH;O` zERc~(lZJC`^h^-gxzcOe4qYYpi>UA4C#f(a7X+w~Q|20wXEnSLjrglD57vEoD|U6e zew=wO=7XY}H-;u=w`_hjUO$jut%vz0ZZ9L|`C+$BrCx%V_V?T`0s$;n*%dD^!qu-v zpCfQ0C$wb^z0SYk``uv0&Dnl7?ay0Yo^i%`ACQ5~?^momEYd#`c_unbG9$D=FJ=(r z644+6P9^0+9=7+U;fe}qc)m>;x-J+@I%sqqOF_pYW7`*U*6sNGfD$v&V1Wd8#LDA9E!RcYD9d0CpcwN zHX!`8b>nS)PBFzviI8)!d<5Lq`p0J6&y2?2?YN^ihHRc^xO%8f4y?zaT zR0StOJ3hI*mGr0A?e+X-7P<+JlD4waY8xTe1?9y794G4-4g1{}^wgH}Q5EkXM5hX9 zN293$Cfz|C=G6m80jKj!6#NfV?{3CNuqqu%Q41lB5HCKwd z^#}ab^k_4RdG{Jf@-rUgiwCb+4eSTWT|GP4=fpnM)@S+rDX#Ie0T8|Z;#yROdB|fmunFSfz zw|mXIT~%6M&nMpme6`n__i%gC8rJY#Z~u|V#K|;`xn%VjbqqSFrk(ze48!@;g13v0 zuWc_E=%VivW)U=@flIIOvUd4(loAcnWJpFF2CyOK?Q!=F@6OkD`=8r)jK>?v2oTEVsT2iA zcAsXU-4OFo?L_5fqycY5Bj8rSzPSXFRnSl<{4YqJxW~h^E*W1{y*dfJw`OL@C;aiyW(RTM zdj2EBtoXIRuJw;_vgxYmsP-SJN}n5j!lvXXsXAt#(8|n<0e~FWx|kR_)EaKlURHiY zdH+@6su-YiOOnM7szox9GWg?*kJ-!h_7%=8I6_{(4`7?{0FThQ%BAurCy%RUi8ty(Bz{@1uTuK@katF0cWO|g<~S;>Ah zl~roQnjIn*GQFxT`zh9i%5kAR`vnClMK0Y!H5mV%bRN?4j@+rck20EjC8kotEccU4t0LMw`vE$0xRjca&ca??@9JbYAce$_XZN zIC4lqF8pRkbl-d4Ldi&^aB=y1nV1QW1Q``ND)5sHPnYOCeib-+)xkguSnm=!T0zNC zm?%jHm7Wgm&=G~A)NP=kt(mGa67@KdyqoDzY3B|qm;QknvHMR|Q<{axfpgEtzE9=@ zFDQLlT)4dtI&5&eaWEAx@5^UMbIcbwrZ_#+nh-$3eiouxW~x{O^y}`F5dm)psz0mF z1wL1#O&)VMT*0FC=kPvD_14U-(@nBzy`Qr(bzl!l#Cdx3{t99?5(fAPZf>r%e%5s& zq6K1@m}AAenD6+ym5X}}D&7fP_nkKXK?mMUVDZ#QU60$$)_FtL;RZ|nuiu3 zz}(A0+}u1j4(@wL48d+i3e#LhJJG(Eo|M#B7bKtDv=cW&Vk>Wl{^KA~TIfx-@2(&;*aPw9o?riTOQ8tC4d%q5ODui zu6Rg)x_;RM!4eI8F%4%qW0t1h3gsF%ohV_@V=nE){3UNDBauI>sFss&P4h3dABpC9 zKd1IuA;Q#EuXcYH0p}4SPUZBQoV z;60Vdubw%qf~w3t4imO9_1a1Og%K*f6#}+!yOK^gFy{Fw@U(XlGI-0cD#Lx>P&S`_ zmBJCpSbgK{xkC};b2-uSMO}*XwEeOn_4p5eNfoVmp{vF8fBpGZlLQRm$~i9_j*JoH zC;NZ~$#w)&ap{HhWz*P;M4Fue(#eOL`F*?ebnNVm#t%cy;Hb;*pm}cM(pAzsLN#Ar zuV$Gz)7(YXJUIH^fnlnrLgVm;$9;V7Z2zv5qnR@+!?JvHx1*V4DbXGYLfEdj!~Hix zIug#zb{A#2$l}xAfW`yiqlIoj~lw{!@f=hmvksuoarrT zIW6O@IDn%*LdTw+EEyeXk8t|#sNT0oz2N7P7x?g=2(`J~I~P1EEUGk20n0!2DoH@9 zmN`l(Wqt`?X_N$jB;h?N;|s} za(@!nU^JIM%%`l%OK1SVhjvuh?X6$hsc*=guv5><&QliT=Sw56SZK03$M?Zavp4gT zk@&!%24!Bh>c- z_=)bG{!tfWTpZEZ;Ionmv6;hR4y*K~b}8wQwX4@MVWX?X+$0OHi+KrwhfECVEDzx> z0@|C@>K@*%OyyJ*era)kZlSToQwe=z!+O?x7W%Gp6dE)+uux#Q8e|c_7ApH)9CRp- zGov$HA}ASezdUHp%1OB2Q%r3vI1WK!hD*yYPgo3yK7S0X245LWTP`UB+;SR<)m^^t z0vL$_v&IIj*kRGTH@WmQUFL``8C}Oh4zd|B{{}3QdHexP>Zm6SC{#;kSFPj~c_ zeysyd@A10xzm<0Bo8~d*qi^l~pvd17d!^?gAR7Bo{N#6iA{WKg!Hp&w>f-{+EdgI3 zX`R65?B&vWOPRWbny_Kv3&WTYgcFO0#8_(fMNui~=FKfz=>D?q$4fp@#v_~UT2Zo# z$>{TD<1GL_zrk!uepxJSz2oxftzd;D8J1-_YR6v%wuK#d_h%POus8)he*yE%GYnQ! zjZ@}cc(finrlX2epKWc%hYaQV9(ytm@j^bOnUbu0^fC1t+w~wZolbg5>%MM?PFgHT zJs)u%)Kp#j@U^o1_SO1WEyZr7`_jW1HEn$b%Gcd{@4((fQ}o~5>MfK~PT412moY33 zCdVr_N_Di^=48Xzq-`at`SZK=mir%pf)cpBQyz9Q38+Mp^Tk;7J#LPUZ z5?`QtRqcuU!OT^j16KT5UX;t-r9PS#9FjX8gSnrAi6cf#fD9LkkCdQ!! z`nD3d_s&z_+1YDEvQVQv!6{C=h2Pa`4%uDYyTr}<; z<%=7-&s7gR36|S!`Zjx&u*@iG<@hFUQ{Nnc2k#TTb6_|_xG4Q=_(u8JRLCRaQf0h# zUHtvl>jY8I3lt>Y=wmCrHT~t1fIs*wzkk-)^f@w`wEfUO7MAI$(%%2>sl{muD|{H4K8HpWlGegK*2KF5uLzh)!OoWn=6kcL&`+pw!<(`f^7 zI2_4zY8#{GvfA?ulOQ_v`w&NdQsTi~dpd@|BPr?QN7`B!dar_hmCsOy{KiJTm3lS? z6tE>~J?LM#M($i%IK%*heL9j&^0Kkl{y12@!&&xyT)o>IS`b7(XpAXT4pRX3P2pbQ zlq(zipt|I~b4LjcF55bZ)N1*=&0+0c8}~HVP{2d1Hr@S%KEMo=?Ieh!I=t@(7Jrlg z-H-u!vo1F=K<;#3F4yii`LWfr0DN((8Ijc@g7ks1XR7nU49BXf?7z#6PkrTT{wqd( z3GbrvTDJ`7JM?@|5?#Z1s8qTC-V1JFm{Rq0FP3gS(bgayD8PNE*p;7McHCIFxdcJq z`a-%m!8ny6Vl^dxReY~&0K}{T7z-yv-DCvfmORFS5;$k3V_F&zj&6(;9iqy9VSUlMsn@@Ag-qjojO%`Z~ z4lN`v@TA;`jwIyU`w@o^kla#^t>qAW-H6BV^eEsYFQjmbMLf*(;X-V@7*{yi=`#=( z6Uhg+8{{8k+FGySB$eOIO(kIRF>$;ryAwmy17e~KOS`mvLGONR6L%{nzp@Isvr!HM z4~Yj#`|9GdPXyL_bV=HlA?Uxl1{Pv=L!A}kHVU1CN`yCzYYdB=W$Wu4Z|@Npa6c5d zC4*rHQavxCp+-+SVF<)Bl}4h@s^-6-k)du!s2PSjrnIFC^_qs zsJ`y_FNQubarc!gT5y#mLSslXzl9Ji#awY897ht=?@Y%0H}zJWv$;#6Q}w#^YnP4x zQgv*M_;Xegx(^Q_`tXUyDLr8v(c*~&p?Ch9vGc6b#CVKddwj)WoS4&247e)>A$7xI-QP7H_||9Ilwi8`|{}77^md@S`f*sJJgYgsCz>} z%8gs$>7}1DS3bqK+?k7`!I7;VK1l-$_ZhF1mCPAHXygdY8{9u=W^5c5;WXH2`e zXaQ1i%faS&=wJ4#njoj~)LPx?Tk7sqoECMb5uV;t8>kIQLDV1V;GPnnbaL4OPwO?% zvy~SPZWn+(@`V+~Jy7La6iV$g_af5to)k!CwVZB9#}mH?oz(Tj*XI?*5l!S`4A&T6 z|9M~CO5(TKD=FdIWcyT*JHDmD<{wP|3hutRZ(%ojy8b*mY)-L2wUW%t;kl15IhYaTxSPlGg&g-W_Rn5ZTPF{9zS`@o zjIU7t`q1p~GZ=Q;#7Iuu-#fF#D4CZCHnyLxVf54g4)Vdfp!%Ffa*_aA^KI){1_uwASo6>k>cF;YO`YRJ zjN()jZwyx{7x7x4cK!u^?L#)o%GnxP223B#tWNXyfPRzhSL$Mb?+Et1NI$=X9>2)M ziE@(flBC!Q$S0g1Zp7LzGiYo$HwP5EvyPEEX7Q=Ab7b3XM&p8^j`?S?phRFCS$tKw z%2U63hR*kQv>l{;#6=C{A@M*G|R z_(Iw;abJ|TEcjK2ksq+0sBt2>2LjL5mv8@Q(P@#G@_UnoF*Nr4HtrdT)Dj5MY?6fitJhz28=y0+9^dk;tO5fExSkC3t zwv*8BQ*45BW)rDMxv#OsuP4HVpJ1#Gl39{f2lot_2+ZM8Zl6`&;@DKa*D%elUFHS) zf+BuK4ik}>y?Yokw%EM3y)>`@-;HGbNXf!&YR(l;jSS;Y3oRT@6vpzVS96x0f)K@f?!oVGUdH}*6Df#R zDO8Bb*3+1uOE#rY& z{M~eadTj)i{(#c4^i8~P^uYgm0nlMv-%?L!`gC>7Y{Azl0P^xpE31P4l+{zo-MF9H zKg)+s))UqfG`W`ALuVWx6^R+9Q8%@0Jn+68?ms5Nd@f(#Hy}AHn~obhY9^nJZ%W>I zU8i)0oSUw7dj{#fK@5pm&i_0(!G0lpyNePEz3drTqC9E*k!{HVK3pU$w?~g#o!A?z zb7UwSArg{z7zLL)A*8fb&z%zra~pkk4apN`JyR#*0_UKv%v+Gd4_~B@u*-wNd62Fimo=U8 z@HYJDMlerH&|e+YZAO(hnds}jXE5mtozzb~JdYdWjG6d8XC_t%?~t=;?E$F^Y}Iv;^?E~!e`k}MCTICx%6hBiv&3Gg~2u=Dz`ZwVKDE2tot zxCK+FlM91WWXp1)Z8XvlT9I`|HaghLx~N z+7K?|UYj%=oQTRn_rksa3UlEt;jBB~^C_GyZN(<~M1Z#&gYS~^MXjbXrWmIrHKLq_ z1%}6daV>>HzTbc-{(aq}vnVPCr2ZH+3q;t<1h4jNaE2e=EBY=FXm364WKxDPllzHg$&vrymJp@r*wGrb}|8ROAbpl zlGXUeiR>`GrF5C;_R_0O@8NVrm%vMUEC}L{xs;N$9#Ve$%=dJzfr1`ORmz|Gr7GF2R(U1m7Y3R$glGT9v^Z3zGP=U7p(MJLx)I+@sp9 zb6JF-Kan5U-so_?m@?i-jwh?@>vT|eO++~1L_P-FI8mZLT|H5A+;RdcCa=8oqWx{0 zXI=QW2D9s6efbLY*s zuC#yb!4-PCKJ@LtM!f{q-ngVZe)jJ3?yC@;r*Y?A&HQOggE(m6zeInSy8Rx8oHNgD zpUv4#hWXHvg=c=`hS0;Fpw~dlac&Rz!Bl7W*{biIrj4uN8C{fssv!8@BpmJiQ1O4I z<}2gF-n`>YvH=Z0vthlbajjf+0qZ9=lzNXr;!z3a({T6ZPR(z!DOuIEFr747=64Q1 z&4AlR{;)%9s0Zo(lE6%L%65!%LS;Um;jPj3glO_K8CmK|`aj~R)~am-#k-!og8xr@ zU-{Km^MxBI6sX~)xR>JY?i46eoFK*By;z`7tY~p}m*Vd3?q0mO69VL(zWv?*;C{So zoi95pD|=@4nVDxlTO#YW?cqGU00UrH)M$99NzXHp%AT*43llM6ru`z=_TNv3mxS8D1xIBbd{r(-o{}6P zAXn~#Vj8%)>?F9Ig+I{x&)OridMJETsA~O5*bsGr(^@juCV)m9C{;Ak(`wUI))85q zbWtJc){$7Tl1AP(#{Sz7#M5wjdTiniIb39QW)W;XBCQu*p2jAndQxmj;Pf|m9$o}IAgt3-yIDsve zV0f8fXcIkHF1xV z*FWcT%37AGM*wdE-}v}{!6o(Wc=B$+d9Pf?I@cl1TP%Cy_Z#GX#VbQAtY9zUU;WxN z#+#7DYQEqvJ}R=fzxvx2gysm7#<4a44_k5}Hf52m_J{}fMJ7?P9_}KK0To8Wgm(e$_ zb%Sf3TeBXkb7$v!o}cb0bg8VZ`O(*XHF{N?M9uXFU#rerLFgqwaL@jE2wk}vO)s5c zP|HSb-)|a>G+-J6_F2dFJ6!4w`2}dApmoM+g^2*m8Pxo+p$fgvqZA+%2j0+95pYDK0o?QBt+M_ua3E1y3Vu7N+sm; zuw$4lvCXEQ0Zmj~USL`h&?@Jmzs@!%arH5xwnEsP9tMP0-(afs_<4ax1vT{Dl~h|C zw`TAc(J3Z`hr*wM_%GSH)RhAQDzP$)wlOMQev$_2sP40LKNGPyUWm@9v>=mA?I4ZM zIU>GrH$MDO#Ql=CEbs`I39*J9xD%@IVh6hz03!b_St^xSfBzw{nvr9{vF(x-+Z z)K+ULxL4a#got&8Ns9Fdt&&($K~f2$yQ3fg1&G8vcjel%+Tl@YLW1@-Zc|qD&M9EJ zcH$Az^rjS zuTD(H_65t^r1m(g2TCZD^O6@v>yd;3O1rH7>Zps{| zFliy_>frK>8X{z30^sw81_Lcu)0 zGGkMcnSU8TvFc@0enk8rVSKnhA#ic#QmyHwh{WeeQ!|6~;`_tQw|7F~d>!b?K|U$N=lM0+X=Q`TUp`qw1IF&Ofi@q#@4HwsxEvsb)_7 zc3%}29gNYVB2R+LQrtl@v`_-Tu)*&E7N2X`$Suy>vp6_*DlydSSSC4JQ|1He-8D<% zQ!=(L_kr?AZ$Jy4LU4w)Y#)3|UxC}VoKq7WSdwO}=O+FAVw%#f=-v{GtX12!i~=AW zG3e`*XHX;V(>%>H^|-hGWKFggIUn4yL&Yxsb^}O&2!0)BGrKye%1DSW5wB@qsO7!- zq@wsBU(+YH^&j6)uKf%YE$02Ty1KyHw-aDQ({}pK!+djH#MEietxr}+wHg#H+~O7xJs@O$rEmVpo(8LQ_?xpXRKr$=~UM-|-Y`#;Y1JquwG z4p?{@mhhJ}frp-o^SbtNNpQ>4dA2{yt6%_8X*BXkY+1iD{3Kz74H~&~!Ihw5$Ki{9 zYqXWs^rr?1*Vi7Z7W7XYWF(+_O4xlOQduKDVZWc4T3{l|RG+$Q@0>g_{=ia0VFwmj zpxzjeqGBV;$Wmtsq+=SI%m@AImoM%fj!+SUFyki;vi5L_uw)|LQtBLGdM5B}xsEb% zN02_sdC>p8fBBAI@g>$49HEXd86wB7j1h&MNesP}4-cAC)9HgJhFDLiJ2P)zz@&#R%Un+buGf#(;j=gf4v;nT0 zOA(elrFg*5B6Pxy$M^&*$~S8>$hk2~65GW_MK4Vp{K&sVTI>J$VS|1I!q63V;B{3) z(@F^lHsgN3CD&r>lNQ~Gf*=gG)k9oL6*e#`Y|oU?BW}}K)Vg~U4UjKxv$SJje?#aw z!qqGf0!`jEfyZ7P_V2zD#}Zts)VIoWrulgzVJvddm7wy`q@(U}<^6uydi0opCm_I7 zAPw+Noem$TCIJaW8a#o71p*D#vh5fKV;!Vjec8t(APSMr=j#8LEra4Hl9m z-Aay|oTn7q46!(#8Q85~UD1Oi zH8^qlfx^C+SK7M;XRY@>SmzOaw$a-5K7OLT$i*E!HsX)kP(E5MD$B3>wKLGfOME2v zvcrZ?FC@~c3Z@NxS&i%P8uw*(`Lt5tXbUR!?fWxCFCGxrKCi(~u1OI);=-G>Zz8+` zbpRsBB}4G+T+A9)UD;m)9xHU!D{;Xo9H^Td9ZK(PebWi7i=)Y8hd2N+j{V>_6YI=# zlfrv}kX|e!m@MYN=t?3=ZYZhKq3dHbF>t-Dc1t{#X#;J8Ol+;nfwpxD8!aE`6i*Tv z3A5-l=;`#Le)r7D`#e7~kF2P?1Wm{l91j9{5YI_pJw?Yz>K&MGt?egklaCXI$rD>U z1$^RYFcLf|*|cLtg&eh0%W(}4t|K=U=9*YhQe_vlS38F*N$p`F&1iofK38?emF}sNPU6w zCL*_!*v?mw$Uxe8IFaF`0%{N4>?ZUpZjRq6uzTH~epXk-UuXIURe80%m_*kP7tK?C8Wt-@~bdM7W0<;x+rHsH9VQ?JoO# zHwXn%?;KgT7qKpYf#aD-N&rR+Z^8Jb^9LZY4`$0aa<^I^rT&y^^GT+Ux%8sEj>R+YyA%(1LB;7e7hA;3Fc=Kxbv4#?;(!pvxptsp1~+38q(Yf7&mj@ z{?!bBcrgFM_+NJ-JePyT?pu?zbN;{;C`R7L8=eNwft*R=9EClEjY0+995?1_=~J}+ zp-nb`RzlUJ>IlA+Ke?N`1!2BD@Cay(iL8~HQy`!+gv~fQ4;&HJAw%qL{0&R;<6LZr zCsn#4ff%R0o%3d4q7zpr3$>F)hQ&L>f@=WgsCy^;BJa_Os`vYiZQsl`NFdH zLhQoa)71n<(H;4XLFN}nP8j;s7?Jfm7VA5Tj$a6{%(cLcu-fY9uQbmjqnP@J_(#pE zN!bP21qIoyf$lRDC3ikQ)$s8RewlrB%Mbdbu5O|(W&Gq}(u22t3!^A`!o@$Ae8Sdp z`~AlyIbrM2GAs}4=M~ixojNGpENbY7V2mw|YFmwUcKP5W<;Lel^{OlQ z?{|Ib)BL+q!?&`;{FcY=`cIS|J3T2=4FsLl>2F4`Kem3oK0jUext#O8V0+-UU58f0 zO!yvWjrx1D-L%A@iGM;{7D4^lu=y?)5wTv`fV;LK{;usSZn9<@fTr!Jv z(Ra-6OM&*7mC*BuF{gK5@Qo1_Qq9nt3cFEy&i_$&O!M&I%XgWny((~Sa@bgzr^0Y& z^=ocDcoKj3mQ)*ViMl?B-s*@}C^39nh@=S&kJ?#cZh4v=CCdE{O(TU5mYCtf=$@6z0c+r);>7FxnUQoxE z&xG--&F+-u=1YER@i_#M^qTjlY{rGfsTyOi> zFH7EXp2OeHi2Rr$d)%_HPVxyCEsnL~SZYvj8yS-8m=u|Rk4A19i*+hl+Ghz%Y&;!} z$-#RnH2#Lw1r<3dD!jhs)Bf`gY@Ov6CevL_`GwBG`7ms{{Yi6%IK%Ti1Ptb@t2ad% zx4iRI>%D5NUvE)6uiT&a<#}okj&0wgRTTHKj?5MJovkhy8Do8pFkvsy=Sjz(a_knP zTI;K4@lnmYtWJNn^n=9_*9y0jjeDRZYNfOajk3_75#yDwOvC1)jn8*l{l_q2ADiNp zy}fW@Lb%JvoyCjx0^eD$HUSqMR-QTwRu?{1Ive_v^tXB1FC8rH)_L@cQ#Ej&9CJ3~t7?}t6!mo9d4ipg}*Txuu3&c=AX z+I~R-ZoOw@^z+!}C=aCW(X>nFs84Ba!9P7;wp*jKlH9yr-tv_Qejp{uyOlFN+Pvao zl`J8x%Q0r3LhLvg1^NaRw9T|c3{e?|wW1e}3N+61zZx04iRGa@u*L7-y(-i&!x=@{ zQs^1(n#x&<)XblrrjYqgwGIobw_SC(^m^)yJgLY3y?r#>`HA~c)-o(EJ%%N2>O&Qx z$lSuT7fV?3pS+QnmrK8_``-x`mK3&m2Qqz_6&$D@+%;H5>67hWS9>9Yo3<%<7-=Hz z%ncF}XWWnGapSg^kRXkZnYABl>a z?gMRf$BDK0{z7Bm&7hc8vM(_D&XKO|NGFWu#Rzjr%3@-Bm zWU+XAcg-+X(VWJ(S5r`zWEAGDOOiOX7EsD4f9A(|%Jn5qG=OAY$lzdXzjcmnAVx5T zi0+xze$(B#wgT3Dq|e2!o3Hi@hIXzeLDCd`eXZ!Xr;NRLHI0cPRLCI3(sr7Z2+CH2 zp<$HnWa1UF09Bj*=7cs+3%NKsb4@nZkBVE-+7!6wzjgPP=t4a(#Wd@jevr(3y$62W z5k_OT_Vuu8Z|8d1%|`2;9pVjDQAhle**dN&=k_7kqel^W}!Q)WF7>Y5w4fCWCe*>pi&Er@-n zCWUV_pSHZaC#*kxp#Qks6=jRmTzb4--5n?*tCu9v-w-W-l#bKWlo8nGE#K14_iPsp+7gjn7 zJ}c=<94xAJ&Scstlf#v;F8I~DB?i+4ldt}ye=BY*yAX-S1Swo@Chjj?IUD^L3Ms3z zn>*TIBF}AH+M;7wV`8p zIH=+kqo;o6xhx+Is)C*^=heK<9@R>F?o^qeEGF)0fqkm$%Wz1khj11+XhJk2$W~39 zg|%HwRQ>ul?~T>S#7mI%!==?9uf_7pRp)sfyO23vYjH2b$XvPdDD^aXFBcs4pYOQE zyeK+IKBZyNS^57i`P~ppNNAlUEMLn@1T&pdjjkON3e*P4h*q7{?df3B#-w>kX%SI6G_xXT;!7tLMcACXds7ha7HMbZlW3Yv~?-Rr8@ zV`u@atFl%t6qG00otX=&~I$)xZsQ0tm<+_Ld^Dx2NLYu&o!u%h21w7?fLbv4g zyD$>W{#U(LpvAv;%Uos1@>b;K#0$`5lkldq_0~vxKlUz#)0`MQD1b2fLtpm&Zadzk z@zLBmx6`q2Md)-Eop=_@$S`Zr!Mnog*7G)VfqPT6_i6#p(egkT=f7jW=_9LU^cnch zKS*X4+dc6!L+5nh{SxmgRJ{%Fc*sZxyeX^{&ZfRk*UI zBDN>4VACN$2s^zJ$(cTBXS{ifM!n>_uYuLJq@(Li5t(X7WSMvjZG9$;)`;%6F#~&)suwwJu|VgX?O@$E%q=+g8aZOfKFKM zCuGDW3-0lB@4_;a`cY3EiMP;?3F()7-r>`nYq7^Q6x|EZ^$Hhw+sW3P2K**=qdkwG z{?2$kHbJ4X8$aY|_)B_PIv}(#m5B~TdC|KI*iUTzK~sz|AuPCUANY$zU5yWVkOU)w zZZwk2ms1?e|2*b($A2|7pPagv+q90j?5y?BQW1F#c}e1KRBJS{QZelc)fr6T`t|_1 zcDH^+22t~_WsDClVdI3HxjV)hjV)NGb8x5VGZs|*@unhAd5~J7k~eSdoLR7O|FXN} z^T}l`;ZEb1-TSTN{*7i>)1I~tFTUITMKnF@39RSN3v`SO`ME%Z{V8aPZpD(iNqZ~6 zA_OXFT9wZ-h%zrmZd=;u7a5$XUoqEm_LayYwBL*8@pZ-V_c6WBAN+#(RjG)wr)ppFXX1FG9;@K8E;@nXtRlvlr^No=3TjS};`Yw!w#x*trYidqav6bq8vEPbNyH(Pt9dlbCUQ2&5Obk>xdN*#{e~ZSqa`Ac(brzG$g@um=Lt&6 ztiVkyUg>e7r4!NEzv~%En-xMQk2W4;Uv9gKYlAY`k{6y6DAUE!$2LA3qnQ1LRvbDNdEIFpm*S~L27GE)bWVQGzWZ7FSZ6Wzh z-)CLyt6Zt(SrRRc#EnOu-GjZFX$6qXG!&n7%xhio!!KQY1gBF z-L+e(>3zFeRp5TzE5e&mDusvGyTm_Dtn&ve>6nbLr3`gi)=z#M({dmsHnYh0wG16t zGOphUYC72F9PP|~(msX>Z_H~ruXFmIShFNFpArNns>>Z1j0KTKG6)ty1M-?`nwdM> zqP1v74$i)zS^G$d&?7*a*6-!PR<8EnFt9@PEwa7shR`fJ@tfRsbn9HNHLjDi0)pco zEef3YRq5s1E)r(y(%+c7Mn}jmajSf5bM$lggao24xG}GK4xI{u)K0i%*t5Utce}We z$^ZUN;iu5ms>cv;Y^n6mnErfsIxZaNLX&fn{loQeVP(S~MyYy9L=_64WK9wm?<3*cS55=_!{xP=&Dit@x-pi&anAq`n7b`=AFjXSReHoe;+w` ze>pGahK`iRNvOuo*hkAl7}rUOTXZZ)y^5{R6Q}zfpIa<0C?<-dJ?RLY_`DE_>b0%l zv6*%dVb-Ck)?WZr=u4$ELpsjWdbogpa?zO$(^xYq(Ww1kC`qeD8}WV?FNet~)6j|f zuixPpnP20fpJ!;Ob~c!N2oFFNZ(i*mUkv&F&7r`I9?NCmz``q<8rv+TTpo9KOisfX zi;#36pK=AZ$@Ot%rRMGZ(yHsrY(ZPsG7^_-B#{6g7d7V5&L774SX+G`b(WcxJXxA0 zERV9j?5p{z*3Afh3S*61Zpw*U$8F!jE&WYNcD=N8VaDc?pWcAgI8tm zB};=TA-E>ZHDg1lAT6-h0E&9MZt}8u-ZKQtY6kGptRrRQbR9c&`N^XOQ<{jE@BYrV|Hb37Ud@Rw4MS-OaZu$nkI^nT zZcT*N=;jsa5Z$p+?d9&CyXZ>@c7dmp8V8BqExXLZn+Op2s8QNRt_0l%pIPDDs$}vZ zkM^MQ+WE^*jO-OOBC`)EZ&|^-?f#xkE8+5rWhU`Qjl1OHM^_mWK``>xSqRPr(CG^kzQ27%tVljX$jcw>5EVVpq zgRl$IL3$ef$S=ulI8_cxw*w=tACwWbup9@1rX>wS2W*C}zLF3eGXC6k{TYKOQgfup zljaUTbs1x>(!fO^D^LBw-+H+IUUg25o##j1a|HHfXoQ0jOpvpsvEyYobbw?~;%OMp zOJ27CgDf4*`;UQftk~{)Q`2VzOp2JO?LKdRYed#^3cZE)Ri*t~-i|1H0XagSGcU=)miKbw8{ zdZMT*2ak_Iubbf)4`Yb>V?8dUa(^M~trgcLzr#hhHrZKGmT%m`lgU=ka=#k_ihAoi zf3Q$x+#T|kzqLD2X4Z(!m7ssrtE8B8d-=vb`AY&6T0O8(;kmAJd}oT`G;*-!rNKc$ z=j-o@QL!?aD2=U!Q>-)Zjvkd3=tDV$WW;{ucpL7-vu^CTzbvGly#BD zAX|Af(<50X)RHX+IB&gI~;j^ehC|Q|)<~InpkqzvQLW?9gI4 zZ#YOto}_4>vcmZht+P%Ahequh4|f!;CfnTBE!O=&XDFwE>bfsM_|*le5y#K9B6prZ z7kSrF3`q^*idz*$I7qVa`1IHDM@jhw>a%T8mCQL;D-AY-RcS_7nd%{w6*o$*fjvih z^{koRJ4mv4ppnL5e%D-Ufzl-uk)6#>e_5oF@Ob_{^`F{^pgdo>bc#NMQ6s0kLqck| z!e3e5f+^(j;cnfyjsg|U|Cj`1-=l~j4^NJ~mEuhFfjAD2M&Q8iSAeZ0o3FwcsVN~U zOBk6nm5Q3humn}dcX__6Cf^uu0Z4-k-ABN{CC0<;uNBg)gKYk2e9CjIi@&$ z)wx8IbA#T{NzdUFKsV@a2pT{A7`|bc7m{*2{I-l5jLVaNf7u3QM<8PqqP)Lgq%d8- z@zZxveyONB{9uI{SnpicX(=H*|uDEK^JnwATFOS1Q~GgIAdq zI~a~$GhrLJH)GkWGC%mnxb@;(Dn>+W0 zXe{b4)p;brBD9lv?syWxB-=jG#~{xgo)Jt>fVwH zpR2m0fAYXc&%FFWs5}VDL~AP+sjL@eevIcp+LK##M44V%K1@TvQ~%VtqMex_vXbIJ zHN3Z zMw9|?$#A&hsOyPY)eVShk}Wk-(WJf_I+P z&Cp1OF@s4}zA}4J#)_{ot5VBR2RQV6;is45Ob|-Pz5xUutw?!_>Ey1)jLd$)T);q zu|>d|hQYqmh6}XEj8hT)JBP4y-sIEaV{Ly+9?-NP`dK(=+ zpBaYjZdss^TXvbeK42Podm)!^pffav5j_QnEvI62xaoLAlrBg1bQ?GIufw~GT=$7C zO}iuxH^Q&MEZ>>fY5s#k&t0jm*x=b0zFhP0#24MSCFu?iie>o72$||a6g#gOleOw* z=C|A?{sjx9P+1>IUf%dBhyW%<>9h3~ZrteOT}$w#s7U>yV%mWnl*jKY6=~IeT2Gj5 z1iC94RgWcn#155Imfd(r z<)VOvEf=g2{YyBynY;xbv8}hbry`n6-Ph|Atyz%*BQyD$6VWJ-(0VbW)H3att*f}& zjlcNg;g7lCbQ@I2MMGAC22#2j@=+~nR$D6ERr^i91dY$5XB-pyQR=FonBcEx*d*A$ zcJGBKx~`7R%lB8(9klI-bNVex28fVEB=05`Um^nelb;lg*4puM4d+O-@F`S#TF$V! zM94;vM&$PZa_VqgQa*P3DBAg1*6&gzo+lh~5JIL5MfTD2Rf~rH3!8MjeTVXsPa#}0 zgpn63Vn=z{na$VeTIG++dAA>0^8h~g!jDr}|2ppEmG)CA2nqCF{0xbTQQPU62gSz> zjWHROmf@i3_CIlg3kZG_*inByF>4Glf%TUVZFI{q5>yc9B^GbR$bTo8XWhfTvt1iK z0XjK|g8L_iJvGulHaGq0bAoF5S+p}s7FNY?x{nd)-sB)J$cvvRXzySyrzs`G=_}8e zje0GFYW_T?Bie&d^CVh=b zsQsiD%Zam%#|@pRs63D_;YIz0$!(qUMWz0&F^0H6t@ISeR(i+P8Y&XxR^Fge2Qk9K zkn!pS^JDW68>Z9AvN*mDoyuDQXGFho)I=aq)+ZH4qlO?k+}SXVCR+Yy#UG@^$&PtF zJW%gre!}rowR~22bsGO}>05^!>H>ou;|(VU#UY)cgvn4_v;}2;Va323KA02;2)Nd; z=rAEz*^-GPxwuea$ia7}q=Yf<=n(!zSR_j{KrK31S3o<`kDMmhu57=WArGO#;bxop670P}_UgK_0Wp#Y z#Du?pU$iVN&#SQ?<>Et6-r$TMXo5=F9vevngjB51Vd_!0K=~mnE@7Zve3W zDNoumv+Z2?bE5E^0MG=FhdnT4U|5nJ3$|W8b6{yIa($*_Fqo(wMcn~GqZVs(lLrGt z(iK4acU-8P2tg#(J8Q@Qq#Ri4g5&Cfy(#p(sApJ%cz94D7&LfUejro`gcQjfb}!IUtj{?{O@V_`!=NGfBh#xAU8;4pc+MTL_pzx z&n+OYu#2PrlQ1UIK}e7rS_z(~zU-={n*!TZFFb51F0>hyI{ZE}eAa@9|U;W?F9HWVV%rnH0 z{wW6`o&a)#*>{rvjVAN&WRF#XLH|?N@&70P|1JOj=C$vDqhzldLdBc&0OB45`Y5R& KQ7-ny|Nj8YQ~@^t literal 31097 zcmbrmby!s07dCum7+?s2p}Rx6q@=sMLj)-SNlB?eIwYkV>244Z1{4I5RzW~YK$LDI z-^24fzwf=i>-zrt{*swFXYaN5UU9E`t!<2smhwGpN^AfC?y0IM=m7u}{1b8k#{mEF z$T}tm0D3@GLDs;}ay!pAkoxP}vjPVPqm;M>?lae6qm!|0Jce)`LP9tz@vp_T#RqzB zl&bWL$u_u@Vls;@>Ynm)Lzg1O$Cqu4>12H)_D^6QHt8DN#nn%kk~*r+W%w-Q~^KI z;XO2E{ckE6bYS!!dGExMVwOQi;$!A<5&id7Ar!gs|16h|un>xh3e!rD`R^-mxzGQ9 zFV~%(Zx50#ZlE0)#!ngvyEJ{~*bpmkf-MWvU;?Fae9F!TN*2sO&{?opH-SqN9rgFu&>USf4*J)#RSL{u7IuZ@ z$KaM14*zokLrA1SWd@qf*%=u$RFXI?%-4Y+zmpI$4cCEKQJP_cdxxCC>ONU`Jbea1 z4MDn3a}g2UE@xKdGp0$>|F0?Gp$&w+84w=v0_ws2>PF8MGQ4CBfoMPy`rl~}g`);W zW~2Sm7Y6}P%$R1yw1GH*Va1>rBn9j#ItsUnI2Am{aiS!SV_rzpE&mf@G`V0etTswV zb(d(QAt-c1?1Oa%P-paE%!>6GR@OFU`I@CxgQz62a>? z&4&m>Ya?9*DvU-3aB$npBNb3kP@znKEIm+%mbsxR#n*&DPi6`y@!=OZt!5>@5G$1R z?sOG8h_k^_+z6A1cVIxg+5in>pfDvOBu93Oo1X~^4KoP8P;vEF+T#j-#p{gk}LrMCN987}&9E072{XRH` zB?~>f*`e4?hu0N4ePe^!SZvvJ#svXn5nS`K=Id1iD6A<|PjLwy8OrTQWqa<@YH_YR zcU{SZSiaNa1U`0RaF|6_dc!|Un1ku%TPcv5*x^;~->2ol3P?84O#G%wOhDcD%SM(w zr2>{ya5ZT4?K}c8t}8ha%SzxFuJ_pq?nGhTKOGGz7dRnTfj_U#SWVFQsT0DO#10N2 zz@l;u>efCwq*CrulwM+>Z#$%_={x|><30>A6b)J%#mbv8aFX)~aFXG;ke&~Hd$$!$ z=Oq6hPso_WhzO$mvn~`PomwpT{9<&S zrSPxpojWB*B1<-ffSS(_WQOYWnEHgu2Fg(i%My1_{Ql>O%_vlV!1oD-{aP|$^pZYU z@fCd7Ir6tWj0?0<eY+w`z{4E+K1|IB=hn0I2i`AwUpw6eCat1mWq&+&ge1+u&s7#C-CMqxvwGEnM zr{dfD_Ymh~cVi3uJ2s=$Fc$I`!QN*QPqW^HcMk{@P-=HBOf|>z&MWvqi(=31qR%7K zD!=A!j!!xtRkJP0Ex1YE+RBDj5;fP3DjKVjUF?3Fv9FbzR)mAiF z>W-38nUqQddfO11?UaZ}2xGG@TIneQ6gcp~tZf=7a442a+Cc&Ief|9KeV~8Mi2{GF zGSu@j3h96YR0`Y#Te&kq#~gt7lF}t`Or$l@`wv@gfDU`1``4Q>M=Ip@hZU;fr>p)eF__0mYy0WX@T7EF(co_)>( zAWt>p-L1XVPa9Zzo~QsbLT*gNB=rFuM4K3xLVG5#8Iy5!T^oWNj@$o3A=_a$FFE_W_qS$3 z43Zye%@Qn$7C3C;d}PMZUr>xVNZqh298y@mg?ID-aBiD7P}4aj4ADdkA9^VHJ$Pt! zb#D~ShiGutGcW*O&jZ_0cvj82X#?ssg<;I+NaPj{pgOq-11=&c0-Id1K15Vk?F|Tq ziIkEmpdQ0Yuy=H2&U4W$=#1<4J;Z#(WN{q#g&{MfKnme4J<#)KXJutCf&bL1M#2yOb_m25 z9U0*6Yw;s3*hJx*FHBF)nzwQbBOdtWAUSc65z$dHbzA_mqB`x&Uw@HMpUiL9HQM)MxId=iO)Gjv zBiCX5XCLeBA%UZZAJAC-jr_?r$4La^gzk?Z|9a14txul<)ut|iEWr{uEj_*A=3`7- zY44=8TV1;YPP{33Jqb0GA-c?Ar`C1mVm#0+`H(h!?g_jgLGiD3=0WYRkxnB})7-$y`t5q_6(iaFDPTg7~} zr?g(VJmnsYl356MMM%SburM29!d$Rf?HwjFszHgHOim#he*Q{ECFXG)vR-u57uk4b zn1Pv^$hs*HV(8^qs7%#FFh0CM;1v`dL*WVx;u3QAqmc#haN=t!_%@r?Q9Mu(`)QRf zuPpA^FAn(=2e>$O`yMV{haP^_$>P`F6#qIJKC1!x!^cn*nM?Y?;&HV4*Jzy;(MQZf z`Y`Ip02nxNfb*vE3h}SFO$C+7%ObfPiCzd0$uTRMqXEW;2{|4T7`?h9iVwHBY?6q< zm`eQ!cwJ}pW*|Hm4m3R_=Vl<7A?oj*EA1FbdGvG6>-e| z(a1MANS#tz*+F9b1D_s}@ZJi;0yg~-C2++k4#}r5i|4# zEQ!+Ac$p5y8v^;O1UoE!4Fv~C2|PZ#TmzMijx6~g4M*0OZAU)bXWlR7h!fezRcVYy zrozKHT7D7qHF7@kB1NX!$BDFxHUaJzyk#Qga?*7st8%Rp&ed*LDY}mlNw3d+fX}`) zj-UvQ@;^ze6F32$z$DEts~5ol+z-7eE@+~)gojolMT#%9*p7=61aLmbOB4@rkYx?S zFlu8!CGFxYv~ivFvTR=oi@r)8}IJ71FFIf^~m#A;ZrbILW$p_df9?_`pckh8(^Z;0p zlV1~sYF9S-<@_{Are{oI1wp1{D9~R1{YR54gn-p}#BZW0{PmDAj2iUZyf!vXO~-3* z7mhvXA?XCzPt+R+LZ?&+K`0BRcr#F&Qg+{#4tanm!$7%7*c3eTzu`z5Y@~a{&12l} zA(!D@R4!6gpH}l+iM6t0P;WtnRo?}MJRVXEE}xpb?U?%gP_;lDOSB9~B7R4SjQ9~V zNmeC95J7PluE|`7OB}E)8eWcmBf7v7A-6^PezaX-5P8b-YL{s_8Zi?ybHb9w(XPRX_yiyl5wHpnD5Jv)K=XQuk*59RTGLj~A0$zTe-wdqi?lZMH~p2DGleI)J#TVJAeHn3}%r@Ud$c!82n=a-?@XcaDWNe31JTe6=(MZ_Efn}th&&!q zj9iLM$B{k|f(h)Iff*&sW81tnQnVUvavJjlwjaeAUY$`$B5dT^2io7Xwk5;>UPY5= zgbD$q9dX}mFw(){cb@AM&BRI5pFM|}x2l4U-k1<`5CQ0QVUb^r(p0Fde}|EWX%BuH zkVcR&F0(>$(t6yX(66pjxNtgsrq$-UDUBzOWKrLs^cI!Z$^7TO#z~CHzX(tj95^^w zI0$zl5aIb?%KI&7W+$)A6tDNccb(EO`yq>JgZ>A1d;t`JZy{saFG3kxV<$Ee@>H@Q_>@rT(88w_BcH~mQr&K+4|^LuJUy#F8kkuqIe!!vu>-@j#&VQWL9iaRXqlRI_5b z46mtLuPB{Mo+Ao9LNt^DaO0=FPvBmyHO3pPO?05UZh!YAD$p-g=KSXTD;Ki zebsu$$Fw=s78@*+$H3Lm_U#*h?^~mRiisMGpzx^WzQ%VS{LVkfwAUJXHZymMX-vWA z>soHJeeLA$Ub}@EiYpq6Tt}DbDBdHC48507Eb~Nw6$SKCq(&6jQ%6JZ$b#^+b8Yfv z5e;lNCzFSMBL>|)_gwuU^oAddfz`7>^@TTs6sWOGuCap($)tv4?yCV%vCk5=zn*HTu+)nB2mqZsq4-nDgp|12uez}b;Yhtdr>o51kF9Xx=VIh=i z1t;9Z4D?RH_`qc-=TOqn1FQyT(3;0YYNx$4e&lM?2TF6=Lf%dORm0Sa<~Jl|KKsMA zuElKS0V#Zk1!O!#z#LbVmW2#S>sLr$K@kukL6M}id!yrOMv4~w(`4k4RPW$DpRGxE7uCo`Eck9xFlB1g(7dc*(+~ER6{m_qhj1F;yAa zdDy_oKuEjC(A)n?eVIJ9XN9SyE~_R0GFcvU)*-Q)gINPYT=aO>t2qB<<8mjU){6BuD79{6al7`A zi$%gC%Y8Z8Z8j?>5YSl)KR|rZh9Iqa4fU*;LV3QiX}mE6sFYD3D_IoPEum|#dS&ku zS0lU*@-U?Gqw!i?ogf5NUtE}hwHx1OhHhVE zv-BBvuSNyVs-wV^dy-Zb$vf+u+$0_j)IvpV>93fXYChCEAbI@<1kpMKS>r5cCzsP0 zJX-Pf?=p>3DC&VR5#zxEoX<*4126qKj!I}WiXPSPZC#Hnek5c`q3UqXR|_O@ zm?HSz^-&0`M##gxPEN1{DbsDbUOwFLYQM^f?k#5 zWRKnk|NEbW6!8Q={xsEu`JDSB7L#l~GeO;ir9FJce`rD4!1OqU4*%Y(%Np>NiBst_ zO^i6=kKVeOj{@-9OkXEXoo9l?TNhwe=1b6EZ-__w;v>FTV=9szUFN&|v&@O|X-h+K zdcO`4D{@jN6~4%&vK3ICcm~*zIY~K;qvh{6yyzpa1r?)LKK8< z9H9U!Pi2Cwi+~Uo`k4@qSBB7D-TEV8~_SmdbePQ~wt)FDk4^h0_`d}Xo>Il;Tr zd!u1C>sso1r9PZ|Ccm{#(5k=5^46v`Z@t@yyE4&6)j+NA0gd)WJUcHENcea);y~n| zSSC+jvnhaPv_jd35%B~WB-+Wmnbmv`cdpEym0;Nt_#ez5YSB~KLx|EUSTAnCY0vV7 zJZ(kp$Uq20;;asf2E+F3^PyJoE{G!Zx`-&QK8Z&U#SFv#;V^P?!}>3iz|ArTmZ9~g z7lpQvTLOD*^1(x~ns@Zla}=t&eIw7n&Z9;1DSK@ce4iWOXd#1y zrk6=PkmYLgG=szK%rlm?;*RtlCW4se0Fz?bSJHm#u@BV4+T`S&-(dC4P=*lfoD_)t zb`KEyrc%yj38w$T1GWc*yf2uvzuf_$J45%Ts2wd~3;)}y?vc}K%APX=cjpB9(+)?frq+!BBm*7sx|Gtw>iu07h7wz09biJK7$`;`ykz$G^=KDt z7TXX{se3CiH%k>2mI1uOA(KD%;$plR(}*OVzl5EW0I{bSfW=0T?b-wf6nB3ylZ&gJ zgKqr*BNRQYh92eR#+%5*W61RKSAy8-Ag)&;4i7r28`ET0M^k#8cE03`BJ3u>w!q!@ ztLL^yvVDpZQ>c6CsqWyi7!`|2@(GO)Zd7sT`u>YW)R-bPkJ6; z{ZeO%@F9YOq`K@NZIgLa)?bRSU!d22bw^SzvZ2ZWomFXTob)m}ooZ1+~Biv0Xj-;HE9dbW|K6AcK!~6|6xj zaeXgQ>0!_vfb?a0$9oO0+w|8+8#t)bQDdZ0r~e5p+_p?-gPpuj@K))UPz6F=&`_~Y z3-%pM60o$hne`nJpm%`-em4a_hol%xTB%!G=yln^oR5MG3@Dc(uydkGW~eY?wvS+! z?klH+EHC!l11O$a*FNSmTe%tShbk$KdQdED*Au-3YcnYJwm&qB3?P}aiQcCePh||# zVw*t6HDYLz9vvoo{K#MYj~1E6#W|6Q&ZMs{fR=Nv>|?2rZbcW(ea}ctn}XdFCp7*J z#ERqM9xgn|^tyP7(v|UpBCk!sEbF|VKPxZ}q)?=WftzJaYWRL-1=r0azUA;6F_-`c z(9bz*kv?JmIax_J1|WlWA!e5dqw8^p5k_tuIH_lb6CdBeuDlu9gSFElFeM(owjF^& zDM)}KwH+ED1k%9k5lT&We)hqj;bVW$w3y~09G^9NGaSnk#{s~o!cfXO!{n;gK= zz>VL(CfhBVur^Ey%>tFw2M(~BFr_sSKt|xlKobqBfdttK#c5$we140W2 zSt+$i{7`hx)fsfc^QMC3il)rdC3k5L#`NLfFZbn#OQkn+4vR)x6Z0)w3sf~u_0ZwQ&1FxZuw zk;MLH*}96ceU6HyUdvi+Nqyar-B4Y$;!C&8=rp;2Oc^tDq``13^7lR34Y_a8fE!d2 z*jLtoOULpIurBto)81K%{=woN8|jc0|D)8Ma>TDKq1w9`bjMxi))U7n!2;!g6<$Ct zf>QQHO#08H%XPv+U#9na6;1oMqEAY6q!^QoK)~#jh!!Ru_#vi-5V8v+N2L-F?8b2S z{a6UQl$dQG&`vjS#DZZeXuYKdty!#plIdRQJhj!tUUvPb8Q~RA0F?G|hD)AOZ_RdyGjhAUgl1b*n01ZN?EMe0+*EBgFHOXIj9I ztD)p6FMx`Yv>!>L5lNE81pey33>Ksi>R)M z5k+pJI%x*6N@)DH=#*yFZ}8CllevvkTFz^1B#u$T_ZMTlLfsT>msLJhD=48ZKLb({|)u{1k;4y>Ff35PCK zH=P$ao}J2mL_a$r#e@|tVj5kxM#Je6l|J-de3kyIRUo4VDo4>ZFZ~4Fn`3`{ZN?-4 z2*&wnCfE5^{3Y>y)wH=<6urMl46pP9=|Hh<3ypFk;QkyBkU7jEh<;ZMz7L@>UBx!r z*rCfXs0^VaH+Lm2o0(&1h${Bncdh@+D7`_%X8~B8)8|wSoP=$t7vq9EaV)=FNJc|M0a zNh??Yc5_rx+rWad69We>fXOn}jO|O1QAQ2RSPa$okR`sIfl9BhkUZm2-{ihx>=e*z z=ZKSkRGF(VuZ9BaHsiN0G)!t*urZbfy|jUOEF75%xl3|JiJ!itK|%eqk?WgX^90vY zyIB_^24Jq%Mo#Y^C3aUTb%%#ifv{nc!R%QoLhqObUNa>O!BedXvozy$xIE>8Md5~R z*^+YuH<&=r+CyLFOt@c$jI&j)&f1wiv{Y?p9JNfeNMrwgtb+bQd@N;;Jjx0};08m< z^(%pz83w24(Piq#r!E=tWKSuc0U88Gh{U-V`}7+D{GDZ@wbX;@9%aX~*re=FlE zmqdc+V4}FJK^^}6M1Z!9qiFhY0uLFI0Ee2>riGn7bO}^RY{tU11Pq?iVTPCIx`cf} zK$Zy4OF7~mpT4>2_W!#qJSp(F_wTqQfKrM!mwwz!r_b1LpTEFbr;x8+GBN=kki7OHqYg zsVvun=wQKZP(JMij6(lvqbsDhMmH^N;Gb!hyV3tw6$X$p9I}<%U}1=q$SMZs>tRhT zsY9#KBbCV;Bv8;|82&t^K+n#jp$LJf8-ze_b%t@7)0Iz-G6q?I#fLoMHw`Q( zAfNcN)}`F_UtScPjkYEv2>rzkFtY^H0X(Bz=qGp8Y(nV2tWWxyrwpO$q31DDNrKEZ<28jme>oDXdEAT-Q>a&1{aki=$KCZ;H>ZXaV-6yGNg#wQ+ z{xLT0((!9^0eP5&Hj1tqgcpw^QJc#-zM~FTJsdb^0l~4UvaT=;E|5dM@J(ur>aZ)8 zxjSn)B!7pb5l>wUbC#y+UCl#lqpLPCY&lpVO|i3ipiJ!dU<=wE=y)EzuPc(xII4hJ zf_3+@S?I0KL->}Keg-B4VDMI~uPR4lA^6m+mX$%ciUquXg;DGSjxQREVgnU?K{r-3 z#`GMH!Xd3}bH9*%Z+McOD?cX($u&5MIi<6f+Sak~$v_IPDaZr+TkBLrK?PBT);bmN;iud5 ztBZoHqju=Z%)7Oi46=Xu+6ZHb*q<)YYcdc|00681{KL0Q&_y;-iSCLL@75mFJgpZ* z;`8P5#$eZA|4a3k{51|wes1@gkxZJyOv0mTb5iQ~Y;>0UF^Yq={OsOS6n zA3W*%7z1%OV^ZvDmDZ5RDAM@>?&?Oezi`3zghlN~Zquw;439XA?$WkZ=Iig^gUb zd!}KOo*&qwL;2p1(AM2CLw)PPIHLsXn5CIgWdV1p zk`P{~V?xunVQ?u{bS+oPn~RibC2A2hMZrmT|gKb7TIZY>3H`%c-d;(P8k0O!j zG>_s@!IWuXOAqMtvd?o--@$U^-&=x$Bl=4P6djDbOPd?N(|$nv-$Ft8JuSw7p&av z9ilQ29@Ty6GFy`O+@xU{Md#hw9upG_;A6BqX&1)9^0=|u5xov<=7?*_i6heBjq(RK z+jw)yb|`q;?#UjKzm?8?;?1 z*D7n=N04ezPp9$%7Hy-cS}frNmqS%FP)86qPetZ z|GV$bU%Hxcap{70zhb{KiI)YVo?hb4OId*_zrwxi~wI= zE~IZK!!a)oCa-p-3_q`ZV4{0x#oe-~N#0kgvFQ>wBL27yOi}^muHU@^KPR*-HqlK9 zdhT8A(B-?fAr!jVC=s*|#1k`Cd*4y*VgZ>#4ZLkMkein;&rMFw-0SDB-~7|)M%Yfp za1HKc2?)0rC{hQMrxUF#wJQZI@o`fFc4+pkmA^Kz4MJt;AMvMm<3{f{P$Fnrof#il z8Xe>OpzFm(J7)yeN|N>_k@O3D8*=ofz{E*5d%UO+3v`hg^-sC)ftwwEqqSVYZe}yK z)~kiy7a!xjDY#d(ox3WWEH1Z$wei-5ZcRY~XpleOK|X@xX9m;z7GCWqK(E?|h|<=x zRYbdNF%;#(r1T;NsR|=lPN?9La@0F->F>E7edcYJr@7e@w97fKjqfsEq4OygUs7km zEA?$x9l1gE`YJjr{l39a6XvXe?6e_3o>A18io3E4HjsHodT{M%p(9H>*eMY1d=T4v zPRu5&%n@L;eu?79D~u`X5i#ma89BO~x=?I=!r1j$;jyxz>1RRy9yU4k*fw;)k5p|7 zinSv6Rox?s3ebftN9r=ZQb0X~CcFrcFes9Yg44B*-Jr6x)@e$cf{5ML zW}UV2?Mc*&?E_QuGP;fqI61B$d1N*s6msK>Dlcw2R~A12>*QeFM9{~{kL|3EVyjv^ z;n~j@IZK&D&BEiez6Xl-e{G^Yxfn%P(bbwI%7~2hQrxbabsh#y?}h1d6LgfhV&$ty zW8CH&0Q(M3P6`;?`*m4v)SKj!tS1>yZGWw0fA6a20x;w?NaXt7X%!l#De4#K;$!H5 z`TgPTLf@R}{?WA4_n!-Ke*mI!u8J=2ikOR#%1^5qn(=#`6D!y*2>J7B$$tKCGi2vh z?>(Qjv)u+X>p_-ZC-W7C74=jH-!wC|TJ2>X3DJdgTfP5sy`p|Eyo6Q3$_k3xTa%8{ z+k&S1{T-J!{7=-*P>}1`;`THZ)h|hhPmYy#ui~D(Om`V;*Zmg@=AtIpDW6FjrdW?= zSuF?6@Ahf2@fAT)SZ}Ok(By-Zudf`G9s4Zh-4w`NdxL|t#-FO!(F)NQWOt;ZCS@!# zO@nyz8_k0MVWX%It}d3tFTA5zzx0mdVhEmDcD^_srl82<5^dnAF|@M|rRe-YE@)8s z1BrXH3+zy#d8~x_Tv_IAn)da6aLovT9I+=Q^0UpjoElv<3zWhLK{ z--$*AfLW40Q-6?AYBEQQGGyhs(XSoe$B$M7Kek#W7WIo8zI&TTw6(F@S@qy+FvffV zSQ+iEj==coSDXdLhM&Q_zAq_k_tjb~x))u!4S-omD8}Jl_JRG$aB_ftFvRiV2FEy2 zQtD%g8yQBpJ`pd$CY0E|8lkahZ7QUsJ4ll-s>! z)j?s2=3$*l)Z>`F!kw0h!?|kAOfXYA^>MomzOP|GN|u%PEAXHaXh`h|U0_pgGu+8; zl&alPhDgq~7OwmpPDLqEs3>Yi%k+XSj7-<`s>;w$?yNZwcXPh>lW&iNg!V1feQl5F zSLRKt?|B})=Vc8q-qd?0z|@xW1cXGyK;VL7HeyyAEEVPW{01E&&mqPkEA+*4mjnIh z6iqGK)!D7TVykp%^rt!KaaBrKZ|DoRuo!xM*jania&EBh>aGn@n%cJXeRULW3fc(^ zWWo~hBs) zn7l+tudbiE`8X(LBu1N^9!w1?mPzz}{y=-;O%s}7XnK`IQpKVefB{f@q`7GR{R<>~o_O{fA*LFihFXT*~e&v`K zf3Ja#L}TmbdFtIdpv_Wmr$~F~*>(8m*KYTm?o9XLz9K&to4Z7GfA=Ut!qsTwe|(|o zfqu-q)C=FQ`HocF{((jdfzxF*Jw;^Y#p715^k+%GEOl}x5ons)YxGeHd5b|X_CIEF z1%KkA0%;RmpvT_m%3$@d``WFcdwPziigHG3KK{wiyJ|57SFdphtx?M_3ZyfhJQz8_ z=614LN_-BWhS7yjTYD_#L=&C&xire*un66mjhelCsu0&n35LOpgq*HyrYx)5)29%- zNCWQgym>YA9)X_gDq{_kK(L#$o+0GdSJr1Dw%k?JTq>!d)m`td50@Covd_ag;u6h^ zaJ0wkTTD}=xl%cOL^fe)D13Y550RQM_eXsR1b5ALmuMf9 z%70Kp#7M%=-Z^NcnXF`9`c*JirK?9f1(|FPc?o#o7;O5(y2!2wn+I!&juA-3*PLHC| zH4RM3pirGm08oCG2LdtE51qXqIqX_DCv5H*XFHxj8$Luh`G5PS;nz`HZ!qZ#v9gMr z_bRBJiAC!G`_6}Oe^Ul~X^w2qbUeGH8cHd2@Jg^y#Rft&0%C0q-t(}} zmaCeO!h;V_&u!n*dsUYvVnXP5&^o60`KxSRoYY8Wlm@PyS-nl_&^u94gy#zwD1g}zU5YdOZ1ChRgII}~2QrTI9_?wTu+c5DUr z%GAkL?}1J$$DMxMD(m*|(aIx#&A;OHJP*FjxmWubk_LG&m~`k};@a$IS_|wtbtsP$ z#ya=LmHQ8uL6Ky`4_2Q(acil2n#MlvGsec&?yR@7khdoil;}vQQW1vCG zI4dh#bZIJualE6|w2&20QRQuvmN(#GQT3<>4VWQ;ORAHP9nnRl4sJi=){8i0q&M+& zE~UZsqay)bE6tm8pD{3jc6FkAHy@89gW=8cl}D?GMV$=|Pc4?RMAeFpenDu0wCvye zSV1&^=pU=9w#u(m2?>sk$H@zC14k&`YDpd>JBQNB6g512IqH~D%GpWsPd}g6G*6W$ zcDMra(c@<3%mty;gD7ldJfe&YY5hdG=6HB*zNd|P+O%Vb$!+6!!!kYp#UDjjJi-dd zLH6CorN!NLCUgJOl5>5gb@{8n%fR@!ohWw-|9!#r^>wAOtFaOqp z{c--V^VYvv&&DUxzp@eIxAogAu#f;s_p>H8+%2c)(1@I$b>%u7_BDAEC6JmnolL+2 ziKp^lK7bV_(0tXHfv~_mdDl3VHvOtas9AF{`LCOX7;$H=GhXClqmhWUOVa#nut~qW z@Xw2JN{JD2fphN`iz~S@%SvGAwbhI3@egXo*tjR#$DIy~oaMf2`TZ_*`N{swv3H4K zp?LYvR~s+M{@(o5MAOt7A9@rqFa6oyoG(BIq!rZV6F56R2O!t+z8@wv*Ynd%vL50{ShIARPk43VBXSdiQ z`jTn+BN*vnAN>-rN%UH@nNV&tET01TyTEoMMXKHYT`zrIND|Lm+zTNvy3I+J1i4}` zba>@0dH$f1@BBD>^C~Ki0$UCyz}yftRy|rCMbqr1zAKZWPDNT-oX>6d^!N6zTUFEM z_a$#$+8Z0&ZN$I#5t7@kTZ^Fdk31bur_pOG+s@e+F9WCb1XolhsZ#ON{7)0*%ycSJ zrLnrbArnO30j^~j@Z9IoTYH6Hw)wo!U1K|sDx&U#Z|=VnXOr@G+wpFPS83+a4~`Y+ zJ*-DlxP)kG4S*7P?l7sSL&_Q2TodQZ!;mRCKB;3B)oIORIDObbN!=oSAy$x(_dv*_ zWnz(^^G6~YF6Kkt;$V|*+qS4cj-$z>s{^2&nfLMS0e{&iIkRd-@H&ckm4lO7exw4u z)R(yyGzXloKiY7zP=6zs$~%~76j0=$V+-=mW)6l2SA#BG2S9Dp&-Zx5LO+I1d~|T( zemovaR4r1h8AbJvVfl;RwBha$YNmo<}woUUDtdM+sC5aXZAOLf=P0N z`~CYQ2tTsWw&AZ-i3!ecKd73N%ni^0d?`6)ur8xVl!0mH5}2^g9aYwrw#}W~$C+Np z=GQD0Jjp9FmoQN`z6Qi@AO8;)Kvuw9BvfGdAhHr+ty^nC~qzC_r7LOU_Ckle`_3H$-%`i*>{NGR0BtC)NkGkZ48MfUVYHCL%;ik{ zX6}cbMi^SzhczoPd>5@4gi%X@AlS&Rn26@JQ21#zPRSd*FZS9Xawj3d*>YM~Y;Y$- zOkQm74{cSK3#NcI-gqW)9N4!hZ5*ua|-0p}TW^DD0co)6Cjacs2qUVd|)!4nruUqs`> znWM zanxtHugjHV6=4{RI^Yt@^^JdhqI9h!Ivdh=1~6wB0bME580_%}YiQcIlpgC{oC zWJD=c5C0}(14KgwG$}$v1n2ENKv0>^8r);|2D-D7Mhoh1^^N55yE z^BtPkn+jfi7IodjW6{YpChFT6qsuzt#I3aw_{(`5WmcQgeFY>AqQO@P~g zubcr(o!RKTAgY__9ZtHQ{mS~8EF}H}>u=+FrUdKTC43Tq6<_Y>)vvi1&069&IVZ2t ziiG?>Zalv%vlcMI)`oQuh&~JsFq|)`u)#TADLmfo67{ zf3FbnF$B%T=yp{nCj5~4d)#n(wdV1=IDI;cglAEA(BfH%m43<@W8f-|ss=3X`>1Y(?ixJR|2&`>hY`EU838rq&3Ch#1WdflH3e?Q=+A*Cll zW3t?>DF5k&sE-WlqJrz#d`%C6LL9#>a*Dfs!T1%+t~gg#K0}x%HrA|-sa^gaM?NJ% zC@~f@n4D@3t9`70LE_T8@@hLD5m>il|IZz`lITymqaeDZ1YB3xodRy|f&jI80MBQT zo5|*9vllx>aG-UIv*O_Ajl^RE`OTX(Chz*{UcHJK7vJ@2Jo=vZACsDWU@^-4i8vi3 zFbe}VV_HX_KlZtTnEaO?<;(fibxY!6Yms}zR|>1ge@{If0!4$q@r9T^Wj%f;TPlF7<2^NbL%0?N8K%Z`8P`2A1ZYj1zqPCzTqdxp|HAJ4x`_bFHm!m-JWW3nL(CiPjbog-Y3>L=3RH%6kz6!dsghW z{TPCMq_eQ?Z_rfC1VyWd3MW!D&WmRkffxZ4lKc+Vd`-tg(q|Gu!X?SK0Rv|fQ=-5u_{yENgz+1`1B zM!IBkgkbia#Oh#}L)#ZJsgcq`fntZLqNY}&L}IaxcSv6zoMIAy=}m@QPAbz}mCvZf z_|~f*!~#c-54S(hx}ew2bZ+Dz=w^rq++Ya_OFd;SdS8ShTo)VrMarp7P+JwdWT5T! zx!CZq&yfPlO%an-ZnqACwBAnH51*f{KS!Xj_DtV-n-Y)!xgj{&M~@d5CD#-nzZ%jb z-=KwZ4QLKOqo4RM%Tz7^{DjjPe!MZ?Xtx+&=c9+UadTi!FCMwRckh#n&{RVPBb9d* zWaf?Z4_|XX_KeJ<=#uO`nN!ue4<%S>1_{ngUAK=ag+0w>UhB^i7+kOnzjfSaefoW2 zDZX_8mxTp-O;Eue^hX2QTIBlj{gH~5A?c*yBFRoOuunysofz+C)*Pbu%B5QRUuLey zsSZu+k)#$nkVtXj6Hml+X0(&Pa+Pz7(JTSR@oFV6EzcdB_`a*j@oP;a`f)ml0eF_m zYMI{_-n8w6hNJAfb#42PpW{a~PN`SD?T>AXg)HPc_1?_QkV^lk#PKlCSW(W)ts0vP zi1_eco0b0#y)KFcN>^LQfW-AusD?`5K^tuc75fs)hjXo!J*jsp34kKJQxq`+qW*R$+JpQ75R0bK~n z#s`Yz`9S3qSHQDDJob(6d(iv&*lg)P=bZ5_5embP)R#9wzRD%F+Ql5IMYa$hL{>}j z{E0B{j{>mmqS33>kCD@M#;D?y=KDZlz*=5FjDA6M|b{ zfZ*1~Id((b=4Y?vp7hGOl6}qmWq?+XK~X89!6U z;KgD1_bV9TiBX@gQ~C4GX#0bl^&Q3QaKE1`64>ZUHXIwiMScv8(1k-(IYcv(8FcJ0 zHTdkLJ;|K#>>#UBn+5+lo|XO(gk5#~3D8A~Bc_^9&{`~{RQ(7NF~?1`XKEtj+2}Xz z55x+76!W94i>}Yl&y{#8H7s7V#RmmF&RNVM@iRvZhx#B=%9PXeZ(p<+^2g*@z4i%P z^Wcd4T?Jk5;p*?qWzF-rinxRPrXsrhVlM{V2~X}R<5qI3V1zc) zu|>V1&$2n&-(?(9UBd&O02!OaMuu+#tzW! zm`}S?$Z|z#lck~XYu&Jf&`$e9qyJeY2b44Ep?&6|s?8<)wTG_-fpaaAwEu_2@%(Ka zf8#yStMl&m$hf0TOy-JghN0^v&12Ad+6PWTkq;;5!X?H<>Fva8*hqq6Kcy<2uW5y})almhHtjB|VcjP@(U znfsM1>GXg*v5v0hMV-Zq7|Pj@#lV_dy&2UAFc7;)(moxP1(x~7ORQ6I$##wMD})cx z8*yQ;6hNeU%)WmW5i39uxu(@{aMo34-JCJ{z>Vjqf-RaFl)rYRm=874`x7ivUmv-k zU2k$I_Mwa^KE~NQgTX6<)(@ahLHUM8ONZ&qbFI%yJ$lg46#f>HR-2}yL|OPtN&Xu? z-yA=8|a~isFIUhFnX>9B&ip=i<8XTc@`*M z?){zWRB-<_{&Hy4`};!Xq_f>@5>&mSA`AXf0*DF|Xv?8`e+$dNK{&-*VC*&Qq*cKz z2RnbwD(zRv5gh91{fLjS&d)Tvov*S8!pJIn-fE48`}%cg=lB^Q)`HAv6Dbx_87Y}! zYQLTEWgnw*8ORAT?NU{170M6qmLA z;gosKB0pilRO0W87Fiw2O`h@SiaN_FqEMN1;Qlk@e7a19azp^dBX|(;mULvA^ECsC z2=gL+G5$1P>=I7_mJf?qe)XT`SMA6h%B1h4_fCWuz!#KK=Vg==Y{o}@xrUk$PVLb* zHUUf4uFQolu#p%NxoV5P_1P1WQFk4)6ii?biAXZx2_fOLq zxJXRVOn>DQmGasWodHZ3TSmCVdHZVudi;ZoG8g91bk=-Y z6BGRYgQvBQ8eX@k=_1E^VA_M5h26rBkmbreb>C?7OtUC^^y|Z3_3)XGBfY`ibsSojO)Ru`k}2KfA*D0G^P~w22NLy<@0%M&acA zO=16TIPJInQ%m+rF7tEHATAFPEshOK+Pr_DA_W184F4~(s|>SLw#LZSon&UB*M^F9 zCw<`y?cG!El7PC>wcqh{xmq?&fWOC|=$voN7;cz4y6kXwI7v9YFDlR;SE-7^}XlM#gZl83Wj!m2itY8{aD_u%er2y?;Zrnhz1Of3iDq+trN)Vl2?s9EZJTwU5M8i-`2>m z_=MfXPLeyHgqg#xvcc<*ahvtM-n_YQJ(KwjnVImBZMv^-6@ok{+)k+`Vx7!|ryp^6 z+MQfxip>toRuUaJ(`O>MVSpW5ta`SrkqdJyXJ-%YHQaaaBS(az!asdIZEZ8Z3O4&* zF{cP)n<02Odbl{l@#3~-{d9!#t}!vf@^L3?=9zdsi2YZu>)7N}L2C2+>F|MyFfqTQ zvJ^s!H>s$wPpFCC5a4I0`ppujUb<$4t{YGK{B2iXRTY6a#*de{t%eJ>a$V$MY_W5J z+O~qiu$);bVxq1spjRuBSD7pZmY?L_7&)p-h0s`;(a%EoqQ^)W_d-Mibwd;0qG%eE z0w#NSJdYpZ9T{mDN2zag#%`T?K4_$&8@j6LC_Rsrj<=El84X69w)y4-aq+?#ITP?I zl?E0k89VS5{UGos1CtIRk29uSPn?HpJ)Z#=O$|hgo@c8x0M%36o#?;)F@Y zwaYeff0FxSz&Oi5JPh6!>O~+cRc!%tM$V)I1B6#HY2Oty%Uhgt2LAaITSxCGnlX}zBj7#$vT6r?%1_HvE622E+d~@;{Uqij6FRo&;MN&Hhy{8IYx*#eVlJI=v16tv<^=wi_K2sb)#o@Tf8NPQlnR%i3mcZ`@j~@CdT)~68!@Wv)m?S zH@!P5WZZ>CwJztJsnQ&KnSO2>^1guOew``J;n<=9(ZcJIh@S5P)^L0j#U5@zSWE z&!c^*K-q?atD$#V6SRiMDmc!iFlQ@0#NKt?N^aQ|>ho_0=%B^iEsg1K3=w;bFC-dl>x8Vak z;_;o*4Z}Az1sS-XoVhEh4u|1=emMISjhBzuGJMJn&cC8_!Xk;T4;dEkzEObPr9C&8 zF`P&;6n#1WXA*D#5%)(fD_$*UC-9z@cDMdl3~*bX_AL_(Pr8{8K3aX*&imQJSAQkR z_1M48AOU3d)SCOiCkqR1EYP0M5~rbdnc=qA2TgM%2gBXsFhmW)$Qs=3H@@O_ow8iPLtkpoDeRvO zRHLk!=`NNZGG~6rPFDluP;~Lx#I{PrYM^?mAQJH`jX)6Yr}{cBCA3E>lf^NxMsPL5 zigK17TE<=*c9PbtbAmgWFgdI-4b_!rJ-yX(=ilM^K9lT`SK>5x)M3DKU_00n93O@+r^&{XPS9BQTl>D(3rK*yafU7q_b8^zzp2zxOaPm6bZs`2g>h##$KO% zR6eP<1>E#RW1irFZgDG{kmfhOEMS=N%5CL$mD}~W0w(5ZQVkea6VQRWqPdcr#uA)G zU;X&b#mJ}nkyDFym%};P{{A}qb|nMLhvU)dCHj^DPZk-~u!-^nzGz^rr!=wGaxFfE zdj16S==|U=7$Qx48@TH0s1KJ~kljH5Y6_SB3@v6)-EFr`-g^Cu!tWvi$1)4crxCu? zc`GjWk(D>Hf|noudX_C`x^c;dT!7?5b@aQF;|0$46JDm2;aJdhIiI`Cv) z!#m9dbhIpPb|wJZI*kNyOXZq z`Z@xdS4GMokk5ySLksDQ&5K96@71;{YQXEPK4<$DB8b9dE(_ z%BHARJWe?~9q>8!Jx-f7#=040B2X{9qBhK%ISEFV%W)Jbt!kn`j7YW0W`tJ>O@BVp zbnTxtWa=8YHGJ$cn?YI|)ozgaeG_tTtlTik_N9I~VE&1(L{)D7LG5#xf_kcA!z%DE z=@&Y!4|iWKqft>T#)+D}4RD{=5J`?+hV}5)ejMZwub{xqN`L(o1*&=+`f;EbF!Cto z-*Qs1wmKV7t4k_`w;8w2Ufx%FU-XggJ{^&=UpcW_sUN)^`_Ip|+flqqMk6_d}$ya&tPgrF*TLNAh`r4HR5_I~-0NpXrgwB*$~g z@6XI}bVVrcG2}MX`z)As=tFDLj81=5k9>iAp4Vsgl5&E4ZhTs187?)1>O~@hc;99Ib>b!Z_oN82=o3d++Z{ zU_g5RJbI&V1YdeEKpz{fEXf_Ep?R{bh%j z?uiZd`35o&f}t5c@H0 zgr~fOY84ifjLHt$d3amW`~DV>Nw8z`M%$$evGV7Fzabn z>~lhRUL|h}B2dC_#rBaMcu%%E(f0HsKf@`CiKbhzt4jW$#kYWYRM%{em2HfgVMdxh zxV6!Ft@B09wx9{1-yKM zMT$K`-v1sDdFp|4{5iJ*|1Rw+3gQAqf4arl|zb z?TJ-p04biJa`{_a*`~}4{jV1AAFTI0el))iZV2^T4sXz zLZxGjpC1O!SYQ6IP!~SqK3DQ|KfkTc9-TveXR|lXPX*!W=x`iNd?*Odu^Es_K(G+eyq_vEUCrPw|M zB0OSQmhHw><~zzl@xP?NO*%XatzWLAnym7n=hMP1-D!#OJ@?d_94bA=%sO3_FJ~L3 zD79)_ecrTvPn1hMhmq%qGvzK&BT^HYu%YCRDwfPQ?ias*wv+4*ATfh*Rnxp$P zr*!G-Zh&x=FKUgD+pE`v}=Bb8e(#@X0 zJ8SJQ)wClZ<3l88MZZ_q_@A&GFPev1b`L57g-(j?OG!~MszOj1G{Qn#$nSeuCi;H0 zHisTArPbcr^bX1tf1GL2_!o!+6vzirARZ{HV?=s&DQ7y3_ILp95q*3lvg>eP0K^(o zSOIS^j}!*irh^r0!iMHKQJ!mSjK#SR5bb9u)VD@;W#O;*^yzicx_sfdSy7JmbSVlr z6ksv%QYt}S_~Qx1F7CA`A;C)tQoS#7-Qm4abCJ7N#RA_9DmF2ER@$&G9SP|l(HOr* zV9v5!CQ!I^hLr$kbB|_^u6orgSvC|8oz-NfDx4n%D(|3jz9<+bNpl5msE8aUQs$Q= zdbmroYhcBK{vg$|F1n!=Ho`_wiBf?SRC>&S4t8Pm{k}_WN7WYSJ2Y!uqB9Or`SQ@7 zU-6s#XX+ICjzwQb2x~5>ZnUAt+5W`9TKNaFB#&~c{GTMI_7bi9+brKIZv9k?qiH!| zIBe@zuUj`&}6{Pn;_L%Vt@hCdiT+axL5V4S{Gr$9%IF8 ztfhCwR+CNhgODzu)H@QkZz}e73)&oz{|&Pf^x@%7CD3G8@?7Pky9}Eb^XYiOLqWgt zEw5DtDF!HJu_k1LMbX$fBE7zpvpnZxWM-d+bwGY(#T(~zh2;+=wL6yq^1B`6dlQnL zrx^u_lh@DR!)z1KD-KtQ4%(8)*q`ku)a(#J;}^qFXennJR~i*OJhf#1ZgC@o6F$G@ zP9=@bqnRy3LCZrg;XFKv{^KsIOU?Ohom;qrP12?F&RRBe8rrvY(+3&E;IIjLIrWSw zbe|us=Szc6mJDxR6p_Pw;Nm>OpRh{BHbXbj8;=W_B~Bh)(zNddy284iXnWIMBbdOR zaWC>=wC$YOz2CWbF+Q^Tu0pF_v-aT}t8Sqa88`;y{oii{&?oJgzgE~I5n8AD2qRGG zjYdii6MZiby|n(Ezxfu%icrln?Or~ilSg)pxjW^D92(&#&%3v~%^Kf6@tmNk3|(?4 zty!!LY8O=WOMr>mB~eslz&^i4B>R1QFcwTBPrk_y62b^`y=a>pg(t%LQx+E)=x(*g zW@Mt-S=p5Y=CNF$A3;QKknm79l1fSzm4ydkMdM2enN zyod_(2OJhk;`Kf3{gMf@LZdD>Y;R4Bp5PX(I;(mvWK?R9B$7>znp#GSQQk^S28r;t zyeEn%&B1>a+|rw?B!X455dItU!3`bd)u;Xeei%Kx7uV^`-{5wIsXNK+<<>Ep4GH34HO9~>UHd{ zx@ZQ}GW6ImiG@gJEicXKRxjoc2>ondR=HGeSBLgWq*Pf?Z*wWp0jIk`xRVZ!TgcvQ9>HhGWUf}mx@fS0TJW{L%wBg zwo6@2mZdcgEbLng@VyuirL#II476XBObfT+!l5B zoHn}gILZ19`J-c#%9|Dfn=MGByg+0WSt~5D^TY2i57(;ATE9qh&VFF6usjrSx>Ra4 zJVc25);nn}?aq*hs-)rAu&(en-?kk`u!yl_2SK40g+Dw&2udUSkL!YB5w9n#Z?hOg~*Ydi_gkIyd*WkrH;AARql6j$J|j*0-Sl*D4g%uG2O7t z8lN6Xhihkz#AiO&FAeIpF)J;-sM$|(rnj(-cIc0-#Og}xi7#c&{lfFbI4~-_syB`W ziKwJ4O+ptCuWqUM$(^#71E9fc)VqGz6lqW18Z$HQI&DhZrHQkN2akiTH;r$0C%_zI zk$yGT4bLT5Zs{W%>el)*j_RK>N$gsrF7#_8Kn5mWgn>tQ(P2@W*37ZXTj-E^tJbPs zrZDg$7Wad<QCJ`hMe1OWPh#$z42dwuX1JXw&%@u(CaW$PrMJL4PbA z$7b!B$?}#Gp8_Z(Z$;3QSkP7q25HWmYdgT>>CLgPYCc9uv$;yKrv{ZIW{^GSbti4y zA7(>Ay2yxJ8gdZd@5$Ux6$uPG(PiZO@Kb>piNJ_Q2LnJoAC2|Rv&7p3k?VtM?`?fo z6#!35;GLPba}v#*%*EtH&bvo>kw=;2zRfN8ERUBVLcD#Z8o@U5q=hY;srs4YUR91m z9+c#tiIFa(4E|{*l#ARQ{#E&w@=%PazwvVid)C|C!JMXJNx!tiiLcB$6wmQZQ5jTE zY6kM1(|hL6=(fqau9rS$MfK>Cc`CNWkR20 z87Z6ZVZKs(ek!DfZeHUb4k@~?QLw{%&^GK0RS7W(CL|af(B<9O*X8sb`eQWTyX&~b zpJL*MHEC04P_LU?5L#oQnO63BiZ{|9mbgV>^Yl^~nfAU&rG+p(;@aWScx?BeadEoZ zImF_1c^~cjaGRWzud6lNr-^8HbS)a4e_)+FYE~4bK2a)Vtg?BzQ(rO$?Q=zDS-VWk zx+{Is7Ey9e830eEgO104FB7hPOpDddG>?AD!9531v|yk<(~glmwS&peg^PT;Mta2^ z8EYJIFXOyRMbQ%IBu}UFIh@0!>Z?g{hu=eK?ZZ24>K&|chL-sdn01vjkG8u6wxT7H z`}nx`=~6Lc_MAFUj@pIA=Z%xc-aUy;>U?^D76v)`KPl#M(qIhTz_n5Z9qs9ma8>lD zzVHxE*s#AbX5QvW70^KUiL!nf9EOs%O!3J7k(@uDey8JvGqKV_weZ;rs2xm z&TXE5`8?SyDU(PCv#uO{K3Guc#IYLfpJ>D*iZSOQThW;yt5Vr|uDR#ckeI~K;n;!&41s$SqhTwJm=uAwNU`uN^`jZD7D984VI~xlDNYDhF-< zReBrNGt+HKfl7R**1z>F7iq8BSw}41?KlQCBiwO;f6)k!?Ih7Q`=!%16I>t4kQ~}@ z_~TnQ>+0jIqrh4BbEoYopK46ee}HG&DPa^?_ok~;^n45u2X-1bb)Ws*Dx9MRQ2HHV z#jh`Dqz}ZT7rmn)s_#(BaaxUQ!{d;3dt1MDjSX(xyIs72aSL3-KWWSJIqKfJhQ-?w zkp_X2m%hh_H_9qFaU>!sWs9~TC|5XNXZ&f1*1758Uaau2JGqKf$l09rrGIEf?Pi2K z2q6sAch&5l)t2*=us+wo-ym;cDGu-vJUNXTw#AUt$w8L2YePT;byk15vo&w;k=^D~ z3Tb2HMFcPSZU$rDaFA@9&~GFHuuAEWl_WMTnd1tBATga!i? z300jCM!TGS&#y%r)BVl7&m3NK(P=`70ykJEx)#CFuJ^J(LX|yPl+xp2dX)^}4 z{O$+-dZt-eJ(G5$UoBrah3=o}!#gO3b{#vVys*Or5-MHV4rqJ+C=na`*Up7i+)%vu z?5cmYnsHRPa0+&}6_GE{E4-B0mz-_^CwMY>uz&3XP)>$1W7jtKmec#nSnp2E}C`xKk51_@-qMVY~=wVfj zFJ@#ph;dO_Z>_j`(m}Q*RTd4-#D2_AbpbzYp(%Z1Us%&Bq&b3%r7se~G!s5fdeVJ} zDOc*OG9rwVn8W#L-nLnIF173WE&4D?^`_NR-S=1B%i*rNwfl@C-l(^tlWELlq%6o_ z^jiY0_+EQ221jl(xslAnTi?LD-)Gxr%K0Y}3us;li(GuX+cO(HxBISO#X0c%ueWF6 z^(#LsU$$0aW`2asj;-3;wB~7YiPN-X)&uV6l?1wCnKuc3RJ^n>e{8VER&JEnyqSmW z--v;x^GM~Zv@f%~HfHzoHO`ux{O;5F)GiavUa%a~GRU92FOQdY)7lj$Kf~(je$lEt zdKD1+`lc1KSz+IH6;Sfv!X8>U$-L{ToD;_J5oR8WMfZhQ<;LUBumtAr%$uhUWPxGE zun<@T=4-Y0zfZkhTjd|`B<9m^myfHy+MauL2sf*yq<+Ud-&OD`KH(on= zpfF7}?;%6VXu->{LUS=2+z^j32TR1U$WOK_tAPH)=u_|Z<9aq_Omf4PPul&2^-)uZ zhrtvsBof`n$IC>oWo+vG7)R7-eYu%YV7?OZ1mnwM`eVBJWCzctidFl(l};Hx_LGWp z+x>vqaxOb(1d1opxayDW8}sDp8b#~wjw)PRqS)k9lSws3ZB7HJ-u55cR ztMJi-ns!=>{i0u9)JL>F`}k#Y|^%j?UT5 z_5*ySH|kw7KRWfrthd^c+j)TFC&9#i$LJS3?S$rY@7t?Vn0KZmsI4X)OXsF%3M0JR zCYwly(AV1Kx<4*)TokQ%(nB$tc*Dafax$(#m$gvWu*I1#gj;!`ega>W7tpxt@ zKb7guF~JfbRQwo>eO&LC3@9V5m3Z6N!+UY(3+&)yDe7is#V_(i)Jbej-V~;Uy)xQs z19GeA-(vlA(UTWPcclufs@7{+pw$#+iUd z+o|UJfp{R^0t^d%Cf-P8HW zVW%;a>I*C2#upzTI?8OLX%CgA;62?qSV+*y^%^NZ+xd(?nv<@<&ryK zb*_vejgLZ;R9aNL(r{@(*Dd9Iav>JHv{~$5DTzQz4kCB;6(W4&Tms+`T@N{_>A&gy zdyDq*r%>2-GpH<(uibuKgLsC^!c*v_pm5|dcQsf`e0Qrp^hs0;Y(CR}0;uvBY3)vTYXy4-^jgrOOqH~V0(EvAz$+xdLGxgG$HgXAh-lf_cY z{n#~s9poACHfE0ChgqbS5ssx=s#js-RHa}sSq!aM|0_JvHPW+O@M@;P{0QXP?0TjvzTg`Gc?{~ zNf$@D`!2-;Ac-c`{dCxR11hk-fME1{-(7cRNv{z9lmlu%Cm$p%-$M*TJb=eik^?|= z091;YjbNw*q^oWfp0L;lj1ost`&##NvJ|F%BGPM^WK`2Mk8VKnCmEu>|Hly7@Oja&-%5ZG z91y|}GI4%RomD1vOEe1PHY`bY(r|MVV1IQ)} zJJ(HIDK!y-6`YJl7VYwd5!9ndcwopuznBAh$PqE`4nF{-U#i9YASL)AEkh*w#j~DZWq$0xC#V%jofPicULQx8!nmD+f$c`{auUs|3>#V&F zg=jH8z}svOL{I@8`Vb^_GLvRq zIDIGRv$0^P8T7ioRhYheG_e>KE>}>199+x>_vY*ARjWov&uXW{Gny0~Iw)I0C?X5? z!lhJ|JQ>Jw=3URs_v@Ho_|SMVKNe&uc?c3b%tr)e;4MnAqa0W!c>(28Ew-Qy#W)0z>4Um8J`jp$@rBk6SSw>pf|7xYh_g(=|5Q8-?*2@Nv}~SX2F-A_5WCYC4#n+9esqxiHyBv~ z5UhX?2Y6O`JXxAOHPZ7fqtb8wn%Ks9;WQZe{bJZC5HZK!Ye29Wl39RWA_V9qd{z@; z8$gNna-~`l%or;QLIkNl`>_4Jr@(vPuqv;1!^bPW;nJf_<+05ARrUo(0+p8@w-eWZ zDA4fJhS`V5*4zKCpm~ z6wsSRj@)6d|3yj%A}x}Epx^)A6hU4RcM(#v9X{@xS>^AV94CTr@1 z5&vH#XCRVkBxoMxUlS>SCMvfOiv5c;AqPY{K?6PfYhn>O&_t=mZqt8}7XL>2e-Hcr gM)v=A8sB=;Qu!T+x*7v@5)epIR8FKqNYC&81MmA$w*UYD diff --git a/src/legacy/core_plugins/vis_type_vega/public/data_model/__tests__/vega_parser.js b/src/legacy/core_plugins/vis_type_vega/public/data_model/__tests__/vega_parser.js index de2d913221451..c442f8f17884a 100644 --- a/src/legacy/core_plugins/vis_type_vega/public/data_model/__tests__/vega_parser.js +++ b/src/legacy/core_plugins/vis_type_vega/public/data_model/__tests__/vega_parser.js @@ -53,7 +53,7 @@ describe(`VegaParser._setDefaultColors`, () => { test({}, true, { config: { range: { category: { scheme: 'elastic' } }, - mark: { color: '#00B3A4' }, + mark: { color: '#5BBAA0' }, }, }) ); @@ -63,15 +63,15 @@ describe(`VegaParser._setDefaultColors`, () => { test({}, false, { config: { range: { category: { scheme: 'elastic' } }, - arc: { fill: '#00B3A4' }, - area: { fill: '#00B3A4' }, - line: { stroke: '#00B3A4' }, - path: { stroke: '#00B3A4' }, - rect: { fill: '#00B3A4' }, - rule: { stroke: '#00B3A4' }, - shape: { stroke: '#00B3A4' }, - symbol: { fill: '#00B3A4' }, - trail: { fill: '#00B3A4' }, + arc: { fill: '#5BBAA0' }, + area: { fill: '#5BBAA0' }, + line: { stroke: '#5BBAA0' }, + path: { stroke: '#5BBAA0' }, + rect: { fill: '#5BBAA0' }, + rule: { stroke: '#5BBAA0' }, + shape: { stroke: '#5BBAA0' }, + symbol: { fill: '#5BBAA0' }, + trail: { fill: '#5BBAA0' }, }, }) ); diff --git a/src/legacy/ui/public/field_editor/components/field_format_editor/editors/bytes/__snapshots__/bytes.test.js.snap b/src/legacy/ui/public/field_editor/components/field_format_editor/editors/bytes/__snapshots__/bytes.test.js.snap index 463c1bfb975f5..1f77660c9784c 100644 --- a/src/legacy/ui/public/field_editor/components/field_format_editor/editors/bytes/__snapshots__/bytes.test.js.snap +++ b/src/legacy/ui/public/field_editor/components/field_format_editor/editors/bytes/__snapshots__/bytes.test.js.snap @@ -44,10 +44,7 @@ exports[`BytesFormatEditor should render normally 1`] = ` labelType="label" > diff --git a/src/legacy/ui/public/field_editor/components/field_format_editor/editors/color/__snapshots__/color.test.js.snap b/src/legacy/ui/public/field_editor/components/field_format_editor/editors/color/__snapshots__/color.test.js.snap index d7026df761d94..7e49e93e4cc4f 100644 --- a/src/legacy/ui/public/field_editor/components/field_format_editor/editors/color/__snapshots__/color.test.js.snap +++ b/src/legacy/ui/public/field_editor/components/field_format_editor/editors/color/__snapshots__/color.test.js.snap @@ -75,6 +75,7 @@ exports[`ColorFormatEditor should render multiple colors 1`] = ` } noItemsMessage="No items found" responsive={true} + tableLayout="fixed" /> diff --git a/src/legacy/ui/public/field_editor/components/field_format_editor/editors/date_nanos/__snapshots__/date_nanos.test.js.snap b/src/legacy/ui/public/field_editor/components/field_format_editor/editors/date_nanos/__snapshots__/date_nanos.test.js.snap index 04d59640554fd..cb570144fcee3 100644 --- a/src/legacy/ui/public/field_editor/components/field_format_editor/editors/date_nanos/__snapshots__/date_nanos.test.js.snap +++ b/src/legacy/ui/public/field_editor/components/field_format_editor/editors/date_nanos/__snapshots__/date_nanos.test.js.snap @@ -44,11 +44,8 @@ exports[`DateFormatEditor should render normally 1`] = ` labelType="label" > diff --git a/src/legacy/ui/public/field_editor/components/field_format_editor/editors/duration/__snapshots__/duration.test.js.snap b/src/legacy/ui/public/field_editor/components/field_format_editor/editors/duration/__snapshots__/duration.test.js.snap index 9722a01986434..ef11d70926ad7 100644 --- a/src/legacy/ui/public/field_editor/components/field_format_editor/editors/duration/__snapshots__/duration.test.js.snap +++ b/src/legacy/ui/public/field_editor/components/field_format_editor/editors/duration/__snapshots__/duration.test.js.snap @@ -20,11 +20,7 @@ exports[`DurationFormatEditor should render human readable output normally 1`] = labelType="label" > diff --git a/src/legacy/ui/public/field_editor/components/field_format_editor/editors/percent/__snapshots__/percent.test.js.snap b/src/legacy/ui/public/field_editor/components/field_format_editor/editors/percent/__snapshots__/percent.test.js.snap index fea665a918f06..30d1de270522e 100644 --- a/src/legacy/ui/public/field_editor/components/field_format_editor/editors/percent/__snapshots__/percent.test.js.snap +++ b/src/legacy/ui/public/field_editor/components/field_format_editor/editors/percent/__snapshots__/percent.test.js.snap @@ -44,10 +44,7 @@ exports[`PercentFormatEditor should render normally 1`] = ` labelType="label" > diff --git a/src/legacy/ui/public/field_editor/components/field_format_editor/editors/static_lookup/__snapshots__/static_lookup.test.js.snap b/src/legacy/ui/public/field_editor/components/field_format_editor/editors/static_lookup/__snapshots__/static_lookup.test.js.snap index 2891b99bba30c..2bfb0bbd15013 100644 --- a/src/legacy/ui/public/field_editor/components/field_format_editor/editors/static_lookup/__snapshots__/static_lookup.test.js.snap +++ b/src/legacy/ui/public/field_editor/components/field_format_editor/editors/static_lookup/__snapshots__/static_lookup.test.js.snap @@ -59,6 +59,7 @@ exports[`StaticLookupFormatEditor should render multiple lookup entries and unkn "maxWidth": "400px", } } + tableLayout="fixed" /> diff --git a/src/legacy/ui/public/field_editor/components/field_format_editor/editors/url/__snapshots__/url.test.js.snap b/src/legacy/ui/public/field_editor/components/field_format_editor/editors/url/__snapshots__/url.test.js.snap index 4b246fecb8146..c727f54874db4 100644 --- a/src/legacy/ui/public/field_editor/components/field_format_editor/editors/url/__snapshots__/url.test.js.snap +++ b/src/legacy/ui/public/field_editor/components/field_format_editor/editors/url/__snapshots__/url.test.js.snap @@ -26,11 +26,7 @@ exports[`UrlFormatEditor should render label template help 1`] = ` labelType="label" > @@ -116,10 +109,7 @@ exports[`UrlFormatEditor should render label template help 1`] = ` labelType="label" > @@ -157,11 +147,7 @@ exports[`UrlFormatEditor should render normally 1`] = ` labelType="label" > @@ -247,10 +230,7 @@ exports[`UrlFormatEditor should render normally 1`] = ` labelType="label" > @@ -288,11 +268,7 @@ exports[`UrlFormatEditor should render url template help 1`] = ` labelType="label" > @@ -378,10 +351,7 @@ exports[`UrlFormatEditor should render url template help 1`] = ` labelType="label" > @@ -419,11 +389,7 @@ exports[`UrlFormatEditor should render width and height fields if image 1`] = ` labelType="label" > @@ -510,10 +473,7 @@ exports[`UrlFormatEditor should render width and height fields if image 1`] = ` labelType="label" > diff --git a/src/legacy/ui/public/field_editor/components/field_format_editor/editors/url/__snapshots__/url_template_flyout.test.js.snap b/src/legacy/ui/public/field_editor/components/field_format_editor/editors/url/__snapshots__/url_template_flyout.test.js.snap index 39189caeedb32..849e307f7b527 100644 --- a/src/legacy/ui/public/field_editor/components/field_format_editor/editors/url/__snapshots__/url_template_flyout.test.js.snap +++ b/src/legacy/ui/public/field_editor/components/field_format_editor/editors/url/__snapshots__/url_template_flyout.test.js.snap @@ -110,6 +110,7 @@ exports[`UrlTemplateFlyout should render normally 1`] = ` } noItemsMessage="No items found" responsive={true} + tableLayout="fixed" /> diff --git a/src/legacy/ui/public/field_editor/components/field_format_editor/samples/__snapshots__/samples.test.js.snap b/src/legacy/ui/public/field_editor/components/field_format_editor/samples/__snapshots__/samples.test.js.snap index 25cbbb7c8684b..73a7c1141c601 100644 --- a/src/legacy/ui/public/field_editor/components/field_format_editor/samples/__snapshots__/samples.test.js.snap +++ b/src/legacy/ui/public/field_editor/components/field_format_editor/samples/__snapshots__/samples.test.js.snap @@ -54,6 +54,7 @@ exports[`FormatEditorSamples should render normally 1`] = ` } noItemsMessage="No items found" responsive={true} + tableLayout="fixed" /> `; diff --git a/src/legacy/ui/public/field_editor/field_editor.test.js b/src/legacy/ui/public/field_editor/field_editor.test.js index f811ad9162728..cf61b6140f42c 100644 --- a/src/legacy/ui/public/field_editor/field_editor.test.js +++ b/src/legacy/ui/public/field_editor/field_editor.test.js @@ -50,9 +50,7 @@ jest.mock('@elastic/eui', () => ({ EuiText: 'eui-text', EuiTextArea: 'eui-textArea', htmlIdGenerator: () => 42, - palettes: { - euiPaletteColorBlind: { colors: ['red'] }, - }, + euiPaletteColorBlind: () => ['red'], })); jest.mock('ui/scripting_languages', () => ({ diff --git a/src/legacy/ui/public/vis/editors/default/controls/__snapshots__/metric_agg.test.tsx.snap b/src/legacy/ui/public/vis/editors/default/controls/__snapshots__/metric_agg.test.tsx.snap index a176295260c44..b51c25952580a 100644 --- a/src/legacy/ui/public/vis/editors/default/controls/__snapshots__/metric_agg.test.tsx.snap +++ b/src/legacy/ui/public/vis/editors/default/controls/__snapshots__/metric_agg.test.tsx.snap @@ -16,9 +16,7 @@ exports[`MetricAggParamEditor should be rendered with default set of props 1`] = compressed={true} data-test-subj="visEditorSubAggMetric1" fullWidth={true} - hasNoInitialSelection={false} isInvalid={false} - isLoading={false} onChange={[Function]} options={ Array [ diff --git a/src/legacy/ui/public/vis/editors/default/controls/__snapshots__/top_aggregate.test.tsx.snap b/src/legacy/ui/public/vis/editors/default/controls/__snapshots__/top_aggregate.test.tsx.snap index 74c952dbf059f..b3a2c058de976 100644 --- a/src/legacy/ui/public/vis/editors/default/controls/__snapshots__/top_aggregate.test.tsx.snap +++ b/src/legacy/ui/public/vis/editors/default/controls/__snapshots__/top_aggregate.test.tsx.snap @@ -31,9 +31,7 @@ exports[`TopAggregateParamEditor should init with the default set of props 1`] = data-test-subj="visDefaultEditorAggregateWith" disabled={false} fullWidth={true} - hasNoInitialSelection={false} isInvalid={false} - isLoading={false} onBlur={[MockFunction]} onChange={[Function]} options={ diff --git a/src/legacy/ui/public/vislib/visualizations/point_series/_point_series.js b/src/legacy/ui/public/vislib/visualizations/point_series/_point_series.js index b9f50b6d941e6..b882048a6b269 100644 --- a/src/legacy/ui/public/vislib/visualizations/point_series/_point_series.js +++ b/src/legacy/ui/public/vislib/visualizations/point_series/_point_series.js @@ -18,14 +18,14 @@ */ import _ from 'lodash'; -import { palettes } from '@elastic/eui/lib/services'; +import { euiPaletteColorBlind } from '@elastic/eui/lib/services'; const thresholdLineDefaults = { show: false, value: 10, width: 1, style: 'full', - color: palettes.euiPaletteColorBlind.colors[9], + color: euiPaletteColorBlind()[9], }; export class PointSeries { diff --git a/src/plugins/data/public/ui/query_string_input/__snapshots__/query_string_input.test.tsx.snap b/src/plugins/data/public/ui/query_string_input/__snapshots__/query_string_input.test.tsx.snap index 15e74e98920e2..4c8edd85eb559 100644 --- a/src/plugins/data/public/ui/query_string_input/__snapshots__/query_string_input.test.tsx.snap +++ b/src/plugins/data/public/ui/query_string_input/__snapshots__/query_string_input.test.tsx.snap @@ -1076,11 +1076,9 @@ exports[`QueryStringInput Should disable autoFocus on EuiFieldText when disableA aria-label="Start typing to search and filter the test page" autoComplete="off" autoFocus={false} - compressed={false} data-test-subj="queryInput" fullWidth={true} inputRef={[Function]} - isLoading={false} onChange={[Function]} onClick={[Function]} onKeyDown={[Function]} @@ -1098,9 +1096,7 @@ exports[`QueryStringInput Should disable autoFocus on EuiFieldText when disableA onSelectLanguage={[Function]} /> } - compressed={false} fullWidth={true} - isLoading={false} >
- +
} - compressed={false} fullWidth={true} - isLoading={false} >
- +
} - compressed={false} fullWidth={true} - isLoading={false} >
- +
; intl: InjectedIntl; isLoading?: boolean; - prepend?: React.ReactNode; + prepend?: React.ComponentProps['prepend']; showQueryInput?: boolean; showDatePicker?: boolean; dateRangeFrom?: string; diff --git a/src/plugins/data/public/ui/query_string_input/query_string_input.tsx b/src/plugins/data/public/ui/query_string_input/query_string_input.tsx index 16b22a164f2f0..960a843f98ab9 100644 --- a/src/plugins/data/public/ui/query_string_input/query_string_input.tsx +++ b/src/plugins/data/public/ui/query_string_input/query_string_input.tsx @@ -58,7 +58,7 @@ interface Props { query: Query; disableAutoFocus?: boolean; screenTitle?: string; - prepend?: React.ReactNode; + prepend?: React.ComponentProps['prepend']; persistedLog?: PersistedLog; bubbleSubmitEvent?: boolean; placeholder?: string; diff --git a/src/plugins/kibana_react/public/field_icon/__snapshots__/field_icon.test.tsx.snap b/src/plugins/kibana_react/public/field_icon/__snapshots__/field_icon.test.tsx.snap index 5abce10c5be61..fb56bf0e4255e 100644 --- a/src/plugins/kibana_react/public/field_icon/__snapshots__/field_icon.test.tsx.snap +++ b/src/plugins/kibana_react/public/field_icon/__snapshots__/field_icon.test.tsx.snap @@ -11,7 +11,7 @@ exports[`FieldIcon renders a blackwhite icon for a string 1`] = ` exports[`FieldIcon renders a colored icon for a number 1`] = ` @@ -20,7 +20,7 @@ exports[`FieldIcon renders a colored icon for a number 1`] = ` exports[`FieldIcon renders an icon for an unknown type 1`] = ` @@ -30,7 +30,7 @@ exports[`FieldIcon renders with className if provided 1`] = ` diff --git a/src/plugins/kibana_react/public/field_icon/field_icon.tsx b/src/plugins/kibana_react/public/field_icon/field_icon.tsx index f9bdf3a25adaa..0c5d2b0c24831 100644 --- a/src/plugins/kibana_react/public/field_icon/field_icon.tsx +++ b/src/plugins/kibana_react/public/field_icon/field_icon.tsx @@ -17,7 +17,7 @@ * under the License. */ import React from 'react'; -import { palettes, EuiIcon } from '@elastic/eui'; +import { euiPaletteColorBlind, EuiIcon } from '@elastic/eui'; import { IconSize } from '@elastic/eui/src/components/icon/icon'; interface IconMapEntry { @@ -43,7 +43,7 @@ interface FieldIconProps { className?: string; } -const { colors } = palettes.euiPaletteColorBlind; +const colors = euiPaletteColorBlind(); // defaultIcon => a unknown datatype const defaultIcon = { icon: 'questionInCircle', color: colors[0] }; diff --git a/src/plugins/kibana_react/public/saved_objects/__snapshots__/saved_object_save_modal.test.tsx.snap b/src/plugins/kibana_react/public/saved_objects/__snapshots__/saved_object_save_modal.test.tsx.snap index 978705a3ad096..18f84f41d5d99 100644 --- a/src/plugins/kibana_react/public/saved_objects/__snapshots__/saved_object_save_modal.test.tsx.snap +++ b/src/plugins/kibana_react/public/saved_objects/__snapshots__/saved_object_save_modal.test.tsx.snap @@ -43,11 +43,9 @@ exports[`SavedObjectSaveModal should render matching snapshot 1`] = ` > diff --git a/test/functional/page_objects/visualize_chart_page.ts b/test/functional/page_objects/visualize_chart_page.ts index 138e5758ede7c..0f14489a39dbc 100644 --- a/test/functional/page_objects/visualize_chart_page.ts +++ b/test/functional/page_objects/visualize_chart_page.ts @@ -204,8 +204,7 @@ export function VisualizeChartPageProvider({ getService, getPageObjects }: FtrPr public async filterLegend(name: string) { await this.toggleLegend(); await testSubjects.click(`legend-${name}`); - const filters = await testSubjects.find(`legend-${name}-filters`); - const [filterIn] = await filters.findAllByCssSelector(`input`); + const filterIn = await testSubjects.find(`legend-${name}-filterIn`); await filterIn.click(); await this.waitForVisualizationRenderingStabilized(); } diff --git a/test/functional/page_objects/visualize_editor_page.ts b/test/functional/page_objects/visualize_editor_page.ts index 7e512975356f3..30e13d551fa28 100644 --- a/test/functional/page_objects/visualize_editor_page.ts +++ b/test/functional/page_objects/visualize_editor_page.ts @@ -97,8 +97,9 @@ export function VisualizeEditorPageProvider({ getService, getPageObjects }: FtrP } public async clickSplitDirection(direction: string) { - const control = await testSubjects.find('visEditorSplitBy'); - const radioBtn = await control.findByCssSelector(`[title="${direction}"]`); + const radioBtn = await find.byCssSelector( + `[data-test-subj="visEditorSplitBy"][title="${direction}"]` + ); await radioBtn.click(); } diff --git a/test/interpreter_functional/plugins/kbn_tp_run_pipeline/package.json b/test/interpreter_functional/plugins/kbn_tp_run_pipeline/package.json index 02c507dbb3ed8..1eac93c8538e4 100644 --- a/test/interpreter_functional/plugins/kbn_tp_run_pipeline/package.json +++ b/test/interpreter_functional/plugins/kbn_tp_run_pipeline/package.json @@ -7,7 +7,7 @@ }, "license": "Apache-2.0", "dependencies": { - "@elastic/eui": "17.3.1", + "@elastic/eui": "18.0.0", "react": "^16.12.0", "react-dom": "^16.12.0" } diff --git a/test/plugin_functional/plugins/kbn_tp_custom_visualizations/package.json b/test/plugin_functional/plugins/kbn_tp_custom_visualizations/package.json index 67ad28c083dbc..1bfb1e8ba4bca 100644 --- a/test/plugin_functional/plugins/kbn_tp_custom_visualizations/package.json +++ b/test/plugin_functional/plugins/kbn_tp_custom_visualizations/package.json @@ -7,7 +7,7 @@ }, "license": "Apache-2.0", "dependencies": { - "@elastic/eui": "17.3.1", + "@elastic/eui": "18.0.0", "react": "^16.12.0" } } diff --git a/test/plugin_functional/plugins/kbn_tp_embeddable_explorer/package.json b/test/plugin_functional/plugins/kbn_tp_embeddable_explorer/package.json index b22a1ff2d4176..6d6b04fba889c 100644 --- a/test/plugin_functional/plugins/kbn_tp_embeddable_explorer/package.json +++ b/test/plugin_functional/plugins/kbn_tp_embeddable_explorer/package.json @@ -8,7 +8,7 @@ }, "license": "Apache-2.0", "dependencies": { - "@elastic/eui": "17.3.1", + "@elastic/eui": "18.0.0", "react": "^16.12.0" }, "scripts": { diff --git a/test/plugin_functional/plugins/kbn_tp_sample_panel_action/package.json b/test/plugin_functional/plugins/kbn_tp_sample_panel_action/package.json index 8c91826d7b450..964adacb2ac09 100644 --- a/test/plugin_functional/plugins/kbn_tp_sample_panel_action/package.json +++ b/test/plugin_functional/plugins/kbn_tp_sample_panel_action/package.json @@ -8,7 +8,7 @@ }, "license": "Apache-2.0", "dependencies": { - "@elastic/eui": "17.3.1", + "@elastic/eui": "18.0.0", "react": "^16.12.0" }, "scripts": { diff --git a/x-pack/legacy/plugins/apm/public/components/app/TransactionDetails/WaterfallWithSummmary/WaterfallContainer/Waterfall/waterfall_helpers/__snapshots__/waterfall_helpers.test.ts.snap b/x-pack/legacy/plugins/apm/public/components/app/TransactionDetails/WaterfallWithSummmary/WaterfallContainer/Waterfall/waterfall_helpers/__snapshots__/waterfall_helpers.test.ts.snap index ece396bc4cfc4..c95855c117047 100644 --- a/x-pack/legacy/plugins/apm/public/components/app/TransactionDetails/WaterfallWithSummmary/WaterfallContainer/Waterfall/waterfall_helpers/__snapshots__/waterfall_helpers.test.ts.snap +++ b/x-pack/legacy/plugins/apm/public/components/app/TransactionDetails/WaterfallWithSummmary/WaterfallContainer/Waterfall/waterfall_helpers/__snapshots__/waterfall_helpers.test.ts.snap @@ -808,8 +808,8 @@ Object { }, }, "serviceColors": Object { - "opbeans-node": "#3185fc", - "opbeans-ruby": "#00b3a4", + "opbeans-node": "#6092c0", + "opbeans-ruby": "#5bbaa0", }, } `; @@ -1212,7 +1212,7 @@ Object { }, }, "serviceColors": Object { - "opbeans-ruby": "#3185fc", + "opbeans-ruby": "#6092c0", }, } `; diff --git a/x-pack/legacy/plugins/apm/public/components/shared/ManagedTable/__test__/__snapshots__/ManagedTable.test.js.snap b/x-pack/legacy/plugins/apm/public/components/shared/ManagedTable/__test__/__snapshots__/ManagedTable.test.js.snap index 59679bfe11641..655fc5a25b9ef 100644 --- a/x-pack/legacy/plugins/apm/public/components/shared/ManagedTable/__test__/__snapshots__/ManagedTable.test.js.snap +++ b/x-pack/legacy/plugins/apm/public/components/shared/ManagedTable/__test__/__snapshots__/ManagedTable.test.js.snap @@ -52,6 +52,7 @@ exports[`ManagedTable component should render a page-full of items, with default }, } } + tableLayout="fixed" /> `; @@ -99,5 +100,6 @@ exports[`ManagedTable component should render when specifying initial values 1`] }, } } + tableLayout="fixed" /> `; diff --git a/x-pack/legacy/plugins/apm/public/components/shared/SelectWithPlaceholder/index.tsx b/x-pack/legacy/plugins/apm/public/components/shared/SelectWithPlaceholder/index.tsx index 25f8128b27211..a8e6bc0a648af 100644 --- a/x-pack/legacy/plugins/apm/public/components/shared/SelectWithPlaceholder/index.tsx +++ b/x-pack/legacy/plugins/apm/public/components/shared/SelectWithPlaceholder/index.tsx @@ -20,7 +20,7 @@ export const SelectWithPlaceholder: typeof EuiSelect = props => ( {...props} options={[ { text: props.placeholder, value: NO_SELECTION }, - ...props.options + ...(props.options || []) ]} value={isEmpty(props.value) ? NO_SELECTION : props.value} onChange={e => { diff --git a/x-pack/legacy/plugins/apm/public/components/shared/charts/CustomPlot/test/__snapshots__/CustomPlot.test.js.snap b/x-pack/legacy/plugins/apm/public/components/shared/charts/CustomPlot/test/__snapshots__/CustomPlot.test.js.snap index 557751a0f0226..1bf125c301644 100644 --- a/x-pack/legacy/plugins/apm/public/components/shared/charts/CustomPlot/test/__snapshots__/CustomPlot.test.js.snap +++ b/x-pack/legacy/plugins/apm/public/components/shared/charts/CustomPlot/test/__snapshots__/CustomPlot.test.js.snap @@ -3,7 +3,7 @@ exports[`when response has data Initially should have 3 legends 1`] = ` Array [ Object { - "color": "#3185fc", + "color": "#6092c0", "disabled": undefined, "onClick": [Function], "text": @@ -14,7 +14,7 @@ Array [ , }, Object { - "color": "#e6c220", + "color": "#fae181", "disabled": undefined, "onClick": [Function], "text": @@ -22,7 +22,7 @@ Array [ , }, Object { - "color": "#f98510", + "color": "#f19f58", "disabled": undefined, "onClick": [Function], "text": @@ -442,7 +442,7 @@ Array [ style={ Object { "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeDasharray": undefined, "strokeWidth": undefined, } @@ -463,9 +463,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -480,9 +480,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -497,9 +497,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -514,9 +514,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -531,9 +531,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -548,9 +548,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -565,9 +565,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -582,9 +582,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -599,9 +599,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -616,9 +616,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -633,9 +633,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -650,9 +650,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -667,9 +667,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -684,9 +684,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -701,9 +701,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -718,9 +718,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -735,9 +735,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -752,9 +752,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -769,9 +769,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -786,9 +786,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -803,9 +803,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -820,9 +820,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -837,9 +837,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -854,9 +854,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -871,9 +871,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -888,9 +888,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -905,9 +905,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -922,9 +922,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -939,9 +939,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -956,9 +956,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -973,9 +973,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -995,7 +995,7 @@ Array [ style={ Object { "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeDasharray": undefined, "strokeWidth": undefined, } @@ -1016,9 +1016,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1033,9 +1033,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1050,9 +1050,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1067,9 +1067,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1084,9 +1084,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1101,9 +1101,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1118,9 +1118,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1135,9 +1135,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1152,9 +1152,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1169,9 +1169,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1186,9 +1186,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1203,9 +1203,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1220,9 +1220,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1237,9 +1237,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1254,9 +1254,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1271,9 +1271,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1288,9 +1288,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1305,9 +1305,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1322,9 +1322,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1339,9 +1339,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1356,9 +1356,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1373,9 +1373,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1390,9 +1390,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1407,9 +1407,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1424,9 +1424,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1441,9 +1441,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1458,9 +1458,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1475,9 +1475,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1492,9 +1492,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1509,9 +1509,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1526,9 +1526,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -1548,7 +1548,7 @@ Array [ style={ Object { "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeDasharray": undefined, "strokeWidth": undefined, } @@ -1569,9 +1569,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1586,9 +1586,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1603,9 +1603,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1620,9 +1620,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1637,9 +1637,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1654,9 +1654,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1671,9 +1671,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1688,9 +1688,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1705,9 +1705,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1722,9 +1722,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1739,9 +1739,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1756,9 +1756,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1773,9 +1773,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1790,9 +1790,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1807,9 +1807,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1824,9 +1824,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1841,9 +1841,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1858,9 +1858,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1875,9 +1875,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1892,9 +1892,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1909,9 +1909,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1926,9 +1926,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1943,9 +1943,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1960,9 +1960,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1977,9 +1977,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -1994,9 +1994,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -2011,9 +2011,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -2028,9 +2028,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -2045,9 +2045,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -2062,9 +2062,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -2079,9 +2079,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -2651,7 +2651,7 @@ Array [ width: 11px; height: 11px; margin-right: 5.5px; - background: #3185fc; + background: #6092c0; border-radius: 100%; } @@ -2659,7 +2659,7 @@ Array [ width: 11px; height: 11px; margin-right: 5.5px; - background: #e6c220; + background: #fae181; border-radius: 100%; } @@ -2667,7 +2667,7 @@ Array [ width: 11px; height: 11px; margin-right: 5.5px; - background: #f98510; + background: #f19f58; border-radius: 100%; } @@ -2723,14 +2723,14 @@ Array [ onClick={[Function]} > @@ -2764,14 +2764,14 @@ Array [ onClick={[Function]} > @@ -2798,14 +2798,14 @@ Array [ onClick={[Function]} > @@ -2849,17 +2849,17 @@ exports[`when response has data when dragging without releasing should display S exports[`when response has data when setting hoverX should display tooltip 1`] = ` Array [ Object { - "color": "#3185fc", + "color": "#6092c0", "text": "Avg.", "value": 438704.4, }, Object { - "color": "#e6c220", + "color": "#fae181", "text": "95th", "value": 1557383.999999999, }, Object { - "color": "#f98510", + "color": "#f19f58", "text": "99th", "value": 1820377.1200000006, }, @@ -2891,7 +2891,7 @@ Array [ width: 8px; height: 8px; margin-right: 4px; - background: #3185fc; + background: #6092c0; border-radius: 100%; } @@ -2899,7 +2899,7 @@ Array [ width: 8px; height: 8px; margin-right: 4px; - background: #e6c220; + background: #fae181; border-radius: 100%; } @@ -2907,7 +2907,7 @@ Array [ width: 8px; height: 8px; margin-right: 4px; - background: #f98510; + background: #f19f58; border-radius: 100%; } @@ -3378,7 +3378,7 @@ Array [ style={ Object { "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeDasharray": undefined, "strokeWidth": undefined, } @@ -3399,9 +3399,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3416,9 +3416,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3433,9 +3433,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3450,9 +3450,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3467,9 +3467,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3484,9 +3484,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3501,9 +3501,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3518,9 +3518,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3535,9 +3535,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3552,9 +3552,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3569,9 +3569,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3586,9 +3586,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3603,9 +3603,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3620,9 +3620,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3637,9 +3637,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3654,9 +3654,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3671,9 +3671,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3688,9 +3688,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3705,9 +3705,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3722,9 +3722,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3739,9 +3739,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3756,9 +3756,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3773,9 +3773,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3790,9 +3790,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3807,9 +3807,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3824,9 +3824,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3841,9 +3841,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3858,9 +3858,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3875,9 +3875,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3892,9 +3892,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3909,9 +3909,9 @@ Array [ r={0.5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -3931,7 +3931,7 @@ Array [ style={ Object { "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeDasharray": undefined, "strokeWidth": undefined, } @@ -3952,9 +3952,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -3969,9 +3969,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -3986,9 +3986,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4003,9 +4003,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4020,9 +4020,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4037,9 +4037,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4054,9 +4054,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4071,9 +4071,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4088,9 +4088,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4105,9 +4105,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4122,9 +4122,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4139,9 +4139,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4156,9 +4156,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4173,9 +4173,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4190,9 +4190,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4207,9 +4207,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4224,9 +4224,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4241,9 +4241,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4258,9 +4258,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4275,9 +4275,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4292,9 +4292,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4309,9 +4309,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4326,9 +4326,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4343,9 +4343,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4360,9 +4360,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4377,9 +4377,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4394,9 +4394,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4411,9 +4411,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4428,9 +4428,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4445,9 +4445,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4462,9 +4462,9 @@ Array [ r={0.5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -4484,7 +4484,7 @@ Array [ style={ Object { "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeDasharray": undefined, "strokeWidth": undefined, } @@ -4505,9 +4505,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4522,9 +4522,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4539,9 +4539,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4556,9 +4556,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4573,9 +4573,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4590,9 +4590,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4607,9 +4607,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4624,9 +4624,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4641,9 +4641,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4658,9 +4658,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4675,9 +4675,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4692,9 +4692,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4709,9 +4709,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4726,9 +4726,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4743,9 +4743,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4760,9 +4760,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4777,9 +4777,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4794,9 +4794,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4811,9 +4811,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4828,9 +4828,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4845,9 +4845,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4862,9 +4862,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4879,9 +4879,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4896,9 +4896,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4913,9 +4913,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4930,9 +4930,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4947,9 +4947,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4964,9 +4964,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4981,9 +4981,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -4998,9 +4998,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -5015,9 +5015,9 @@ Array [ r={0.5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -5072,9 +5072,9 @@ Array [ r={5} style={ Object { - "fill": "#f98510", + "fill": "#f19f58", "opacity": 1, - "stroke": "#f98510", + "stroke": "#f19f58", "strokeWidth": 1, } } @@ -5089,9 +5089,9 @@ Array [ r={5} style={ Object { - "fill": "#e6c220", + "fill": "#fae181", "opacity": 1, - "stroke": "#e6c220", + "stroke": "#fae181", "strokeWidth": 1, } } @@ -5106,9 +5106,9 @@ Array [ r={5} style={ Object { - "fill": "#3185fc", + "fill": "#6092c0", "opacity": 1, - "stroke": "#3185fc", + "stroke": "#6092c0", "strokeWidth": 1, } } @@ -5158,7 +5158,7 @@ Array [ className="c3" > @@ -5174,14 +5174,14 @@ Array [ fontSize="12px" > @@ -5204,7 +5204,7 @@ Array [ className="c3" > @@ -5220,14 +5220,14 @@ Array [ fontSize="12px" > @@ -5250,7 +5250,7 @@ Array [ className="c3" > @@ -5266,14 +5266,14 @@ Array [ fontSize="12px" > @@ -5830,7 +5830,7 @@ Array [ width: 11px; height: 11px; margin-right: 5.5px; - background: #3185fc; + background: #6092c0; border-radius: 100%; } @@ -5838,7 +5838,7 @@ Array [ width: 11px; height: 11px; margin-right: 5.5px; - background: #e6c220; + background: #fae181; border-radius: 100%; } @@ -5846,7 +5846,7 @@ Array [ width: 11px; height: 11px; margin-right: 5.5px; - background: #f98510; + background: #f19f58; border-radius: 100%; } @@ -5902,14 +5902,14 @@ Array [ onClick={[Function]} > @@ -5943,14 +5943,14 @@ Array [ onClick={[Function]} > @@ -5977,14 +5977,14 @@ Array [ onClick={[Function]} > diff --git a/x-pack/legacy/plugins/apm/public/components/shared/charts/Histogram/__test__/__snapshots__/Histogram.test.js.snap b/x-pack/legacy/plugins/apm/public/components/shared/charts/Histogram/__test__/__snapshots__/Histogram.test.js.snap index da71e264ac099..f1c7d4826fe0c 100644 --- a/x-pack/legacy/plugins/apm/public/components/shared/charts/Histogram/__test__/__snapshots__/Histogram.test.js.snap +++ b/x-pack/legacy/plugins/apm/public/components/shared/charts/Histogram/__test__/__snapshots__/Histogram.test.js.snap @@ -434,11 +434,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.628571428571433} @@ -453,11 +453,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.628571428571433} @@ -472,11 +472,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.62857142857142} @@ -491,11 +491,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.628571428571433} @@ -510,11 +510,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.628571428571405} @@ -529,11 +529,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.62857142857142} @@ -548,11 +548,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.628571428571405} @@ -567,11 +567,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.628571428571405} @@ -586,11 +586,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.628571428571377} @@ -605,11 +605,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.628571428571462} @@ -624,11 +624,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.62857142857149} @@ -643,11 +643,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.62857142857149} @@ -662,11 +662,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.62857142857149} @@ -681,11 +681,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.628571428571433} @@ -700,11 +700,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.628571428571433} @@ -719,11 +719,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.628571428571433} @@ -738,11 +738,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.628571428571547} @@ -757,11 +757,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.62857142857149} @@ -776,11 +776,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.628571428571547} @@ -795,11 +795,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.628571428571433} @@ -814,11 +814,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.628571428571433} @@ -833,11 +833,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.628571428571377} @@ -852,11 +852,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.62857142857149} @@ -871,11 +871,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.62857142857149} @@ -890,11 +890,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.628571428571604} @@ -909,11 +909,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.62857142857149} @@ -928,11 +928,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.62857142857149} @@ -947,11 +947,11 @@ exports[`Histogram Initially should have default markup 1`] = ` onMouseOver={[Function]} style={ Object { - "fill": "#98c2fd", + "fill": "#afc8df", "opacity": 1, "rx": "0px", "ry": "0px", - "stroke": "#98c2fd", + "stroke": "#afc8df", } } width={22.628571428571377} diff --git a/x-pack/legacy/plugins/apm/public/selectors/__tests__/chartSelectors.test.ts b/x-pack/legacy/plugins/apm/public/selectors/__tests__/chartSelectors.test.ts index 2b0263f69db8f..1218bc726c3b7 100644 --- a/x-pack/legacy/plugins/apm/public/selectors/__tests__/chartSelectors.test.ts +++ b/x-pack/legacy/plugins/apm/public/selectors/__tests__/chartSelectors.test.ts @@ -21,7 +21,7 @@ describe('chartSelectors', () => { it('should return anomalyScoreSeries', () => { const data = [{ x0: 0, x: 10 }]; expect(getAnomalyScoreSeries(data)).toEqual({ - areaColor: 'rgba(146,0,0,0.1)', + areaColor: 'rgba(231,102,76,0.1)', color: 'none', data: [{ x0: 0, x: 10 }], hideLegend: true, @@ -57,7 +57,7 @@ describe('chartSelectors', () => { getResponseTimeSeries({ apmTimeseries, anomalyTimeseries: undefined }) ).toEqual([ { - color: '#3185fc', + color: '#6092c0', data: [ { x: 0, y: 100 }, { x: 1000, y: 200 } @@ -67,7 +67,7 @@ describe('chartSelectors', () => { type: 'linemark' }, { - color: '#e6c220', + color: '#fae181', data: [ { x: 0, y: 200 }, { x: 1000, y: 300 } @@ -77,7 +77,7 @@ describe('chartSelectors', () => { type: 'linemark' }, { - color: '#f98510', + color: '#f19f58', data: [ { x: 0, y: 300 }, { x: 1000, y: 400 } diff --git a/x-pack/legacy/plugins/apm/server/lib/transactions/breakdown/index.test.ts b/x-pack/legacy/plugins/apm/server/lib/transactions/breakdown/index.test.ts index f49c1e022a070..870b02fa7ba6d 100644 --- a/x-pack/legacy/plugins/apm/server/lib/transactions/breakdown/index.test.ts +++ b/x-pack/legacy/plugins/apm/server/lib/transactions/breakdown/index.test.ts @@ -70,13 +70,13 @@ describe('getTransactionBreakdown', () => { expect(response.kpis[0]).toEqual({ name: 'app', - color: '#00b3a4', + color: '#5bbaa0', percentage: 0.5408550899466306 }); expect(response.kpis[3]).toEqual({ name: 'postgresql', - color: '#490092', + color: '#9170b8', percentage: 0.047366859295002 }); }); diff --git a/x-pack/legacy/plugins/beats_management/public/components/inputs/input.tsx b/x-pack/legacy/plugins/beats_management/public/components/inputs/input.tsx index 0e07c2b4960b7..29cdcfccfc756 100644 --- a/x-pack/legacy/plugins/beats_management/public/components/inputs/input.tsx +++ b/x-pack/legacy/plugins/beats_management/public/components/inputs/input.tsx @@ -3,12 +3,15 @@ * or more contributor license agreements. Licensed under the Elastic License; * you may not use this file except in compliance with the Elastic License. */ -import { EuiFieldText, EuiFieldTextProps, EuiFormRow } from '@elastic/eui'; +import { EuiFieldText, EuiFormRow } from '@elastic/eui'; import { CommonProps } from '@elastic/eui/src/components/common'; import { FormsyInputProps, withFormsy } from 'formsy-react'; import React, { Component, InputHTMLAttributes } from 'react'; -interface ComponentProps extends FormsyInputProps, CommonProps, EuiFieldTextProps { +interface ComponentProps + extends FormsyInputProps, + CommonProps, + Omit, 'onChange' | 'onBlur'> { instantValidation?: boolean; label: string; errorText: string; diff --git a/x-pack/legacy/plugins/graph/public/components/field_manager/field_icon.tsx b/x-pack/legacy/plugins/graph/public/components/field_manager/field_icon.tsx index 429eec19a47fa..0c099135f631d 100644 --- a/x-pack/legacy/plugins/graph/public/components/field_manager/field_icon.tsx +++ b/x-pack/legacy/plugins/graph/public/components/field_manager/field_icon.tsx @@ -5,7 +5,7 @@ */ import React from 'react'; -import { ICON_TYPES, palettes, EuiIcon } from '@elastic/eui'; +import { ICON_TYPES, euiPaletteColorBlind, EuiIcon } from '@elastic/eui'; function stringToNum(s: string) { return Array.from(s).reduce((acc, ch) => acc + ch.charCodeAt(0), 1); @@ -23,7 +23,7 @@ function getIconForDataType(dataType: string) { export function getColorForDataType(type: string) { const iconType = getIconForDataType(type); - const { colors } = palettes.euiPaletteColorBlind; + const colors = euiPaletteColorBlind(); const colorIndex = stringToNum(iconType) % colors.length; return colors[colorIndex]; } diff --git a/x-pack/legacy/plugins/graph/public/helpers/style_choices.ts b/x-pack/legacy/plugins/graph/public/helpers/style_choices.ts index 855818886ab6f..46fec39bfce06 100644 --- a/x-pack/legacy/plugins/graph/public/helpers/style_choices.ts +++ b/x-pack/legacy/plugins/graph/public/helpers/style_choices.ts @@ -6,7 +6,7 @@ import { i18n } from '@kbn/i18n'; // @ts-ignore -import { palettes } from '@elastic/eui/lib/services'; +import { euiPaletteColorBlind } from '@elastic/eui/lib/services'; export interface FontawesomeIcon { class: string; @@ -255,4 +255,4 @@ urlTemplateIconChoices.forEach(icon => { urlTemplateIconChoicesByClass[icon.class] = icon; }); -export const colorChoices = palettes.euiPaletteColorBlind.colors; +export const colorChoices = euiPaletteColorBlind(); diff --git a/x-pack/legacy/plugins/graph/public/services/persistence/deserialize.test.ts b/x-pack/legacy/plugins/graph/public/services/persistence/deserialize.test.ts index 1861479f85f18..efef3d246ac98 100644 --- a/x-pack/legacy/plugins/graph/public/services/persistence/deserialize.test.ts +++ b/x-pack/legacy/plugins/graph/public/services/persistence/deserialize.test.ts @@ -161,7 +161,7 @@ describe('deserialize', () => { }, Object { "aggregatable": true, - "color": "#CE0060", + "color": "#D36086", "hopSize": 5, "icon": Object { "class": "fa-folder-open-o", diff --git a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/field_icon.test.tsx b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/field_icon.test.tsx index 85c1deb0ea7e1..e0e33ef03d3d1 100644 --- a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/field_icon.test.tsx +++ b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/field_icon.test.tsx @@ -17,37 +17,37 @@ import { FieldIcon } from './field_icon'; describe('FieldIcon', () => { it('should render icons', () => { expect(shallow()).toMatchInlineSnapshot(` - - `); + + `); expect(shallow()).toMatchInlineSnapshot(` - - `); + + `); expect(shallow()).toMatchInlineSnapshot(` - - `); + + `); expect(shallow()).toMatchInlineSnapshot(` - - `); + + `); expect(shallow()).toMatchInlineSnapshot(` `); diff --git a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/field_icon.tsx b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/field_icon.tsx index f1e8db04860a7..796f200bffd97 100644 --- a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/field_icon.tsx +++ b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/field_icon.tsx @@ -5,7 +5,7 @@ */ import React from 'react'; -import { ICON_TYPES, palettes, EuiIcon } from '@elastic/eui'; +import { ICON_TYPES, euiPaletteColorBlind, EuiIcon } from '@elastic/eui'; import classNames from 'classnames'; import { DataType } from '../types'; @@ -24,7 +24,7 @@ function getIconForDataType(dataType: string) { export function getColorForDataType(type: string) { const iconType = getIconForDataType(type); - const { colors } = palettes.euiPaletteColorBlind; + const colors = euiPaletteColorBlind(); const colorIndex = stringToNum(iconType) % colors.length; return colors[colorIndex]; } diff --git a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/lens_field_icon.test.tsx b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/lens_field_icon.test.tsx index 7441083550706..a470f5fc51cfb 100644 --- a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/lens_field_icon.test.tsx +++ b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/lens_field_icon.test.tsx @@ -20,10 +20,10 @@ test('LensFieldIcon renders properly', () => { test('LensFieldIcon getColorForDataType for a valid type', () => { const color = getColorForDataType('date'); - expect(color).toEqual('#B0916F'); + expect(color).toEqual('#F19F58'); }); test('LensFieldIcon getColorForDataType for an invalid type', () => { const color = getColorForDataType('invalid'); - expect(color).toEqual('#1EA593'); + expect(color).toEqual('#5BBAA0'); }); diff --git a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/lens_field_icon.tsx b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/lens_field_icon.tsx index cd2bb69f6e580..2e6a5fcd8115f 100644 --- a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/lens_field_icon.tsx +++ b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/lens_field_icon.tsx @@ -5,7 +5,7 @@ */ import React from 'react'; -import { palettes } from '@elastic/eui'; +import { euiPaletteColorBlind } from '@elastic/eui'; import { FieldIcon, typeToEuiIconMap } from '../../../../../../src/plugins/kibana_react/public'; import { DataType } from '../types'; import { normalizeOperationDataType } from './utils'; @@ -15,7 +15,7 @@ export function getColorForDataType(type: string) { if (iconMap) { return iconMap.color; } - return palettes.euiPaletteColorBlind.colors[0]; + return euiPaletteColorBlind()[0]; } export function LensFieldIcon({ type }: { type: DataType }) { diff --git a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/operations/definitions/terms.test.tsx b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/operations/definitions/terms.test.tsx index a891814bb0496..d21c6c74e1050 100644 --- a/x-pack/legacy/plugins/lens/public/indexpattern_plugin/operations/definitions/terms.test.tsx +++ b/x-pack/legacy/plugins/lens/public/indexpattern_plugin/operations/definitions/terms.test.tsx @@ -354,7 +354,7 @@ describe('terms', () => { expect(select.prop('value')).toEqual('alphabetical'); - expect(select.prop('options').map(({ value }) => value)).toEqual([ + expect(select.prop('options')!.map(({ value }) => value)).toEqual([ 'column$$$col2', 'alphabetical', ]); @@ -423,7 +423,7 @@ describe('terms', () => { .find(EuiSelect); expect(select.prop('value')).toEqual('asc'); - expect(select.prop('options').map(({ value }) => value)).toEqual(['asc', 'desc']); + expect(select.prop('options')!.map(({ value }) => value)).toEqual(['asc', 'desc']); }); it('should update state with the order direction value', () => { diff --git a/x-pack/legacy/plugins/lens/public/xy_visualization_plugin/__snapshots__/xy_expression.test.tsx.snap b/x-pack/legacy/plugins/lens/public/xy_visualization_plugin/__snapshots__/xy_expression.test.tsx.snap index 8df2d764c0208..76802e701b387 100644 --- a/x-pack/legacy/plugins/lens/public/xy_visualization_plugin/__snapshots__/xy_expression.test.tsx.snap +++ b/x-pack/legacy/plugins/lens/public/xy_visualization_plugin/__snapshots__/xy_expression.test.tsx.snap @@ -86,18 +86,18 @@ exports[`xy_expression XYChart component it renders area 1`] = ` "top": 0, }, "colors": Object { - "defaultVizColor": "#3185FC", + "defaultVizColor": "#6092C0", "vizColors": Array [ - "#1EA593", - "#2B70F7", - "#CE0060", - "#38007E", - "#FCA5D3", - "#F37020", - "#E49E29", - "#B0916F", - "#7B000B", - "#34130C", + "#5BBAA0", + "#6092C0", + "#D36086", + "#9170B8", + "#EEAFCF", + "#FAE181", + "#CDBD9D", + "#F19F58", + "#B46F5F", + "#E7664C", ], }, "crosshair": Object { @@ -272,18 +272,18 @@ exports[`xy_expression XYChart component it renders bar 1`] = ` "top": 0, }, "colors": Object { - "defaultVizColor": "#3185FC", + "defaultVizColor": "#6092C0", "vizColors": Array [ - "#1EA593", - "#2B70F7", - "#CE0060", - "#38007E", - "#FCA5D3", - "#F37020", - "#E49E29", - "#B0916F", - "#7B000B", - "#34130C", + "#5BBAA0", + "#6092C0", + "#D36086", + "#9170B8", + "#EEAFCF", + "#FAE181", + "#CDBD9D", + "#F19F58", + "#B46F5F", + "#E7664C", ], }, "crosshair": Object { @@ -458,18 +458,18 @@ exports[`xy_expression XYChart component it renders horizontal bar 1`] = ` "top": 0, }, "colors": Object { - "defaultVizColor": "#3185FC", + "defaultVizColor": "#6092C0", "vizColors": Array [ - "#1EA593", - "#2B70F7", - "#CE0060", - "#38007E", - "#FCA5D3", - "#F37020", - "#E49E29", - "#B0916F", - "#7B000B", - "#34130C", + "#5BBAA0", + "#6092C0", + "#D36086", + "#9170B8", + "#EEAFCF", + "#FAE181", + "#CDBD9D", + "#F19F58", + "#B46F5F", + "#E7664C", ], }, "crosshair": Object { @@ -644,18 +644,18 @@ exports[`xy_expression XYChart component it renders line 1`] = ` "top": 0, }, "colors": Object { - "defaultVizColor": "#3185FC", + "defaultVizColor": "#6092C0", "vizColors": Array [ - "#1EA593", - "#2B70F7", - "#CE0060", - "#38007E", - "#FCA5D3", - "#F37020", - "#E49E29", - "#B0916F", - "#7B000B", - "#34130C", + "#5BBAA0", + "#6092C0", + "#D36086", + "#9170B8", + "#EEAFCF", + "#FAE181", + "#CDBD9D", + "#F19F58", + "#B46F5F", + "#E7664C", ], }, "crosshair": Object { @@ -830,18 +830,18 @@ exports[`xy_expression XYChart component it renders stacked area 1`] = ` "top": 0, }, "colors": Object { - "defaultVizColor": "#3185FC", + "defaultVizColor": "#6092C0", "vizColors": Array [ - "#1EA593", - "#2B70F7", - "#CE0060", - "#38007E", - "#FCA5D3", - "#F37020", - "#E49E29", - "#B0916F", - "#7B000B", - "#34130C", + "#5BBAA0", + "#6092C0", + "#D36086", + "#9170B8", + "#EEAFCF", + "#FAE181", + "#CDBD9D", + "#F19F58", + "#B46F5F", + "#E7664C", ], }, "crosshair": Object { @@ -1020,18 +1020,18 @@ exports[`xy_expression XYChart component it renders stacked bar 1`] = ` "top": 0, }, "colors": Object { - "defaultVizColor": "#3185FC", + "defaultVizColor": "#6092C0", "vizColors": Array [ - "#1EA593", - "#2B70F7", - "#CE0060", - "#38007E", - "#FCA5D3", - "#F37020", - "#E49E29", - "#B0916F", - "#7B000B", - "#34130C", + "#5BBAA0", + "#6092C0", + "#D36086", + "#9170B8", + "#EEAFCF", + "#FAE181", + "#CDBD9D", + "#F19F58", + "#B46F5F", + "#E7664C", ], }, "crosshair": Object { @@ -1210,18 +1210,18 @@ exports[`xy_expression XYChart component it renders stacked horizontal bar 1`] = "top": 0, }, "colors": Object { - "defaultVizColor": "#3185FC", + "defaultVizColor": "#6092C0", "vizColors": Array [ - "#1EA593", - "#2B70F7", - "#CE0060", - "#38007E", - "#FCA5D3", - "#F37020", - "#E49E29", - "#B0916F", - "#7B000B", - "#34130C", + "#5BBAA0", + "#6092C0", + "#D36086", + "#9170B8", + "#EEAFCF", + "#FAE181", + "#CDBD9D", + "#F19F58", + "#B46F5F", + "#E7664C", ], }, "crosshair": Object { diff --git a/x-pack/legacy/plugins/logstash/public/components/pipeline_editor/__snapshots__/pipeline_editor.test.js.snap b/x-pack/legacy/plugins/logstash/public/components/pipeline_editor/__snapshots__/pipeline_editor.test.js.snap index dc51c066a8cb9..74f109df382cd 100644 --- a/x-pack/legacy/plugins/logstash/public/components/pipeline_editor/__snapshots__/pipeline_editor.test.js.snap +++ b/x-pack/legacy/plugins/logstash/public/components/pipeline_editor/__snapshots__/pipeline_editor.test.js.snap @@ -48,11 +48,9 @@ exports[`PipelineEditor component includes required error message for falsy pipe labelType="label" > `; diff --git a/x-pack/legacy/plugins/maps/public/components/__snapshots__/geometry_filter_form.test.js.snap b/x-pack/legacy/plugins/maps/public/components/__snapshots__/geometry_filter_form.test.js.snap index 98e6fa0517f58..2dc355513ece2 100644 --- a/x-pack/legacy/plugins/maps/public/components/__snapshots__/geometry_filter_form.test.js.snap +++ b/x-pack/legacy/plugins/maps/public/components/__snapshots__/geometry_filter_form.test.js.snap @@ -13,8 +13,6 @@ exports[`should not render relation select when geo field is geo_point 1`] = ` > @@ -92,8 +90,6 @@ exports[`should not show "within" relation when filter geometry is not closed 1` > @@ -151,9 +147,6 @@ exports[`should not show "within" relation when filter geometry is not closed 1` > @@ -283,8 +274,6 @@ exports[`should render relation select when geo field is geo_shape 1`] = ` > @@ -342,9 +331,6 @@ exports[`should render relation select when geo field is geo_shape 1`] = ` > tinycolor(color) diff --git a/x-pack/legacy/plugins/ml/public/application/components/annotations/annotations_table/__snapshots__/annotations_table.test.js.snap b/x-pack/legacy/plugins/ml/public/application/components/annotations/annotations_table/__snapshots__/annotations_table.test.js.snap index 1d95c217e10f7..48cf53cf1ac01 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/annotations/annotations_table/__snapshots__/annotations_table.test.js.snap +++ b/x-pack/legacy/plugins/ml/public/application/components/annotations/annotations_table/__snapshots__/annotations_table.test.js.snap @@ -89,6 +89,7 @@ exports[`AnnotationsTable Initialization with annotations prop. 1`] = ` }, } } + tableLayout="fixed" /> `; diff --git a/x-pack/legacy/plugins/ml/public/application/components/kql_filter_bar/filter_bar/__snapshots__/filter_bar.test.js.snap b/x-pack/legacy/plugins/ml/public/application/components/kql_filter_bar/filter_bar/__snapshots__/filter_bar.test.js.snap index 217aa113fba4d..f3c825a66ee2f 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/kql_filter_bar/filter_bar/__snapshots__/filter_bar.test.js.snap +++ b/x-pack/legacy/plugins/ml/public/application/components/kql_filter_bar/filter_bar/__snapshots__/filter_bar.test.js.snap @@ -23,6 +23,7 @@ exports[`FilterBar snapshot suggestions not shown 1`] = ` fullWidth={true} incremental={false} inputRef={[Function]} + isClearable={true} isLoading={false} onChange={[Function]} onClick={[Function]} @@ -88,6 +89,7 @@ exports[`FilterBar snapshot suggestions shown 1`] = ` fullWidth={true} incremental={false} inputRef={[Function]} + isClearable={true} isLoading={false} onChange={[Function]} onClick={[Function]} diff --git a/x-pack/legacy/plugins/ml/public/application/components/rule_editor/__snapshots__/condition_expression.test.js.snap b/x-pack/legacy/plugins/ml/public/application/components/rule_editor/__snapshots__/condition_expression.test.js.snap index 177ba5019fbe3..43b4625e81f79 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/rule_editor/__snapshots__/condition_expression.test.js.snap +++ b/x-pack/legacy/plugins/ml/public/application/components/rule_editor/__snapshots__/condition_expression.test.js.snap @@ -55,10 +55,6 @@ exports[`ConditionExpression renders with appliesTo, operator and value supplied } > @@ -495,9 +477,7 @@ exports[`CustomUrlEditor renders the editor for a discover type URL with valid t @@ -742,9 +714,7 @@ exports[`CustomUrlEditor renders the editor for a new dashboard type URL with no @@ -56,10 +53,8 @@ exports[`CustomUrlList renders a list of custom URLs 1`] = ` labelType="label" > @@ -214,10 +203,8 @@ exports[`CustomUrlList renders a list of custom URLs 1`] = ` labelType="label" > @@ -372,10 +353,8 @@ exports[`CustomUrlList renders a list of custom URLs 1`] = ` labelType="label" > `; @@ -166,6 +167,7 @@ exports[`EventsTable Renders events table with search bar 1`] = ` }, } } + tableLayout="fixed" /> `; diff --git a/x-pack/legacy/plugins/ml/public/application/settings/calendars/list/table/__snapshots__/table.test.js.snap b/x-pack/legacy/plugins/ml/public/application/settings/calendars/list/table/__snapshots__/table.test.js.snap index d689d1b874462..8c518f42e0ec7 100644 --- a/x-pack/legacy/plugins/ml/public/application/settings/calendars/list/table/__snapshots__/table.test.js.snap +++ b/x-pack/legacy/plugins/ml/public/application/settings/calendars/list/table/__snapshots__/table.test.js.snap @@ -108,6 +108,7 @@ exports[`CalendarsListTable renders the table with all calendars 1`] = ` }, } } + tableLayout="fixed" /> `; diff --git a/x-pack/legacy/plugins/ml/public/application/settings/filter_lists/components/edit_description_popover/__snapshots__/edit_description_popover.test.js.snap b/x-pack/legacy/plugins/ml/public/application/settings/filter_lists/components/edit_description_popover/__snapshots__/edit_description_popover.test.js.snap index 6513f2795ed3a..f4fb2734a5e82 100644 --- a/x-pack/legacy/plugins/ml/public/application/settings/filter_lists/components/edit_description_popover/__snapshots__/edit_description_popover.test.js.snap +++ b/x-pack/legacy/plugins/ml/public/application/settings/filter_lists/components/edit_description_popover/__snapshots__/edit_description_popover.test.js.snap @@ -46,9 +46,6 @@ exports[`FilterListUsagePopover opens the popover onButtonClick 1`] = ` labelType="label" > diff --git a/x-pack/legacy/plugins/ml/public/application/settings/filter_lists/edit/__snapshots__/header.test.js.snap b/x-pack/legacy/plugins/ml/public/application/settings/filter_lists/edit/__snapshots__/header.test.js.snap index 7c0aa7951e951..85a31fbcd9185 100644 --- a/x-pack/legacy/plugins/ml/public/application/settings/filter_lists/edit/__snapshots__/header.test.js.snap +++ b/x-pack/legacy/plugins/ml/public/application/settings/filter_lists/edit/__snapshots__/header.test.js.snap @@ -70,10 +70,7 @@ exports[`EditFilterListHeader renders the header when creating a new filter list labelType="label" > `; @@ -196,6 +197,7 @@ exports[`Filter Lists Table renders with filter lists supplied 1`] = ` }, } } + tableLayout="fixed" /> `; diff --git a/x-pack/legacy/plugins/monitoring/public/components/beats/overview/__snapshots__/latest_active.test.js.snap b/x-pack/legacy/plugins/monitoring/public/components/beats/overview/__snapshots__/latest_active.test.js.snap index 0bddf48d88278..b7d57b9bb5d9d 100644 --- a/x-pack/legacy/plugins/monitoring/public/components/beats/overview/__snapshots__/latest_active.test.js.snap +++ b/x-pack/legacy/plugins/monitoring/public/components/beats/overview/__snapshots__/latest_active.test.js.snap @@ -41,5 +41,6 @@ exports[`Latest Active that latest active component renders normally 1`] = ` } noItemsMessage="No items found" responsive={true} + tableLayout="fixed" /> `; diff --git a/x-pack/legacy/plugins/monitoring/public/components/beats/overview/__snapshots__/latest_types.test.js.snap b/x-pack/legacy/plugins/monitoring/public/components/beats/overview/__snapshots__/latest_types.test.js.snap index e2fd9be796012..0021bfae57d6e 100644 --- a/x-pack/legacy/plugins/monitoring/public/components/beats/overview/__snapshots__/latest_types.test.js.snap +++ b/x-pack/legacy/plugins/monitoring/public/components/beats/overview/__snapshots__/latest_types.test.js.snap @@ -33,5 +33,6 @@ exports[`Latest Types that latest active component renders normally 1`] = ` } noItemsMessage="No items found" responsive={true} + tableLayout="fixed" /> `; diff --git a/x-pack/legacy/plugins/monitoring/public/components/beats/overview/__snapshots__/latest_versions.test.js.snap b/x-pack/legacy/plugins/monitoring/public/components/beats/overview/__snapshots__/latest_versions.test.js.snap index 65f6ae1603352..93ff1299323a0 100644 --- a/x-pack/legacy/plugins/monitoring/public/components/beats/overview/__snapshots__/latest_versions.test.js.snap +++ b/x-pack/legacy/plugins/monitoring/public/components/beats/overview/__snapshots__/latest_versions.test.js.snap @@ -29,5 +29,6 @@ exports[`Latest Versions that latest active component renders normally 1`] = ` } noItemsMessage="No items found" responsive={true} + tableLayout="fixed" /> `; diff --git a/x-pack/legacy/plugins/monitoring/public/components/elasticsearch/ccr/__snapshots__/ccr.test.js.snap b/x-pack/legacy/plugins/monitoring/public/components/elasticsearch/ccr/__snapshots__/ccr.test.js.snap index 37e0039c94ec4..d54612b6f4f29 100644 --- a/x-pack/legacy/plugins/monitoring/public/components/elasticsearch/ccr/__snapshots__/ccr.test.js.snap +++ b/x-pack/legacy/plugins/monitoring/public/components/elasticsearch/ccr/__snapshots__/ccr.test.js.snap @@ -131,6 +131,7 @@ exports[`Ccr that it renders normally 1`] = ` }, } } + tableLayout="fixed" /> diff --git a/x-pack/legacy/plugins/monitoring/public/components/elasticsearch/ccr_shard/__snapshots__/ccr_shard.test.js.snap b/x-pack/legacy/plugins/monitoring/public/components/elasticsearch/ccr_shard/__snapshots__/ccr_shard.test.js.snap index 02e42b8647c03..366c23135cc76 100644 --- a/x-pack/legacy/plugins/monitoring/public/components/elasticsearch/ccr_shard/__snapshots__/ccr_shard.test.js.snap +++ b/x-pack/legacy/plugins/monitoring/public/components/elasticsearch/ccr_shard/__snapshots__/ccr_shard.test.js.snap @@ -45,6 +45,7 @@ exports[`CcrShard that is renders an exception properly 1`] = ` } noItemsMessage="No items found" responsive={true} + tableLayout="fixed" /> `; diff --git a/x-pack/legacy/plugins/monitoring/public/components/logs/__snapshots__/logs.test.js.snap b/x-pack/legacy/plugins/monitoring/public/components/logs/__snapshots__/logs.test.js.snap index 4affadd127530..de02fb10a5937 100644 --- a/x-pack/legacy/plugins/monitoring/public/components/logs/__snapshots__/logs.test.js.snap +++ b/x-pack/legacy/plugins/monitoring/public/components/logs/__snapshots__/logs.test.js.snap @@ -270,6 +270,7 @@ exports[`Logs should render normally 1`] = ` } noItemsMessage="No items found" responsive={true} + tableLayout="fixed" /> @@ -378,9 +376,7 @@ exports[`Flyout beats part one should render normally 1`] = ` labelType="label" > @@ -761,9 +757,7 @@ exports[`Flyout elasticsearch part one should render normally 1`] = ` labelType="label" > @@ -1104,9 +1098,7 @@ exports[`Flyout kibana part one should render normally 1`] = ` labelType="label" > @@ -1454,9 +1446,7 @@ exports[`Flyout logstash part one should render normally 1`] = ` labelType="label" > diff --git a/x-pack/legacy/plugins/reporting/public/components/__snapshots__/report_listing.test.tsx.snap b/x-pack/legacy/plugins/reporting/public/components/__snapshots__/report_listing.test.tsx.snap index fe5625fa0dfa6..3b6d7a0b5f003 100644 --- a/x-pack/legacy/plugins/reporting/public/components/__snapshots__/report_listing.test.tsx.snap +++ b/x-pack/legacy/plugins/reporting/public/components/__snapshots__/report_listing.test.tsx.snap @@ -45,6 +45,7 @@ Array [ } } responsive={true} + tableLayout="fixed" >
`; diff --git a/x-pack/legacy/plugins/siem/public/components/autocomplete_field/__snapshots__/index.test.tsx.snap b/x-pack/legacy/plugins/siem/public/components/autocomplete_field/__snapshots__/index.test.tsx.snap index 3fbf46760f3a5..dfd9612d52443 100644 --- a/x-pack/legacy/plugins/siem/public/components/autocomplete_field/__snapshots__/index.test.tsx.snap +++ b/x-pack/legacy/plugins/siem/public/components/autocomplete_field/__snapshots__/index.test.tsx.snap @@ -10,6 +10,7 @@ exports[`Autocomplete rendering it renders against snapshot 1`] = ` fullWidth={true} incremental={false} inputRef={[Function]} + isClearable={true} isInvalid={true} isLoading={false} onChange={[Function]} diff --git a/x-pack/legacy/plugins/siem/public/components/ml_popover/jobs_table/__snapshots__/jobs_table.test.tsx.snap b/x-pack/legacy/plugins/siem/public/components/ml_popover/jobs_table/__snapshots__/jobs_table.test.tsx.snap index 983eb2409bd77..d8b8ae63cf41f 100644 --- a/x-pack/legacy/plugins/siem/public/components/ml_popover/jobs_table/__snapshots__/jobs_table.test.tsx.snap +++ b/x-pack/legacy/plugins/siem/public/components/ml_popover/jobs_table/__snapshots__/jobs_table.test.tsx.snap @@ -112,5 +112,6 @@ exports[`JobsTableComponent renders correctly against snapshot 1`] = ` } } responsive={false} + tableLayout="fixed" /> `; diff --git a/x-pack/legacy/plugins/siem/public/components/notes/note_card/__snapshots__/note_card_body.test.tsx.snap b/x-pack/legacy/plugins/siem/public/components/notes/note_card/__snapshots__/note_card_body.test.tsx.snap index e8ed09658c788..11fd78d81052a 100644 --- a/x-pack/legacy/plugins/siem/public/components/notes/note_card/__snapshots__/note_card_body.test.tsx.snap +++ b/x-pack/legacy/plugins/siem/public/components/notes/note_card/__snapshots__/note_card_body.test.tsx.snap @@ -167,16 +167,16 @@ exports[`NoteCardBody renders correctly against snapshot 1`] = ` "euiColorPrimary": "#1ba9f5", "euiColorSecondary": "#7de2d1", "euiColorSuccess": "#7de2d1", - "euiColorVis0": "#00b3a4", - "euiColorVis1": "#3185fc", - "euiColorVis2": "#db1374", - "euiColorVis3": "#490092", - "euiColorVis4": "#feb6db", - "euiColorVis5": "#e6c220", - "euiColorVis6": "#bfa180", - "euiColorVis7": "#f98510", - "euiColorVis8": "#461a0a", - "euiColorVis9": "#920000", + "euiColorVis0": "#5bbaa0", + "euiColorVis1": "#6092c0", + "euiColorVis2": "#d36086", + "euiColorVis3": "#9170b8", + "euiColorVis4": "#eeafcf", + "euiColorVis5": "#fae181", + "euiColorVis6": "#cdbd9d", + "euiColorVis7": "#f19f58", + "euiColorVis8": "#b46f5f", + "euiColorVis9": "#e7664c", "euiColorWarning": "#ffce7a", "euiContextMenuWidth": "256px", "euiControlBarBackground": "#000000", @@ -351,15 +351,17 @@ exports[`NoteCardBody renders correctly against snapshot 1`] = ` "warning": "#ffce7a", }, "euiSuggestItemColors": Object { - "tint0": "#00b3a4", - "tint1": "#3185fc", - "tint2": "#db1374", - "tint3": "#490092", - "tint4": "#e6c220", - "tint5": "#f98510", - "tint6": "#461a0a", - "tint7": "#920000", - "tint8": "#98a2b3", + "tint0": "#5bbaa0", + "tint1": "#6092c0", + "tint10": "#98a2b3", + "tint2": "#d36086", + "tint3": "#9170b8", + "tint4": "#eeafcf", + "tint5": "#fae181", + "tint6": "#cdbd9d", + "tint7": "#f19f58", + "tint8": "#b46f5f", + "tint9": "#e7664c", }, "euiSuperDatePickerButtonWidth": "118px", "euiSuperDatePickerWidth": "480px", @@ -505,11 +507,11 @@ exports[`NoteCardBody renders correctly against snapshot 1`] = ` "tokenTypes": Object { "tokenTint01": "#1ba9f5", "tokenTint02": "#f990c0", - "tokenTint03": "#490092", - "tokenTint04": "#f98510", - "tokenTint05": "#3185fc", + "tokenTint03": "#9170b8", + "tokenTint04": "#f19f58", + "tokenTint05": "#6092c0", "tokenTint06": "#e6c220", - "tokenTint07": "#00b3a4", + "tokenTint07": "#5bbaa0", "tokenTint08": "#920000", "tokenTint09": "#ff00ff", "tokenTint10": "#26ab00", diff --git a/x-pack/legacy/plugins/siem/public/components/paginated_table/__snapshots__/index.test.tsx.snap b/x-pack/legacy/plugins/siem/public/components/paginated_table/__snapshots__/index.test.tsx.snap index 98c9fc202dd6b..82bcd62c77cbe 100644 --- a/x-pack/legacy/plugins/siem/public/components/paginated_table/__snapshots__/index.test.tsx.snap +++ b/x-pack/legacy/plugins/siem/public/components/paginated_table/__snapshots__/index.test.tsx.snap @@ -167,16 +167,16 @@ exports[`Paginated Table Component rendering it renders the default load more ta "euiColorPrimary": "#1ba9f5", "euiColorSecondary": "#7de2d1", "euiColorSuccess": "#7de2d1", - "euiColorVis0": "#00b3a4", - "euiColorVis1": "#3185fc", - "euiColorVis2": "#db1374", - "euiColorVis3": "#490092", - "euiColorVis4": "#feb6db", - "euiColorVis5": "#e6c220", - "euiColorVis6": "#bfa180", - "euiColorVis7": "#f98510", - "euiColorVis8": "#461a0a", - "euiColorVis9": "#920000", + "euiColorVis0": "#5bbaa0", + "euiColorVis1": "#6092c0", + "euiColorVis2": "#d36086", + "euiColorVis3": "#9170b8", + "euiColorVis4": "#eeafcf", + "euiColorVis5": "#fae181", + "euiColorVis6": "#cdbd9d", + "euiColorVis7": "#f19f58", + "euiColorVis8": "#b46f5f", + "euiColorVis9": "#e7664c", "euiColorWarning": "#ffce7a", "euiContextMenuWidth": "256px", "euiControlBarBackground": "#000000", @@ -351,15 +351,17 @@ exports[`Paginated Table Component rendering it renders the default load more ta "warning": "#ffce7a", }, "euiSuggestItemColors": Object { - "tint0": "#00b3a4", - "tint1": "#3185fc", - "tint2": "#db1374", - "tint3": "#490092", - "tint4": "#e6c220", - "tint5": "#f98510", - "tint6": "#461a0a", - "tint7": "#920000", - "tint8": "#98a2b3", + "tint0": "#5bbaa0", + "tint1": "#6092c0", + "tint10": "#98a2b3", + "tint2": "#d36086", + "tint3": "#9170b8", + "tint4": "#eeafcf", + "tint5": "#fae181", + "tint6": "#cdbd9d", + "tint7": "#f19f58", + "tint8": "#b46f5f", + "tint9": "#e7664c", }, "euiSuperDatePickerButtonWidth": "118px", "euiSuperDatePickerWidth": "480px", @@ -505,11 +507,11 @@ exports[`Paginated Table Component rendering it renders the default load more ta "tokenTypes": Object { "tokenTint01": "#1ba9f5", "tokenTint02": "#f990c0", - "tokenTint03": "#490092", - "tokenTint04": "#f98510", - "tokenTint05": "#3185fc", + "tokenTint03": "#9170b8", + "tokenTint04": "#f19f58", + "tokenTint05": "#6092c0", "tokenTint06": "#e6c220", - "tokenTint07": "#00b3a4", + "tokenTint07": "#5bbaa0", "tokenTint08": "#920000", "tokenTint09": "#ff00ff", "tokenTint10": "#26ab00", diff --git a/x-pack/legacy/plugins/spaces/public/management/components/confirm_delete_modal/__snapshots__/confirm_delete_modal.test.tsx.snap b/x-pack/legacy/plugins/spaces/public/management/components/confirm_delete_modal/__snapshots__/confirm_delete_modal.test.tsx.snap index db9913ea7f072..8930dedfa0035 100644 --- a/x-pack/legacy/plugins/spaces/public/management/components/confirm_delete_modal/__snapshots__/confirm_delete_modal.test.tsx.snap +++ b/x-pack/legacy/plugins/spaces/public/management/components/confirm_delete_modal/__snapshots__/confirm_delete_modal.test.tsx.snap @@ -56,10 +56,7 @@ exports[`ConfirmDeleteModal renders as expected 1`] = ` labelType="label" > diff --git a/x-pack/legacy/plugins/spaces/public/management/edit_space/customize_space/__snapshots__/space_identifier.test.tsx.snap b/x-pack/legacy/plugins/spaces/public/management/edit_space/customize_space/__snapshots__/space_identifier.test.tsx.snap index 15fd1ae81a347..2aec970def9df 100644 --- a/x-pack/legacy/plugins/spaces/public/management/edit_space/customize_space/__snapshots__/space_identifier.test.tsx.snap +++ b/x-pack/legacy/plugins/spaces/public/management/edit_space/customize_space/__snapshots__/space_identifier.test.tsx.snap @@ -49,10 +49,8 @@ exports[`renders without crashing 1`] = ` labelType="label" > @@ -140,7 +141,7 @@ Array [ } > Minimal initialization 1`] = ` labelType="label" > diff --git a/x-pack/legacy/plugins/transform/public/app/sections/create_transform/components/group_by_list/__snapshots__/popover_form.test.tsx.snap b/x-pack/legacy/plugins/transform/public/app/sections/create_transform/components/group_by_list/__snapshots__/popover_form.test.tsx.snap index 01114e3b9cfa3..ba53bb2da5716 100644 --- a/x-pack/legacy/plugins/transform/public/app/sections/create_transform/components/group_by_list/__snapshots__/popover_form.test.tsx.snap +++ b/x-pack/legacy/plugins/transform/public/app/sections/create_transform/components/group_by_list/__snapshots__/popover_form.test.tsx.snap @@ -21,11 +21,8 @@ exports[`Transform: Group By Minimal initialization 1`] = ` labelType="label" > @@ -41,10 +38,6 @@ exports[`Transform: Group By Minimal initialization 1`] = ` labelType="label" > { // expected. test('render', () => { expect(shallowWithIntl()).toMatchInlineSnapshot(` - -`); + "hidePerPageOptions": true, + "pageIndex": 0, + "pageSize": 10, + "pageSizeOptions": Array [], + "totalItemCount": 3, + } + } + responsive={true} + sorting={ + Object { + "sort": Object { + "direction": "asc", + "field": "index", + }, + } + } + tableLayout="fixed" + /> + `); }); }); diff --git a/x-pack/legacy/plugins/uptime/public/components/functional/filter_group/__tests__/__snapshots__/filter_popover.test.tsx.snap b/x-pack/legacy/plugins/uptime/public/components/functional/filter_group/__tests__/__snapshots__/filter_popover.test.tsx.snap index 0e6ea3662b97e..af1ed12e5e811 100644 --- a/x-pack/legacy/plugins/uptime/public/components/functional/filter_group/__tests__/__snapshots__/filter_popover.test.tsx.snap +++ b/x-pack/legacy/plugins/uptime/public/components/functional/filter_group/__tests__/__snapshots__/filter_popover.test.tsx.snap @@ -29,6 +29,7 @@ exports[`FilterPopover component does not show item list when loading 1`] = ` disabled={false} fullWidth={false} incremental={false} + isClearable={true} isLoading={false} onSearch={[Function]} placeholder="Loading..." @@ -66,6 +67,7 @@ exports[`FilterPopover component renders without errors for valid props 1`] = ` disabled={false} fullWidth={false} incremental={false} + isClearable={true} isLoading={false} onSearch={[Function]} placeholder="Search bar" diff --git a/x-pack/legacy/plugins/uptime/public/components/functional/monitor_list/__tests__/__snapshots__/monitor_list.test.tsx.snap b/x-pack/legacy/plugins/uptime/public/components/functional/monitor_list/__tests__/__snapshots__/monitor_list.test.tsx.snap index dc98878f6fe08..e32771faf5912 100644 --- a/x-pack/legacy/plugins/uptime/public/components/functional/monitor_list/__tests__/__snapshots__/monitor_list.test.tsx.snap +++ b/x-pack/legacy/plugins/uptime/public/components/functional/monitor_list/__tests__/__snapshots__/monitor_list.test.tsx.snap @@ -63,6 +63,7 @@ exports[`MonitorList component renders a no items message when no data is provid loading={false} noItemsMessage="No uptime monitors found" responsive={true} + tableLayout="fixed" /> diff --git a/x-pack/package.json b/x-pack/package.json index 5951ac43241be..61cb04de49386 100644 --- a/x-pack/package.json +++ b/x-pack/package.json @@ -179,7 +179,7 @@ "@elastic/apm-rum-react": "^0.3.2", "@elastic/datemath": "5.0.2", "@elastic/ems-client": "1.0.5", - "@elastic/eui": "17.3.1", + "@elastic/eui": "18.0.0", "@elastic/filesaver": "1.1.2", "@elastic/maki": "6.1.0", "@elastic/node-crypto": "^1.0.0", diff --git a/x-pack/plugins/security/public/nav_control/nav_control_service.test.ts b/x-pack/plugins/security/public/nav_control/nav_control_service.test.ts index a9a89ee05f561..a73ffcc51a301 100644 --- a/x-pack/plugins/security/public/nav_control/nav_control_service.test.ts +++ b/x-pack/plugins/security/public/nav_control/nav_control_service.test.ts @@ -73,7 +73,7 @@ describe('SecurityNavControlService', () => {
Date: Tue, 14 Jan 2020 11:35:35 -0700 Subject: [PATCH 119/139] [kbn/ui-shared-deps] include polyfills, required by some deps (#54667) * [kbn/ui-shared-deps] include polyfills, required by some deps * remove unnecessary dep * replace abort-controller for server side use Co-authored-by: Elastic Machine --- package.json | 1 - packages/kbn-ui-shared-deps/entry.js | 3 +++ packages/kbn-ui-shared-deps/package.json | 8 +++++- packages/kbn-ui-shared-deps/polyfills.js | 26 +++++++++++++++++++ .../vendor/childnode_remove_polyfill.js | 19 +------------- .../tests_bundle/tests_entry_template.js | 9 ------- .../ui/ui_bundles/app_entry_template.js | 8 ------ 7 files changed, 37 insertions(+), 37 deletions(-) create mode 100644 packages/kbn-ui-shared-deps/polyfills.js rename webpackShims/childnode-remove-polyfill.js => packages/kbn-ui-shared-deps/vendor/childnode_remove_polyfill.js (68%) diff --git a/package.json b/package.json index 7a8596da9d377..a623b656ec9a1 100644 --- a/package.json +++ b/package.json @@ -163,7 +163,6 @@ "compare-versions": "3.5.1", "core-js": "^3.2.1", "css-loader": "2.1.1", - "custom-event-polyfill": "^0.3.0", "d3": "3.5.17", "d3-cloud": "1.2.5", "deep-freeze-strict": "^1.1.1", diff --git a/packages/kbn-ui-shared-deps/entry.js b/packages/kbn-ui-shared-deps/entry.js index 250abd162f91d..7a15c3bb742c0 100644 --- a/packages/kbn-ui-shared-deps/entry.js +++ b/packages/kbn-ui-shared-deps/entry.js @@ -17,6 +17,9 @@ * under the License. */ +// import global polyfills before everything else +require('./polyfills'); + // must load before angular export const Jquery = require('jquery'); window.$ = window.jQuery = Jquery; diff --git a/packages/kbn-ui-shared-deps/package.json b/packages/kbn-ui-shared-deps/package.json index 2e62eb3504aca..c9434f3ec1c38 100644 --- a/packages/kbn-ui-shared-deps/package.json +++ b/packages/kbn-ui-shared-deps/package.json @@ -13,8 +13,11 @@ "@elastic/charts": "^16.1.0", "@kbn/dev-utils": "1.0.0", "@yarnpkg/lockfile": "^1.1.0", + "abortcontroller-polyfill": "^1.3.0", "angular": "^1.7.9", + "core-js": "^3.2.1", "css-loader": "^2.1.1", + "custom-event-polyfill": "^0.3.0", "del": "^5.1.0", "jquery": "^3.4.1", "mini-css-extract-plugin": "0.8.0", @@ -24,6 +27,9 @@ "react-intl": "^2.8.0", "react": "^16.12.0", "read-pkg": "^5.2.0", - "webpack": "4.41.0" + "regenerator-runtime": "^0.13.3", + "symbol-observable": "^1.2.0", + "webpack": "4.41.0", + "whatwg-fetch": "^3.0.0" } } \ No newline at end of file diff --git a/packages/kbn-ui-shared-deps/polyfills.js b/packages/kbn-ui-shared-deps/polyfills.js new file mode 100644 index 0000000000000..d2305d643e4d2 --- /dev/null +++ b/packages/kbn-ui-shared-deps/polyfills.js @@ -0,0 +1,26 @@ +/* + * Licensed to Elasticsearch B.V. under one or more contributor + * license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright + * ownership. Elasticsearch B.V. licenses this file to you under + * the Apache License, Version 2.0 (the "License"); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +require('core-js/stable'); +require('regenerator-runtime/runtime'); +require('custom-event-polyfill'); +require('whatwg-fetch'); +require('abortcontroller-polyfill/dist/polyfill-patch-fetch'); +require('./vendor/childnode_remove_polyfill'); +require('symbol-observable'); diff --git a/webpackShims/childnode-remove-polyfill.js b/packages/kbn-ui-shared-deps/vendor/childnode_remove_polyfill.js similarity index 68% rename from webpackShims/childnode-remove-polyfill.js rename to packages/kbn-ui-shared-deps/vendor/childnode_remove_polyfill.js index 26c21d1674b07..d8818fe809ccb 100644 --- a/webpackShims/childnode-remove-polyfill.js +++ b/packages/kbn-ui-shared-deps/vendor/childnode_remove_polyfill.js @@ -1,21 +1,4 @@ -/* - * Licensed to Elasticsearch B.V. under one or more contributor - * license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright - * ownership. Elasticsearch B.V. licenses this file to you under - * the Apache License, Version 2.0 (the "License"); you may - * not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, - * software distributed under the License is distributed on an - * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY - * KIND, either express or implied. See the License for the - * specific language governing permissions and limitations - * under the License. - */ +/* eslint-disable @kbn/eslint/require-license-header */ /* @notice * This product bundles childnode-remove which is available under a diff --git a/src/legacy/core_plugins/tests_bundle/tests_entry_template.js b/src/legacy/core_plugins/tests_bundle/tests_entry_template.js index 02b1f5fec9c19..2f8a2264530d5 100644 --- a/src/legacy/core_plugins/tests_bundle/tests_entry_template.js +++ b/src/legacy/core_plugins/tests_bundle/tests_entry_template.js @@ -29,16 +29,7 @@ export const createTestEntryTemplate = defaultUiSettings => bundle => ` * */ -// import global polyfills before everything else -import 'core-js/stable'; -import 'regenerator-runtime/runtime'; -import 'custom-event-polyfill'; -import 'whatwg-fetch'; -import 'abortcontroller-polyfill'; -import 'childnode-remove-polyfill'; import fetchMock from 'fetch-mock/es5/client'; -import Symbol_observable from 'symbol-observable'; - import { CoreSystem } from '__kibanaCore__'; // Fake uiCapabilities returned to Core in browser tests diff --git a/src/legacy/ui/ui_bundles/app_entry_template.js b/src/legacy/ui/ui_bundles/app_entry_template.js index f0ca97f473324..a1c3a153a196c 100644 --- a/src/legacy/ui/ui_bundles/app_entry_template.js +++ b/src/legacy/ui/ui_bundles/app_entry_template.js @@ -28,14 +28,6 @@ export const appEntryTemplate = bundle => ` * context: ${bundle.getContext()} */ -// import global polyfills -import Symbol_observable from 'symbol-observable'; -import 'core-js/stable'; -import 'regenerator-runtime/runtime'; -import 'custom-event-polyfill'; -import 'whatwg-fetch'; -import 'abortcontroller-polyfill'; -import 'childnode-remove-polyfill'; ${apmImport()} import { i18n } from '@kbn/i18n'; import { CoreSystem } from '__kibanaCore__' From 573885538950d1d350c0c12dc8a50097222edef1 Mon Sep 17 00:00:00 2001 From: Tiago Costa Date: Tue, 14 Jan 2020 18:44:24 +0000 Subject: [PATCH 120/139] fix(NA): recursive delete function on watch cache directory (#54758) --- src/optimize/watch/watch_cache.ts | 34 +++++++++++++++---------------- 1 file changed, 16 insertions(+), 18 deletions(-) diff --git a/src/optimize/watch/watch_cache.ts b/src/optimize/watch/watch_cache.ts index 15957210b3d43..b6784c1734a17 100644 --- a/src/optimize/watch/watch_cache.ts +++ b/src/optimize/watch/watch_cache.ts @@ -170,22 +170,20 @@ export class WatchCache { * very large folders (with 84K+ files) cause a stack overflow. */ async function recursiveDelete(directory: string) { - const entries = await readdirAsync(directory, { withFileTypes: true }); - await Promise.all( - entries.map(entry => { - const absolutePath = path.join(directory, entry.name); - const result = entry.isDirectory() - ? recursiveDelete(absolutePath) - : unlinkAsync(absolutePath); - - // Ignore errors, if the file or directory doesn't exist. - return result.catch(e => { - if (e.code !== 'ENOENT') { - throw e; - } - }); - }) - ); - - return rmdirAsync(directory); + try { + const entries = await readdirAsync(directory, { withFileTypes: true }); + + await Promise.all( + entries.map(entry => { + const absolutePath = path.join(directory, entry.name); + return entry.isDirectory() ? recursiveDelete(absolutePath) : unlinkAsync(absolutePath); + }) + ); + + return rmdirAsync(directory); + } catch (error) { + if (error.code !== 'ENOENT') { + throw error; + } + } } From 1b076171f3c6171c0abebda6f3887568823efb6a Mon Sep 17 00:00:00 2001 From: Dima Arnautov Date: Tue, 14 Jan 2020 19:52:58 +0100 Subject: [PATCH 121/139] [ML] Data Visualizer redesign (#54358) * [ML] change basic page structure * [ML] adjust search panel * [ML] adjust fields_panel.tsx * [ML] card icon styles * [ML] styles * [ML] adjust actions_panel.tsx * Update styling of panels, spacing * [ML] change basic page structure * [ML] adjust search panel * [ML] adjust fields_panel.tsx * [ML] card icon styles * [ML] styles * [ML] adjust actions_panel.tsx * [ML] fix i18n * [ML] fix styles * [ML] adjust top values styles * [ML] remove conflicts artifacts * Use EuiBorderColor * [ML] fix i18n * [ML] fix i18n * [ML] fix counters * [ML] fixed width for sample size select * [ML] fix layout for file viz * [ML] fix empty cards rendering * Update text styling and spacing * [ML] fix field stats card * [ML] fix counter for showAllFields * [ML] reset title for the badge * [ML] boolean_content.tsx with the bar chart * [ML] fix counters Co-authored-by: DeFazio Co-authored-by: Elastic Machine --- .../display_value/display_value.tsx | 4 +- .../field_title_bar/_field_title_bar.scss | 14 +- .../field_type_icon/_field_type_icon.scss | 14 +- .../fields_stats/_field_stats_card.scss | 74 ++++-- .../fields_stats/field_stats_card.js | 229 +++++++++--------- .../components/fields_stats/fields_stats.js | 11 +- .../actions_panel/actions_panel.tsx | 12 +- .../field_data_card/_field_data_card.scss | 70 ++++-- .../content_types/boolean_content.tsx | 123 +++++----- .../content_types/date_content.tsx | 26 +- .../content_types/geo_point_content.tsx | 46 ++-- .../content_types/ip_content.tsx | 44 ++-- .../content_types/keyword_content.tsx | 59 +++-- .../content_types/not_in_docs_content.tsx | 30 +-- .../content_types/number_content.tsx | 133 +++++----- .../content_types/other_content.tsx | 42 ++-- .../examples_list/examples_list.tsx | 18 +- .../field_data_card/field_data_card.tsx | 23 +- .../field_data_card/top_values/top_values.tsx | 6 +- .../components/fields_panel/fields_panel.tsx | 126 +++++----- .../components/search_panel/search_panel.tsx | 173 ++++++------- .../datavisualizer/index_based/page.tsx | 148 ++++++----- .../translations/translations/ja-JP.json | 5 - .../translations/translations/zh-CN.json | 5 - 24 files changed, 803 insertions(+), 632 deletions(-) diff --git a/x-pack/legacy/plugins/ml/public/application/components/display_value/display_value.tsx b/x-pack/legacy/plugins/ml/public/application/components/display_value/display_value.tsx index cfe3d09a16320..36225cb839704 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/display_value/display_value.tsx +++ b/x-pack/legacy/plugins/ml/public/application/components/display_value/display_value.tsx @@ -13,11 +13,11 @@ export const DisplayValue: FC<{ value: any }> = ({ value }) => { const length = String(value).length; if (length <= MAX_CHARS) { - return value; + return {value}; } else { return ( - {value} + {value} ); } diff --git a/x-pack/legacy/plugins/ml/public/application/components/field_title_bar/_field_title_bar.scss b/x-pack/legacy/plugins/ml/public/application/components/field_title_bar/_field_title_bar.scss index 0fa087deacf91..75118266d45db 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/field_title_bar/_field_title_bar.scss +++ b/x-pack/legacy/plugins/ml/public/application/components/field_title_bar/_field_title_bar.scss @@ -1,9 +1,14 @@ .ml-field-title-bar { - color: $euiColorEmptyShade; - @include euiFontSizeL; + @include euiFontSizeM; + font-family: Roboto Mono, serif; + font-style: normal; + font-weight: bold; + font-size: $euiFontSizeS; + border-radius: $euiBorderRadius $euiBorderRadius 0 0; + padding: $euiSizeXS; + margin: (-$euiSize) (-$euiSize) 0 (-$euiSize); + border-top: 3px solid; text-align: center; - border-radius: $euiBorderRadius $euiBorderRadius 0px 0px; - padding-bottom: $euiSizeXS/2; .field-type-icon { vertical-align: middle; @@ -18,5 +23,6 @@ padding-right: $euiSizeS; max-width: 290px; // SASSTODO: Calculate value display: inline-block; + margin-left: $euiSizeS; } } diff --git a/x-pack/legacy/plugins/ml/public/application/components/field_type_icon/_field_type_icon.scss b/x-pack/legacy/plugins/ml/public/application/components/field_type_icon/_field_type_icon.scss index ba318057bcae1..864df28f2c055 100644 --- a/x-pack/legacy/plugins/ml/public/application/components/field_type_icon/_field_type_icon.scss +++ b/x-pack/legacy/plugins/ml/public/application/components/field_type_icon/_field_type_icon.scss @@ -1,8 +1,18 @@ +$icon-size: 20px; + .field-type-icon-container { - display: inline !important; + display: inline-block !important; + vertical-align: middle; + border: 1px solid; + border-radius: 4px; + width: $icon-size; + height: $icon-size; + line-height: $icon-size;; + text-align: center; .field-type-icon { - padding-right: $euiSizeXS / 2; + padding: 0; display: inline !important; + vertical-align: initial; } } diff --git a/x-pack/legacy/plugins/ml/public/application/datavisualizer/file_based/components/fields_stats/_field_stats_card.scss b/x-pack/legacy/plugins/ml/public/application/datavisualizer/file_based/components/fields_stats/_field_stats_card.scss index 39a87ece68ac9..2702817a55749 100644 --- a/x-pack/legacy/plugins/ml/public/application/datavisualizer/file_based/components/fields_stats/_field_stats_card.scss +++ b/x-pack/legacy/plugins/ml/public/application/datavisualizer/file_based/components/fields_stats/_field_stats_card.scss @@ -8,56 +8,96 @@ // These styles should all be removed once the file data visualizer is using // the same field_data_card component as the index based data visualizer. height: 408px; + box-shadow: none; + border-color: $euiBorderColor; + // Note the names of these styles need to match the type of the field they are displaying. .boolean { - background-color: #e6c220; + color: $euiColorVis5; + border-color: $euiColorVis5; + + .field-type-icon-container { + background-color: rgba($euiColorVis5, 0.5); + } } .date { - background-color: #f98510; + color: $euiColorVis7; + border-color: $euiColorVis7; + + .field-type-icon-container { + background-color: rgba($euiColorVis7, 0.5); + } } .document_count { - background-color: #db1374; + color: $euiColorVis2; + border-color: $euiColorVis2; + + .field-type-icon-container { + background-color: rgba($euiColorVis2, 0.5); + } } .geo_point { - background-color: #461a0a; + color: $euiColorVis8; + border-color: $euiColorVis8; + + .field-type-icon-container { + background-color: rgba($euiColorVis8, 0.5); + } } .ip { - background-color: #490092; + color: $euiColorVis3; + border-color: $euiColorVis3; + + .field-type-icon-container { + background-color: rgba($euiColorVis3, 0.5); + } } .keyword { - background-color: #00b3a4; + color: $euiColorVis0; + border-color: $euiColorVis0; + + .field-type-icon-container { + background-color: rgba($euiColorVis0, 0.5); + } } .number { - background-color: #3185fc; + color: $euiColorVis1; + border-color: $euiColorVis1; + + .field-type-icon-container { + background-color: rgba($euiColorVis1, 0.5); + } } .text { - background-color: #920000; + color: $euiColorVis9; + border-color: $euiColorVis9; + + .field-type-icon-container { + background-color: rgba($euiColorVis9, 0.5); + } } .type-other, .unknown { - background-color: #bfa180; + color: $euiColorVis6; + border-color: $euiColorVis6; + + .field-type-icon-container { + background-color: rgba($euiColorVis6, 0.5); + } } // Use euiPanel styling @include euiPanel($selector: '.card-contents'); - .card-contents { - height: 378px; - line-height: 21px; - border-radius: 0px 0px $euiBorderRadius $euiBorderRadius; - overflow: hidden; - } - .stats { - padding: 10px 10px 0px 10px; text-align: center; } diff --git a/x-pack/legacy/plugins/ml/public/application/datavisualizer/file_based/components/fields_stats/field_stats_card.js b/x-pack/legacy/plugins/ml/public/application/datavisualizer/file_based/components/fields_stats/field_stats_card.js index b1167266a5d29..988fb653dd1ad 100644 --- a/x-pack/legacy/plugins/ml/public/application/datavisualizer/file_based/components/fields_stats/field_stats_card.js +++ b/x-pack/legacy/plugins/ml/public/application/datavisualizer/file_based/components/fields_stats/field_stats_card.js @@ -5,7 +5,7 @@ */ import React from 'react'; -import { EuiSpacer } from '@elastic/eui'; +import { EuiSpacer, EuiPanel, EuiFlexGroup, EuiFlexItem, EuiText, EuiProgress } from '@elastic/eui'; import { FormattedMessage } from '@kbn/i18n/react'; import { FieldTypeIcon } from '../../../../components/field_type_icon'; @@ -25,129 +25,136 @@ export function FieldStatsCard({ field }) { } return ( - -
-
-
- -
- {field.name} -
+ +
+
+ +
+ {field.name}
+
-
- {field.count > 0 && ( - -
-
-